4 releases

0.6.3 Dec 18, 2024
0.6.2 Dec 2, 2024
0.6.1 Nov 19, 2024
0.6.0 Nov 19, 2024

#10 in #subgraph

Download history 230/week @ 2024-11-15 50/week @ 2024-11-22 140/week @ 2024-11-29 33/week @ 2024-12-06 92/week @ 2024-12-13 20/week @ 2024-12-20

121 downloads per month

MIT license

29KB
474 lines

The Graph Networks Registry Rust Library

Crates.io Docs.rs License: MIT

Rust types and helpers for working with The Graph Networks Registry.

Documentation available here.

Usage

If you want to always get up-to-date registry, make sure to use the latest version of the crate.

Cargo.toml:

[dependencies]
graph-networks-registry = "0.6.1"

Reading from a local file

To read the registry from a local file

use graph_networks_registry::NetworksRegistry;
fn main() {
    // Parse registry from JSON file
    let registry = NetworksRegistry::from_file("TheGraphNetworksRegistry_v0_6_0.json")
        .expect("Failed to parse registry");

    if let Some(network) = registry.get_network_by_id("mainnet") {
        println!("Found mainnet: {:?}", network);
    }
}

Fetching the latest registry

To fetch the latest compatible registry version from networks-registry.thegraph.com

use graph_networks_registry::NetworksRegistry;

#[tokio::main]
async fn main() {
    let registry = NetworksRegistry::from_latest_version()
        .await
        .expect("Failed to fetch registry");
    println!("Loaded {} networks", registry.networks.len());
}

Features

  • fetch - Enables remote registry fetching functionality using reqwest (enabled by default)

If you don't need to fetch the registry from the network, you can turn off the fetch feature in your Cargo.toml:

[dependencies]
graph-networks-registry = { version = "0.6.1", default-features = false }

Dependencies

~0.7–17MB
~168K SLoC