mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-02-03 23:00:14 -05:00
- we are getting rid of the concept of having multiple api versions in a single ghost install - we no longer need to pass the apiVersion around using res.locals - To simplify code that uses our frontend proxy the proxy now _only_ exposes canary
62 lines
2 KiB
JavaScript
62 lines
2 KiB
JavaScript
const debug = require('@tryghost/debug')('services:routing:controllers:emailpost');
|
|
const config = require('../../../../shared/config');
|
|
const {routerManager} = require('../');
|
|
const urlUtils = require('../../../../shared/url-utils');
|
|
const renderer = require('../../rendering');
|
|
|
|
/**
|
|
* @description Email Post Controller.
|
|
* @param {Object} req
|
|
* @param {Object} res
|
|
* @param {Function} next
|
|
* @returns {Promise}
|
|
*/
|
|
module.exports = function emailPostController(req, res, next) {
|
|
debug('emailPostController');
|
|
|
|
const api = require('../../proxy').api;
|
|
|
|
const params = {
|
|
uuid: req.params.uuid,
|
|
include: 'authors,tags,tiers',
|
|
context: {
|
|
member: res.locals.member
|
|
}
|
|
};
|
|
|
|
return api[res.routerOptions.query.controller]
|
|
.read(params)
|
|
.then(function then(result) {
|
|
const post = result[res.routerOptions.query.resource][0];
|
|
|
|
if (!post) {
|
|
return next();
|
|
}
|
|
|
|
if (req.params.options && req.params.options.toLowerCase() === 'edit') {
|
|
// CASE: last param of the url is /edit but admin redirects are disabled
|
|
if (!config.get('admin:redirects')) {
|
|
return next();
|
|
}
|
|
|
|
// CASE: last param of the url is /edit, redirect to admin
|
|
// NOTE: only 'post' resources support email-only mode
|
|
return urlUtils.redirectToAdmin(302, res, `/#/editor/post/${post.id}`);
|
|
} else if (req.params.options) {
|
|
// CASE: unknown options param detected, ignore
|
|
return next();
|
|
}
|
|
|
|
if (post.status === 'published') {
|
|
return urlUtils.redirect301(res, routerManager.getUrlByResourceId(post.id, {withSubdirectory: true}));
|
|
}
|
|
|
|
post.access = !!post.html;
|
|
|
|
// @TODO: See renderer/secure
|
|
renderer.secure(req, post);
|
|
|
|
return renderer.renderEntry(req, res)(post);
|
|
})
|
|
.catch(renderer.handleError(next));
|
|
};
|