|
|
|
package core
|
|
|
|
|
|
|
|
import (
|
|
|
|
"math/big"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
|
|
"github.com/ethereum/go-ethereum/ethdb"
|
|
|
|
"github.com/ethereum/go-ethereum/event"
|
|
|
|
"github.com/harmony-one/harmony/block"
|
|
|
|
"github.com/harmony-one/harmony/consensus/engine"
|
|
|
|
"github.com/harmony-one/harmony/consensus/reward"
|
|
|
|
"github.com/harmony-one/harmony/core/rawdb"
|
|
|
|
"github.com/harmony-one/harmony/core/state"
|
|
|
|
"github.com/harmony-one/harmony/core/types"
|
|
|
|
"github.com/harmony-one/harmony/core/vm"
|
Mainnet Release Candidate 2023.1.2 (#4376)
* remove default timeouts
* store the evm call timeout in rosetta object
* [cmd] actually apply ToRPCServerConfig
* Removed unused method.
* Rotate external leaders on non-beacon chains.
* Fix nil panic.
* Bump github.com/aws/aws-sdk-go from 1.33.0 to 1.34.0
Bumps [github.com/aws/aws-sdk-go](https://github.com/aws/aws-sdk-go) from 1.33.0 to 1.34.0.
- [Release notes](https://github.com/aws/aws-sdk-go/releases)
- [Changelog](https://github.com/aws/aws-sdk-go/blob/v1.34.0/CHANGELOG.md)
- [Commits](https://github.com/aws/aws-sdk-go/compare/v1.33.0...v1.34.0)
---
updated-dependencies:
- dependency-name: github.com/aws/aws-sdk-go
dependency-type: direct:production
...
Signed-off-by: dependabot[bot] <support@github.com>
* Bump github.com/ipld/go-ipld-prime from 0.9.0 to 0.19.0
Bumps [github.com/ipld/go-ipld-prime](https://github.com/ipld/go-ipld-prime) from 0.9.0 to 0.19.0.
- [Release notes](https://github.com/ipld/go-ipld-prime/releases)
- [Changelog](https://github.com/ipld/go-ipld-prime/blob/master/CHANGELOG.md)
- [Commits](https://github.com/ipld/go-ipld-prime/compare/v0.9.0...v0.19.0)
---
updated-dependencies:
- dependency-name: github.com/ipld/go-ipld-prime
dependency-type: indirect
...
Signed-off-by: dependabot[bot] <support@github.com>
* Bump golang.org/x/net from 0.3.0 to 0.7.0
Bumps [golang.org/x/net](https://github.com/golang/net) from 0.3.0 to 0.7.0.
- [Release notes](https://github.com/golang/net/releases)
- [Commits](https://github.com/golang/net/compare/v0.3.0...v0.7.0)
---
updated-dependencies:
- dependency-name: golang.org/x/net
dependency-type: indirect
...
Signed-off-by: dependabot[bot] <support@github.com>
* Small fixes.
* in progress.
* in progress.
* in progress.
* consensus check is forked
* update master
* fix leader
* check leader for N blocks
* fix
* fix
* Cleanup and fix update pub keys.
* Rotate leader.
* fix
fix
fix
fix
fix
* Cleaned.
* Cache for `GetLeaderPubKeyFromCoinbase`, removed `NthNextHmyExt`.
* activate epoch
* comment activation
* 295 epoch
* Fix failed tests.
* Fixed code review.
* Fix review "--port flag".
* Fix review comments.
* Returned locks in rotateLeader.
* Rebased onto dev.
* Commented golangci.
* staged stream sync v1.0
* fix protocol tests
* fix spell
* remove unused struct
* fix rosetta test
* add comments and refactor verify sig
* add comments, remove extra function
* add comment
* refactor errors, rename metrics
* refactor p2p host creation
* fix initsync and host creation
* fix short range hash chain
* fix beacon node detection for p2p protocol
* refactor stream peer cooldown and fix protocol beacon node field
* refactor p2p host and routing
* fix p2p discovery test issue
* add MaxAdvertiseWaitTime to handle advertisements interval and address stream connection issue
* terminal print the peer id and proto id
* fix boot complete message when node is shut down
* add new config option ( ForceReachabilityPublic ) to fix local-net consensus issue
* fix self query issue
* fix test NewDNSSyncingPeerProvider
* [testnet] disable leader rotation
* fix discovery issue for legacy sync
* add watermark low/high options for p2p connection manager
* add test for new conn manager flags
* fix dedent
* add comment to inform about p2p connection manager options
* fix max height issue
* add a separate log for get max height error
* fix log
* feat: triesInMemory flag
* fix: panic if TriesInMemory is 1 to 2
* in progress.
* consensus check is forked
* fix
* Cleanup and fix update pub keys.
* fix
fix
fix
fix
fix
* activate epoch
* EpochTBD for leader rotation epoch.
* 295 epoch
* Decider no longer requires public keys as a dependency. (#4289)
* Consensus doesn't require anymore `Node` as a circular dependency.
* Proper blockchain initialization.
* Rwlock consensus.
* Removed channels.
* Removed view change locks.
* Removed timers locks.
* Removed fbft locks.
* Removed multiSigMutex locks.
* Removed leader locks.
* Removed additional locks and isViewChange.
* Added locks detected by race.
* Added locks detected by race.
* Locks for start.
* Removed additional logs.
* Removed additional locks.
* Removed additional locks.
* Make func private.
* Make VerifyBlock private.
* Make IsLeader private.
* Make ParseFBFTMessage private.
* Fix remove locks.
* Added additional locks.
* Added additional locks.
* Added readSignatureBitmapPayload locks.
* Added HandleMessageUpdate locks.
* Added LastMile locks.
* Locks for IsValidatorInCommittee.
* Fixed locks.
* Fixed tests.
* Fixed tests.
* Fixed lock.
* Rebased over leader rotation.
* Fix formatting.
* Rebased onto dev.
* in progress.
* consensus check is forked
* update master
* fix leader
* check leader for N blocks
* fix
* fix
* Cleanup and fix update pub keys.
* Rotate leader.
* fix
fix
fix
fix
fix
* Cleaned.
* Cache for `GetLeaderPubKeyFromCoinbase`, removed `NthNextHmyExt`.
* comment activation
* 295 epoch
* Fix failed tests.
* Fixed code review.
* Fix review comments.
* Merged leader rotation.
* Rebased on dev.
* Rebased on dev.
* Fix usage of private methods.
* Fix usage of private methods.
* Fix usage of private methods.
* Removed deadcode, LockedFBFTPhase.
* Fix review comment.
* Fix review comment.
* Go mod tidy.
* Set to EpochTBD.
* Fix tests.
* [core] fix state handling of self destruct
If a contract self destructs to self and then receives funds within the
same transaction, it is possible for its stale state to be saved. This
change removes that possibility by checking for deleted state objects
before returning them.
* Fixed race error.
* rpc: add configurable http and `eth_call` timeout
* remove default timeouts
* store the evm call timeout in rosetta object
* [cmd] actually apply ToRPCServerConfig
* Removed unused method.
* Rotate external leaders on non-beacon chains.
* Fix nil panic.
* in progress.
* in progress.
* in progress.
* consensus check is forked
* update master
* fix leader
* check leader for N blocks
* fix
* fix
* Cleanup and fix update pub keys.
* Rotate leader.
* fix
fix
fix
fix
fix
* Cleaned.
* Cache for `GetLeaderPubKeyFromCoinbase`, removed `NthNextHmyExt`.
* Fixed code review.
* Fix review comments.
* Returned locks in rotateLeader.
* Rebased onto dev.
* staged stream sync v1.0
* refactor errors, rename metrics
* fix p2p discovery test issue
* add watermark low/high options for p2p connection manager
* fix dedent
* in progress.
* consensus check is forked
* fix
* Cleanup and fix update pub keys.
* fix
fix
fix
fix
fix
* activate epoch
* EpochTBD for leader rotation epoch.
* 295 epoch
* Decider no longer requires public keys as a dependency. (#4289)
* Consensus doesn't require anymore `Node` as a circular dependency.
* Proper blockchain initialization.
* Rwlock consensus.
* Removed channels.
* Removed view change locks.
* Removed multiSigMutex locks.
* Removed leader locks.
* Removed additional locks and isViewChange.
* Added locks detected by race.
* Added locks detected by race.
* Locks for start.
* Removed additional locks.
* Removed additional locks.
* Make func private.
* Make VerifyBlock private.
* Make IsLeader private.
* Make ParseFBFTMessage private.
* Fix remove locks.
* Added additional locks.
* Added additional locks.
* Added readSignatureBitmapPayload locks.
* Added HandleMessageUpdate locks.
* Added LastMile locks.
* Locks for IsValidatorInCommittee.
* Fixed locks.
* Fixed tests.
* Fixed lock.
* Rebased over leader rotation.
* in progress.
* consensus check is forked
* update master
* fix leader
* check leader for N blocks
* fix
* fix
* Cleanup and fix update pub keys.
* Rotate leader.
* fix
fix
fix
fix
fix
* Cleaned.
* Cache for `GetLeaderPubKeyFromCoinbase`, removed `NthNextHmyExt`.
* Fix failed tests.
* Fixed code review.
* Fix review comments.
* Merged leader rotation.
* Rebased on dev.
* Rebased on dev.
* Fix usage of private methods.
* Fix usage of private methods.
* Fix usage of private methods.
* Removed deadcode, LockedFBFTPhase.
* Fix review comment.
* Go mod tidy.
* remove default timeouts
* Rotate external leaders on non-beacon chains.
* Fix nil panic.
* Fixes.
* Update singleton.go
* evm: don't return extcode for validators
Due to technical debt, validator information is stored in the code field
of the address. The code field can be accessed in Solidity for an
arbitrary address using `extcodesize`, `extcodehash`, and `extcodecopy`
or helper commands (such as `address.code.Length`). The presence of this
field is used by contract developers to (erroneously) deny smart
contract access to other smart contracts (and therefore, validators).
This PR fixes that oversight by returning the same values as other EOAs
for known validator addresses. Obviously, it needs a hard fork that will
be scheduled separately.
* Fix context passing.
* Clean up code.
* Removed engine dependency.
* Fix possible panic.
* Clean up code.
* Network type.
* Fix tests.
* Revert "Removed engine dependency." (#4392)
* Revert "Fix tests."
This reverts commit 597ba2d6f1ed54ff599b9d9b8940c7285ab1277a.
* Revert "Network type."
This reverts commit 5e1878aedca3989dc0f34161dae1833e43ca6a76.
* Revert "Clean up code."
This reverts commit 15885f4c9b9263746827172b4f4f56d0926d18e2.
* Revert "Fix possible panic."
This reverts commit 1a70d5eb66cdbf8a23791806b71a323eed320085.
* Revert "Removed engine dependency."
This reverts commit 8c2ff803f709f944cfc8b1278f35cf5b2cacf859.
* gitignore the cache folder (#4389)
* stable localnet with external validator (#4388)
* stable localnet with external validator
* ignore deploy config file comments
* reduce node launched in localnet
* update makefile
* localnet configuration - add more fn
* fix validator information command typo
---------
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: MaxMustermann2 <82761650+MaxMustermann2@users.noreply.github.com>
Co-authored-by: frozen <355847+Frozen@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: “GheisMohammadi” <“Gheis.Mohammadi@gmail.com”>
Co-authored-by: “GheisMohammadi” <36589218+GheisMohammadi@users.noreply.github.com>
Co-authored-by: Sun Hyuk Ahn <sunhyukahn@Suns-MacBook-Pro.local>
Co-authored-by: Soph <35721420+sophoah@users.noreply.github.com>
2 years ago
|
|
|
"github.com/harmony-one/harmony/crypto/bls"
|
|
|
|
harmonyconfig "github.com/harmony-one/harmony/internal/configs/harmony"
|
|
|
|
"github.com/harmony-one/harmony/internal/params"
|
|
|
|
"github.com/harmony-one/harmony/internal/tikv/redis_helper"
|
|
|
|
"github.com/harmony-one/harmony/shard"
|
|
|
|
"github.com/harmony-one/harmony/staking/slash"
|
|
|
|
staking "github.com/harmony-one/harmony/staking/types"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Smoke test.
|
|
|
|
var _ BlockChain = Stub{}
|
|
|
|
|
|
|
|
type Stub struct {
|
|
|
|
Name string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ValidateNewBlock(block *types.Block, beaconChain BlockChain) error {
|
|
|
|
return errors.Errorf("method ValidateNewBlock not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) SetHead(head uint64) error {
|
|
|
|
return errors.Errorf("method SetHead not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ShardID() uint32 {
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) CurrentBlock() *types.Block {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) Validator() Validator {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) Processor() Processor {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) State() (*state.DB, error) {
|
|
|
|
return nil, errors.Errorf("method State not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) StateAt(common.Hash) (*state.DB, error) {
|
|
|
|
return nil, errors.Errorf("method StateAt not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) HasBlock(hash common.Hash, number uint64) bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) HasState(hash common.Hash) bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) HasBlockAndState(hash common.Hash, number uint64) bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetBlock(hash common.Hash, number uint64) *types.Block {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetBlockByHash(hash common.Hash) *types.Block {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetBlockByNumber(number uint64) *types.Block {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetReceiptsByHash(hash common.Hash) types.Receipts {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) Stop() {
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) Rollback(chain []common.Hash) error {
|
|
|
|
return errors.Errorf("method Rollback not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteBlockWithoutState(block *types.Block, td *big.Int) (err error) {
|
|
|
|
return errors.Errorf("method WriteBlockWithoutState not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteBlockWithState(block *types.Block, receipts []*types.Receipt, cxReceipts []*types.CXReceipt, stakeMsgs []staking.StakeMsg, paid reward.Reader, state *state.DB) (status WriteStatus, err error) {
|
|
|
|
return 0, errors.Errorf("method WriteBlockWithState not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetMaxGarbageCollectedBlockNumber() int64 {
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) InsertChain(chain types.Blocks, verifyHeaders bool) (int, error) {
|
|
|
|
return 0, errors.Errorf("method InsertChain not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) BadBlocks() []BadBlock {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) CurrentHeader() *block.Header {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetHeader(hash common.Hash, number uint64) *block.Header {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetHeaderByHash(hash common.Hash) *block.Header {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetCanonicalHash(number uint64) common.Hash {
|
|
|
|
return common.Hash{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetHeaderByNumber(number uint64) *block.Header {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) Config() *params.ChainConfig {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) Engine() engine.Engine {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) SubscribeRemovedLogsEvent(ch chan<- RemovedLogsEvent) event.Subscription {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) SubscribeTraceEvent(ch chan<- TraceEvent) event.Subscription {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) SubscribeChainEvent(ch chan<- ChainEvent) event.Subscription {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) SubscribeChainHeadEvent(ch chan<- ChainHeadEvent) event.Subscription {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) SubscribeChainSideEvent(ch chan<- ChainSideEvent) event.Subscription {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) SubscribeLogsEvent(ch chan<- []*types.Log) event.Subscription {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadShardState(epoch *big.Int) (*shard.State, error) {
|
|
|
|
return nil, errors.Errorf("method ReadShardState not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteShardStateBytes(db rawdb.DatabaseWriter, epoch *big.Int, shardState []byte) (*shard.State, error) {
|
|
|
|
return nil, errors.Errorf("method WriteShardStateBytes not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteHeadBlock(block *types.Block) error {
|
|
|
|
return errors.Errorf("method WriteHeadBlock not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadCommitSig(blockNum uint64) ([]byte, error) {
|
|
|
|
return nil, errors.Errorf("method ReadCommitSig not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteCommitSig(blockNum uint64, lastCommits []byte) error {
|
|
|
|
return errors.Errorf("method WriteCommitSig not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetVdfByNumber(number uint64) []byte {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetVrfByNumber(number uint64) []byte {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ChainDb() ethdb.Database {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetEpochBlockNumber(epoch *big.Int) (*big.Int, error) {
|
|
|
|
return nil, errors.Errorf("method GetEpochBlockNumber not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) StoreEpochBlockNumber(epoch *big.Int, blockNum *big.Int) error {
|
|
|
|
return errors.Errorf("method StoreEpochBlockNumber not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadEpochVrfBlockNums(epoch *big.Int) ([]uint64, error) {
|
|
|
|
return nil, errors.Errorf("method ReadEpochVrfBlockNums not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteEpochVrfBlockNums(epoch *big.Int, vrfNumbers []uint64) error {
|
|
|
|
return errors.Errorf("method WriteEpochVrfBlockNums not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadEpochVdfBlockNum(epoch *big.Int) (*big.Int, error) {
|
|
|
|
return nil, errors.Errorf("method ReadEpochVdfBlockNum not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteEpochVdfBlockNum(epoch *big.Int, blockNum *big.Int) error {
|
|
|
|
return errors.Errorf("method WriteEpochVdfBlockNum not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteCrossLinks(batch rawdb.DatabaseWriter, cls []types.CrossLink) error {
|
|
|
|
return errors.Errorf("method WriteCrossLinks not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) DeleteCrossLinks(cls []types.CrossLink) error {
|
|
|
|
return errors.Errorf("method DeleteCrossLinks not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadCrossLink(shardID uint32, blockNum uint64) (*types.CrossLink, error) {
|
|
|
|
return nil, errors.Errorf("method ReadCrossLink not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) LastContinuousCrossLink(batch rawdb.DatabaseWriter, shardID uint32) error {
|
|
|
|
return errors.Errorf("method LastContinuousCrossLink not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadShardLastCrossLink(shardID uint32) (*types.CrossLink, error) {
|
|
|
|
return nil, errors.Errorf("method ReadShardLastCrossLink not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) DeleteFromPendingSlashingCandidates(processed slash.Records) error {
|
|
|
|
return errors.Errorf("method DeleteFromPendingSlashingCandidates not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadPendingSlashingCandidates() slash.Records {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadPendingCrossLinks() ([]types.CrossLink, error) {
|
|
|
|
return nil, errors.Errorf("method ReadPendingCrossLinks not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) CachePendingCrossLinks(crossLinks []types.CrossLink) error {
|
|
|
|
return errors.Errorf("method CachePendingCrossLinks not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) SavePendingCrossLinks() error {
|
|
|
|
return errors.Errorf("method SavePendingCrossLinks not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) AddPendingSlashingCandidates(candidates slash.Records) error {
|
|
|
|
return errors.Errorf("method AddPendingSlashingCandidates not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) AddPendingCrossLinks(pendingCLs []types.CrossLink) (int, error) {
|
|
|
|
return 0, errors.Errorf("method AddPendingCrossLinks not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) DeleteFromPendingCrossLinks(crossLinks []types.CrossLink) (int, error) {
|
|
|
|
return 0, errors.Errorf("method DeleteFromPendingCrossLinks not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) IsSameLeaderAsPreviousBlock(block *types.Block) bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetVMConfig() *vm.Config {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadCXReceipts(shardID uint32, blockNum uint64, blockHash common.Hash) (types.CXReceipts, error) {
|
|
|
|
return nil, errors.Errorf("method ReadCXReceipts not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) CXMerkleProof(toShardID uint32, block *types.Block) (*types.CXMerkleProof, error) {
|
|
|
|
return nil, errors.Errorf("method CXMerkleProof not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteCXReceiptsProofSpent(db rawdb.DatabaseWriter, cxps []*types.CXReceiptsProof) error {
|
|
|
|
return errors.Errorf("method WriteCXReceiptsProofSpent not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) IsSpent(cxp *types.CXReceiptsProof) bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadTxLookupEntry(txID common.Hash) (common.Hash, uint64, uint64) {
|
|
|
|
return common.Hash{}, 0, 0
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadValidatorInformationAtRoot(addr common.Address, root common.Hash) (*staking.ValidatorWrapper, error) {
|
|
|
|
return nil, errors.Errorf("method ReadValidatorInformationAtRoot not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadValidatorInformationAtState(addr common.Address, state *state.DB) (*staking.ValidatorWrapper, error) {
|
|
|
|
return nil, errors.Errorf("method ReadValidatorInformationAtState not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadValidatorInformation(addr common.Address) (*staking.ValidatorWrapper, error) {
|
|
|
|
return nil, errors.Errorf("method ReadValidatorInformation not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadValidatorSnapshotAtEpoch(epoch *big.Int, addr common.Address) (*staking.ValidatorSnapshot, error) {
|
|
|
|
return nil, errors.Errorf("method ReadValidatorSnapshotAtEpoch not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadValidatorSnapshot(addr common.Address) (*staking.ValidatorSnapshot, error) {
|
|
|
|
return nil, errors.Errorf("method ReadValidatorSnapshot not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteValidatorSnapshot(batch rawdb.DatabaseWriter, snapshot *staking.ValidatorSnapshot) error {
|
|
|
|
return errors.Errorf("method WriteValidatorSnapshot not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadValidatorStats(addr common.Address) (*staking.ValidatorStats, error) {
|
|
|
|
return nil, errors.Errorf("method ReadValidatorStats not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) UpdateValidatorVotingPower(batch rawdb.DatabaseWriter, block *types.Block, newEpochSuperCommittee, currentEpochSuperCommittee *shard.State, state *state.DB) (map[common.Address]*staking.ValidatorStats, error) {
|
|
|
|
return nil, errors.Errorf("method UpdateValidatorVotingPower not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ComputeAndUpdateAPR(block *types.Block, now *big.Int, wrapper *staking.ValidatorWrapper, stats *staking.ValidatorStats) error {
|
|
|
|
return errors.Errorf("method ComputeAndUpdateAPR not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) UpdateValidatorSnapshots(batch rawdb.DatabaseWriter, epoch *big.Int, state *state.DB, newValidators []common.Address) error {
|
|
|
|
return errors.Errorf("method UpdateValidatorSnapshots not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadValidatorList() ([]common.Address, error) {
|
|
|
|
return nil, errors.Errorf("method ReadValidatorList not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteValidatorList(db rawdb.DatabaseWriter, addrs []common.Address) error {
|
|
|
|
return errors.Errorf("method WriteValidatorList not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadDelegationsByDelegator(delegator common.Address) (m staking.DelegationIndexes, err error) {
|
|
|
|
return nil, errors.Errorf("method ReadDelegationsByDelegator not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadDelegationsByDelegatorAt(delegator common.Address, blockNum *big.Int) (m staking.DelegationIndexes, err error) {
|
|
|
|
return nil, errors.Errorf("method ReadDelegationsByDelegatorAt not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) UpdateStakingMetaData(batch rawdb.DatabaseWriter, block *types.Block, stakeMsgs []staking.StakeMsg, state *state.DB, epoch, newEpoch *big.Int) (newValidators []common.Address, err error) {
|
|
|
|
return nil, errors.Errorf("method UpdateStakingMetaData not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ReadBlockRewardAccumulator(number uint64) (*big.Int, error) {
|
|
|
|
return nil, errors.Errorf("method ReadBlockRewardAccumulator not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) WriteBlockRewardAccumulator(batch rawdb.DatabaseWriter, reward *big.Int, number uint64) error {
|
|
|
|
return errors.Errorf("method WriteBlockRewardAccumulator not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) UpdateBlockRewardAccumulator(batch rawdb.DatabaseWriter, diff *big.Int, number uint64) error {
|
|
|
|
return errors.Errorf("method UpdateBlockRewardAccumulator not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) ValidatorCandidates() []common.Address {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) DelegatorsInformation(addr common.Address) []*staking.Delegation {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) GetECDSAFromCoinbase(header *block.Header) (common.Address, error) {
|
|
|
|
return common.Address{}, errors.Errorf("method GetECDSAFromCoinbase not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) SuperCommitteeForNextEpoch(beacon engine.ChainReader, header *block.Header, isVerify bool) (*shard.State, error) {
|
|
|
|
return nil, errors.Errorf("method SuperCommitteeForNextEpoch not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) EnablePruneBeaconChainFeature() {
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) IsEnablePruneBeaconChainFeature() bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) CommitOffChainData(batch rawdb.DatabaseWriter, block *types.Block, receipts []*types.Receipt, cxReceipts []*types.CXReceipt, stakeMsgs []staking.StakeMsg, payout reward.Reader, state *state.DB) (status WriteStatus, err error) {
|
|
|
|
return 0, errors.Errorf("method CommitOffChainData not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
Mainnet Release Candidate 2023.1.2 (#4376)
* remove default timeouts
* store the evm call timeout in rosetta object
* [cmd] actually apply ToRPCServerConfig
* Removed unused method.
* Rotate external leaders on non-beacon chains.
* Fix nil panic.
* Bump github.com/aws/aws-sdk-go from 1.33.0 to 1.34.0
Bumps [github.com/aws/aws-sdk-go](https://github.com/aws/aws-sdk-go) from 1.33.0 to 1.34.0.
- [Release notes](https://github.com/aws/aws-sdk-go/releases)
- [Changelog](https://github.com/aws/aws-sdk-go/blob/v1.34.0/CHANGELOG.md)
- [Commits](https://github.com/aws/aws-sdk-go/compare/v1.33.0...v1.34.0)
---
updated-dependencies:
- dependency-name: github.com/aws/aws-sdk-go
dependency-type: direct:production
...
Signed-off-by: dependabot[bot] <support@github.com>
* Bump github.com/ipld/go-ipld-prime from 0.9.0 to 0.19.0
Bumps [github.com/ipld/go-ipld-prime](https://github.com/ipld/go-ipld-prime) from 0.9.0 to 0.19.0.
- [Release notes](https://github.com/ipld/go-ipld-prime/releases)
- [Changelog](https://github.com/ipld/go-ipld-prime/blob/master/CHANGELOG.md)
- [Commits](https://github.com/ipld/go-ipld-prime/compare/v0.9.0...v0.19.0)
---
updated-dependencies:
- dependency-name: github.com/ipld/go-ipld-prime
dependency-type: indirect
...
Signed-off-by: dependabot[bot] <support@github.com>
* Bump golang.org/x/net from 0.3.0 to 0.7.0
Bumps [golang.org/x/net](https://github.com/golang/net) from 0.3.0 to 0.7.0.
- [Release notes](https://github.com/golang/net/releases)
- [Commits](https://github.com/golang/net/compare/v0.3.0...v0.7.0)
---
updated-dependencies:
- dependency-name: golang.org/x/net
dependency-type: indirect
...
Signed-off-by: dependabot[bot] <support@github.com>
* Small fixes.
* in progress.
* in progress.
* in progress.
* consensus check is forked
* update master
* fix leader
* check leader for N blocks
* fix
* fix
* Cleanup and fix update pub keys.
* Rotate leader.
* fix
fix
fix
fix
fix
* Cleaned.
* Cache for `GetLeaderPubKeyFromCoinbase`, removed `NthNextHmyExt`.
* activate epoch
* comment activation
* 295 epoch
* Fix failed tests.
* Fixed code review.
* Fix review "--port flag".
* Fix review comments.
* Returned locks in rotateLeader.
* Rebased onto dev.
* Commented golangci.
* staged stream sync v1.0
* fix protocol tests
* fix spell
* remove unused struct
* fix rosetta test
* add comments and refactor verify sig
* add comments, remove extra function
* add comment
* refactor errors, rename metrics
* refactor p2p host creation
* fix initsync and host creation
* fix short range hash chain
* fix beacon node detection for p2p protocol
* refactor stream peer cooldown and fix protocol beacon node field
* refactor p2p host and routing
* fix p2p discovery test issue
* add MaxAdvertiseWaitTime to handle advertisements interval and address stream connection issue
* terminal print the peer id and proto id
* fix boot complete message when node is shut down
* add new config option ( ForceReachabilityPublic ) to fix local-net consensus issue
* fix self query issue
* fix test NewDNSSyncingPeerProvider
* [testnet] disable leader rotation
* fix discovery issue for legacy sync
* add watermark low/high options for p2p connection manager
* add test for new conn manager flags
* fix dedent
* add comment to inform about p2p connection manager options
* fix max height issue
* add a separate log for get max height error
* fix log
* feat: triesInMemory flag
* fix: panic if TriesInMemory is 1 to 2
* in progress.
* consensus check is forked
* fix
* Cleanup and fix update pub keys.
* fix
fix
fix
fix
fix
* activate epoch
* EpochTBD for leader rotation epoch.
* 295 epoch
* Decider no longer requires public keys as a dependency. (#4289)
* Consensus doesn't require anymore `Node` as a circular dependency.
* Proper blockchain initialization.
* Rwlock consensus.
* Removed channels.
* Removed view change locks.
* Removed timers locks.
* Removed fbft locks.
* Removed multiSigMutex locks.
* Removed leader locks.
* Removed additional locks and isViewChange.
* Added locks detected by race.
* Added locks detected by race.
* Locks for start.
* Removed additional logs.
* Removed additional locks.
* Removed additional locks.
* Make func private.
* Make VerifyBlock private.
* Make IsLeader private.
* Make ParseFBFTMessage private.
* Fix remove locks.
* Added additional locks.
* Added additional locks.
* Added readSignatureBitmapPayload locks.
* Added HandleMessageUpdate locks.
* Added LastMile locks.
* Locks for IsValidatorInCommittee.
* Fixed locks.
* Fixed tests.
* Fixed tests.
* Fixed lock.
* Rebased over leader rotation.
* Fix formatting.
* Rebased onto dev.
* in progress.
* consensus check is forked
* update master
* fix leader
* check leader for N blocks
* fix
* fix
* Cleanup and fix update pub keys.
* Rotate leader.
* fix
fix
fix
fix
fix
* Cleaned.
* Cache for `GetLeaderPubKeyFromCoinbase`, removed `NthNextHmyExt`.
* comment activation
* 295 epoch
* Fix failed tests.
* Fixed code review.
* Fix review comments.
* Merged leader rotation.
* Rebased on dev.
* Rebased on dev.
* Fix usage of private methods.
* Fix usage of private methods.
* Fix usage of private methods.
* Removed deadcode, LockedFBFTPhase.
* Fix review comment.
* Fix review comment.
* Go mod tidy.
* Set to EpochTBD.
* Fix tests.
* [core] fix state handling of self destruct
If a contract self destructs to self and then receives funds within the
same transaction, it is possible for its stale state to be saved. This
change removes that possibility by checking for deleted state objects
before returning them.
* Fixed race error.
* rpc: add configurable http and `eth_call` timeout
* remove default timeouts
* store the evm call timeout in rosetta object
* [cmd] actually apply ToRPCServerConfig
* Removed unused method.
* Rotate external leaders on non-beacon chains.
* Fix nil panic.
* in progress.
* in progress.
* in progress.
* consensus check is forked
* update master
* fix leader
* check leader for N blocks
* fix
* fix
* Cleanup and fix update pub keys.
* Rotate leader.
* fix
fix
fix
fix
fix
* Cleaned.
* Cache for `GetLeaderPubKeyFromCoinbase`, removed `NthNextHmyExt`.
* Fixed code review.
* Fix review comments.
* Returned locks in rotateLeader.
* Rebased onto dev.
* staged stream sync v1.0
* refactor errors, rename metrics
* fix p2p discovery test issue
* add watermark low/high options for p2p connection manager
* fix dedent
* in progress.
* consensus check is forked
* fix
* Cleanup and fix update pub keys.
* fix
fix
fix
fix
fix
* activate epoch
* EpochTBD for leader rotation epoch.
* 295 epoch
* Decider no longer requires public keys as a dependency. (#4289)
* Consensus doesn't require anymore `Node` as a circular dependency.
* Proper blockchain initialization.
* Rwlock consensus.
* Removed channels.
* Removed view change locks.
* Removed multiSigMutex locks.
* Removed leader locks.
* Removed additional locks and isViewChange.
* Added locks detected by race.
* Added locks detected by race.
* Locks for start.
* Removed additional locks.
* Removed additional locks.
* Make func private.
* Make VerifyBlock private.
* Make IsLeader private.
* Make ParseFBFTMessage private.
* Fix remove locks.
* Added additional locks.
* Added additional locks.
* Added readSignatureBitmapPayload locks.
* Added HandleMessageUpdate locks.
* Added LastMile locks.
* Locks for IsValidatorInCommittee.
* Fixed locks.
* Fixed tests.
* Fixed lock.
* Rebased over leader rotation.
* in progress.
* consensus check is forked
* update master
* fix leader
* check leader for N blocks
* fix
* fix
* Cleanup and fix update pub keys.
* Rotate leader.
* fix
fix
fix
fix
fix
* Cleaned.
* Cache for `GetLeaderPubKeyFromCoinbase`, removed `NthNextHmyExt`.
* Fix failed tests.
* Fixed code review.
* Fix review comments.
* Merged leader rotation.
* Rebased on dev.
* Rebased on dev.
* Fix usage of private methods.
* Fix usage of private methods.
* Fix usage of private methods.
* Removed deadcode, LockedFBFTPhase.
* Fix review comment.
* Go mod tidy.
* remove default timeouts
* Rotate external leaders on non-beacon chains.
* Fix nil panic.
* Fixes.
* Update singleton.go
* evm: don't return extcode for validators
Due to technical debt, validator information is stored in the code field
of the address. The code field can be accessed in Solidity for an
arbitrary address using `extcodesize`, `extcodehash`, and `extcodecopy`
or helper commands (such as `address.code.Length`). The presence of this
field is used by contract developers to (erroneously) deny smart
contract access to other smart contracts (and therefore, validators).
This PR fixes that oversight by returning the same values as other EOAs
for known validator addresses. Obviously, it needs a hard fork that will
be scheduled separately.
* Fix context passing.
* Clean up code.
* Removed engine dependency.
* Fix possible panic.
* Clean up code.
* Network type.
* Fix tests.
* Revert "Removed engine dependency." (#4392)
* Revert "Fix tests."
This reverts commit 597ba2d6f1ed54ff599b9d9b8940c7285ab1277a.
* Revert "Network type."
This reverts commit 5e1878aedca3989dc0f34161dae1833e43ca6a76.
* Revert "Clean up code."
This reverts commit 15885f4c9b9263746827172b4f4f56d0926d18e2.
* Revert "Fix possible panic."
This reverts commit 1a70d5eb66cdbf8a23791806b71a323eed320085.
* Revert "Removed engine dependency."
This reverts commit 8c2ff803f709f944cfc8b1278f35cf5b2cacf859.
* gitignore the cache folder (#4389)
* stable localnet with external validator (#4388)
* stable localnet with external validator
* ignore deploy config file comments
* reduce node launched in localnet
* update makefile
* localnet configuration - add more fn
* fix validator information command typo
---------
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: MaxMustermann2 <82761650+MaxMustermann2@users.noreply.github.com>
Co-authored-by: frozen <355847+Frozen@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: “GheisMohammadi” <“Gheis.Mohammadi@gmail.com”>
Co-authored-by: “GheisMohammadi” <36589218+GheisMohammadi@users.noreply.github.com>
Co-authored-by: Sun Hyuk Ahn <sunhyukahn@Suns-MacBook-Pro.local>
Co-authored-by: Soph <35721420+sophoah@users.noreply.github.com>
2 years ago
|
|
|
func (a Stub) GetLeaderPubKeyFromCoinbase(h *block.Header) (*bls.PublicKeyWrapper, error) {
|
|
|
|
return nil, errors.Errorf("method GetLeaderPubKeyFromCoinbase not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) IsTikvWriterMaster() bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) RedisPreempt() *redis_helper.RedisPreempt {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) SyncFromTiKVWriter(newBlkNum uint64, logs []*types.Log) error {
|
|
|
|
return errors.Errorf("method SyncFromTiKVWriter not implemented for %s", a.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a Stub) InitTiKV(conf *harmonyconfig.TiKVConfig) {
|
|
|
|
return
|
|
|
|
}
|