cloudflare
Version:
The official TypeScript library for the Cloudflare API
104 lines (92 loc) • 3.24 kB
text/typescript
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
import { APIResource } from '../../../resource';
import * as Core from '../../../core';
export class AdvertisementStatus extends APIResource {
/**
* Advertise or withdraw the BGP route for a prefix.
*
* **Deprecated:** Prefer the BGP Prefixes endpoints, which additionally allow for
* advertising and withdrawing subnets of an IP prefix.
*/
edit(
prefixId: string,
params: AdvertisementStatusEditParams,
options?: Core.RequestOptions,
): Core.APIPromise<AdvertisementStatusEditResponse> {
const { account_id, ...body } = params;
return (
this._client.patch(`/accounts/${account_id}/addressing/prefixes/${prefixId}/bgp/status`, {
body,
...options,
}) as Core.APIPromise<{ result: AdvertisementStatusEditResponse }>
)._thenUnwrap((obj) => obj.result);
}
/**
* View the current advertisement state for a prefix.
*
* **Deprecated:** Prefer the BGP Prefixes endpoints, which additionally allow for
* advertising and withdrawing subnets of an IP prefix.
*/
get(
prefixId: string,
params: AdvertisementStatusGetParams,
options?: Core.RequestOptions,
): Core.APIPromise<AdvertisementStatusGetResponse> {
const { account_id } = params;
return (
this._client.get(
`/accounts/${account_id}/addressing/prefixes/${prefixId}/bgp/status`,
options,
) as Core.APIPromise<{ result: AdvertisementStatusGetResponse }>
)._thenUnwrap((obj) => obj.result);
}
}
export interface AdvertisementStatusEditResponse {
/**
* Advertisement status of the prefix. If `true`, the BGP route for the prefix is
* advertised to the Internet. If `false`, the BGP route is withdrawn.
*/
advertised?: boolean;
/**
* Last time the advertisement status was changed. This field is only not 'null' if
* on demand is enabled.
*/
advertised_modified_at?: string | null;
}
export interface AdvertisementStatusGetResponse {
/**
* Advertisement status of the prefix. If `true`, the BGP route for the prefix is
* advertised to the Internet. If `false`, the BGP route is withdrawn.
*/
advertised?: boolean;
/**
* Last time the advertisement status was changed. This field is only not 'null' if
* on demand is enabled.
*/
advertised_modified_at?: string | null;
}
export interface AdvertisementStatusEditParams {
/**
* Path param: Identifier of a Cloudflare account.
*/
account_id: string;
/**
* Body param: Advertisement status of the prefix. If `true`, the BGP route for the
* prefix is advertised to the Internet. If `false`, the BGP route is withdrawn.
*/
advertised: boolean;
}
export interface AdvertisementStatusGetParams {
/**
* Identifier of a Cloudflare account.
*/
account_id: string;
}
export declare namespace AdvertisementStatus {
export {
type AdvertisementStatusEditResponse as AdvertisementStatusEditResponse,
type AdvertisementStatusGetResponse as AdvertisementStatusGetResponse,
type AdvertisementStatusEditParams as AdvertisementStatusEditParams,
type AdvertisementStatusGetParams as AdvertisementStatusGetParams,
};
}