PeerTube/server/helpers/video.ts

59 lines
2.4 KiB
TypeScript
Raw Normal View History

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