From 3b8e2b11cea68c2e59156da979c43bb4c77f0c00 Mon Sep 17 00:00:00 2001 From: ISA Date: Fri, 3 Jan 2025 06:39:31 +0100 Subject: [PATCH] =?UTF-8?q?feat:=20API-Proxy=20f=C3=BCr=20GisStationsStatu?= =?UTF-8?q?sDistrict=20hinzugef=C3=BCgt?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Unterstützung für Parameter 'm' (idMap) und 'u' (idUser) zum Abrufen von Statusdaten. - Dynamische URL-Ermittlung basierend auf Anfrage-Headern (Protokoll, Host). - Parameter-Validierung mit Fehlerhinweis, falls Werte fehlen. - Fehlerbehandlung und Debugging-Logs hinzugefügt. - XML-Daten vom Webservice werden direkt an den Client weitergeleitet. --- pages/api/gisStationsStaticDistrict.js | 1 + pages/api/gisStationsStatusDistrict.js | 67 ++++++++++++++++++++++++++ 2 files changed, 68 insertions(+) create mode 100644 pages/api/gisStationsStatusDistrict.js diff --git a/pages/api/gisStationsStaticDistrict.js b/pages/api/gisStationsStaticDistrict.js index e425ee6ef..2f57a0b93 100644 --- a/pages/api/gisStationsStaticDistrict.js +++ b/pages/api/gisStationsStaticDistrict.js @@ -1,3 +1,4 @@ +// pages/api/gisStationsStaticDistrict.js // Proxy für GisStationsStaticDistrict export default async function handler(req, res) { // CORS-Header setzen res.setHeader("Access-Control-Allow-Credentials", true); diff --git a/pages/api/gisStationsStatusDistrict.js b/pages/api/gisStationsStatusDistrict.js new file mode 100644 index 000000000..c4d02fac3 --- /dev/null +++ b/pages/api/gisStationsStatusDistrict.js @@ -0,0 +1,67 @@ +// pages/api/gisStationsStatusDistrict.js +// Proxy für GisStationsStatusDistrict +export default async function handler(req, res) { + // CORS-Header setzen + res.setHeader("Access-Control-Allow-Credentials", true); + res.setHeader("Access-Control-Allow-Origin", "*"); + res.setHeader("Access-Control-Allow-Methods", "GET,POST,OPTIONS"); + res.setHeader("Access-Control-Allow-Headers", "Content-Type, Authorization"); + + // OPTIONS-Preflight-Anfrage sofort beantworten + if (req.method === "OPTIONS") { + res.status(200).end(); + return; + } + + try { + // Parameter aus URL oder Fallback-Werte verwenden + const idMap = req.query.m || req.query.idMap; // 'm' = idMap + const idUser = req.query.u || req.query.idUser; // 'u' = idUser + + // Überprüfung, ob Parameter fehlen + if (!idMap || !idUser) { + res.status(400).json({ + error: "Fehlende Parameter", + message: "Die Parameter 'm' (idMap) und 'u' (idUser) sind erforderlich. Beispiel: ?m=12&u=484", + }); + return; // Beende die Funktion, wenn Parameter fehlen + } + + console.log("idMap:", idMap); // Debugging + console.log("idUser:", idUser); // Debugging + + // Dynamische URL basierend auf der Anfrage + const protocol = req.headers["x-forwarded-proto"] || "http"; // Protokoll ermitteln + const host = req.headers.host.split(":")[0]; // Hostname ohne Port + const serverBaseUrl = `${protocol}://${host}:80`; // Port explizit auf 80 setzen + + console.log("Dynamische Server-URL:", serverBaseUrl); // Debugging + + // Ziel-URL für den Webservice + const targetUrl = `${serverBaseUrl}/talas5/ClientData/WebServiceMap.asmx/GisStationsStatusDistrict?idMap=${idMap}&idUser=${idUser}`; + console.log("Ziel-URL:", targetUrl); // Debugging + + // Daten vom Webservice abrufen + const response = await fetch(targetUrl, { + method: "GET", // GET-Request + headers: { + "Content-Type": "application/xml", // XML als Antwort erwartet + }, + }); + + // Antwort überprüfen + if (!response.ok) { + throw new Error(`Server antwortet mit Status ${response.status}`); + } + + // XML-Antwort als Text auslesen + const xmlText = await response.text(); + console.log("XML-Antwort:", xmlText); // Debugging + + // XML direkt an den Client zurückgeben + res.status(200).send(xmlText); + } catch (error) { + console.error("Fehler beim Abrufen der Daten:", error); + res.status(500).json({ error: "Fehler beim Abrufen der Daten" }); + } +}