// 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 { 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>; /** * 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; } 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, }; }