UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

108 lines (97 loc) 3.5 kB
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import * as Core from "../../../../../core"; import { APIResource } from "../../../../../resource"; import { type Response } from "../../../../../_shims/index"; import * as ContentAPI from "./content"; import * as WorkersAPI from "../../../../workers/workers"; import * as ScriptsAPI from "../../../../workers/scripts/scripts"; import { type Uploadable, multipartFormRequestOptions } from "../../../../../core"; export class Content extends APIResource { /** * Put script content for a script uploaded to a Workers for Platforms namespace. */ update( dispatchNamespace: string, scriptName: string, params: ContentUpdateParams, options?: Core.RequestOptions, ): Core.APIPromise<ScriptsAPI.Script> { const { account_id, 'CF-WORKER-BODY-PART': cfWorkerBodyPart, 'CF-WORKER-MAIN-MODULE-PART': cfWorkerMainModulePart, ...body } = params; return ( this._client.put( `/accounts/${account_id}/workers/dispatch/namespaces/${dispatchNamespace}/scripts/${scriptName}/content`, multipartFormRequestOptions({ body, ...options, headers: { 'CF-WORKER-BODY-PART': cfWorkerBodyPart || '', 'CF-WORKER-MAIN-MODULE-PART': cfWorkerMainModulePart || '', ...options?.headers, }, }), ) as Core.APIPromise<{ result: ScriptsAPI.Script }> )._thenUnwrap((obj) => obj.result); } /** * Fetch script content from a script uploaded to a Workers for Platforms * namespace. */ get( dispatchNamespace: string, scriptName: string, params: ContentGetParams, options?: Core.RequestOptions, ): Core.APIPromise<Response> { const { account_id } = params; return this._client.get( `/accounts/${account_id}/workers/dispatch/namespaces/${dispatchNamespace}/scripts/${scriptName}/content`, { ...options, __binaryResponse: true }, ); } } export interface ContentUpdateParams { /** * Path param: Identifier */ account_id: string; /** * Body param: A module comprising a Worker script, often a javascript file. * Multiple modules may be provided as separate named parts, but at least one * module must be present. This should be referenced either in the metadata as * `main_module` (esm)/`body_part` (service worker) or as a header * `CF-WORKER-MAIN-MODULE-PART` (esm) /`CF-WORKER-BODY-PART` (service worker) by * part name. Source maps may also be included using the `application/source-map` * content type. */ '<any part name>'?: Array<Uploadable>; /** * Body param: JSON encoded metadata about the uploaded parts and Worker * configuration. */ metadata?: WorkersAPI.WorkerMetadata; /** * Header param: The multipart name of a script upload part containing script * content in service worker format. Alternative to including in a metadata part. */ 'CF-WORKER-BODY-PART'?: string; /** * Header param: The multipart name of a script upload part containing script * content in es module format. Alternative to including in a metadata part. */ 'CF-WORKER-MAIN-MODULE-PART'?: string; } export interface ContentGetParams { /** * Identifier */ account_id: string; } export namespace Content { export import ContentUpdateParams = ContentAPI.ContentUpdateParams; export import ContentGetParams = ContentAPI.ContentGetParams; }