mirror of
https://github.com/Lissy93/web-check.git
synced 2024-11-07 17:05:53 +01:00
97 lines
2.3 KiB
JavaScript
97 lines
2.3 KiB
JavaScript
import { URL } from 'url';
|
|
import followRedirects from 'follow-redirects';
|
|
import middleware from './_common/middleware.js';
|
|
|
|
const { https } = followRedirects;
|
|
|
|
const SECURITY_TXT_PATHS = [
|
|
'/security.txt',
|
|
'/.well-known/security.txt',
|
|
];
|
|
|
|
const parseResult = (result) => {
|
|
let output = {};
|
|
let counts = {};
|
|
const lines = result.split('\n');
|
|
const regex = /^([^:]+):\s*(.+)$/;
|
|
|
|
for (const line of lines) {
|
|
if (!line.startsWith("#") && !line.startsWith("-----") && line.trim() !== '') {
|
|
const match = line.match(regex);
|
|
if (match && match.length > 2) {
|
|
let key = match[1].trim();
|
|
const value = match[2].trim();
|
|
if (output.hasOwnProperty(key)) {
|
|
counts[key] = counts[key] ? counts[key] + 1 : 1;
|
|
key += counts[key];
|
|
}
|
|
output[key] = value;
|
|
}
|
|
}
|
|
}
|
|
|
|
return output;
|
|
};
|
|
|
|
const isPgpSigned = (result) => {
|
|
if (result.includes('-----BEGIN PGP SIGNED MESSAGE-----')) {
|
|
return true;
|
|
}
|
|
return false;
|
|
};
|
|
|
|
const securityTxtHandler = async (urlParam) => {
|
|
|
|
let url;
|
|
try {
|
|
url = new URL(urlParam.includes('://') ? urlParam : 'https://' + urlParam);
|
|
} catch (error) {
|
|
throw new Error('Invalid URL format');
|
|
}
|
|
url.pathname = '';
|
|
|
|
for (let path of SECURITY_TXT_PATHS) {
|
|
try {
|
|
const result = await fetchSecurityTxt(url, path);
|
|
if (result && result.includes('<html')) return { isPresent: false };
|
|
if (result) {
|
|
return {
|
|
isPresent: true,
|
|
foundIn: path,
|
|
content: result,
|
|
isPgpSigned: isPgpSigned(result),
|
|
fields: parseResult(result),
|
|
};
|
|
}
|
|
} catch (error) {
|
|
throw new Error(error.message);
|
|
}
|
|
}
|
|
|
|
return { isPresent: false };
|
|
};
|
|
|
|
async function fetchSecurityTxt(baseURL, path) {
|
|
return new Promise((resolve, reject) => {
|
|
const url = new URL(path, baseURL);
|
|
https.get(url.toString(), (res) => {
|
|
if (res.statusCode === 200) {
|
|
let data = '';
|
|
res.on('data', (chunk) => {
|
|
data += chunk;
|
|
});
|
|
res.on('end', () => {
|
|
resolve(data);
|
|
});
|
|
} else {
|
|
resolve(null);
|
|
}
|
|
}).on('error', (err) => {
|
|
reject(err);
|
|
});
|
|
});
|
|
}
|
|
|
|
export const handler = middleware(securityTxtHandler);
|
|
export default handler;
|