mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-09 07:25:46 +01:00
started moving admin mdw into middleware/admin.js; res.render post-processing to append admin footer/header
This commit is contained in:
49
src/middleware/admin.js
Normal file
49
src/middleware/admin.js
Normal file
@@ -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) {
|
||||||
|
|||||||
Reference in New Issue
Block a user