"use strict"; // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. Object.defineProperty(exports, "__esModule", { value: true }); exports.Threads = void 0; const tslib_1 = require("../../../internal/tslib.js"); const resource_1 = require("../../../core/resource.js"); const MessagesAPI = tslib_1.__importStar(require("./messages.js")); const messages_1 = require("./messages.js"); const RunsAPI = tslib_1.__importStar(require("./runs/runs.js")); const runs_1 = require("./runs/runs.js"); const headers_1 = require("../../../internal/headers.js"); const AssistantStream_1 = require("../../../lib/AssistantStream.js"); const path_1 = require("../../../internal/utils/path.js"); /** * @deprecated The Assistants API is deprecated in favor of the Responses API */ class Threads extends resource_1.APIResource { constructor() { super(...arguments); this.runs = new RunsAPI.Runs(this._client); this.messages = new MessagesAPI.Messages(this._client); } /** * Create a thread. * * @deprecated The Assistants API is deprecated in favor of the Responses API */ create(body = {}, options) { return this._client.post('/threads', { body, ...options, headers: (0, headers_1.buildHeaders)([{ 'OpenAI-Beta': 'assistants=v2' }, options?.headers]), }); } /** * Retrieves a thread. * * @deprecated The Assistants API is deprecated in favor of the Responses API */ retrieve(threadID, options) { return this._client.get((0, path_1.path) `/threads/${threadID}`, { ...options, headers: (0, headers_1.buildHeaders)([{ 'OpenAI-Beta': 'assistants=v2' }, options?.headers]), }); } /** * Modifies a thread. * * @deprecated The Assistants API is deprecated in favor of the Responses API */ update(threadID, body, options) { return this._client.post((0, path_1.path) `/threads/${threadID}`, { body, ...options, headers: (0, headers_1.buildHeaders)([{ 'OpenAI-Beta': 'assistants=v2' }, options?.headers]), }); } /** * Delete a thread. * * @deprecated The Assistants API is deprecated in favor of the Responses API */ delete(threadID, options) { return this._client.delete((0, path_1.path) `/threads/${threadID}`, { ...options, headers: (0, headers_1.buildHeaders)([{ 'OpenAI-Beta': 'assistants=v2' }, options?.headers]), }); } createAndRun(body, options) { return this._client.post('/threads/runs', { body, ...options, headers: (0, headers_1.buildHeaders)([{ 'OpenAI-Beta': 'assistants=v2' }, options?.headers]), stream: body.stream ?? false, }); } /** * A helper to create a thread, start a run and then poll for a terminal state. * More information on Run lifecycles can be found here: * https://platform.openai.com/docs/assistants/how-it-works/runs-and-run-steps */ async createAndRunPoll(body, options) { const run = await this.createAndRun(body, options); return await this.runs.poll(run.id, { thread_id: run.thread_id }, options); } /** * Create a thread and stream the run back */ createAndRunStream(body, options) { return AssistantStream_1.AssistantStream.createThreadAssistantStream(body, this._client.beta.threads, options); } } exports.Threads = Threads; Threads.Runs = runs_1.Runs; Threads.Messages = messages_1.Messages; //# sourceMappingURL=threads.js.map