X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fhelpers%2Fvideo.ts;h=907564703b7f4a9097b216dd15ef39449da8ff97;hb=7eba5e1fa81c8e54cb8fe298a96e8070afa50921;hp=b1577a6b0911f14614cf063d964a8fafadcfdb70;hpb=0491173a61aed66205c017e0d7e0503ea316c144;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/helpers/video.ts b/server/helpers/video.ts index b1577a6b0..907564703 100644 --- a/server/helpers/video.ts +++ b/server/helpers/video.ts @@ -1,9 +1,37 @@ import { VideoModel } from '../models/video/video' +import * as Bluebird from 'bluebird' +import { + MVideoAccountLightBlacklistAllFiles, + MVideoFullLight, + MVideoIdThumbnail, + MVideoThumbnail, + MVideoWithRights, + MVideoImmutable +} from '@server/typings/models' +import { Response } from 'express' -type VideoFetchType = 'all' | 'only-video' | 'id' | 'none' +type VideoFetchType = 'all' | 'only-video' | 'only-video-with-rights' | 'id' | 'none' | 'only-immutable-attributes' -function fetchVideo (id: number | string, fetchType: VideoFetchType) { - if (fetchType === 'all') return VideoModel.loadAndPopulateAccountAndServerAndTags(id) +function fetchVideo (id: number | string, fetchType: 'all', userId?: number): Bluebird +function fetchVideo (id: number | string, fetchType: 'only-immutable-attributes'): Bluebird +function fetchVideo (id: number | string, fetchType: 'only-video', userId?: number): Bluebird +function fetchVideo (id: number | string, fetchType: 'only-video-with-rights', userId?: number): Bluebird +function fetchVideo (id: number | string, fetchType: 'id' | 'none', userId?: number): Bluebird +function fetchVideo ( + id: number | string, + fetchType: VideoFetchType, + userId?: number +): Bluebird +function fetchVideo ( + id: number | string, + fetchType: VideoFetchType, + userId?: number +): Bluebird { + if (fetchType === 'all') return VideoModel.loadAndPopulateAccountAndServerAndTags(id, undefined, userId) + + if (fetchType === 'only-immutable-attributes') return VideoModel.loadImmutableAttributes(id) + + if (fetchType === 'only-video-with-rights') return VideoModel.loadWithRights(id) if (fetchType === 'only-video') return VideoModel.load(id) @@ -11,15 +39,24 @@ function fetchVideo (id: number | string, fetchType: VideoFetchType) { } type VideoFetchByUrlType = 'all' | 'only-video' -function fetchVideoByUrl (url: string, fetchType: VideoFetchByUrlType) { + +function fetchVideoByUrl (url: string, fetchType: 'all'): Bluebird +function fetchVideoByUrl (url: string, fetchType: 'only-video'): Bluebird +function fetchVideoByUrl (url: string, fetchType: VideoFetchByUrlType): Bluebird +function fetchVideoByUrl (url: string, fetchType: VideoFetchByUrlType): Bluebird { if (fetchType === 'all') return VideoModel.loadByUrlAndPopulateAccount(url) if (fetchType === 'only-video') return VideoModel.loadByUrl(url) } +function getVideoWithAttributes (res: Response) { + return res.locals.videoAll || res.locals.onlyVideo || res.locals.onlyVideoWithRights +} + export { VideoFetchType, VideoFetchByUrlType, fetchVideo, + getVideoWithAttributes, fetchVideoByUrl }