Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: remove previous header in Prepare/Process Proposal + provide chain id in baseapp + fix context for verifying txs #15303

Merged
merged 34 commits into from
Mar 13, 2023
Merged
Changes from 2 commits
Commits
Show all changes
34 commits
Select commit Hold shift + click to select a range
5600add
fix: remove previous header to avoid inconsistencies in Prepare\/Proc…
facundomedica Mar 8, 2023
a07fd6f
nit
facundomedica Mar 8, 2023
fbe491f
get chain id from genesis
facundomedica Mar 8, 2023
ac12759
progress
facundomedica Mar 8, 2023
233a4a4
progress
facundomedica Mar 8, 2023
fe1cd5b
progress
facundomedica Mar 8, 2023
257f4be
progress
facundomedica Mar 8, 2023
06d2021
progress
facundomedica Mar 8, 2023
4a79357
progress
facundomedica Mar 8, 2023
71d93ca
progress
facundomedica Mar 8, 2023
755611d
progress
facundomedica Mar 8, 2023
be89d62
fix leak
facundomedica Mar 8, 2023
bf4c3f2
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into facu…
facundomedica Mar 8, 2023
d7e7bd8
Merge branch 'main' into facu/empty-header-prepproc-prop
facundomedica Mar 9, 2023
09ae43a
cl++
facundomedica Mar 9, 2023
a578ddb
add some extra checks and fix context for prepare and process proposal
facundomedica Mar 10, 2023
630175a
add some extra checks and fix context for prepare and process proposal
facundomedica Mar 10, 2023
950cd21
fix comment
facundomedica Mar 10, 2023
966dba8
fix e2e test in params
facundomedica Mar 10, 2023
820e34e
rm comment
facundomedica Mar 10, 2023
b17f178
attempt to simplify (#15348)
julienrbrt Mar 10, 2023
adfac48
Merge branch 'facu/empty-header-prepproc-prop' of https://github.com/…
facundomedica Mar 10, 2023
3f23381
fix
facundomedica Mar 10, 2023
3bcaa15
rollback rollback.go
facundomedica Mar 10, 2023
bc1b4c1
Merge branch 'main' into facu/empty-header-prepproc-prop
facundomedica Mar 10, 2023
f5e883e
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into facu…
facundomedica Mar 10, 2023
52a64aa
suggestions from @alexanderbez
facundomedica Mar 10, 2023
6b8b529
Merge branch 'main' into facu/empty-header-prepproc-prop
facundomedica Mar 13, 2023
02b6ad1
Merge branch 'main' into facu/empty-header-prepproc-prop
facundomedica Mar 13, 2023
143af44
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into facu…
facundomedica Mar 13, 2023
f307b3b
remove some unnecessary changes, like new lines
facundomedica Mar 13, 2023
89b90da
Merge branch 'facu/empty-header-prepproc-prop' of https://github.com/…
facundomedica Mar 13, 2023
ed69776
Merge branch 'main' into facu/empty-header-prepproc-prop
facundomedica Mar 13, 2023
814fc92
Merge branch 'main' into facu/empty-header-prepproc-prop
facundomedica Mar 13, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
19 changes: 15 additions & 4 deletions baseapp/abci.go
Original file line number Diff line number Diff line change
Expand Up @@ -57,8 +57,13 @@ func (app *BaseApp) InitChain(req abci.RequestInitChain) (res abci.ResponseInitC
// initialize states with a correct header
app.setState(runTxModeDeliver, initHeader)
app.setState(runTxModeCheck, initHeader)
app.setState(runTxPrepareProposal, initHeader)
app.setState(runTxProcessProposal, initHeader)

// Use an empty header for prepare and process proposal states. Although it
// doesn't matter what header we use here as they get overwritten for the
// first block (see getContextForProposal()) and cleaned up on every Commit().
emptyHeader := cmtproto.Header{}
app.setState(runTxPrepareProposal, emptyHeader)
app.setState(runTxProcessProposal, emptyHeader)

// Store the consensus params in the BaseApp's paramstore. Note, this must be
// done after the deliver state and context have been set as it's persisted
Expand Down Expand Up @@ -450,8 +455,12 @@ func (app *BaseApp) Commit() abci.ResponseCommit {
// NOTE: This is safe because CometBFT holds a lock on the mempool for
// Commit. Use the header from this latest block.
app.setState(runTxModeCheck, header)
app.setState(runTxPrepareProposal, header)
app.setState(runTxProcessProposal, header)

// Reset state to the latest committed but with an empty header to avoid
// leaking the header from the last block.
emptyHeader := cmtproto.Header{}
app.setState(runTxPrepareProposal, emptyHeader)
app.setState(runTxProcessProposal, emptyHeader)

// empty/reset the deliver state
app.deliverState = nil
Expand Down Expand Up @@ -969,6 +978,8 @@ func SplitABCIQueryPath(requestPath string) (path []string) {
func (app *BaseApp) getContextForProposal(ctx sdk.Context, height int64) sdk.Context {
if height == 1 {
ctx, _ = app.deliverState.ctx.CacheContext()
// TODO: clear all context data set during InitChain to avoid inconsistent behavior
facundomedica marked this conversation as resolved.
Show resolved Hide resolved
ctx = ctx.WithBlockHeader(cmtproto.Header{}).WithChainID("")
facundomedica marked this conversation as resolved.
Show resolved Hide resolved
return ctx
}
return ctx
Expand Down