14 releases (9 breaking)

0.10.0 Apr 2, 2025
0.9.1 Feb 24, 2025
0.9.0 Jan 29, 2025
0.8.0 Dec 2, 2024
0.1.1 Jan 15, 2024

#5 in #celestia

Download history 1/week @ 2025-01-07 9/week @ 2025-01-21 142/week @ 2025-01-28 76/week @ 2025-02-04 26/week @ 2025-02-11 112/week @ 2025-02-18 108/week @ 2025-02-25 13/week @ 2025-03-04 18/week @ 2025-03-11 1/week @ 2025-03-18 3/week @ 2025-03-25 145/week @ 2025-04-01 23/week @ 2025-04-08

178 downloads per month
Used in 3 crates

Apache-2.0

1MB
21K SLoC

Lumina node

A crate to configure, run and interact with Celestia's data availability nodes.

use std::sync::Arc;

use lumina_node::blockstore::RedbBlockstore;
use lumina_node::network::Network;
use lumina_node::node::Node;
use lumina_node::store::RedbStore;
use redb::Database;
use tokio::task::spawn_blocking;

#[tokio::main]
async fn main() {
    let db = spawn_blocking(|| Database::create("lumina.redb"))
        .await
        .expect("Failed to join")
        .expect("Failed to open the database");
    let db = Arc::new(db);

    let store = RedbStore::new(db.clone())
        .await
        .expect("Failed to create a store");
    let blockstore = RedbBlockstore::new(db);

    let node = Node::builder()
        .store(store)
        .blockstore(blockstore)
        .network(Network::Mainnet)
        .listen(["/ip4/0.0.0.0/tcp/0".parse().unwrap()])
        .start()
        .await
        .expect("Failed to build and start node");

    node.wait_connected().await.expect("Failed to connect");

    let header = node
        .request_header_by_height(15)
        .await
        .expect("Height not found");

    println!("{}", serde_json::to_string_pretty(&header).unwrap());
}

Dependencies

~28–68MB
~1M SLoC