ac907dc7c1
More precise, avoid weird decrease, reuse an id to federate viewers
42 lines
1.4 KiB
TypeScript
42 lines
1.4 KiB
TypeScript
import { VideoViewsManager } from '@server/lib/views/video-views-manager'
|
|
import { ActivityView } from '../../../../shared/models/activitypub'
|
|
import { APProcessorOptions } from '../../../types/activitypub-processor.model'
|
|
import { MActorSignature } from '../../../types/models'
|
|
import { forwardVideoRelatedActivity } from '../send/shared/send-utils'
|
|
import { getOrCreateAPVideo } from '../videos'
|
|
|
|
async function processViewActivity (options: APProcessorOptions<ActivityView>) {
|
|
const { activity, byActor } = options
|
|
|
|
return processCreateView(activity, byActor)
|
|
}
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
export {
|
|
processViewActivity
|
|
}
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
async function processCreateView (activity: ActivityView, byActor: MActorSignature) {
|
|
const videoObject = activity.object
|
|
|
|
const { video } = await getOrCreateAPVideo({
|
|
videoObject,
|
|
fetchType: 'only-video',
|
|
allowRefresh: false
|
|
})
|
|
|
|
const viewerExpires = activity.expires
|
|
? new Date(activity.expires)
|
|
: undefined
|
|
|
|
await VideoViewsManager.Instance.processRemoteView({ video, viewerId: activity.id, viewerExpires })
|
|
|
|
if (video.isOwned()) {
|
|
// Forward the view but don't resend the activity to the sender
|
|
const exceptions = [ byActor ]
|
|
await forwardVideoRelatedActivity(activity, undefined, exceptions, video)
|
|
}
|
|
}
|