61 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
 | 
						|
import { APIResource } from "../../core/resource.mjs";
 | 
						|
import * as PartsAPI from "./parts.mjs";
 | 
						|
import { Parts } from "./parts.mjs";
 | 
						|
import { path } from "../../internal/utils/path.mjs";
 | 
						|
export class Uploads extends APIResource {
 | 
						|
    constructor() {
 | 
						|
        super(...arguments);
 | 
						|
        this.parts = new PartsAPI.Parts(this._client);
 | 
						|
    }
 | 
						|
    /**
 | 
						|
     * Creates an intermediate
 | 
						|
     * [Upload](https://platform.openai.com/docs/api-reference/uploads/object) object
 | 
						|
     * that you can add
 | 
						|
     * [Parts](https://platform.openai.com/docs/api-reference/uploads/part-object) to.
 | 
						|
     * Currently, an Upload can accept at most 8 GB in total and expires after an hour
 | 
						|
     * after you create it.
 | 
						|
     *
 | 
						|
     * Once you complete the Upload, we will create a
 | 
						|
     * [File](https://platform.openai.com/docs/api-reference/files/object) object that
 | 
						|
     * contains all the parts you uploaded. This File is usable in the rest of our
 | 
						|
     * platform as a regular File object.
 | 
						|
     *
 | 
						|
     * For certain `purpose` values, the correct `mime_type` must be specified. Please
 | 
						|
     * refer to documentation for the
 | 
						|
     * [supported MIME types for your use case](https://platform.openai.com/docs/assistants/tools/file-search#supported-files).
 | 
						|
     *
 | 
						|
     * For guidance on the proper filename extensions for each purpose, please follow
 | 
						|
     * the documentation on
 | 
						|
     * [creating a File](https://platform.openai.com/docs/api-reference/files/create).
 | 
						|
     */
 | 
						|
    create(body, options) {
 | 
						|
        return this._client.post('/uploads', { body, ...options });
 | 
						|
    }
 | 
						|
    /**
 | 
						|
     * Cancels the Upload. No Parts may be added after an Upload is cancelled.
 | 
						|
     */
 | 
						|
    cancel(uploadID, options) {
 | 
						|
        return this._client.post(path `/uploads/${uploadID}/cancel`, options);
 | 
						|
    }
 | 
						|
    /**
 | 
						|
     * Completes the
 | 
						|
     * [Upload](https://platform.openai.com/docs/api-reference/uploads/object).
 | 
						|
     *
 | 
						|
     * Within the returned Upload object, there is a nested
 | 
						|
     * [File](https://platform.openai.com/docs/api-reference/files/object) object that
 | 
						|
     * is ready to use in the rest of the platform.
 | 
						|
     *
 | 
						|
     * You can specify the order of the Parts by passing in an ordered list of the Part
 | 
						|
     * IDs.
 | 
						|
     *
 | 
						|
     * The number of bytes uploaded upon completion must match the number of bytes
 | 
						|
     * initially specified when creating the Upload object. No Parts may be added after
 | 
						|
     * an Upload is completed.
 | 
						|
     */
 | 
						|
    complete(uploadID, body, options) {
 | 
						|
        return this._client.post(path `/uploads/${uploadID}/complete`, { body, ...options });
 | 
						|
    }
 | 
						|
}
 | 
						|
Uploads.Parts = Parts;
 | 
						|
//# sourceMappingURL=uploads.mjs.map
 |