cloudflare
Version:
The official TypeScript library for the Cloudflare API
231 lines (203 loc) • 6.11 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';
import { SinglePage } from '../../../pagination';
export class ProxyEndpoints extends APIResource {
/**
* Create a new Zero Trust Gateway proxy endpoint.
*
* @example
* ```ts
* const proxyEndpoint =
* await client.zeroTrust.gateway.proxyEndpoints.create({
* account_id: '699d98642c564d2e855e9661899b7252',
* ips: ['192.0.2.1/32'],
* name: 'Devops team',
* });
* ```
*/
create(params: ProxyEndpointCreateParams, options?: Core.RequestOptions): Core.APIPromise<ProxyEndpoint> {
const { account_id, ...body } = params;
return (
this._client.post(`/accounts/${account_id}/gateway/proxy_endpoints`, {
body,
...options,
}) as Core.APIPromise<{ result: ProxyEndpoint }>
)._thenUnwrap((obj) => obj.result);
}
/**
* List all Zero Trust Gateway proxy endpoints for an account.
*
* @example
* ```ts
* const proxyEndpoint =
* await client.zeroTrust.gateway.proxyEndpoints.list({
* account_id: '699d98642c564d2e855e9661899b7252',
* });
* ```
*/
list(params: ProxyEndpointListParams, options?: Core.RequestOptions): Core.APIPromise<ProxyEndpoint> {
const { account_id } = params;
return (
this._client.get(`/accounts/${account_id}/gateway/proxy_endpoints`, options) as Core.APIPromise<{
result: ProxyEndpoint;
}>
)._thenUnwrap((obj) => obj.result);
}
/**
* Delete a configured Zero Trust Gateway proxy endpoint.
*
* @example
* ```ts
* const proxyEndpoint =
* await client.zeroTrust.gateway.proxyEndpoints.delete(
* 'ed35569b41ce4d1facfe683550f54086',
* { account_id: '699d98642c564d2e855e9661899b7252' },
* );
* ```
*/
delete(
proxyEndpointId: string,
params: ProxyEndpointDeleteParams,
options?: Core.RequestOptions,
): Core.APIPromise<ProxyEndpointDeleteResponse> {
const { account_id } = params;
return (
this._client.delete(
`/accounts/${account_id}/gateway/proxy_endpoints/${proxyEndpointId}`,
options,
) as Core.APIPromise<{ result: ProxyEndpointDeleteResponse }>
)._thenUnwrap((obj) => obj.result);
}
/**
* Update a configured Zero Trust Gateway proxy endpoint.
*
* @example
* ```ts
* const proxyEndpoint =
* await client.zeroTrust.gateway.proxyEndpoints.edit(
* 'ed35569b41ce4d1facfe683550f54086',
* { account_id: '699d98642c564d2e855e9661899b7252' },
* );
* ```
*/
edit(
proxyEndpointId: string,
params: ProxyEndpointEditParams,
options?: Core.RequestOptions,
): Core.APIPromise<ProxyEndpoint> {
const { account_id, ...body } = params;
return (
this._client.patch(`/accounts/${account_id}/gateway/proxy_endpoints/${proxyEndpointId}`, {
body,
...options,
}) as Core.APIPromise<{ result: ProxyEndpoint }>
)._thenUnwrap((obj) => obj.result);
}
/**
* Get a single Zero Trust Gateway proxy endpoint.
*
* @example
* ```ts
* // Automatically fetches more pages as needed.
* for await (const proxyEndpoint of client.zeroTrust.gateway.proxyEndpoints.get(
* 'ed35569b41ce4d1facfe683550f54086',
* { account_id: '699d98642c564d2e855e9661899b7252' },
* )) {
* // ...
* }
* ```
*/
get(
proxyEndpointId: string,
params: ProxyEndpointGetParams,
options?: Core.RequestOptions,
): Core.PagePromise<ProxyEndpointsSinglePage, ProxyEndpoint> {
const { account_id } = params;
return this._client.getAPIList(
`/accounts/${account_id}/gateway/proxy_endpoints/${proxyEndpointId}`,
ProxyEndpointsSinglePage,
options,
);
}
}
export class ProxyEndpointsSinglePage extends SinglePage<ProxyEndpoint> {}
/**
* Specify an IPv4 or IPv6 CIDR. Limit IPv6 to a maximum of /109 and IPv4 to a
* maximum of /25.
*/
export type GatewayIPs = string;
/**
* Specify an IPv4 or IPv6 CIDR. Limit IPv6 to a maximum of /109 and IPv4 to a
* maximum of /25.
*/
export type GatewayIPsParam = string;
export interface ProxyEndpoint {
id?: string;
created_at?: string;
/**
* Specify the list of CIDRs to restrict ingress connections.
*/
ips?: Array<GatewayIPs>;
/**
* Specify the name of the proxy endpoint.
*/
name?: string;
/**
* Specify the subdomain to use as the destination in the proxy client.
*/
subdomain?: string;
updated_at?: string;
}
export type ProxyEndpointDeleteResponse = unknown;
export interface ProxyEndpointCreateParams {
/**
* Path param:
*/
account_id: string;
/**
* Body param: Specify the list of CIDRs to restrict ingress connections.
*/
ips: Array<GatewayIPsParam>;
/**
* Body param: Specify the name of the proxy endpoint.
*/
name: string;
}
export interface ProxyEndpointListParams {
account_id: string;
}
export interface ProxyEndpointDeleteParams {
account_id: string;
}
export interface ProxyEndpointEditParams {
/**
* Path param:
*/
account_id: string;
/**
* Body param: Specify the list of CIDRs to restrict ingress connections.
*/
ips?: Array<GatewayIPsParam>;
/**
* Body param: Specify the name of the proxy endpoint.
*/
name?: string;
}
export interface ProxyEndpointGetParams {
account_id: string;
}
ProxyEndpoints.ProxyEndpointsSinglePage = ProxyEndpointsSinglePage;
export declare namespace ProxyEndpoints {
export {
type GatewayIPs as GatewayIPs,
type ProxyEndpoint as ProxyEndpoint,
type ProxyEndpointDeleteResponse as ProxyEndpointDeleteResponse,
ProxyEndpointsSinglePage as ProxyEndpointsSinglePage,
type ProxyEndpointCreateParams as ProxyEndpointCreateParams,
type ProxyEndpointListParams as ProxyEndpointListParams,
type ProxyEndpointDeleteParams as ProxyEndpointDeleteParams,
type ProxyEndpointEditParams as ProxyEndpointEditParams,
type ProxyEndpointGetParams as ProxyEndpointGetParams,
};
}