cloudflare
Version:
The official TypeScript library for the Cloudflare API
189 lines (167 loc) • 4.97 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 OwnershipResource extends APIResource {
/**
* Adds an AWS or GCP bucket to use with full packet captures.
*
* @example
* ```ts
* const ownership =
* await client.magicTransit.pcaps.ownership.create({
* account_id: '023e105f4ecef8ad9ca31a8372d0c353',
* destination_conf: 's3://pcaps-bucket?region=us-east-1',
* });
* ```
*/
create(params: OwnershipCreateParams, options?: Core.RequestOptions): Core.APIPromise<Ownership> {
const { account_id, ...body } = params;
return (
this._client.post(`/accounts/${account_id}/pcaps/ownership`, { body, ...options }) as Core.APIPromise<{
result: Ownership;
}>
)._thenUnwrap((obj) => obj.result);
}
/**
* Deletes buckets added to the packet captures API.
*
* @example
* ```ts
* await client.magicTransit.pcaps.ownership.delete(
* '023e105f4ecef8ad9ca31a8372d0c353',
* { account_id: '023e105f4ecef8ad9ca31a8372d0c353' },
* );
* ```
*/
delete(
ownershipId: string,
params: OwnershipDeleteParams,
options?: Core.RequestOptions,
): Core.APIPromise<void> {
const { account_id } = params;
return this._client.delete(`/accounts/${account_id}/pcaps/ownership/${ownershipId}`, {
...options,
headers: { Accept: '*/*', ...options?.headers },
});
}
/**
* List all buckets configured for use with PCAPs API.
*
* @example
* ```ts
* // Automatically fetches more pages as needed.
* for await (const ownership of client.magicTransit.pcaps.ownership.get(
* { account_id: '023e105f4ecef8ad9ca31a8372d0c353' },
* )) {
* // ...
* }
* ```
*/
get(
params: OwnershipGetParams,
options?: Core.RequestOptions,
): Core.PagePromise<OwnershipsSinglePage, Ownership> {
const { account_id } = params;
return this._client.getAPIList(`/accounts/${account_id}/pcaps/ownership`, OwnershipsSinglePage, options);
}
/**
* Validates buckets added to the packet captures API.
*
* @example
* ```ts
* const ownership =
* await client.magicTransit.pcaps.ownership.validate({
* account_id: '023e105f4ecef8ad9ca31a8372d0c353',
* destination_conf: 's3://pcaps-bucket?region=us-east-1',
* ownership_challenge:
* 'ownership-challenge-9883874ecac311ec8475433579a6bf5f.txt',
* });
* ```
*/
validate(params: OwnershipValidateParams, options?: Core.RequestOptions): Core.APIPromise<Ownership> {
const { account_id, ...body } = params;
return (
this._client.post(`/accounts/${account_id}/pcaps/ownership/validate`, {
body,
...options,
}) as Core.APIPromise<{ result: Ownership }>
)._thenUnwrap((obj) => obj.result);
}
}
export class OwnershipsSinglePage extends SinglePage<Ownership> {}
export interface Ownership {
/**
* The bucket ID associated with the packet captures API.
*/
id: string;
/**
* The full URI for the bucket. This field only applies to `full` packet captures.
*/
destination_conf: string;
/**
* The ownership challenge filename stored in the bucket.
*/
filename: string;
/**
* The status of the ownership challenge. Can be pending, success or failed.
*/
status: 'pending' | 'success' | 'failed';
/**
* The RFC 3339 timestamp when the bucket was added to packet captures API.
*/
submitted: string;
/**
* The RFC 3339 timestamp when the bucket was validated.
*/
validated?: string;
}
export interface OwnershipCreateParams {
/**
* Path param: Identifier.
*/
account_id: string;
/**
* Body param: The full URI for the bucket. This field only applies to `full`
* packet captures.
*/
destination_conf: string;
}
export interface OwnershipDeleteParams {
/**
* Identifier.
*/
account_id: string;
}
export interface OwnershipGetParams {
/**
* Identifier.
*/
account_id: string;
}
export interface OwnershipValidateParams {
/**
* Path param: Identifier.
*/
account_id: string;
/**
* Body param: The full URI for the bucket. This field only applies to `full`
* packet captures.
*/
destination_conf: string;
/**
* Body param: The ownership challenge filename stored in the bucket.
*/
ownership_challenge: string;
}
OwnershipResource.OwnershipsSinglePage = OwnershipsSinglePage;
export declare namespace OwnershipResource {
export {
type Ownership as Ownership,
OwnershipsSinglePage as OwnershipsSinglePage,
type OwnershipCreateParams as OwnershipCreateParams,
type OwnershipDeleteParams as OwnershipDeleteParams,
type OwnershipGetParams as OwnershipGetParams,
type OwnershipValidateParams as OwnershipValidateParams,
};
}