Mixnet Client Builder

You can spin up an ephemeral client like so. This client will not have a persistent identity and its keys will be dropped on restart. Since there is currently no way of reconnecting a client that has been disconnected after use, then treat disconnecting a client the same as dropping its keys entirely.

You can find this code here (opens in a new tab).

use nym_sdk::mixnet;
use nym_sdk::mixnet::MixnetMessageSender;
 
#[tokio::main]
async fn main() {
    nym_bin_common::logging::setup_logging();
 
    // Create client builder, including ephemeral keys. The builder can be usable in the context
    // where you don't want to connect just yet.
    let client = mixnet::MixnetClientBuilder::new_ephemeral()
        .build()
        .unwrap();
 
    // Now we connect to the mixnet, using ephemeral keys already created
    let mut client = client.connect_to_mixnet().await.unwrap();
 
    // Be able to get our client address
    let our_address = client.nym_address();
    println!("Our client nym address is: {our_address}");
 
    // Send a message through the mixnet to ourselves
    client
        .send_plain_message(*our_address, "hello there")
        .await
        .unwrap();
 
    println!("Waiting for message");
    if let Some(received) = client.wait_for_messages().await {
        for r in received {
            println!("Received: {}", String::from_utf8_lossy(&r.message));
        }
    }
 
    client.disconnect().await;
}