Refactor basic auth header generation

This commit is contained in:
shamoon
2025-09-04 10:23:43 -07:00
parent 547ef0c4c5
commit 78b73e8166

View File

@@ -8,6 +8,10 @@ import widgets from "widgets/widgets";
const logger = createLogger("credentialedProxyHandler");
function basicAuthHeader(widget) {
return `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`;
}
export default async function credentialedProxyHandler(req, res, map) {
const { group, service, endpoint, index } = req.query;
@@ -61,7 +65,7 @@ export default async function credentialedProxyHandler(req, res, map) {
if (widget.key) {
headers.Authorization = `Bearer ${widget.key}`;
} else {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`;
headers.Authorization = basicAuthHeader(widget);
}
} else if (widget.type === "proxmox") {
headers.Authorization = `PVEAPIToken=${widget.username}=${widget.password}`;
@@ -78,31 +82,31 @@ export default async function credentialedProxyHandler(req, res, map) {
if (widget.key) {
headers["NC-Token"] = `${widget.key}`;
} else {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`;
headers.Authorization = basicAuthHeader(widget);
}
} else if (widget.type === "paperlessngx") {
if (widget.key) {
headers.Authorization = `Token ${widget.key}`;
} else {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`;
headers.Authorization = basicAuthHeader(widget);
}
} else if (widget.type === "azuredevops") {
headers.Authorization = `Basic ${Buffer.from(`$:${widget.key}`).toString("base64")}`;
} else if (widget.type === "glances") {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`;
headers.Authorization = basicAuthHeader(widget);
} else if (widget.type === "plantit") {
headers.Key = `${widget.key}`;
} else if (widget.type === "myspeed") {
headers.Password = `${widget.password}`;
} else if (widget.type === "esphome") {
if (widget.username && widget.password) {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`;
headers.Authorization = basicAuthHeader(widget);
} else if (widget.key) {
headers.Cookie = `authenticated=${widget.key}`;
}
} else if (widget.type === "wgeasy") {
if (widget.username && widget.password) {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`;
headers.Authorization = basicAuthHeader(widget);
} else {
headers.Authorization = widget.password;
}