PeerTube/server/core/lib/redundancy.ts

60 lines
2.1 KiB
TypeScript
Raw Normal View History

2018-09-11 09:27:07 -05:00
import { Transaction } from 'sequelize'
import { logger, loggerTagsFactory } from '@server/helpers/logger.js'
import { CONFIG } from '@server/initializers/config.js'
import { ActorFollowModel } from '@server/models/actor/actor-follow.js'
import { getServerActor } from '@server/models/application/application.js'
import { MActorSignature, MVideoRedundancyVideo } from '@server/types/models/index.js'
import { Activity } from '@peertube/peertube-models'
import { VideoRedundancyModel } from '../models/redundancy/video-redundancy.js'
import { sendUndoCacheFile } from './activitypub/send/index.js'
2018-09-11 09:27:07 -05:00
2021-08-26 04:01:59 -05:00
const lTags = loggerTagsFactory('redundancy')
2019-08-15 04:53:26 -05:00
async function removeVideoRedundancy (videoRedundancy: MVideoRedundancyVideo, t?: Transaction) {
2018-09-11 09:27:07 -05:00
const serverActor = await getServerActor()
// Local cache, send undo to remote instances
if (videoRedundancy.actorId === serverActor.id) await sendUndoCacheFile(serverActor, videoRedundancy, t)
2018-09-11 09:27:07 -05:00
await videoRedundancy.destroy({ transaction: t })
}
2020-01-10 03:11:28 -06:00
async function removeRedundanciesOfServer (serverId: number) {
const redundancies = await VideoRedundancyModel.listLocalOfServer(serverId)
2020-01-10 03:11:28 -06:00
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') {
2021-08-26 04:01:59 -05:00
logger.info('Do not accept remote redundancy %s due instance accept policy.', activity.id, lTags())
return false
}
if (configAcceptFrom === 'followings') {
const serverActor = await getServerActor()
const allowed = await ActorFollowModel.isFollowedBy(byActor.id, serverActor.id)
if (allowed !== true) {
2021-08-26 04:01:59 -05:00
logger.info(
'Do not accept remote redundancy %s because actor %s is not followed by our instance.',
activity.id, byActor.url, lTags()
)
return false
}
}
return true
}
2018-09-11 09:27:07 -05:00
// ---------------------------------------------------------------------------
export {
isRedundancyAccepted,
2020-01-10 03:11:28 -06:00
removeRedundanciesOfServer,
2018-09-11 09:27:07 -05:00
removeVideoRedundancy
}