]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/controllers/api/videos/abuse.ts
Correctly send Flag/Dislike/View activities
[github/Chocobozzz/PeerTube.git] / server / controllers / api / videos / abuse.ts
CommitLineData
4d4e5cd4 1import * as express from 'express'
268eebed 2import { UserRight, VideoAbuseCreate, VideoAbuseState } from '../../../../shared'
da854ddd
C
3import { logger } from '../../../helpers/logger'
4import { getFormattedObjects } from '../../../helpers/utils'
3fd3ab2d 5import { sequelizeTypescript } from '../../../initializers'
65fcc311 6import {
90d4bb81
C
7 asyncMiddleware,
8 asyncRetryTransactionMiddleware,
9 authenticate,
10 ensureUserHasRight,
11 paginationValidator,
12 setDefaultPagination,
13 setDefaultSort,
268eebed 14 videoAbuseGetValidator,
90d4bb81 15 videoAbuseReportValidator,
268eebed
C
16 videoAbusesSortValidator,
17 videoAbuseUpdateValidator
65fcc311 18} from '../../../middlewares'
3fd3ab2d
C
19import { AccountModel } from '../../../models/account/account'
20import { VideoModel } from '../../../models/video/video'
21import { VideoAbuseModel } from '../../../models/video/video-abuse'
80e36cd9 22import { auditLoggerFactory, VideoAbuseAuditView } from '../../../helpers/audit-logger'
91411dba 23import { UserModel } from '../../../models/account/user'
cef534ed 24import { Notifier } from '../../../lib/notifier'
1e7eb25f 25import { sendVideoAbuse } from '../../../lib/activitypub/send/send-flag'
65fcc311 26
80e36cd9 27const auditLogger = auditLoggerFactory('abuse')
65fcc311
C
28const abuseVideoRouter = express.Router()
29
30abuseVideoRouter.get('/abuse',
31 authenticate,
954605a8 32 ensureUserHasRight(UserRight.MANAGE_VIDEO_ABUSES),
65fcc311
C
33 paginationValidator,
34 videoAbusesSortValidator,
1174a847 35 setDefaultSort,
f05a1c30 36 setDefaultPagination,
eb080476 37 asyncMiddleware(listVideoAbuses)
d33242b0 38)
268eebed
C
39abuseVideoRouter.put('/:videoId/abuse/:id',
40 authenticate,
41 ensureUserHasRight(UserRight.MANAGE_VIDEO_ABUSES),
42 asyncMiddleware(videoAbuseUpdateValidator),
43 asyncRetryTransactionMiddleware(updateVideoAbuse)
44)
45abuseVideoRouter.post('/:videoId/abuse',
65fcc311 46 authenticate,
a2431b7d 47 asyncMiddleware(videoAbuseReportValidator),
90d4bb81 48 asyncRetryTransactionMiddleware(reportVideoAbuse)
d33242b0 49)
268eebed
C
50abuseVideoRouter.delete('/:videoId/abuse/:id',
51 authenticate,
52 ensureUserHasRight(UserRight.MANAGE_VIDEO_ABUSES),
53 asyncMiddleware(videoAbuseGetValidator),
54 asyncRetryTransactionMiddleware(deleteVideoAbuse)
55)
d33242b0
C
56
57// ---------------------------------------------------------------------------
58
65fcc311
C
59export {
60 abuseVideoRouter
61}
d33242b0
C
62
63// ---------------------------------------------------------------------------
64
268eebed 65async function listVideoAbuses (req: express.Request, res: express.Response) {
3fd3ab2d 66 const resultList = await VideoAbuseModel.listForApi(req.query.start, req.query.count, req.query.sort)
eb080476
C
67
68 return res.json(getFormattedObjects(resultList.data, resultList.total))
d33242b0
C
69}
70
268eebed
C
71async function updateVideoAbuse (req: express.Request, res: express.Response) {
72 const videoAbuse: VideoAbuseModel = res.locals.videoAbuse
73
74 if (req.body.moderationComment !== undefined) videoAbuse.moderationComment = req.body.moderationComment
75 if (req.body.state !== undefined) videoAbuse.state = req.body.state
76
77 await sequelizeTypescript.transaction(t => {
78 return videoAbuse.save({ transaction: t })
79 })
80
81 // Do not send the delete to other instances, we updated OUR copy of this video abuse
82
83 return res.type('json').status(204).end()
84}
85
86async function deleteVideoAbuse (req: express.Request, res: express.Response) {
87 const videoAbuse: VideoAbuseModel = res.locals.videoAbuse
88
89 await sequelizeTypescript.transaction(t => {
90 return videoAbuse.destroy({ transaction: t })
91 })
92
93 // Do not send the delete to other instances, we delete OUR copy of this video abuse
94
95 return res.type('json').status(204).end()
96}
97
eb080476 98async function reportVideoAbuse (req: express.Request, res: express.Response) {
3fd3ab2d 99 const videoInstance = res.locals.video as VideoModel
4771e000 100 const body: VideoAbuseCreate = req.body
d33242b0 101
268eebed 102 const videoAbuse: VideoAbuseModel = await sequelizeTypescript.transaction(async t => {
91411dba
C
103 const reporterAccount = await AccountModel.load((res.locals.oauth.token.User as UserModel).Account.id, t)
104
105 const abuseToCreate = {
106 reporterAccountId: reporterAccount.id,
107 reason: body.reason,
108 videoId: videoInstance.id,
109 state: VideoAbuseState.PENDING
110 }
111
3fd3ab2d 112 const videoAbuseInstance = await VideoAbuseModel.create(abuseToCreate, { transaction: t })
21e0727a 113 videoAbuseInstance.Video = videoInstance
80e36cd9 114 videoAbuseInstance.Account = reporterAccount
8e13fa7d
C
115
116 // We send the video abuse to the origin server
eb080476 117 if (videoInstance.isOwned() === false) {
c48e82b5 118 await sendVideoAbuse(reporterAccount.Actor, videoAbuseInstance, videoInstance)
eb080476 119 }
eb080476 120
cef534ed
C
121 Notifier.Instance.notifyOnNewVideoAbuse(videoAbuseInstance)
122
80e36cd9 123 auditLogger.create(reporterAccount.Actor.getIdentifier(), new VideoAbuseAuditView(videoAbuseInstance.toFormattedJSON()))
268eebed
C
124
125 return videoAbuseInstance
80e36cd9 126 })
90d4bb81 127
268eebed 128 logger.info('Abuse report for video %s created.', videoInstance.name)
91411dba
C
129
130 return res.json({ videoAbuse: videoAbuse.toFormattedJSON() }).end()
d33242b0 131}