mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-11-28 22:43:30 +03:00
9f9d8b2fec
no issue - This started as an attempt to simplify the admin redirect code - I realised we were sometimes using utils.redirect301 and sometimes not - Decided to move this into utils.url as it's more relevant to URL generation - Unified usage of redirects in the codebase - Updated tests & ensured we have basic coverage - rename adminRedirect -> redirectToAdmin - Tweak method signature, fix channel edit redirects - Tests: Optimised test descriptions for url-redirects_spec.js - ensure caching works as expected
40 lines
1.2 KiB
JavaScript
40 lines
1.2 KiB
JavaScript
var api = require('../api'),
|
|
utils = require('../utils'),
|
|
filters = require('../filters'),
|
|
handleError = require('./frontend/error'),
|
|
renderPost = require('./frontend/render-post'),
|
|
setRequestIsSecure = require('./frontend/secure');
|
|
|
|
module.exports = function preview(req, res, next) {
|
|
var params = {
|
|
uuid: req.params.uuid,
|
|
status: 'all',
|
|
include: 'author,tags'
|
|
};
|
|
|
|
api.posts.read(params).then(function then(result) {
|
|
var post = result.posts[0];
|
|
|
|
if (!post) {
|
|
return next();
|
|
}
|
|
|
|
if (req.params.options && req.params.options.toLowerCase() === 'edit') {
|
|
// CASE: last param is of url is /edit, redirect to admin
|
|
return utils.url.redirectToAdmin(302, res, '#/editor/' + post.id);
|
|
} else if (req.params.options) {
|
|
// CASE: unknown options param detected. Ignore and end in 404.
|
|
return next();
|
|
}
|
|
|
|
if (post.status === 'published') {
|
|
return utils.url.redirect301(res, utils.url.urlFor('post', {post: post}));
|
|
}
|
|
|
|
setRequestIsSecure(req, post);
|
|
|
|
filters.doFilter('prePostsRender', post, res.locals)
|
|
.then(renderPost(req, res));
|
|
}).catch(handleError(next));
|
|
};
|