UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

769 lines (638 loc) 17.9 kB
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import { APIResource } from '../../../resource'; import { isRequestOptions } from '../../../core'; import * as Core from '../../../core'; export class Top extends APIResource { /** * Retrieves the top locations of DNS queries to AS112 with DNSSEC (DNS Security * Extensions) support. * * @example * ```ts * const response = await client.radar.as112.top.dnssec( * 'SUPPORTED', * ); * ``` */ dnssec( dnssec: 'SUPPORTED' | 'NOT_SUPPORTED', query?: TopDNSSECParams, options?: Core.RequestOptions, ): Core.APIPromise<TopDNSSECResponse>; dnssec( dnssec: 'SUPPORTED' | 'NOT_SUPPORTED', options?: Core.RequestOptions, ): Core.APIPromise<TopDNSSECResponse>; dnssec( dnssec: 'SUPPORTED' | 'NOT_SUPPORTED', query: TopDNSSECParams | Core.RequestOptions = {}, options?: Core.RequestOptions, ): Core.APIPromise<TopDNSSECResponse> { if (isRequestOptions(query)) { return this.dnssec(dnssec, {}, query); } return ( this._client.get(`/radar/as112/top/locations/dnssec/${dnssec}`, { query, ...options, }) as Core.APIPromise<{ result: TopDNSSECResponse }> )._thenUnwrap((obj) => obj.result); } /** * Retrieves the top locations of DNS queries to AS112 with EDNS (Extension * Mechanisms for DNS) support. * * @example * ```ts * const response = await client.radar.as112.top.edns( * 'SUPPORTED', * ); * ``` */ edns( edns: 'SUPPORTED' | 'NOT_SUPPORTED', query?: TopEdnsParams, options?: Core.RequestOptions, ): Core.APIPromise<TopEdnsResponse>; edns(edns: 'SUPPORTED' | 'NOT_SUPPORTED', options?: Core.RequestOptions): Core.APIPromise<TopEdnsResponse>; edns( edns: 'SUPPORTED' | 'NOT_SUPPORTED', query: TopEdnsParams | Core.RequestOptions = {}, options?: Core.RequestOptions, ): Core.APIPromise<TopEdnsResponse> { if (isRequestOptions(query)) { return this.edns(edns, {}, query); } return ( this._client.get(`/radar/as112/top/locations/edns/${edns}`, { query, ...options }) as Core.APIPromise<{ result: TopEdnsResponse; }> )._thenUnwrap((obj) => obj.result); } /** * Retrieves the top locations of DNS queries to AS112 for an IP version. * * @example * ```ts * const response = await client.radar.as112.top.ipVersion( * 'IPv4', * ); * ``` */ ipVersion( ipVersion: 'IPv4' | 'IPv6', query?: TopIPVersionParams, options?: Core.RequestOptions, ): Core.APIPromise<TopIPVersionResponse>; ipVersion(ipVersion: 'IPv4' | 'IPv6', options?: Core.RequestOptions): Core.APIPromise<TopIPVersionResponse>; ipVersion( ipVersion: 'IPv4' | 'IPv6', query: TopIPVersionParams | Core.RequestOptions = {}, options?: Core.RequestOptions, ): Core.APIPromise<TopIPVersionResponse> { if (isRequestOptions(query)) { return this.ipVersion(ipVersion, {}, query); } return ( this._client.get(`/radar/as112/top/locations/ip_version/${ipVersion}`, { query, ...options, }) as Core.APIPromise<{ result: TopIPVersionResponse }> )._thenUnwrap((obj) => obj.result); } /** * Retrieves the top locations by AS112 DNS queries. * * @example * ```ts * const response = await client.radar.as112.top.locations(); * ``` */ locations(query?: TopLocationsParams, options?: Core.RequestOptions): Core.APIPromise<TopLocationsResponse>; locations(options?: Core.RequestOptions): Core.APIPromise<TopLocationsResponse>; locations( query: TopLocationsParams | Core.RequestOptions = {}, options?: Core.RequestOptions, ): Core.APIPromise<TopLocationsResponse> { if (isRequestOptions(query)) { return this.locations({}, query); } return ( this._client.get('/radar/as112/top/locations', { query, ...options }) as Core.APIPromise<{ result: TopLocationsResponse; }> )._thenUnwrap((obj) => obj.result); } } export interface TopDNSSECResponse { /** * Metadata for the results. */ meta: TopDNSSECResponse.Meta; top_0: Array<TopDNSSECResponse.Top0>; } export namespace TopDNSSECResponse { /** * Metadata for the results. */ export interface Meta { confidenceInfo: Meta.ConfidenceInfo | null; dateRange: Array<Meta.DateRange>; /** * Timestamp of the last dataset update. */ lastUpdated: string; /** * Normalization method applied to the results. Refer to * [Normalization methods](https://developers.cloudflare.com/radar/concepts/normalization/). */ normalization: | 'PERCENTAGE' | 'MIN0_MAX' | 'MIN_MAX' | 'RAW_VALUES' | 'PERCENTAGE_CHANGE' | 'ROLLING_AVERAGE' | 'OVERLAPPED_PERCENTAGE' | 'RATIO'; /** * Measurement units for the results. */ units: Array<Meta.Unit>; } export namespace Meta { export interface ConfidenceInfo { annotations: Array<ConfidenceInfo.Annotation>; /** * Provides an indication of how much confidence Cloudflare has in the data. */ level: number; } export namespace ConfidenceInfo { /** * Annotation associated with the result (e.g. outage or other type of event). */ export interface Annotation { dataSource: string; description: string; endDate: string; eventType: string; /** * Whether event is a single point in time or a time range. */ isInstantaneous: boolean; linkedUrl: string; startDate: string; } } export interface DateRange { /** * Adjusted end of date range. */ endTime: string; /** * Adjusted start of date range. */ startTime: string; } export interface Unit { name: string; value: string; } } export interface Top0 { clientCountryAlpha2: string; clientCountryName: string; /** * A numeric string. */ value: string; } } export interface TopEdnsResponse { /** * Metadata for the results. */ meta: TopEdnsResponse.Meta; top_0: Array<TopEdnsResponse.Top0>; } export namespace TopEdnsResponse { /** * Metadata for the results. */ export interface Meta { confidenceInfo: Meta.ConfidenceInfo | null; dateRange: Array<Meta.DateRange>; /** * Timestamp of the last dataset update. */ lastUpdated: string; /** * Normalization method applied to the results. Refer to * [Normalization methods](https://developers.cloudflare.com/radar/concepts/normalization/). */ normalization: | 'PERCENTAGE' | 'MIN0_MAX' | 'MIN_MAX' | 'RAW_VALUES' | 'PERCENTAGE_CHANGE' | 'ROLLING_AVERAGE' | 'OVERLAPPED_PERCENTAGE' | 'RATIO'; /** * Measurement units for the results. */ units: Array<Meta.Unit>; } export namespace Meta { export interface ConfidenceInfo { annotations: Array<ConfidenceInfo.Annotation>; /** * Provides an indication of how much confidence Cloudflare has in the data. */ level: number; } export namespace ConfidenceInfo { /** * Annotation associated with the result (e.g. outage or other type of event). */ export interface Annotation { dataSource: string; description: string; endDate: string; eventType: string; /** * Whether event is a single point in time or a time range. */ isInstantaneous: boolean; linkedUrl: string; startDate: string; } } export interface DateRange { /** * Adjusted end of date range. */ endTime: string; /** * Adjusted start of date range. */ startTime: string; } export interface Unit { name: string; value: string; } } export interface Top0 { clientCountryAlpha2: string; clientCountryName: string; /** * A numeric string. */ value: string; } } export interface TopIPVersionResponse { /** * Metadata for the results. */ meta: TopIPVersionResponse.Meta; top_0: Array<TopIPVersionResponse.Top0>; } export namespace TopIPVersionResponse { /** * Metadata for the results. */ export interface Meta { confidenceInfo: Meta.ConfidenceInfo | null; dateRange: Array<Meta.DateRange>; /** * Timestamp of the last dataset update. */ lastUpdated: string; /** * Normalization method applied to the results. Refer to * [Normalization methods](https://developers.cloudflare.com/radar/concepts/normalization/). */ normalization: | 'PERCENTAGE' | 'MIN0_MAX' | 'MIN_MAX' | 'RAW_VALUES' | 'PERCENTAGE_CHANGE' | 'ROLLING_AVERAGE' | 'OVERLAPPED_PERCENTAGE' | 'RATIO'; /** * Measurement units for the results. */ units: Array<Meta.Unit>; } export namespace Meta { export interface ConfidenceInfo { annotations: Array<ConfidenceInfo.Annotation>; /** * Provides an indication of how much confidence Cloudflare has in the data. */ level: number; } export namespace ConfidenceInfo { /** * Annotation associated with the result (e.g. outage or other type of event). */ export interface Annotation { dataSource: string; description: string; endDate: string; eventType: string; /** * Whether event is a single point in time or a time range. */ isInstantaneous: boolean; linkedUrl: string; startDate: string; } } export interface DateRange { /** * Adjusted end of date range. */ endTime: string; /** * Adjusted start of date range. */ startTime: string; } export interface Unit { name: string; value: string; } } export interface Top0 { clientCountryAlpha2: string; clientCountryName: string; /** * A numeric string. */ value: string; } } export interface TopLocationsResponse { /** * Metadata for the results. */ meta: TopLocationsResponse.Meta; top_0: Array<TopLocationsResponse.Top0>; } export namespace TopLocationsResponse { /** * Metadata for the results. */ export interface Meta { confidenceInfo: Meta.ConfidenceInfo | null; dateRange: Array<Meta.DateRange>; /** * Timestamp of the last dataset update. */ lastUpdated: string; /** * Normalization method applied to the results. Refer to * [Normalization methods](https://developers.cloudflare.com/radar/concepts/normalization/). */ normalization: | 'PERCENTAGE' | 'MIN0_MAX' | 'MIN_MAX' | 'RAW_VALUES' | 'PERCENTAGE_CHANGE' | 'ROLLING_AVERAGE' | 'OVERLAPPED_PERCENTAGE' | 'RATIO'; /** * Measurement units for the results. */ units: Array<Meta.Unit>; } export namespace Meta { export interface ConfidenceInfo { annotations: Array<ConfidenceInfo.Annotation>; /** * Provides an indication of how much confidence Cloudflare has in the data. */ level: number; } export namespace ConfidenceInfo { /** * Annotation associated with the result (e.g. outage or other type of event). */ export interface Annotation { dataSource: string; description: string; endDate: string; eventType: string; /** * Whether event is a single point in time or a time range. */ isInstantaneous: boolean; linkedUrl: string; startDate: string; } } export interface DateRange { /** * Adjusted end of date range. */ endTime: string; /** * Adjusted start of date range. */ startTime: string; } export interface Unit { name: string; value: string; } } export interface Top0 { clientCountryAlpha2: string; clientCountryName: string; /** * A numeric string. */ value: string; } } export interface TopDNSSECParams { /** * Filters results by continent. Specify a comma-separated list of alpha-2 codes. * Prefix with `-` to exclude continents from results. For example, `-EU,NA` * excludes results from EU, but includes results from NA. */ continent?: Array<string>; /** * End of the date range (inclusive). */ dateEnd?: Array<string>; /** * Filters results by date range. For example, use `7d` and `7dcontrol` to compare * this week with the previous week. Use this parameter or set specific start and * end dates (`dateStart` and `dateEnd` parameters). */ dateRange?: Array<string>; /** * Start of the date range. */ dateStart?: Array<string>; /** * Format in which results will be returned. */ format?: 'JSON' | 'CSV'; /** * Limits the number of objects returned in the response. */ limit?: number; /** * Filters results by location. Specify a comma-separated list of alpha-2 codes. * Prefix with `-` to exclude locations from results. For example, `-US,PT` * excludes results from the US, but includes results from PT. */ location?: Array<string>; /** * Array of names used to label the series in the response. */ name?: Array<string>; } export interface TopEdnsParams { /** * Filters results by continent. Specify a comma-separated list of alpha-2 codes. * Prefix with `-` to exclude continents from results. For example, `-EU,NA` * excludes results from EU, but includes results from NA. */ continent?: Array<string>; /** * End of the date range (inclusive). */ dateEnd?: Array<string>; /** * Filters results by date range. For example, use `7d` and `7dcontrol` to compare * this week with the previous week. Use this parameter or set specific start and * end dates (`dateStart` and `dateEnd` parameters). */ dateRange?: Array<string>; /** * Start of the date range. */ dateStart?: Array<string>; /** * Format in which results will be returned. */ format?: 'JSON' | 'CSV'; /** * Limits the number of objects returned in the response. */ limit?: number; /** * Filters results by location. Specify a comma-separated list of alpha-2 codes. * Prefix with `-` to exclude locations from results. For example, `-US,PT` * excludes results from the US, but includes results from PT. */ location?: Array<string>; /** * Array of names used to label the series in the response. */ name?: Array<string>; } export interface TopIPVersionParams { /** * Filters results by continent. Specify a comma-separated list of alpha-2 codes. * Prefix with `-` to exclude continents from results. For example, `-EU,NA` * excludes results from EU, but includes results from NA. */ continent?: Array<string>; /** * End of the date range (inclusive). */ dateEnd?: Array<string>; /** * Filters results by date range. For example, use `7d` and `7dcontrol` to compare * this week with the previous week. Use this parameter or set specific start and * end dates (`dateStart` and `dateEnd` parameters). */ dateRange?: Array<string>; /** * Start of the date range. */ dateStart?: Array<string>; /** * Format in which results will be returned. */ format?: 'JSON' | 'CSV'; /** * Limits the number of objects returned in the response. */ limit?: number; /** * Filters results by location. Specify a comma-separated list of alpha-2 codes. * Prefix with `-` to exclude locations from results. For example, `-US,PT` * excludes results from the US, but includes results from PT. */ location?: Array<string>; /** * Array of names used to label the series in the response. */ name?: Array<string>; } export interface TopLocationsParams { /** * Filters results by continent. Specify a comma-separated list of alpha-2 codes. * Prefix with `-` to exclude continents from results. For example, `-EU,NA` * excludes results from EU, but includes results from NA. */ continent?: Array<string>; /** * End of the date range (inclusive). */ dateEnd?: Array<string>; /** * Filters results by date range. For example, use `7d` and `7dcontrol` to compare * this week with the previous week. Use this parameter or set specific start and * end dates (`dateStart` and `dateEnd` parameters). */ dateRange?: Array<string>; /** * Start of the date range. */ dateStart?: Array<string>; /** * Format in which results will be returned. */ format?: 'JSON' | 'CSV'; /** * Limits the number of objects returned in the response. */ limit?: number; /** * Filters results by location. Specify a comma-separated list of alpha-2 codes. * Prefix with `-` to exclude locations from results. For example, `-US,PT` * excludes results from the US, but includes results from PT. */ location?: Array<string>; /** * Array of names used to label the series in the response. */ name?: Array<string>; } export declare namespace Top { export { type TopDNSSECResponse as TopDNSSECResponse, type TopEdnsResponse as TopEdnsResponse, type TopIPVersionResponse as TopIPVersionResponse, type TopLocationsResponse as TopLocationsResponse, type TopDNSSECParams as TopDNSSECParams, type TopEdnsParams as TopEdnsParams, type TopIPVersionParams as TopIPVersionParams, type TopLocationsParams as TopLocationsParams, }; }