-
Notifications
You must be signed in to change notification settings - Fork 36
/
Copy pathevent.go
118 lines (102 loc) · 3.11 KB
/
event.go
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
package scalecodec
import (
"fmt"
scaleType "github.com/itering/scale.go/types"
"github.com/itering/scale.go/types/scaleBytes"
"github.com/itering/scale.go/utiles"
)
type EventsDecoder struct {
scaleType.Vec
Metadata *scaleType.MetadataStruct
}
func (e *EventsDecoder) Init(data scaleBytes.ScaleBytes, option *scaleType.ScaleDecoderOption) {
if option.Metadata == nil {
panic("ExtrinsicDecoder option metadata required")
}
e.TypeString = "Vec<EventRecord>"
e.Metadata = option.Metadata
e.Vec.Init(data, option)
}
type EventParam struct {
Type string `json:"type"`
Name string `json:"name,omitempty"`
TypeName string `json:"type_name"`
Value interface{} `json:"value"`
}
func (e *EventsDecoder) Process() {
elementCount := e.ProcessAndUpdateData("Compact<u32>").(int)
er := EventRecord{Metadata: e.Metadata}
er.Data = e.Data
er.Spec = e.Spec
er.ScaleDecoder.Metadata = e.Metadata
var result []interface{}
for i := 0; i < elementCount; i++ {
element := er.Process()
element["event_idx"] = i
result = append(result, element)
}
e.Value = result
}
type EventRecord struct {
scaleType.ScaleDecoder
Metadata *scaleType.MetadataStruct
Phase int `json:"phase"`
ExtrinsicIdx int `json:"extrinsic_idx"`
Type string `json:"type"`
Params []EventParam `json:"params"`
Event scaleType.MetadataEvents `json:"event"`
Topic []string `json:"topic"`
ParamsRaw string `json:"params_raw"`
}
func (e *EventRecord) Process() map[string]interface{} {
e.Params = []EventParam{}
e.ExtrinsicIdx = 0
e.Topic = []string{}
e.Phase = e.GetNextU8()
// enum
// isApplyExtrinsic: bool;
// asApplyExtrinsic: u32;
// isFinalization: boolean;
// isInitialization: boolean;
if e.Phase == 0 {
e.ExtrinsicIdx = int(e.ProcessAndUpdateData("U32").(uint32))
}
e.Type = utiles.BytesToHex(e.NextBytes(2))
call, ok := e.Metadata.EventIndex[e.Type]
if !ok {
panic(fmt.Sprintf("Not find Event Lookup %s, please check metadata info", e.Type))
}
e.Event = call.Call
e.Module = call.Module.Name
offset := e.Data.Offset
for index, argType := range e.Event.Args {
value := e.ProcessAndUpdateData(argType)
param := EventParam{Type: argType, Value: value}
if len(e.Event.ArgsTypeName) == len(e.Event.Args) {
param.TypeName = e.Event.ArgsTypeName[index]
}
if len(e.Event.ArgsName) == len(e.Event.Args) {
param.Name = e.Event.ArgsName[index]
}
e.Params = append(e.Params, param)
}
e.ParamsRaw = utiles.BytesToHex(e.Data.Data[offset:e.Data.Offset])
if e.Metadata.MetadataVersion >= 5 {
if topic := e.ProcessAndUpdateData("Vec<Hash>"); topic != nil {
topicValue := topic.([]interface{})
for _, v := range topicValue {
e.Topic = append(e.Topic, v.(string))
}
}
}
return map[string]interface{}{
"phase": e.Phase,
"extrinsic_idx": e.ExtrinsicIdx,
"type": e.Type,
"module_id": call.Module.Name,
"event_id": e.Event.Name,
"params": e.Params,
"topic": e.Topic,
"params_raw": e.ParamsRaw,
}
}