60 lines
2.0 KiB
JavaScript
Raw Normal View History

import { formatApiCall } from "utils/api-helpers";
import createLogger from "utils/logger";
import genericProxyHandler from "utils/proxies/generic";
2022-09-25 19:43:47 +03:00
import widgets from "widgets/widgets";
2022-09-25 19:43:47 +03:00
const logger = createLogger("servicesProxy");
export default async function handler(req, res) {
try {
const { type } = req.query;
2022-09-25 19:43:47 +03:00
const widget = widgets[type];
if (!widget) {
logger.debug("Unknown proxy service type: %s", type);
return res.status(403).json({ error: "Unkown proxy service type" });
}
const serviceProxyHandler = widget.proxyHandler || genericProxyHandler;
req.method = "GET";
2022-09-25 19:43:47 +03:00
if (serviceProxyHandler instanceof Function) {
// map opaque endpoints to their actual endpoint
const mapping = widget?.mappings?.[req.query.endpoint];
const mappingParams = mapping.params;
2022-09-25 19:43:47 +03:00
const map = mapping?.map;
const endpoint = mapping?.endpoint;
const endpointProxy = mapping?.proxyHandler || serviceProxyHandler;
req.method = mapping?.method || "GET";
2022-09-25 19:43:47 +03:00
if (!endpoint) {
logger.debug("Unsupported service endpoint: %s", type);
return res.status(403).json({ error: "Unsupported service endpoint" });
}
2022-09-25 19:43:47 +03:00
req.query.endpoint = endpoint;
if (req.query.segments) {
const segments = JSON.parse(req.query.segments);
req.query.endpoint = formatApiCall(endpoint, segments);
}
if (req.query.query) {
const queryParams = JSON.parse(req.query.query);
2022-09-26 00:35:54 +03:00
const query = new URLSearchParams(mappingParams.map((p) => [p, queryParams[p]]));
req.query.endpoint = `${req.query.endpoint}?${query}`;
}
2022-09-25 19:43:47 +03:00
if (endpointProxy instanceof Function) {
return endpointProxy(req, res, map);
}
2022-09-25 19:43:47 +03:00
return serviceProxyHandler(req, res, map);
}
logger.debug("Unknown proxy service type: %s", type);
return res.status(403).json({ error: "Unkown proxy service type" });
2022-09-25 19:43:47 +03:00
} catch (ex) {
logger.error(ex);
return res.status(500).send({ error: "Unexpected error" });
}
}