PeerTube/server/helpers/video.ts

72 lines
2.9 KiB
TypeScript
Raw Normal View History

2018-09-19 04:16:23 -05:00
import { VideoModel } from '../models/video/video'
2019-08-15 04:53:26 -05:00
import * as Bluebird from 'bluebird'
2019-08-20 06:52:49 -05:00
import {
MVideoAccountLightBlacklistAllFiles,
MVideoFullLight,
MVideoIdThumbnail,
MVideoThumbnail,
MVideoWithRights,
MVideoImmutable
2019-08-20 06:52:49 -05:00
} from '@server/typings/models'
2019-08-15 04:53:26 -05:00
import { Response } from 'express'
2018-09-19 04:16:23 -05:00
type VideoFetchType = 'all' | 'only-video' | 'only-video-with-rights' | 'id' | 'none' | 'only-immutable-attributes'
2018-09-19 04:16:23 -05:00
2019-08-15 04:53:26 -05:00
function fetchVideo (id: number | string, fetchType: 'all', userId?: number): Bluebird<MVideoFullLight>
function fetchVideo (id: number | string, fetchType: 'only-immutable-attributes'): Bluebird<MVideoImmutable>
2019-08-15 04:53:26 -05:00
function fetchVideo (id: number | string, fetchType: 'only-video', userId?: number): Bluebird<MVideoThumbnail>
function fetchVideo (id: number | string, fetchType: 'only-video-with-rights', userId?: number): Bluebird<MVideoWithRights>
function fetchVideo (id: number | string, fetchType: 'id' | 'none', userId?: number): Bluebird<MVideoIdThumbnail>
function fetchVideo (
id: number | string,
fetchType: VideoFetchType,
userId?: number
): Bluebird<MVideoFullLight | MVideoThumbnail | MVideoWithRights | MVideoIdThumbnail | MVideoImmutable>
2019-08-15 04:53:26 -05:00
function fetchVideo (
id: number | string,
fetchType: VideoFetchType,
userId?: number
): Bluebird<MVideoFullLight | MVideoThumbnail | MVideoWithRights | MVideoIdThumbnail | MVideoImmutable> {
2018-10-05 04:15:06 -05:00
if (fetchType === 'all') return VideoModel.loadAndPopulateAccountAndServerAndTags(id, undefined, userId)
2018-09-19 04:16:23 -05:00
if (fetchType === 'only-immutable-attributes') return VideoModel.loadImmutableAttributes(id)
2019-01-29 01:37:25 -06:00
if (fetchType === 'only-video-with-rights') return VideoModel.loadWithRights(id)
2018-09-19 04:16:23 -05:00
if (fetchType === 'only-video') return VideoModel.load(id)
if (fetchType === 'id' || fetchType === 'none') return VideoModel.loadOnlyId(id)
}
type VideoFetchByUrlType = 'all' | 'only-video' | 'only-immutable-attributes'
2019-08-15 04:53:26 -05:00
2019-08-20 06:52:49 -05:00
function fetchVideoByUrl (url: string, fetchType: 'all'): Bluebird<MVideoAccountLightBlacklistAllFiles>
function fetchVideoByUrl (url: string, fetchType: 'only-immutable-attributes'): Bluebird<MVideoImmutable>
2019-08-15 04:53:26 -05:00
function fetchVideoByUrl (url: string, fetchType: 'only-video'): Bluebird<MVideoThumbnail>
function fetchVideoByUrl (
url: string,
fetchType: VideoFetchByUrlType
): Bluebird<MVideoAccountLightBlacklistAllFiles | MVideoThumbnail | MVideoImmutable>
function fetchVideoByUrl (
url: string,
fetchType: VideoFetchByUrlType
): Bluebird<MVideoAccountLightBlacklistAllFiles | MVideoThumbnail | MVideoImmutable> {
2018-09-19 04:16:23 -05:00
if (fetchType === 'all') return VideoModel.loadByUrlAndPopulateAccount(url)
if (fetchType === 'only-immutable-attributes') return VideoModel.loadByUrlImmutableAttributes(url)
2018-09-19 04:16:23 -05:00
if (fetchType === 'only-video') return VideoModel.loadByUrl(url)
}
2019-08-20 06:52:49 -05:00
function getVideoWithAttributes (res: Response) {
return res.locals.videoAll || res.locals.onlyVideo || res.locals.onlyVideoWithRights
}
2018-09-19 04:16:23 -05:00
export {
VideoFetchType,
VideoFetchByUrlType,
fetchVideo,
2019-08-20 06:52:49 -05:00
getVideoWithAttributes,
2018-09-19 04:16:23 -05:00
fetchVideoByUrl
}