Files
NodeBB/src/middleware/admin.js
2014-09-14 10:21:32 -04:00

104 lines
2.4 KiB
JavaScript

"use strict";
var app,
middleware = {},
nconf = require('nconf'),
async = require('async'),
path = require('path'),
user = require('./../user'),
meta = require('./../meta'),
plugins = require('./../plugins'),
controllers = {
api: require('./../controllers/api')
};
middleware.isAdmin = function(req, res, next) {
if (!req.user) {
return res.json(404, {
error: 'not-found'
});
}
user.isAdministrator((req.user && req.user.uid) ? req.user.uid : 0, function (err, isAdmin) {
if (err) {
return next(err);
}
if (!isAdmin) {
res.status(403);
res.redirect('/403');
} else {
next();
}
});
};
middleware.buildHeader = function(req, res, next) {
var uid = req.user ? req.user.uid : 0;
async.parallel([
function(next) {
var custom_header = {
'plugins': [],
'authentication': []
};
user.getUserFields(uid, ['username', 'userslug', 'picture'], function(err, userData) {
async.parallel({
scripts: function(next) {
plugins.fireHook('filter:admin.scripts.get', [], function(err, scripts) {
var arr = [];
scripts.forEach(function(script) {
arr.push({src: nconf.get('url') + script});
});
next(err, arr);
});
},
custom_header: function(next) {
plugins.fireHook('filter:admin.header.build', custom_header, next);
}
}, function(err, pluginData) {
var data = {
csrf: req.csrfToken ? req.csrfToken() : undefined,
relative_path: nconf.get('relative_path'),
plugins: pluginData.custom_header.plugins,
authentication: pluginData.custom_header.authentication,
scripts: pluginData.scripts,
userpicture: userData.picture,
username: userData.username,
userslug: userData.userslug,
'cache-buster': meta.config['cache-buster'] ? 'v=' + meta.config['cache-buster'] : '',
env: process.env.NODE_ENV ? true : false
};
app.render('admin/header', data, function(err, template) {
res.locals.adminHeader = template;
next(err);
});
});
});
},
function(next) {
controllers.api.getConfig(req, res, function(err, config) {
res.locals.config = config;
next(err);
});
},
function(next) {
app.render('admin/footer', {}, function(err, template) {
res.locals.adminFooter = template;
next(err);
});
}
], function(err) {
next();
});
};
module.exports = function(webserver) {
app = webserver;
return middleware;
};