cloudflare
Version:
The official TypeScript library for the Cloudflare API
146 lines (121 loc) • 3.62 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 { SinglePage } from '../../pagination';
export class Messages extends APIResource {
/**
* Acknowledge + Retry messages from a Queue
*/
ack(
queueId: string,
params: MessageAckParams,
options?: Core.RequestOptions,
): Core.APIPromise<MessageAckResponse> {
const { account_id, ...body } = params;
return (
this._client.post(`/accounts/${account_id}/queues/${queueId}/messages/ack`, {
body,
...options,
}) as Core.APIPromise<{ result: MessageAckResponse }>
)._thenUnwrap((obj) => obj.result);
}
/**
* Pull a batch of messages from a Queue
*/
pull(
queueId: string,
params: MessagePullParams,
options?: Core.RequestOptions,
): Core.PagePromise<MessagePullResponsesSinglePage, MessagePullResponse> {
const { account_id, ...body } = params;
return this._client.getAPIList(
`/accounts/${account_id}/queues/${queueId}/messages/pull`,
MessagePullResponsesSinglePage,
{ body, method: 'post', ...options },
);
}
}
export class MessagePullResponsesSinglePage extends SinglePage<MessagePullResponse> {}
export interface MessageAckResponse {
/**
* The number of messages that were succesfully acknowledged.
*/
ackCount?: number;
/**
* The number of messages that were succesfully retried.
*/
retryCount?: number;
warnings?: Array<string>;
}
export interface MessagePullResponse {
id?: string;
attempts?: number;
body?: string;
/**
* An ID that represents an "in-flight" message that has been pulled from a Queue.
* You must hold on to this ID and use it to acknowledge this message.
*/
lease_id?: string;
metadata?: unknown;
timestamp_ms?: number;
}
export interface MessageAckParams {
/**
* Path param: A Resource identifier.
*/
account_id: string;
/**
* Body param:
*/
acks?: Array<MessageAckParams.Ack>;
/**
* Body param:
*/
retries?: Array<MessageAckParams.Retry>;
}
export namespace MessageAckParams {
export interface Ack {
/**
* An ID that represents an "in-flight" message that has been pulled from a Queue.
* You must hold on to this ID and use it to acknowledge this message.
*/
lease_id?: string;
}
export interface Retry {
/**
* The number of seconds to delay before making the message available for another
* attempt.
*/
delay_seconds?: number;
/**
* An ID that represents an "in-flight" message that has been pulled from a Queue.
* You must hold on to this ID and use it to acknowledge this message.
*/
lease_id?: string;
}
}
export interface MessagePullParams {
/**
* Path param: A Resource identifier.
*/
account_id: string;
/**
* Body param: The maximum number of messages to include in a batch.
*/
batch_size?: number;
/**
* Body param: The number of milliseconds that a message is exclusively leased.
* After the timeout, the message becomes available for another attempt.
*/
visibility_timeout_ms?: number;
}
Messages.MessagePullResponsesSinglePage = MessagePullResponsesSinglePage;
export declare namespace Messages {
export {
type MessageAckResponse as MessageAckResponse,
type MessagePullResponse as MessagePullResponse,
MessagePullResponsesSinglePage as MessagePullResponsesSinglePage,
type MessageAckParams as MessageAckParams,
type MessagePullParams as MessagePullParams,
};
}