import { AllowNull, BelongsTo, Column, CreatedAt, DataType, DefaultScope, ForeignKey, Model, Table, UpdatedAt } from 'sequelize-typescript'
+import { CONFIG } from '@server/initializers/config'
import { WEBSERVER } from '@server/initializers/constants'
import { MVideoLive, MVideoLiveVideo } from '@server/types/models'
-import { VideoLive } from '@shared/models/videos/video-live.model'
+import { LiveVideo, LiveVideoLatencyMode, VideoState } from '@shared/models'
+import { AttributesOnly } from '@shared/typescript-utils'
import { VideoModel } from './video'
+import { VideoBlacklistModel } from './video-blacklist'
@DefaultScope(() => ({
include: [
{
model: VideoModel,
- required: true
+ required: true,
+ include: [
+ {
+ model: VideoBlacklistModel,
+ required: false
+ }
+ ]
}
]
}))
}
]
})
-export class VideoLiveModel extends Model<VideoLiveModel> {
+export class VideoLiveModel extends Model<Partial<AttributesOnly<VideoLiveModel>>> {
- @AllowNull(false)
+ @AllowNull(true)
@Column(DataType.STRING)
streamKey: string
+ @AllowNull(false)
+ @Column
+ saveReplay: boolean
+
+ @AllowNull(false)
+ @Column
+ permanentLive: boolean
+
+ @AllowNull(false)
+ @Column
+ latencyMode: LiveVideoLatencyMode
+
@CreatedAt
createdAt: Date
const query = {
where: {
streamKey
- }
+ },
+ include: [
+ {
+ model: VideoModel.unscoped(),
+ required: true,
+ where: {
+ state: VideoState.WAITING_FOR_LIVE
+ },
+ include: [
+ {
+ model: VideoBlacklistModel.unscoped(),
+ required: false
+ }
+ ]
+ }
+ ]
}
return VideoLiveModel.findOne<MVideoLiveVideo>(query)
return VideoLiveModel.findOne<MVideoLive>(query)
}
- toFormattedJSON (): VideoLive {
+ toFormattedJSON (canSeePrivateInformation: boolean): LiveVideo {
+ let privateInformation: Pick<LiveVideo, 'rtmpUrl' | 'rtmpsUrl' | 'streamKey'> | {} = {}
+
+ // If we don't have a stream key, it means this is a remote live so we don't specify the rtmp URL
+ // We also display these private information only to the live owne/moderators
+ if (this.streamKey && canSeePrivateInformation === true) {
+ privateInformation = {
+ streamKey: this.streamKey,
+
+ rtmpUrl: CONFIG.LIVE.RTMP.ENABLED
+ ? WEBSERVER.RTMP_URL
+ : null,
+
+ rtmpsUrl: CONFIG.LIVE.RTMPS.ENABLED
+ ? WEBSERVER.RTMPS_URL
+ : null
+ }
+ }
+
return {
- rtmpUrl: WEBSERVER.RTMP_URL,
- streamKey: this.streamKey
+ ...privateInformation,
+
+ permanentLive: this.permanentLive,
+ saveReplay: this.saveReplay,
+ latencyMode: this.latencyMode
}
}
}