|
|
@ -183,35 +183,42 @@ func passphraseForBls() { |
|
|
|
blsPassphrase = passphrase |
|
|
|
blsPassphrase = passphrase |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func setupInitialAccount() (isLeader bool) { |
|
|
|
func setupLegacyNodeAccount() error { |
|
|
|
genesisShardingConfig := shard.Schedule.InstanceForEpoch(big.NewInt(core.GenesisEpoch)) |
|
|
|
genesisShardingConfig := shard.Schedule.InstanceForEpoch(big.NewInt(core.GenesisEpoch)) |
|
|
|
pubKey := setupConsensusKey(nodeconfig.GetDefaultConfig()) |
|
|
|
pubKey := setupConsensusKey(nodeconfig.GetDefaultConfig()) |
|
|
|
|
|
|
|
|
|
|
|
reshardingEpoch := genesisShardingConfig.ReshardingEpoch() |
|
|
|
reshardingEpoch := genesisShardingConfig.ReshardingEpoch() |
|
|
|
// TODO: after staking, what if the FN validator uses the old bls pub keys?
|
|
|
|
|
|
|
|
if reshardingEpoch != nil && len(reshardingEpoch) > 0 { |
|
|
|
if reshardingEpoch != nil && len(reshardingEpoch) > 0 { |
|
|
|
for _, epoch := range reshardingEpoch { |
|
|
|
for _, epoch := range reshardingEpoch { |
|
|
|
config := shard.Schedule.InstanceForEpoch(epoch) |
|
|
|
config := shard.Schedule.InstanceForEpoch(epoch) |
|
|
|
isLeader, initialAccount = config.FindAccount(pubKey.SerializeToHexStr()) |
|
|
|
_, initialAccount = config.FindAccount(pubKey.SerializeToHexStr()) |
|
|
|
if initialAccount != nil { |
|
|
|
if initialAccount != nil { |
|
|
|
break |
|
|
|
break |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
isLeader, initialAccount = genesisShardingConfig.FindAccount(pubKey.SerializeToHexStr()) |
|
|
|
_, initialAccount = genesisShardingConfig.FindAccount(pubKey.SerializeToHexStr()) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if initialAccount == nil { |
|
|
|
if initialAccount == nil { |
|
|
|
|
|
|
|
return errors.Errorf("cannot find key %s in table", pubKey.SerializeToHexStr()) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
fmt.Printf("My Genesis Account: %v\n", *initialAccount) |
|
|
|
|
|
|
|
return nil |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func setupStakingNodeAccount() error { |
|
|
|
|
|
|
|
pubKey := setupConsensusKey(nodeconfig.GetDefaultConfig()) |
|
|
|
|
|
|
|
shardID, err := nodeconfig.GetDefaultConfig().ShardIDFromConsensusKey() |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
return errors.Wrap(err, "cannot determine shard to join") |
|
|
|
|
|
|
|
} |
|
|
|
initialAccount = &genesis.DeployAccount{} |
|
|
|
initialAccount = &genesis.DeployAccount{} |
|
|
|
initialAccount.ShardID = uint32(*shardID) |
|
|
|
initialAccount.ShardID = shardID |
|
|
|
initialAccount.BlsPublicKey = pubKey.SerializeToHexStr() |
|
|
|
initialAccount.BlsPublicKey = pubKey.SerializeToHexStr() |
|
|
|
blsAddressBytes := pubKey.GetAddress() |
|
|
|
blsAddressBytes := pubKey.GetAddress() |
|
|
|
initialAccount.Address = hex.EncodeToString(blsAddressBytes[:]) |
|
|
|
initialAccount.Address = hex.EncodeToString(blsAddressBytes[:]) |
|
|
|
} else { |
|
|
|
return nil |
|
|
|
fmt.Printf("My Genesis Account: %v\n", *initialAccount) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return isLeader |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func setupConsensusKey(nodeConfig *nodeconfig.ConfigType) *bls.PublicKey { |
|
|
|
func setupConsensusKey(nodeConfig *nodeconfig.ConfigType) *bls.PublicKey { |
|
|
@ -452,16 +459,16 @@ func main() { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if *nodeType == "validator" { |
|
|
|
if *nodeType == "validator" { |
|
|
|
setupInitialAccount() |
|
|
|
var err error |
|
|
|
if *stakingFlag { |
|
|
|
if *stakingFlag { |
|
|
|
shardID, err := nodeconfig.GetDefaultConfig().ShardIDFromConsensusKey() |
|
|
|
err = setupStakingNodeAccount() |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
err = setupLegacyNodeAccount() |
|
|
|
|
|
|
|
} |
|
|
|
if err != nil { |
|
|
|
if err != nil { |
|
|
|
_, _ = fmt.Fprintf(os.Stderr, |
|
|
|
_, _ = fmt.Fprintf(os.Stderr, "cannot set up node account: %s\n", err) |
|
|
|
"ERROR cannot determine shard to join: %s", err) |
|
|
|
|
|
|
|
os.Exit(1) |
|
|
|
os.Exit(1) |
|
|
|
} |
|
|
|
} |
|
|
|
initialAccount.ShardID = shardID |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
fmt.Printf("%s mode; node key %s -> shard %d\n", |
|
|
|
fmt.Printf("%s mode; node key %s -> shard %d\n", |
|
|
|
map[bool]string{false: "Legacy", true: "Staking"}[*stakingFlag], |
|
|
|
map[bool]string{false: "Legacy", true: "Staking"}[*stakingFlag], |
|
|
|