homepage/src/utils/proxies/generic.js

51 lines
1.5 KiB
JavaScript
Raw Normal View History

2022-09-07 16:53:24 +03:00
import getServiceWidget from "utils/service-helpers";
import { formatApiCall } from "utils/api-helpers";
import { httpProxy } from "utils/http";
import createLogger from "utils/logger";
const logger = createLogger('genericProxyHandler');
2022-09-17 08:32:40 +03:00
export default async function genericProxyHandler(req, res, maps) {
const { group, service, endpoint } = req.query;
if (group && service) {
const widget = await getServiceWidget(group, service);
if (widget) {
const url = new URL(formatApiCall(widget.type, { endpoint, ...widget }));
2022-09-16 14:05:27 +03:00
let headers;
if (widget.username && widget.password) {
headers = {
Authorization: `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`,
};
}
2022-09-11 14:30:28 +03:00
const [status, contentType, data] = await httpProxy(url, {
method: req.method,
2022-09-16 14:05:27 +03:00
headers,
2022-09-11 14:30:28 +03:00
});
let resultData = data;
if ((status === 200) && (maps?.[endpoint])) {
2022-09-17 08:32:40 +03:00
resultData = maps[endpoint](data);
}
if (contentType) res.setHeader("Content-Type", contentType);
2022-09-11 14:30:14 +03:00
if (status === 204 || status === 304) {
return res.status(status).end();
}
if (status >= 400) {
logger.debug("HTTP Error %d calling %s//%s%s...", status, url.protocol, url.hostname, url.pathname);
}
return res.status(status).send(resultData);
}
}
logger.debug("Invalid or missing proxy service type '%s' in group '%s'", service, group);
return res.status(400).json({ error: "Invalid proxy service type" });
}