// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import * as Core from 'cloudflare/core'; import { APIResource } from 'cloudflare/resource'; import * as AudioTracksAPI from 'cloudflare/resources/stream/audio-tracks'; export class AudioTracks extends 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. */ delete( identifier: string, audioIdentifier: string, params: AudioTrackDeleteParams, options?: Core.RequestOptions, ): Core.APIPromise { const { account_id } = params; return ( this._client.delete( `/accounts/${account_id}/stream/${identifier}/audio/${audioIdentifier}`, options, ) as Core.APIPromise<{ result: AudioTrackDeleteResponse }> )._thenUnwrap((obj) => obj.result); } /** * Adds an additional audio track to a video using the provided audio track URL. */ copy( identifier: string, params: AudioTrackCopyParams, options?: Core.RequestOptions, ): Core.APIPromise { const { account_id, ...body } = params; return ( this._client.post(`/accounts/${account_id}/stream/${identifier}/audio/copy`, { body, ...options, }) as Core.APIPromise<{ result: StreamAudio }> )._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`. */ edit( identifier: string, audioIdentifier: string, params: AudioTrackEditParams, options?: Core.RequestOptions, ): Core.APIPromise { const { account_id, ...body } = params; return ( this._client.patch(`/accounts/${account_id}/stream/${identifier}/audio/${audioIdentifier}`, { body, ...options, }) as Core.APIPromise<{ result: StreamAudio }> )._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. */ get( identifier: string, params: AudioTrackGetParams, options?: Core.RequestOptions, ): Core.APIPromise { const { account_id } = params; return ( this._client.get(`/accounts/${account_id}/stream/${identifier}/audio`, options) as Core.APIPromise<{ result: AudioTrackGetResponse; }> )._thenUnwrap((obj) => obj.result); } } export interface StreamAudio { /** * Denotes whether the audio track will be played by default in a player. */ default?: boolean; /** * A string to uniquely identify the track amongst other audio track labels for the * specified video. */ label?: string; /** * Specifies the processing status of the video. */ status?: 'queued' | 'ready' | 'error'; /** * A Cloudflare-generated unique identifier for a media item. */ uid?: string; } export type AudioTrackDeleteResponse = unknown | string; export type AudioTrackGetResponse = Array; export interface AudioTrackDeleteParams { /** * The account identifier tag. */ account_id: string; } export interface AudioTrackCopyParams { /** * Path param: The account identifier tag. */ account_id: string; /** * Body param: A string to uniquely identify the track amongst other audio track * labels for the specified video. */ label: string; /** * Body param: An audio track URL. The server must be publicly routable and support * `HTTP HEAD` requests and `HTTP GET` range requests. The server should respond to * `HTTP HEAD` requests with a `content-range` header that includes the size of the * file. */ url?: string; } export interface AudioTrackEditParams { /** * Path param: The account identifier tag. */ account_id: string; /** * Body param: Denotes whether the audio track will be played by default in a * player. */ default?: boolean; /** * Body param: A string to uniquely identify the track amongst other audio track * labels for the specified video. */ label?: string; } export interface AudioTrackGetParams { /** * The account identifier tag. */ account_id: string; } export namespace AudioTracks { export import StreamAudio = AudioTracksAPI.StreamAudio; export import AudioTrackDeleteResponse = AudioTracksAPI.AudioTrackDeleteResponse; export import AudioTrackGetResponse = AudioTracksAPI.AudioTrackGetResponse; export import AudioTrackDeleteParams = AudioTracksAPI.AudioTrackDeleteParams; export import AudioTrackCopyParams = AudioTracksAPI.AudioTrackCopyParams; export import AudioTrackEditParams = AudioTracksAPI.AudioTrackEditParams; export import AudioTrackGetParams = AudioTracksAPI.AudioTrackGetParams; }