cloudflare
Version:
The official TypeScript library for the Cloudflare API
73 lines (63 loc) • 1.95 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 AssetUpload extends APIResource {
/**
* Start uploading a collection of assets for use in a Worker version. To learn
* more about the direct uploads of assets, see
* https://developers.cloudflare.com/workers/static-assets/direct-upload/
*/
create(
dispatchNamespace: string,
scriptName: string,
params: AssetUploadCreateParams,
options?: Core.RequestOptions,
): Core.APIPromise<AssetUploadCreateResponse> {
const { account_id, ...body } = params;
return (
this._client.post(
`/accounts/${account_id}/workers/dispatch/namespaces/${dispatchNamespace}/scripts/${scriptName}/assets-upload-session`,
{ body, ...options },
) as Core.APIPromise<{ result: AssetUploadCreateResponse }>
)._thenUnwrap((obj) => obj.result);
}
}
export interface AssetUploadCreateResponse {
/**
* The requests to make to upload assets.
*/
buckets?: Array<Array<string>>;
/**
* A JWT to use as authentication for uploading assets.
*/
jwt?: string;
}
export interface AssetUploadCreateParams {
/**
* Path param: Identifier
*/
account_id: string;
/**
* Body param: A manifest ([path]: {hash, size}) map of files to upload. As an
* example, `/blog/hello-world.html` would be a valid path key.
*/
manifest?: Record<string, AssetUploadCreateParams.Manifest>;
}
export namespace AssetUploadCreateParams {
export interface Manifest {
/**
* The hash of the file.
*/
hash?: string;
/**
* The size of the file in bytes.
*/
size?: number;
}
}
export declare namespace AssetUpload {
export {
type AssetUploadCreateResponse as AssetUploadCreateResponse,
type AssetUploadCreateParams as AssetUploadCreateParams,
};
}