mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-08 20:22:53 +03:00
fa91c6c954
closes #11574 - the current implementation of the access property has it frontend only, and wired up only in one place - this leaves it only available in a handful of places, e.g. can't use it in a post loop or get helper - the current implementation also fails logically if the html content of the post is blank This fix moves the behaviour to the API - this ensures the field is always available no matter what context you are in - it also updates the logic to use the same membersHasAccess logic as is used to gate the post, so it's always correct TODO: should reconsider the location of this code
93 lines
3.4 KiB
JavaScript
93 lines
3.4 KiB
JavaScript
const debug = require('ghost-ignition').debug('services:routing:controllers:entry');
|
|
const url = require('url');
|
|
const config = require('../../../../shared/config');
|
|
const urlService = require('../../../services/url');
|
|
const urlUtils = require('../../../../shared/url-utils');
|
|
const helpers = require('../helpers');
|
|
|
|
/**
|
|
* @description Entry controller.
|
|
* @param {Object} req
|
|
* @param {Object} res
|
|
* @param {Function} next
|
|
* @returns {Promise}
|
|
*/
|
|
module.exports = function entryController(req, res, next) {
|
|
debug('entryController', res.routerOptions);
|
|
|
|
return helpers.entryLookup(req.path, res.routerOptions, res.locals)
|
|
.then(function then(lookup) {
|
|
// Format data 1
|
|
const entry = lookup ? lookup.entry : false;
|
|
|
|
if (!entry) {
|
|
debug('no entry');
|
|
return next();
|
|
}
|
|
|
|
// CASE: postlookup can detect options for example /edit, unknown options get ignored and end in 404
|
|
if (lookup.isUnknownOption) {
|
|
debug('isUnknownOption');
|
|
return next();
|
|
}
|
|
|
|
// CASE: last param is of url is /edit, redirect to admin
|
|
if (lookup.isEditURL) {
|
|
if (!config.get('admin:redirects')) {
|
|
debug('is edit url but admin redirects are disabled');
|
|
return next();
|
|
}
|
|
|
|
debug('redirect. is edit url');
|
|
const resourceType = entry.page ? 'page' : 'post';
|
|
|
|
return urlUtils.redirectToAdmin(302, res, `/#/editor/${resourceType}/${entry.id}`);
|
|
}
|
|
|
|
/**
|
|
* CASE: check if type of router owns this resource
|
|
*
|
|
* Static pages have a hardcoded permalink, which is `/:slug/`.
|
|
* Imagine you define a collection under `/` with the permalink `/:slug/`.
|
|
*
|
|
* The router hierarchy is:
|
|
*
|
|
* 1. collections
|
|
* 2. static pages
|
|
*
|
|
* Both permalinks are registered in express. If you serve a static page, the
|
|
* collection router will try to serve this as a post resource.
|
|
*
|
|
* That's why we have to check against the router type.
|
|
*/
|
|
if (urlService.getResourceById(entry.id).config.type !== res.routerOptions.resourceType) {
|
|
debug('not my resource type');
|
|
return next();
|
|
}
|
|
|
|
/**
|
|
* CASE: Permalink is not valid anymore, we redirect him permanently to the correct one
|
|
* This should only happen if you have date permalinks enabled and you change
|
|
* your publish date.
|
|
*
|
|
* @NOTE:
|
|
*
|
|
* Ensure we redirect to the correct post url including subdirectory.
|
|
*/
|
|
if (urlUtils.absoluteToRelative(entry.url, {withoutSubdirectory: true}) !== req.path) {
|
|
debug('redirect');
|
|
|
|
return urlUtils.redirect301(res, url.format({
|
|
pathname: url.parse(entry.url).pathname,
|
|
search: url.parse(req.originalUrl).search
|
|
}));
|
|
}
|
|
|
|
helpers.secure(req, entry);
|
|
|
|
const renderer = helpers.renderEntry(req, res);
|
|
return renderer(entry);
|
|
})
|
|
.catch(helpers.handleError(next));
|
|
};
|