cloudflare
Version:
The official TypeScript library for the Cloudflare API
246 lines (216 loc) • 6.92 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 CORS extends APIResource {
/**
* Set the CORS policy for a bucket
*/
update(
bucketName: string,
params: CORSUpdateParams,
options?: Core.RequestOptions,
): Core.APIPromise<CORSUpdateResponse> {
const { account_id, jurisdiction, ...body } = params;
return (
this._client.put(`/accounts/${account_id}/r2/buckets/${bucketName}/cors`, {
body,
...options,
headers: {
...(jurisdiction?.toString() != null ?
{ 'cf-r2-jurisdiction': jurisdiction?.toString() }
: undefined),
...options?.headers,
},
}) as Core.APIPromise<{ result: CORSUpdateResponse }>
)._thenUnwrap((obj) => obj.result);
}
/**
* Delete the CORS policy for a bucket
*/
delete(
bucketName: string,
params: CORSDeleteParams,
options?: Core.RequestOptions,
): Core.APIPromise<CORSDeleteResponse> {
const { account_id, jurisdiction } = params;
return (
this._client.delete(`/accounts/${account_id}/r2/buckets/${bucketName}/cors`, {
...options,
headers: {
...(jurisdiction?.toString() != null ?
{ 'cf-r2-jurisdiction': jurisdiction?.toString() }
: undefined),
...options?.headers,
},
}) as Core.APIPromise<{ result: CORSDeleteResponse }>
)._thenUnwrap((obj) => obj.result);
}
/**
* Get the CORS policy for a bucket
*/
get(
bucketName: string,
params: CORSGetParams,
options?: Core.RequestOptions,
): Core.APIPromise<CORSGetResponse> {
const { account_id, jurisdiction } = params;
return (
this._client.get(`/accounts/${account_id}/r2/buckets/${bucketName}/cors`, {
...options,
headers: {
...(jurisdiction?.toString() != null ?
{ 'cf-r2-jurisdiction': jurisdiction?.toString() }
: undefined),
...options?.headers,
},
}) as Core.APIPromise<{ result: CORSGetResponse }>
)._thenUnwrap((obj) => obj.result);
}
}
export type CORSUpdateResponse = unknown;
export type CORSDeleteResponse = unknown;
export interface CORSGetResponse {
rules?: Array<CORSGetResponse.Rule>;
}
export namespace CORSGetResponse {
export interface Rule {
/**
* Object specifying allowed origins, methods and headers for this CORS rule.
*/
allowed: Rule.Allowed;
/**
* Identifier for this rule
*/
id?: string;
/**
* Specifies the headers that can be exposed back, and accessed by, the JavaScript
* making the cross-origin request. If you need to access headers beyond the
* safelisted response headers, such as Content-Encoding or cf-cache-status, you
* must specify it here.
*/
exposeHeaders?: Array<string>;
/**
* Specifies the amount of time (in seconds) browsers are allowed to cache CORS
* preflight responses. Browsers may limit this to 2 hours or less, even if the
* maximum value (86400) is specified.
*/
maxAgeSeconds?: number;
}
export namespace Rule {
/**
* Object specifying allowed origins, methods and headers for this CORS rule.
*/
export interface Allowed {
/**
* Specifies the value for the Access-Control-Allow-Methods header R2 sets when
* requesting objects in a bucket from a browser.
*/
methods: Array<'GET' | 'PUT' | 'POST' | 'DELETE' | 'HEAD'>;
/**
* Specifies the value for the Access-Control-Allow-Origin header R2 sets when
* requesting objects in a bucket from a browser.
*/
origins: Array<string>;
/**
* Specifies the value for the Access-Control-Allow-Headers header R2 sets when
* requesting objects in this bucket from a browser. Cross-origin requests that
* include custom headers (e.g. x-user-id) should specify these headers as
* AllowedHeaders.
*/
headers?: Array<string>;
}
}
}
export interface CORSUpdateParams {
/**
* Path param: Account ID
*/
account_id: string;
/**
* Body param:
*/
rules?: Array<CORSUpdateParams.Rule>;
/**
* Header param: The bucket jurisdiction
*/
jurisdiction?: 'default' | 'eu' | 'fedramp';
}
export namespace CORSUpdateParams {
export interface Rule {
/**
* Object specifying allowed origins, methods and headers for this CORS rule.
*/
allowed: Rule.Allowed;
/**
* Identifier for this rule
*/
id?: string;
/**
* Specifies the headers that can be exposed back, and accessed by, the JavaScript
* making the cross-origin request. If you need to access headers beyond the
* safelisted response headers, such as Content-Encoding or cf-cache-status, you
* must specify it here.
*/
exposeHeaders?: Array<string>;
/**
* Specifies the amount of time (in seconds) browsers are allowed to cache CORS
* preflight responses. Browsers may limit this to 2 hours or less, even if the
* maximum value (86400) is specified.
*/
maxAgeSeconds?: number;
}
export namespace Rule {
/**
* Object specifying allowed origins, methods and headers for this CORS rule.
*/
export interface Allowed {
/**
* Specifies the value for the Access-Control-Allow-Methods header R2 sets when
* requesting objects in a bucket from a browser.
*/
methods: Array<'GET' | 'PUT' | 'POST' | 'DELETE' | 'HEAD'>;
/**
* Specifies the value for the Access-Control-Allow-Origin header R2 sets when
* requesting objects in a bucket from a browser.
*/
origins: Array<string>;
/**
* Specifies the value for the Access-Control-Allow-Headers header R2 sets when
* requesting objects in this bucket from a browser. Cross-origin requests that
* include custom headers (e.g. x-user-id) should specify these headers as
* AllowedHeaders.
*/
headers?: Array<string>;
}
}
}
export interface CORSDeleteParams {
/**
* Path param: Account ID
*/
account_id: string;
/**
* Header param: The bucket jurisdiction
*/
jurisdiction?: 'default' | 'eu' | 'fedramp';
}
export interface CORSGetParams {
/**
* Path param: Account ID
*/
account_id: string;
/**
* Header param: The bucket jurisdiction
*/
jurisdiction?: 'default' | 'eu' | 'fedramp';
}
export declare namespace CORS {
export {
type CORSUpdateResponse as CORSUpdateResponse,
type CORSDeleteResponse as CORSDeleteResponse,
type CORSGetResponse as CORSGetResponse,
type CORSUpdateParams as CORSUpdateParams,
type CORSDeleteParams as CORSDeleteParams,
type CORSGetParams as CORSGetParams,
};
}