const waterfall = require('async/waterfall')
const db = require('../../initializers/database')
+const constants = require('../../initializers/constants')
const logger = require('../../helpers/logger')
+const peertubeCrypto = require('../../helpers/peertube-crypto')
+const utils = require('../../helpers/utils')
const friends = require('../../lib/friends')
const middlewares = require('../../middlewares')
const admin = middlewares.admin
const oAuth = middlewares.oauth
const podsMiddleware = middlewares.pods
-const checkSignature = middlewares.secure.checkSignature
const validators = middlewares.validators.pods
-const signatureValidator = middlewares.validators.remote.signature
const router = express.Router()
router.get('/', listPods)
router.post('/',
+ podsMiddleware.setBodyHostPort, // We need to modify the host before running the validator!
validators.podsAdd,
- podsMiddleware.setBodyHostPort,
addPods
)
router.post('/makefriends',
admin.ensureIsAdmin,
quitFriends
)
-// Post because this is a secured request
-router.post('/remove',
- signatureValidator,
- checkSignature,
- removePods
-)
// ---------------------------------------------------------------------------
},
function fetchMyCertificate (callback) {
- friends.getMyCertificate(function (err, cert) {
+ peertubeCrypto.getMyPublicCert(function (err, cert) {
if (err) {
logger.error('Cannot read cert file.')
return callback(err)
], function (err, cert) {
if (err) return next(err)
- return res.json({ cert: cert })
+ return res.json({ cert: cert, email: constants.CONFIG.ADMIN.EMAIL })
})
}
db.Pod.list(function (err, podsList) {
if (err) return next(err)
- res.json(getFormatedPods(podsList))
+ res.json(utils.getFormatedObjects(podsList, podsList.length))
})
}
res.type('json').status(204).end()
}
-function removePods (req, res, next) {
- const host = req.body.signature.host
-
- waterfall([
- function loadPod (callback) {
- db.Pod.loadByHost(host, callback)
- },
-
- function removePod (pod, callback) {
- pod.destroy().asCallback(callback)
- }
- ], function (err) {
- if (err) return next(err)
-
- return res.type('json').status(204).end()
- })
-}
-
function quitFriends (req, res, next) {
friends.quitFriends(function (err) {
if (err) return next(err)
res.type('json').status(204).end()
})
}
-
-// ---------------------------------------------------------------------------
-
-function getFormatedPods (pods) {
- const formatedPods = []
-
- pods.forEach(function (pod) {
- formatedPods.push(pod.toFormatedJSON())
- })
-
- return formatedPods
-}