From a2616cfafe45eda2c19d262fec0ee461d9705948 Mon Sep 17 00:00:00 2001 From: Roman Khimov Date: Fri, 14 Feb 2020 19:21:24 +0300 Subject: [PATCH] consensus: correctly generate miner TX outputs based on net fee --- pkg/consensus/consensus.go | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/pkg/consensus/consensus.go b/pkg/consensus/consensus.go index d4daca7da..23c28ae88 100644 --- a/pkg/consensus/consensus.go +++ b/pkg/consensus/consensus.go @@ -411,10 +411,25 @@ func (s *service) getVerifiedTx(count int) []block.Transaction { } res := make([]block.Transaction, len(txx)+1) + var netFee util.Fixed8 for i := range txx { res[i+1] = txx[i] + netFee += s.Config.Chain.NetworkFee(txx[i]) } + var txOuts []transaction.Output + if netFee != 0 { + sh := s.wallet.GetChangeAddress() + if sh.Equals(util.Uint160{}) { + pk := s.dbft.Pub.(*publicKey) + sh = hash.Hash160(pk.GetVerificationScript()) + } + txOuts = []transaction.Output{transaction.Output{ + AssetID: core.UtilityTokenID(), + Amount: netFee, + ScriptHash: sh, + }} + } for { nonce := rand.Uint32() res[0] = &transaction.Transaction{ @@ -423,7 +438,7 @@ func (s *service) getVerifiedTx(count int) []block.Transaction { Data: &transaction.MinerTX{Nonce: nonce}, Attributes: nil, Inputs: nil, - Outputs: nil, + Outputs: txOuts, Scripts: nil, Trimmed: false, }