v1.18.x
barisusakli 10 years ago
parent 93e6916fe6
commit c3719ea5b5

@ -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();
} }

Loading…
Cancel
Save