
* Add server endpoints * Refactoring test suites * Update server and add openapi documentation * fix compliation and tests * upload/import password protected video on client * add server error code * Add video password to update resolver * add custom message when sharing pw protected video * improve confirm component * Add new alert in component * Add ability to watch protected video on client * Cannot have password protected replay privacy * Add migration * Add tests * update after review * Update check params tests * Add live videos test * Add more filter test * Update static file privacy test * Update object storage tests * Add test on feeds * Add missing word * Fix tests * Fix tests on live videos * add embed support on password protected videos * fix style * Correcting data leaks * Unable to add password protected privacy on replay * Updated code based on review comments * fix validator and command * Updated code based on review comments
35 lines
989 B
TypeScript
35 lines
989 B
TypeScript
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/no-floating-promises */
|
|
|
|
import { HttpStatusCode, VideoToken } from '@shared/models'
|
|
import { unwrapBody } from '../requests'
|
|
import { AbstractCommand, OverrideCommandOptions } from '../shared'
|
|
|
|
export class VideoTokenCommand extends AbstractCommand {
|
|
|
|
create (options: OverrideCommandOptions & {
|
|
videoId: number | string
|
|
videoPassword?: string
|
|
}) {
|
|
const { videoId, videoPassword } = options
|
|
const path = '/api/v1/videos/' + videoId + '/token'
|
|
|
|
return unwrapBody<VideoToken>(this.postBodyRequest({
|
|
...options,
|
|
headers: this.buildVideoPasswordHeader(videoPassword),
|
|
|
|
path,
|
|
implicitToken: true,
|
|
defaultExpectedStatus: HttpStatusCode.OK_200
|
|
}))
|
|
}
|
|
|
|
async getVideoFileToken (options: OverrideCommandOptions & {
|
|
videoId: number | string
|
|
videoPassword?: string
|
|
}) {
|
|
const { files } = await this.create(options)
|
|
|
|
return files.token
|
|
}
|
|
}
|