const https = require('https'); exports.handler = async function(event, context) { const siteURL = (event.queryStringParameters || event.query).url; const errorResponse = (message, statusCode = 500) => { return { statusCode: statusCode, body: JSON.stringify({ error: message }), }; }; const hstsIncompatible = (message, statusCode = 200) => { return { statusCode: statusCode, body: JSON.stringify({ message, compatible: false }), }; }; if (!siteURL) { return { statusCode: 400, body: JSON.stringify({ error: 'URL parameter is missing!' }), }; } return new Promise((resolve, reject) => { const req = https.request(siteURL, res => { const headers = res.headers; const hstsHeader = headers['strict-transport-security']; if (!hstsHeader) { resolve(hstsIncompatible(`Site does not serve any HSTS headers.`)); } else { const maxAgeMatch = hstsHeader.match(/max-age=(\d+)/); const includesSubDomains = hstsHeader.includes('includeSubDomains'); const preload = hstsHeader.includes('preload'); if (!maxAgeMatch || parseInt(maxAgeMatch[1]) < 10886400) { resolve(hstsIncompatible(`HSTS max-age is less than 10886400.`)); } else if (!includesSubDomains) { resolve(hstsIncompatible(`HSTS header does not include all subdomains.`)); } else if (!preload) { resolve(hstsIncompatible(`HSTS header does not contain the preload directive.`)); } else { resolve({ statusCode: 200, body: JSON.stringify({ message: "Site is compatible with the HSTS preload list!", compatible: true, hstsHeader: hstsHeader, }), }); } } }); req.on('error', (error) => { resolve(errorResponse(`Error making request: ${error.message}`)); }); req.end(); }); };