mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-18 03:31:03 +01:00
closes #3519
This commit is contained in:
@@ -112,7 +112,7 @@ $(document).ready(function() {
|
|||||||
if (data) {
|
if (data) {
|
||||||
data.responseJSON.config = config;
|
data.responseJSON.config = config;
|
||||||
var status = parseInt(data.status, 10);
|
var status = parseInt(data.status, 10);
|
||||||
if (status === 403 || status === 404 || status === 500 || status === 502) {
|
if (status === 403 || status === 404 || status === 500 || status === 502 || status === 503) {
|
||||||
if (status === 502) {
|
if (status === 502) {
|
||||||
status = 500;
|
status = 500;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
var nconf = require('nconf');
|
||||||
var meta = require('../meta');
|
var meta = require('../meta');
|
||||||
var user = require('../user');
|
var user = require('../user');
|
||||||
var translator = require('../../public/src/modules/translator');
|
var translator = require('../../public/src/modules/translator');
|
||||||
@@ -8,39 +9,36 @@ var translator = require('../../public/src/modules/translator');
|
|||||||
module.exports = function(middleware) {
|
module.exports = function(middleware) {
|
||||||
|
|
||||||
middleware.maintenanceMode = function(req, res, next) {
|
middleware.maintenanceMode = function(req, res, next) {
|
||||||
console.log(req.path, meta.config.maintenanceMode)
|
|
||||||
if (parseInt(meta.config.maintenanceMode, 10) !== 1) {
|
if (parseInt(meta.config.maintenanceMode, 10) !== 1) {
|
||||||
return next();
|
return next();
|
||||||
}
|
}
|
||||||
|
var url = req.url.replace(nconf.get('relative_path'), '');
|
||||||
|
|
||||||
var allowedRoutes = [
|
var allowedRoutes = [
|
||||||
'/login',
|
'^/login',
|
||||||
'/stylesheet.css',
|
'^/stylesheet.css',
|
||||||
'/nodebb.min.js',
|
'^/favicon',
|
||||||
'/vendor/fontawesome/fonts/fontawesome-webfont.woff',
|
'^/nodebb.min.js',
|
||||||
'/src/(modules|client)/[\\w/]+.js',
|
'^/vendor/fontawesome/fonts/fontawesome-webfont.woff',
|
||||||
'/templates/[\\w/]+.tpl',
|
'^/src/(modules|client)/[\\w/]+.js',
|
||||||
'/api/login',
|
'^/templates/[\\w/]+.tpl',
|
||||||
'/api/?',
|
'^/api/login',
|
||||||
'/language/.+',
|
'^/api/widgets/render',
|
||||||
'/uploads/system/site-logo.png'
|
'^/language/.+',
|
||||||
|
'^/uploads/system/site-logo.png'
|
||||||
],
|
],
|
||||||
render = function() {
|
render = function() {
|
||||||
res.status(503);
|
res.status(503);
|
||||||
|
var data = {
|
||||||
if (!isApiRoute.test(req.url)) {
|
|
||||||
middleware.buildHeader(req, res, function() {
|
|
||||||
res.render('maintenance', {
|
|
||||||
site_title: meta.config.title || 'NodeBB',
|
site_title: meta.config.title || 'NodeBB',
|
||||||
message: meta.config.maintenanceModeMessage
|
message: meta.config.maintenanceModeMessage
|
||||||
});
|
};
|
||||||
|
if (!isApiRoute.test(url)) {
|
||||||
|
middleware.buildHeader(req, res, function() {
|
||||||
|
res.render('503', data);
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
translator.translate('[[pages:maintenance.text, ' + meta.config.title + ']]', meta.config.defaultLang || 'en_GB', function(translated) {
|
res.json(data);
|
||||||
res.json({
|
|
||||||
error: translated
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
isAllowed = function(url) {
|
isAllowed = function(url) {
|
||||||
@@ -54,7 +52,7 @@ module.exports = function(middleware) {
|
|||||||
},
|
},
|
||||||
isApiRoute = /^\/api/;
|
isApiRoute = /^\/api/;
|
||||||
|
|
||||||
if (isAllowed(req.url)) {
|
if (isAllowed(url)) {
|
||||||
return next();
|
return next();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user