UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

265 lines (231 loc) 7.15 kB
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import { APIResource } from '../../../resource'; import * as Core from '../../../core'; import { SinglePage } from '../../../pagination'; export class ServiceBindings extends APIResource { /** * Creates a new Service Binding, routing traffic to IPs within the given CIDR to a * service running on Cloudflare's network. **Note:** This API may only be used on * prefixes currently configured with a Magic Transit/Cloudflare CDN/Cloudflare * Spectrum service binding, and only allows creating upgrade service bindings for * the Cloudflare CDN or Cloudflare Spectrum. * * @example * ```ts * const serviceBinding = * await client.addressing.prefixes.serviceBindings.create( * '2af39739cc4e3b5910c918468bb89828', * { account_id: '258def64c72dae45f3e4c8516e2111f2' }, * ); * ``` */ create( prefixId: string, params: ServiceBindingCreateParams, options?: Core.RequestOptions, ): Core.APIPromise<ServiceBinding> { const { account_id, ...body } = params; return ( this._client.post(`/accounts/${account_id}/addressing/prefixes/${prefixId}/bindings`, { body, ...options, }) as Core.APIPromise<{ result: ServiceBinding }> )._thenUnwrap((obj) => obj.result); } /** * List the Cloudflare services this prefix is currently bound to. Traffic sent to * an address within an IP prefix will be routed to the Cloudflare service of the * most-specific Service Binding matching the address. **Example:** binding * `192.0.2.0/24` to Cloudflare Magic Transit and `192.0.2.1/32` to the Cloudflare * CDN would route traffic for `192.0.2.1` to the CDN, and traffic for all other * IPs in the prefix to Cloudflare Magic Transit. * * @example * ```ts * // Automatically fetches more pages as needed. * for await (const serviceBinding of client.addressing.prefixes.serviceBindings.list( * '2af39739cc4e3b5910c918468bb89828', * { account_id: '258def64c72dae45f3e4c8516e2111f2' }, * )) { * // ... * } * ``` */ list( prefixId: string, params: ServiceBindingListParams, options?: Core.RequestOptions, ): Core.PagePromise<ServiceBindingsSinglePage, ServiceBinding> { const { account_id } = params; return this._client.getAPIList( `/accounts/${account_id}/addressing/prefixes/${prefixId}/bindings`, ServiceBindingsSinglePage, options, ); } /** * Delete a Service Binding * * @example * ```ts * const serviceBinding = * await client.addressing.prefixes.serviceBindings.delete( * '2af39739cc4e3b5910c918468bb89828', * '0429b49b6a5155297b78e75a44b09e14', * { account_id: '258def64c72dae45f3e4c8516e2111f2' }, * ); * ``` */ delete( prefixId: string, bindingId: string, params: ServiceBindingDeleteParams, options?: Core.RequestOptions, ): Core.APIPromise<ServiceBindingDeleteResponse> { const { account_id } = params; return this._client.delete( `/accounts/${account_id}/addressing/prefixes/${prefixId}/bindings/${bindingId}`, options, ); } /** * Fetch a single Service Binding * * @example * ```ts * const serviceBinding = * await client.addressing.prefixes.serviceBindings.get( * '2af39739cc4e3b5910c918468bb89828', * '0429b49b6a5155297b78e75a44b09e14', * { account_id: '258def64c72dae45f3e4c8516e2111f2' }, * ); * ``` */ get( prefixId: string, bindingId: string, params: ServiceBindingGetParams, options?: Core.RequestOptions, ): Core.APIPromise<ServiceBinding> { const { account_id } = params; return ( this._client.get( `/accounts/${account_id}/addressing/prefixes/${prefixId}/bindings/${bindingId}`, options, ) as Core.APIPromise<{ result: ServiceBinding }> )._thenUnwrap((obj) => obj.result); } } export class ServiceBindingsSinglePage extends SinglePage<ServiceBinding> {} export interface ServiceBinding { /** * Identifier of a Service Binding. */ id?: string; /** * IP Prefix in Classless Inter-Domain Routing format. */ cidr?: string; /** * Status of a Service Binding's deployment to the Cloudflare network */ provisioning?: ServiceBinding.Provisioning; /** * Identifier of a Service on the Cloudflare network. Available services and their * IDs may be found in the **List Services** endpoint. */ service_id?: string; /** * Name of a service running on the Cloudflare network */ service_name?: string; } export namespace ServiceBinding { /** * Status of a Service Binding's deployment to the Cloudflare network */ export interface Provisioning { /** * When a binding has been deployed to a majority of Cloudflare datacenters, the * binding will become active and can be used with its associated service. */ state?: 'provisioning' | 'active'; } } export interface ServiceBindingDeleteResponse { errors: Array<ServiceBindingDeleteResponse.Error>; messages: Array<ServiceBindingDeleteResponse.Message>; /** * Whether the API call was successful. */ success: true; } export namespace ServiceBindingDeleteResponse { export interface Error { code: number; message: string; documentation_url?: string; source?: Error.Source; } export namespace Error { export interface Source { pointer?: string; } } export interface Message { code: number; message: string; documentation_url?: string; source?: Message.Source; } export namespace Message { export interface Source { pointer?: string; } } } export interface ServiceBindingCreateParams { /** * Path param: Identifier of a Cloudflare account. */ account_id: string; /** * Body param: IP Prefix in Classless Inter-Domain Routing format. */ cidr?: string; /** * Body param: Identifier of a Service on the Cloudflare network. Available * services and their IDs may be found in the **List Services** endpoint. */ service_id?: string; } export interface ServiceBindingListParams { /** * Identifier of a Cloudflare account. */ account_id: string; } export interface ServiceBindingDeleteParams { /** * Identifier of a Cloudflare account. */ account_id: string; } export interface ServiceBindingGetParams { /** * Identifier of a Cloudflare account. */ account_id: string; } ServiceBindings.ServiceBindingsSinglePage = ServiceBindingsSinglePage; export declare namespace ServiceBindings { export { type ServiceBinding as ServiceBinding, type ServiceBindingDeleteResponse as ServiceBindingDeleteResponse, ServiceBindingsSinglePage as ServiceBindingsSinglePage, type ServiceBindingCreateParams as ServiceBindingCreateParams, type ServiceBindingListParams as ServiceBindingListParams, type ServiceBindingDeleteParams as ServiceBindingDeleteParams, type ServiceBindingGetParams as ServiceBindingGetParams, }; }