2022-11-07 11:35:13 -08:00
|
|
|
import { performance } from "perf_hooks";
|
|
|
|
|
|
|
|
import createLogger from "utils/logger";
|
|
|
|
import { httpProxy } from "utils/proxy/http";
|
|
|
|
|
|
|
|
const logger = createLogger("ping");
|
|
|
|
|
|
|
|
export default async function handler(req, res) {
|
|
|
|
const { ping: pingURL } = req.query;
|
|
|
|
|
|
|
|
if (!pingURL) {
|
|
|
|
logger.debug("No ping URL specified");
|
|
|
|
return res.status(400).send({
|
|
|
|
error: "No ping URL given",
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-11-28 20:10:44 -08:00
|
|
|
let startTime = performance.now();
|
|
|
|
let [status] = await httpProxy(pingURL, {
|
2022-11-07 11:35:13 -08:00
|
|
|
method: "HEAD"
|
|
|
|
});
|
2022-11-28 20:10:44 -08:00
|
|
|
let endTime = performance.now();
|
|
|
|
|
|
|
|
if (status >= 400 && status < 500) {
|
|
|
|
// try one more time as a GET in case HEAD is rejected for whatever reason
|
|
|
|
startTime = performance.now();
|
|
|
|
[status] = await httpProxy(pingURL);
|
|
|
|
endTime = performance.now();
|
|
|
|
}
|
2022-11-07 11:35:13 -08:00
|
|
|
|
|
|
|
return res.status(200).json({
|
|
|
|
status,
|
|
|
|
latency: endTime - startTime
|
|
|
|
});
|
|
|
|
}
|