mirror of
https://github.com/ethereum/go-ethereum.git
synced 2026-06-20 21:54:30 +00:00
update return error when update M1
This commit is contained in:
parent
6adb7c1d68
commit
51ef74203a
4 changed files with 70 additions and 61 deletions
|
|
@ -14,7 +14,6 @@
|
|||
// You should have received a copy of the GNU General Public License
|
||||
// along with go-ethereum. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
// XDC is the official command-line client for Ethereum.
|
||||
package main
|
||||
|
||||
import (
|
||||
|
|
@ -26,13 +25,9 @@ import (
|
|||
"time"
|
||||
|
||||
"github.com/ethereum/go-ethereum/accounts"
|
||||
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
||||
"github.com/ethereum/go-ethereum/accounts/keystore"
|
||||
"github.com/ethereum/go-ethereum/cmd/utils"
|
||||
"github.com/ethereum/go-ethereum/common"
|
||||
"github.com/ethereum/go-ethereum/consensus/XDPoS"
|
||||
"github.com/ethereum/go-ethereum/console"
|
||||
validatorContract "github.com/ethereum/go-ethereum/contracts/validator/contract"
|
||||
"github.com/ethereum/go-ethereum/core"
|
||||
"github.com/ethereum/go-ethereum/eth"
|
||||
"github.com/ethereum/go-ethereum/ethclient"
|
||||
|
|
@ -51,7 +46,7 @@ var (
|
|||
// Git SHA1 commit hash of the release (set via linker flags)
|
||||
gitCommit = ""
|
||||
// The app that holds all commands and flags.
|
||||
app = utils.NewApp(gitCommit, "the XDC command line interface")
|
||||
app = utils.NewApp(gitCommit, "the XDCchain command line interface")
|
||||
// flags that configure the node
|
||||
nodeFlags = []cli.Flag{
|
||||
utils.IdentityFlag,
|
||||
|
|
@ -151,7 +146,7 @@ func init() {
|
|||
// Initialize the CLI app and start XDC
|
||||
app.Action = XDC
|
||||
app.HideVersion = true // we have a command to print the version
|
||||
app.Copyright = "Copyright (c) 2018 Xinfin "
|
||||
app.Copyright = "Copyright (c) 2018 Xinfin"
|
||||
app.Commands = []cli.Command{
|
||||
// See chaincmd.go:
|
||||
initCommand,
|
||||
|
|
@ -315,7 +310,7 @@ func startNode(ctx *cli.Context, stack *node.Node) {
|
|||
utils.Fatalf("Failed to start staking: %v", err)
|
||||
}
|
||||
started = true
|
||||
log.Info("Enabled staking node!!!")
|
||||
log.Info("Enabled staking node!!!")
|
||||
}
|
||||
defer close(core.CheckpointCh)
|
||||
defer close(core.M1Ch)
|
||||
|
|
@ -329,13 +324,13 @@ func startNode(ctx *cli.Context, stack *node.Node) {
|
|||
}
|
||||
if !ok {
|
||||
if started {
|
||||
log.Info("Only masternode can propose and verify blocks. Cancelling staking on this node...")
|
||||
log.Info("Only masternode can propose and verify blocks. Cancelling staking on this node...")
|
||||
ethereum.StopStaking()
|
||||
started = false
|
||||
log.Info("Cancelled mining mode!!!")
|
||||
}
|
||||
} else if !started {
|
||||
log.Info("Masternode found. Enabling staking mode...")
|
||||
log.Info("Masternode found. Enabling staking mode...")
|
||||
// Use a reduced number of threads if requested
|
||||
if threads := ctx.GlobalInt(utils.StakerThreadsFlag.Name); threads > 0 {
|
||||
type threaded interface {
|
||||
|
|
@ -354,52 +349,9 @@ func startNode(ctx *cli.Context, stack *node.Node) {
|
|||
log.Info("Enabled staking node!!!")
|
||||
}
|
||||
case <-core.M1Ch:
|
||||
log.Info("It's time to update new set of masternodes for the next epoch...")
|
||||
// get masternodes information from smart contract
|
||||
client, err := ethclient.Dial(stack.IPCEndpoint())
|
||||
if err != nil {
|
||||
utils.Fatalf("Fail to connect IPC: %v", err)
|
||||
}
|
||||
addr := common.HexToAddress(common.MasternodeVotingSMC)
|
||||
validator, err := validatorContract.NewXDCValidator(addr, client)
|
||||
if err != nil {
|
||||
utils.Fatalf("Fail to get validator smc: %v", err)
|
||||
}
|
||||
opts := new(bind.CallOpts)
|
||||
candidates, err := validator.GetCandidates(opts)
|
||||
if err != nil {
|
||||
utils.Fatalf("Can't get list of masternode candidates: %v", err)
|
||||
}
|
||||
|
||||
var ms []XDPoS.Masternode
|
||||
for _, candidate := range candidates {
|
||||
v, err := validator.GetCandidateCap(opts, candidate)
|
||||
if err != nil {
|
||||
log.Warn("Can't get cap of a masternode candidate. Will ignore him", "address", candidate, "error", err)
|
||||
}
|
||||
//TODO: smart contract shouldn't return "0x0000000000000000000000000000000000000000"
|
||||
if candidate.String() != "0x0000000000000000000000000000000000000000" {
|
||||
ms = append(ms, XDPoS.Masternode{Address: candidate, Stake: v.String()})
|
||||
}
|
||||
}
|
||||
//// order by cap
|
||||
//sort.Slice(ms, func(i, j int) bool {
|
||||
// return ms[i].Stake > ms[j].Stake
|
||||
//})
|
||||
log.Info("Ordered list of masternode candidates")
|
||||
for _, m := range ms {
|
||||
fmt.Printf("address: %s, stake: %s\n", m.Address.String(), m.Stake)
|
||||
}
|
||||
if len(ms) == 0 {
|
||||
log.Info("No masternode candidates found. Keep the current masternodes set for the next epoch")
|
||||
} else {
|
||||
// update masternodes
|
||||
log.Info("Updating new set of masternodes")
|
||||
err = ethereum.UpdateMasternodes(ms)
|
||||
if err != nil {
|
||||
utils.Fatalf("Can't update masternodes: %v", err)
|
||||
}
|
||||
log.Info("Masternodes are ready for the next epoch")
|
||||
err := ethereum.BlockChain().UpdateM1()
|
||||
if(err !=nil){
|
||||
log.Error("Error when update M1",err)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -27,9 +27,12 @@ import (
|
|||
"sync/atomic"
|
||||
"time"
|
||||
|
||||
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
||||
"github.com/ethereum/go-ethereum/common"
|
||||
"github.com/ethereum/go-ethereum/common/mclock"
|
||||
"github.com/ethereum/go-ethereum/consensus"
|
||||
"github.com/ethereum/go-ethereum/consensus/XDPoS"
|
||||
contractValidator "github.com/ethereum/go-ethereum/contracts/validator/contract"
|
||||
"github.com/ethereum/go-ethereum/core/state"
|
||||
"github.com/ethereum/go-ethereum/core/types"
|
||||
"github.com/ethereum/go-ethereum/core/vm"
|
||||
|
|
@ -695,7 +698,7 @@ func (bc *BlockChain) procFutureBlocks() {
|
|||
type WriteStatus byte
|
||||
|
||||
const (
|
||||
NonStatTy WriteStatus = iota
|
||||
NonStatTy WriteStatus = iota
|
||||
CanonStatTy
|
||||
SideStatTy
|
||||
)
|
||||
|
|
@ -1195,7 +1198,7 @@ func (bc *BlockChain) insertChain(chain types.Blocks) (int, []interface{}, []*ty
|
|||
CheckpointCh <- 1
|
||||
}
|
||||
// prepare set of masternodes for the next epoch
|
||||
if (chain[i].NumberU64() % bc.chainConfig.XDPoS.Epoch) == (bc.chainConfig.XDPoS.Epoch - bc.chainConfig.Clique.Gap) {
|
||||
if (chain[i].NumberU64() % bc.chainConfig.XDPoS.Epoch) == (bc.chainConfig.XDPoS.Epoch - bc.chainConfig.XDPoS.Gap) {
|
||||
M1Ch <- 1
|
||||
}
|
||||
}
|
||||
|
|
@ -1587,4 +1590,55 @@ func (bc *BlockChain) GetClient() (*ethclient.Client, error) {
|
|||
}
|
||||
|
||||
return bc.Client, nil
|
||||
}
|
||||
|
||||
func (bc *BlockChain) UpdateM1() error {
|
||||
if bc.Config().XDPoS == nil {
|
||||
return errors.New("XDPoS not found in config")
|
||||
}
|
||||
engine := bc.Engine().(*XDPoS.XDPoS)
|
||||
log.Info("It's time to update new set of masternodes for the next epoch...")
|
||||
// get masternodes information from smart contract
|
||||
client, err := ethclient.Dial(bc.IPCEndpoint)
|
||||
if err != nil {
|
||||
log.Crit("Fail to connect IPC: %v", err)
|
||||
}
|
||||
addr := common.HexToAddress(common.MasternodeVotingSMC)
|
||||
validator, err := contractValidator.NewXDCValidator(addr, client)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
opts := new(bind.CallOpts)
|
||||
candidates, err := validator.GetCandidates(opts)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
var ms []XDPoS.Masternode
|
||||
for _, candidate := range candidates {
|
||||
v, err := validator.GetCandidateCap(opts, candidate)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
//TODO: smart contract shouldn't return "0x0000000000000000000000000000000000000000"
|
||||
if candidate.String() != "0x0000000000000000000000000000000000000000" {
|
||||
ms = append(ms, XDPoS.Masternode{Address: candidate, Stake: v.String()})
|
||||
}
|
||||
}
|
||||
log.Info("Ordered list of masternode candidates")
|
||||
for _, m := range ms {
|
||||
fmt.Printf("address: %s, stake: %s\n", m.Address.String(), m.Stake)
|
||||
}
|
||||
if len(ms) == 0 {
|
||||
log.Info("No masternode candidates found. Keep the current masternodes set for the next epoch")
|
||||
} else {
|
||||
// update masternodes
|
||||
log.Info("Updating new set of masternodes")
|
||||
err = engine.UpdateMasternodes(bc, bc.CurrentHeader(), ms)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
log.Info("Masternodes are ready for the next epoch")
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
|
@ -173,7 +173,7 @@ type LightChain interface {
|
|||
// BlockChain encapsulates functions required to sync a (full or fast) blockchain.
|
||||
type BlockChain interface {
|
||||
Config() *params.ChainConfig
|
||||
UpdateM1()
|
||||
UpdateM1() error
|
||||
LightChain
|
||||
|
||||
// HasBlock verifies a block's presence in the local chain.
|
||||
|
|
@ -1349,7 +1349,10 @@ func (d *Downloader) processFullSyncContent() error {
|
|||
}
|
||||
// prepare set of masternodes for the next epoch
|
||||
if (inserts[len(inserts)-1].Header.Number.Uint64() % epoch) == (epoch - gap) {
|
||||
d.blockchain.UpdateM1()
|
||||
err := d.blockchain.UpdateM1()
|
||||
if (err != nil) {
|
||||
log.Error("Error when update M1", err)
|
||||
}
|
||||
}
|
||||
}
|
||||
start = end + 1
|
||||
|
|
|
|||
|
|
@ -458,7 +458,7 @@ func (dl *downloadTester) dropPeer(id string) {
|
|||
|
||||
// Config retrieves the blockchain's chain configuration.
|
||||
func (dl *downloadTester) Config() *params.ChainConfig { return params.TestChainConfig }
|
||||
func (dl *downloadTester) UpdateM1() {}
|
||||
func (dl *downloadTester) UpdateM1() error { return nil }
|
||||
|
||||
type downloadTesterPeer struct {
|
||||
dl *downloadTester
|
||||
|
|
|
|||
Loading…
Reference in a new issue