123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- import { VideoRedundancyModel } from '../models/redundancy/video-redundancy'
- import { sendUndoCacheFile } from './activitypub/send'
- import { Transaction } from 'sequelize'
- import { MActorSignature, MVideoRedundancyVideo } from '@server/types/models'
- import { CONFIG } from '@server/initializers/config'
- import { logger } from '@server/helpers/logger'
- import { ActorFollowModel } from '@server/models/activitypub/actor-follow'
- import { Activity } from '@shared/models'
- import { getServerActor } from '@server/models/application/application'
- async function removeVideoRedundancy (videoRedundancy: MVideoRedundancyVideo, t?: Transaction) {
- const serverActor = await getServerActor()
- // Local cache, send undo to remote instances
- if (videoRedundancy.actorId === serverActor.id) await sendUndoCacheFile(serverActor, videoRedundancy, t)
- await videoRedundancy.destroy({ transaction: t })
- }
- async function removeRedundanciesOfServer (serverId: number) {
- const redundancies = await VideoRedundancyModel.listLocalOfServer(serverId)
- for (const redundancy of redundancies) {
- await removeVideoRedundancy(redundancy)
- }
- }
- async function isRedundancyAccepted (activity: Activity, byActor: MActorSignature) {
- const configAcceptFrom = CONFIG.REMOTE_REDUNDANCY.VIDEOS.ACCEPT_FROM
- if (configAcceptFrom === 'nobody') {
- logger.info('Do not accept remote redundancy %s due instance accept policy.', activity.id)
- return false
- }
- if (configAcceptFrom === 'followings') {
- const serverActor = await getServerActor()
- const allowed = await ActorFollowModel.isFollowedBy(byActor.id, serverActor.id)
- if (allowed !== true) {
- logger.info('Do not accept remote redundancy %s because actor %s is not followed by our instance.', activity.id, byActor.url)
- return false
- }
- }
- return true
- }
- // ---------------------------------------------------------------------------
- export {
- isRedundancyAccepted,
- removeRedundanciesOfServer,
- removeVideoRedundancy
- }
|