Research
Security News
Threat Actor Exposes Playbook for Exploiting npm to Build Blockchain-Powered Botnets
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.
Wait for the results of multiple callbacks
Repository: https://github.com/mantoni/listen.js
npm install listen
Standalone browser package are here: http://maxantoni.de/listen.js/
However, you may want to use npm and bundle it with your application using Browserify.
var listen = require('listen');
var listener = listen();
var callbackA = listener();
var callbackB = listener();
/*
* Do async stuff with callbacks.
*
* Callbacks follow the Node.js convention. They expect an error or null as
* the first argument and an optional value as the second:
*
* Fail: callback(new Error('ouch!'));
* Return: callback(null, 'some return value');
*/
listener.then(function (err, values) {
/*
* err - 1) null if no callback err'd
* 2) the error of the callback that err'd
* 3) an error with name ErrorList wrapping multiple errors
*
* values - The non-undefined return values from all callbacks in order of
* callback creation
*/
});
listen()
Creates and returns a new listener function.
listen(values)
Creates and returns a new listener with the given initial values.
listener()
Creates a new callback associated with the listener. Throws if called after then
.
listener(name)
Creates a new named callback that provides its value under the given name.
listener(timeout)
Creates a new callback that errs with a TimeoutError
if the callback was not invoked within the given timeout.
listener(func)
Creates a new callback that also invokes the given function with (err, value)
.
listener(name, func)
Combined listener(name)
and listener(func)
.
listener(name, timeout)
Combined listener(name)
and listener(timeout)
.
listener(func, timeout)
Combined listener(func)
and listener(timeout)
.
listener(name, func, timeout)
Combined listener(name)
, listener(func)
and listener(timeout)
.
listener.then(func)
Invokes the given function once all callbacks where invoked. If none of the callbacks had errors, the first argument is null
, otherwise it's an Error
. The second argument is the values array in order of callback creation. Can only be called once.
listener.push(value)
Pushes a value to the internal values array. Throws if called after then
.
listener.err(error)
Adds an error to the internal error list. Throws if called after then
.
Here is what you need for development:
npm install
will install all the dev dependenciesmake
does all of the followingmake lint
lint the code with JSLintmake test
runs all unit tests in Nodemake browser
generates a static web page at test/all.html
to run the tests in a browser.make phantom
runs all tests in a the headless Phantom.JS. Make sure you have phantomjs
in your path.To build a browser package containing the merged / minified scripts run make package
.
FAQs
Wait for the results of multiple callbacks
The npm package listen receives a total of 1,651 weekly downloads. As such, listen popularity was classified as popular.
We found that listen demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.
Security News
NVD’s backlog surpasses 20,000 CVEs as analysis slows and NIST announces new system updates to address ongoing delays.
Security News
Research
A malicious npm package disguised as a WhatsApp client is exploiting authentication flows with a remote kill switch to exfiltrate data and destroy files.