]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/middlewares/validators/user-subscriptions.ts
Merge branch 'release/3.2.0' into develop
[github/Chocobozzz/PeerTube.git] / server / middlewares / validators / user-subscriptions.ts
CommitLineData
06a05d5f 1import * as express from 'express'
c8861d5d 2import { body, param, query } from 'express-validator'
7d9ba5c0 3import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
f37dc0dd 4import { areValidActorHandles, isValidActorHandle } from '../../helpers/custom-validators/activitypub/actor'
f37dc0dd 5import { toArray } from '../../helpers/custom-validators/misc'
7d9ba5c0 6import { logger } from '../../helpers/logger'
6dd9de95 7import { WEBSERVER } from '../../initializers/constants'
7d9ba5c0
C
8import { ActorFollowModel } from '../../models/actor/actor-follow'
9import { areValidationErrors } from './utils'
06a05d5f 10
4f5d0459
RK
11const userSubscriptionListValidator = [
12 query('search').optional().not().isEmpty().withMessage('Should have a valid search'),
13
14 (req: express.Request, res: express.Response, next: express.NextFunction) => {
15 logger.debug('Checking userSubscriptionListValidator parameters', { parameters: req.query })
16
17 if (areValidationErrors(req, res)) return
18
19 return next()
20 }
21]
22
06a05d5f
C
23const userSubscriptionAddValidator = [
24 body('uri').custom(isValidActorHandle).withMessage('Should have a valid URI to follow (username@domain)'),
25
26 (req: express.Request, res: express.Response, next: express.NextFunction) => {
27 logger.debug('Checking userSubscriptionAddValidator parameters', { parameters: req.body })
28
29 if (areValidationErrors(req, res)) return
30
31 return next()
32 }
33]
34
f37dc0dd
C
35const areSubscriptionsExistValidator = [
36 query('uris')
37 .customSanitizer(toArray)
38 .custom(areValidActorHandles).withMessage('Should have a valid uri array'),
39
40 (req: express.Request, res: express.Response, next: express.NextFunction) => {
41 logger.debug('Checking areSubscriptionsExistValidator parameters', { parameters: req.query })
42
43 if (areValidationErrors(req, res)) return
44
45 return next()
46 }
47]
48
99492dbc 49const userSubscriptionGetValidator = [
06a05d5f
C
50 param('uri').custom(isValidActorHandle).withMessage('Should have a valid URI to unfollow'),
51
52 async (req: express.Request, res: express.Response, next: express.NextFunction) => {
99492dbc 53 logger.debug('Checking userSubscriptionGetValidator parameters', { parameters: req.params })
06a05d5f
C
54
55 if (areValidationErrors(req, res)) return
56
57 let [ name, host ] = req.params.uri.split('@')
6dd9de95 58 if (host === WEBSERVER.HOST) host = null
06a05d5f 59
dae86118 60 const user = res.locals.oauth.token.User
f37dc0dd 61 const subscription = await ActorFollowModel.loadByActorAndTargetNameAndHostForAPI(user.Account.Actor.id, name, host)
06a05d5f 62
99492dbc 63 if (!subscription || !subscription.ActorFollowing.VideoChannel) {
06a05d5f 64 return res
2d53be02 65 .status(HttpStatusCode.NOT_FOUND_404)
06a05d5f
C
66 .json({
67 error: `Subscription ${req.params.uri} not found.`
68 })
06a05d5f
C
69 }
70
71 res.locals.subscription = subscription
72 return next()
73 }
74]
75
76// ---------------------------------------------------------------------------
77
78export {
f37dc0dd 79 areSubscriptionsExistValidator,
4f5d0459 80 userSubscriptionListValidator,
06a05d5f 81 userSubscriptionAddValidator,
99492dbc 82 userSubscriptionGetValidator
06a05d5f 83}