@robindiddams/y-websocket v1.3.14
y-websocket :tophat:
WebSocket Provider for Yjs
This is a fork of https://github.com/yjs/y-websocket with changes for pinpt
The Websocket Provider implements a classical client server model. Clients connect to a single endpoint over Websocket. The server distributes awareness information and document updates among clients.
The Websocket Provider is a solid choice if you want a central source that handles authentication and authorization. Websockets also send header information and cookies, so you can use existing authentication mechanisms with this server.
- Supports cross-tab communication. When you open the same document in the same browser, changes on the document are exchanged via cross-tab communication (Broadcast Channel and localStorage as fallback).
- Supports exchange of awareness information (e.g. cursors).
Quick Start
Client Code:
import * as Y from 'yjs'
import { WebsocketProvider } from 'y-websocket'
const doc = new Y.Doc()
const wsProvider = new WebsocketProvider('ws://localhost:1234', 'my-roomname', doc)
wsProvider.on('status', event => {
  console.log(event.status) // logs "connected" or "disconnected"
})Client Code in Node.js
The WebSocket provider requires a WebSocket object to create connection to a server. You can polyfill WebSocket support in Node.js using the ws package.
const wsProvider = new WebsocketProvider('ws://localhost:1234', 'my-roomname', doc, { WebSocketPolyfill: require('ws') })API
import { WebsocketProvider } from 'y-websocket'wsOpts = {
  // Set this to `false` if you want to connect manually using wsProvider.connect()
  connect: true,
  // Specify a query-string that will be url-encoded and attached to the `serverUrl`
  // I.e. params = { auth: "bearer" } will be transformed to "?auth=bearer"
  params: {}, // Object<string,string>
  // You may polyill the Websocket object (https://developer.mozilla.org/en-US/docs/Web/API/WebSocket).
  // E.g. In nodejs, you could specify WebsocketPolyfill = require('ws')
  WebsocketPolyfill: Websocket,
  // Specify an existing Awareness instance - see https://github.com/yjs/y-protocols
  awareness: new awarenessProtocol.Awareness(ydoc)
}Websocket Server
Start a y-websocket server:
PORT=1234 npx y-websocket-serverSince npm symlinks the y-websocket-server executable from your local ./node_modules/.bin folder, you can simply run npx. The PORT environment variable already defaults to 1234.
Websocket Server with Persistence
Persist document updates in a LevelDB database.
See LevelDB Persistence for more info.
PORT=1234 YPERSISTENCE=./dbDir node ./node_modules/y-websocket/bin/server.jsWebsocket Server with HTTP callback
Send a debounced callback to an HTTP server (POST) on document update.
Can take the following ENV variables:
- CALLBACK_URL: Callback server URL
- CALLBACK_DEBOUNCE_WAIT: Debounce time between callbacks (in ms). Defaults to 2000 ms
- CALLBACK_DEBOUNCE_MAXWAIT: Maximum time to wait before callback. Defaults to 10 seconds
- CALLBACK_TIMEOUT: Timeout for the HTTP call. Defaults to 5 seconds
- CALLBACK_OBJECTS: JSON of shared objects to get data (- '{"SHARED_OBJECT_NAME":"SHARED_OBJECT_TYPE}')
CALLBACK_URL=http://localhost:3000/ CALLBACK_OBJECTS='{"prosemirror":"XmlFragment"}' npm startThis sends a debounced callback to localhost:3000 2 seconds after receiving an update (default DEBOUNCE_WAIT) with the data of an XmlFragment named "prosemirror" in the body.
License
The MIT License © Kevin Jahns
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago