0.0.12 • Published 4 months ago

@fails-components/webtransport-ponyfill-websocket v0.0.12

Weekly downloads
-
License
BSD-3-Clause
Repository
github
Last release
4 months ago

"FAILS logo"

Fancy automated internet lecture system (FAILS) - components (Webtransport module)

Tests on master master

(c) 2022- Marten Richter

This package is part of FAILS. A web based lecture system developed out of university lectures.

The package provides a Webtransport ponyfill using websocket as transport to node.js and the browser. In this way you can support WebTransport and Websocket with the same code basis. It is useful, if a browser does not support WebTransport or if the network blocks UDP to your servers. If you require webtransport support in node.js use our webtransport package build using libquiche https://github.com/google/quiche.

While FAILS as a whole is licensed via GNU Affero GPL version 3.0, this package is licensed under a BSD-style license that can be found in the LICENSE file. This package is licensed more permissive, since it can be useful outside of the FAILS environment, and FAILS will benefit from the feedback of a larger developer base.

This packages a WebTransport interface similar to the browser side and our webtransport node.js packages, but uses internally websocket over http. So you must use it on the client and server side (but not all webtransport features are implemented). For server as well as for client, see test/test.js, test/testsuite.js, test/echoclient.js, test/echoserver.js for examples.

Internally it opens websocket http/1 (to prevent head of line blocking) for the main WebTransport session and for every stream. A json webtoken like mechanism is used to pin and secure the stream to the main session.

PR request are welcome and will be supported by advise from the author.

  • This is one of the first releases, if any problems occur, please report the issue via github to make the package stable. *

Installation and usage

You can install the package directly via npm from node.js or github packages:

npm install @fails-components/webtransport-ponyfill-websocket

In case of github packages, please add to your .npmrc file

@fails-components:registry=https://npm.pkg.github.com

In this case you need to be authenticated against github.

You need also to install the package ws, if you are using the package with node.

In the directory test you find a simple echo server code. That answers to a series of WebTransport echos transported via Websocket. Furthermore some example browser code and finally a unit test of the library.

0.0.13

4 months ago

0.0.10

7 months ago

0.0.12

7 months ago

0.0.9

10 months ago

0.0.8

1 year ago

0.0.7

1 year ago

0.0.6

1 year ago

0.0.4

2 years ago

0.0.3

2 years ago

0.0.2

2 years ago