Merge branch 'dev' into new-update-indicator

This commit is contained in:
Thomas Camlong
2022-12-11 14:41:53 +09:00
committed by GitHub

View File

@@ -4,18 +4,24 @@ import { NextApiRequest, NextApiResponse } from 'next';
async function Get(req: NextApiRequest, res: NextApiResponse) { async function Get(req: NextApiRequest, res: NextApiResponse) {
// Parse req.body as a ServiceItem // Parse req.body as a ServiceItem
const { url } = req.query; const { url } = req.query;
// Parse url as URL object const agent = new https.Agent({ rejectUnauthorized: false });
const parsedUrl = new URL(url as string); await axios
// Ping the URL .get(url as string, { httpsAgent: agent, timeout: 2000 })
const response = await ping.promise.probe(parsedUrl.hostname, { .then((response) => {
timeout: 1, res.status(response.status).json(response.statusText);
}); })
// Return 200 if the alive property is true .catch((error) => {
if (response.alive) { if (error.response) {
return res.status(200).json({ alive: true }); res.status(error.response.status).json(error.response.statusText);
} } else if (error.code === 'ECONNABORTED') {
// Return 404 if the alive property is false res.status(408).json('Request Timeout');
return res.status(404).json({ alive: false }); } else {
res.status(500).json('Server Error');
}
});
// // Make a request to the URL
// const response = await axios.get(url);
// // Return the response
} }
export default async (req: NextApiRequest, res: NextApiResponse) => { export default async (req: NextApiRequest, res: NextApiResponse) => {