91 lines
3.2 KiB
JavaScript
91 lines
3.2 KiB
JavaScript
|
|
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
||
|
|
import { APIResource } from "../../../core/resource.mjs";
|
||
|
|
import * as MessagesAPI from "./messages.mjs";
|
||
|
|
import { Messages, } from "./messages.mjs";
|
||
|
|
import * as RunsAPI from "./runs/runs.mjs";
|
||
|
|
import { Runs, } from "./runs/runs.mjs";
|
||
|
|
import { buildHeaders } from "../../../internal/headers.mjs";
|
||
|
|
import { AssistantStream } from "../../../lib/AssistantStream.mjs";
|
||
|
|
import { path } from "../../../internal/utils/path.mjs";
|
||
|
|
/**
|
||
|
|
* @deprecated The Assistants API is deprecated in favor of the Responses API
|
||
|
|
*/
|
||
|
|
export class Threads extends 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: 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(path `/threads/${threadID}`, {
|
||
|
|
...options,
|
||
|
|
headers: 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(path `/threads/${threadID}`, {
|
||
|
|
body,
|
||
|
|
...options,
|
||
|
|
headers: 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(path `/threads/${threadID}`, {
|
||
|
|
...options,
|
||
|
|
headers: buildHeaders([{ 'OpenAI-Beta': 'assistants=v2' }, options?.headers]),
|
||
|
|
});
|
||
|
|
}
|
||
|
|
createAndRun(body, options) {
|
||
|
|
return this._client.post('/threads/runs', {
|
||
|
|
body,
|
||
|
|
...options,
|
||
|
|
headers: 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.createThreadAssistantStream(body, this._client.beta.threads, options);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
Threads.Runs = Runs;
|
||
|
|
Threads.Messages = Messages;
|
||
|
|
//# sourceMappingURL=threads.mjs.map
|