// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import { APIResource } from '../../../core/resource'; import * as CompletionsAPI from './completions'; import { ChatCompletionStoreMessagesPage } from './completions'; import { CursorPage, type CursorPageParams, PagePromise } from '../../../core/pagination'; import { RequestOptions } from '../../../internal/request-options'; import { path } from '../../../internal/utils/path'; export class Messages extends APIResource { /** * Get the messages in a stored chat completion. Only Chat Completions that have * been created with the `store` parameter set to `true` will be returned. * * @example * ```ts * // Automatically fetches more pages as needed. * for await (const chatCompletionStoreMessage of client.chat.completions.messages.list( * 'completion_id', * )) { * // ... * } * ``` */ list( completionID: string, query: MessageListParams | null | undefined = {}, options?: RequestOptions, ): PagePromise { return this._client.getAPIList( path`/chat/completions/${completionID}/messages`, CursorPage, { query, ...options }, ); } } export interface MessageListParams extends CursorPageParams { /** * Sort order for messages by timestamp. Use `asc` for ascending order or `desc` * for descending order. Defaults to `asc`. */ order?: 'asc' | 'desc'; } export declare namespace Messages { export { type MessageListParams as MessageListParams }; } export { type ChatCompletionStoreMessagesPage };