Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

clerx

Package Overview
Dependencies
Maintainers
1
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

clerx

The Clerical Rx Suite

  • 2.0.2
  • latest
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

clerx 💁

A Timely Suite of RxJS Operators and Observables

Install

npm install clerx

Try out the example

Operators

As defined in the RxJS docs:

Operators are the essential pieces that allow complex asynchronous code to be easily composed in a declarative manner. Operators are functions.

rateLimiter(count, slidingWindowTime)

Defer sending events if count events occur within slidingWindowTime (milliseconds). Optionally, stop deferring if the wait time goes past timeoutDue. Returns an Observable.

Examples

Only send two events within three seconds

In this example, only 2 (count) events are sent during a 3 second (3000 ms slidingWindowTime) sliding window. As displayed in the marble diagram, additional events beyond 2 events in the sliding window will be deferred.

abcdef--g---

> rateLimiter(2, 3000)

ab-cd-ef-g--

rate-limiter

Only one event within five seconds

Similarly, this example limits events to one (count) event in a five second (5000 ms slidingWindowTime) window. The marble diagram shows how the events are distributed over time.

-(abc)def

> rateLimiter(1, 5000)

-a----b----c----d----e----f----

rate-limit-five-tick

Observables

As defined in the RxJS docs:

Observables are lazy Push collections of multiple values.

postDelay(event: T, dueTime): Observable<T>

Creates an observable that emits the event then waits dueTime (milliseconds) before closing the observable, like so:

event--{ dueTime }--|

Example: Delay 5 seconds after emitting an event

> postDelay("a", 5000)

a----|

post-delay

intervalBackoff(backoff: number): Observable<number>

Creates an Observable that emits sequential numbers in an exponentially increasing interval of time. backoff is the starting time interval, in milliseconds, and will exponentially increase with each event.

Example: Exponentially increase delay starting at a one second interval

The marble diagram illustrates the exponentially growing duration between events.

> intervalBackoff(1000)

01-2---3-------4---------------5

interval-backoff

Keywords

FAQs

Package last updated on 30 Nov 2021

Did you know?

Socket

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
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc