2018-07-12 18:20:26 -07:00
|
|
|
package baseapp
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2019-08-06 05:59:22 -07:00
|
|
|
"io"
|
2018-07-12 18:20:26 -07:00
|
|
|
|
2019-08-02 06:20:39 -07:00
|
|
|
dbm "github.com/tendermint/tm-db"
|
2018-12-10 06:27:25 -08:00
|
|
|
|
2020-10-15 06:07:59 -07:00
|
|
|
"github.com/cosmos/cosmos-sdk/codec/types"
|
2020-09-08 02:05:44 -07:00
|
|
|
"github.com/cosmos/cosmos-sdk/snapshots"
|
2018-09-26 06:17:46 -07:00
|
|
|
"github.com/cosmos/cosmos-sdk/store"
|
2018-07-12 18:20:26 -07:00
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
refactor!: BaseApp {Check,Deliver}Tx with middleware design (#9920)
<!--
The default pull request template is for types feat, fix, or refactor.
For other templates, add one of the following parameters to the url:
- template=docs.md
- template=other.md
-->
## Description
ref: #9585
This PR if the 1st step (out of 2) in the #9585 refactor. It transforms baseapp's ABCI {Check,Deliver}Tx into middleware stacks. A middleware is defined by the following interfaces:
```go
// types/tx package
type Handler interface {
CheckTx(ctx context.Context, tx sdk.Tx, req abci.RequestCheckTx) (abci.ResponseCheckTx, error)
DeliverTx(ctx context.Context, tx sdk.Tx, req abci.RequestDeliverTx) (abci.ResponseDeliverTx, error)
SimulateTx(ctx context.Context, tx sdk.Tx, req RequestSimulateTx) (ResponseSimulateTx, error)
}
type Middleware func(Handler) Handler
```
This Pr doesn't migrate antehandlers, but only baseapp's runTx and runMsgs as middlewares. It bundles antehandlers into one single middleware (for now).
More specifically, it introduces the 5 following middlewares:
| Middleware | Description |
| ----------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| RunMsgsTxMiddleware | This middleware replaces the old baseapp's `runMsgs`. |
| LegacyAnteMiddleware | This middleware is temporary, it bundles all antehandlers into one middleware. It's only created for the purpose of breaking the refactor into 2 pieces. **It will be removed in Part 2**, and each antehandler will be replaced by its own middleware. |
| IndexEventsTxMiddleware | This is a simple middleware that chooses which events to index in Tendermint. Replaces `baseapp.indexEvents` (which unfortunately still exists in baseapp too, because it's used to index Begin/EndBlock events) |
| RecoveryTxMiddleware | This index recovers from panics. It replaces baseapp.runTx's panic recovery. |
| GasTxMiddleware | This replaces the [`Setup`](https://github.com/cosmos/cosmos-sdk/blob/master/x/auth/ante/setup.go) Antehandler. It sets a GasMeter on sdk.Context. Note that before, GasMeter was set on sdk.Context inside the antehandlers, and there was some mess around the fact that antehandlers had their own panic recovery system so that the GasMeter could be read by baseapp's recovery system. Now, this mess is all removed: one middleware sets GasMeter, another one handles recovery. |
---
### Author Checklist
*All items are required. Please add a note to the item if the item is not applicable and
please add links to any relevant follow up issues.*
I have...
- [x] included the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title
- [x] added `!` to the type prefix if API or client breaking change
- [x] targeted the correct branch (see [PR Targeting](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#pr-targeting))
- [x] provided a link to the relevant issue or specification
- [ ] followed the guidelines for [building modules](https://github.com/cosmos/cosmos-sdk/blob/master/docs/building-modules)
- [x] included the necessary unit and integration [tests](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#testing)
- [x] added a changelog entry to `CHANGELOG.md`
- [x] included comments for [documenting Go code](https://blog.golang.org/godoc)
- [ ] updated the relevant documentation or specification
- [x] reviewed "Files changed" and left comments if necessary
- [ ] confirmed all CI checks have passed
### Reviewers Checklist
*All items are required. Please add a note if the item is not applicable and please add
your handle next to the items reviewed if you only reviewed selected items.*
I have...
- [ ] confirmed the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title
- [ ] confirmed `!` in the type prefix if API or client breaking change
- [ ] confirmed all author checklist items have been addressed
- [ ] reviewed state machine logic
- [ ] reviewed API design and naming
- [ ] reviewed documentation is accurate
- [ ] reviewed tests and test coverage
- [ ] manually tested (if applicable)
2021-08-25 07:40:33 -07:00
|
|
|
"github.com/cosmos/cosmos-sdk/types/tx"
|
2018-07-12 18:20:26 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
// File for storing in-package BaseApp optional functions,
|
|
|
|
// for options that need access to non-exported fields of the BaseApp
|
|
|
|
|
|
|
|
// SetPruning sets a pruning option on the multistore associated with the app
|
2019-01-09 07:06:22 -08:00
|
|
|
func SetPruning(opts sdk.PruningOptions) func(*BaseApp) {
|
2021-11-20 01:32:30 -08:00
|
|
|
return func(bapp *BaseApp) { bapp.cms.SetPruning(opts) }
|
2018-07-12 18:20:26 -07:00
|
|
|
}
|
2018-09-19 08:25:52 -07:00
|
|
|
|
2019-02-05 19:11:57 -08:00
|
|
|
// SetMinGasPrices returns an option that sets the minimum gas prices on the app.
|
2019-01-18 08:45:20 -08:00
|
|
|
func SetMinGasPrices(gasPricesStr string) func(*BaseApp) {
|
|
|
|
gasPrices, err := sdk.ParseDecCoins(gasPricesStr)
|
2018-09-19 08:25:52 -07:00
|
|
|
if err != nil {
|
2019-01-18 08:45:20 -08:00
|
|
|
panic(fmt.Sprintf("invalid minimum gas prices: %v", err))
|
2018-09-19 08:25:52 -07:00
|
|
|
}
|
2019-01-18 08:45:20 -08:00
|
|
|
|
2021-11-20 01:32:30 -08:00
|
|
|
return func(bapp *BaseApp) { bapp.setMinGasPrices(gasPrices) }
|
2018-09-19 08:25:52 -07:00
|
|
|
}
|
2018-09-26 06:17:46 -07:00
|
|
|
|
2019-09-09 07:08:10 -07:00
|
|
|
// SetHaltHeight returns a BaseApp option function that sets the halt block height.
|
|
|
|
func SetHaltHeight(blockHeight uint64) func(*BaseApp) {
|
2021-11-20 01:32:30 -08:00
|
|
|
return func(bapp *BaseApp) { bapp.setHaltHeight(blockHeight) }
|
2019-09-09 07:08:10 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// SetHaltTime returns a BaseApp option function that sets the halt block time.
|
|
|
|
func SetHaltTime(haltTime uint64) func(*BaseApp) {
|
2021-11-20 01:32:30 -08:00
|
|
|
return func(bapp *BaseApp) { bapp.setHaltTime(haltTime) }
|
2019-04-23 06:33:11 -07:00
|
|
|
}
|
|
|
|
|
2020-09-14 07:12:49 -07:00
|
|
|
// SetMinRetainBlocks returns a BaseApp option function that sets the minimum
|
|
|
|
// block retention height value when determining which heights to prune during
|
|
|
|
// ABCI Commit.
|
|
|
|
func SetMinRetainBlocks(minRetainBlocks uint64) func(*BaseApp) {
|
|
|
|
return func(bapp *BaseApp) { bapp.setMinRetainBlocks(minRetainBlocks) }
|
|
|
|
}
|
|
|
|
|
2020-07-05 09:56:17 -07:00
|
|
|
// SetTrace will turn on or off trace flag
|
|
|
|
func SetTrace(trace bool) func(*BaseApp) {
|
|
|
|
return func(app *BaseApp) { app.setTrace(trace) }
|
|
|
|
}
|
|
|
|
|
2020-08-20 09:19:16 -07:00
|
|
|
// SetIndexEvents provides a BaseApp option function that sets the events to index.
|
|
|
|
func SetIndexEvents(ie []string) func(*BaseApp) {
|
|
|
|
return func(app *BaseApp) { app.setIndexEvents(ie) }
|
|
|
|
}
|
|
|
|
|
2021-11-20 01:32:30 -08:00
|
|
|
// SetIAVLCacheSize provides a BaseApp option function that sets the size of IAVL cache.
|
|
|
|
func SetIAVLCacheSize(size int) func(*BaseApp) {
|
|
|
|
return func(bapp *BaseApp) { bapp.cms.SetIAVLCacheSize(size) }
|
|
|
|
}
|
|
|
|
|
2019-09-04 10:33:32 -07:00
|
|
|
// SetInterBlockCache provides a BaseApp option function that sets the
|
|
|
|
// inter-block cache.
|
|
|
|
func SetInterBlockCache(cache sdk.MultiStorePersistentCache) func(*BaseApp) {
|
|
|
|
return func(app *BaseApp) { app.setInterBlockCache(cache) }
|
|
|
|
}
|
|
|
|
|
2020-09-08 02:05:44 -07:00
|
|
|
// SetSnapshotInterval sets the snapshot interval.
|
|
|
|
func SetSnapshotInterval(interval uint64) func(*BaseApp) {
|
|
|
|
return func(app *BaseApp) { app.SetSnapshotInterval(interval) }
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetSnapshotKeepRecent sets the recent snapshots to keep.
|
|
|
|
func SetSnapshotKeepRecent(keepRecent uint32) func(*BaseApp) {
|
|
|
|
return func(app *BaseApp) { app.SetSnapshotKeepRecent(keepRecent) }
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetSnapshotStore sets the snapshot store.
|
|
|
|
func SetSnapshotStore(snapshotStore *snapshots.Store) func(*BaseApp) {
|
|
|
|
return func(app *BaseApp) { app.SetSnapshotStore(snapshotStore) }
|
|
|
|
}
|
|
|
|
|
2018-09-26 06:17:46 -07:00
|
|
|
func (app *BaseApp) SetName(name string) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetName() on sealed BaseApp")
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2018-09-26 06:17:46 -07:00
|
|
|
app.name = name
|
|
|
|
}
|
|
|
|
|
2020-04-16 08:10:39 -07:00
|
|
|
// SetParamStore sets a parameter store on the BaseApp.
|
|
|
|
func (app *BaseApp) SetParamStore(ps ParamStore) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetParamStore() on sealed BaseApp")
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2020-04-16 08:10:39 -07:00
|
|
|
app.paramStore = ps
|
|
|
|
}
|
|
|
|
|
2021-04-02 07:11:58 -07:00
|
|
|
// SetVersion sets the application's version string.
|
|
|
|
func (app *BaseApp) SetVersion(v string) {
|
2019-05-02 12:37:44 -07:00
|
|
|
if app.sealed {
|
2021-04-02 07:11:58 -07:00
|
|
|
panic("SetVersion() on sealed BaseApp")
|
2019-05-02 12:37:44 -07:00
|
|
|
}
|
2021-04-02 07:11:58 -07:00
|
|
|
app.version = v
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2021-04-02 07:11:58 -07:00
|
|
|
// SetProtocolVersion sets the application's protocol version
|
|
|
|
func (app *BaseApp) SetProtocolVersion(v uint64) {
|
2019-05-02 12:37:44 -07:00
|
|
|
app.appVersion = v
|
|
|
|
}
|
|
|
|
|
2018-09-26 06:17:46 -07:00
|
|
|
func (app *BaseApp) SetDB(db dbm.DB) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetDB() on sealed BaseApp")
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2018-09-26 06:17:46 -07:00
|
|
|
app.db = db
|
|
|
|
}
|
|
|
|
|
|
|
|
func (app *BaseApp) SetCMS(cms store.CommitMultiStore) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetEndBlocker() on sealed BaseApp")
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2018-09-26 06:17:46 -07:00
|
|
|
app.cms = cms
|
|
|
|
}
|
|
|
|
|
|
|
|
func (app *BaseApp) SetInitChainer(initChainer sdk.InitChainer) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetInitChainer() on sealed BaseApp")
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2018-09-26 06:17:46 -07:00
|
|
|
app.initChainer = initChainer
|
|
|
|
}
|
|
|
|
|
|
|
|
func (app *BaseApp) SetBeginBlocker(beginBlocker sdk.BeginBlocker) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetBeginBlocker() on sealed BaseApp")
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2018-09-26 06:17:46 -07:00
|
|
|
app.beginBlocker = beginBlocker
|
|
|
|
}
|
|
|
|
|
|
|
|
func (app *BaseApp) SetEndBlocker(endBlocker sdk.EndBlocker) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetEndBlocker() on sealed BaseApp")
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2018-09-26 06:17:46 -07:00
|
|
|
app.endBlocker = endBlocker
|
|
|
|
}
|
|
|
|
|
refactor!: BaseApp {Check,Deliver}Tx with middleware design (#9920)
<!--
The default pull request template is for types feat, fix, or refactor.
For other templates, add one of the following parameters to the url:
- template=docs.md
- template=other.md
-->
## Description
ref: #9585
This PR if the 1st step (out of 2) in the #9585 refactor. It transforms baseapp's ABCI {Check,Deliver}Tx into middleware stacks. A middleware is defined by the following interfaces:
```go
// types/tx package
type Handler interface {
CheckTx(ctx context.Context, tx sdk.Tx, req abci.RequestCheckTx) (abci.ResponseCheckTx, error)
DeliverTx(ctx context.Context, tx sdk.Tx, req abci.RequestDeliverTx) (abci.ResponseDeliverTx, error)
SimulateTx(ctx context.Context, tx sdk.Tx, req RequestSimulateTx) (ResponseSimulateTx, error)
}
type Middleware func(Handler) Handler
```
This Pr doesn't migrate antehandlers, but only baseapp's runTx and runMsgs as middlewares. It bundles antehandlers into one single middleware (for now).
More specifically, it introduces the 5 following middlewares:
| Middleware | Description |
| ----------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| RunMsgsTxMiddleware | This middleware replaces the old baseapp's `runMsgs`. |
| LegacyAnteMiddleware | This middleware is temporary, it bundles all antehandlers into one middleware. It's only created for the purpose of breaking the refactor into 2 pieces. **It will be removed in Part 2**, and each antehandler will be replaced by its own middleware. |
| IndexEventsTxMiddleware | This is a simple middleware that chooses which events to index in Tendermint. Replaces `baseapp.indexEvents` (which unfortunately still exists in baseapp too, because it's used to index Begin/EndBlock events) |
| RecoveryTxMiddleware | This index recovers from panics. It replaces baseapp.runTx's panic recovery. |
| GasTxMiddleware | This replaces the [`Setup`](https://github.com/cosmos/cosmos-sdk/blob/master/x/auth/ante/setup.go) Antehandler. It sets a GasMeter on sdk.Context. Note that before, GasMeter was set on sdk.Context inside the antehandlers, and there was some mess around the fact that antehandlers had their own panic recovery system so that the GasMeter could be read by baseapp's recovery system. Now, this mess is all removed: one middleware sets GasMeter, another one handles recovery. |
---
### Author Checklist
*All items are required. Please add a note to the item if the item is not applicable and
please add links to any relevant follow up issues.*
I have...
- [x] included the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title
- [x] added `!` to the type prefix if API or client breaking change
- [x] targeted the correct branch (see [PR Targeting](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#pr-targeting))
- [x] provided a link to the relevant issue or specification
- [ ] followed the guidelines for [building modules](https://github.com/cosmos/cosmos-sdk/blob/master/docs/building-modules)
- [x] included the necessary unit and integration [tests](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#testing)
- [x] added a changelog entry to `CHANGELOG.md`
- [x] included comments for [documenting Go code](https://blog.golang.org/godoc)
- [ ] updated the relevant documentation or specification
- [x] reviewed "Files changed" and left comments if necessary
- [ ] confirmed all CI checks have passed
### Reviewers Checklist
*All items are required. Please add a note if the item is not applicable and please add
your handle next to the items reviewed if you only reviewed selected items.*
I have...
- [ ] confirmed the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title
- [ ] confirmed `!` in the type prefix if API or client breaking change
- [ ] confirmed all author checklist items have been addressed
- [ ] reviewed state machine logic
- [ ] reviewed API design and naming
- [ ] reviewed documentation is accurate
- [ ] reviewed tests and test coverage
- [ ] manually tested (if applicable)
2021-08-25 07:40:33 -07:00
|
|
|
func (app *BaseApp) SetTxHandler(txHandler tx.Handler) {
|
2018-09-26 06:17:46 -07:00
|
|
|
if app.sealed {
|
refactor!: BaseApp {Check,Deliver}Tx with middleware design (#9920)
<!--
The default pull request template is for types feat, fix, or refactor.
For other templates, add one of the following parameters to the url:
- template=docs.md
- template=other.md
-->
## Description
ref: #9585
This PR if the 1st step (out of 2) in the #9585 refactor. It transforms baseapp's ABCI {Check,Deliver}Tx into middleware stacks. A middleware is defined by the following interfaces:
```go
// types/tx package
type Handler interface {
CheckTx(ctx context.Context, tx sdk.Tx, req abci.RequestCheckTx) (abci.ResponseCheckTx, error)
DeliverTx(ctx context.Context, tx sdk.Tx, req abci.RequestDeliverTx) (abci.ResponseDeliverTx, error)
SimulateTx(ctx context.Context, tx sdk.Tx, req RequestSimulateTx) (ResponseSimulateTx, error)
}
type Middleware func(Handler) Handler
```
This Pr doesn't migrate antehandlers, but only baseapp's runTx and runMsgs as middlewares. It bundles antehandlers into one single middleware (for now).
More specifically, it introduces the 5 following middlewares:
| Middleware | Description |
| ----------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| RunMsgsTxMiddleware | This middleware replaces the old baseapp's `runMsgs`. |
| LegacyAnteMiddleware | This middleware is temporary, it bundles all antehandlers into one middleware. It's only created for the purpose of breaking the refactor into 2 pieces. **It will be removed in Part 2**, and each antehandler will be replaced by its own middleware. |
| IndexEventsTxMiddleware | This is a simple middleware that chooses which events to index in Tendermint. Replaces `baseapp.indexEvents` (which unfortunately still exists in baseapp too, because it's used to index Begin/EndBlock events) |
| RecoveryTxMiddleware | This index recovers from panics. It replaces baseapp.runTx's panic recovery. |
| GasTxMiddleware | This replaces the [`Setup`](https://github.com/cosmos/cosmos-sdk/blob/master/x/auth/ante/setup.go) Antehandler. It sets a GasMeter on sdk.Context. Note that before, GasMeter was set on sdk.Context inside the antehandlers, and there was some mess around the fact that antehandlers had their own panic recovery system so that the GasMeter could be read by baseapp's recovery system. Now, this mess is all removed: one middleware sets GasMeter, another one handles recovery. |
---
### Author Checklist
*All items are required. Please add a note to the item if the item is not applicable and
please add links to any relevant follow up issues.*
I have...
- [x] included the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title
- [x] added `!` to the type prefix if API or client breaking change
- [x] targeted the correct branch (see [PR Targeting](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#pr-targeting))
- [x] provided a link to the relevant issue or specification
- [ ] followed the guidelines for [building modules](https://github.com/cosmos/cosmos-sdk/blob/master/docs/building-modules)
- [x] included the necessary unit and integration [tests](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#testing)
- [x] added a changelog entry to `CHANGELOG.md`
- [x] included comments for [documenting Go code](https://blog.golang.org/godoc)
- [ ] updated the relevant documentation or specification
- [x] reviewed "Files changed" and left comments if necessary
- [ ] confirmed all CI checks have passed
### Reviewers Checklist
*All items are required. Please add a note if the item is not applicable and please add
your handle next to the items reviewed if you only reviewed selected items.*
I have...
- [ ] confirmed the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title
- [ ] confirmed `!` in the type prefix if API or client breaking change
- [ ] confirmed all author checklist items have been addressed
- [ ] reviewed state machine logic
- [ ] reviewed API design and naming
- [ ] reviewed documentation is accurate
- [ ] reviewed tests and test coverage
- [ ] manually tested (if applicable)
2021-08-25 07:40:33 -07:00
|
|
|
panic("SetTxHandler() on sealed BaseApp")
|
2018-09-26 06:17:46 -07:00
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
refactor!: BaseApp {Check,Deliver}Tx with middleware design (#9920)
<!--
The default pull request template is for types feat, fix, or refactor.
For other templates, add one of the following parameters to the url:
- template=docs.md
- template=other.md
-->
## Description
ref: #9585
This PR if the 1st step (out of 2) in the #9585 refactor. It transforms baseapp's ABCI {Check,Deliver}Tx into middleware stacks. A middleware is defined by the following interfaces:
```go
// types/tx package
type Handler interface {
CheckTx(ctx context.Context, tx sdk.Tx, req abci.RequestCheckTx) (abci.ResponseCheckTx, error)
DeliverTx(ctx context.Context, tx sdk.Tx, req abci.RequestDeliverTx) (abci.ResponseDeliverTx, error)
SimulateTx(ctx context.Context, tx sdk.Tx, req RequestSimulateTx) (ResponseSimulateTx, error)
}
type Middleware func(Handler) Handler
```
This Pr doesn't migrate antehandlers, but only baseapp's runTx and runMsgs as middlewares. It bundles antehandlers into one single middleware (for now).
More specifically, it introduces the 5 following middlewares:
| Middleware | Description |
| ----------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| RunMsgsTxMiddleware | This middleware replaces the old baseapp's `runMsgs`. |
| LegacyAnteMiddleware | This middleware is temporary, it bundles all antehandlers into one middleware. It's only created for the purpose of breaking the refactor into 2 pieces. **It will be removed in Part 2**, and each antehandler will be replaced by its own middleware. |
| IndexEventsTxMiddleware | This is a simple middleware that chooses which events to index in Tendermint. Replaces `baseapp.indexEvents` (which unfortunately still exists in baseapp too, because it's used to index Begin/EndBlock events) |
| RecoveryTxMiddleware | This index recovers from panics. It replaces baseapp.runTx's panic recovery. |
| GasTxMiddleware | This replaces the [`Setup`](https://github.com/cosmos/cosmos-sdk/blob/master/x/auth/ante/setup.go) Antehandler. It sets a GasMeter on sdk.Context. Note that before, GasMeter was set on sdk.Context inside the antehandlers, and there was some mess around the fact that antehandlers had their own panic recovery system so that the GasMeter could be read by baseapp's recovery system. Now, this mess is all removed: one middleware sets GasMeter, another one handles recovery. |
---
### Author Checklist
*All items are required. Please add a note to the item if the item is not applicable and
please add links to any relevant follow up issues.*
I have...
- [x] included the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title
- [x] added `!` to the type prefix if API or client breaking change
- [x] targeted the correct branch (see [PR Targeting](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#pr-targeting))
- [x] provided a link to the relevant issue or specification
- [ ] followed the guidelines for [building modules](https://github.com/cosmos/cosmos-sdk/blob/master/docs/building-modules)
- [x] included the necessary unit and integration [tests](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#testing)
- [x] added a changelog entry to `CHANGELOG.md`
- [x] included comments for [documenting Go code](https://blog.golang.org/godoc)
- [ ] updated the relevant documentation or specification
- [x] reviewed "Files changed" and left comments if necessary
- [ ] confirmed all CI checks have passed
### Reviewers Checklist
*All items are required. Please add a note if the item is not applicable and please add
your handle next to the items reviewed if you only reviewed selected items.*
I have...
- [ ] confirmed the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title
- [ ] confirmed `!` in the type prefix if API or client breaking change
- [ ] confirmed all author checklist items have been addressed
- [ ] reviewed state machine logic
- [ ] reviewed API design and naming
- [ ] reviewed documentation is accurate
- [ ] reviewed tests and test coverage
- [ ] manually tested (if applicable)
2021-08-25 07:40:33 -07:00
|
|
|
app.txHandler = txHandler
|
2018-09-26 06:17:46 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
func (app *BaseApp) SetAddrPeerFilter(pf sdk.PeerFilter) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetAddrPeerFilter() on sealed BaseApp")
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2018-09-26 06:17:46 -07:00
|
|
|
app.addrPeerFilter = pf
|
|
|
|
}
|
|
|
|
|
2019-02-07 17:52:24 -08:00
|
|
|
func (app *BaseApp) SetIDPeerFilter(pf sdk.PeerFilter) {
|
2018-09-26 06:17:46 -07:00
|
|
|
if app.sealed {
|
2019-02-07 17:52:24 -08:00
|
|
|
panic("SetIDPeerFilter() on sealed BaseApp")
|
2018-09-26 06:17:46 -07:00
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2019-02-07 17:52:24 -08:00
|
|
|
app.idPeerFilter = pf
|
2018-09-26 06:17:46 -07:00
|
|
|
}
|
|
|
|
|
2018-11-27 00:14:22 -08:00
|
|
|
func (app *BaseApp) SetFauxMerkleMode() {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetFauxMerkleMode() on sealed BaseApp")
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2018-11-27 00:14:22 -08:00
|
|
|
app.fauxMerkleMode = true
|
|
|
|
}
|
2019-08-06 05:59:22 -07:00
|
|
|
|
|
|
|
// SetCommitMultiStoreTracer sets the store tracer on the BaseApp's underlying
|
|
|
|
// CommitMultiStore.
|
|
|
|
func (app *BaseApp) SetCommitMultiStoreTracer(w io.Writer) {
|
|
|
|
app.cms.SetTracer(w)
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetStoreLoader allows us to customize the rootMultiStore initialization.
|
|
|
|
func (app *BaseApp) SetStoreLoader(loader StoreLoader) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetStoreLoader() on sealed BaseApp")
|
|
|
|
}
|
2020-05-02 12:26:59 -07:00
|
|
|
|
2019-08-06 05:59:22 -07:00
|
|
|
app.storeLoader = loader
|
|
|
|
}
|
2020-01-04 11:50:38 -08:00
|
|
|
|
2020-09-08 02:05:44 -07:00
|
|
|
// SetSnapshotStore sets the snapshot store.
|
|
|
|
func (app *BaseApp) SetSnapshotStore(snapshotStore *snapshots.Store) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetSnapshotStore() on sealed BaseApp")
|
|
|
|
}
|
2020-11-03 14:02:27 -08:00
|
|
|
if snapshotStore == nil {
|
|
|
|
app.snapshotManager = nil
|
|
|
|
return
|
|
|
|
}
|
2020-09-08 02:05:44 -07:00
|
|
|
app.snapshotManager = snapshots.NewManager(snapshotStore, app.cms)
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetSnapshotInterval sets the snapshot interval.
|
|
|
|
func (app *BaseApp) SetSnapshotInterval(snapshotInterval uint64) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetSnapshotInterval() on sealed BaseApp")
|
|
|
|
}
|
|
|
|
app.snapshotInterval = snapshotInterval
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetSnapshotKeepRecent sets the number of recent snapshots to keep.
|
|
|
|
func (app *BaseApp) SetSnapshotKeepRecent(snapshotKeepRecent uint32) {
|
|
|
|
if app.sealed {
|
|
|
|
panic("SetSnapshotKeepRecent() on sealed BaseApp")
|
|
|
|
}
|
|
|
|
app.snapshotKeepRecent = snapshotKeepRecent
|
|
|
|
}
|
2020-10-15 06:07:59 -07:00
|
|
|
|
|
|
|
// SetInterfaceRegistry sets the InterfaceRegistry.
|
|
|
|
func (app *BaseApp) SetInterfaceRegistry(registry types.InterfaceRegistry) {
|
|
|
|
app.interfaceRegistry = registry
|
|
|
|
app.grpcQueryRouter.SetInterfaceRegistry(registry)
|
|
|
|
}
|
2021-10-24 14:37:37 -07:00
|
|
|
|
|
|
|
// SetStreamingService is used to set a streaming service into the BaseApp hooks and load the listeners into the multistore
|
|
|
|
func (app *BaseApp) SetStreamingService(s StreamingService) {
|
|
|
|
// add the listeners for each StoreKey
|
|
|
|
for key, lis := range s.Listeners() {
|
|
|
|
app.cms.AddListeners(key, lis)
|
|
|
|
}
|
|
|
|
// register the StreamingService within the BaseApp
|
|
|
|
// BaseApp will pass BeginBlock, DeliverTx, and EndBlock requests and responses to the streaming services to update their ABCI context
|
|
|
|
app.abciListeners = append(app.abciListeners, s)
|
|
|
|
}
|