25 breaking releases

new 0.31.0 Jan 14, 2025
0.30.1 Dec 20, 2024
0.29.0 Dec 4, 2024
0.28.1 Nov 4, 2024
0.11.0 Nov 17, 2023

#350 in Network programming

Download history 755/week @ 2024-09-24 1213/week @ 2024-10-01 924/week @ 2024-10-08 1209/week @ 2024-10-15 1543/week @ 2024-10-22 1599/week @ 2024-10-29 1525/week @ 2024-11-05 1143/week @ 2024-11-12 1191/week @ 2024-11-19 1330/week @ 2024-11-26 1709/week @ 2024-12-03 1135/week @ 2024-12-10 1495/week @ 2024-12-17 480/week @ 2024-12-24 1081/week @ 2024-12-31 773/week @ 2025-01-07

3,910 downloads per month
Used in 6 crates (3 directly)

MIT/Apache

235KB
4.5K SLoC

iroh-gossip

This crate implements the iroh-gossip protocol. It is based on epidemic broadcast trees to disseminate messages among a swarm of peers interested in a topic. The implementation is based on the papers HyParView and PlumTree.

The crate is made up from two modules: The proto module is the protocol implementation, as a state machine without any IO. The net module connects the protocol to the networking stack from iroh-net.

The net module is optional behind the net feature flag (enabled by default).

Getting Started

The iroh-gossip protocol was designed to be used in conjunction with iroh. Iroh is a networking library for making direct connections, these connections are how gossip messages are sent.

Iroh provides a Router that takes an Endpoint and any protocols needed for the application. Similar to a router in webserver library, it runs a loop accepting incoming connections and routes them to the specific protocol handler, based on ALPN.

Here is a basic example of how to set up iroh-gossip with iroh:

use iroh::{protocol::Router, Endpoint};
use iroh_gossip::{net::Gossip, ALPN};

#[tokio::main]
async fn main() -> anyhow::Result<()> {
    // create an iroh endpoint that includes the standard discovery mechanisms
    // we've built at number0
    let endpoint = Endpoint::builder().discovery_n0().bind().await?;

    // build gossip protocol
    let gossip = Gossip::builder().spawn(endpoint.clone()).await?;

    // setup router
    let router = Router::builder(endpoint.clone())
        .accept(ALPN, gossip.clone())
        .spawn()
        .await?;
    // do fun stuff with the gossip protocol
    router.shutdown().await?;
    Ok(())
}

License

This project is licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this project by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~14–51MB
~826K SLoC