Log error on unknown hook
[oweals/peertube.git] / server / lib / video-blacklist.ts
1 import { Transaction } from 'sequelize'
2 import { CONFIG } from '../initializers/config'
3 import { UserRight, VideoBlacklistType } from '../../shared/models'
4 import { VideoBlacklistModel } from '../models/video/video-blacklist'
5 import { UserModel } from '../models/account/user'
6 import { VideoModel } from '../models/video/video'
7 import { logger } from '../helpers/logger'
8 import { UserAdminFlag } from '../../shared/models/users/user-flag.model'
9 import { Hooks } from './plugins/hooks'
10
11 async function autoBlacklistVideoIfNeeded (parameters: {
12   video: VideoModel,
13   user?: UserModel,
14   isRemote: boolean,
15   isNew: boolean,
16   transaction?: Transaction
17 }) {
18   const { video, user, isRemote, isNew, transaction } = parameters
19   const doAutoBlacklist = await Hooks.wrapPromiseFun(
20     autoBlacklistNeeded,
21     { video, user, isRemote, isNew },
22     'filter:video.auto-blacklist.result'
23   )
24
25   if (!doAutoBlacklist) return false
26
27   const videoBlacklistToCreate = {
28     videoId: video.id,
29     unfederated: true,
30     reason: 'Auto-blacklisted. Moderator review required.',
31     type: VideoBlacklistType.AUTO_BEFORE_PUBLISHED
32   }
33   const [ videoBlacklist ] = await VideoBlacklistModel.findOrCreate({
34     where: {
35       videoId: video.id
36     },
37     defaults: videoBlacklistToCreate,
38     transaction
39   })
40
41   video.VideoBlacklist = videoBlacklist
42
43   logger.info('Video %s auto-blacklisted.', video.uuid)
44
45   return true
46 }
47
48 async function autoBlacklistNeeded (parameters: {
49   video: VideoModel,
50   isRemote: boolean,
51   isNew: boolean,
52   user?: UserModel
53 }) {
54   const { user, video, isRemote, isNew } = parameters
55
56   // Already blacklisted
57   if (video.VideoBlacklist) return false
58   if (!CONFIG.AUTO_BLACKLIST.VIDEOS.OF_USERS.ENABLED || !user) return false
59   if (isRemote || isNew) return false
60
61   if (user.hasRight(UserRight.MANAGE_VIDEO_BLACKLIST) || user.hasAdminFlag(UserAdminFlag.BY_PASS_VIDEO_AUTO_BLACKLIST)) return false
62
63   return true
64 }
65
66 // ---------------------------------------------------------------------------
67
68 export {
69   autoBlacklistVideoIfNeeded
70 }