Files
nodeMap/pages/api/gisStationsStaticDistrict.js
ISA 3b8e2b11ce feat: API-Proxy für GisStationsStatusDistrict hinzugefügt
- 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.
2025-01-03 06:39:31 +01:00

58 lines
2.1 KiB
JavaScript

// 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);
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 || 12; // 'm' = idMap
const idUser = req.query.u || 484; // 'u' = idUser
console.log("idMap:", idMap);
console.log("idUser:", idUser);
// 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/GisStationsStaticDistrict?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" });
}
}