X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fmiddlewares%2Fvalidators%2Ffollows.ts;h=be98a4c04bfac936cf72fdaa4febd635476c361d;hb=cea2fd90ddb3bf57c2fed77128938d12d4c2be6b;hp=16abdd096c948a44777de807988134c41543726a;hpb=ac27887774e63d99f4e227fbe18846f143cc4b3c;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/middlewares/validators/follows.ts b/server/middlewares/validators/follows.ts index 16abdd096..be98a4c04 100644 --- a/server/middlewares/validators/follows.ts +++ b/server/middlewares/validators/follows.ts @@ -1,12 +1,13 @@ -import * as express from 'express' +import express from 'express' import { body, param, query } from 'express-validator' +import { isProdInstance } from '@server/helpers/core-utils' import { isEachUniqueHandleValid, isFollowStateValid, isRemoteHandleValid } from '@server/helpers/custom-validators/follows' import { loadActorUrlOrGetFromWebfinger } from '@server/lib/activitypub/actors' import { getRemoteNameAndHost } from '@server/lib/activitypub/follow' import { getServerActor } from '@server/models/application/application' import { MActorFollowActorsDefault } from '@server/types/models' +import { ServerFollowCreate } from '@shared/models' import { HttpStatusCode } from '../../../shared/models/http/http-error-codes' -import { isTestInstance } from '../../helpers/core-utils' import { isActorTypeValid, isValidActorHandle } from '../../helpers/custom-validators/activitypub/actor' import { isEachUniqueHostValid, isHostValid } from '../../helpers/custom-validators/servers' import { logger } from '../../helpers/logger' @@ -14,15 +15,14 @@ import { WEBSERVER } from '../../initializers/constants' import { ActorModel } from '../../models/actor/actor' import { ActorFollowModel } from '../../models/actor/actor-follow' import { areValidationErrors } from './shared' -import { ServerFollowCreate } from '@shared/models' const listFollowsValidator = [ query('state') .optional() - .custom(isFollowStateValid).withMessage('Should have a valid follow state'), + .custom(isFollowStateValid), query('actorType') .optional() - .custom(isActorTypeValid).withMessage('Should have a valid actor type'), + .custom(isActorTypeValid), (req: express.Request, res: express.Response, next: express.NextFunction) => { if (areValidationErrors(req, res)) return @@ -42,7 +42,7 @@ const followValidator = [ (req: express.Request, res: express.Response, next: express.NextFunction) => { // Force https if the administrator wants to follow remote actors - if (isTestInstance() === false && WEBSERVER.SCHEME === 'http') { + if (isProdInstance() && WEBSERVER.SCHEME === 'http') { return res .status(HttpStatusCode.INTERNAL_SERVER_ERROR_500) .json({ @@ -50,8 +50,6 @@ const followValidator = [ }) } - logger.debug('Checking follow parameters', { parameters: req.body }) - if (areValidationErrors(req, res)) return const body: ServerFollowCreate = req.body @@ -70,18 +68,19 @@ const followValidator = [ const removeFollowingValidator = [ param('hostOrHandle') - .custom(value => isHostValid(value) || isRemoteHandleValid(value)) - .withMessage('Should have a valid host/handle'), + .custom(value => isHostValid(value) || isRemoteHandleValid(value)), async (req: express.Request, res: express.Response, next: express.NextFunction) => { - logger.debug('Checking unfollowing parameters', { parameters: req.params }) - if (areValidationErrors(req, res)) return const serverActor = await getServerActor() const { name, host } = getRemoteNameAndHost(req.params.hostOrHandle) - const follow = await ActorFollowModel.loadByActorAndTargetNameAndHostForAPI(serverActor.id, name, host) + const follow = await ActorFollowModel.loadByActorAndTargetNameAndHostForAPI({ + actorId: serverActor.id, + targetName: name, + targetHost: host + }) if (!follow) { return res.fail({ @@ -96,11 +95,10 @@ const removeFollowingValidator = [ ] const getFollowerValidator = [ - param('nameWithHost').custom(isValidActorHandle).withMessage('Should have a valid nameWithHost'), + param('nameWithHost') + .custom(isValidActorHandle), async (req: express.Request, res: express.Response, next: express.NextFunction) => { - logger.debug('Checking get follower parameters', { parameters: req.params }) - if (areValidationErrors(req, res)) return let follow: MActorFollowActorsDefault @@ -126,13 +124,22 @@ const getFollowerValidator = [ } ] -const acceptOrRejectFollowerValidator = [ +const acceptFollowerValidator = [ (req: express.Request, res: express.Response, next: express.NextFunction) => { - logger.debug('Checking accept/reject follower parameters', { parameters: req.params }) + const follow = res.locals.follow + if (follow.state !== 'pending' && follow.state !== 'rejected') { + return res.fail({ message: 'Follow is not in pending/rejected state.' }) + } + + return next() + } +] +const rejectFollowerValidator = [ + (req: express.Request, res: express.Response, next: express.NextFunction) => { const follow = res.locals.follow - if (follow.state !== 'pending') { - return res.fail({ message: 'Follow is not in pending state.' }) + if (follow.state !== 'pending' && follow.state !== 'accepted') { + return res.fail({ message: 'Follow is not in pending/accepted state.' }) } return next() @@ -145,6 +152,7 @@ export { followValidator, removeFollowingValidator, getFollowerValidator, - acceptOrRejectFollowerValidator, + acceptFollowerValidator, + rejectFollowerValidator, listFollowsValidator }