UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

342 lines (274 loc) 8.18 kB
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import * as Core from "../../../core"; import { APIResource } from "../../../resource"; import * as TracerouteTestsAPI from "./traceroute-tests"; import * as DEXAPI from "./dex"; import * as PercentilesAPI from "./http-tests/percentiles"; export class TracerouteTests extends APIResource { /** * Get test details and aggregate performance metrics for an traceroute test for a * given time period between 1 hour and 7 days. */ get( testId: string, params: TracerouteTestGetParams, options?: Core.RequestOptions, ): Core.APIPromise<Traceroute> { const { account_id, ...query } = params; return ( this._client.get(`/accounts/${account_id}/dex/traceroute-tests/${testId}`, { query, ...options, }) as Core.APIPromise<{ result: Traceroute }> )._thenUnwrap((obj) => obj.result); } /** * Get a breakdown of metrics by hop for individual traceroute test runs */ networkPath( testId: string, params: TracerouteTestNetworkPathParams, options?: Core.RequestOptions, ): Core.APIPromise<DEXAPI.NetworkPathResponse> { const { account_id, ...query } = params; return ( this._client.get(`/accounts/${account_id}/dex/traceroute-tests/${testId}/network-path`, { query, ...options, }) as Core.APIPromise<{ result: DEXAPI.NetworkPathResponse }> )._thenUnwrap((obj) => obj.result); } /** * Get percentiles for a traceroute test for a given time period between 1 hour and * 7 days. */ percentiles( testId: string, params: TracerouteTestPercentilesParams, options?: Core.RequestOptions, ): Core.APIPromise<TracerouteTestPercentilesResponse> { const { account_id, ...query } = params; return ( this._client.get(`/accounts/${account_id}/dex/traceroute-tests/${testId}/percentiles`, { query, ...options, }) as Core.APIPromise<{ result: TracerouteTestPercentilesResponse }> )._thenUnwrap((obj) => obj.result); } } export interface Traceroute { /** * The host of the Traceroute synthetic application test */ host: string; /** * The interval at which the Traceroute synthetic application test is set to run. */ interval: string; kind: 'traceroute'; /** * The name of the Traceroute synthetic application test */ name: string; target_policies?: Array<DEXAPI.DeviceExperienceMonitor> | null; targeted?: boolean; tracerouteStats?: Traceroute.TracerouteStats | null; tracerouteStatsByColo?: Array<Traceroute.TracerouteStatsByColo>; } export namespace Traceroute { export interface TracerouteStats { availabilityPct: TracerouteStats.AvailabilityPct; hopsCount: PercentilesAPI.TestStatOverTime; packetLossPct: TracerouteStats.PacketLossPct; roundTripTimeMs: PercentilesAPI.TestStatOverTime; /** * Count of unique devices that have run this test in the given time period */ uniqueDevicesTotal: number; } export namespace TracerouteStats { export interface AvailabilityPct { slots: Array<AvailabilityPct.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 AvailabilityPct { export interface Slot { timestamp: string; value: number; } } export interface PacketLossPct { slots: Array<PacketLossPct.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 PacketLossPct { export interface Slot { timestamp: string; value: number; } } } export interface TracerouteStatsByColo { availabilityPct: TracerouteStatsByColo.AvailabilityPct; colo: string; hopsCount: PercentilesAPI.TestStatOverTime; packetLossPct: TracerouteStatsByColo.PacketLossPct; roundTripTimeMs: PercentilesAPI.TestStatOverTime; /** * Count of unique devices that have run this test in the given time period */ uniqueDevicesTotal: number; } export namespace TracerouteStatsByColo { export interface AvailabilityPct { slots: Array<AvailabilityPct.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 AvailabilityPct { export interface Slot { timestamp: string; value: number; } } export interface PacketLossPct { slots: Array<PacketLossPct.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 PacketLossPct { export interface Slot { timestamp: string; value: number; } } } } export interface TracerouteTestPercentilesResponse { hopsCount?: DEXAPI.Percentiles; packetLossPct?: DEXAPI.Percentiles; roundTripTimeMs?: DEXAPI.Percentiles; } export interface TracerouteTestGetParams { /** * Path param: Unique identifier linked to an account */ account_id: string; /** * Query param: Time interval for aggregate time slots. */ interval: 'minute' | 'hour'; /** * Query param: End time for aggregate metrics in ISO ms */ timeEnd: string; /** * Query param: Start time for aggregate metrics in ISO ms */ timeStart: 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 interface TracerouteTestNetworkPathParams { /** * Path param: unique identifier linked to an account */ account_id: string; /** * Query param: Device to filter tracroute result runs to */ deviceId: string; /** * Query param: Time interval for aggregate time slots. */ interval: 'minute' | 'hour'; /** * Query param: End time for aggregate metrics in ISO ms */ timeEnd: string; /** * Query param: Start time for aggregate metrics in ISO ms */ timeStart: string; } export interface TracerouteTestPercentilesParams { /** * Path param: unique identifier linked to an account in the API request path. */ account_id: string; /** * Query param: End time for aggregate metrics in ISO format */ timeEnd: string; /** * Query param: Start time for aggregate metrics in ISO format */ timeStart: 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 namespace TracerouteTests { export import Traceroute = TracerouteTestsAPI.Traceroute; export import TracerouteTestPercentilesResponse = TracerouteTestsAPI.TracerouteTestPercentilesResponse; export import TracerouteTestGetParams = TracerouteTestsAPI.TracerouteTestGetParams; export import TracerouteTestNetworkPathParams = TracerouteTestsAPI.TracerouteTestNetworkPathParams; export import TracerouteTestPercentilesParams = TracerouteTestsAPI.TracerouteTestPercentilesParams; }