mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-23 00:18:00 +00:00
b4eb406ee5
* Add and use subxt-signer crate for WASM compatible signing * cargo fmt * dev keypairs already references * WIP fix various breakages * re-jig features to be simpler and various test fixes etc * doc and web fix * fix various bits and pieces * fix a test I broke * dev-deps can't be linked to in docs, hrmph * cargo fmt * another doc link * document the subxt_signer crate more thoroughly * move feature flag for consistency * more docs, no default subxt feature flag on signer, update release instrs * Add missing license header * unwrap_inner => into_inner * extend a test a little to better check derive junctions * note more clearly that the crypto bits come from sp_core::crypto
28 lines
1004 B
Rust
28 lines
1004 B
Rust
use subxt::dynamic::{At, Value};
|
|
use subxt::{OnlineClient, PolkadotConfig};
|
|
use subxt_signer::sr25519::dev;
|
|
|
|
#[tokio::main]
|
|
async fn main() -> Result<(), Box<dyn std::error::Error>> {
|
|
// Create a new API client, configured to talk to Polkadot nodes.
|
|
let api = OnlineClient::<PolkadotConfig>::new().await?;
|
|
|
|
// Build a dynamic storage query to access account information.
|
|
let account = dev::alice().public_key();
|
|
let storage_query =
|
|
subxt::dynamic::storage("System", "Account", vec![Value::from_bytes(account)]);
|
|
|
|
// Use that query to `fetch` a result. Because the query is dynamic, we don't know what the result
|
|
// type will be either, and so we get a type back that can be decoded into a dynamic Value type.
|
|
let result = api
|
|
.storage()
|
|
.at_latest()
|
|
.await?
|
|
.fetch(&storage_query)
|
|
.await?;
|
|
let value = result.unwrap().to_value()?;
|
|
|
|
println!("Alice has free balance: {:?}", value.at("data").at("free"));
|
|
Ok(())
|
|
}
|