1
0
mirror of https://github.com/uetchy/namae.git synced 2025-03-17 20:40:32 +09:00
namae/api/services/domain/[query].ts

48 lines
1.2 KiB
TypeScript
Raw Permalink Normal View History

2020-08-31 08:41:53 +09:00
import { NowRequest, NowResponse } from '@vercel/node';
2020-09-17 15:40:42 +09:00
import fetch from 'cross-fetch';
import { send, sendError } from '../../../util/http';
2019-07-31 02:08:41 +09:00
2019-12-24 01:57:07 +09:00
export default async function handler(
req: NowRequest,
2020-08-20 00:57:33 +09:00
res: NowResponse
2019-12-24 01:57:07 +09:00
): Promise<void> {
2020-08-31 08:41:53 +09:00
const { query } = req.query;
2020-09-17 15:40:42 +09:00
console.log(query);
2019-07-31 02:08:41 +09:00
2020-06-19 16:15:53 +09:00
if (!query || typeof query !== 'string') {
2020-08-31 08:41:53 +09:00
return sendError(res, new Error('No query given'));
2019-07-31 02:08:41 +09:00
}
try {
2020-09-17 15:40:42 +09:00
const response = await fetch(
`https://domainr.p.rapidapi.com/v2/status?domain=${encodeURIComponent(
query
)}`,
{
headers: {
'X-RapidAPI-Key': process.env.DOMAINR_API_KEY,
},
}
).then((res) => res.json());
if (!response.status) {
throw new Error('Internal Server Error');
}
const availability = response.status.map((stat) => ({
query: stat.domain,
availability: stat.summary === 'inactive',
}));
if (availability.length === 0) {
return send(res, { availability: [] });
}
// NOTE: for backward compatibility
send(res, {
availability:
response.status.length > 1
? availability
: availability[0].availability,
});
2019-07-31 02:08:41 +09:00
} catch (err) {
2020-08-31 08:41:53 +09:00
sendError(res, err);
2019-07-31 02:08:41 +09:00
}
}