forked from scs/substrate-api-client
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample_custom_storage_struct.rs.DEPRECATED
executable file
·79 lines (65 loc) · 2.96 KB
/
example_custom_storage_struct.rs.DEPRECATED
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*
Copyright 2019 Supercomputing Systems AG
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
//! This example shows how to decode a runtime value that is a custom struct.
//!
//! *Note*: The runtime module here is not in the generic substrate node. Hence, this example
//! must run against the customized node found in `https://github.com/scs/substrate-test-nodes`.
//!
use clap::{load_yaml, App};
use codec::{Decode, Encode};
use keyring::AccountKeyring;
use log::*;
use sp_core::{crypto::Pair, H256};
use substrate_api_client::{
compose_extrinsic, extrinsic::xt_primitives::UncheckedExtrinsicV4, Api, XtStatus
};
// The custom struct that is to be decoded. The user must know the structure for this to work, which can fortunately
// be looked up from the node metadata and printed with the `example_print_metadata`.
#[derive(Encode, Decode, Debug, Clone)]
struct Kitty {
id: H256,
price: u128,
}
fn main() {
env_logger::init();
let url = get_node_url_from_cli();
// initialize api and set the signer (sender) that is used to sign the extrinsics
let from = AccountKeyring::Alice.pair();
let api = Api::new(format!("ws://{}", url)).set_signer(from.clone());
let xt: UncheckedExtrinsicV4<_> =
compose_extrinsic!(api.clone(), "KittyModule", "create_kitty", 10 as u128);
println!("[+] Composed extrinsic to create Kitty:\n\n {:?}", xt);
// send and watch extrinsic until finalized
let tx_hash = api.send_extrinsic(xt.hex_encode(), XtStatus::Finalized).unwrap();
println!("[+] Transaction got finalized. Hash: {:?}\n", tx_hash);
// Get the index at which Alice's Kitty resides. Alternatively, we could listen to the StoredKitty
// event similar to what we do in the example_contract.
let index: u64 = api
.get_storage_map("Kitty", "KittyIndex", from.public())
.unwrap();
println!("[+] Alice's Kitty is at index : {}\n", index);
// get the Kitty
let kitty: Kitty = api
.get_storage_map("Kitty", "Kitties", index)
.unwrap();
println!("[+] Cute decoded Kitty: {:?}\n", kitty);
}
pub fn get_node_url_from_cli() -> String {
let yml = load_yaml!("../../src/examples/cli.yml");
let matches = App::from_yaml(yml).get_matches();
let node_ip = matches.value_of("node-server").unwrap_or("127.0.0.1");
let node_port = matches.value_of("node-port").unwrap_or("9944");
let url = format!("{}:{}", node_ip, node_port);
println!("Interacting with node on {}\n", url);
url
}