PeerTube/server/middlewares/validators/pods.ts

91 lines
2.7 KiB
TypeScript
Raw Normal View History

2017-06-10 22:15:25 +02:00
import 'express-validator'
import * as express from 'express'
2017-05-22 20:58:25 +02:00
import { database as db } from '../../initializers/database'
2017-05-15 22:22:03 +02:00
import { checkErrors } from './utils'
import { logger } from '../../helpers'
import { CONFIG } from '../../initializers'
import { hasFriends } from '../../lib'
import { isTestInstance } from '../../helpers'
2017-06-10 22:15:25 +02:00
function makeFriendsValidator (req: express.Request, res: express.Response, next: express.NextFunction) {
// Force https if the administrator wants to make friends
2017-05-15 22:22:03 +02:00
if (isTestInstance() === false && CONFIG.WEBSERVER.SCHEME === 'http') {
2017-08-25 18:36:49 +02:00
return res.status(400).send('Cannot make friends with a non HTTPS web server.')
}
req.checkBody('hosts', 'Should have an array of unique hosts').isEachUniqueHostValid()
logger.debug('Checking makeFriends parameters', { parameters: req.body })
2017-07-11 17:04:57 +02:00
checkErrors(req, res, () => {
hasFriends()
.then(heHasFriends => {
if (heHasFriends === true) {
// We need to quit our friends before make new ones
return res.sendStatus(409)
}
return next()
})
.catch(err => {
2017-07-07 18:26:12 +02:00
logger.error('Cannot know if we have friends.', err)
res.sendStatus(500)
})
})
}
2017-06-10 22:15:25 +02:00
function podsAddValidator (req: express.Request, res: express.Response, next: express.NextFunction) {
2017-02-16 19:19:56 +01:00
req.checkBody('host', 'Should have a host').isHostValid()
req.checkBody('email', 'Should have an email').isEmail()
req.checkBody('publicKey', 'Should have a public key').notEmpty()
logger.debug('Checking podsAdd parameters', { parameters: req.body })
2017-07-11 17:04:57 +02:00
checkErrors(req, res, () => {
db.Pod.loadByHost(req.body.host)
.then(pod => {
// Pod with this host already exists
if (pod) {
return res.sendStatus(409)
}
return next()
})
.catch(err => {
2017-07-07 18:26:12 +02:00
logger.error('Cannot load pod by host.', err)
res.sendStatus(500)
})
})
}
function podRemoveValidator (req: express.Request, res: express.Response, next: express.NextFunction) {
req.checkParams('id', 'Should have a valid id').notEmpty().isNumeric()
logger.debug('Checking podRemoveValidator parameters', { parameters: req.params })
checkErrors(req, res, function () {
db.Pod.load(req.params.id)
.then(pod => {
if (!pod) {
logger.error('Cannot find pod %d.', req.params.id)
return res.sendStatus(404)
}
res.locals.pod = pod
return next()
})
.catch(err => {
logger.error('Cannot load pod %d.', req.params.id, err)
res.sendStatus(500)
})
})
}
// ---------------------------------------------------------------------------
2017-05-15 22:22:03 +02:00
export {
makeFriendsValidator,
podsAddValidator,
podRemoveValidator
2017-05-15 22:22:03 +02:00
}