import { ContextType } from '../activitypub/context'
-import { VideoResolution } from '../videos/video-resolution.enum'
+import { VideoState } from '../videos'
+import { VideoStudioTaskCut } from '../videos/studio'
+import { VideoResolution } from '../videos/file/video-resolution.enum'
import { SendEmailOptions } from './emailer.model'
-export type JobState = 'active' | 'completed' | 'failed' | 'waiting' | 'delayed'
+export type JobState = 'active' | 'completed' | 'failed' | 'waiting' | 'delayed' | 'paused'
export type JobType =
| 'activitypub-http-unicast'
| 'activitypub-http-broadcast'
+ | 'activitypub-http-broadcast-parallel'
| 'activitypub-http-fetcher'
+ | 'activitypub-cleaner'
| 'activitypub-follow'
| 'video-file-import'
| 'video-transcoding'
| 'email'
| 'video-import'
- | 'videos-views'
+ | 'videos-views-stats'
| 'activitypub-refresher'
| 'video-redundancy'
| 'video-live-ending'
+ | 'actor-keys'
+ | 'manage-video-torrent'
+ | 'move-to-object-storage'
+ | 'video-studio-edition'
export interface Job {
id: number
state: JobState
type: JobType
data: any
+ priority: number
+ progress: number
error: any
createdAt: Date | string
finishedOn: Date | string
export type ActivitypubHttpBroadcastPayload = {
uris: string[]
- signatureActorId?: number
+ contextType: ContextType
body: any
- contextType?: ContextType
+ signatureActorId?: number
}
export type ActivitypubFollowPayload = {
assertIsChannel?: boolean
}
-export type FetchType = 'activity' | 'video-likes' | 'video-dislikes' | 'video-shares' | 'video-comments' | 'account-playlists'
+export type FetchType = 'activity' | 'video-shares' | 'video-comments' | 'account-playlists'
export type ActivitypubHttpFetcherPayload = {
uri: string
type: FetchType
videoId?: number
- accountId?: number
}
export type ActivitypubHttpUnicastPayload = {
uri: string
+ contextType: ContextType
signatureActorId?: number
- body: any
- contextType?: ContextType
+ body: object
}
export type RefreshPayload = {
type: VideoImportYoutubeDLPayloadType
videoImportId: number
- generateThumbnail: boolean
- generatePreview: boolean
-
fileExt?: string
}
export type VideoImportTorrentPayload = {
videoId: number
}
+export type ManageVideoTorrentPayload =
+ {
+ action: 'create'
+ videoId: number
+ videoFileId: number
+ } | {
+ action: 'update-metadata'
+
+ videoId?: number
+ streamingPlaylistId?: number
+
+ videoFileId: number
+ }
+
// Video transcoding payloads
interface BaseTranscodingPayload {
isNewVideo?: boolean
}
-interface HLSTranscodingPayload extends BaseTranscodingPayload {
- type: 'hls'
- isPortraitMode?: boolean
+export interface HLSTranscodingPayload extends BaseTranscodingPayload {
+ type: 'new-resolution-to-hls'
resolution: VideoResolution
copyCodecs: boolean
-}
-export interface NewResolutionTranscodingPayload extends BaseTranscodingPayload {
- type: 'new-resolution'
+ hasAudio: boolean
isPortraitMode?: boolean
+
+ autoDeleteWebTorrentIfNeeded: boolean
+ isMaxQuality: boolean
+}
+
+export interface NewWebTorrentResolutionTranscodingPayload extends BaseTranscodingPayload {
+ type: 'new-resolution-to-webtorrent'
resolution: VideoResolution
+
+ hasAudio: boolean
+ createHLSIfNeeded: boolean
+
+ isPortraitMode?: boolean
}
export interface MergeAudioTranscodingPayload extends BaseTranscodingPayload {
- type: 'merge-audio'
+ type: 'merge-audio-to-webtorrent'
resolution: VideoResolution
+ createHLSIfNeeded: true
}
export interface OptimizeTranscodingPayload extends BaseTranscodingPayload {
- type: 'optimize'
+ type: 'optimize-to-webtorrent'
}
export type VideoTranscodingPayload =
HLSTranscodingPayload
- | NewResolutionTranscodingPayload
+ | NewWebTorrentResolutionTranscodingPayload
| OptimizeTranscodingPayload
| MergeAudioTranscodingPayload
export interface VideoLiveEndingPayload {
videoId: number
+ publishedAt: string
+ liveSessionId: number
+ streamingPlaylistId: number
+
+ replayDirectory?: string
+}
+
+export interface ActorKeysPayload {
+ actorId: number
+}
+
+export interface DeleteResumableUploadMetaFilePayload {
+ filepath: string
+}
+
+export interface MoveObjectStoragePayload {
+ videoUUID: string
+ isNewVideo: boolean
+ previousVideoState: VideoState
+}
+
+export type VideoStudioTaskCutPayload = VideoStudioTaskCut
+
+export type VideoStudioTaskIntroPayload = {
+ name: 'add-intro'
+
+ options: {
+ file: string
+ }
+}
+
+export type VideoStudioTaskOutroPayload = {
+ name: 'add-outro'
+
+ options: {
+ file: string
+ }
+}
+
+export type VideoStudioTaskWatermarkPayload = {
+ name: 'add-watermark'
+
+ options: {
+ file: string
+ }
+}
+
+export type VideoStudioTaskPayload =
+ VideoStudioTaskCutPayload |
+ VideoStudioTaskIntroPayload |
+ VideoStudioTaskOutroPayload |
+ VideoStudioTaskWatermarkPayload
+
+export interface VideoStudioEditionPayload {
+ videoUUID: string
+ tasks: VideoStudioTaskPayload[]
}