-
Notifications
You must be signed in to change notification settings - Fork 1.7k
/
orm.go
111 lines (91 loc) · 3.04 KB
/
orm.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
package forwarders
import (
"database/sql"
"github.com/ethereum/go-ethereum/common"
"github.com/pkg/errors"
"github.com/smartcontractkit/sqlx"
"github.com/smartcontractkit/chainlink/core/logger"
"github.com/smartcontractkit/chainlink/core/services/pg"
"github.com/smartcontractkit/chainlink/core/utils"
)
type ORM interface {
CreateForwarder(addr common.Address, evmChainId utils.Big) (fwd Forwarder, err error)
FindForwarders(offset, limit int) ([]Forwarder, int, error)
FindForwardersByChain(evmChainId utils.Big) ([]Forwarder, error)
DeleteForwarder(id int32) error
FindForwardersInListByChain(evmChainId utils.Big, addrs []common.Address) ([]Forwarder, error)
}
type orm struct {
q pg.Q
}
var _ ORM = (*orm)(nil)
func NewORM(db *sqlx.DB, lggr logger.Logger, cfg pg.QConfig) *orm {
return &orm{pg.NewQ(db, lggr, cfg)}
}
// CreateForwarder creates the Forwarder address associated with the current EVM chain id.
func (o *orm) CreateForwarder(addr common.Address, evmChainId utils.Big) (fwd Forwarder, err error) {
sql := `INSERT INTO evm_forwarders (address, evm_chain_id, created_at, updated_at) VALUES ($1, $2, now(), now()) RETURNING *`
err = o.q.Get(&fwd, sql, addr, evmChainId)
return fwd, err
}
// DeleteForwarder removes a forwarder address.
func (o *orm) DeleteForwarder(id int32) error {
q := `DELETE FROM evm_forwarders WHERE id = $1`
result, err := o.q.Exec(q, id)
if err != nil {
return err
}
rowsAffected, err := result.RowsAffected()
if err != nil {
return err
}
if rowsAffected == 0 {
return sql.ErrNoRows
}
return nil
}
// FindForwarders returns all forwarder addresses from offset up until limit.
func (o *orm) FindForwarders(offset, limit int) (fwds []Forwarder, count int, err error) {
sql := `SELECT count(*) FROM evm_forwarders`
if err = o.q.Get(&count, sql); err != nil {
return
}
sql = `SELECT * FROM evm_forwarders ORDER BY created_at DESC, id DESC LIMIT $1 OFFSET $2`
if err = o.q.Select(&fwds, sql, limit, offset); err != nil {
return
}
return
}
// FindForwardersByChain returns all forwarder addresses for a chain.
func (o *orm) FindForwardersByChain(evmChainId utils.Big) (fwds []Forwarder, err error) {
sql := `SELECT * FROM evm_forwarders where evm_chain_id = $1 ORDER BY created_at DESC, id DESC`
err = o.q.Select(&fwds, sql, evmChainId)
return
}
func (o *orm) FindForwardersInListByChain(evmChainId utils.Big, addrs []common.Address) ([]Forwarder, error) {
var fwdrs []Forwarder
arg := map[string]interface{}{
"addresses": addrs,
"chainid": evmChainId,
}
query, args, err := sqlx.Named(`
SELECT * FROM evm_forwarders
WHERE evm_chain_id = :chainid
AND address IN (:addresses)
ORDER BY created_at DESC, id DESC`,
arg,
)
if err != nil {
return nil, errors.Wrap(err, "Failed to format query")
}
query, args, err = sqlx.In(query, args...)
if err != nil {
return nil, errors.Wrap(err, "Failed to run sqlx.IN on query")
}
query = o.q.Rebind(query)
err = o.q.Select(&fwdrs, query, args...)
if err != nil {
return nil, errors.Wrap(err, "Failed to execute query")
}
return fwdrs, nil
}