import { APIResource } from "../../../resource.js"; import * as Core from "../../../core.js"; import { SinglePage } from "../../../pagination.js"; export declare 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; /** * 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; /** * 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; /** * 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; } export declare class ServiceBindingsSinglePage extends SinglePage { } 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 declare namespace ServiceBinding { /** * Status of a Service Binding's deployment to the Cloudflare network */ 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; messages: Array; /** * Whether the API call was successful. */ success: true; } export declare namespace ServiceBindingDeleteResponse { interface Error { code: number; message: string; documentation_url?: string; source?: Error.Source; } namespace Error { interface Source { pointer?: string; } } interface Message { code: number; message: string; documentation_url?: string; source?: Message.Source; } namespace Message { 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; } 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, }; } //# sourceMappingURL=service-bindings.d.ts.map