-
Notifications
You must be signed in to change notification settings - Fork 22
/
protocol_upgrade.go
58 lines (48 loc) · 1.68 KB
/
protocol_upgrade.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
package service
import (
"context"
"sync/atomic"
"code.vegaprotocol.io/vega/datanode/entities"
"code.vegaprotocol.io/vega/logging"
)
type pupStore interface {
Add(ctx context.Context, p entities.ProtocolUpgradeProposal) error
List(ctx context.Context,
status *entities.ProtocolUpgradeProposalStatus,
approvedBy *string,
pagination entities.CursorPagination,
) ([]entities.ProtocolUpgradeProposal, entities.PageInfo, error)
GetByTxHash(ctx context.Context, txHash entities.TxHash) ([]entities.ProtocolUpgradeProposal, error)
}
type ProtocolUpgrade struct {
pupStore pupStore
// Flag update needs to be visible across threads
upgradeStarted atomic.Bool
log *logging.Logger
}
func NewProtocolUpgrade(pupStore pupStore, log *logging.Logger) *ProtocolUpgrade {
return &ProtocolUpgrade{
pupStore: pupStore,
log: log,
}
}
func (p *ProtocolUpgrade) GetProtocolUpgradeStarted() bool {
return p.upgradeStarted.Load()
}
func (p *ProtocolUpgrade) SetProtocolUpgradeStarted() {
p.log.Info("datanode is ready for protocol upgrade")
p.upgradeStarted.Store(true)
}
func (p *ProtocolUpgrade) AddProposal(ctx context.Context, pup entities.ProtocolUpgradeProposal) error {
return p.pupStore.Add(ctx, pup)
}
func (p *ProtocolUpgrade) ListProposals(ctx context.Context,
status *entities.ProtocolUpgradeProposalStatus,
approvedBy *string,
pagination entities.CursorPagination,
) ([]entities.ProtocolUpgradeProposal, entities.PageInfo, error) {
return p.pupStore.List(ctx, status, approvedBy, pagination)
}
func (p *ProtocolUpgrade) GetByTxHash(ctx context.Context, txHash entities.TxHash) ([]entities.ProtocolUpgradeProposal, error) {
return p.pupStore.GetByTxHash(ctx, txHash)
}