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
 |