UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

111 lines (93 loc) 2.67 kB
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import { APIResource } from '../../../../resource'; import * as Core from '../../../../core'; import * as DEXAPI from '../dex'; export class Percentiles extends APIResource { /** * Get percentiles for an http test for a given time period between 1 hour and 7 * days. * * @example * ```ts * const httpDetailsPercentiles = * await client.zeroTrust.dex.httpTests.percentiles.get( * 'f174e90a-fafe-4643-bbbc-4a0ed4fc8415', * { * account_id: '01a7362d577a6c3019a474fd6f485823', * from: '2023-09-20T17:00:00Z', * to: '2023-09-20T17:00:00Z', * }, * ); * ``` */ get( testId: string, params: PercentileGetParams, options?: Core.RequestOptions, ): Core.APIPromise<HTTPDetailsPercentiles> { const { account_id, ...query } = params; return ( this._client.get(`/accounts/${account_id}/dex/http-tests/${testId}/percentiles`, { query, ...options, }) as Core.APIPromise<{ result: HTTPDetailsPercentiles }> )._thenUnwrap((obj) => obj.result); } } export interface HTTPDetailsPercentiles { dnsResponseTimeMs?: DEXAPI.Percentiles; resourceFetchTimeMs?: DEXAPI.Percentiles; serverResponseTimeMs?: DEXAPI.Percentiles; } export interface TestStatOverTime { slots: Array<TestStatOverTime.Slot>; /** * average observed in the time period */ avg?: number | null; /** * highest observed in the time period */ max?: number | null; /** * lowest observed in the time period */ min?: number | null; } export namespace TestStatOverTime { export interface Slot { timestamp: string; value: number; } } export interface PercentileGetParams { /** * Path param: unique identifier linked to an account in the API request path. */ account_id: string; /** * Query param: Start time for the query in ISO (RFC3339 - ISO 8601) format */ from: string; /** * Query param: End time for the query in ISO (RFC3339 - ISO 8601) format */ to: string; /** * Query param: Optionally filter result stats to a Cloudflare colo. Cannot be used * in combination with deviceId param. */ colo?: string; /** * Query param: Optionally filter result stats to a specific device(s). Cannot be * used in combination with colo param. */ deviceId?: Array<string>; } export declare namespace Percentiles { export { type HTTPDetailsPercentiles as HTTPDetailsPercentiles, type TestStatOverTime as TestStatOverTime, type PercentileGetParams as PercentileGetParams, }; }