mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
🦄 Channels: Stored config in res.locals not req (#8884)
refs #5091 - This tiny refactor opens the door for using channel config inside of helpers - This means that ghost_head, and the next_post/prev_post helpers can be context aware
This commit is contained in:
parent
137b8bf973
commit
bd41dba35b
6 changed files with 45 additions and 37 deletions
|
@ -35,7 +35,7 @@ function handlePageParam(req, res, next, page) {
|
||||||
|
|
||||||
rssRouter = function rssRouter(channelConfig) {
|
rssRouter = function rssRouter(channelConfig) {
|
||||||
function rssConfigMiddleware(req, res, next) {
|
function rssConfigMiddleware(req, res, next) {
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
next();
|
next();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,7 +57,7 @@ rssRouter = function rssRouter(channelConfig) {
|
||||||
channelRouter = function router() {
|
channelRouter = function router() {
|
||||||
function channelConfigMiddleware(channel) {
|
function channelConfigMiddleware(channel) {
|
||||||
return function doChannelConfig(req, res, next) {
|
return function doChannelConfig(req, res, next) {
|
||||||
req.channelConfig = _.cloneDeep(channel);
|
res.locals.channel = _.cloneDeep(channel);
|
||||||
next();
|
next();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ var debug = require('debug')('ghost:channels:render'),
|
||||||
function renderChannel(req, res, next) {
|
function renderChannel(req, res, next) {
|
||||||
debug('renderChannel called');
|
debug('renderChannel called');
|
||||||
// Parse the parameters we need from the URL
|
// Parse the parameters we need from the URL
|
||||||
var channelOpts = req.channelConfig,
|
var channelOpts = res.locals.channel,
|
||||||
pageParam = req.params.page !== undefined ? req.params.page : 1,
|
pageParam = req.params.page !== undefined ? req.params.page : 1,
|
||||||
slugParam = req.params.slug ? safeString(req.params.slug) : undefined;
|
slugParam = req.params.slug ? safeString(req.params.slug) : undefined;
|
||||||
|
|
||||||
|
|
|
@ -161,16 +161,17 @@ generate = function generate(req, res, next) {
|
||||||
// Initialize RSS
|
// Initialize RSS
|
||||||
var pageParam = req.params.page !== undefined ? req.params.page : 1,
|
var pageParam = req.params.page !== undefined ? req.params.page : 1,
|
||||||
slugParam = req.params.slug,
|
slugParam = req.params.slug,
|
||||||
baseUrl = getBaseUrl(req, slugParam);
|
baseUrl = getBaseUrl(req, slugParam),
|
||||||
|
channelConfig = res.locals.channel;
|
||||||
|
|
||||||
// Ensure we at least have an empty object for postOptions
|
// Ensure we at least have an empty object for postOptions
|
||||||
req.channelConfig.postOptions = req.channelConfig.postOptions || {};
|
channelConfig.postOptions = channelConfig.postOptions || {};
|
||||||
// Set page on postOptions for the query made later
|
// Set page on postOptions for the query made later
|
||||||
req.channelConfig.postOptions.page = pageParam;
|
channelConfig.postOptions.page = pageParam;
|
||||||
|
|
||||||
req.channelConfig.slugParam = slugParam;
|
channelConfig.slugParam = slugParam;
|
||||||
|
|
||||||
return getData(req.channelConfig).then(function then(data) {
|
return getData(channelConfig).then(function then(data) {
|
||||||
var maxPage = data.results.meta.pagination.pages;
|
var maxPage = data.results.meta.pagination.pages;
|
||||||
|
|
||||||
// If page is greater than number of pages we have, redirect to last page
|
// If page is greater than number of pages we have, redirect to last page
|
||||||
|
|
|
@ -29,7 +29,8 @@ describe('Channels', function () {
|
||||||
// Run a test which should result in a render
|
// Run a test which should result in a render
|
||||||
function testChannelRender(props, assertions, done) {
|
function testChannelRender(props, assertions, done) {
|
||||||
res = {
|
res = {
|
||||||
redirect: sandbox.spy()
|
redirect: sandbox.spy(),
|
||||||
|
locals: {}
|
||||||
};
|
};
|
||||||
|
|
||||||
res.render = function (view) {
|
res.render = function (view) {
|
||||||
|
@ -47,7 +48,8 @@ describe('Channels', function () {
|
||||||
function testChannelRedirect(props, assertions, done) {
|
function testChannelRedirect(props, assertions, done) {
|
||||||
res = {
|
res = {
|
||||||
render: sandbox.spy(),
|
render: sandbox.spy(),
|
||||||
set: sandbox.spy()
|
set: sandbox.spy(),
|
||||||
|
locals: {}
|
||||||
};
|
};
|
||||||
|
|
||||||
res.redirect = function (status, path) {
|
res.redirect = function (status, path) {
|
||||||
|
@ -66,7 +68,8 @@ describe('Channels', function () {
|
||||||
res = {
|
res = {
|
||||||
redirect: sandbox.spy(),
|
redirect: sandbox.spy(),
|
||||||
render: sandbox.spy(),
|
render: sandbox.spy(),
|
||||||
set: sandbox.spy()
|
set: sandbox.spy(),
|
||||||
|
locals: {}
|
||||||
};
|
};
|
||||||
|
|
||||||
_.extend(req, props);
|
_.extend(req, props);
|
||||||
|
|
|
@ -24,9 +24,13 @@ describe('Render Channel', function () {
|
||||||
|
|
||||||
describe('Tag config', function () {
|
describe('Tag config', function () {
|
||||||
var req = {
|
var req = {
|
||||||
channelConfig: channelConfig('tag'),
|
|
||||||
params: {}
|
params: {}
|
||||||
},
|
},
|
||||||
|
res = {
|
||||||
|
locals: {
|
||||||
|
channel: channelConfig('tag')
|
||||||
|
}
|
||||||
|
},
|
||||||
promise = {
|
promise = {
|
||||||
then: function () {
|
then: function () {
|
||||||
return {
|
return {
|
||||||
|
@ -45,7 +49,7 @@ describe('Render Channel', function () {
|
||||||
return promise;
|
return promise;
|
||||||
});
|
});
|
||||||
|
|
||||||
renderChannel(req);
|
renderChannel(req, res);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -97,8 +97,8 @@ describe('RSS', function () {
|
||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
|
|
||||||
req.channelConfig = channelConfig.get('index');
|
res.locals.channel = channelConfig.get('index');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
rss(req, res, failTest(done));
|
rss(req, res, failTest(done));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -140,8 +140,8 @@ describe('RSS', function () {
|
||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
|
|
||||||
req.channelConfig = channelConfig.get('index');
|
res.locals.channel = channelConfig.get('index');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
rss(req, res, failTest(done));
|
rss(req, res, failTest(done));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -176,8 +176,8 @@ describe('RSS', function () {
|
||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
|
|
||||||
req.channelConfig = channelConfig.get('index');
|
res.locals.channel = channelConfig.get('index');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
rss(req, res, failTest(done));
|
rss(req, res, failTest(done));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -204,8 +204,8 @@ describe('RSS', function () {
|
||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
|
|
||||||
req.channelConfig = channelConfig.get('index');
|
res.locals.channel = channelConfig.get('index');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
rss(req, res, failTest(done));
|
rss(req, res, failTest(done));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -238,8 +238,8 @@ describe('RSS', function () {
|
||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
|
|
||||||
req.channelConfig = channelConfig.get('index');
|
res.locals.channel = channelConfig.get('index');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
rss(req, res, failTest(done));
|
rss(req, res, failTest(done));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -270,8 +270,8 @@ describe('RSS', function () {
|
||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
|
|
||||||
req.channelConfig = channelConfig.get('index');
|
res.locals.channel = channelConfig.get('index');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
rss(req, res, failTest(done));
|
rss(req, res, failTest(done));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -327,8 +327,8 @@ describe('RSS', function () {
|
||||||
done();
|
done();
|
||||||
};
|
};
|
||||||
|
|
||||||
req.channelConfig = channelConfig.get('index');
|
res.locals.channel = channelConfig.get('index');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
rss(req, res, failTest(done));
|
rss(req, res, failTest(done));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -336,8 +336,8 @@ describe('RSS', function () {
|
||||||
// setup
|
// setup
|
||||||
req.originalUrl = '/tag/magic/rss/';
|
req.originalUrl = '/tag/magic/rss/';
|
||||||
req.params.slug = 'magic';
|
req.params.slug = 'magic';
|
||||||
req.channelConfig = channelConfig.get('tag');
|
res.locals.channel = channelConfig.get('tag');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
|
|
||||||
// test
|
// test
|
||||||
res.send = function send(xmlData) {
|
res.send = function send(xmlData) {
|
||||||
|
@ -358,8 +358,8 @@ describe('RSS', function () {
|
||||||
it('should process the data correctly for an author feed', function (done) {
|
it('should process the data correctly for an author feed', function (done) {
|
||||||
req.originalUrl = '/author/joe/rss/';
|
req.originalUrl = '/author/joe/rss/';
|
||||||
req.params.slug = 'joe';
|
req.params.slug = 'joe';
|
||||||
req.channelConfig = channelConfig.get('author');
|
res.locals.channel = channelConfig.get('author');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
|
|
||||||
// test
|
// test
|
||||||
res.send = function send(xmlData) {
|
res.send = function send(xmlData) {
|
||||||
|
@ -401,8 +401,8 @@ describe('RSS', function () {
|
||||||
results: {posts: [], meta: {pagination: {pages: 1}}}
|
results: {posts: [], meta: {pagination: {pages: 1}}}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
req.channelConfig = channelConfig.get('index');
|
res.locals.channel = channelConfig.get('index');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
|
|
||||||
function secondCall() {
|
function secondCall() {
|
||||||
res.send = function sendFirst(data) {
|
res.send = function sendFirst(data) {
|
||||||
|
@ -454,8 +454,8 @@ describe('RSS', function () {
|
||||||
|
|
||||||
req = {params: {page: 4}, route: {path: '/rss/:page/'}};
|
req = {params: {page: 4}, route: {path: '/rss/:page/'}};
|
||||||
req.originalUrl = req.route.path.replace(':page', req.params.page);
|
req.originalUrl = req.route.path.replace(':page', req.params.page);
|
||||||
req.channelConfig = channelConfig.get('index');
|
res.locals.channel = channelConfig.get('index');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
|
|
||||||
rss(req, res, function (err) {
|
rss(req, res, function (err) {
|
||||||
should.exist(err);
|
should.exist(err);
|
||||||
|
@ -471,8 +471,8 @@ describe('RSS', function () {
|
||||||
|
|
||||||
req = {params: {page: 4}, route: {path: '/rss/:page/'}};
|
req = {params: {page: 4}, route: {path: '/rss/:page/'}};
|
||||||
req.originalUrl = req.route.path.replace(':page', req.params.page);
|
req.originalUrl = req.route.path.replace(':page', req.params.page);
|
||||||
req.channelConfig = channelConfig.get('index');
|
res.locals.channel = channelConfig.get('index');
|
||||||
req.channelConfig.isRSS = true;
|
res.locals.channel.isRSS = true;
|
||||||
|
|
||||||
rss(req, res, function (err) {
|
rss(req, res, function (err) {
|
||||||
should.exist(err);
|
should.exist(err);
|
||||||
|
|
Loading…
Add table
Reference in a new issue