Security News
Input Validation Vulnerabilities Dominate MITRE's 2024 CWE Top 25 List
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
marcosc-async
Advanced tools
This is a light-weight approximate implementation of ES7's async-await pattern.
You can npm install it.
npm install marcosc-async --save
You can play with the async API through gh-pages.
Once you import it (using either a script tag or require), there will be an "async" function you can use on the global object.
The async function takes generator, and returns a function that you can call as needed. It returns a promise.
const doAsyncThing = async(function*(args) {
var result = yield Promise.resolve(1);
return result;
});
doAsyncThing()
.then(value => console.log(value)); // 1
You can create simple async functions like so:
const async = require("marcosc-async");
var doSomethingAsync = async(function*(){
return yield Promise.resolve("hi")
});
doSomethingAsync()
.then(value => console.log(value)); // "hi"
Simple example for downloading a list of URLs.
const urls = ["/a", "/b"];
const doAsyncThing = async(function*(listOfURLs) {
let responses = [];
for (let url of listOfURLs) {
responses.push(yield fetch(url));
}
return yield Promise.all(responses.map(res => res.toJSON()));
});
doAsyncThing(urls)
.then(doSomethingElse)
.catch(err => console.error(error));
It allows for simple creation of async function and "tasks". For example:
const async = require("marcosc-async");
const myThinger = {
doAsynThing: async(function*(url) {
const response = yield fetch(url);
const text = yield response.text();
return process(result);
}),
};
And task-like things can be created as follows:
const async = require("marcosc-async");
// Run immediately
const myTask = async.task(function*(url) {
const response = yield fetch(url);
const text = yield response.text();
return process(result);
}).then(doSomethingElse);
this
You can also correctly bind this
like so:
const async = require("marcosc-async");
const myThinger = {
someValue: "value",
asyncTaskA(...args) {
return async(function*() {
return yield this.asyncTaskB(...args)
}, this);
},
asyncTaskB(...args) {
async(function*() {
return this.value;
}, this);
},
};
FAQs
Lightweight promise/generator machinery.
We found that marcosc-async demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 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.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.
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.