mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-24 19:33:02 +03:00
63723aa36a
closes #8037 🔥 Remove API-level default settings population - This is a relic! - We ALWAYS populate defaults on server start therefore this code could never run. - This was a lot of complicated code that wasn't even needed!! 🎨 Move settings cache - Move settings cache to be its own thing - Update all references - Adds TODOs for further cleanup 🎨 Create settings initialisation step - Create new settings library, which will eventually house more code - Unify the interface for initialising settings (will be more useful later) - Reduce number of calls to updateSettingsCache
89 lines
2.9 KiB
JavaScript
89 lines
2.9 KiB
JavaScript
var path = require('path'),
|
|
express = require('express'),
|
|
_ = require('lodash'),
|
|
ampRouter = express.Router(),
|
|
i18n = require('../../../i18n'),
|
|
|
|
// Dirty requires
|
|
errors = require('../../../errors'),
|
|
settingsCache = require('../../../settings/cache'),
|
|
templates = require('../../../controllers/frontend/templates'),
|
|
postLookup = require('../../../controllers/frontend/post-lookup'),
|
|
setResponseContext = require('../../../controllers/frontend/context');
|
|
|
|
function controller(req, res, next) {
|
|
var defaultView = path.resolve(__dirname, 'views', 'amp.hbs'),
|
|
paths = templates.getActiveThemePaths(req.app.get('activeTheme')),
|
|
data = req.body || {};
|
|
|
|
if (res.error) {
|
|
data.error = res.error;
|
|
}
|
|
|
|
setResponseContext(req, res, data);
|
|
|
|
// we have to check the context. Our context must be ['post', 'amp'], otherwise we won't render the template
|
|
if (_.includes(res.locals.context, 'post') && _.includes(res.locals.context, 'amp')) {
|
|
if (paths.hasOwnProperty('amp.hbs')) {
|
|
return res.render('amp', data);
|
|
} else {
|
|
return res.render(defaultView, data);
|
|
}
|
|
} else {
|
|
return next();
|
|
}
|
|
}
|
|
|
|
function getPostData(req, res, next) {
|
|
req.body = req.body || {};
|
|
|
|
postLookup(res.locals.relativeUrl)
|
|
.then(function (result) {
|
|
if (result && result.post) {
|
|
req.body.post = result.post;
|
|
}
|
|
|
|
next();
|
|
})
|
|
.catch(function (err) {
|
|
next(err);
|
|
});
|
|
}
|
|
|
|
function checkIfAMPIsEnabled(req, res, next) {
|
|
var ampIsEnabled = settingsCache.get('amp');
|
|
|
|
if (ampIsEnabled) {
|
|
return next();
|
|
}
|
|
|
|
// CASE: we don't support amp pages for static pages
|
|
if (req.body.post && req.body.post.page) {
|
|
return next(new errors.NotFoundError({message: i18n.t('errors.errors.pageNotFound')}));
|
|
}
|
|
|
|
/**
|
|
* CASE: amp is disabled, we serve 404
|
|
*
|
|
* Alternatively we could redirect to the original post, as the user can enable/disable AMP every time.
|
|
*
|
|
* If we would call `next()`, express jumps to the frontend controller (server/controllers/frontend/index.js fn single)
|
|
* and tries to lookup the post (again) and checks whether the post url equals the requested url (post.url !== req.path).
|
|
* This check would fail if the blog is setup on a subdirectory.
|
|
*/
|
|
return next(new errors.NotFoundError({message: i18n.t('errors.errors.pageNotFound')}));
|
|
}
|
|
|
|
// AMP frontend route
|
|
ampRouter.route('/')
|
|
.get(
|
|
getPostData,
|
|
checkIfAMPIsEnabled,
|
|
controller
|
|
);
|
|
|
|
module.exports = ampRouter;
|
|
module.exports.controller = controller;
|
|
module.exports.getPostData = getPostData;
|
|
module.exports.checkIfAMPIsEnabled = checkIfAMPIsEnabled;
|