mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-23 10:48:00 +00:00
ca5345c47e
* WIP config * WIP separate default config * Separate trait impls on client * WIP introduce new ApiConfig (to be renamed) trait * Update generated polkadot codegen * Allow configuring Config and Extra types independently * Add extra default configuration * Revert ir parsing of config attr * Add default-features = false to substrate deps * Revert "Add default-features = false to substrate deps" This reverts commit 099d20cd4cbf8000ff938d1dc090ecbc28a5e788.
52 lines
1.5 KiB
Rust
52 lines
1.5 KiB
Rust
// Copyright 2019-2022 Parity Technologies (UK) Ltd.
|
|
// This file is part of subxt.
|
|
//
|
|
// subxt is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// subxt is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with subxt. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
use subxt::{
|
|
ClientBuilder,
|
|
DefaultConfig,
|
|
DefaultExtra,
|
|
};
|
|
|
|
#[subxt::subxt(runtime_metadata_path = "examples/polkadot_metadata.scale")]
|
|
pub mod polkadot {}
|
|
|
|
#[async_std::main]
|
|
async fn main() -> Result<(), Box<dyn std::error::Error>> {
|
|
env_logger::init();
|
|
|
|
let api = ClientBuilder::new()
|
|
.set_url("wss://rpc.polkadot.io:443")
|
|
.build()
|
|
.await?
|
|
.to_runtime_api::<polkadot::RuntimeApi<DefaultConfig, DefaultExtra<DefaultConfig>>>();
|
|
|
|
let block_number = 1;
|
|
|
|
let block_hash = api
|
|
.client
|
|
.rpc()
|
|
.block_hash(Some(block_number.into()))
|
|
.await?;
|
|
|
|
if let Some(hash) = block_hash {
|
|
println!("Block hash for block number {}: {}", block_number, hash);
|
|
} else {
|
|
println!("Block number {} not found.", block_number);
|
|
}
|
|
|
|
Ok(())
|
|
}
|