unregister x/metrics & call BeginBlocker directly (#1691)

registering x/metrics to the module manager breaks the AppHash because
its consensus version is added to the ModuleVersionMap which affects the
AppHash.

this commit unregisters the module so it is not consensus breaking.
instead, it directly calls the BeginBlock before running the module
manager's.
This commit is contained in:
Robert Pirtle 2023-08-28 12:00:25 -07:00 committed by GitHub
parent f898e3aff4
commit 35358df72a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -218,7 +218,6 @@ var (
router.AppModuleBasic{}, router.AppModuleBasic{},
mint.AppModuleBasic{}, mint.AppModuleBasic{},
community.AppModuleBasic{}, community.AppModuleBasic{},
metrics.AppModuleBasic{},
) )
// module account permissions // module account permissions
@ -334,6 +333,12 @@ type App struct {
// configurator // configurator
configurator module.Configurator configurator module.Configurator
// backported x/metrics Metrics
// to prevent AppHash mismatch, the module is not registered to the module manager.
// instead, the module's BeginBlocker is called directly.
// this way, its consensus version has no bearing on the ModuleVersionMap included in the AppHash.
metrics *metricstypes.Metrics
} }
func init() { func init() {
@ -387,6 +392,7 @@ func NewApp(
keys: keys, keys: keys,
tkeys: tkeys, tkeys: tkeys,
memKeys: memKeys, memKeys: memKeys,
metrics: metricstypes.NewMetrics(options.TelemetryOptions),
} }
// init params keeper and subspaces // init params keeper and subspaces
@ -794,12 +800,10 @@ func NewApp(
// nil InflationCalculationFn, use SDK's default inflation function // nil InflationCalculationFn, use SDK's default inflation function
mint.NewAppModule(appCodec, app.mintKeeper, app.accountKeeper, nil), mint.NewAppModule(appCodec, app.mintKeeper, app.accountKeeper, nil),
community.NewAppModule(app.communityKeeper, app.accountKeeper), community.NewAppModule(app.communityKeeper, app.accountKeeper),
metrics.NewAppModule(options.TelemetryOptions),
) )
// Warning: Some begin blockers must run before others. Ensure the dependencies are understood before modifying this list. // Warning: Some begin blockers must run before others. Ensure the dependencies are understood before modifying this list.
app.mm.SetOrderBeginBlockers( app.mm.SetOrderBeginBlockers(
metricstypes.ModuleName,
// Upgrade begin blocker runs migrations on the first block after an upgrade. It should run before any other module. // Upgrade begin blocker runs migrations on the first block after an upgrade. It should run before any other module.
upgradetypes.ModuleName, upgradetypes.ModuleName,
// Capability begin blocker runs non state changing initialization. // Capability begin blocker runs non state changing initialization.
@ -888,7 +892,6 @@ func NewApp(
routertypes.ModuleName, routertypes.ModuleName,
minttypes.ModuleName, minttypes.ModuleName,
communitytypes.ModuleName, communitytypes.ModuleName,
metricstypes.ModuleName,
) )
// Warning: Some init genesis methods must run before others. Ensure the dependencies are understood before modifying this list // Warning: Some init genesis methods must run before others. Ensure the dependencies are understood before modifying this list
@ -930,7 +933,6 @@ func NewApp(
validatorvestingtypes.ModuleName, validatorvestingtypes.ModuleName,
liquidtypes.ModuleName, liquidtypes.ModuleName,
routertypes.ModuleName, routertypes.ModuleName,
metricstypes.ModuleName,
) )
app.mm.RegisterInvariants(&app.crisisKeeper) app.mm.RegisterInvariants(&app.crisisKeeper)
@ -1018,6 +1020,10 @@ func (app *App) RegisterServices(cfg module.Configurator) {
// BeginBlocker contains app specific logic for the BeginBlock abci call. // BeginBlocker contains app specific logic for the BeginBlock abci call.
func (app *App) BeginBlocker(ctx sdk.Context, req abci.RequestBeginBlock) abci.ResponseBeginBlock { func (app *App) BeginBlocker(ctx sdk.Context, req abci.RequestBeginBlock) abci.ResponseBeginBlock {
// call the metrics BeginBlocker directly instead of registering the module to the module manager.
// all consensus versions of modules registrered to the moduel manager contribute to the AppHash.
// to prevent the backport of x/metrics from being consensus breaking, it is called directly.
metrics.BeginBlocker(ctx, app.metrics)
return app.mm.BeginBlock(ctx, req) return app.mm.BeginBlock(ctx, req)
} }