tracman-server/config/routes/admin.js

51 lines
1.2 KiB
JavaScript
Raw Normal View History

2016-03-31 15:57:34 -06:00
var router = require('express').Router(),
mw = require('../middleware.js'),
2016-09-08 05:26:12 -06:00
User = require('../models/user.js');
2016-03-31 15:57:34 -06:00
2016-06-12 18:18:34 -06:00
router.route('/')
.all(mw.ensureAdmin, function(req,res,next){
2016-03-31 15:57:34 -06:00
next();
}).get(function(req,res){
2016-06-30 14:40:21 -06:00
var cbc = 0;
var checkCBC = function(req,res,err){
2017-01-04 15:35:39 -07:00
if (err) {
req.flash('error', err.message);
console.log(err);
}
if (cbc<1){ cbc++; }
else { // done
2016-06-30 14:40:21 -06:00
res.render('admin.html', {
2016-03-31 15:57:34 -06:00
noFooter: '1',
success:req.flash('success')[0],
error:req.flash('error')[0]
});
2016-06-30 14:40:21 -06:00
}
2017-01-04 15:35:39 -07:00
};
2016-06-30 14:40:21 -06:00
User.findById(req.session.passport.user, function(err, found) {
res.locals.user = found;
checkCBC(req,res,err);
});
2016-09-08 05:26:12 -06:00
2016-06-30 14:40:21 -06:00
User.find({}).sort({lastLogin:-1}).exec(function(err, found){
res.locals.users = found;
checkCBC(req,res,err);
});
});
router.route('/users')
2016-06-30 14:40:21 -06:00
.all(mw.ensureAdmin, function(req,res,next){
2016-08-09 23:51:49 -06:00
next();
2017-01-04 15:35:39 -07:00
}).post(function(req,res,next){
if (req.body.delete) {
User.findOneAndRemove({'_id':req.body.delete}, function(err,user){
if (err){ req.flash('error', err.message); }
else { req.flash('success', '<i>'+user.name+'</i> deleted.'); }
2016-06-30 14:40:21 -06:00
res.redirect('/admin#users');
});
} else { console.log('ERROR! POST without action sent. '); next(); }
2016-03-31 15:57:34 -06:00
});
module.exports = router;