npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

event-emitter-enhancer

v2.0.0

Published

Enhances the Node.js EventEmitter with extra capabilities.

Downloads

1,123

Readme

event-emitter-enhancer

NPM Version CI Coverage Status Known Vulnerabilities Inline docs License Total Downloads

Extends the Node.js events.EventEmitter to provide additional functionality.

Overview

This library extends the Node.js events.EventEmitter to provide additional functionality.

Usage

First you must require this library as follows:

var EventEmitterEnhancer = require('event-emitter-enhancer');

Next you can either modify the proto of an EventEmiter type class, or extend it to get a new custom type or modify a specific emitter instance.

var EventEmitter = require('events').EventEmitter;

//Get predefined extended version of the events.EventEmitter class (original EventEmitter is not impacted)
var emitter = new EventEmitterEnhancer.EnhancedEventEmitter();   //create a new instance using the new extended class type.

//extend events.EventEmitter class (or any class that has the same interface)
//now you can create instances of the new EnhancedEventEmitter type while events.EventEmitter is not modified/impacted in any way
var EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);   //extend the event emitter class (can be Node.js of some custom event emitter). original base class is not affected.
var emitter = new EnhancedEventEmitter();   //create a new instance using the new extended class type.

//modify the proto of an events.EventEmitter class (or any class that has the same interface)
//now all existing and future instances of the original class are modified to include the new extended capabilities.
EventEmitterEnhancer.modify(EventEmitter); //modify the event emitter class prototype (can be Node.js of some custom event emitter). existing instances are impacted.
var emitter = new EventEmitter();   //create an instance of the original class and automatically get the new extended capabilities.

//modify specific instance to include the extended capabilities (other existing/future instances of that class type are not modified/impacted in any way).
var emitter = new EventEmitter();   //create an instance of an event emitter (can be Node.js of some custom event emitter)
EventEmitterEnhancer.modifyInstance(emitter);   //modify the specific instance and add the extended capabilities. the original prototype is not affected.

'emitter.on(event, listener) ⇒ function'

See node.js events.EventEmitter.on. This function also returns a removeListener function to easily remove the provided listener.

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();

const remove = emitter.on('error', function (error) {
   console.error(error);
});

//remove listener (no longer need to keep a reference to the listener function)
remove();

'emitter.on(options) ⇒ function'

Enables more complex on capabilities including providing multiple listeners/event names, timeout the listener and more. To remove the listener/s, the returned function must be called instead of doing emitter.removeListener(...)

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();

const removeListener = emitter.on({
  event: ['error', 'connection-error', 'write-error', 'read-error'], //The event names (can be string for a single event)
  listener: [ //The listener callback functions (can be a function instead of an array for a single listener callback)
    function firstListener(arg1, arg2) {
      //do something
    },
    function secondListener(arg1, arg2) {
      //do something
    }
  ],
  async: true, //The callback functions will be called after next tick
  timeout: 1500 //All listeners will be removed after the provided timeout (if not provided, listeners can only be removed manually via returned function)
});

//emit any event
emitter.emit('write-error', 1, 2, 3);

//once done, remove all listeners from all events
removeListener();

'emitter.once(event, listener) ⇒ function'

See node.js events.EventEmitter.once. This function also returns a removeListener function to easily remove the provided listener.

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();

const remove = emitter.once('error', function (error) {
   console.error(error);
});

//remove listener (no longer need to keep a reference to the listener function)
remove();

'emitter.removeAllListeners([event])'

See node.js events.EventEmitter.removeAllListeners. This function is modified to also accept an array of event names.

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();

//same as the basic removeAllListeners
emitter.removeAllListeners('my-event');

//also supports array of event names
emitter.removeAllListeners(['my-event', 'another-event']);

'emitter.else(listener)'

Adds an 'else' listener which will be triggered by all events that do not have a listener currently for them (apart of the special 'error' event).

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();
emitter.else(function onUnhandledEvent(event, arg1, arg2) {
 //logic here....

 //to remove 'else' listeners, simply use the unelse function
 emitter.unelse(this);
});

emitter.emit('test', 1, 2);

'emitter.suspend(event)'

Suspends all emit calls for the provided event name (including 'else' listeners). For suspended events, the emit function will simply do nothing ('else' listeners won't be invoked either).

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();
emitter.on('test', function () {
  //will never be called
});

emitter.suspended = true;  //suspend ALL events (to unsuspend use emitter.suspended = false;)
//or
emitter.suspend('test');   //suspend only 'test' event (to unsuspend use emitter.unsuspend('test');)

emitter.emit('test');

'emitter.elseError(event)'

In case an event with the provided name is emitted but no listener is attached to it, an error event will emitted by this emitter instance instead.

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();
emitter.on('error', function (error) {
  //logic here...

  //To remove elseError
  emitter.unelseError('test');
});

emitter.elseError('test');

emitter.emit('test');

'emitter.emitAsync(event, [...params], [callback])'

Invokes the emit after a timeout to enable calling flow to continue and not block due to event listeners.

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();
emitter.on('test', function onTestEvent(num1, num2) {
   //event logic here
});

emitter.emitAsync('test', 1, 2, function onEmitDone(event, num1, num2, emitted) {
   //emit callback logic
});

'emitter.onAsync(event, listener) ⇒ function'

Adds a listener that will be triggered after a timeout during an emit. This ensures that the provided listener is invoked after all other listeners and that it will not block the emit caller flow. To remove the listener, the returned function must be called instead of doing emitter.removeListener(...)

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();
emitter.on('test', function onEventSync() {
  //sync handle function logic
});
const removeListener = emitter.onAsync('test', function onEventAsync() {
  //async handle function logic
});

emitter.emit('test', 1, 2);

//remove the async listener
removeListener();

'emitter.onAny(events, listener) ⇒ function'

Adds a listener to all provided event names. To remove the listener, the returned function must be called instead of doing emitter.removeListener(...)

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();

//add same listener to multiple events
const remove = emitter.onAny(['test1', 'test2', 'test3'], function (arg1, arg2, arg3) {
   console.log(arg1, arg2, arg3);
});

//remove listener from all events
remove();

'emitter.filter([event], filter) ⇒ function'

Adds a filter that will be triggered before every emit for the provided event type (if no event is provided, than the filter is invoked for all events). The filter enables to prevent events from reaching the listeners in case some criteria is met.

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();

//add filters for test event only
const removeTestEventFilter = emitter.filter('test', function (event, arg1, arg2) {
   if (arg1 && (arg1 > 3)) {
       return true;    //continue with emit
   }

   return false;   //prevent emit
});
emitter.filter('test', function (event, arg1, arg2) {
   if (arg2 && (arg2 < 20)) {
       return true;    //continue with emit
   }

   return false;   //prevent emit
});

//add global filter for all events
emitter.filter(function (event, arg1, arg2) {
   if (arg1 && (arg1 > 5)) {
       return true;    //continue with emit
   }

   return false;   //prevent emit
});
const removeGlobalArg2Filter = emitter.filter(function (event, arg1, arg2) {
   if (arg2 && (arg2 < 18)) {
       return true;    //continue with emit
   }

   return false;   //prevent emit
});

emitter.on('test', function onTestEvent(arg1, arg2) {
   //event logic here...
});

emitter.emit('test', 10, 15);

//remove some filters
removeTestEventFilter();
removeGlobalArg2Filter();

'emitter.proxyEvents(emitters, events) ⇒ function'

Will setup an event proxy so if any of the requested event/s are fired from the provided emitter/s, they will be triggered by this emitter.

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();

//proxy the 'data' and 'end' events from all sockets
const stop = emitter.proxyEvents(sockets, ['data', 'end']);

//listen to events via emitter
emitter.on('data', onData);

//stop events proxy
stop();

'emitter.addNoop(event) ⇒ function'

Adds empty event handler.

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();

//add noop even handler for the 'error' event
const remove = emitter.addNoop('error');

//remove listener
remove();

'emitter.ignoreError()'

Adds empty error event handler to prevent node.js from crashing in case of an error which we do not want/need to handle. This function will only add a new empty handler in case no other handler is defined for the error event.

Example

const EnhancedEventEmitter = EventEmitterEnhancer.extend(EventEmitter);
const emitter = new EnhancedEventEmitter();

//adds empty error handler
emitter.ignoreError();

//emit error will not crash the node.js process
emitter.emit('error', new Error('test'));

Installation

In order to use this library, just run the following npm install command:

npm install --save event-emitter-enhancer

API Documentation

See full docs at: API Docs

Contributing

See contributing guide

Release History

| Date | Version | Description | | ----------- | ------- | ----------- | | 2020-05-11 | v2.0.0 | Migrate to github actions and upgrade minimal node version | | 2019-12-06 | v1.1.0 | Support event parent parsing and emit #7 | | 2018-06-13 | v1.0.57 | Added typescript definition (#5 and #6) | | 2017-11-03 | v1.0.51 | Added 'addNoop' | | 2017-10-30 | v1.0.49 | Added 'ignoreError' | | 2017-10-30 | v1.0.48 | New extended 'removeAllListeners' function | | 2017-01-16 | v1.0.27 | New extended 'once' function | | 2017-01-07 | v1.0.25 | New 'proxyEvents' function | | 2017-01-06 | v1.0.24 | New extended 'on' function | | 2016-11-11 | v1.0.15 | 'emitAsync' callback is now optional | | 2015-09-23 | v0.0.44 | Added 'onAny' | | 2015-04-22 | v0.0.31 | Prevent from multiple enhance of same prototype/instance | | 2014-12-31 | v0.0.10 | EventEmitter is no longer automatically modified,instead there are 2 ways to extend/modify prototype/modify instancefunctions exposed by this library. | | 2014-12-30 | v0.0.9 | Added ability to enhance compatible EventEmitter types | | 2014-12-29 | v0.0.6 | Added 'filter' | | 2014-12-28 | v0.0.5 | Added 'onAsync' | | 2014-12-28 | v0.0.4 | Added 'emitAsync' | | 2014-12-28 | v0.0.2 | Initial release. |

License

Developed by Sagie Gur-Ari and licensed under the Apache 2 open source license.