@jgtools/bunnyws
TypeScript icon, indicating that this package has built-in type declarations

4.0.8 • Public • Published

BunnyWS

npm npm GitHub

Lightweight WebSocket library for Bun

Features

  • 🐰 Works with Bun
  • ⚡ Zero dependencies
  • ⚙️ Assigns an ID to each client connection
  • 🟦 Written in TypeScript

Installation

Using bun

bun a @jgtools/bunnyws
import { BunnyWS } from "@jgtools/bunnyws";
// ...

Usage

import { BunnyMsg, BunnyWS, BunnyWSEvents, BunnyWSClient } from "@jgtools/bunnyws";

const events: BunnyWSEvents = {
    open: (ws: BunnyWSClient) => {
        console.log("Client has connected", ws.data.id);
    },
    message: (ws: BunnyWSClient, msg: BunnyMsg) => {
        console.log("Received:", msg);
        ws.send(msg); // send to client
        ws.publish("global", msg); // send to all connected clients (excluding itself)
    },
    close: (ws: BunnyWSClient) => {
        console.log("Client has disconnected:", ws.data.id);
    }
}

const bws = new BunnyWS(8080, events);
setInterval(() => bws.publish("Published to all"), 3000);

Docs

BunnyWS

BunnyWS is a WebSocket server.

Constructor parameters:

Parameter Type
port number
events BunnyWSEvents

Methods:

Method Type
publish (msg: string | ArrayBufferView | ArrayBuffer, compress?: boolean) => number

BunnyWSEvents

BunnyWSEvents is an interface that defines the event handlers for a BunnyWS server.

Property Type
open (ws: BunnyWSClient) => void
message (ws: BunnyWSClient, msg: BunnyMsg) => void
close (ws: BunnyWSClient) => void

License

MIT

Package Sidebar

Install

npm i @jgtools/bunnyws

Weekly Downloads

0

Version

4.0.8

License

MIT

Unpacked Size

7.21 kB

Total Files

6

Last publish

Collaborators

  • jgtools