This ponyfill/polyfill is now deprecated and will not be updated. The node.js package @fails-components/webtransports acts, since version 1.0.0 also as a polyfill/ponyfill. It uses a different protocol, closer to the http/2 webtransport protcol.
(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.
Pleae use @fails-components/webtransport-ponyfill-websocket
instead.
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.