/
tx_token.go
101 lines (81 loc) · 2.52 KB
/
tx_token.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
package txfeeder
import (
"context"
"github.com/Planxnx/defi-tx-kit/contract"
"github.com/Planxnx/defi-tx-kit/enums"
"github.com/Planxnx/defi-tx-kit/utils"
"github.com/ethereum/go-ethereum"
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/core/types"
"github.com/pkg/errors"
)
type TransferHandlers func(*contract.TokenTransfer) error
type ApprovalHandlers func(*contract.TokenApproval) error
func (t *TxFeeder) AddTransferLogsHandler(ctx context.Context, eventFilter ethereum.FilterQuery, handler TransferHandlers) error {
t.handlersLock.Lock()
defer t.handlersLock.Unlock()
eventFilter.Topics = [][]common.Hash{
{utils.TokenABI.Events[enums.TokenEventTransfer.ToString()].ID},
}
t.handlers = append(t.handlers, func() (ethereum.Subscription, error) {
txLogs := make(chan types.Log)
sub, err := t.client.SubscribeFilterLogs(ctx, eventFilter, txLogs)
if err != nil {
return nil, errors.Wrap(err, "Start subscribe error")
}
t.handlersWg.Add(1)
go func() {
defer t.handlersWg.Done()
for txLog := range txLogs {
t.handleTxLogs(txLog, func(txLog types.Log) error {
data, err := utils.TokenParseTransfer(txLog)
if err != nil {
return errors.Wrap(err, "Can't parse transfer logs data")
}
return handler(data)
})
}
}()
return sub, nil
})
if t.IsRunning() {
if err := t.run(t.handlers[len(t.handlers)-1]); err != nil {
return errors.Wrap(err, "Added handler can't start")
}
}
return nil
}
func (t *TxFeeder) AddApprovalLogsHandler(ctx context.Context, eventFilter ethereum.FilterQuery, handler ApprovalHandlers) error {
t.handlersLock.Lock()
defer t.handlersLock.Unlock()
eventFilter.Topics = [][]common.Hash{
{utils.TokenABI.Events[enums.TokenEventApproval.ToString()].ID},
}
t.handlers = append(t.handlers, func() (ethereum.Subscription, error) {
txLogs := make(chan types.Log)
sub, err := t.client.SubscribeFilterLogs(ctx, eventFilter, txLogs)
if err != nil {
return nil, errors.Wrap(err, "Start subscribe error")
}
t.handlersWg.Add(1)
go func() {
defer t.handlersWg.Done()
for txLog := range txLogs {
t.handleTxLogs(txLog, func(txLog types.Log) error {
data, err := utils.TokenParseApproval(txLog)
if err != nil {
return errors.Wrap(err, "Can't parse approval logs data")
}
return handler(data)
})
}
}()
return sub, nil
})
if t.IsRunning() {
if err := t.run(t.handlers[len(t.handlers)-1]); err != nil {
return errors.Wrap(err, "Added handler can't start")
}
}
return nil
}