Added cookie support for auth on ESPHome widget
This commit is contained in:
parent
2aa7a3898b
commit
4c35872064
@ -16,4 +16,5 @@ To group both `offline` and `unknown` devices together, users should use the `of
|
|||||||
widget:
|
widget:
|
||||||
type: esphome
|
type: esphome
|
||||||
url: http://esphome.host.or.ip:port
|
url: http://esphome.host.or.ip:port
|
||||||
|
cookie: authenticated=MYCOOKIE # Only for auth enabled, you can get the cookie value watching at a request from the frontend
|
||||||
```
|
```
|
||||||
|
|||||||
68
src/widgets/esphome/proxy.js
Normal file
68
src/widgets/esphome/proxy.js
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
import getServiceWidget from "utils/config/service-helpers";
|
||||||
|
import { formatApiCall, sanitizeErrorURL } from "utils/proxy/api-helpers";
|
||||||
|
import validateWidgetData from "utils/proxy/validate-widget-data";
|
||||||
|
import { httpProxy } from "utils/proxy/http";
|
||||||
|
import createLogger from "utils/logger";
|
||||||
|
import widgets from "widgets/widgets";
|
||||||
|
|
||||||
|
const logger = createLogger("espHomeProxyHandler");
|
||||||
|
|
||||||
|
export default async function espHomeProxyHandler(req, res, map) {
|
||||||
|
|
||||||
|
const { group, service, endpoint } = req.query;
|
||||||
|
|
||||||
|
if (group && service) {
|
||||||
|
const widget = await getServiceWidget(group, service);
|
||||||
|
|
||||||
|
if (widget) {
|
||||||
|
const url = new URL(
|
||||||
|
formatApiCall(widgets[widget.type].api, { endpoint, ...widget }).replace(/(?<=\?.*)\?/g, "&"),
|
||||||
|
);
|
||||||
|
|
||||||
|
const params = {
|
||||||
|
method: widget.method ?? req.method,
|
||||||
|
headers: widget.headers.cookie ? { "Cookie": widget.headers.cookie } : {}
|
||||||
|
};
|
||||||
|
|
||||||
|
const [status, contentType, data] = await httpProxy(url, params);
|
||||||
|
|
||||||
|
let resultData = data;
|
||||||
|
|
||||||
|
if (resultData.error?.url) {
|
||||||
|
resultData.error.url = sanitizeErrorURL(url);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (status === 200) {
|
||||||
|
if (!validateWidgetData(widget, endpoint, resultData)) {
|
||||||
|
return res
|
||||||
|
.status(status)
|
||||||
|
.json({ error: { message: "Invalid data", url: sanitizeErrorURL(url), data: resultData } });
|
||||||
|
}
|
||||||
|
if (map) resultData = map(resultData);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (contentType) res.setHeader("Content-Type", contentType);
|
||||||
|
|
||||||
|
if (status === 204 || status === 304) {
|
||||||
|
return res.status(status).end();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (status >= 400) {
|
||||||
|
logger.debug(
|
||||||
|
"HTTP Error %d calling %s//%s%s%s...",
|
||||||
|
status,
|
||||||
|
url.protocol,
|
||||||
|
url.hostname,
|
||||||
|
url.port ? `:${url.port}` : "",
|
||||||
|
url.pathname,
|
||||||
|
);
|
||||||
|
return res.status(status).json({ error: { message: "HTTP Error", url: sanitizeErrorURL(url), resultData } });
|
||||||
|
}
|
||||||
|
|
||||||
|
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" });
|
||||||
|
}
|
||||||
@ -1,8 +1,8 @@
|
|||||||
import genericProxyHandler from "utils/proxy/handlers/generic";
|
import espHomeProxyHandler from "./proxy";
|
||||||
|
|
||||||
const widget = {
|
const widget = {
|
||||||
api: "{url}/ping",
|
api: "{url}/ping",
|
||||||
proxyHandler: genericProxyHandler,
|
proxyHandler: espHomeProxyHandler,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default widget;
|
export default widget;
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user