-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<VideoResolution>
- 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
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<VideoState>
scheduledUpdate?: VideoScheduleUpdate
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<VideoState>
trackerUrls: string[]
+ files: VideoFile[]
streamingPlaylists: VideoStreamingPlaylist[]
}