Skip to main content

moq_native/
lib.rs

1//! Helper library for native MoQ applications.
2//!
3//! Establishes MoQ connections over:
4//! - WebTransport (HTTP/3)
5//! - Raw QUIC (with ALPN negotiation)
6//! - WebSocket (fallback via [web-transport-ws](https://crates.io/crates/web-transport-ws))
7//! - Iroh P2P (requires `iroh` feature)
8//!
9//! See [`Client`] for connecting to relays and [`Server`] for accepting connections.
10
11/// Default maximum number of concurrent QUIC streams (bidi and uni) per connection.
12pub(crate) const DEFAULT_MAX_STREAMS: u64 = 1024;
13
14mod client;
15mod crypto;
16mod log;
17#[cfg(feature = "noq")]
18mod noq;
19#[cfg(feature = "quinn")]
20mod quinn;
21mod server;
22#[cfg(any(feature = "noq", feature = "quinn"))]
23mod tls;
24#[cfg(feature = "websocket")]
25mod websocket;
26
27pub use client::*;
28pub use log::*;
29pub use server::*;
30#[cfg(feature = "websocket")]
31pub use websocket::*;
32
33// Re-export these crates.
34pub use moq_lite;
35pub use rustls;
36
37#[cfg(feature = "noq")]
38pub use web_transport_noq;
39#[cfg(feature = "quinn")]
40pub use web_transport_quinn;
41
42#[cfg(feature = "quiche")]
43mod quiche;
44#[cfg(feature = "quiche")]
45pub use web_transport_quiche;
46
47#[cfg(feature = "iroh")]
48mod iroh;
49#[cfg(feature = "iroh")]
50pub use iroh::*;
51
52/// The QUIC backend to use for connections.
53#[derive(Clone, Debug, clap::ValueEnum, serde::Serialize, serde::Deserialize)]
54#[serde(rename_all = "lowercase")]
55#[non_exhaustive]
56pub enum QuicBackend {
57	/// [web-transport-quinn](https://crates.io/crates/web-transport-quinn)
58	#[cfg(feature = "quinn")]
59	Quinn,
60
61	/// [web-transport-quiche](https://crates.io/crates/web-transport-quiche)
62	#[cfg(feature = "quiche")]
63	Quiche,
64
65	/// [web-transport-noq](https://crates.io/crates/web-transport-noq)
66	#[cfg(feature = "noq")]
67	Noq,
68}