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

pubsub-ts

Package Overview
Dependencies
Maintainers
1
Versions
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

pubsub-ts

PubSub Messaging Pattern in Typescript

  • 0.2.0
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
278
increased by5.7%
Maintainers
1
Weekly downloads
 
Created
Source

PubSub

Publisher/Subscriber pattern plus messaging queue and notifications written in Typescript.

Installation

npm install pubsub-ts

Usage

Creating a Subscriber

import {PubSub} from "pubsub-ts";

let subscriber: PubSub.Subscriber = new PubSub.Subscriber();

Registering for Notifications

subscriber.on('postMsg', (notification: PubSub.Notification) => {
    this.msg = notification.body;
});

De-registering for Notifications

subscriber.off('postMsg');

Start receiving notifications

subscriber.start();

Pause receiving notifications

subscriber.pause();

Creating a Publisher

import {PubSub} from "pubsub-ts";

let publisher: PubSub.Publisher = new PubSub.Publisher();

Registering a Subscriber

publisher.add(subscriber);

Removing a Subscriber

publisher.delete(subscriber);

Sending a Notification

publisher.notify('postMsg', 'a message');

You can also prioritize a Notification.

publisher.notifyPriority('postMsg', 'priority message');

Or send a Notification as urgent to be delivered immediately.

publisher.notifyUrgent('postMsg', 'urgent message');

Notification Queue

Subscribers are equipped with a queue of notifications. You can control when the Subscriber should start() receiving notifications that were posted to its queue as well as pause() the queue.

This allows to preserve the order of notifications until the subscriber is ready to receive them. For example when waiting for an async operation to complete.

When a Subscriber is in the paused state, notifications are pushed into the queue for later processing.

When a Subscriber is in the started state, the queue will resume processing notifications.

NOTE: Subscribers are paused by default. You must invoke start() to enable processing from the queue. This is done so you have explicit control as to when notifications should start being posted to the subscriber.

Sample

import {PubSub} from "pubsub-ts";

class TransactionAgent extends PubSub.Subscriber {
    constructor() {
        this.on('connectionChange', this.onConnection);
        this.on('withdrawal', this.onWithdrawal);
    }

    public onConnection(notification: PubSub.Notification): void {
        if (notification.body.status === 'online') {
            // Start receiving notifications
            this.start();
        } else {
            // Pause receiving notifications
            this.pause();
        }
    }

    public onWithdrawal(notification: PubSub.Notification): void {
        let amount: number = notification.body;
        console.log('[TransactionAgent]', amount);
    }
}

class ATM extends PubSub.Publisher {
    constructor() {
        this.add(new TransactionAgent());
    }

    public withdrawAmount(amount: number): void {
        this.notify('withdrawal', amount);
    }

    public connectionChange(status: string): void {
        this.notify('connectionChange', {status: status});
    }
}
let atm: ATM = new ATM();
// 1. ATM not connected. Offline.
// 2. User requests withdrawal.
atm.withdrawAmount(1500);
// 3. ATM back online. Connection ready.
atm.connectionChange('online');
// 4. Transaction agent starts processing from the queue
// console log:
[TransactionAgent], 1500

License

MIT License

Keywords

FAQs

Package last updated on 04 May 2018

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