mirror of
https://github.com/checktheroads/hyperglass
synced 2024-05-11 05:55:08 +00:00
67 lines
1.8 KiB
TypeScript
67 lines
1.8 KiB
TypeScript
import { useQuery } from 'react-query';
|
|
import { useConfig } from '~/context';
|
|
import { fetchWithTimeout } from '~/util';
|
|
import { useGoogleAnalytics } from './useGoogleAnalytics';
|
|
|
|
import type { QueryFunction, QueryFunctionContext, QueryObserverResult } from 'react-query';
|
|
import type { DnsOverHttps } from '~/types';
|
|
import type { DNSQueryKey } from './types';
|
|
|
|
/**
|
|
* Perform a DNS over HTTPS query using the application/dns-json MIME type.
|
|
*/
|
|
const query: QueryFunction<DnsOverHttps.Response, DNSQueryKey> = async (
|
|
ctx: QueryFunctionContext<DNSQueryKey>,
|
|
) => {
|
|
const [url, { target, family }] = ctx.queryKey;
|
|
|
|
const controller = new AbortController();
|
|
|
|
let json;
|
|
const type = family === 4 ? 'A' : family === 6 ? 'AAAA' : '';
|
|
|
|
if (url !== null) {
|
|
const res = await fetchWithTimeout(
|
|
`${url}?name=${target}&type=${type}`,
|
|
{
|
|
headers: { accept: 'application/dns-json' },
|
|
mode: 'cors',
|
|
},
|
|
5000,
|
|
controller,
|
|
);
|
|
|
|
json = await res.json();
|
|
}
|
|
|
|
return json;
|
|
};
|
|
|
|
/**
|
|
* Query the configured DNS over HTTPS provider for the provided target. If `family` is `4`, only
|
|
* an A record will be queried. If `family` is `6`, only a AAAA record will be queried.
|
|
*/
|
|
export function useDNSQuery(
|
|
/**
|
|
* Hostname for DNS query.
|
|
*/
|
|
target: string | null,
|
|
/**
|
|
* Address family, e.g. IPv4 or IPv6.
|
|
*/
|
|
family: 4 | 6,
|
|
): QueryObserverResult<DnsOverHttps.Response> {
|
|
const { cache, web } = useConfig();
|
|
const { trackEvent } = useGoogleAnalytics();
|
|
|
|
if (typeof target === 'string') {
|
|
trackEvent({ category: 'DNS', action: 'Query', label: target, dimension1: `IPv${family}` });
|
|
}
|
|
|
|
return useQuery<DnsOverHttps.Response, unknown, DnsOverHttps.Response, DNSQueryKey>({
|
|
queryKey: [web.dns_provider.url, { target, family }],
|
|
queryFn: query,
|
|
cacheTime: cache.timeout * 1000,
|
|
});
|
|
}
|