UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

105 lines (94 loc) 3.2 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"; import * as ScriptsAPI from "./scripts"; import { type Uploadable, multipartFormRequestOptions } from "../../../core"; export class Content extends APIResource { /** * Put script content without touching config or metadata */ update( 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/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 only */ get( scriptName: string, params: ContentGetParams, options?: Core.RequestOptions, ): Core.APIPromise<Response> { const { account_id } = params; return this._client.get(`/accounts/${account_id}/workers/scripts/${scriptName}/content/v2`, { ...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; }