From 2047fe71396629620afd0023f5118bfc896ca53e Mon Sep 17 00:00:00 2001 From: Daisuke Iuchi <42408108+da1suk8@users.noreply.github.com> Date: Fri, 26 Apr 2024 17:31:35 +0900 Subject: [PATCH] refactor: improve Stargate msg handling with denylist --- x/wasm/keeper/msg_dispatcher.go | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/x/wasm/keeper/msg_dispatcher.go b/x/wasm/keeper/msg_dispatcher.go index bb3df7f4f1..98a0f258f2 100644 --- a/x/wasm/keeper/msg_dispatcher.go +++ b/x/wasm/keeper/msg_dispatcher.go @@ -83,14 +83,14 @@ func (d MessageDispatcher) DispatchSubmessages(ctx sdk.Context, contractAddr sdk var rsp []byte for _, msg := range msgs { - // Prevent the use of fswap and fbridge module in Submessages + // Prevent the use of specific modules in Submessages // https://github.com/Finschia/finschia-sdk/pull/1336, https://github.com/Finschia/finschia-sdk/pull/1340 if stargateMsg := msg.Msg.Stargate; stargateMsg != nil { - if strings.HasPrefix(stargateMsg.TypeURL, "/lbm.fswap.v1") { - return nil, sdkerrors.Wrap(types.ErrUnsupportedForContract, "fswap not supported by Stargate") - } - if strings.HasPrefix(stargateMsg.TypeURL, "/lbm.fbridge.v1") { - return nil, sdkerrors.Wrap(types.ErrUnsupportedForContract, "fbridge not supported by Stargate") + deniedModules := []string{"/lbm.fswap.v1", "/lbm.fbridge.v1"} + for _, moduleName := range deniedModules { + if strings.HasPrefix(stargateMsg.TypeURL, moduleName) { + return nil, sdkerrors.Wrap(types.ErrUnsupportedForContract, moduleName+" not supported by Stargate") + } } }