X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=shared%2Fmodels%2Fvideos%2Fvideo.model.ts;h=f98eed012f2b3c22146e977beda7d80114e24f38;hb=d2d4a5a999746ae0f01a2ce89b844252346bab27;hp=963268674c2129d29255f8b1499e9a87a4c63cd5;hpb=97567dd81f508dd6295ac4d73d849aa2ce0a6549;p=github%2FChocobozzz%2FPeerTube.git diff --git a/shared/models/videos/video.model.ts b/shared/models/videos/video.model.ts index 963268674..f98eed012 100644 --- a/shared/models/videos/video.model.ts +++ b/shared/models/videos/video.model.ts @@ -1,32 +1,17 @@ -import { AccountSummary, VideoChannelSummary, VideoResolution, VideoState } from '../../index' -import { Account } from '../actors' -import { Avatar } from '../avatars/avatar.model' -import { VideoChannel } from './channel/video-channel.model' +import { Account, AccountSummary } from '../actors' +import { VideoChannel, VideoChannelSummary } from './channel/video-channel.model' +import { VideoFile } from './file' +import { VideoConstant } from './video-constant.model' import { VideoPrivacy } from './video-privacy.enum' import { VideoScheduleUpdate } from './video-schedule-update.model' -import { VideoConstant } from './video-constant.model' +import { VideoState } from './video-state.enum' import { VideoStreamingPlaylist } from './video-streaming-playlist.model' -export interface VideoFile { - magnetUri: string - resolution: VideoConstant - size: number // Bytes - torrentUrl: string - torrentDownloadUrl: string - fileUrl: string - fileDownloadUrl: string - fps: number -} - -export interface PlaylistElement { - position: number - startTimestamp: number - stopTimestamp: number -} - export interface Video { id: number uuid: string + shortUUID: string + createdAt: Date | string updatedAt: Date | string publishedAt: Date | string @@ -39,14 +24,38 @@ 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 + // If live + viewers?: number + likes: number dislikes: number nsfw: boolean + account: AccountSummary + channel: VideoChannelSummary + + userHistory?: { + currentTime: number + } + + pluginData?: any + + // Additional attributes dependending on the query waitTranscoding?: boolean state?: VideoConstant scheduledUpdate?: VideoScheduleUpdate @@ -54,31 +63,28 @@ export interface Video { blacklisted?: boolean blacklistedReason?: string - account: AccountSummary - channel: VideoChannelSummary - - userHistory?: { - currentTime: number - } + blockedOwner?: boolean + blockedServer?: boolean - playlistElement?: PlaylistElement + 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 Video) + // Not optional in details (unlike in parent Video) waitTranscoding: boolean state: VideoConstant trackerUrls: string[] + files: VideoFile[] streamingPlaylists: VideoStreamingPlaylist[] }