mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-23 03:47:59 +00:00
a0cb14aa4f
* start migrating, broken * first iteration of updating * fmt and clippy * add Composite<u32> decoding via scale value patch * bump scale type gen versions * fix decoding with new scale decode * compiling with changed deps * core utils, condig, client, metadata * core crate compiling * signer crate no once lock * add core to no-std-tests, change imports * broken commit, start pulling everything together in subxt * port more things to subxt * events in core crate, extrinsics sadly much more difficult * almost all examples pass again * dynamic values fix in examples * fix no std issue and fmt * remove unused dependencies * fix lightclient impl * runtime version refactor * formatting and addressing nits * more comments addressed * update wasm example and no-std-signer tests * other nits and error impl on signer errors * fix feature flag * fix runtime version refactor * fix doc links * fix integration tests * fix feature flag gated client state * fix native feature in CI * fix lightclient utils * make imports more lean in subxt-core * integrate changes from subxt-core imports into subxt * other changes in subxt simplify imports more * fix and docs * doc false for cli * fix clippy * remove events block hash in tests * codegen no-std support in generated code * export alloc crate for no-std codegen * fix doc test * implement James comments * remove std traits, use core traits instead * address nits * remove unusued dep in no-std tests * fix Box import in no_std * sp-crypto-hashing instead of sp-core-hashing * bump scale-typegen, add no std codegen tests * fix some things * replace unmaintained derivative with derive_where to remove non-canonical warnings * fmt * remove unused dep * fix deps * update artifacts to fix type ID mismatches * bump to latest scale-typegen --------- Co-authored-by: James Wilson <james@jsdw.me>
46 lines
1.6 KiB
Rust
46 lines
1.6 KiB
Rust
use codec::{Decode};
|
|
use subxt::{config::substrate::H256, OfflineClient, PolkadotConfig};
|
|
use subxt_metadata::Metadata;
|
|
|
|
#[subxt::subxt(runtime_metadata_path = "../../../../artifacts/metadata_with_custom_values.scale", derive_for_all_types = "Eq, PartialEq")]
|
|
pub mod node {}
|
|
use node::runtime_types::generate_custom_metadata::Foo;
|
|
|
|
fn main() {
|
|
let api = construct_offline_client();
|
|
|
|
let expected_foo = Foo {
|
|
a: 42,
|
|
b: "Have a great day!".into(),
|
|
};
|
|
|
|
// static query:
|
|
let foo_address = node::custom().foo();
|
|
let foo = api.custom_values().at(&foo_address).unwrap();
|
|
assert_eq!(foo, expected_foo);
|
|
|
|
// dynamic query:
|
|
let foo_value = api.custom_values().at("Foo").unwrap();
|
|
let foo: Foo = foo_value.as_type().unwrap();
|
|
assert_eq!(foo, expected_foo);
|
|
|
|
// static query for some custom value that has an invalid type id: (we can still access the bytes)
|
|
let custom_bytes = api.custom_values().bytes_at("InvalidTypeId").unwrap();
|
|
assert_eq!(vec![0,1,2,3], custom_bytes);
|
|
}
|
|
|
|
fn construct_offline_client() -> OfflineClient<PolkadotConfig> {
|
|
let genesis_hash = {
|
|
let h = "91b171bb158e2d3848fa23a9f1c25182fb8e20313b2c1eb49219da7a70ce90c3";
|
|
let bytes = hex::decode(h).unwrap();
|
|
H256::from_slice(&bytes)
|
|
};
|
|
let runtime_version = subxt::client::RuntimeVersion::new(9370, 20);
|
|
|
|
let metadata = {
|
|
let bytes = std::fs::read("../../../../artifacts/metadata_with_custom_values.scale").unwrap();
|
|
Metadata::decode(&mut &*bytes).unwrap()
|
|
};
|
|
OfflineClient::<PolkadotConfig>::new(genesis_hash, runtime_version, metadata)
|
|
}
|