]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/controllers/api/users/my-blocklist.ts
Add inspect to test script
[github/Chocobozzz/PeerTube.git] / server / controllers / api / users / my-blocklist.ts
CommitLineData
7ad9b984
C
1import * as express from 'express'
2import 'multer'
3import { getFormattedObjects } from '../../../helpers/utils'
4import {
5 asyncMiddleware,
6 asyncRetryTransactionMiddleware,
7 authenticate,
8 paginationValidator,
7ad9b984
C
9 setDefaultPagination,
10 setDefaultSort,
11 unblockAccountByAccountValidator
12} from '../../../middlewares'
13import {
14 accountsBlocklistSortValidator,
b44164bb
C
15 blockAccountValidator,
16 blockServerValidator,
7ad9b984
C
17 serversBlocklistSortValidator,
18 unblockServerByAccountValidator
19} from '../../../middlewares/validators'
7ad9b984
C
20import { AccountBlocklistModel } from '../../../models/account/account-blocklist'
21import { addAccountInBlocklist, addServerInBlocklist, removeAccountFromBlocklist, removeServerFromBlocklist } from '../../../lib/blocklist'
22import { ServerBlocklistModel } from '../../../models/server/server-blocklist'
ea3674d0
C
23import { UserNotificationModel } from '@server/models/account/user-notification'
24import { logger } from '@server/helpers/logger'
7ad9b984
C
25
26const myBlocklistRouter = express.Router()
27
28myBlocklistRouter.get('/me/blocklist/accounts',
29 authenticate,
30 paginationValidator,
31 accountsBlocklistSortValidator,
32 setDefaultSort,
33 setDefaultPagination,
34 asyncMiddleware(listBlockedAccounts)
35)
36
37myBlocklistRouter.post('/me/blocklist/accounts',
38 authenticate,
b44164bb 39 asyncMiddleware(blockAccountValidator),
7ad9b984
C
40 asyncRetryTransactionMiddleware(blockAccount)
41)
42
43myBlocklistRouter.delete('/me/blocklist/accounts/:accountName',
44 authenticate,
45 asyncMiddleware(unblockAccountByAccountValidator),
46 asyncRetryTransactionMiddleware(unblockAccount)
47)
48
49myBlocklistRouter.get('/me/blocklist/servers',
50 authenticate,
51 paginationValidator,
52 serversBlocklistSortValidator,
53 setDefaultSort,
54 setDefaultPagination,
55 asyncMiddleware(listBlockedServers)
56)
57
58myBlocklistRouter.post('/me/blocklist/servers',
59 authenticate,
b44164bb 60 asyncMiddleware(blockServerValidator),
7ad9b984
C
61 asyncRetryTransactionMiddleware(blockServer)
62)
63
64myBlocklistRouter.delete('/me/blocklist/servers/:host',
65 authenticate,
66 asyncMiddleware(unblockServerByAccountValidator),
67 asyncRetryTransactionMiddleware(unblockServer)
68)
69
70export {
71 myBlocklistRouter
72}
73
74// ---------------------------------------------------------------------------
75
76async function listBlockedAccounts (req: express.Request, res: express.Response) {
dae86118 77 const user = res.locals.oauth.token.User
7ad9b984 78
e0a92917
RK
79 const resultList = await AccountBlocklistModel.listForApi({
80 start: req.query.start,
81 count: req.query.count,
82 sort: req.query.sort,
83 search: req.query.search,
84 accountId: user.Account.id
85 })
7ad9b984
C
86
87 return res.json(getFormattedObjects(resultList.data, resultList.total))
88}
89
90async function blockAccount (req: express.Request, res: express.Response) {
dae86118 91 const user = res.locals.oauth.token.User
2ba92871 92 const accountToBlock = res.locals.account
7ad9b984
C
93
94 await addAccountInBlocklist(user.Account.id, accountToBlock.id)
95
ea3674d0
C
96 UserNotificationModel.removeNotificationsOf({
97 id: accountToBlock.id,
98 type: 'account',
99 forUserId: user.id
100 }).catch(err => logger.error('Cannot remove notifications after an account mute.', { err }))
101
7ad9b984
C
102 return res.status(204).end()
103}
104
105async function unblockAccount (req: express.Request, res: express.Response) {
dae86118 106 const accountBlock = res.locals.accountBlock
7ad9b984
C
107
108 await removeAccountFromBlocklist(accountBlock)
109
110 return res.status(204).end()
111}
112
113async function listBlockedServers (req: express.Request, res: express.Response) {
dae86118 114 const user = res.locals.oauth.token.User
7ad9b984 115
e0a92917
RK
116 const resultList = await ServerBlocklistModel.listForApi({
117 start: req.query.start,
118 count: req.query.count,
119 sort: req.query.sort,
120 search: req.query.search,
121 accountId: user.Account.id
122 })
7ad9b984
C
123
124 return res.json(getFormattedObjects(resultList.data, resultList.total))
125}
126
127async function blockServer (req: express.Request, res: express.Response) {
dae86118
C
128 const user = res.locals.oauth.token.User
129 const serverToBlock = res.locals.server
7ad9b984
C
130
131 await addServerInBlocklist(user.Account.id, serverToBlock.id)
132
ea3674d0
C
133 UserNotificationModel.removeNotificationsOf({
134 id: serverToBlock.id,
135 type: 'server',
136 forUserId: user.id
137 }).catch(err => logger.error('Cannot remove notifications after a server mute.', { err }))
138
7ad9b984
C
139 return res.status(204).end()
140}
141
142async function unblockServer (req: express.Request, res: express.Response) {
dae86118 143 const serverBlock = res.locals.serverBlock
7ad9b984
C
144
145 await removeServerFromBlocklist(serverBlock)
146
147 return res.status(204).end()
148}