mirror of
https://gitlab.com/veilid/veilid.git
synced 2025-01-25 14:07:40 -05:00
veilid-wasm
This package is a Rust cargo crate the generates WebAssembly (WASM) bindings for veilid-core::VeilidAPI
, and outputs JavaScript and TypeScript interfaces for calling the WASM module.
Limitations
Running Veilid in the browser via WebAssembly has some limitations:
Browser-based limitations
- TCP/UDP sockets are unavailable in the browser. This limits WASM nodes to communicating using WebSockets.
- Lookup of DNS records is unavailable in the browser, which means bootstrapping via TXT record also will not work. WASM nodes will need to connect to the bootstrap server directly via WebSockets, using this URL format:
ws://bootstrap.veilid.net:5150/ws
in thenetwork.routing_table.bootstrap[]
section of the veilid config. - Do not set up any nodes with a core.network.protocol.wss.url IP address such as wss://12.34.56.78:5150/ws to support SSL. Even though a Certificate Authority (trusted by browsers) will give you an SSL certificate for an IP address, this is unsupported by Veilid as of v0.2.3. Any wss:// URL containing an IP address causes an RPC error in veilid-core and your node will lose communication with other nodes.
- Since a WASM node running in the browser can't open ports, WASM nodes select another node to act as its Inbound Relay, so other nodes can react out to it and open a WS connection.
- Because of browser security policy regarding WebSockets:
ws://
only works onhttp://
siteswss://
only works onhttps://
site with SSL certificates.
Running WASM on HTTPS sites [Not currently implemented]
Since WSS connections require WSS peers with valid SSL certificates, veilid-core
plans to implement a feature called Outbound Relays. Outbound Relays will likely be hosted by the same host of the WASM web-app, and must run have valid SSL certificates that are signed by a Certificate Authority that's trusted by browsers. Outbound Relays will allow WASM nodes to communicate to other nodes over TCP/UDP/WS/WSS through the Outbound Relay's connection.
Running unit tests
Prerequisites:
- NodeJS - ensure
node
andnpm
are installed. - Firefox browser installed, and available as
firefox
.
Run the test script:
./wasm_test.sh
to test with debug symbols../wasm_test.sh release
to test against a release build.
Development notes
Important cargo crates and their functions
wasm-bindgen
is used to generate interop code between JavaScript and Rust, as well as basic TypeScript types.tsify
is used to export TypeScript types in places wherewasm-bindgen
runs into limitations, or in places where you don't need the mappings thatwasm-bindgen
generates.serde-wasm-bindgen
enables serialization/deserialization.