Socket
Socket
Sign inDemoInstall

async-broadcaster

Package Overview
Dependencies
0
Maintainers
1
Versions
2
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    async-broadcaster

Observable alternative using async iterators


Version published
Weekly downloads
0
Maintainers
1
Created
Weekly downloads
 

Readme

Source

async-broadcaster

Observable alternative using async iterators

Install

npm i async-broadcaster

Why

It's a common requirement to let users subscribe to new values that are produced asynchronously. Often we reach for an observable library (RxJS, zen-observable, Wonka, etc.) to manage subscriptions and allow broadcasting of new values, but full observable implementations may be overkill for simple subscriptions. Observable also bring along a new API, when JavaScript already has an standard API for consuming asynchronous values: async iterables.

What's needed to enable consumers to use async iterables is a way for producers to make async iterables that can be listened to by multiple listeners and correctly handle buffering, unsubscription, etc.

This is what AsyncBroadcaster does.

AsyncBroadcaster takes a single async iterable and adapts it to allow multiple listeners.

Features

  • Supports multiple listeners
  • Buffers values for slow listeners
  • Efficiently clears the buffer of values seen by all listeners
  • Supports AbortSignal for cancelling iteration
  • Automatically cleans up when listeners break or return from for/await...of loops

Usage

import {AsyncBroadcaster} from 'async-broadcaster';

async function* makeOneHundred() {
  for (let i = 0; i < 100; i++) {
    yield i;
  }
}

const broadcaster = new AsyncBroadcaster(makeOneHundred());

// listen to broadcast values
logValues(broadcaster.iterable);

// We can listen more than once
logValues(broadcaster.iterable);

async function logValues(iterable) {
  // listening is done with anything that can consume async iterables, like
  // a for/await-of loop:
  for await (const o of iterable) {
    console.log(o);
  }
}

Pairs well with IxJS

Async iterables don't have the functional methods that Array does like map(), reduce(), or filter(), nor the common reactive operators like count(), zip(), etc.

These can be imported from a library that works with any async iterable, such as IxJS.


import { filter, map } from 'ix/asynciterable/operators';

const results = from(broadcaster.iterable).pipe(
  filter(async x => x % 2 === 0),
  map(async x => x * x)
);

for await (let item of results) {
  console.log(`Next: ${item}`);
}

Keywords

FAQs

Last updated on 24 Jun 2021

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc