75 lines
2.6 KiB
TypeScript
75 lines
2.6 KiB
TypeScript
// services/fetchAnalogInputsHistory.ts
|
|
|
|
import { AnalogInputsHistoryEntry } from "@/redux/slices/analogInputs/analogInputsHistorySlice";
|
|
|
|
export async function fetchAnalogInputsHistory(
|
|
eingang: number,
|
|
zeitraum: string,
|
|
vonDatum?: string,
|
|
bisDatum?: string
|
|
): Promise<{ daten: AnalogInputsHistoryEntry[] }> {
|
|
// Umgebung erkennen
|
|
const isDev =
|
|
window.location.hostname === "localhost" ||
|
|
window.location.hostname === "127.0.0.1";
|
|
|
|
if (isDev) {
|
|
// Entwicklung: API-Route verwenden
|
|
const url =
|
|
`/api/cpl/getAnalogInputsHistory?eingang=${eingang}&zeitraum=${zeitraum}` +
|
|
(vonDatum ? `&von=${vonDatum}` : "") +
|
|
(bisDatum ? `&bis=${bisDatum}` : "");
|
|
|
|
const res = await fetch(url);
|
|
if (!res.ok) {
|
|
throw new Error("Serverantwort war nicht erfolgreich");
|
|
}
|
|
const json = await res.json();
|
|
return { daten: json.daten };
|
|
} else {
|
|
// Produktion: CPL-Webserver direkt abfragen
|
|
// Erwartetes Format: /CPL?seite.ACP&DIA1=YYYY;MM;DD;YYYY;MM;DD;Eingang;Zeitraum
|
|
// Annahme: vonDatum/bisDatum sind im Format YYYY-MM-DD
|
|
if (!vonDatum || !bisDatum) {
|
|
throw new Error("vonDatum und bisDatum sind erforderlich in Produktion");
|
|
}
|
|
const [vonJahr, vonMonat, vonTag] = vonDatum.split("-");
|
|
const [bisJahr, bisMonat, bisTag] = bisDatum.split("-");
|
|
// CPL-Eingang: 1-8, Zeitraum: 1=Stündlich, 2=Täglich, 0=Alle Messwerte
|
|
let cplZeitraum = 1;
|
|
if (zeitraum === "DIA2") cplZeitraum = 2;
|
|
if (zeitraum === "DIA0") cplZeitraum = 0;
|
|
// Beispiel: /CPL?seite.ACP&DIA1=2025;01;01;2025;07;31;2;4
|
|
const url = `${window.location.origin}/CPL?seite.ACP&DIA1=${vonJahr};${vonMonat};${vonTag};${bisJahr};${bisMonat};${bisTag};${eingang};${cplZeitraum}`;
|
|
const res = await fetch(url);
|
|
if (!res.ok) {
|
|
throw new Error("Fehler bei CPL-Server: " + res.status);
|
|
}
|
|
const json = await res.json();
|
|
// Die Struktur der Antwort kann ggf. angepasst werden
|
|
return { daten: json };
|
|
}
|
|
}
|
|
|
|
/* // ⬇️ PRODUKTION: direkt vom CPL-Webserver holen
|
|
for (let i = 0; i < 8; i++) {
|
|
const inputNumber = i + 1;
|
|
const sourceId = 99 + inputNumber;
|
|
|
|
try {
|
|
const url = `${window.location.origin}/CPL?Service/empty.acp&DIA0=${fromDate};${toDate};${sourceId};1`;
|
|
const response = await fetch(url);
|
|
if (!response.ok)
|
|
throw new Error(`Fehler bei AE${inputNumber}: ${response.status}`);
|
|
const data = await response.json();
|
|
result[sourceId] = data;
|
|
} catch (error) {
|
|
console.error(`❌ Fehler beim Laden von AE${inputNumber}:`, error);
|
|
result[sourceId] = [];
|
|
}
|
|
}
|
|
|
|
return result;
|
|
}
|
|
*/
|