-import { VideoChannel } from './video-channel.model'
-
-export interface VideoFile {
- magnetUri: string
- resolution: number
- resolutionLabel: string
- size: number // Bytes
- torrentUrl: string
- fileUrl: string
-}
+import { AccountSummary, VideoChannelSummary, VideoState } from '../../index'
+import { Account } from '../actors'
+import { VideoChannel } from './channel/video-channel.model'
+import { VideoPrivacy } from './video-privacy.enum'
+import { VideoScheduleUpdate } from './video-schedule-update.model'
+import { VideoConstant } from './video-constant.model'
+import { VideoStreamingPlaylist } from './video-streaming-playlist.model'
+import { VideoFile } from './video-file.model'
export interface Video {
id: number
uuid: string
- author: string
createdAt: Date | string
updatedAt: Date | string
- categoryLabel: string
- category: number
- licenceLabel: string
- licence: number
- languageLabel: string
- language: number
+ publishedAt: Date | string
+ originallyPublishedAt: Date | string
+ category: VideoConstant<number>
+ licence: VideoConstant<number>
+ language: VideoConstant<string>
+ privacy: VideoConstant<VideoPrivacy>
description: string
duration: number
isLocal: boolean
name: string
- podHost: string
- tags: string[]
thumbnailPath: string
previewPath: string
embedPath: string
likes: number
dislikes: number
nsfw: boolean
+
+ waitTranscoding?: boolean
+ state?: VideoConstant<VideoState>
+ scheduledUpdate?: VideoScheduleUpdate
+
+ blacklisted?: boolean
+ blacklistedReason?: string
+
+ account: AccountSummary
+ channel: VideoChannelSummary
+
+ userHistory?: {
+ currentTime: number
+ }
}
export interface VideoDetails extends Video {
+ descriptionPath: string
+ support: string
channel: VideoChannel
+ account: Account
+ tags: string[]
files: VideoFile[]
+ commentsEnabled: boolean
+ downloadEnabled: boolean
+
+ // Not optional in details (unlike in Video)
+ waitTranscoding: boolean
+ state: VideoConstant<VideoState>
+
+ trackerUrls: string[]
+
+ streamingPlaylists: VideoStreamingPlaylist[]
}