avoid doing nconf.get over and over again on the same key

v1.18.x
psychobunny 11 years ago
parent 3c0c3a9649
commit 3f22027007

@ -13,18 +13,23 @@ var templates = require('./../../public/src/templates'),
fs = require('fs'), fs = require('fs'),
nconf = require('nconf'), nconf = require('nconf'),
express = require('express'), express = require('express'),
winston = require('winston'); winston = require('winston'),
relativePath,
viewsPath,
themesPath,
baseTemplatesPath,
themeTemplatesPath;
var middleware = {};
var middleware = {};
function routeThemeScreenshots(app, themes) { function routeThemeScreenshots(app, themes) {
var screenshotPath; var screenshotPath;
async.each(themes, function(themeObj, next) { async.each(themes, function(themeObj, next) {
if (themeObj.screenshot) { if (themeObj.screenshot) {
screenshotPath = path.join(nconf.get('themes_path'), themeObj.id, themeObj.screenshot); screenshotPath = path.join(themesPath, themeObj.id, themeObj.screenshot);
(function(id, path) { (function(id, path) {
fs.exists(path, function(exists) { fs.exists(path, function(exists) {
if (exists) { if (exists) {
@ -50,7 +55,7 @@ function routeCurrentTheme(app, themeData) {
// Theme's static directory // Theme's static directory
if (themeData['theme:staticDir']) { if (themeData['theme:staticDir']) {
app.use(nconf.get('relative_path') + '/css/assets', express.static(path.join(nconf.get('themes_path'), themeData['theme:id'], themeData['theme:staticDir']), { app.use(relativePath + '/css/assets', express.static(path.join(themesPath, themeData['theme:id'], themeData['theme:staticDir']), {
maxAge: app.enabled('cache') ? 5184000000 : 0 maxAge: app.enabled('cache') ? 5184000000 : 0
})); }));
if (process.env.NODE_ENV === 'development') { if (process.env.NODE_ENV === 'development') {
@ -64,37 +69,37 @@ function compileTemplates(pluginTemplates) {
rimraf = require('rimraf'); rimraf = require('rimraf');
winston.info('[themes] Compiling templates'); winston.info('[themes] Compiling templates');
rimraf.sync(nconf.get('views_dir')); rimraf.sync(viewsPath);
mkdirp.sync(nconf.get('views_dir')); mkdirp.sync(viewsPath);
utils.walk(nconf.get('base_templates_path'), function(err, baseTpls) { utils.walk(baseTemplatesPath, function(err, baseTpls) {
utils.walk(nconf.get('theme_templates_path'), function (err, themeTpls) { utils.walk(themeTemplatesPath, function (err, themeTpls) {
var paths = pluginTemplates; var paths = pluginTemplates;
if (!baseTpls || !themeTpls) { if (!baseTpls || !themeTpls) {
winston.warn('[themes] Could not find base template files at: ' + nconf.get('base_templates_path')); winston.warn('[themes] Could not find base template files at: ' + baseTemplatesPath);
} }
baseTpls = !baseTpls ? [] : baseTpls.map(function(tpl) { return tpl.replace(nconf.get('base_templates_path'), ''); }); baseTpls = !baseTpls ? [] : baseTpls.map(function(tpl) { return tpl.replace(baseTemplatesPath, ''); });
themeTpls = !themeTpls ? [] : themeTpls.map(function(tpl) { return tpl.replace(nconf.get('theme_templates_path'), ''); }); themeTpls = !themeTpls ? [] : themeTpls.map(function(tpl) { return tpl.replace(themeTemplatesPath, ''); });
baseTpls.forEach(function(el, i) { baseTpls.forEach(function(el, i) {
paths[baseTpls[i]] = path.join(nconf.get('base_templates_path'), baseTpls[i]); paths[baseTpls[i]] = path.join(baseTemplatesPath, baseTpls[i]);
}); });
themeTpls.forEach(function(el, i) { themeTpls.forEach(function(el, i) {
paths[themeTpls[i]] = path.join(nconf.get('theme_templates_path'), themeTpls[i]); paths[themeTpls[i]] = path.join(themeTemplatesPath, themeTpls[i]);
}); });
async.each(Object.keys(paths), function(relative_path, next) { async.each(Object.keys(paths), function(relativePath, next) {
var file = fs.readFileSync(paths[relative_path]).toString(), var file = fs.readFileSync(paths[relativePath]).toString(),
matches = null, matches = null,
regex = /[ \t]*<!-- IMPORT ([\s\S]*?)? -->[ \t]*/; regex = /[ \t]*<!-- IMPORT ([\s\S]*?)? -->[ \t]*/;
while(matches = file.match(regex)) { while(matches = file.match(regex)) {
var partial = "/" + matches[1]; var partial = "/" + matches[1];
if (paths[partial] && relative_path !== partial) { if (paths[partial] && relativePath !== partial) {
file = file.replace(regex, fs.readFileSync(paths[partial]).toString()); file = file.replace(regex, fs.readFileSync(paths[partial]).toString());
} else { } else {
winston.warn('[themes] Partial not loaded: ' + matches[1]); winston.warn('[themes] Partial not loaded: ' + matches[1]);
@ -102,8 +107,8 @@ function compileTemplates(pluginTemplates) {
} }
} }
mkdirp.sync(path.join(nconf.get('views_dir'), relative_path.split('/').slice(0, -1).join('/'))); mkdirp.sync(path.join(viewsPath, relativePath.split('/').slice(0, -1).join('/')));
fs.writeFile(path.join(nconf.get('views_dir'), relative_path), file, next); fs.writeFile(path.join(viewsPath, relativePath), file, next);
}, function(err) { }, function(err) {
if (err) { if (err) {
winston.error(err); winston.error(err);
@ -130,8 +135,8 @@ function handleErrors(err, req, res, next) {
} }
function catch404(req, res, next) { function catch404(req, res, next) {
var isLanguage = new RegExp('^' + nconf.get('relative_path') + '/language/[\\w]{2,}/.*.json'), var isLanguage = new RegExp('^' + relativePath + '/language/[\\w]{2,}/.*.json'),
isClientScript = new RegExp('^' + nconf.get('relative_path') + '\\/src\\/forum(\\/admin)?\\/.+\\.js'); isClientScript = new RegExp('^' + relativePath + '\\/src\\/forum(\\/admin)?\\/.+\\.js');
res.status(404); res.status(404);
@ -144,7 +149,7 @@ function catch404(req, res, next) {
winston.warn('Route requested but not found: ' + req.url); winston.warn('Route requested but not found: ' + req.url);
} }
res.redirect(nconf.get('relative_path') + '/404'); res.redirect(relativePath + '/404');
} else if (req.accepts('json')) { } else if (req.accepts('json')) {
if (process.env.NODE_ENV === 'development') { if (process.env.NODE_ENV === 'development') {
winston.warn('Route requested but not found: ' + req.url); winston.warn('Route requested but not found: ' + req.url);
@ -164,15 +169,21 @@ function catch404(req, res, next) {
module.exports = function(app, data) { module.exports = function(app, data) {
middleware = require('./middleware')(app); middleware = require('./middleware')(app);
relativePath = nconf.get('relative_path');
viewsPath = nconf.get('views_dir');
themesPath = nconf.get('themes_path');
baseTemplatesPath = nconf.get('base_templates_path');
themeTemplatesPath = nconf.get('theme_templates_path');
app.configure(function() { app.configure(function() {
app.engine('tpl', templates.__express); app.engine('tpl', templates.__express);
app.set('view engine', 'tpl'); app.set('view engine', 'tpl');
app.set('views', nconf.get('views_dir')); app.set('views', viewsPath);
app.use(express.compress()); app.use(express.compress());
app.use(express.favicon(path.join(__dirname, '../../', 'public', meta.config['brand:favicon'] ? meta.config['brand:favicon'] : 'favicon.ico'))); app.use(express.favicon(path.join(__dirname, '../../', 'public', meta.config['brand:favicon'] ? meta.config['brand:favicon'] : 'favicon.ico')));
app.use(nconf.get('relative_path') + '/apple-touch-icon', middleware.routeTouchIcon); app.use(relativePath + '/apple-touch-icon', middleware.routeTouchIcon);
app.use(express.bodyParser()); app.use(express.bodyParser());
app.use(express.cookieParser()); app.use(express.cookieParser());
@ -206,9 +217,9 @@ module.exports = function(app, data) {
compileTemplates(pluginTemplates); compileTemplates(pluginTemplates);
}); });
app.use(nconf.get('relative_path'), app.router); app.use(relativePath, app.router);
app.use(nconf.get('relative_path'), express.static(path.join(__dirname, '../../', 'public'), { app.use(relativePath, express.static(path.join(__dirname, '../../', 'public'), {
maxAge: app.enabled('cache') ? 5184000000 : 0 maxAge: app.enabled('cache') ? 5184000000 : 0
})); }));

Loading…
Cancel
Save