2023-06-30 00:40:06 +02:00
|
|
|
const https = require('https');
|
|
|
|
const { performance, PerformanceObserver } = require('perf_hooks');
|
|
|
|
|
|
|
|
exports.handler = async function(event, context) {
|
2023-07-28 22:46:20 +02:00
|
|
|
const url = (event.queryStringParameters || event.query).url;
|
2023-06-30 00:40:06 +02:00
|
|
|
|
|
|
|
if (!url) {
|
|
|
|
return {
|
|
|
|
statusCode: 400,
|
2023-07-10 00:23:50 +02:00
|
|
|
body: JSON.stringify({ error: 'You must provide a URL query parameter!' }),
|
2023-06-30 00:40:06 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
let dnsLookupTime;
|
|
|
|
let responseCode;
|
2023-07-10 00:23:50 +02:00
|
|
|
let startTime;
|
2023-06-30 00:40:06 +02:00
|
|
|
|
|
|
|
const obs = new PerformanceObserver((items) => {
|
|
|
|
dnsLookupTime = items.getEntries()[0].duration;
|
|
|
|
performance.clearMarks();
|
|
|
|
});
|
|
|
|
|
|
|
|
obs.observe({ entryTypes: ['measure'] });
|
|
|
|
|
|
|
|
performance.mark('A');
|
|
|
|
|
2023-07-10 00:23:50 +02:00
|
|
|
try {
|
|
|
|
startTime = performance.now();
|
|
|
|
const response = await new Promise((resolve, reject) => {
|
|
|
|
const req = https.get(url, res => {
|
|
|
|
let data = '';
|
|
|
|
responseCode = res.statusCode;
|
|
|
|
res.on('data', chunk => {
|
|
|
|
data += chunk;
|
|
|
|
});
|
|
|
|
res.on('end', () => {
|
|
|
|
resolve(res);
|
2023-06-30 00:40:06 +02:00
|
|
|
});
|
|
|
|
});
|
2023-07-10 00:23:50 +02:00
|
|
|
|
|
|
|
req.on('error', reject);
|
|
|
|
req.end();
|
2023-06-30 00:40:06 +02:00
|
|
|
});
|
2023-07-10 00:23:50 +02:00
|
|
|
|
|
|
|
if (responseCode < 200 || responseCode >= 400) {
|
|
|
|
return {
|
|
|
|
statusCode: 200,
|
|
|
|
body: JSON.stringify({ error: `Received non-success response code: ${responseCode}` }),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
performance.mark('B');
|
|
|
|
performance.measure('A to B', 'A', 'B');
|
|
|
|
let responseTime = performance.now() - startTime;
|
|
|
|
obs.disconnect();
|
|
|
|
|
|
|
|
return {
|
|
|
|
statusCode: 200,
|
|
|
|
body: JSON.stringify({ isUp: true, dnsLookupTime, responseTime, responseCode }),
|
|
|
|
};
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
obs.disconnect();
|
|
|
|
return {
|
|
|
|
statusCode: 200,
|
|
|
|
body: JSON.stringify({ error: `Error during operation: ${error.message}` }),
|
|
|
|
};
|
|
|
|
}
|
2023-06-30 00:40:06 +02:00
|
|
|
};
|