UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

282 lines (260 loc) 7.93 kB
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import * as Core from "../../../core"; import { APIResource } from "../../../resource"; import { isRequestOptions } from "../../../core"; import { CloudflareError } from "../../../error"; import * as VersionsAPI from "./versions"; import * as RulesAPI from "../rules"; import * as RulesetsAPI from "../rulesets"; import { RulesetsSinglePage } from "../rulesets"; import * as ByTagAPI from "./by-tag"; export class Versions extends APIResource { byTag: ByTagAPI.ByTag = new ByTagAPI.ByTag(this._client); /** * Fetches the versions of an account or zone ruleset. */ list( rulesetId: string, params?: VersionListParams, options?: Core.RequestOptions, ): Core.PagePromise<RulesetsSinglePage, RulesetsAPI.Ruleset>; list( rulesetId: string, options?: Core.RequestOptions, ): Core.PagePromise<RulesetsSinglePage, RulesetsAPI.Ruleset>; list( rulesetId: string, params: VersionListParams | Core.RequestOptions = {}, options?: Core.RequestOptions, ): Core.PagePromise<RulesetsSinglePage, RulesetsAPI.Ruleset> { if (isRequestOptions(params)) { return this.list(rulesetId, {}, params); } const { account_id, zone_id } = params; if (!account_id && !zone_id) { throw new CloudflareError('You must provide either account_id or zone_id.'); } if (account_id && zone_id) { throw new CloudflareError('You cannot provide both account_id and zone_id.'); } const { accountOrZone, accountOrZoneId } = account_id ? { accountOrZone: 'accounts', accountOrZoneId: account_id, } : { accountOrZone: 'zones', accountOrZoneId: zone_id, }; return this._client.getAPIList( `/${accountOrZone}/${accountOrZoneId}/rulesets/${rulesetId}/versions`, RulesetsSinglePage, options, ); } /** * Deletes an existing version of an account or zone ruleset. */ delete( rulesetId: string, rulesetVersion: string, params?: VersionDeleteParams, options?: Core.RequestOptions, ): Core.APIPromise<void>; delete(rulesetId: string, rulesetVersion: string, options?: Core.RequestOptions): Core.APIPromise<void>; delete( rulesetId: string, rulesetVersion: string, params: VersionDeleteParams | Core.RequestOptions = {}, options?: Core.RequestOptions, ): Core.APIPromise<void> { if (isRequestOptions(params)) { return this.delete(rulesetId, rulesetVersion, {}, params); } const { account_id, zone_id } = params; if (!account_id && !zone_id) { throw new CloudflareError('You must provide either account_id or zone_id.'); } if (account_id && zone_id) { throw new CloudflareError('You cannot provide both account_id and zone_id.'); } const { accountOrZone, accountOrZoneId } = account_id ? { accountOrZone: 'accounts', accountOrZoneId: account_id, } : { accountOrZone: 'zones', accountOrZoneId: zone_id, }; return this._client.delete( `/${accountOrZone}/${accountOrZoneId}/rulesets/${rulesetId}/versions/${rulesetVersion}`, { ...options, headers: { Accept: '*/*', ...options?.headers } }, ); } /** * Fetches a specific version of an account or zone ruleset. */ get( rulesetId: string, rulesetVersion: string, params?: VersionGetParams, options?: Core.RequestOptions, ): Core.APIPromise<VersionGetResponse>; get( rulesetId: string, rulesetVersion: string, options?: Core.RequestOptions, ): Core.APIPromise<VersionGetResponse>; get( rulesetId: string, rulesetVersion: string, params: VersionGetParams | Core.RequestOptions = {}, options?: Core.RequestOptions, ): Core.APIPromise<VersionGetResponse> { if (isRequestOptions(params)) { return this.get(rulesetId, rulesetVersion, {}, params); } const { account_id, zone_id } = params; if (!account_id && !zone_id) { throw new CloudflareError('You must provide either account_id or zone_id.'); } if (account_id && zone_id) { throw new CloudflareError('You cannot provide both account_id and zone_id.'); } const { accountOrZone, accountOrZoneId } = account_id ? { accountOrZone: 'accounts', accountOrZoneId: account_id, } : { accountOrZone: 'zones', accountOrZoneId: zone_id, }; return ( this._client.get( `/${accountOrZone}/${accountOrZoneId}/rulesets/${rulesetId}/versions/${rulesetVersion}`, options, ) as Core.APIPromise<{ result: VersionGetResponse }> )._thenUnwrap((obj) => obj.result); } } /** * A ruleset object. */ export interface VersionGetResponse { /** * The unique ID of the ruleset. */ id: string; /** * The kind of the ruleset. */ kind: 'managed' | 'custom' | 'root' | 'zone'; /** * The timestamp of when the ruleset was last modified. */ last_updated: string; /** * The human-readable name of the ruleset. */ name: string; /** * The phase of the ruleset. */ phase: | 'ddos_l4' | 'ddos_l7' | 'http_config_settings' | 'http_custom_errors' | 'http_log_custom_fields' | 'http_ratelimit' | 'http_request_cache_settings' | 'http_request_dynamic_redirect' | 'http_request_firewall_custom' | 'http_request_firewall_managed' | 'http_request_late_transform' | 'http_request_origin' | 'http_request_redirect' | 'http_request_sanitize' | 'http_request_sbfm' | 'http_request_select_configuration' | 'http_request_transform' | 'http_response_compression' | 'http_response_firewall_managed' | 'http_response_headers_transform' | 'magic_transit' | 'magic_transit_ids_managed' | 'magic_transit_managed'; /** * The list of rules in the ruleset. */ rules: Array< | RulesAPI.BlockRule | RulesAPI.ChallengeRule | RulesAPI.CompressResponseRule | RulesAPI.ExecuteRule | RulesAPI.JSChallengeRule | RulesAPI.LogRule | RulesAPI.ManagedChallengeRule | RulesAPI.RedirectRule | RulesAPI.RewriteRule | RulesAPI.RouteRule | RulesAPI.ScoreRule | RulesAPI.ServeErrorRule | RulesAPI.SetConfigRule | RulesAPI.SkipRule | RulesAPI.SetCacheSettingsRule >; /** * The version of the ruleset. */ version: string; /** * An informative description of the ruleset. */ description?: string; } export interface VersionListParams { /** * The Account ID to use for this endpoint. Mutually exclusive with the Zone ID. */ account_id?: string; /** * The Zone ID to use for this endpoint. Mutually exclusive with the Account ID. */ zone_id?: string; } export interface VersionDeleteParams { /** * The Account ID to use for this endpoint. Mutually exclusive with the Zone ID. */ account_id?: string; /** * The Zone ID to use for this endpoint. Mutually exclusive with the Account ID. */ zone_id?: string; } export interface VersionGetParams { /** * The Account ID to use for this endpoint. Mutually exclusive with the Zone ID. */ account_id?: string; /** * The Zone ID to use for this endpoint. Mutually exclusive with the Account ID. */ zone_id?: string; } export namespace Versions { export import VersionGetResponse = VersionsAPI.VersionGetResponse; export import VersionListParams = VersionsAPI.VersionListParams; export import VersionDeleteParams = VersionsAPI.VersionDeleteParams; export import VersionGetParams = VersionsAPI.VersionGetParams; export import ByTag = ByTagAPI.ByTag; export import ByTagGetResponse = ByTagAPI.ByTagGetResponse; export import ByTagGetParams = ByTagAPI.ByTagGetParams; } export { RulesetsSinglePage };