X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fmiddlewares%2Fvalidators%2Ffollows.ts;h=605872ecf9c70a55f2d42fde15167ccde6c7a871;hb=98ec8b8e73a918d5680e6f13aaef56ca8756c2a8;hp=e22349726e581dd40fb7eaa235949b4573bcadf1;hpb=54141398354e6e7b94aa3065a705a1251390111c;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/middlewares/validators/follows.ts b/server/middlewares/validators/follows.ts index e22349726..605872ecf 100644 --- a/server/middlewares/validators/follows.ts +++ b/server/middlewares/validators/follows.ts @@ -1,12 +1,12 @@ import * as express from 'express' -import { body } from 'express-validator/check' +import { body, param } from 'express-validator/check' import { isTestInstance } from '../../helpers/core-utils' -import { isAccountIdValid } from '../../helpers/custom-validators/activitypub/account' import { isEachUniqueHostValid } from '../../helpers/custom-validators/servers' import { logger } from '../../helpers/logger' import { CONFIG, database as db } from '../../initializers' -import { checkErrors } from './utils' +import { areValidationErrors } from './utils' import { getServerAccount } from '../../helpers/utils' +import { isIdOrUUIDValid } from '../../helpers/custom-validators/misc' const followValidator = [ body('hosts').custom(isEachUniqueHostValid).withMessage('Should have an array of unique hosts'), @@ -23,34 +23,30 @@ const followValidator = [ logger.debug('Checking follow parameters', { parameters: req.body }) - checkErrors(req, res, next) + if (areValidationErrors(req, res)) return + + return next() } ] const removeFollowingValidator = [ - body('accountId').custom(isAccountIdValid).withMessage('Should have a valid account id'), + param('accountId').custom(isIdOrUUIDValid).withMessage('Should have a valid account id'), - (req: express.Request, res: express.Response, next: express.NextFunction) => { - logger.debug('Checking follow parameters', { parameters: req.body }) + async (req: express.Request, res: express.Response, next: express.NextFunction) => { + logger.debug('Checking unfollow parameters', { parameters: req.params }) - checkErrors(req, res, async () => { - try { - const serverAccount = await getServerAccount() - const following = await db.AccountFollow.loadByAccountAndTarget(serverAccount.id, req.params.accountId) + if (areValidationErrors(req, res)) return - if (!following) { - return res.status(404) - .end() - } + const serverAccount = await getServerAccount() + const follow = await db.AccountFollow.loadByAccountAndTarget(serverAccount.id, req.params.accountId) - res.locals.following = following + if (!follow) { + return res.status(404) + .end() + } - return next() - } catch (err) { - logger.error('Error in remove following validator.', err) - return res.sendStatus(500) - } - }) + res.locals.follow = follow + return next() } ]