From 2341cdd75a5f00f56a2e0eef028c15d6589f67dc Mon Sep 17 00:00:00 2001 From: Alex Johnson Date: Mon, 30 Sep 2024 14:52:50 -0400 Subject: [PATCH] fix: clean up market map hooks (#778) --- x/marketmap/keeper/msg_server.go | 4 ++++ x/marketmap/types/hooks.go | 8 ++++---- x/marketmap/types/mocks/MarketMapHooks.go | 10 +++++----- x/oracle/keeper/hooks.go | 5 +++-- 4 files changed, 16 insertions(+), 11 deletions(-) diff --git a/x/marketmap/keeper/msg_server.go b/x/marketmap/keeper/msg_server.go index a58f4c8c4..9433695a8 100644 --- a/x/marketmap/keeper/msg_server.go +++ b/x/marketmap/keeper/msg_server.go @@ -283,6 +283,10 @@ func (ms msgServer) RemoveMarkets( ctx.Logger().Info(fmt.Sprintf("deleted market %s", market)) deletedMarkets = append(deletedMarkets, market) } + + if err := ms.k.hooks.AfterMarketRemoved(ctx, market); err != nil { + return nil, fmt.Errorf("unable to run market removal hook: %w", err) + } } // check if the resulting state is valid: it may not be valid if the removed market is used as a normalization pair diff --git a/x/marketmap/types/hooks.go b/x/marketmap/types/hooks.go index 90b70c769..276d55591 100644 --- a/x/marketmap/types/hooks.go +++ b/x/marketmap/types/hooks.go @@ -16,7 +16,7 @@ type MarketMapHooks interface { AfterMarketGenesis(ctx sdk.Context, tickers map[string]Market) error // AfterMarketRemoved is called after a market is removed. - AfterMarketRemoved(ctx sdk.Context, market Market) error + AfterMarketRemoved(ctx sdk.Context, key string) error } var _ MarketMapHooks = &MultiMarketMapHooks{} @@ -58,9 +58,9 @@ func (mh MultiMarketMapHooks) AfterMarketGenesis(ctx sdk.Context, markets map[st } // AfterMarketRemoved calls all AfterMarketRemoved hooks registered to the MultiMarketMapHooks. -func (mh MultiMarketMapHooks) AfterMarketRemoved(ctx sdk.Context, market Market) error { +func (mh MultiMarketMapHooks) AfterMarketRemoved(ctx sdk.Context, key string) error { for i := range mh { - if err := mh[i].AfterMarketRemoved(ctx, market); err != nil { + if err := mh[i].AfterMarketRemoved(ctx, key); err != nil { return err } } @@ -88,6 +88,6 @@ func (n *NoopMarketMapHooks) AfterMarketGenesis(_ sdk.Context, _ map[string]Mark return nil } -func (n *NoopMarketMapHooks) AfterMarketRemoved(_ sdk.Context, _ Market) error { +func (n *NoopMarketMapHooks) AfterMarketRemoved(_ sdk.Context, _ string) error { return nil } diff --git a/x/marketmap/types/mocks/MarketMapHooks.go b/x/marketmap/types/mocks/MarketMapHooks.go index 9b29faa9f..b289a2cac 100644 --- a/x/marketmap/types/mocks/MarketMapHooks.go +++ b/x/marketmap/types/mocks/MarketMapHooks.go @@ -51,17 +51,17 @@ func (_m *MarketMapHooks) AfterMarketGenesis(ctx types.Context, tickers map[stri return r0 } -// AfterMarketRemoved provides a mock function with given fields: ctx, market -func (_m *MarketMapHooks) AfterMarketRemoved(ctx types.Context, market marketmaptypes.Market) error { - ret := _m.Called(ctx, market) +// AfterMarketRemoved provides a mock function with given fields: ctx, key +func (_m *MarketMapHooks) AfterMarketRemoved(ctx types.Context, key string) error { + ret := _m.Called(ctx, key) if len(ret) == 0 { panic("no return value specified for AfterMarketRemoved") } var r0 error - if rf, ok := ret.Get(0).(func(types.Context, marketmaptypes.Market) error); ok { - r0 = rf(ctx, market) + if rf, ok := ret.Get(0).(func(types.Context, string) error); ok { + r0 = rf(ctx, key) } else { r0 = ret.Error(0) } diff --git a/x/oracle/keeper/hooks.go b/x/oracle/keeper/hooks.go index a65540c3e..69464e797 100644 --- a/x/oracle/keeper/hooks.go +++ b/x/oracle/keeper/hooks.go @@ -49,7 +49,8 @@ func (h Hooks) AfterMarketGenesis(ctx sdk.Context, markets map[string]marketmapt // AfterMarketRemoved is the marketmap hook for x/oracle that is run after a market is removed in // the marketmap. -func (h Hooks) AfterMarketRemoved(ctx sdk.Context, market marketmaptypes.Market) error { - ctx.Logger().Info(fmt.Sprintf("market %s removed. retaining x/oracle state if it exists", market.Ticker.String())) +func (h Hooks) AfterMarketRemoved(ctx sdk.Context, key string) error { + ctx.Logger().Info(fmt.Sprintf("market %s removed. retaining x/oracle state if it exists", key)) + return nil }