2021-06-30 14:56:57 +01:00
|
|
|
/**
|
|
|
|
* Why has this not been moved to e.g. @tryghost/events or shared yet?
|
|
|
|
*
|
|
|
|
* - We currently massively overuse this utility, coupling together bits of the codebase in unexpected ways
|
|
|
|
* - We want to prevent this, not reinforce it
|
|
|
|
* * Having an @tryghost/events or shared/events module would reinforce this bad patter of using the same event emitter everywhere
|
|
|
|
*
|
|
|
|
* - Ideally, we want to refactor to:
|
|
|
|
* - either remove dependence on events where we can
|
|
|
|
* - or have separate event emitters for e.g. model layer and routing layer
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-04-29 16:44:27 +01:00
|
|
|
const events = require('events');
|
|
|
|
const util = require('util');
|
|
|
|
let EventRegistry;
|
|
|
|
let EventRegistryInstance;
|
2015-03-24 22:23:23 +02:00
|
|
|
|
2016-04-09 19:20:56 -05:00
|
|
|
EventRegistry = function () {
|
|
|
|
events.EventEmitter.call(this);
|
|
|
|
};
|
2016-05-19 13:49:22 +02:00
|
|
|
|
2015-03-24 22:23:23 +02:00
|
|
|
util.inherits(EventRegistry, events.EventEmitter);
|
|
|
|
|
2015-10-09 19:27:49 +01:00
|
|
|
EventRegistryInstance = new EventRegistry();
|
|
|
|
EventRegistryInstance.setMaxListeners(100);
|
|
|
|
|
|
|
|
module.exports = EventRegistryInstance;
|