forked from scs/substrate-api-client
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample_event_callback.rs
executable file
·86 lines (73 loc) · 3.23 KB
/
example_event_callback.rs
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
80
81
82
83
84
85
86
/*
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.
*/
///! Very simple example that shows how to subscribe to events.
use std::sync::mpsc::channel;
use clap::{load_yaml, App};
use codec::Decode;
use log::{debug, error};
use sp_core::sr25519;
use sp_core::H256 as Hash;
// This module depends on node_runtime.
// To avoid dependency collisions, node_runtime has been removed from the substrate-api-client library.
// Replace this crate by your own if you run a custom substrate node to get your custom events.
use node_template_runtime::Event;
use substrate_api_client::utils::FromHexString;
use substrate_api_client::Api;
fn main() {
env_logger::init();
let url = get_node_url_from_cli();
let api = Api::<sr25519::Pair>::new(url).unwrap();
println!("Subscribe to events");
let (events_in, events_out) = channel();
api.subscribe_events(events_in).unwrap();
loop {
let event_str = events_out.recv().unwrap();
let _unhex = Vec::from_hex(event_str).unwrap();
let mut _er_enc = _unhex.as_slice();
let _events = Vec::<system::EventRecord<Event, Hash>>::decode(&mut _er_enc);
match _events {
Ok(evts) => {
for evr in &evts {
println!("decoded: {:?} {:?}", evr.phase, evr.event);
match &evr.event {
Event::pallet_balances(be) => {
println!(">>>>>>>>>> balances event: {:?}", be);
match &be {
balances::RawEvent::Transfer(transactor, dest, value) => {
println!("Transactor: {:?}", transactor);
println!("Destination: {:?}", dest);
println!("Value: {:?}", value);
return;
}
_ => {
debug!("ignoring unsupported balances event");
}
}
}
_ => debug!("ignoring unsupported module event: {:?}", evr.event),
}
}
}
Err(_) => error!("couldn't decode event record list"),
}
}
}
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("ws://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 {}", url);
url
}