cloudflare
Version:
The official TypeScript library for the Cloudflare API
122 lines (107 loc) • 3 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 { type Response } from '../../_shims/index';
export class LOADocuments extends APIResource {
/**
* Submit LOA document (pdf format) under the account.
*
* @example
* ```ts
* const loaDocument =
* await client.addressing.loaDocuments.create({
* account_id: '258def64c72dae45f3e4c8516e2111f2',
* loa_document: '@document.pdf',
* });
* ```
*/
create(
params: LOADocumentCreateParams,
options?: Core.RequestOptions,
): Core.APIPromise<LOADocumentCreateResponse> {
const { account_id, ...body } = params;
return (
this._client.post(
`/accounts/${account_id}/addressing/loa_documents`,
Core.multipartFormRequestOptions({ body, ...options }),
) as Core.APIPromise<{ result: LOADocumentCreateResponse }>
)._thenUnwrap((obj) => obj.result);
}
/**
* Download specified LOA document under the account.
*
* @example
* ```ts
* const loaDocument =
* await client.addressing.loaDocuments.get(
* 'd933b1530bc56c9953cf8ce166da8004',
* { account_id: '258def64c72dae45f3e4c8516e2111f2' },
* );
*
* const content = await loaDocument.blob();
* console.log(content);
* ```
*/
get(
loaDocumentId: string | null,
params: LOADocumentGetParams,
options?: Core.RequestOptions,
): Core.APIPromise<Response> {
const { account_id } = params;
return this._client.get(`/accounts/${account_id}/addressing/loa_documents/${loaDocumentId}/download`, {
...options,
headers: { Accept: 'application/pdf', ...options?.headers },
__binaryResponse: true,
});
}
}
export interface LOADocumentCreateResponse {
/**
* Identifier for the uploaded LOA document.
*/
id?: string | null;
/**
* Identifier of a Cloudflare account.
*/
account_id?: string;
created?: string;
/**
* Name of LOA document. Max file size 10MB, and supported filetype is pdf.
*/
filename?: string;
/**
* File size of the uploaded LOA document.
*/
size_bytes?: number;
/**
* Whether the LOA has been verified by Cloudflare staff.
*/
verified?: boolean;
/**
* Timestamp of the moment the LOA was marked as validated.
*/
verified_at?: string | null;
}
export interface LOADocumentCreateParams {
/**
* Path param: Identifier of a Cloudflare account.
*/
account_id: string;
/**
* Body param: LOA document to upload.
*/
loa_document: string;
}
export interface LOADocumentGetParams {
/**
* Identifier of a Cloudflare account.
*/
account_id: string;
}
export declare namespace LOADocuments {
export {
type LOADocumentCreateResponse as LOADocumentCreateResponse,
type LOADocumentCreateParams as LOADocumentCreateParams,
type LOADocumentGetParams as LOADocumentGetParams,
};
}