UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

176 lines (154 loc) 4.75 kB
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import { APIResource } from '../../resource'; import * as Core from '../../core'; import { SinglePage } from '../../pagination'; 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<AudioTrackDeleteResponse> { 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<Audio> { const { account_id, ...body } = params; return ( this._client.post(`/accounts/${account_id}/stream/${identifier}/audio/copy`, { body, ...options, }) as Core.APIPromise<{ result: Audio }> )._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<Audio> { const { account_id, ...body } = params; return ( this._client.patch(`/accounts/${account_id}/stream/${identifier}/audio/${audioIdentifier}`, { body, ...options, }) as Core.APIPromise<{ result: Audio }> )._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.PagePromise<AudioSinglePage, Audio> { const { account_id } = params; return this._client.getAPIList( `/accounts/${account_id}/stream/${identifier}/audio`, AudioSinglePage, options, ); } } export class AudioSinglePage extends SinglePage<Audio> {} export interface Audio { /** * 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 = string; 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; } AudioTracks.AudioSinglePage = AudioSinglePage; export declare namespace AudioTracks { export { type Audio as Audio, type AudioTrackDeleteResponse as AudioTrackDeleteResponse, AudioSinglePage as AudioSinglePage, type AudioTrackDeleteParams as AudioTrackDeleteParams, type AudioTrackCopyParams as AudioTrackCopyParams, type AudioTrackEditParams as AudioTrackEditParams, type AudioTrackGetParams as AudioTrackGetParams, }; }