2025-11-13 13:13:34 -07:00

92 lines
3.3 KiB
JavaScript

"use strict";
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
Object.defineProperty(exports, "__esModule", { value: true });
exports.AudioSinglePage = exports.AudioTracks = void 0;
const resource_1 = require("../../resource.js");
const pagination_1 = require("../../pagination.js");
class AudioTracks extends resource_1.APIResource {
/**
* Deletes additional audio tracks on a video. Deleting a default audio track is
* not allowed. You must assign another audio track as default prior to deletion.
*
* @example
* ```ts
* const audioTrack = await client.stream.audioTracks.delete(
* 'ea95132c15732412d22c1476fa83f27a',
* 'ea95132c15732412d22c1476fa83f27a',
* { account_id: '023e105f4ecef8ad9ca31a8372d0c353' },
* );
* ```
*/
delete(identifier, audioIdentifier, params, options) {
const { account_id } = params;
return this._client.delete(`/accounts/${account_id}/stream/${identifier}/audio/${audioIdentifier}`, options)._thenUnwrap((obj) => obj.result);
}
/**
* Adds an additional audio track to a video using the provided audio track URL.
*
* @example
* ```ts
* const audio = await client.stream.audioTracks.copy(
* 'ea95132c15732412d22c1476fa83f27a',
* {
* account_id: '023e105f4ecef8ad9ca31a8372d0c353',
* label: 'director commentary',
* },
* );
* ```
*/
copy(identifier, params, options) {
const { account_id, ...body } = params;
return this._client.post(`/accounts/${account_id}/stream/${identifier}/audio/copy`, {
body,
...options,
})._thenUnwrap((obj) => obj.result);
}
/**
* Edits additional audio tracks on a video. Editing the default status of an audio
* track to `true` will mark all other audio tracks on the video default status to
* `false`.
*
* @example
* ```ts
* const audio = await client.stream.audioTracks.edit(
* 'ea95132c15732412d22c1476fa83f27a',
* 'ea95132c15732412d22c1476fa83f27a',
* { account_id: '023e105f4ecef8ad9ca31a8372d0c353' },
* );
* ```
*/
edit(identifier, audioIdentifier, params, options) {
const { account_id, ...body } = params;
return this._client.patch(`/accounts/${account_id}/stream/${identifier}/audio/${audioIdentifier}`, {
body,
...options,
})._thenUnwrap((obj) => obj.result);
}
/**
* Lists additional audio tracks on a video. Note this API will not return
* information for audio attached to the video upload.
*
* @example
* ```ts
* // Automatically fetches more pages as needed.
* for await (const audio of client.stream.audioTracks.get(
* 'ea95132c15732412d22c1476fa83f27a',
* { account_id: '023e105f4ecef8ad9ca31a8372d0c353' },
* )) {
* // ...
* }
* ```
*/
get(identifier, params, options) {
const { account_id } = params;
return this._client.getAPIList(`/accounts/${account_id}/stream/${identifier}/audio`, AudioSinglePage, options);
}
}
exports.AudioTracks = AudioTracks;
class AudioSinglePage extends pagination_1.SinglePage {
}
exports.AudioSinglePage = AudioSinglePage;
AudioTracks.AudioSinglePage = AudioSinglePage;
//# sourceMappingURL=audio-tracks.js.map