12 releases (breaking)

0.9.0 Jan 29, 2025
0.8.0 Dec 2, 2024
0.7.0 Dec 2, 2024
0.6.0 Oct 29, 2024
0.1.1 Jan 15, 2024

#3 in #celestia

Download history 130/week @ 2024-10-28 16/week @ 2024-11-04 2/week @ 2024-11-11 7/week @ 2024-11-18 3/week @ 2024-11-25 292/week @ 2024-12-02 42/week @ 2024-12-09 5/week @ 2024-12-16 1/week @ 2025-01-06 7/week @ 2025-01-20 141/week @ 2025-01-27 69/week @ 2025-02-03 27/week @ 2025-02-10

245 downloads per month
Used in 2 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

~27–65MB
~1M SLoC