started moving admin mdw into middleware/admin.js; res.render post-processing to append admin footer/header

v1.18.x
psychobunny 11 years ago
parent e588762aa0
commit eed97648b1

@ -0,0 +1,49 @@
"use strict";
var app,
middleware = {},
nconf = require('nconf'),
user = require('./../user'),
plugins = require('./../plugins');
middleware.isAdmin = function (req, res, next) {
user.isAdministrator((req.user && req.user.uid) ? req.user.uid : 0, function (err, isAdmin) {
if (!isAdmin) {
res.status(403);
res.redirect('/403');
} else {
next();
}
});
};
middleware.buildHeader = function (req, res, callback) {
var custom_header = {
'plugins': [],
'authentication': []
};
user.getUserFields(req.user.uid, ['username', 'userslug', 'picture'], function(err, userData) {
plugins.fireHook('filter:admin.header.build', custom_header, function(err, custom_header) {
callback(err, templates['admin/header'].parse({
csrf: res.locals.csrf_token,
relative_path: nconf.get('relative_path'),
plugins: custom_header.plugins,
authentication: custom_header.authentication,
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
}));
});
});
};
module.exports = function(webserver) {
app = webserver;
return middleware;
};

@ -278,6 +278,8 @@ middleware.processRender = function(req, res, next) {
render.call(self, template, options, function(err, str) { render.call(self, template, options, function(err, str) {
if (res.locals.footer) { if (res.locals.footer) {
str = str + res.locals.footer; str = str + res.locals.footer;
} else if (res.locals.adminFooter) {
str = str + res.locals.adminFooter;
} }
if (res.locals.renderHeader) { if (res.locals.renderHeader) {
@ -291,6 +293,14 @@ middleware.processRender = function(req, res, next) {
fn(err, translated); fn(err, translated);
}); });
}); });
} else if (res.locals.renderAdminHeader) {
middleware.admin.renderHeader({
req: req,
res: res
}, function(err, template) {
str = template + str;
fn(err, str);
});
} else { } else {
fn(err, str); fn(err, str);
} }
@ -312,6 +322,7 @@ middleware.routeTouchIcon = function(req, res) {
module.exports = function(webserver) { module.exports = function(webserver) {
app = webserver; app = webserver;
middleware.admin = require('./admin')(webserver);
plugins.ready(function() { plugins.ready(function() {
// Minify client-side libraries // Minify client-side libraries

@ -103,10 +103,8 @@ module.exports = function(app, middleware, controllers) {
}()); }());
app.namespace('/admin', function () { app.namespace('/admin', function () {
app.get('/', function (req, res) { app.get('/', middleware.buildHeader, function(req, res, next) {
Admin.buildHeader(req, res, function(err, header) { res.render('admin/index', {});
res.send(header + app.create_route('admin/index') + templates['admin/footer']);
});
}); });
app.get('/index', function (req, res) { app.get('/index', function (req, res) {

Loading…
Cancel
Save