call beacon to get nonce&balance and create staking transaction

pull/423/head
Minh Doan 6 years ago committed by Minh Doan
parent e74788d6ef
commit 6fa8eb7887
  1. 58
      api/service/staking/service.go
  2. 2
      node/node.go

@ -1,8 +1,15 @@
package staking package staking
import ( import (
"crypto/ecdsa"
"math/big"
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/log" "github.com/ethereum/go-ethereum/log"
client "github.com/harmony-one/harmony/api/client/service"
proto "github.com/harmony-one/harmony/api/client/service/proto"
"github.com/harmony-one/harmony/api/proto/message" "github.com/harmony-one/harmony/api/proto/message"
"github.com/harmony-one/harmony/core/types"
"github.com/harmony-one/harmony/internal/utils" "github.com/harmony-one/harmony/internal/utils"
"github.com/harmony-one/harmony/p2p" "github.com/harmony-one/harmony/p2p"
) )
@ -12,14 +19,17 @@ type Service struct {
stopChan chan struct{} stopChan chan struct{}
stoppedChan chan struct{} stoppedChan chan struct{}
peerChan <-chan p2p.Peer peerChan <-chan p2p.Peer
account common.Address
AccountKey *ecdsa.PrivateKey
} }
// New returns staking service. // New returns staking service.
func New(peerChan <-chan p2p.Peer) *Service { func New(account common.Address, peerChan <-chan p2p.Peer) *Service {
return &Service{ return &Service{
stopChan: make(chan struct{}), stopChan: make(chan struct{}),
stoppedChan: make(chan struct{}), stoppedChan: make(chan struct{}),
peerChan: peerChan, peerChan: peerChan,
account: account,
} }
} }
@ -44,7 +54,7 @@ func (s *Service) Run() {
case peer := <-s.peerChan: case peer := <-s.peerChan:
utils.GetLogInstance().Info("Running role conversion") utils.GetLogInstance().Info("Running role conversion")
// TODO: Write some logic here. // TODO: Write some logic here.
s.DoService(&peer) s.DoService(peer)
case <-s.stopChan: case <-s.stopChan:
return return
} }
@ -53,24 +63,46 @@ func (s *Service) Run() {
} }
// DoService does staking. // DoService does staking.
func (s *Service) DoService(peer *p2p.Peer) { func (s *Service) DoService(peer p2p.Peer) {
utils.GetLogInstance().Info("Staking with Peer") utils.GetLogInstance().Info("Staking with Peer")
// TODO(minhdoan): How to use the p2p or pubsub to send Staking Message to beacon chain. // TODO(minhdoan): How to use the p2p or pubsub to send Staking Message to beacon chain.
// See below of how to create a staking message. // See below of how to create a staking message.
} }
func (s *Service) createStakingMessage() *message.Message { func (s *Service) getAccountState(beaconPeer p2p.Peer) *proto.FetchAccountStateResponse {
// TODO(minhdoan): Add signature and public key. client := client.NewClient(beaconPeer.IP, beaconPeer.Port)
// To add public we need to assign a fake account to new node initially. defer client.Close()
return &message.Message{ return client.GetBalance(s.account)
Type: message.MessageType_NEWNODE_BEACON_STAKING, }
Request: &message.Message_Staking{
Staking: &message.StakingRequest{ func (s *Service) createStakingMessage(beaconPeer p2p.Peer) *message.Message {
Transaction: []byte{}, accountState := s.getAccountState(beaconPeer)
NodeId: "", toAddress := common.HexToAddress("0x4592d8f8d7b001e72cb26a73e4fa1806a51ac79d")
gasLimit := uint64(0)
gasPrice := big.NewInt(0)
tx := types.NewTransaction(
accountState.Nonce,
toAddress,
0, // beacon chain.
new(big.Int).SetBytes(accountState.Balance),
gasLimit,
gasPrice,
nil)
if signedTx, err := types.SignTx(tx, types.HomesteadSigner{}, s.AccountKey); err == nil {
ts := types.Transactions{signedTx}
return &message.Message{
Type: message.MessageType_NEWNODE_BEACON_STAKING,
Request: &message.Message_Staking{
Staking: &message.StakingRequest{
Transaction: ts.GetRlp(0),
NodeId: "",
},
}, },
}, }
} else {
return nil
} }
} }

@ -614,7 +614,7 @@ func (node *Node) setupForNewNode() {
stakingPeer := make(chan p2p.Peer) stakingPeer := make(chan p2p.Peer)
// Register staking service. // Register staking service.
node.serviceManager.RegisterService(service_manager.Staking, staking.New(stakingPeer)) node.serviceManager.RegisterService(service_manager.Staking, staking.New(crypto.PubkeyToAddress(node.AccountKey.PublicKey), stakingPeer))
// Register peer discovery service. "0" is the beacon shard ID // Register peer discovery service. "0" is the beacon shard ID
node.serviceManager.RegisterService(service_manager.PeerDiscovery, discovery.New(node.host, "0", chanPeer, stakingPeer)) node.serviceManager.RegisterService(service_manager.PeerDiscovery, discovery.New(node.host, "0", chanPeer, stakingPeer))
// Register networkinfo service. "0" is the beacon shard ID // Register networkinfo service. "0" is the beacon shard ID

Loading…
Cancel
Save