mirror of
https://github.com/Lissy93/web-check.git
synced 2024-11-22 16:23:56 +01:00
Fix for when Traceroute is not installed on host
This commit is contained in:
parent
83272e4536
commit
dd2baec866
@ -1,37 +1,88 @@
|
||||
const traceroute = require('traceroute');
|
||||
const util = require('util');
|
||||
const url = require('url');
|
||||
|
||||
// Convert traceroute.trace method to return a Promise
|
||||
const traceroutePromise = util.promisify(traceroute.trace);
|
||||
|
||||
exports.handler = async function(event, context) {
|
||||
const urlString = event.queryStringParameters.url;
|
||||
const startTime = Date.now();
|
||||
|
||||
try {
|
||||
if (!urlString) {
|
||||
throw new Error('URL parameter is missing!');
|
||||
|
||||
return {
|
||||
statusCode: 400,
|
||||
body: JSON.stringify({
|
||||
|
||||
|
||||
error: 'URL parameter is missing!'
|
||||
}),
|
||||
};
|
||||
}
|
||||
|
||||
// Parse the URL and get the hostname
|
||||
const urlObject = url.parse(urlString);
|
||||
const host = urlObject.hostname;
|
||||
|
||||
|
||||
if (!host) {
|
||||
throw new Error('Invalid URL provided');
|
||||
|
||||
return {
|
||||
statusCode: 400,
|
||||
body: JSON.stringify({
|
||||
error: 'Invalid URL provided'
|
||||
}),
|
||||
};
|
||||
}
|
||||
|
||||
const result = await traceroutePromise(host);
|
||||
const timeTaken = Date.now() - startTime;
|
||||
return {
|
||||
statusCode: 200,
|
||||
body: JSON.stringify({ message: "Traceroute completed!", result, timeTaken }),
|
||||
};
|
||||
// Traceroute with callback
|
||||
return await new Promise((resolve, reject) => {
|
||||
traceroute.trace(host, (err, hops) => {
|
||||
if (err) {
|
||||
reject(err);
|
||||
} else if (hops) {
|
||||
resolve(hops);
|
||||
}
|
||||
});
|
||||
// Check if remaining time is less than 8.8 seconds, then reject promise
|
||||
if (context.getRemainingTimeInMillis() < 8800) {
|
||||
reject(new Error('Lambda is about to timeout'));
|
||||
}
|
||||
}).then((result) => {
|
||||
const timeTaken = Date.now() - startTime;
|
||||
|
||||
return {
|
||||
statusCode: 200,
|
||||
body: JSON.stringify({
|
||||
message: "Traceroute completed!",
|
||||
result,
|
||||
timeTaken
|
||||
}),
|
||||
};
|
||||
}).catch((err) => {
|
||||
return {
|
||||
statusCode: 500,
|
||||
body: JSON.stringify({
|
||||
error: err.message
|
||||
}),
|
||||
};
|
||||
});
|
||||
|
||||
|
||||
} catch (err) {
|
||||
return {
|
||||
statusCode: 500,
|
||||
body: JSON.stringify({ message: `Error: ${err.message}` }),
|
||||
};
|
||||
if (err.code === 'ENOENT') {
|
||||
|
||||
return {
|
||||
statusCode: 400,
|
||||
body: JSON.stringify({
|
||||
error: 'Traceroute command is not installed on the host.'
|
||||
}),
|
||||
};
|
||||
} else {
|
||||
|
||||
return {
|
||||
statusCode: 500,
|
||||
body: JSON.stringify({
|
||||
error: err.message
|
||||
}),
|
||||
};
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -9,6 +9,7 @@ import Card from 'components/Form/Card';
|
||||
import Modal from 'components/Form/Modal';
|
||||
import Footer from 'components/misc/Footer';
|
||||
import { RowProps } from 'components/Form/Row';
|
||||
import ErrorBoundary from 'components/misc/ErrorBoundary';
|
||||
import docs from 'utils/docs';
|
||||
|
||||
|
||||
@ -435,12 +436,14 @@ const Results = (): JSX.Element => {
|
||||
{
|
||||
resultCardData.map(({ id, title, result, refresh, Component }, index: number) => (
|
||||
(result && !result.error) ? (
|
||||
<Component
|
||||
key={`${title}-${index}`}
|
||||
data={{...result}}
|
||||
title={title}
|
||||
actionButtons={refresh ? MakeActionButtons(title, refresh, () => showInfo(id)) : undefined}
|
||||
/>
|
||||
<ErrorBoundary title={title}>
|
||||
<Component
|
||||
key={`${title}-${index}`}
|
||||
data={{...result}}
|
||||
title={title}
|
||||
actionButtons={refresh ? MakeActionButtons(title, refresh, () => showInfo(id)) : undefined}
|
||||
/>
|
||||
</ErrorBoundary>
|
||||
) : <></>
|
||||
))
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user