Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Browser globals, AMD and Node Events
bane
is a small event emitter library that works in browsers (including old
and rowdy ones, like IE6) and Node. It will define itself as an AMD module if
you want it to (i.e. if there's a define
function available).
bane
is not entirely API compatible with Node's event emitter, but it does
provide the iconic on
and emit
functions.
npm install
./node_modules/buster/bin/buster-test --node
./node_modules/buster/bin/buster-server
./node_modules/buster/bin/buster-test --browser
var emitter = bane.createEventEmitter([object]);
Create a new event emitter. If an object is passed, it will be modified by adding the event emitter methods (see below).
on(event, listener)
Register the listener
function to be called when the emitter emits the
event
(which is a string).
on(listener)
Register the listener
function as a "supervisor". It will be called for
any event emitted from the emitter.
off(event, listener)
Remove a previously registered listener
function for the specified event
(which is a string). If the function has not previously been registered, it is
silently ignored.
off(listener)
Remove a previously registered "supervisor" listener
function. If the
function has not previously been registered, it is silently ignored.
###off(event)
Remove all previously registered listener
functions for the specified
event
(which is a string). If no functions have previously been registered,
it is silently ignored.
###off()
Remove all previously registered listeners on the object, both regular listeners, supervisor listeners, and errbacks. If no functions have previously been registrered, it is silently ignored.
###once(event, listener)
Register a listener
function for the given event
(which is a string)
only once. After the first event has been emitted, the listener is removed.
###bind(object)
Register all methods on object
as listeners for the event named as the
method name. Convenient way to bind many event listeners in one go:
var listener = {
start: function () {
console.log("Started!");
},
end: function () {
console.log("Ended");
}
};
emitter.bind(listener);
The above example will bind listener.start
to the "start"
event and vice
versa with end
. Note that property names can be quoted to bind to any kind of
event name (e.g. "test:start"
).
bind(object, events)
Binds methods on object
to corresponding events (see bind(object)
above), but instead of binding all methods on the object, only binds the
events listed in the provided events
array.
###errback(listener)
Register the listener
function as an "errback". It will be called with the
arguments event
and error
for any error thrown when listeners are
notified.
emit(event[, data1[, data2[, ...]]])
Emit the event
(which is a string) with optional data. Will cause all
registered listeners for the named event to be called. If additional arguments
are provided, the listeners will be called with them.
Two-clause BSD-license, see LICENSE
FAQs
(Yet another) Event emitter for Node, Browser globals and AMD
The npm package bane receives a total of 359 weekly downloads. As such, bane popularity was classified as not popular.
We found that bane demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.