v1.18.x
Baris Usakli 7 years ago
parent b02e918220
commit cc6a683bc4

@ -1,6 +1,8 @@
'use strict'; 'use strict';
var async = require('async'); var async = require('async');
var url = require('url');
var plugins = require('../plugins'); var plugins = require('../plugins');
var meta = require('../meta'); var meta = require('../meta');
var user = require('../user'); var user = require('../user');
@ -18,7 +20,7 @@ function getUserHomeRoute(uid, callback) {
var route = adminHomePageRoute(); var route = adminHomePageRoute();
if (settings.homePageRoute !== 'undefined' && settings.homePageRoute !== 'none') { if (settings.homePageRoute !== 'undefined' && settings.homePageRoute !== 'none') {
route = settings.homePageRoute || route; route = (settings.homePageRoute || route).replace(/^\/+/, '');
} }
next(null, route); next(null, route);
@ -40,13 +42,21 @@ function rewrite(req, res, next) {
} }
}, },
function (route, next) { function (route, next) {
var hook = 'action:homepage.get:' + route; var parsedUrl;
try {
parsedUrl = url.parse(route, true);
} catch (err) {
return next(err);
}
var pathname = parsedUrl.pathname;
var hook = 'action:homepage.get:' + pathname;
if (!plugins.hasListeners(hook)) { if (!plugins.hasListeners(hook)) {
req.url = req.path + (!req.path.endsWith('/') ? '/' : '') + route; req.url = req.path + (!req.path.endsWith('/') ? '/' : '') + pathname;
} else { } else {
res.locals.homePageRoute = route; res.locals.homePageRoute = pathname;
} }
req.query = Object.assign(parsedUrl.query, req.query);
next(); next();
}, },

Loading…
Cancel
Save