mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-28 17:57:56 +00:00
3b9fd72b26
* added at_latest * change some documentation * remove inline
40 lines
1.3 KiB
Rust
40 lines
1.3 KiB
Rust
// Copyright 2019-2023 Parity Technologies (UK) Ltd.
|
|
// This file is dual-licensed as Apache-2.0 or GPL-3.0.
|
|
// see LICENSE for license details.
|
|
|
|
//! To run this example, a local polkadot node should be running. Example verified against polkadot v0.9.28-9ffe6e9e3da.
|
|
//!
|
|
//! E.g.
|
|
//! ```bash
|
|
//! curl "https://github.com/paritytech/polkadot/releases/download/v0.9.28/polkadot" --output /usr/local/bin/polkadot --location
|
|
//! polkadot --dev --tmp
|
|
//! ```
|
|
|
|
use futures::join;
|
|
use sp_keyring::AccountKeyring;
|
|
use subxt::{OnlineClient, PolkadotConfig};
|
|
|
|
#[subxt::subxt(runtime_metadata_path = "../artifacts/polkadot_metadata.scale")]
|
|
pub mod polkadot {}
|
|
|
|
#[tokio::main]
|
|
async fn main() -> Result<(), Box<dyn std::error::Error>> {
|
|
let api = OnlineClient::<PolkadotConfig>::new().await?;
|
|
|
|
let addr = AccountKeyring::Bob.to_account_id().into();
|
|
|
|
// Construct storage addresses to access:
|
|
let staking_bonded = polkadot::storage().staking().bonded(&addr);
|
|
let staking_ledger = polkadot::storage().staking().ledger(&addr);
|
|
|
|
// For storage requests, we can join futures together to
|
|
// await multiple futures concurrently:
|
|
let a_fut = api.storage().at_latest().await?.fetch(&staking_bonded);
|
|
let b_fut = api.storage().at_latest().await?.fetch(&staking_ledger);
|
|
let (a, b) = join!(a_fut, b_fut);
|
|
|
|
println!("{a:?}, {b:?}");
|
|
|
|
Ok(())
|
|
}
|