forked from scs/substrate-api-client
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathevent_callback.rs
More file actions
72 lines (63 loc) · 2.36 KB
/
event_callback.rs
File metadata and controls
72 lines (63 loc) · 2.36 KB
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
/*
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 codec::Decode;
use kitchensink_runtime::Runtime;
use log::debug;
use sp_core::{sr25519, H256 as Hash};
use substrate_api_client::{
rpc::{HandleSubscription, JsonrpseeClient},
Api, PlainTipExtrinsicParams, SubscribeFrameSystem,
};
// 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 kitchensink_runtime::RuntimeEvent;
#[tokio::main]
async fn main() {
env_logger::init();
// Initialize the api.
let client = JsonrpseeClient::with_default_url().unwrap();
let api =
Api::<sr25519::Pair, _, PlainTipExtrinsicParams<Runtime>, Runtime>::new(client).unwrap();
println!("Subscribe to events");
let mut subscription = api.subscribe_system_events().unwrap();
// Wait for event callbacks from the node, which are received via subscription.
for _ in 0..5 {
let event_bytes = subscription.next().unwrap().unwrap().changes[0].1.clone().unwrap().0;
let events = Vec::<frame_system::EventRecord<RuntimeEvent, Hash>>::decode(
&mut event_bytes.as_slice(),
)
.unwrap();
for evr in &events {
println!("decoded: {:?} {:?}", evr.phase, evr.event);
match &evr.event {
RuntimeEvent::Balances(be) => {
println!(">>>>>>>>>> balances event: {:?}", be);
match &be {
pallet_balances::Event::Transfer { from, to, amount } => {
println!("Transactor: {:?}", from);
println!("Destination: {:?}", to);
println!("Value: {:?}", amount);
return
},
_ => {
debug!("ignoring unsupported balances event");
},
}
},
_ => debug!("ignoring unsupported module event: {:?}", evr.event),
}
}
}
}