0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-06 22:40:14 -05:00
ghost/core/server/services/channels/parent-router.js
Hannah Wolfe 016ee17ebb
Rework route service to prevent circular dependencies (#9229)
refs #9192, refs #9178  

After trying to progress with current implementation, it became clear that the route service can't control the boot sequence, because then we end up with circular dependencies between the route service and the channel service.

The route service now exposes:
-  a siteRouter 
- a way for apps to register routes.
- ParentRouter base class for other modules to use
- the registry

...

- moved the default route setup back to site/routes.js 🙈
- moved the parent channel router back to the channel service (this makes way more sense imo)
- this structure prevents circular dependencies
- split the registry out into it's own thing
- fixed-up various bits of tests and comments
- DEBUG will print a list of routes 🎉
2017-11-09 13:58:22 +00:00

19 lines
634 B
JavaScript

var ParentRouter = require('../route').ParentRouter,
loader = require('./loader'),
channelRouter = require('./router');
/**
* Channels Router
* Parent channels router will load & mount all routes when
* .router() is called. This allows for reloading.
*/
module.exports.router = function channelsRouter() {
var channelsRouter = new ParentRouter('channels');
loader.list().forEach(function (channel) {
// Create a new channelRouter, and mount it onto the parent at the correct route
channelsRouter.mountRouter(channel.route, channelRouter(channel));
});
return channelsRouter.router();
};