import { openapiOperationDoc } from '@server/middlewares/doc'
import { FilteredModelAttributes } from '@server/types'
import { MVideoFullLight } from '@server/types/models'
-import { VideoUpdate } from '../../../../shared'
-import { HttpStatusCode } from '../../../../shared/models'
+import { HttpStatusCode, VideoUpdate } from '@shared/models'
import { auditLoggerFactory, getAuditIdFromRes, VideoAuditView } from '../../../helpers/audit-logger'
import { resetSequelizeInstance } from '../../../helpers/database-utils'
import { createReqFiles } from '../../../helpers/express-utils'
})
try {
- const videoInstanceUpdated = await sequelizeTypescript.transaction(async t => {
+ const { videoInstanceUpdated, isNewVideo } = await sequelizeTypescript.transaction(async t => {
// Refresh video since thumbnails to prevent concurrent updates
const video = await VideoModel.loadAndPopulateAccountAndServerAndTags(videoFromReq.id, t)
transaction: t
})
- await federateVideoIfNeeded(videoInstanceUpdated, isNewVideo, t)
-
auditLogger.update(
getAuditIdFromRes(res),
new VideoAuditView(videoInstanceUpdated.toFormattedDetailsJSON()),
)
logger.info('Video with name %s and uuid %s updated.', video.name, video.uuid, lTags(video.uuid))
- return videoInstanceUpdated
+ return { videoInstanceUpdated, isNewVideo }
})
if (videoInfoToUpdate.name) await updateTorrentsMetadata(videoInstanceUpdated)
+
+ await sequelizeTypescript.transaction(t => federateVideoIfNeeded(videoInstanceUpdated, isNewVideo, t))
+
if (wasConfidentialVideo) Notifier.Instance.notifyOnNewVideoIfNeeded(videoInstanceUpdated)
Hooks.runAction('action:api.video.updated', { video: videoInstanceUpdated, body: req.body, req, res })
}
async function updateTorrentsMetadata (video: MVideoFullLight) {
- for (const file of video.getAllFiles()) {
+ for (const file of (video.VideoFiles || [])) {
await updateTorrentMetadata(video, file)
+
+ await file.save()
+ }
+
+ const hls = video.getHLSPlaylist()
+ if (!hls) return
+
+ for (const file of (hls.VideoFiles || [])) {
+ await updateTorrentMetadata(hls, file)
+
+ await file.save()
}
}