- fixed empty password not working

- Airbnb style guide
pull/496/head
stuffinator 2 years ago
parent 69786600b1
commit 1fd9686e41

@ -1,10 +1,10 @@
import cache from "memory-cache"; import cache from 'memory-cache';
import getServiceWidget from "utils/config/service-helpers"; import getServiceWidget from 'utils/config/service-helpers';
import { formatApiCall } from "utils/proxy/api-helpers"; import { formatApiCall } from 'utils/proxy/api-helpers';
import widgets from "widgets/widgets"; import widgets from 'widgets/widgets';
import createLogger from "utils/logger"; import createLogger from 'utils/logger';
import { httpProxy } from "utils/proxy/http"; import { httpProxy } from 'utils/proxy/http';
const proxyName = 'pyloadProxyHandler'; const proxyName = 'pyloadProxyHandler';
const logger = createLogger(proxyName); const logger = createLogger(proxyName);
@ -12,24 +12,23 @@ const sessionCacheKey = `${proxyName}__sessionId`;
async function fetchFromPyloadAPI(url, sessionId, params) { async function fetchFromPyloadAPI(url, sessionId, params) {
const options = { const options = {
method: "POST", body: params
? Object.keys(params)
.map((prop) => `${prop}=${params[prop]}`)
.join('&')
: `session=${sessionId}`,
method: 'POST',
headers: { headers: {
"Content-Type": "application/x-www-form-urlencoded", 'Content-Type': 'application/x-www-form-urlencoded',
}, },
}; };
if (params) {
options.body = Object.keys(params).map(k => `${k}=${params[k]}`).join('&');
} else {
options.body = `session=${sessionId}`;
}
// eslint-disable-next-line no-unused-vars // eslint-disable-next-line no-unused-vars
const [status, contentType, data] = await httpProxy(url, options); const [status, contentType, data] = await httpProxy(url, options);
return [status, JSON.parse(Buffer.from(data).toString())]; return [status, JSON.parse(Buffer.from(data).toString())];
} }
async function login(loginUrl, username, password) { async function login(loginUrl, username, password = '') {
const [status, sessionId] = await fetchFromPyloadAPI(loginUrl, null, { username, password }); const [status, sessionId] = await fetchFromPyloadAPI(loginUrl, null, { username, password });
if (status !== 200) { if (status !== 200) {
throw new Error(`HTTP error ${status} logging into Pyload API, returned: ${sessionId}`); throw new Error(`HTTP error ${status} logging into Pyload API, returned: ${sessionId}`);
@ -45,26 +44,21 @@ export default async function pyloadProxyHandler(req, res) {
try { try {
if (group && service) { if (group && service) {
const widget = await getServiceWidget(group, service); const widget = await getServiceWidget(group, service);
if (widget) { if (widget) {
const url = new URL(formatApiCall(widgets[widget.type].api, { endpoint, ...widget })); const url = new URL(formatApiCall(widgets[widget.type].api, { endpoint, ...widget }));
const loginUrl = `${widget.url}/api/login`; const loginUrl = `${widget.url}/api/login`;
let sessionId = cache.get(sessionCacheKey);
if (!sessionId) { let sessionId = cache.get(sessionCacheKey) ?? await login(loginUrl, widget.username, widget.password);
sessionId = await login(loginUrl, widget.username, widget.password);
}
let [status, data] = await fetchFromPyloadAPI(url, sessionId); let [status, data] = await fetchFromPyloadAPI(url, sessionId);
if (status === 403) { if (status === 403) {
logger.debug("Failed to retrieve data from Pyload API, login and re-try"); logger.debug('Failed to retrieve data from Pyload API, login and re-try');
cache.del(sessionCacheKey); cache.del(sessionCacheKey);
sessionId = await login(loginUrl, widget.username, widget.password); sessionId = await login(loginUrl, widget.username, widget.password);
[status, data] = await fetchFromPyloadAPI(url, sessionId); [status, data] = await fetchFromPyloadAPI(url, sessionId);
} }
if (data?.error || status !== 200) { if (data?.error || status !== 200) {
return res.status(500).send(Buffer.from(data).toString()); return res.status(500).send(Buffer.from(data).toString());
} }
@ -77,5 +71,5 @@ export default async function pyloadProxyHandler(req, res) {
return res.status(500).send(e.toString()); return res.status(500).send(e.toString());
} }
return res.status(400).json({ error: "Invalid proxy service type" }); return res.status(400).json({ error: 'Invalid proxy service type' });
} }

Loading…
Cancel
Save