mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-01 07:16:52 +03:00
Moved routing helpers to rendering service
- The helpers folder was full of things used for rendering pages - It belongs as its own service so that we can see what it really does
This commit is contained in:
parent
c902d91c81
commit
08479f3816
@ -8,7 +8,7 @@ const errors = require('@tryghost/errors');
|
|||||||
// Dirty requires
|
// Dirty requires
|
||||||
const urlService = require('../../../../server/services/url');
|
const urlService = require('../../../../server/services/url');
|
||||||
const dataService = require('../../../services/data');
|
const dataService = require('../../../services/data');
|
||||||
const helpers = require('../../../services/routing/helpers');
|
const renderer = require('../../../services/rendering');
|
||||||
const templateName = 'amp';
|
const templateName = 'amp';
|
||||||
|
|
||||||
const messages = {
|
const messages = {
|
||||||
@ -32,7 +32,7 @@ function _renderer(req, res, next) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Render Call
|
// Render Call
|
||||||
return helpers.renderer(req, res, body);
|
return renderer.renderer(req, res, body);
|
||||||
}
|
}
|
||||||
|
|
||||||
// This here is a controller.
|
// This here is a controller.
|
||||||
|
@ -2,7 +2,7 @@ const path = require('path');
|
|||||||
const express = require('../../../../shared/express');
|
const express = require('../../../../shared/express');
|
||||||
const middleware = require('./middleware');
|
const middleware = require('./middleware');
|
||||||
const bodyParser = require('body-parser');
|
const bodyParser = require('body-parser');
|
||||||
const routing = require('../../../services/routing');
|
const renderer = require('../../../services/rendering');
|
||||||
const web = require('../../../../server/web');
|
const web = require('../../../../server/web');
|
||||||
const templateName = 'private';
|
const templateName = 'private';
|
||||||
const privateRouter = express.Router(templateName);
|
const privateRouter = express.Router(templateName);
|
||||||
@ -23,7 +23,7 @@ function _renderer(req, res) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Render Call
|
// Render Call
|
||||||
return routing.helpers.renderer(req, res, data);
|
return renderer.renderer(req, res, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
// password-protected frontend route
|
// password-protected frontend route
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
const _ = require('lodash');
|
const _ = require('lodash');
|
||||||
const {prepareContextResource} = require('../../proxy');
|
const {prepareContextResource} = require('../proxy');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description Formats API response into handlebars/theme format.
|
* @description Formats API response into handlebars/theme format.
|
@ -1,4 +1,4 @@
|
|||||||
const debug = require('@tryghost/debug')('services:routing:helpers:render-entries');
|
const debug = require('@tryghost/debug')('services:routing:renderer:render-entries');
|
||||||
const formatResponse = require('./format-response');
|
const formatResponse = require('./format-response');
|
||||||
const renderer = require('./renderer');
|
const renderer = require('./renderer');
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
const debug = require('@tryghost/debug')('services:routing:helpers:render-post');
|
const debug = require('@tryghost/debug')('services:routing:renderer:render-post');
|
||||||
const formatResponse = require('./format-response');
|
const formatResponse = require('./format-response');
|
||||||
const renderer = require('./renderer');
|
const renderer = require('./renderer');
|
||||||
/**
|
/**
|
@ -1,4 +1,4 @@
|
|||||||
const debug = require('@tryghost/debug')('services:routing:helpers:renderer');
|
const debug = require('@tryghost/debug')('services:routing:renderer:renderer');
|
||||||
const setContext = require('./context');
|
const setContext = require('./context');
|
||||||
const templates = require('./templates');
|
const templates = require('./templates');
|
||||||
|
|
@ -6,8 +6,8 @@ const _ = require('lodash');
|
|||||||
|
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const url = require('url');
|
const url = require('url');
|
||||||
const config = require('../../../../shared/config');
|
const config = require('../../../shared/config');
|
||||||
const themeEngine = require('../../theme-engine');
|
const themeEngine = require('../theme-engine');
|
||||||
const _private = {};
|
const _private = {};
|
||||||
|
|
||||||
/**
|
/**
|
@ -30,7 +30,7 @@ class CollectionRouter extends ParentRouter {
|
|||||||
value: object.permalink
|
value: object.permalink
|
||||||
};
|
};
|
||||||
|
|
||||||
// @NOTE: see helpers/templates - we use unshift to prepend the templates
|
// @NOTE: see renderer/templates - we use unshift to prepend the templates
|
||||||
this.templates = (object.templates || []).reverse();
|
this.templates = (object.templates || []).reverse();
|
||||||
|
|
||||||
this.filter = object.filter;
|
this.filter = object.filter;
|
||||||
|
@ -5,7 +5,7 @@ const errors = require('@tryghost/errors');
|
|||||||
const security = require('@tryghost/security');
|
const security = require('@tryghost/security');
|
||||||
const themeEngine = require('../../theme-engine');
|
const themeEngine = require('../../theme-engine');
|
||||||
const dataService = require('../../data');
|
const dataService = require('../../data');
|
||||||
const helpers = require('../helpers');
|
const renderer = require('../../rendering');
|
||||||
|
|
||||||
const messages = {
|
const messages = {
|
||||||
pageNotFound: 'Page not found.'
|
pageNotFound: 'Page not found.'
|
||||||
@ -61,16 +61,15 @@ module.exports = function channelController(req, res, next) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Format data 1
|
// Format data 1
|
||||||
// @TODO: See helpers/secure for explanation.
|
// @TODO: See renderer/secure for explanation.
|
||||||
helpers.secure(req, result.posts);
|
renderer.secure(req, result.posts);
|
||||||
|
|
||||||
// @TODO: See helpers/secure for explanation.
|
// @TODO: See renderer/secure for explanation.
|
||||||
_.each(result.data, function (data) {
|
_.each(result.data, function (data) {
|
||||||
helpers.secure(req, data);
|
renderer.secure(req, data);
|
||||||
});
|
});
|
||||||
|
|
||||||
const renderer = helpers.renderEntries(req, res);
|
return renderer.renderEntries(req, res)(result);
|
||||||
return renderer(result);
|
|
||||||
})
|
})
|
||||||
.catch(helpers.handleError(next));
|
.catch(renderer.handleError(next));
|
||||||
};
|
};
|
||||||
|
@ -5,7 +5,7 @@ const errors = require('@tryghost/errors');
|
|||||||
const security = require('@tryghost/security');
|
const security = require('@tryghost/security');
|
||||||
const {routerManager} = require('../');
|
const {routerManager} = require('../');
|
||||||
const themeEngine = require('../../theme-engine');
|
const themeEngine = require('../../theme-engine');
|
||||||
const helpers = require('../helpers');
|
const renderer = require('../../rendering');
|
||||||
const dataService = require('../../data');
|
const dataService = require('../../data');
|
||||||
|
|
||||||
const messages = {
|
const messages = {
|
||||||
@ -81,16 +81,15 @@ module.exports = function collectionController(req, res, next) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Format data 1
|
// Format data 1
|
||||||
// @TODO: See helpers/secure for explanation.
|
// @TODO: See renderer/secure for explanation.
|
||||||
helpers.secure(req, result.posts);
|
renderer.secure(req, result.posts);
|
||||||
|
|
||||||
// @TODO: See helpers/secure for explanation.
|
// @TODO: See renderer/secure for explanation.
|
||||||
_.each(result.data, function (data) {
|
_.each(result.data, function (data) {
|
||||||
helpers.secure(req, data);
|
renderer.secure(req, data);
|
||||||
});
|
});
|
||||||
|
|
||||||
const renderer = helpers.renderEntries(req, res);
|
return renderer.renderEntries(req, res)(result);
|
||||||
return renderer(result);
|
|
||||||
})
|
})
|
||||||
.catch(helpers.handleError(next));
|
.catch(renderer.handleError(next));
|
||||||
};
|
};
|
||||||
|
@ -2,7 +2,7 @@ const debug = require('@tryghost/debug')('services:routing:controllers:emailpost
|
|||||||
const config = require('../../../../shared/config');
|
const config = require('../../../../shared/config');
|
||||||
const {routerManager} = require('../');
|
const {routerManager} = require('../');
|
||||||
const urlUtils = require('../../../../shared/url-utils');
|
const urlUtils = require('../../../../shared/url-utils');
|
||||||
const helpers = require('../helpers');
|
const renderer = require('../../rendering');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description Email Post Controller.
|
* @description Email Post Controller.
|
||||||
@ -55,11 +55,10 @@ module.exports = function emailPostController(req, res, next) {
|
|||||||
post.access = !!post.html;
|
post.access = !!post.html;
|
||||||
}
|
}
|
||||||
|
|
||||||
// @TODO: See helpers/secure
|
// @TODO: See renderer/secure
|
||||||
helpers.secure(req, post);
|
renderer.secure(req, post);
|
||||||
|
|
||||||
const renderer = helpers.renderEntry(req, res);
|
return renderer.renderEntry(req, res)(post);
|
||||||
return renderer(post);
|
|
||||||
})
|
})
|
||||||
.catch(helpers.handleError(next));
|
.catch(renderer.handleError(next));
|
||||||
};
|
};
|
||||||
|
@ -4,7 +4,7 @@ const config = require('../../../../shared/config');
|
|||||||
const {routerManager} = require('../');
|
const {routerManager} = require('../');
|
||||||
const urlUtils = require('../../../../shared/url-utils');
|
const urlUtils = require('../../../../shared/url-utils');
|
||||||
const dataService = require('../../data');
|
const dataService = require('../../data');
|
||||||
const helpers = require('../helpers');
|
const renderer = require('../../rendering');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description Entry controller.
|
* @description Entry controller.
|
||||||
@ -84,10 +84,9 @@ module.exports = function entryController(req, res, next) {
|
|||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
helpers.secure(req, entry);
|
renderer.secure(req, entry);
|
||||||
|
|
||||||
const renderer = helpers.renderEntry(req, res);
|
return renderer.renderEntry(req, res)(entry);
|
||||||
return renderer(entry);
|
|
||||||
})
|
})
|
||||||
.catch(helpers.handleError(next));
|
.catch(renderer.handleError(next));
|
||||||
};
|
};
|
||||||
|
@ -2,7 +2,7 @@ const debug = require('@tryghost/debug')('services:routing:controllers:preview')
|
|||||||
const config = require('../../../../shared/config');
|
const config = require('../../../../shared/config');
|
||||||
const {routerManager} = require('../');
|
const {routerManager} = require('../');
|
||||||
const urlUtils = require('../../../../shared/url-utils');
|
const urlUtils = require('../../../../shared/url-utils');
|
||||||
const helpers = require('../helpers');
|
const renderer = require('../../rendering');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description Preview Controller.
|
* @description Preview Controller.
|
||||||
@ -57,11 +57,10 @@ module.exports = function previewController(req, res, next) {
|
|||||||
post.access = !!post.html;
|
post.access = !!post.html;
|
||||||
}
|
}
|
||||||
|
|
||||||
// @TODO: See helpers/secure
|
// @TODO: See renderer/secure
|
||||||
helpers.secure(req, post);
|
renderer.secure(req, post);
|
||||||
|
|
||||||
const renderer = helpers.renderEntry(req, res);
|
return renderer.renderEntry(req, res)(post);
|
||||||
return renderer(post);
|
|
||||||
})
|
})
|
||||||
.catch(helpers.handleError(next));
|
.catch(renderer.handleError(next));
|
||||||
};
|
};
|
||||||
|
@ -4,7 +4,7 @@ const url = require('url');
|
|||||||
const security = require('@tryghost/security');
|
const security = require('@tryghost/security');
|
||||||
const settingsCache = require('../../../../shared/settings-cache');
|
const settingsCache = require('../../../../shared/settings-cache');
|
||||||
const rssService = require('../../rss');
|
const rssService = require('../../rss');
|
||||||
const helpers = require('../helpers');
|
const renderer = require('../../rendering');
|
||||||
const dataService = require('../../data');
|
const dataService = require('../../data');
|
||||||
|
|
||||||
// @TODO: is this really correct? Should we be using meta data title?
|
// @TODO: is this really correct? Should we be using meta data title?
|
||||||
@ -48,5 +48,5 @@ module.exports = function rssController(req, res, next) {
|
|||||||
.then(function (data) {
|
.then(function (data) {
|
||||||
return rssService.render(res, baseUrl, data);
|
return rssService.render(res, baseUrl, data);
|
||||||
})
|
})
|
||||||
.catch(helpers.handleError(next));
|
.catch(renderer.handleError(next));
|
||||||
};
|
};
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
const _ = require('lodash');
|
const _ = require('lodash');
|
||||||
const Promise = require('bluebird');
|
const Promise = require('bluebird');
|
||||||
const debug = require('@tryghost/debug')('services:routing:controllers:static');
|
const debug = require('@tryghost/debug')('services:routing:controllers:static');
|
||||||
const helpers = require('../helpers');
|
const renderer = require('../../rendering');
|
||||||
|
|
||||||
function processQuery(query, locals) {
|
function processQuery(query, locals) {
|
||||||
const api = require('../../proxy').api[locals.apiVersion];
|
const api = require('../../proxy').api[locals.apiVersion];
|
||||||
@ -60,12 +60,12 @@ module.exports = function staticController(req, res, next) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// @TODO: See helpers/secure for more context.
|
// @TODO: See renderer/secure for more context.
|
||||||
_.each(response.data, function (data) {
|
_.each(response.data, function (data) {
|
||||||
helpers.secure(req, data);
|
renderer.secure(req, data);
|
||||||
});
|
});
|
||||||
|
|
||||||
helpers.renderer(req, res, helpers.formatResponse.entries(response));
|
renderer.renderer(req, res, renderer.formatResponse.entries(response));
|
||||||
})
|
})
|
||||||
.catch(helpers.handleError(next));
|
.catch(renderer.handleError(next));
|
||||||
};
|
};
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
const debug = require('@tryghost/debug')('services:routing:controllers:unsubscribe');
|
const debug = require('@tryghost/debug')('services:routing:controllers:unsubscribe');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const megaService = require('../../../../server/services/mega');
|
const megaService = require('../../../../server/services/mega');
|
||||||
const helpers = require('../../../services/routing/helpers');
|
const renderer = require('../../rendering');
|
||||||
|
|
||||||
module.exports = async function unsubscribeController(req, res) {
|
module.exports = async function unsubscribeController(req, res) {
|
||||||
debug('unsubscribeController');
|
debug('unsubscribeController');
|
||||||
@ -22,5 +22,5 @@ module.exports = async function unsubscribeController(req, res) {
|
|||||||
defaultTemplate: path.resolve(__dirname, '../../../views/', templateName)
|
defaultTemplate: path.resolve(__dirname, '../../../views/', templateName)
|
||||||
};
|
};
|
||||||
|
|
||||||
return helpers.renderer(req, res, data);
|
return renderer.renderer(req, res, data);
|
||||||
};
|
};
|
||||||
|
@ -7,9 +7,5 @@ module.exports = {
|
|||||||
|
|
||||||
get registry() {
|
get registry() {
|
||||||
return registry;
|
return registry;
|
||||||
},
|
|
||||||
|
|
||||||
get helpers() {
|
|
||||||
return require('./helpers');
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -4,7 +4,7 @@ const tpl = require('@tryghost/tpl');
|
|||||||
const sentry = require('../../../shared/sentry');
|
const sentry = require('../../../shared/sentry');
|
||||||
|
|
||||||
const config = require('../../../shared/config');
|
const config = require('../../../shared/config');
|
||||||
const helpers = require('../../services/routing/helpers');
|
const renderer = require('../../services/rendering');
|
||||||
|
|
||||||
// @TODO: make this properly shared code
|
// @TODO: make this properly shared code
|
||||||
const {prepareError, prepareStack} = require('@tryghost/mw-error-handler');
|
const {prepareError, prepareStack} = require('@tryghost/mw-error-handler');
|
||||||
@ -55,7 +55,7 @@ const themeErrorRenderer = (err, req, res, next) => {
|
|||||||
|
|
||||||
// Template
|
// Template
|
||||||
// @TODO: very dirty !!!!!!
|
// @TODO: very dirty !!!!!!
|
||||||
helpers.templates.setTemplate(req, res);
|
renderer.templates.setTemplate(req, res);
|
||||||
|
|
||||||
// It can be that something went wrong with the theme or otherwise loading handlebars
|
// It can be that something went wrong with the theme or otherwise loading handlebars
|
||||||
// This ensures that no matter what res.render will work here
|
// This ensures that no matter what res.render will work here
|
||||||
|
@ -4,7 +4,7 @@ const sinon = require('sinon');
|
|||||||
const path = require('path');
|
const path = require('path');
|
||||||
const ampController = require('../../../../../core/frontend/apps/amp/lib/router');
|
const ampController = require('../../../../../core/frontend/apps/amp/lib/router');
|
||||||
const urlService = require('../../../../../core/server/services/url');
|
const urlService = require('../../../../../core/server/services/url');
|
||||||
const helpers = require('../../../../../core/frontend/services/routing/helpers');
|
const renderer = require('../../../../../core/frontend/services/rendering');
|
||||||
const dataService = require('../../../../../core/frontend/services/data');
|
const dataService = require('../../../../../core/frontend/services/data');
|
||||||
const testUtils = require('../../../../utils');
|
const testUtils = require('../../../../utils');
|
||||||
const configUtils = require('../../../../utils/configUtils');
|
const configUtils = require('../../../../utils/configUtils');
|
||||||
@ -27,7 +27,7 @@ describe('Unit - apps/amp/lib/router', function () {
|
|||||||
beforeEach(function () {
|
beforeEach(function () {
|
||||||
rendererStub = sinon.stub();
|
rendererStub = sinon.stub();
|
||||||
|
|
||||||
sinon.stub(helpers, 'renderer').get(function () {
|
sinon.stub(renderer, 'renderer').get(function () {
|
||||||
return rendererStub;
|
return rendererStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -59,7 +59,7 @@ describe('Unit - apps/amp/lib/router', function () {
|
|||||||
|
|
||||||
describe('fn: renderer', function () {
|
describe('fn: renderer', function () {
|
||||||
it('should render default amp page when theme has no amp template', function (done) {
|
it('should render default amp page when theme has no amp template', function (done) {
|
||||||
helpers.renderer.callsFake(function (_req, _res, data) {
|
renderer.renderer.callsFake(function (_req, _res, data) {
|
||||||
_res.routerOptions.defaultTemplate.should.eql(defaultPath);
|
_res.routerOptions.defaultTemplate.should.eql(defaultPath);
|
||||||
data.should.eql({post: {title: 'test'}});
|
data.should.eql({post: {title: 'test'}});
|
||||||
done();
|
done();
|
||||||
@ -73,7 +73,7 @@ describe('Unit - apps/amp/lib/router', function () {
|
|||||||
|
|
||||||
ampController.renderer(req, res, function (err) {
|
ampController.renderer(req, res, function (err) {
|
||||||
(err instanceof errors.NotFoundError).should.be.true();
|
(err instanceof errors.NotFoundError).should.be.true();
|
||||||
helpers.renderer.called.should.be.false();
|
renderer.renderer.called.should.be.false();
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@ -87,7 +87,7 @@ describe('Unit - apps/amp/lib/router', function () {
|
|||||||
|
|
||||||
ampController.renderer(req, res, function (err) {
|
ampController.renderer(req, res, function (err) {
|
||||||
(err instanceof errors.NotFoundError).should.be.true();
|
(err instanceof errors.NotFoundError).should.be.true();
|
||||||
helpers.renderer.called.should.be.false();
|
renderer.renderer.called.should.be.false();
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
const should = require('should');
|
const should = require('should');
|
||||||
const sinon = require('sinon');
|
const sinon = require('sinon');
|
||||||
const _ = require('lodash');
|
const _ = require('lodash');
|
||||||
const testUtils = require('../../../../../utils');
|
const testUtils = require('../../../../utils');
|
||||||
const helpers = require('../../../../../../core/frontend/services/routing/helpers');
|
const renderer = require('../../../../../core/frontend/services/rendering');
|
||||||
const labs = require('../../../../../../core/shared/labs');
|
const labs = require('../../../../../core/shared/labs');
|
||||||
|
|
||||||
describe('Contexts', function () {
|
describe('Contexts', function () {
|
||||||
let req;
|
let req;
|
||||||
@ -33,14 +33,14 @@ describe('Contexts', function () {
|
|||||||
res = {};
|
res = {};
|
||||||
data = {};
|
data = {};
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(0);
|
res.locals.context.should.be.an.Array().with.lengthOf(0);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return empty array with no error with basic parameters', function () {
|
it('should return empty array with no error with basic parameters', function () {
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(0);
|
res.locals.context.should.be.an.Array().with.lengthOf(0);
|
||||||
@ -52,7 +52,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = '/does/not/matter/';
|
res.locals.relativeUrl = '/does/not/matter/';
|
||||||
res.routerOptions.context = ['index'];
|
res.routerOptions.context = ['index'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
||||||
@ -64,7 +64,7 @@ describe('Contexts', function () {
|
|||||||
res.routerOptions.context = ['index'];
|
res.routerOptions.context = ['index'];
|
||||||
|
|
||||||
// Execute test
|
// Execute test
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
// Check context
|
// Check context
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
@ -78,7 +78,7 @@ describe('Contexts', function () {
|
|||||||
res.routerOptions.context = [];
|
res.routerOptions.context = [];
|
||||||
|
|
||||||
// Execute test
|
// Execute test
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
// Check context
|
// Check context
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
@ -90,7 +90,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = '/page/2/';
|
res.locals.relativeUrl = '/page/2/';
|
||||||
res.routerOptions.context = ['index'];
|
res.routerOptions.context = ['index'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
||||||
@ -102,7 +102,7 @@ describe('Contexts', function () {
|
|||||||
req.params.page = 2;
|
req.params.page = 2;
|
||||||
res.routerOptions.context = ['index'];
|
res.routerOptions.context = ['index'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
||||||
@ -116,7 +116,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = '/tag/getting-started/';
|
res.locals.relativeUrl = '/tag/getting-started/';
|
||||||
res.routerOptions.context = ['tag'];
|
res.routerOptions.context = ['tag'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
||||||
@ -127,7 +127,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = '/tag/getting-started/';
|
res.locals.relativeUrl = '/tag/getting-started/';
|
||||||
res.routerOptions.context = [];
|
res.routerOptions.context = [];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(0);
|
res.locals.context.should.be.an.Array().with.lengthOf(0);
|
||||||
@ -137,7 +137,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = '/tag/getting-started/page/2/';
|
res.locals.relativeUrl = '/tag/getting-started/page/2/';
|
||||||
res.routerOptions.context = ['tag'];
|
res.routerOptions.context = ['tag'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
||||||
@ -149,7 +149,7 @@ describe('Contexts', function () {
|
|||||||
req.params.page = 2;
|
req.params.page = 2;
|
||||||
res.routerOptions.context = ['tag'];
|
res.routerOptions.context = ['tag'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
||||||
@ -163,7 +163,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = '/author/pat/';
|
res.locals.relativeUrl = '/author/pat/';
|
||||||
res.routerOptions.context = ['author'];
|
res.routerOptions.context = ['author'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
||||||
@ -174,7 +174,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = '/author/pat/';
|
res.locals.relativeUrl = '/author/pat/';
|
||||||
res.routerOptions.context = [];
|
res.routerOptions.context = [];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(0);
|
res.locals.context.should.be.an.Array().with.lengthOf(0);
|
||||||
@ -184,7 +184,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = '/author/pat/page/2/';
|
res.locals.relativeUrl = '/author/pat/page/2/';
|
||||||
res.routerOptions.context = ['author'];
|
res.routerOptions.context = ['author'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
||||||
@ -196,7 +196,7 @@ describe('Contexts', function () {
|
|||||||
req.params.page = 2;
|
req.params.page = 2;
|
||||||
res.routerOptions.context = ['author'];
|
res.routerOptions.context = ['author'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
||||||
@ -210,7 +210,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = 'anything';
|
res.locals.relativeUrl = 'anything';
|
||||||
res.routerOptions.context = ['custom-context', 'test'];
|
res.routerOptions.context = ['custom-context', 'test'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
||||||
@ -224,7 +224,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = '/welcome-to-ghost/';
|
res.locals.relativeUrl = '/welcome-to-ghost/';
|
||||||
res.routerOptions.context = ['post'];
|
res.routerOptions.context = ['post'];
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
||||||
@ -237,7 +237,7 @@ describe('Contexts', function () {
|
|||||||
res.locals.relativeUrl = '/private/?r=';
|
res.locals.relativeUrl = '/private/?r=';
|
||||||
delete res.routerOptions;
|
delete res.routerOptions;
|
||||||
|
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
||||||
@ -252,7 +252,7 @@ describe('Contexts', function () {
|
|||||||
data.post = testUtils.DataGenerator.forKnex.createPost();
|
data.post = testUtils.DataGenerator.forKnex.createPost();
|
||||||
|
|
||||||
delete res.routerOptions;
|
delete res.routerOptions;
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
res.locals.context.should.be.an.Array().with.lengthOf(1);
|
||||||
@ -266,7 +266,7 @@ describe('Contexts', function () {
|
|||||||
data.post = testUtils.DataGenerator.forKnex.createPost();
|
data.post = testUtils.DataGenerator.forKnex.createPost();
|
||||||
|
|
||||||
delete res.routerOptions;
|
delete res.routerOptions;
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
||||||
@ -279,7 +279,7 @@ describe('Contexts', function () {
|
|||||||
data.page = testUtils.DataGenerator.forKnex.createPost({page: true});
|
data.page = testUtils.DataGenerator.forKnex.createPost({page: true});
|
||||||
|
|
||||||
delete res.routerOptions;
|
delete res.routerOptions;
|
||||||
helpers.context(req, res, data);
|
renderer.context(req, res, data);
|
||||||
|
|
||||||
should.exist(res.locals.context);
|
should.exist(res.locals.context);
|
||||||
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
res.locals.context.should.be.an.Array().with.lengthOf(2);
|
@ -1,7 +1,7 @@
|
|||||||
const should = require('should');
|
const should = require('should');
|
||||||
const sinon = require('sinon');
|
const sinon = require('sinon');
|
||||||
const errors = require('@tryghost/errors');
|
const errors = require('@tryghost/errors');
|
||||||
const helpers = require('../../../../../../core/frontend/services/routing/helpers');
|
const helpers = require('../../../../../core/frontend/services/rendering');
|
||||||
|
|
||||||
describe('handleError', function () {
|
describe('handleError', function () {
|
||||||
let next;
|
let next;
|
@ -1,7 +1,7 @@
|
|||||||
const should = require('should');
|
const should = require('should');
|
||||||
const testUtils = require('../../../../../utils');
|
const testUtils = require('../../../../utils');
|
||||||
const helpers = require('../../../../../../core/frontend/services/routing/helpers');
|
const helpers = require('../../../../../core/frontend/services/rendering');
|
||||||
const {SafeString} = require('../../../../../../core/frontend/services/handlebars');
|
const {SafeString} = require('../../../../../core/frontend/services/handlebars');
|
||||||
|
|
||||||
describe('Unit - services/routing/helpers/format-response', function () {
|
describe('Unit - services/routing/helpers/format-response', function () {
|
||||||
let posts;
|
let posts;
|
@ -1,8 +1,8 @@
|
|||||||
const should = require('should');
|
const should = require('should');
|
||||||
const sinon = require('sinon');
|
const sinon = require('sinon');
|
||||||
const rewire = require('rewire');
|
const rewire = require('rewire');
|
||||||
const templates = rewire('../../../../../../core/frontend/services/routing/helpers/templates');
|
const templates = rewire('../../../../../core/frontend/services/rendering/templates');
|
||||||
const themeEngine = require('../../../../../../core/frontend/services/theme-engine');
|
const themeEngine = require('../../../../../core/frontend/services/theme-engine');
|
||||||
|
|
||||||
describe('templates', function () {
|
describe('templates', function () {
|
||||||
let getActiveThemeStub;
|
let getActiveThemeStub;
|
@ -5,7 +5,7 @@ const testUtils = require('../../../../../utils');
|
|||||||
const security = require('@tryghost/security');
|
const security = require('@tryghost/security');
|
||||||
const themeEngine = require('../../../../../../core/frontend/services/theme-engine');
|
const themeEngine = require('../../../../../../core/frontend/services/theme-engine');
|
||||||
const controllers = require('../../../../../../core/frontend/services/routing/controllers');
|
const controllers = require('../../../../../../core/frontend/services/routing/controllers');
|
||||||
const helpers = require('../../../../../../core/frontend/services/routing/helpers');
|
const renderer = require('../../../../../../core/frontend/services/rendering');
|
||||||
const dataService = require('../../../../../../core/frontend/services/data');
|
const dataService = require('../../../../../../core/frontend/services/data');
|
||||||
|
|
||||||
function failTest(done) {
|
function failTest(done) {
|
||||||
@ -41,7 +41,7 @@ describe('Unit - services/routing/controllers/channel', function () {
|
|||||||
|
|
||||||
sinon.stub(security.string, 'safe').returns('safe');
|
sinon.stub(security.string, 'safe').returns('safe');
|
||||||
|
|
||||||
sinon.stub(helpers, 'secure').get(function () {
|
sinon.stub(renderer, 'secure').get(function () {
|
||||||
return secureStub;
|
return secureStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -53,7 +53,7 @@ describe('Unit - services/routing/controllers/channel', function () {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
sinon.stub(helpers, 'renderEntries').returns(renderStub);
|
sinon.stub(renderer, 'renderEntries').returns(renderStub);
|
||||||
|
|
||||||
req = {
|
req = {
|
||||||
path: '/',
|
path: '/',
|
||||||
|
@ -6,7 +6,7 @@ const security = require('@tryghost/security');
|
|||||||
const themeEngine = require('../../../../../../core/frontend/services/theme-engine');
|
const themeEngine = require('../../../../../../core/frontend/services/theme-engine');
|
||||||
const routerManager = require('../../../../../../core/frontend/services/routing/').routerManager;
|
const routerManager = require('../../../../../../core/frontend/services/routing/').routerManager;
|
||||||
const controllers = require('../../../../../../core/frontend/services/routing/controllers');
|
const controllers = require('../../../../../../core/frontend/services/routing/controllers');
|
||||||
const helpers = require('../../../../../../core/frontend/services/routing/helpers');
|
const renderer = require('../../../../../../core/frontend/services/rendering');
|
||||||
const dataService = require('../../../../../../core/frontend/services/data');
|
const dataService = require('../../../../../../core/frontend/services/data');
|
||||||
|
|
||||||
function failTest(done) {
|
function failTest(done) {
|
||||||
@ -43,7 +43,7 @@ describe('Unit - services/routing/controllers/collection', function () {
|
|||||||
|
|
||||||
sinon.stub(security.string, 'safe').returns('safe');
|
sinon.stub(security.string, 'safe').returns('safe');
|
||||||
|
|
||||||
sinon.stub(helpers, 'secure').get(function () {
|
sinon.stub(renderer, 'secure').get(function () {
|
||||||
return secureStub;
|
return secureStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -55,7 +55,7 @@ describe('Unit - services/routing/controllers/collection', function () {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
sinon.stub(helpers, 'renderEntries').returns(renderStub);
|
sinon.stub(renderer, 'renderEntries').returns(renderStub);
|
||||||
|
|
||||||
ownsStub = sinon.stub(routerManager, 'owns');
|
ownsStub = sinon.stub(routerManager, 'owns');
|
||||||
ownsStub.withArgs('identifier', posts[0].id).returns(true);
|
ownsStub.withArgs('identifier', posts[0].id).returns(true);
|
||||||
|
@ -5,7 +5,7 @@ const configUtils = require('../../../../../utils/configUtils');
|
|||||||
const urlUtils = require('../../../../../../core/shared/url-utils');
|
const urlUtils = require('../../../../../../core/shared/url-utils');
|
||||||
const routerManager = require('../../../../../../core/frontend/services/routing/').routerManager;
|
const routerManager = require('../../../../../../core/frontend/services/routing/').routerManager;
|
||||||
const controllers = require('../../../../../../core/frontend/services/routing/controllers');
|
const controllers = require('../../../../../../core/frontend/services/routing/controllers');
|
||||||
const helpers = require('../../../../../../core/frontend/services/routing/helpers');
|
const renderer = require('../../../../../../core/frontend/services/rendering');
|
||||||
const dataService = require('../../../../../../core/frontend/services/data');
|
const dataService = require('../../../../../../core/frontend/services/data');
|
||||||
const EDITOR_URL = `/#/editor/post/`;
|
const EDITOR_URL = `/#/editor/post/`;
|
||||||
|
|
||||||
@ -32,11 +32,11 @@ describe('Unit - services/routing/controllers/entry', function () {
|
|||||||
return entryLookUpStub;
|
return entryLookUpStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
sinon.stub(helpers, 'secure').get(function () {
|
sinon.stub(renderer, 'secure').get(function () {
|
||||||
return secureStub;
|
return secureStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
sinon.stub(helpers, 'renderEntry').get(function () {
|
sinon.stub(renderer, 'renderEntry').get(function () {
|
||||||
return renderStub;
|
return renderStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ const testUtils = require('../../../../../utils');
|
|||||||
const configUtils = require('../../../../../utils/configUtils');
|
const configUtils = require('../../../../../utils/configUtils');
|
||||||
const api = require('../../../../../../core/server/api').canary;
|
const api = require('../../../../../../core/server/api').canary;
|
||||||
const controllers = require('../../../../../../core/frontend/services/routing/controllers');
|
const controllers = require('../../../../../../core/frontend/services/routing/controllers');
|
||||||
const helpers = require('../../../../../../core/frontend/services/routing/helpers');
|
const renderer = require('../../../../../../core/frontend/services/rendering');
|
||||||
const urlService = require('../../../../../../core/server/services/url');
|
const urlService = require('../../../../../../core/server/services/url');
|
||||||
const urlUtils = require('../../../../../../core/shared/url-utils');
|
const urlUtils = require('../../../../../../core/shared/url-utils');
|
||||||
|
|
||||||
@ -64,12 +64,12 @@ describe('Unit - services/routing/controllers/preview', function () {
|
|||||||
sinon.stub(urlUtils, 'redirect301');
|
sinon.stub(urlUtils, 'redirect301');
|
||||||
sinon.stub(urlService, 'getUrlByResourceId');
|
sinon.stub(urlService, 'getUrlByResourceId');
|
||||||
|
|
||||||
sinon.stub(helpers, 'secure').get(function () {
|
sinon.stub(renderer, 'secure').get(function () {
|
||||||
return secureStub;
|
return secureStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
renderStub = sinon.stub();
|
renderStub = sinon.stub();
|
||||||
sinon.stub(helpers, 'renderEntry').get(function () {
|
sinon.stub(renderer, 'renderEntry').get(function () {
|
||||||
return function () {
|
return function () {
|
||||||
return renderStub;
|
return renderStub;
|
||||||
};
|
};
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
const should = require('should');
|
const should = require('should');
|
||||||
const sinon = require('sinon');
|
const sinon = require('sinon');
|
||||||
const testUtils = require('../../../../../utils');
|
|
||||||
const API_VERSION = 'canary';
|
const API_VERSION = 'canary';
|
||||||
const api = require('../../../../../../core/server/api')[API_VERSION];
|
const api = require('../../../../../../core/server/api')[API_VERSION];
|
||||||
const themeEngine = require('../../../../../../core/frontend/services/theme-engine');
|
const themeEngine = require('../../../../../../core/frontend/services/theme-engine');
|
||||||
const helpers = require('../../../../../../core/frontend/services/routing/helpers');
|
const renderer = require('../../../../../../core/frontend/services/rendering');
|
||||||
const controllers = require('../../../../../../core/frontend/services/routing/controllers');
|
const controllers = require('../../../../../../core/frontend/services/routing/controllers');
|
||||||
|
|
||||||
function failTest(done) {
|
function failTest(done) {
|
||||||
@ -40,11 +40,11 @@ describe('Unit - services/routing/controllers/static', function () {
|
|||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
sinon.stub(helpers, 'secure').get(function () {
|
sinon.stub(renderer, 'secure').get(function () {
|
||||||
return secureStub;
|
return secureStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
sinon.stub(helpers, 'handleError').get(function () {
|
sinon.stub(renderer, 'handleError').get(function () {
|
||||||
return handleErrorStub;
|
return handleErrorStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -56,11 +56,11 @@ describe('Unit - services/routing/controllers/static', function () {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
sinon.stub(helpers, 'renderer').get(function () {
|
sinon.stub(renderer, 'renderer').get(function () {
|
||||||
return renderStub;
|
return renderStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
sinon.stub(helpers, 'formatResponse').get(function () {
|
sinon.stub(renderer, 'formatResponse').get(function () {
|
||||||
return formatResponseStub;
|
return formatResponseStub;
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -85,10 +85,10 @@ describe('Unit - services/routing/controllers/static', function () {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it('no extra data to fetch', function (done) {
|
it('no extra data to fetch', function (done) {
|
||||||
helpers.renderer.callsFake(function () {
|
renderer.renderer.callsFake(function () {
|
||||||
helpers.formatResponse.entries.calledOnce.should.be.true();
|
renderer.formatResponse.entries.calledOnce.should.be.true();
|
||||||
tagsReadStub.called.should.be.false();
|
tagsReadStub.called.should.be.false();
|
||||||
helpers.secure.called.should.be.false();
|
renderer.secure.called.should.be.false();
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -109,10 +109,10 @@ describe('Unit - services/routing/controllers/static', function () {
|
|||||||
|
|
||||||
tagsReadStub = sinon.stub().resolves({tags: [{slug: 'bacon'}]});
|
tagsReadStub = sinon.stub().resolves({tags: [{slug: 'bacon'}]});
|
||||||
|
|
||||||
helpers.renderer.callsFake(function () {
|
renderer.renderer.callsFake(function () {
|
||||||
tagsReadStub.called.should.be.true();
|
tagsReadStub.called.should.be.true();
|
||||||
helpers.formatResponse.entries.calledOnce.should.be.true();
|
renderer.formatResponse.entries.calledOnce.should.be.true();
|
||||||
helpers.secure.calledOnce.should.be.true();
|
renderer.secure.calledOnce.should.be.true();
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user