import { generateMagnetUri } from '@server/helpers/webtorrent'
import { getActivityStreamDuration } from '@server/lib/activitypub/activity'
+import { tracer } from '@server/lib/opentelemetry/tracing'
import { getLocalVideoFileMetadataUrl } from '@server/lib/video-urls'
import { VideoViewsManager } from '@server/lib/views/video-views-manager'
import { uuidToShort } from '@shared/extra-utils'
import {
MServer,
MStreamingPlaylistRedundanciesOpt,
+ MUserId,
MVideo,
MVideoAP,
MVideoFile,
}
function guessAdditionalAttributesFromQuery (query: VideosCommonQueryAfterSanitize): VideoFormattingJSONOptions {
- if (!query || !query.include) return {}
+ if (!query?.include) return {}
return {
additionalAttributes: {
}
function videoModelToFormattedJSON (video: MVideoFormattable, options: VideoFormattingJSONOptions = {}): Video {
+ const span = tracer.startSpan('peertube.VideoModel.toFormattedJSON')
+
const userHistory = isArray(video.UserVideoHistories) ? video.UserVideoHistories[0] : undefined
const videoObject: Video = {
},
nsfw: video.nsfw,
+ truncatedDescription: video.getTruncatedDescription(),
description: options && options.completeDescription === true
? video.description
: video.getTruncatedDescription(),
videoObject.files = videoFilesModelToFormattedJSON(video, video.VideoFiles)
}
+ span.end()
+
return videoObject
}
function videoModelToFormattedDetailsJSON (video: MVideoFormattableDetails): VideoDetails {
+ const span = tracer.startSpan('peertube.VideoModel.toFormattedDetailsJSON')
+
const videoJSON = video.toFormattedJSON({
+ completeDescription: true,
additionalAttributes: {
scheduledUpdate: true,
blacklistInfo: true,
trackerUrls: video.getTrackerUrls()
}
+ span.end()
+
return Object.assign(videoJSON, detailsJSON)
}
function videoFilesModelToFormattedJSON (
video: MVideoFormattable,
videoFiles: MVideoFileRedundanciesOpt[],
- includeMagnet = true
+ options: {
+ includeMagnet?: boolean // default true
+ } = {}
): VideoFile[] {
+ const { includeMagnet = true } = options
+
const trackerUrls = includeMagnet
? video.getTrackerUrls()
: []
.sort(sortByResolutionDesc)
.map(videoFile => {
return {
+ id: videoFile.id,
+
resolution: {
id: videoFile.resolution,
label: videoFile.resolution === 0 ? 'Audio' : `${videoFile.resolution}p`
})
}
-function addVideoFilesInAPAcc (
- acc: ActivityUrlObject[] | ActivityTagObject[],
- video: MVideo,
+function addVideoFilesInAPAcc (options: {
+ acc: ActivityUrlObject[] | ActivityTagObject[]
+ video: MVideo
files: MVideoFile[]
-) {
+ user?: MUserId
+}) {
+ const { acc, video, files } = options
+
const trackerUrls = video.getTrackerUrls()
const sortedFiles = (files || [])
}
]
- addVideoFilesInAPAcc(url, video, video.VideoFiles || [])
+ addVideoFilesInAPAcc({ acc: url, video, files: video.VideoFiles || [] })
for (const playlist of (video.VideoStreamingPlaylists || [])) {
const tag = playlist.p2pMediaLoaderInfohashes
href: playlist.getSha256SegmentsUrl(video)
})
- addVideoFilesInAPAcc(tag, video, playlist.VideoFiles || [])
+ addVideoFilesInAPAcc({ acc: tag, video, files: playlist.VideoFiles || [] })
url.push({
type: 'Link',
}
function getCategoryLabel (id: number) {
- return VIDEO_CATEGORIES[id] || 'Misc'
+ return VIDEO_CATEGORIES[id] || 'Unknown'
}
function getLicenceLabel (id: number) {