Rust library, which can be used by other project to programmatically interact with the Miden rollup.
In order to utilize the miden-client
library, you can add the dependency to your project's Cargo.toml
file:
miden-client = { version = "0.5" }
async
: enables async traits. Automatically enabled forweb-tonic
feature. Disabled by default.concurrent
: used to enable concurrency during execution and proof generation. Disabled by default.idxdb
: includesWebStore
, an IdexedDB implementation of theStore
trait. Disabled by default.sqlite
: includesSqliteStore
, a SQLite implementation of theStore
trait. Disabled by default.tonic
: includesTonicRpcClient
, a Tonic client to communicate with Miden node. Disabled by default.web-tonic
: includesWebTonicRpcClient
, an Tonic client to communicate with the Miden node in the browser. Disabled by default.testing
: useful feature that lowers PoW difficulty when enabled, meant to be used during development and not on production. Disabled by default.
To compile with no_std
, disable default features via --no-default-features
flag.
The library user can provide their own implementations of Store
and RpcClient
traits, which can be used as components of Client
, though it is not necessary. The Store
trait is used to persist the state of the client, while the RpcClient
trait is used to communicate via gRPC with the Miden node.
The sqlite
and tonic
features provide implementations for these traits using Rusqlite and Tonic respectively. The idxdb
and web-tonic
features provide implementations based on IndexedDB and tonic-web which can be used in the browser.
This project is MIT licensed.