cloudflare
Version:
The official TypeScript library for the Cloudflare API
105 lines (94 loc) • 3.2 kB
text/typescript
// 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;
}