import * as express from 'express'
-
-import { database as db } from '../../../initializers/database'
-import {
- logger,
- getFormattedObjects,
- retryTransactionWrapper
-} from '../../../helpers'
+import { AbuseModel } from '@server/models/abuse/abuse'
+import { getServerActor } from '@server/models/application/application'
+import { AbuseCreate, UserRight, VideoAbuseCreate } from '../../../../shared'
import {
+ abusesSortValidator,
+ asyncMiddleware,
+ asyncRetryTransactionMiddleware,
authenticate,
ensureUserHasRight,
paginationValidator,
+ setDefaultPagination,
+ setDefaultSort,
+ videoAbuseGetValidator,
+ videoAbuseListValidator,
videoAbuseReportValidator,
- videoAbusesSortValidator,
- setVideoAbusesSort,
- setPagination,
- asyncMiddleware
+ videoAbuseUpdateValidator
} from '../../../middlewares'
-import { VideoInstance } from '../../../models'
-import { VideoAbuseCreate, UserRight } from '../../../../shared'
-import { sendVideoAbuse } from '../../../lib/index'
+import { deleteAbuse, reportAbuse, updateAbuse } from '../abuse'
+
+// FIXME: deprecated in 2.3. Remove this controller
const abuseVideoRouter = express.Router()
abuseVideoRouter.get('/abuse',
authenticate,
- ensureUserHasRight(UserRight.MANAGE_VIDEO_ABUSES),
+ ensureUserHasRight(UserRight.MANAGE_ABUSES),
paginationValidator,
- videoAbusesSortValidator,
- setVideoAbusesSort,
- setPagination,
+ abusesSortValidator,
+ setDefaultSort,
+ setDefaultPagination,
+ videoAbuseListValidator,
asyncMiddleware(listVideoAbuses)
)
-abuseVideoRouter.post('/:id/abuse',
+abuseVideoRouter.put('/:videoId/abuse/:id',
authenticate,
- videoAbuseReportValidator,
- asyncMiddleware(reportVideoAbuseRetryWrapper)
+ ensureUserHasRight(UserRight.MANAGE_ABUSES),
+ asyncMiddleware(videoAbuseUpdateValidator),
+ asyncRetryTransactionMiddleware(updateVideoAbuse)
+)
+abuseVideoRouter.post('/:videoId/abuse',
+ authenticate,
+ asyncMiddleware(videoAbuseReportValidator),
+ asyncRetryTransactionMiddleware(reportVideoAbuse)
+)
+abuseVideoRouter.delete('/:videoId/abuse/:id',
+ authenticate,
+ ensureUserHasRight(UserRight.MANAGE_ABUSES),
+ asyncMiddleware(videoAbuseGetValidator),
+ asyncRetryTransactionMiddleware(deleteVideoAbuse)
)
// ---------------------------------------------------------------------------
// ---------------------------------------------------------------------------
-async function listVideoAbuses (req: express.Request, res: express.Response, next: express.NextFunction) {
- const resultList = await db.VideoAbuse.listForApi(req.query.start, req.query.count, req.query.sort)
+async function listVideoAbuses (req: express.Request, res: express.Response) {
+ const user = res.locals.oauth.token.user
+ const serverActor = await getServerActor()
+
+ const resultList = await AbuseModel.listForAdminApi({
+ start: req.query.start,
+ count: req.query.count,
+ sort: req.query.sort,
+ id: req.query.id,
+ filter: 'video',
+ predefinedReason: req.query.predefinedReason,
+ search: req.query.search,
+ state: req.query.state,
+ videoIs: req.query.videoIs,
+ searchReporter: req.query.searchReporter,
+ searchReportee: req.query.searchReportee,
+ searchVideo: req.query.searchVideo,
+ searchVideoChannel: req.query.searchVideoChannel,
+ serverAccountId: serverActor.Account.id,
+ user
+ })
- return res.json(getFormattedObjects(resultList.data, resultList.total))
+ return res.json({
+ total: resultList.total,
+ data: resultList.data.map(d => d.toFormattedAdminJSON())
+ })
}
-async function reportVideoAbuseRetryWrapper (req: express.Request, res: express.Response, next: express.NextFunction) {
- const options = {
- arguments: [ req, res ],
- errorMessage: 'Cannot report abuse to the video with many retries.'
- }
-
- await retryTransactionWrapper(reportVideoAbuse, options)
+async function updateVideoAbuse (req: express.Request, res: express.Response) {
+ return updateAbuse(req, res)
+}
- return res.type('json').status(204).end()
+async function deleteVideoAbuse (req: express.Request, res: express.Response) {
+ return deleteAbuse(req, res)
}
async function reportVideoAbuse (req: express.Request, res: express.Response) {
- const videoInstance = res.locals.video as VideoInstance
- const reporterAccount = res.locals.oauth.token.User.Account
- const body: VideoAbuseCreate = req.body
-
- const abuseToCreate = {
- reporterAccountId: reporterAccount.id,
- reason: body.reason,
- videoId: videoInstance.id
- }
-
- await db.sequelize.transaction(async t => {
- const videoAbuseInstance = await db.VideoAbuse.create(abuseToCreate, { transaction: t })
-
- // We send the video abuse to the origin server
- if (videoInstance.isOwned() === false) {
- await sendVideoAbuse(reporterAccount, videoAbuseInstance, videoInstance, t)
+ const oldBody = req.body as VideoAbuseCreate
+
+ req.body = {
+ accountId: res.locals.videoAll.VideoChannel.accountId,
+
+ reason: oldBody.reason,
+ predefinedReasons: oldBody.predefinedReasons,
+
+ video: {
+ id: res.locals.videoAll.id,
+ startAt: oldBody.startAt,
+ endAt: oldBody.endAt
}
- })
+ } as AbuseCreate
- logger.info('Abuse report for video %s created.', videoInstance.name)
+ return reportAbuse(req, res)
}