2017-03-13 11:30:35 -05:00
|
|
|
var debug = require('debug')('ghost:themes'),
|
2017-03-13 15:13:17 -05:00
|
|
|
_ = require('lodash'),
|
2017-03-13 11:30:35 -05:00
|
|
|
events = require('../events'),
|
2017-03-13 15:13:17 -05:00
|
|
|
errors = require('../errors'),
|
2017-03-13 11:30:35 -05:00
|
|
|
logging = require('../logging'),
|
|
|
|
i18n = require('../i18n'),
|
|
|
|
themeLoader = require('./loader'),
|
2017-03-13 15:13:17 -05:00
|
|
|
active = require('./active'),
|
|
|
|
validate = require('./validate'),
|
2017-03-13 11:30:35 -05:00
|
|
|
settingsCache = require('../settings/cache');
|
2017-02-21 18:26:19 -05:00
|
|
|
|
2017-03-02 11:53:48 -05:00
|
|
|
// @TODO: reduce the amount of things we expose to the outside world
|
|
|
|
// Make this a nice clean sensible API we can all understand!
|
2017-02-21 18:26:19 -05:00
|
|
|
module.exports = {
|
2017-03-13 11:30:35 -05:00
|
|
|
// Init themes module
|
|
|
|
// TODO: move this once we're clear what needs to happen here
|
|
|
|
init: function initThemes() {
|
2017-03-13 15:13:17 -05:00
|
|
|
var activeThemeName = settingsCache.get('activeTheme'),
|
|
|
|
self = this;
|
|
|
|
|
2017-03-13 11:30:35 -05:00
|
|
|
debug('init themes', activeThemeName);
|
|
|
|
|
|
|
|
// Register a listener for server-start to load all themes
|
|
|
|
events.on('server:start', function readAllThemesOnServerStart() {
|
|
|
|
themeLoader.loadAllThemes();
|
|
|
|
});
|
|
|
|
|
|
|
|
// Just read the active theme for now
|
|
|
|
return themeLoader
|
|
|
|
.loadOneTheme(activeThemeName)
|
2017-03-13 15:13:17 -05:00
|
|
|
.then(function activeThemeHasLoaded(theme) {
|
|
|
|
// Validate
|
|
|
|
return validate
|
|
|
|
.check(theme)
|
|
|
|
.then(function resultHandler(checkedTheme) {
|
|
|
|
// Activate! (sort of)
|
|
|
|
debug('Activating theme (method A on boot)', activeThemeName);
|
|
|
|
self.activate(theme, checkedTheme);
|
|
|
|
})
|
|
|
|
.catch(function () {
|
|
|
|
// Active theme is not valid, we don't want to exit because the admin panel will still work
|
|
|
|
logging.warn(i18n.t('errors.middleware.themehandler.invalidTheme', {theme: activeThemeName}));
|
|
|
|
});
|
|
|
|
})
|
2017-03-13 11:30:35 -05:00
|
|
|
.catch(function () {
|
|
|
|
// Active theme is missing, we don't want to exit because the admin panel will still work
|
|
|
|
logging.warn(i18n.t('errors.middleware.themehandler.missingTheme', {theme: activeThemeName}));
|
|
|
|
});
|
|
|
|
},
|
|
|
|
// Load themes, soon to be removed and exposed via specific function.
|
2017-03-02 11:53:48 -05:00
|
|
|
loadAll: themeLoader.loadAllThemes,
|
|
|
|
loadOne: themeLoader.loadOneTheme,
|
|
|
|
list: require('./list'),
|
2017-03-13 15:13:17 -05:00
|
|
|
validate: validate,
|
|
|
|
toJSON: require('./to-json'),
|
|
|
|
getActive: active.get,
|
|
|
|
activate: function activate(loadedTheme, checkedTheme) {
|
|
|
|
if (!_.has(checkedTheme, 'results.score.level') || checkedTheme.results.score.level !== 'passing') {
|
|
|
|
throw new errors.InternalServerError({
|
|
|
|
message: i18n.t('errors.middleware.themehandler.invalidTheme', {theme: loadedTheme.name})
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Use the two theme objects to set the current active theme
|
|
|
|
active.set(loadedTheme, checkedTheme);
|
|
|
|
}
|
2017-02-21 18:26:19 -05:00
|
|
|
};
|