cloudflare
Version:
The official TypeScript library for the Cloudflare API
158 lines (142 loc) • 4.44 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 { CloudflareError } from '../../error';
export class Ownership extends APIResource {
/**
* Gets a new ownership challenge sent to your destination.
*
* @example
* ```ts
* const ownership = await client.logpush.ownership.create({
* destination_conf: 's3://mybucket/logs?region=us-west-2',
* account_id: 'account_id',
* });
* ```
*/
create(
params: OwnershipCreateParams,
options?: Core.RequestOptions,
): Core.APIPromise<OwnershipCreateResponse | null> {
const { account_id, zone_id, ...body } = params;
if (!account_id && !zone_id) {
throw new CloudflareError('You must provide either account_id or zone_id.');
}
if (account_id && zone_id) {
throw new CloudflareError('You cannot provide both account_id and zone_id.');
}
const { accountOrZone, accountOrZoneId } =
account_id ?
{
accountOrZone: 'accounts',
accountOrZoneId: account_id,
}
: {
accountOrZone: 'zones',
accountOrZoneId: zone_id,
};
return (
this._client.post(`/${accountOrZone}/${accountOrZoneId}/logpush/ownership`, {
body,
...options,
}) as Core.APIPromise<{ result: OwnershipCreateResponse | null }>
)._thenUnwrap((obj) => obj.result);
}
/**
* Validates ownership challenge of the destination.
*
* @example
* ```ts
* const ownershipValidation =
* await client.logpush.ownership.validate({
* destination_conf: 's3://mybucket/logs?region=us-west-2',
* ownership_challenge: '00000000000000000000',
* account_id: 'account_id',
* });
* ```
*/
validate(
params: OwnershipValidateParams,
options?: Core.RequestOptions,
): Core.APIPromise<OwnershipValidation | null> {
const { account_id, zone_id, ...body } = params;
if (!account_id && !zone_id) {
throw new CloudflareError('You must provide either account_id or zone_id.');
}
if (account_id && zone_id) {
throw new CloudflareError('You cannot provide both account_id and zone_id.');
}
const { accountOrZone, accountOrZoneId } =
account_id ?
{
accountOrZone: 'accounts',
accountOrZoneId: account_id,
}
: {
accountOrZone: 'zones',
accountOrZoneId: zone_id,
};
return (
this._client.post(`/${accountOrZone}/${accountOrZoneId}/logpush/ownership/validate`, {
body,
...options,
}) as Core.APIPromise<{ result: OwnershipValidation | null }>
)._thenUnwrap((obj) => obj.result);
}
}
export interface OwnershipValidation {
valid?: boolean;
}
export interface OwnershipCreateResponse {
filename?: string;
message?: string;
valid?: boolean;
}
export interface OwnershipCreateParams {
/**
* Body param: Uniquely identifies a resource (such as an s3 bucket) where data.
* will be pushed. Additional configuration parameters supported by the destination
* may be included.
*/
destination_conf: string;
/**
* Path param: The Account ID to use for this endpoint. Mutually exclusive with the
* Zone ID.
*/
account_id?: string;
/**
* Path param: The Zone ID to use for this endpoint. Mutually exclusive with the
* Account ID.
*/
zone_id?: string;
}
export interface OwnershipValidateParams {
/**
* Body param: Uniquely identifies a resource (such as an s3 bucket) where data.
* will be pushed. Additional configuration parameters supported by the destination
* may be included.
*/
destination_conf: string;
/**
* Body param: Ownership challenge token to prove destination ownership.
*/
ownership_challenge: string;
/**
* Path param: The Account ID to use for this endpoint. Mutually exclusive with the
* Zone ID.
*/
account_id?: string;
/**
* Path param: The Zone ID to use for this endpoint. Mutually exclusive with the
* Account ID.
*/
zone_id?: string;
}
export declare namespace Ownership {
export {
type OwnershipValidation as OwnershipValidation,
type OwnershipCreateResponse as OwnershipCreateResponse,
type OwnershipCreateParams as OwnershipCreateParams,
type OwnershipValidateParams as OwnershipValidateParams,
};
}