2022-10-30 18:14:02 +01:00
|
|
|
const fs = require("fs");
|
|
|
|
const path = require("path");
|
|
|
|
const Log = require("logger");
|
2023-11-20 08:03:29 +01:00
|
|
|
|
2023-09-13 22:46:17 +02:00
|
|
|
const startUp = new Date();
|
2022-10-30 18:14:02 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the config.
|
|
|
|
* @param {Request} req - the request
|
|
|
|
* @param {Response} res - the result
|
|
|
|
*/
|
2023-12-25 08:17:11 +01:00
|
|
|
function getConfig (req, res) {
|
2022-10-30 18:14:02 +01:00
|
|
|
res.send(config);
|
|
|
|
}
|
|
|
|
|
2023-09-13 22:46:17 +02:00
|
|
|
/**
|
|
|
|
* Gets the startup time.
|
|
|
|
* @param {Request} req - the request
|
|
|
|
* @param {Response} res - the result
|
|
|
|
*/
|
2023-12-25 08:17:11 +01:00
|
|
|
function getStartup (req, res) {
|
2023-09-13 22:46:17 +02:00
|
|
|
res.send(startUp);
|
|
|
|
}
|
|
|
|
|
2022-10-30 18:14:02 +01:00
|
|
|
/**
|
2023-02-20 20:04:40 +01:00
|
|
|
* A method that forwards HTTP Get-methods to the internet to avoid CORS-errors.
|
2022-10-30 18:14:02 +01:00
|
|
|
*
|
|
|
|
* Example input request url: /cors?sendheaders=header1:value1,header2:value2&expectedheaders=header1,header2&url=http://www.test.com/path?param1=value1
|
|
|
|
*
|
|
|
|
* Only the url-param of the input request url is required. It must be the last parameter.
|
|
|
|
* @param {Request} req - the request
|
|
|
|
* @param {Response} res - the result
|
|
|
|
*/
|
2023-12-25 08:17:11 +01:00
|
|
|
async function cors (req, res) {
|
2022-10-30 18:14:02 +01:00
|
|
|
try {
|
|
|
|
const urlRegEx = "url=(.+?)$";
|
2023-02-20 20:04:40 +01:00
|
|
|
let url;
|
2022-10-30 18:14:02 +01:00
|
|
|
|
|
|
|
const match = new RegExp(urlRegEx, "g").exec(req.url);
|
|
|
|
if (!match) {
|
2023-03-19 14:32:23 +01:00
|
|
|
url = `invalid url: ${req.url}`;
|
2022-10-30 18:14:02 +01:00
|
|
|
Log.error(url);
|
|
|
|
res.send(url);
|
|
|
|
} else {
|
|
|
|
url = match[1];
|
|
|
|
|
|
|
|
const headersToSend = getHeadersToSend(req.url);
|
|
|
|
const expectedRecievedHeaders = geExpectedRecievedHeaders(req.url);
|
|
|
|
|
2023-03-19 14:32:23 +01:00
|
|
|
Log.log(`cors url: ${url}`);
|
2022-10-30 18:14:02 +01:00
|
|
|
const response = await fetch(url, { headers: headersToSend });
|
|
|
|
|
|
|
|
for (const header of expectedRecievedHeaders) {
|
|
|
|
const headerValue = response.headers.get(header);
|
|
|
|
if (header) res.set(header, headerValue);
|
|
|
|
}
|
|
|
|
const data = await response.text();
|
|
|
|
res.send(data);
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
Log.error(error);
|
|
|
|
res.send(error);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2023-02-20 20:04:40 +01:00
|
|
|
* Gets headers and values to attach to the web request.
|
2022-10-30 18:14:02 +01:00
|
|
|
* @param {string} url - The url containing the headers and values to send.
|
|
|
|
* @returns {object} An object specifying name and value of the headers.
|
|
|
|
*/
|
2023-12-25 08:17:11 +01:00
|
|
|
function getHeadersToSend (url) {
|
2023-03-19 14:32:23 +01:00
|
|
|
const headersToSend = { "User-Agent": `Mozilla/5.0 MagicMirror/${global.version}` };
|
2022-10-30 18:14:02 +01:00
|
|
|
const headersToSendMatch = new RegExp("sendheaders=(.+?)(&|$)", "g").exec(url);
|
|
|
|
if (headersToSendMatch) {
|
|
|
|
const headers = headersToSendMatch[1].split(",");
|
|
|
|
for (const header of headers) {
|
|
|
|
const keyValue = header.split(":");
|
|
|
|
if (keyValue.length !== 2) {
|
|
|
|
throw new Error(`Invalid format for header ${header}`);
|
|
|
|
}
|
|
|
|
headersToSend[keyValue[0]] = decodeURIComponent(keyValue[1]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return headersToSend;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the headers expected from the response.
|
|
|
|
* @param {string} url - The url containing the expected headers from the response.
|
|
|
|
* @returns {string[]} headers - The name of the expected headers.
|
|
|
|
*/
|
2023-12-25 08:17:11 +01:00
|
|
|
function geExpectedRecievedHeaders (url) {
|
2022-10-30 18:14:02 +01:00
|
|
|
const expectedRecievedHeaders = ["Content-Type"];
|
|
|
|
const expectedRecievedHeadersMatch = new RegExp("expectedheaders=(.+?)(&|$)", "g").exec(url);
|
|
|
|
if (expectedRecievedHeadersMatch) {
|
|
|
|
const headers = expectedRecievedHeadersMatch[1].split(",");
|
|
|
|
for (const header of headers) {
|
|
|
|
expectedRecievedHeaders.push(header);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return expectedRecievedHeaders;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the HTML to display the magic mirror.
|
|
|
|
* @param {Request} req - the request
|
|
|
|
* @param {Response} res - the result
|
|
|
|
*/
|
2023-12-25 08:17:11 +01:00
|
|
|
function getHtml (req, res) {
|
2022-10-30 18:14:02 +01:00
|
|
|
let html = fs.readFileSync(path.resolve(`${global.root_path}/index.html`), { encoding: "utf8" });
|
|
|
|
html = html.replace("#VERSION#", global.version);
|
|
|
|
|
|
|
|
let configFile = "config/config.js";
|
|
|
|
if (typeof global.configuration_file !== "undefined") {
|
|
|
|
configFile = global.configuration_file;
|
|
|
|
}
|
|
|
|
html = html.replace("#CONFIG_FILE#", configFile);
|
|
|
|
|
|
|
|
res.send(html);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the MagicMirror version.
|
|
|
|
* @param {Request} req - the request
|
|
|
|
* @param {Response} res - the result
|
|
|
|
*/
|
2023-12-25 08:17:11 +01:00
|
|
|
function getVersion (req, res) {
|
2022-10-30 18:14:02 +01:00
|
|
|
res.send(global.version);
|
|
|
|
}
|
|
|
|
|
2023-09-13 22:46:17 +02:00
|
|
|
module.exports = { cors, getConfig, getHtml, getVersion, getStartup };
|