X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=shared%2Fmodels%2Fvideos%2Fvideo.model.ts;h=26cb595e73ab0acf305ca41f7c04e72d3d3fcac3;hb=3c10840fa90fc88fc98e8169faf4745ff6c80893;hp=1c86545d39982c07f8717c48db0ce980aa1a5037;hpb=02756fbd11190e75b8bed9fad5751027e2e0de49;p=github%2FChocobozzz%2FPeerTube.git diff --git a/shared/models/videos/video.model.ts b/shared/models/videos/video.model.ts index 1c86545d3..26cb595e7 100644 --- a/shared/models/videos/video.model.ts +++ b/shared/models/videos/video.model.ts @@ -1,30 +1,21 @@ -import { VideoResolution } from '../../index' -import { Account } from '../actors' -import { Avatar } from '../avatars/avatar.model' -import { VideoChannel } from './video-channel.model' +import { Account, AccountSummary } from '../actors' +import { VideoChannel, VideoChannelSummary } from './channel/video-channel.model' +import { VideoConstant } from './video-constant.model' +import { VideoFile } from './video-file.model' import { VideoPrivacy } from './video-privacy.enum' - -export interface VideoConstant { - id: T - label: string -} - -export interface VideoFile { - magnetUri: string - resolution: VideoConstant - size: number // Bytes - torrentUrl: string - torrentDownloadUrl: string - fileUrl: string - fileDownloadUrl: string -} +import { VideoScheduleUpdate } from './video-schedule-update.model' +import { VideoState } from './video-state.enum' +import { VideoStreamingPlaylist } from './video-streaming-playlist.model' export interface Video { id: number uuid: string + shortUUID: string + createdAt: Date | string updatedAt: Date | string publishedAt: Date | string + originallyPublishedAt: Date | string category: VideoConstant licence: VideoConstant language: VideoConstant @@ -33,41 +24,64 @@ export interface Video { duration: number isLocal: boolean name: string + + isLive: boolean + thumbnailPath: string + thumbnailUrl?: string + previewPath: string + previewUrl?: string + embedPath: string + embedUrl?: string + + url: string + views: number likes: number dislikes: number nsfw: boolean - account: { - id: number - uuid: string - name: string - displayName: string - url: string - host: string - avatar: Avatar - } + account: AccountSummary + channel: VideoChannelSummary - channel: { - id: number - uuid: string - name: string - displayName: string - url: string - host: string - avatar: Avatar + userHistory?: { + currentTime: number } + + pluginData?: any + + // Additional attributes dependending on the query + waitTranscoding?: boolean + state?: VideoConstant + scheduledUpdate?: VideoScheduleUpdate + + blacklisted?: boolean + blacklistedReason?: string + + blockedOwner?: boolean + blockedServer?: boolean + + files?: VideoFile[] + streamingPlaylists?: VideoStreamingPlaylist[] } export interface VideoDetails extends Video { descriptionPath: string support: string channel: VideoChannel - tags: string[] - files: VideoFile[] account: Account + tags: string[] commentsEnabled: boolean + downloadEnabled: boolean + + // Not optional in details (unlike in parent Video) + waitTranscoding: boolean + state: VideoConstant + + trackerUrls: string[] + + files: VideoFile[] + streamingPlaylists: VideoStreamingPlaylist[] }