Expand description
P2P WebRTC connection establishment and pooling. Tx5 uses SBD as the WebRTC signaling protocol for connection establishment, providing an interface where you can attempt to send data to any known peer with the expectation that Tx5 will open a connection to that peer or use an existing open connection.
§Tx5
- tx5 -
- The main holochain tx5 webrtc networking crate integrating the other code in this monorepo.
§Tx5 Support Crates
- tx5-connection -
- Holochain webrtc connection.
- tx5-core -
- Core types used in other tx5 crates.
- tx5-online -
- Network online connectivity status events.
- tx5-go-pion-turn -
- Rust process wrapper around tx5-go-pion-turn executable.
- tx5-go-pion-sys -
- Low level rust bindings to the go pion webrtc library.
- tx5-go-pion -
- Higher level rust bindings to the go pion webrtc library.
- tx5-signal -
- Holochain webrtc signal client.
- tx5-demo -
- Demo showing off tx5 p2p connectivity.
§tx5-connection
Holochain webrtc connection. Starts by sending messages over the sbd signal server, if we can upgrade to a proper webrtc p2p connection, we do so.
§WebRTC Backend Features
Tx5 can be backed currently by 1 of 2 backend webrtc libraries.
*DEFAULT*backend-libdatachannel- WebRTC library written in C++.backend-go-pion- The pion webrtc library written in Go (golang).
The go pion library was the original implementation, but as libdatachannel has reached stability, we have switched it over to be the default as it is much easier to write rust FFI bindings to C++ code than Go code.
Re-exports§
pub use tx5_signal;pub use super::*;
Structs§
- Conn
- A tx5 connection.
- Conn
Recv - Receive messages from a tx5 connection.
- Conn
Stats - Connection statistics.
- Framed
Conn - A framed wrapper that can send and receive larger messages than the base connection.
- Framed
Conn Recv - Receive a framed message on the connection.
- Hub
- A signal server connection from which we can establish tx5 connections.
- HubConfig
- Tx5 connection hub config.
- HubRecv
- A stream of incoming p2p connections.
- IceServers
- Configuration for a group of ICE servers.
- Tx5Init
Config - Initial configuration. If you would like to change this from the default, please call Tx5InitConfig::set_as_global_default before creating any peer connections.
- WebRtc
Config - WebRTC config.
Enums§
- Backend
Module - The backend webrtc module to use.
- Credential
Type - The type of credential to use for ICE servers.
- Transport
Policy - ICE transport policy.