Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Villa is a set of promise utilities for async
-await
-ready environment.
Promises have been widely used in JavaScript, and there are quite a few fully
featured promise libraries like
bluebird and
Q. But with the growing adoption of
async
/await
provided by ES-next (via transpilers like
TypeScript and Babel),
some cretical features provided by those libraries become less relevant.
And there is another problem with third-party promise for code using
async
/await
: it could be confusing having different promise instances with
different APIs, while an async
function always returns native promise object.
While most of the promise use cases so far can be addressed using
async
/await
with simple helpers, I created villa with my favorite features
from my own promise library ThenFail and
more.
Villa is written in TypeScript and compiled with TypeScript 2.0, and works with TypeScript, Babel and ES6 generators.
npm install villa --save
import * as FS from 'fs';
import * as Path from 'path';
import * as v from 'villa';
async function copy(source, target) {
let readStream = FS.createReadStream(source);
let writeStream = FS.createWriteStream(target);
readStream.pipe(writeStream);
await v.awaitable(writeStream, [readStream]);
}
async function copyAll(sourceDir, targetDir) {
await v
.chainable(v.call(FS.readdir, sourceDir))
.filter(async fileName => {
let stats = await v.call(FS.stat, fileName);
return stats.isFile();
})
.each(async fileName => {
let source = Path.join(sourceDir, fileName);
let target = Path.join(targetDir, fileName);
await copy(source, target);
});
}
awaitable(emitter: EventEmitter, types: string | string[], errorEmitters?: EventEmitter[]): Promise<void>
+4Create a promise for an event emitter.
awaitable<T>(emitter: EventEmitter, types: string | string[], errorEmitters?: EventEmitter[]): Promise<T>
awaitable<T>(emitter: EventEmitter, types: string | string[], assertion: EventEmitterResultAssertion<T>, errorEmitters?: EventEmitter[]): Promise<T>
awaitable(process: ChildProcess, errorEmitters?: EventEmitter[]): Promise<void>
awaitable(stream: Readable | Writable, errorEmitters?: EventEmitter[]): Promise<void>
chainable<T>(resolvable: Resolvable<T[]>): Chainable<T>
Wrap given resolvable with a chainable derived of built-in promise.
lock<T>(object: any, handler: LockHandler<T>): Promise<T>
A simple asynchronous lock that helps queueing operations.
parallel<T>(values: T[], handler: ParallelHandler<T>, concurrency?: number): Promise<void>
Run tasks in parallel, similar to v.map
but not mean to transform.
race<T, TResult>(values: T[], transformer: RaceTransformer<T, TResult>): Promise<TResult>
Race tasks and fulfill or reject as soon as one of them fulfills or rejects.
call<T>(fn: NodeStyleAsyncFunction<T>, ...args: any[]): Promise<T>
Call a Node.js-style asynchronous function and return a correspondent promise.
async<T>(fn: NodeStyleAsyncFunction<T>): AsyncFunction<T>
Wrap a Node.js-style asynchronous function to a function that returns promise.
bear(error: any): undefined
A no-operation function that acts as the rejection handler of a promise.
sleep(duration: number): Promise<void>
Create a promise that will be fulfilled in given duration (milliseconds).
retry<T>(handler: RetryHandler<T>, options?: RetryOptions): Promise<T>
Retry procedure in the handler for several times.
each<T>(values: T[], handler: EachHandler<T>): Promise<boolean>
Asynchronous version of Array#forEach()
.
some<T>(values: T[], handler: SomeHandler<T>): Promise<boolean>
Asynchronous version of Array#some()
.
every<T>(values: T[], handler: EveryHandler<T>): Promise<boolean>
Asynchronous version of Array#every()
.
map<T, TResult>(values: T[], transformer: MapTransformer<T, TResult>, concurrency?: number): Promise<TResult[]>
Asynchronous version of Array#map()
with basic concurrency control.
reduce<T, TResult>(values: T[], transformer: ReduceTransformer<T, TResult>, initial: TResult): Promise<TResult>
+1Asynchronous version of Array#reduce()
.
reduce<T>(values: T[], transformer: ReduceTransformer<T, T>): Promise<T | undefined>
reduceRight<T, TResult>(values: T[], transformer: ReduceTransformer<T, TResult>, initial: TResult): Promise<TResult>
+1Asynchronous version of Array#reduceRight()
.
reduceRight<T>(values: T[], transformer: ReduceTransformer<T, T>): Promise<T | undefined>
filter<T>(values: T[], handler: FilterHandler<T>): Promise<T[]>
Asynchronous version of Array#filter()
.
find<T>(values: T[], handler: FindHandler<T>): Promise<T | undefined>
Asynchronous version of Array#find()
.
findIndex<T>(values: T[], handler: FindHandler<T>): Promise<number>
Asynchronous version of Array#findIndex()
.
MIT License.
FAQs
Promise utilities for async/await-ready environment.
We found that villa 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.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.