in locals middleware require tavern and mods only once

This commit is contained in:
Matteo Pagliazzi
2015-08-14 13:10:53 +02:00
parent fbeeb18923
commit 34dd4494ec
2 changed files with 7 additions and 2 deletions

View File

@@ -6,6 +6,8 @@ var i18n = require('../i18n.js');
var buildManifest = require('../libs/buildManifest');
var shared = require('../../../common');
var forceRefresh = require('./forceRefresh');
var tavern = require('../models/group').tavern;
var mods = require('../models/user').mods;
module.exports = function(req, res, next) {
var language = _.find(i18n.avalaibleLanguages, {code: req.language});
@@ -14,7 +16,6 @@ module.exports = function(req, res, next) {
// Load moment.js language file only when not on static pages
language.momentLang = ((!isStaticPage && i18n.momentLangs[language.code]) || undefined);
var tavern = require('../models/group').tavern;
var envVars = _.pick(nconf.get(), 'NODE_ENV BASE_URL GA_ID STRIPE_PUB_KEY FACEBOOK_KEY AMPLITUDE_KEY'.split(' '));
res.locals.habitrpg = _.merge(envVars, {
IS_MOBILE: /Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(req.header('User-Agent')),
@@ -31,7 +32,7 @@ module.exports = function(req, res, next) {
},
siteVersion: forceRefresh.siteVersion,
Content: shared.content,
mods: require('../models/user').mods,
mods: mods,
tavern: tavern, // for world boss
worldDmg: (tavern && tavern.quest && tavern.quest.extra && tavern.quest.extra.worldDmg) || {},
_: _,

View File

@@ -577,6 +577,10 @@ UserSchema.methods.unlink = function(options, cb) {
module.exports.schema = UserSchema;
module.exports.model = mongoose.model("User", UserSchema);
// Initially export an empty object so external requires will get
// the right object by reference when it's defined later
// Otherwise it would remain undefined if requested before the query executes
module.exports.mods = {};
mongoose.model("User")
.find({'contributor.admin':true})