20 unstable releases (9 breaking)

0.10.2 Dec 9, 2023
0.10.1 Nov 12, 2023
0.9.3 Oct 18, 2023
0.9.0-alpha Jul 31, 2023
0.2.0 Mar 31, 2021

#2063 in Network programming

Download history 17122/week @ 2023-12-23 28339/week @ 2023-12-30 38687/week @ 2024-01-06 44360/week @ 2024-01-13 43959/week @ 2024-01-20 44110/week @ 2024-01-27 46710/week @ 2024-02-03 46071/week @ 2024-02-10 57307/week @ 2024-02-17 51536/week @ 2024-02-24 47125/week @ 2024-03-02 49369/week @ 2024-03-09 54376/week @ 2024-03-16 52283/week @ 2024-03-23 65893/week @ 2024-03-30 52139/week @ 2024-04-06

232,869 downloads per month
Used in 185 crates (4 directly)

MIT license

445KB
8K SLoC

Implementation of the QUIC transport protocol for libp2p.

Usage

Example:

#
#
use libp2p_quic as quic;
use libp2p_core::{Multiaddr, Transport, transport::ListenerId};

let keypair = libp2p_identity::Keypair::generate_ed25519();
let quic_config = quic::Config::new(&keypair);

let mut quic_transport = quic::async_std::Transport::new(quic_config);

let addr = "/ip4/127.0.0.1/udp/12345/quic-v1".parse().expect("address should be valid");
quic_transport.listen_on(ListenerId::next(), addr).expect("listen error.");
#

The GenTransport struct implements the libp2p_core::Transport. See the documentation of libp2p_core and of libp2p in general to learn how to use the Transport trait.

Note that QUIC provides transport, security, and multiplexing in a single protocol. Therefore, QUIC connections do not need to be upgraded. You will get a compile-time error if you try. Instead, you must pass all needed configuration into the constructor.

Dependencies

~20–58MB
~1M SLoC