forked from scs/substrate-api-client
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathevent_callback.rs
78 lines (68 loc) · 2.69 KB
/
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
/*
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.
*/
//! Example that shows how to subscribe to events and do some action
//! upon encounterign them.
use log::debug;
use sp_core::H256 as Hash;
use substrate_api_client::{rpc::JsonrpseeClient, Api, PlainTipExtrinsicParams, SubscribeEvents};
// This module depends on the specific node runtime.
// Replace this crate by your own if you run a custom substrate node to get your custom events.
use kitchensink_runtime::{Runtime, RuntimeEvent};
#[tokio::main]
async fn main() {
env_logger::init();
// Initialize the api.
let client = JsonrpseeClient::with_default_url().unwrap();
let api = Api::<(), _, PlainTipExtrinsicParams<Runtime>, Runtime>::new(client).unwrap();
println!("Subscribe to events");
let mut subscription = api.subscribe_events().unwrap();
// Wait for event callbacks from the node, which are received via subscription.
for _ in 0..5 {
let event_records = subscription.next_event::<RuntimeEvent, Hash>().unwrap().unwrap();
for event_record in &event_records {
println!("decoded: {:?} {:?}", event_record.phase, event_record.event);
match &event_record.event {
RuntimeEvent::Balances(balances_event) => {
println!(">>>>>>>>>> balances event: {:?}", balances_event);
match &balances_event {
pallet_balances::Event::Transfer { from, to, amount } => {
println!("Transactor: {:?}", from);
println!("Destination: {:?}", to);
println!("Value: {:?}", amount);
return
},
_ => {
debug!("ignoring unsupported balances event");
},
}
},
RuntimeEvent::System(system_event) => {
println!(">>>>>>>>>> system event: {:?}", system_event);
match &system_event {
frame_system::Event::ExtrinsicSuccess { dispatch_info } => {
println!("DispatchInfo: {:?}", dispatch_info);
return
},
_ => {
debug!("ignoring unsupported system event");
},
}
},
_ => debug!("ignoring unsupported module event: {:?}", event_record.event),
}
}
}
// After we finished whatever we wanted, unusubscribe from the subscription,
// to ensure, that the node does not keep sending us events.
subscription.unsubscribe().unwrap();
}