]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/controllers/api/videos/abuse.ts
Add audit logs in various modules
[github/Chocobozzz/PeerTube.git] / server / controllers / api / videos / abuse.ts
CommitLineData
4d4e5cd4 1import * as express from 'express'
50d6de9c 2import { UserRight, VideoAbuseCreate } from '../../../../shared'
da854ddd
C
3import { logger } from '../../../helpers/logger'
4import { getFormattedObjects } from '../../../helpers/utils'
3fd3ab2d 5import { sequelizeTypescript } from '../../../initializers'
50d6de9c 6import { sendVideoAbuse } from '../../../lib/activitypub/send'
65fcc311 7import {
90d4bb81
C
8 asyncMiddleware,
9 asyncRetryTransactionMiddleware,
10 authenticate,
11 ensureUserHasRight,
12 paginationValidator,
13 setDefaultPagination,
14 setDefaultSort,
15 videoAbuseReportValidator,
1174a847 16 videoAbusesSortValidator
65fcc311 17} from '../../../middlewares'
3fd3ab2d
C
18import { AccountModel } from '../../../models/account/account'
19import { VideoModel } from '../../../models/video/video'
20import { VideoAbuseModel } from '../../../models/video/video-abuse'
80e36cd9 21import { auditLoggerFactory, VideoAbuseAuditView } from '../../../helpers/audit-logger'
65fcc311 22
80e36cd9 23const auditLogger = auditLoggerFactory('abuse')
65fcc311
C
24const abuseVideoRouter = express.Router()
25
26abuseVideoRouter.get('/abuse',
27 authenticate,
954605a8 28 ensureUserHasRight(UserRight.MANAGE_VIDEO_ABUSES),
65fcc311
C
29 paginationValidator,
30 videoAbusesSortValidator,
1174a847 31 setDefaultSort,
f05a1c30 32 setDefaultPagination,
eb080476 33 asyncMiddleware(listVideoAbuses)
d33242b0 34)
65fcc311
C
35abuseVideoRouter.post('/:id/abuse',
36 authenticate,
a2431b7d 37 asyncMiddleware(videoAbuseReportValidator),
90d4bb81 38 asyncRetryTransactionMiddleware(reportVideoAbuse)
d33242b0
C
39)
40
41// ---------------------------------------------------------------------------
42
65fcc311
C
43export {
44 abuseVideoRouter
45}
d33242b0
C
46
47// ---------------------------------------------------------------------------
48
eb080476 49async function listVideoAbuses (req: express.Request, res: express.Response, next: express.NextFunction) {
3fd3ab2d 50 const resultList = await VideoAbuseModel.listForApi(req.query.start, req.query.count, req.query.sort)
eb080476
C
51
52 return res.json(getFormattedObjects(resultList.data, resultList.total))
d33242b0
C
53}
54
eb080476 55async function reportVideoAbuse (req: express.Request, res: express.Response) {
3fd3ab2d
C
56 const videoInstance = res.locals.video as VideoModel
57 const reporterAccount = res.locals.oauth.token.User.Account as AccountModel
4771e000 58 const body: VideoAbuseCreate = req.body
d33242b0 59
eb080476 60 const abuseToCreate = {
8e13fa7d 61 reporterAccountId: reporterAccount.id,
4771e000 62 reason: body.reason,
8e13fa7d 63 videoId: videoInstance.id
d33242b0
C
64 }
65
3fd3ab2d
C
66 await sequelizeTypescript.transaction(async t => {
67 const videoAbuseInstance = await VideoAbuseModel.create(abuseToCreate, { transaction: t })
21e0727a 68 videoAbuseInstance.Video = videoInstance
80e36cd9 69 videoAbuseInstance.Account = reporterAccount
8e13fa7d
C
70
71 // We send the video abuse to the origin server
eb080476 72 if (videoInstance.isOwned() === false) {
50d6de9c 73 await sendVideoAbuse(reporterAccount.Actor, videoAbuseInstance, videoInstance, t)
eb080476 74 }
eb080476 75
80e36cd9
AB
76 auditLogger.create(reporterAccount.Actor.getIdentifier(), new VideoAbuseAuditView(videoAbuseInstance.toFormattedJSON()))
77 logger.info('Abuse report for video %s created.', videoInstance.name)
78 })
90d4bb81
C
79
80 return res.type('json').status(204).end()
d33242b0 81}