cloudflare
Version:
The official TypeScript library for the Cloudflare API
90 lines (76 loc) • 2.04 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 Schedules extends APIResource {
/**
* Updates Cron Triggers for a Worker.
*/
update(
scriptName: string,
params: ScheduleUpdateParams,
options?: Core.RequestOptions,
): Core.APIPromise<ScheduleUpdateResponse> {
const { account_id, body } = params;
return (
this._client.put(`/accounts/${account_id}/workers/scripts/${scriptName}/schedules`, {
body: body,
...options,
}) as Core.APIPromise<{ result: ScheduleUpdateResponse }>
)._thenUnwrap((obj) => obj.result);
}
/**
* Fetches Cron Triggers for a Worker.
*/
get(
scriptName: string,
params: ScheduleGetParams,
options?: Core.RequestOptions,
): Core.APIPromise<ScheduleGetResponse> {
const { account_id } = params;
return (
this._client.get(
`/accounts/${account_id}/workers/scripts/${scriptName}/schedules`,
options,
) as Core.APIPromise<{ result: ScheduleGetResponse }>
)._thenUnwrap((obj) => obj.result);
}
}
export interface Schedule {
created_on?: string;
cron?: string;
modified_on?: string;
}
export interface ScheduleParam {
cron?: string;
}
export interface ScheduleUpdateResponse {
schedules?: Array<Schedule>;
}
export interface ScheduleGetResponse {
schedules?: Array<Schedule>;
}
export interface ScheduleUpdateParams {
/**
* Path param: Identifier
*/
account_id: string;
/**
* Body param:
*/
body: Array<ScheduleParam>;
}
export interface ScheduleGetParams {
/**
* Identifier
*/
account_id: string;
}
export declare namespace Schedules {
export {
type Schedule as Schedule,
type ScheduleUpdateResponse as ScheduleUpdateResponse,
type ScheduleGetResponse as ScheduleGetResponse,
type ScheduleUpdateParams as ScheduleUpdateParams,
type ScheduleGetParams as ScheduleGetParams,
};
}