import { logger } from '../helpers/logger'
import { UserAdminFlag } from '../../shared/models/users/user-flag.model'
import { Hooks } from './plugins/hooks'
+import { Notifier } from './notifier'
async function autoBlacklistVideoIfNeeded (parameters: {
video: VideoModel,
user?: UserModel,
isRemote: boolean,
isNew: boolean,
+ notify?: boolean,
transaction?: Transaction
}) {
- const { video, user, isRemote, isNew, transaction } = parameters
+ const { video, user, isRemote, isNew, notify = true, transaction } = parameters
const doAutoBlacklist = await Hooks.wrapPromiseFun(
autoBlacklistNeeded,
{ video, user, isRemote, isNew },
defaults: videoBlacklistToCreate,
transaction
})
-
video.VideoBlacklist = videoBlacklist
+ if (notify) Notifier.Instance.notifyOnVideoAutoBlacklist(video)
+
logger.info('Video %s auto-blacklisted.', video.uuid)
return true
// Already blacklisted
if (video.VideoBlacklist) return false
if (!CONFIG.AUTO_BLACKLIST.VIDEOS.OF_USERS.ENABLED || !user) return false
- if (isRemote || isNew) return false
+ if (isRemote || isNew === false) return false
if (user.hasRight(UserRight.MANAGE_VIDEO_BLACKLIST) || user.hasAdminFlag(UserAdminFlag.BY_PASS_VIDEO_AUTO_BLACKLIST)) return false