cloudflare
Version:
The official TypeScript library for the Cloudflare API
170 lines (155 loc) • 4.94 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';
import { type Response } from '../../../_shims/index';
export class Values extends APIResource {
/**
* Write a value identified by a key. Use URL-encoding to use special characters
* (for example, `:`, `!`, `%`) in the key name. Body should be the value to be
* stored. If JSON metadata to be associated with the key/value pair is needed, use
* `multipart/form-data` content type for your PUT request (see dropdown below in
* `REQUEST BODY SCHEMA`). Existing values, expirations, and metadata 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.
*
* @example
* ```ts
* const value = await client.kv.namespaces.values.update(
* '0f2ac74b498b48028cb68387c421e279',
* 'My-Key',
* {
* account_id: '023e105f4ecef8ad9ca31a8372d0c353',
* value: 'Some Value',
* },
* );
* ```
*/
update(
namespaceId: string,
keyName: string,
params: ValueUpdateParams,
options?: Core.RequestOptions,
): Core.APIPromise<ValueUpdateResponse | null> {
const { account_id, expiration, expiration_ttl, ...body } = params;
return (
this._client.put(
`/accounts/${account_id}/storage/kv/namespaces/${namespaceId}/values/${keyName}`,
Core.multipartFormRequestOptions({
query: { expiration, expiration_ttl },
body,
__multipartSyntax: 'json',
...options,
}),
) as Core.APIPromise<{ result: ValueUpdateResponse | null }>
)._thenUnwrap((obj) => obj.result);
}
/**
* Remove a KV pair from the namespace. Use URL-encoding to use special characters
* (for example, `:`, `!`, `%`) in the key name.
*
* @example
* ```ts
* const value = await client.kv.namespaces.values.delete(
* '0f2ac74b498b48028cb68387c421e279',
* 'My-Key',
* { account_id: '023e105f4ecef8ad9ca31a8372d0c353' },
* );
* ```
*/
delete(
namespaceId: string,
keyName: string,
params: ValueDeleteParams,
options?: Core.RequestOptions,
): Core.APIPromise<ValueDeleteResponse | null> {
const { account_id } = params;
return (
this._client.delete(
`/accounts/${account_id}/storage/kv/namespaces/${namespaceId}/values/${keyName}`,
options,
) as Core.APIPromise<{ result: ValueDeleteResponse | null }>
)._thenUnwrap((obj) => obj.result);
}
/**
* Returns the value associated with the given key in the given namespace. Use
* URL-encoding to use special characters (for example, `:`, `!`, `%`) in the key
* name. If the KV-pair is set to expire at some point, the expiration time as
* measured in seconds since the UNIX epoch will be returned in the `expiration`
* response header.
*
* @example
* ```ts
* const value = await client.kv.namespaces.values.get(
* '0f2ac74b498b48028cb68387c421e279',
* 'My-Key',
* { account_id: '023e105f4ecef8ad9ca31a8372d0c353' },
* );
*
* const content = await value.blob();
* console.log(content);
* ```
*/
get(
namespaceId: string,
keyName: string,
params: ValueGetParams,
options?: Core.RequestOptions,
): Core.APIPromise<Response> {
const { account_id } = params;
return this._client.get(
`/accounts/${account_id}/storage/kv/namespaces/${namespaceId}/values/${keyName}`,
{
...options,
headers: { Accept: 'application/octet-stream', ...options?.headers },
__binaryResponse: true,
},
);
}
}
export interface ValueUpdateResponse {}
export interface ValueDeleteResponse {}
export interface ValueUpdateParams {
/**
* Path param: Identifier.
*/
account_id: string;
/**
* Body param: A byte sequence to be stored, up to 25 MiB in length.
*/
value: string;
/**
* Query param: Expires the key at a certain time, measured in number of seconds
* since the UNIX epoch.
*/
expiration?: number;
/**
* Query param: Expires the key after a number of seconds. Must be at least 60.
*/
expiration_ttl?: number;
/**
* Body param: Associates arbitrary JSON data with a key/value pair.
*/
metadata?: unknown;
}
export interface ValueDeleteParams {
/**
* Identifier.
*/
account_id: string;
}
export interface ValueGetParams {
/**
* Identifier.
*/
account_id: string;
}
export declare namespace Values {
export {
type ValueUpdateResponse as ValueUpdateResponse,
type ValueDeleteResponse as ValueDeleteResponse,
type ValueUpdateParams as ValueUpdateParams,
type ValueDeleteParams as ValueDeleteParams,
type ValueGetParams as ValueGetParams,
};
}