-
Notifications
You must be signed in to change notification settings - Fork 22
/
staking.go
82 lines (69 loc) · 2.67 KB
/
staking.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
// Copyright (c) 2022 Gobalsky Labs Limited
//
// Use of this software is governed by the Business Source License included
// in the LICENSE.VEGA file and at https://www.mariadb.com/bsl11.
//
// Change Date: 18 months from the later of the date of the first publicly
// available Distribution of this version of the repository, and 25 June 2022.
//
// On the date above, in accordance with the Business Source License, use
// of this software will be governed by version 3 or later of the GNU General
// Public License.
package staking
import (
"context"
"fmt"
"math/big"
"code.vegaprotocol.io/vega/core/netparams"
"code.vegaprotocol.io/vega/core/types"
"code.vegaprotocol.io/vega/logging"
ethtypes "github.com/ethereum/go-ethereum/core/types"
)
type AllEthereumClient interface {
EthereumClient
EthereumClientConfirmations
EthereumClientCaller
}
//go:generate go run github.com/golang/mock/mockgen -destination mocks/ethereum_client_confirmations_mock.go -package mocks code.vegaprotocol.io/vega/core/staking EthereumClientConfirmations
type EthereumClientConfirmations interface {
HeaderByNumber(context.Context, *big.Int) (*ethtypes.Header, error)
}
//go:generate go run github.com/golang/mock/mockgen -destination mocks/ethereum_event_source_mock.go -package mocks code.vegaprotocol.io/vega/core/staking EthereumEventSource
type EthereumEventSource interface {
UpdateStakingStartingBlock(uint64)
}
func New(
log *logging.Logger,
cfg Config,
ts TimeService,
broker Broker,
witness Witness,
ethClient AllEthereumClient,
netp *netparams.Store,
evtFwd EvtForwarder,
isValidator bool,
ethCfns EthConfirmations,
ethEventSource EthereumEventSource,
) (*Accounting, *StakeVerifier, *Checkpoint) {
log = log.Named(namedLogger)
log.SetLevel(cfg.Level.Get())
accs := NewAccounting(log, cfg, ts, broker, ethClient, evtFwd, witness, isValidator)
ocv := NewOnChainVerifier(cfg, log, ethClient, ethCfns)
stakeV := NewStakeVerifier(log, cfg, accs, witness, ts, broker, ocv, ethEventSource)
_ = netp.Watch(netparams.WatchParam{
Param: netparams.BlockchainsEthereumConfig,
Watcher: func(_ context.Context, cfg interface{}) error {
ethCfg, err := types.EthereumConfigFromUntypedProto(cfg)
if err != nil {
return fmt.Errorf("staking didn't receive a valid Ethereum configuration: %w", err)
}
ocv.UpdateStakingBridgeAddresses(ethCfg.StakingBridgeAddresses())
// We just need one of the staking bridges.
if err := accs.UpdateStakingBridgeAddress(ethCfg.StakingBridgeAddresses()[0]); err != nil {
return fmt.Errorf("couldn't update Ethereum configuration in accounting: %w", err)
}
return nil
},
})
return accs, stakeV, NewCheckpoint(log, accs, stakeV, ethEventSource)
}