consensus: move stateroot generation from newBlockFromContext to newCommit
Fixes #1313. newCommit is only called once and only when we have enough signatures unlike newBlockFromContext that is also being called to create PrepareResponse.
This commit is contained in:
parent
5f46aa096f
commit
ee61120e13
1 changed files with 27 additions and 23 deletions
|
@ -145,7 +145,7 @@ func NewService(cfg Config) (Service, error) {
|
||||||
dbft.WithNewPrepareRequest(srv.newPrepareRequest),
|
dbft.WithNewPrepareRequest(srv.newPrepareRequest),
|
||||||
dbft.WithNewPrepareResponse(srv.newPrepareResponse),
|
dbft.WithNewPrepareResponse(srv.newPrepareResponse),
|
||||||
dbft.WithNewChangeView(func() payload.ChangeView { return new(changeView) }),
|
dbft.WithNewChangeView(func() payload.ChangeView { return new(changeView) }),
|
||||||
dbft.WithNewCommit(func() payload.Commit { return new(commit) }),
|
dbft.WithNewCommit(srv.newCommit),
|
||||||
dbft.WithNewRecoveryRequest(func() payload.RecoveryRequest { return new(recoveryRequest) }),
|
dbft.WithNewRecoveryRequest(func() payload.RecoveryRequest { return new(recoveryRequest) }),
|
||||||
dbft.WithNewRecoveryMessage(srv.newRecoveryMessage),
|
dbft.WithNewRecoveryMessage(srv.newRecoveryMessage),
|
||||||
dbft.WithVerifyPrepareRequest(srv.verifyRequest),
|
dbft.WithVerifyPrepareRequest(srv.verifyRequest),
|
||||||
|
@ -259,6 +259,32 @@ func (s *service) getStateRootSig() []byte {
|
||||||
return sig
|
return sig
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *service) newCommit() payload.Commit {
|
||||||
|
if s.stateRootEnabled() {
|
||||||
|
// This is being called when we're ready to commit, so we can safely
|
||||||
|
// relay stateroot here.
|
||||||
|
stateRoot, err := s.Chain.GetStateRoot(s.dbft.Context.BlockIndex - 1)
|
||||||
|
if err != nil {
|
||||||
|
s.log.Warn("can't get stateroot", zap.Uint32("block", s.dbft.Context.BlockIndex-1))
|
||||||
|
}
|
||||||
|
r := stateRoot.MPTRoot
|
||||||
|
r.Witness = s.getWitness(func(ctx dbft.Context, i int) []byte {
|
||||||
|
if p := ctx.PreparationPayloads[i]; p != nil && p.ViewNumber() == ctx.ViewNumber {
|
||||||
|
if int(ctx.PrimaryIndex) == i {
|
||||||
|
return p.GetPrepareRequest().(*prepareRequest).stateRootSig[:]
|
||||||
|
}
|
||||||
|
return p.GetPrepareResponse().(*prepareResponse).stateRootSig[:]
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
if err := s.Chain.AddStateRoot(&r); err != nil {
|
||||||
|
s.log.Warn("errors while adding state root", zap.Error(err))
|
||||||
|
}
|
||||||
|
s.Broadcast(&r)
|
||||||
|
}
|
||||||
|
return new(commit)
|
||||||
|
}
|
||||||
|
|
||||||
func (s *service) newPrepareResponse() payload.PrepareResponse {
|
func (s *service) newPrepareResponse() payload.PrepareResponse {
|
||||||
res := &prepareResponse{
|
res := &prepareResponse{
|
||||||
stateRootEnabled: s.stateRootEnabled(),
|
stateRootEnabled: s.stateRootEnabled(),
|
||||||
|
@ -622,28 +648,6 @@ func convertKeys(validators []crypto.PublicKey) (pubs []*keys.PublicKey) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *service) newBlockFromContext(ctx *dbft.Context) block.Block {
|
func (s *service) newBlockFromContext(ctx *dbft.Context) block.Block {
|
||||||
if s.stateRootEnabled() {
|
|
||||||
// This is being called when we're ready to commit, so we can safely
|
|
||||||
// relay stateroot here.
|
|
||||||
stateRoot, err := s.Chain.GetStateRoot(s.dbft.Context.BlockIndex - 1)
|
|
||||||
if err != nil {
|
|
||||||
s.log.Warn("can't get stateroot", zap.Uint32("block", s.dbft.Context.BlockIndex-1))
|
|
||||||
}
|
|
||||||
r := stateRoot.MPTRoot
|
|
||||||
r.Witness = s.getWitness(func(ctx dbft.Context, i int) []byte {
|
|
||||||
if p := ctx.PreparationPayloads[i]; p != nil && p.ViewNumber() == ctx.ViewNumber {
|
|
||||||
if int(ctx.PrimaryIndex) == i {
|
|
||||||
return p.GetPrepareRequest().(*prepareRequest).stateRootSig[:]
|
|
||||||
}
|
|
||||||
return p.GetPrepareResponse().(*prepareResponse).stateRootSig[:]
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
})
|
|
||||||
if err := s.Chain.AddStateRoot(&r); err != nil {
|
|
||||||
s.log.Warn("errors while adding state root", zap.Error(err))
|
|
||||||
}
|
|
||||||
s.Broadcast(&r)
|
|
||||||
}
|
|
||||||
block := new(neoBlock)
|
block := new(neoBlock)
|
||||||
if len(ctx.TransactionHashes) == 0 {
|
if len(ctx.TransactionHashes) == 0 {
|
||||||
return nil
|
return nil
|
||||||
|
|
Loading…
Reference in a new issue