cloudflare
Version:
The official TypeScript library for the Cloudflare API
184 lines • 6.65 kB
JavaScript
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
import { APIResource } from "../../../resource.mjs";
import * as KeysAPI from "./keys.mjs";
import { Keys, KeysCursorPaginationAfter, } from "./keys.mjs";
import * as MetadataAPI from "./metadata.mjs";
import { Metadata } from "./metadata.mjs";
import * as ValuesAPI from "./values.mjs";
import { Values as ValuesAPIValues, } from "./values.mjs";
import { V4PagePaginationArray } from "../../../pagination.mjs";
export class Namespaces extends APIResource {
constructor() {
super(...arguments);
this.keys = new KeysAPI.Keys(this._client);
this.metadata = new MetadataAPI.Metadata(this._client);
this.values = new ValuesAPI.Values(this._client);
}
/**
* Creates a namespace under the given title. A `400` is returned if the account
* already owns a namespace with this title. A namespace must be explicitly deleted
* to be replaced.
*
* @example
* ```ts
* const namespace = await client.kv.namespaces.create({
* account_id: '023e105f4ecef8ad9ca31a8372d0c353',
* title: 'My Own Namespace',
* });
* ```
*/
create(params, options) {
const { account_id, ...body } = params;
return this._client.post(`/accounts/${account_id}/storage/kv/namespaces`, {
body,
...options,
})._thenUnwrap((obj) => obj.result);
}
/**
* Modifies a namespace's title.
*
* @example
* ```ts
* const namespace = await client.kv.namespaces.update(
* '0f2ac74b498b48028cb68387c421e279',
* {
* account_id: '023e105f4ecef8ad9ca31a8372d0c353',
* title: 'My Own Namespace',
* },
* );
* ```
*/
update(namespaceId, params, options) {
const { account_id, ...body } = params;
return this._client.put(`/accounts/${account_id}/storage/kv/namespaces/${namespaceId}`, {
body,
...options,
})._thenUnwrap((obj) => obj.result);
}
/**
* Returns the namespaces owned by an account.
*
* @example
* ```ts
* // Automatically fetches more pages as needed.
* for await (const namespace of client.kv.namespaces.list({
* account_id: '023e105f4ecef8ad9ca31a8372d0c353',
* })) {
* // ...
* }
* ```
*/
list(params, options) {
const { account_id, ...query } = params;
return this._client.getAPIList(`/accounts/${account_id}/storage/kv/namespaces`, NamespacesV4PagePaginationArray, { query, ...options });
}
/**
* Deletes the namespace corresponding to the given ID.
*
* @example
* ```ts
* const namespace = await client.kv.namespaces.delete(
* '0f2ac74b498b48028cb68387c421e279',
* { account_id: '023e105f4ecef8ad9ca31a8372d0c353' },
* );
* ```
*/
delete(namespaceId, params, options) {
const { account_id } = params;
return this._client.delete(`/accounts/${account_id}/storage/kv/namespaces/${namespaceId}`, options)._thenUnwrap((obj) => obj.result);
}
/**
* Remove multiple KV pairs from the namespace. Body should be an array of up to
* 10,000 keys to be removed.
*
* @example
* ```ts
* const response = await client.kv.namespaces.bulkDelete(
* '0f2ac74b498b48028cb68387c421e279',
* {
* account_id: '023e105f4ecef8ad9ca31a8372d0c353',
* body: ['My-Key'],
* },
* );
* ```
*/
bulkDelete(namespaceId, params, options) {
const { account_id, body } = params;
return this._client.post(`/accounts/${account_id}/storage/kv/namespaces/${namespaceId}/bulk/delete`, {
body: body,
...options,
})._thenUnwrap((obj) => obj.result);
}
/**
* Retrieve up to 100 KV pairs from the namespace. Keys must contain text-based
* values. JSON values can optionally be parsed instead of being returned as a
* string value. Metadata can be included if `withMetadata` is true.
*
* @example
* ```ts
* const response = await client.kv.namespaces.bulkGet(
* '0f2ac74b498b48028cb68387c421e279',
* {
* account_id: '023e105f4ecef8ad9ca31a8372d0c353',
* keys: ['My-Key'],
* },
* );
* ```
*/
bulkGet(namespaceId, params, options) {
const { account_id, ...body } = params;
return this._client.post(`/accounts/${account_id}/storage/kv/namespaces/${namespaceId}/bulk/get`, {
body,
...options,
})._thenUnwrap((obj) => obj.result);
}
/**
* Write multiple keys and values at once. Body should be an array of up to 10,000
* key-value pairs to be stored, along with optional expiration information.
* Existing values and expirations will be overwritten. If neither `expiration` nor
* `expiration_ttl` is specified, the key-value pair will never expire. If both are
* set, `expiration_ttl` is used and `expiration` is ignored. The entire request
* size must be 100 megabytes or less.
*
* @example
* ```ts
* const response = await client.kv.namespaces.bulkUpdate(
* '0f2ac74b498b48028cb68387c421e279',
* {
* account_id: '023e105f4ecef8ad9ca31a8372d0c353',
* body: [{ key: 'My-Key', value: 'Some string' }],
* },
* );
* ```
*/
bulkUpdate(namespaceId, params, options) {
const { account_id, body } = params;
return this._client.put(`/accounts/${account_id}/storage/kv/namespaces/${namespaceId}/bulk`, {
body: body,
...options,
})._thenUnwrap((obj) => obj.result);
}
/**
* Get the namespace corresponding to the given ID.
*
* @example
* ```ts
* const namespace = await client.kv.namespaces.get(
* '0f2ac74b498b48028cb68387c421e279',
* { account_id: '023e105f4ecef8ad9ca31a8372d0c353' },
* );
* ```
*/
get(namespaceId, params, options) {
const { account_id } = params;
return this._client.get(`/accounts/${account_id}/storage/kv/namespaces/${namespaceId}`, options)._thenUnwrap((obj) => obj.result);
}
}
export class NamespacesV4PagePaginationArray extends V4PagePaginationArray {
}
Namespaces.NamespacesV4PagePaginationArray = NamespacesV4PagePaginationArray;
Namespaces.Keys = Keys;
Namespaces.KeysCursorPaginationAfter = KeysCursorPaginationAfter;
Namespaces.Metadata = Metadata;
Namespaces.Values = ValuesAPIValues;
//# sourceMappingURL=namespaces.mjs.map