Skip to content

Commit

Permalink
refactor: removed unutilized and deprecated properties in AxelarApp
Browse files Browse the repository at this point in the history
The following properties were removed from the AxelarApp struct due to them either being unused, or deprecated: 'legacyAmino', 'invCheckPeriod', 'ibcKeeper', 'evidenceKeeper', 'feegrantKeeper', 'tkeys', 'memKeys' and 'configurator'. Also, each keeper is now defined closer to its corresponding usage throughout the app.go file. Consequently, logger parameter is removed from the NewAppModule in module.go file as it is unused. Simplification aims for better readability and maintenance of the codebase.
  • Loading branch information
cgorenflo committed Oct 24, 2023
1 parent c4dd592 commit 02b39fb
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 77 deletions.
94 changes: 35 additions & 59 deletions app/app.go
Original file line number Diff line number Diff line change
Expand Up @@ -191,33 +191,21 @@ func init() {
type AxelarApp struct {
*bam.BaseApp

legacyAmino *codec.LegacyAmino
appCodec codec.Codec
interfaceRegistry types.InterfaceRegistry

invCheckPeriod uint

// necessery keepers for export
stakingKeeper stakingkeeper.Keeper
crisisKeeper crisiskeeper.Keeper
distrKeeper distrkeeper.Keeper
slashingKeeper slashingkeeper.Keeper
ibcKeeper *ibckeeper.Keeper
evidenceKeeper evidencekeeper.Keeper
transferKeeper ibctransferkeeper.Keeper
capabilityKeeper *capabilitykeeper.Keeper
feegrantKeeper feegrantkeeper.Keeper
stakingKeeper stakingkeeper.Keeper
crisisKeeper crisiskeeper.Keeper
distrKeeper distrkeeper.Keeper
slashingKeeper slashingkeeper.Keeper

// keys to access the substores
keys map[string]*sdk.KVStoreKey
tkeys map[string]*sdk.TransientStoreKey
memKeys map[string]*sdk.MemoryStoreKey
keys map[string]*sdk.KVStoreKey

mm *module.Manager
paramsKeeper paramskeeper.Keeper
upgradeKeeper upgradekeeper.Keeper

configurator module.Configurator
}

// NewAxelarApp is a constructor function for axelar
Expand Down Expand Up @@ -279,13 +267,9 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest

var app = &AxelarApp{
BaseApp: bApp,
legacyAmino: legacyAmino,
appCodec: appCodec,
interfaceRegistry: interfaceRegistry,
invCheckPeriod: invCheckPeriod,
keys: keys,
tkeys: tkeys,
memKeys: memKeys,
}

paramsK := initParamsKeeper(appCodec, legacyAmino, keys[paramstypes.StoreKey], tkeys[paramstypes.TStoreKey])
Expand Down Expand Up @@ -333,10 +317,8 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
evidenceK := evidencekeeper.NewKeeper(
appCodec, keys[evidencetypes.StoreKey], &stakingK, slashingK,
)
app.evidenceKeeper = *evidenceK

feegrantK := feegrantkeeper.NewKeeper(appCodec, keys[feegrant.StoreKey], accountK)
app.feegrantKeeper = feegrantK

// register the staking hooks
// NOTE: stakingKeeper above is passed by reference, so that it will contain these hooks
Expand All @@ -346,20 +328,20 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
app.stakingKeeper = stakingK

// add capability keeper and ScopeToModule for ibc module
app.capabilityKeeper = capabilitykeeper.NewKeeper(appCodec, keys[capabilitytypes.StoreKey], memKeys[capabilitytypes.MemStoreKey])
capabilityKeeper := capabilitykeeper.NewKeeper(appCodec, keys[capabilitytypes.StoreKey], memKeys[capabilitytypes.MemStoreKey])

// grant capabilities for the ibc and ibc-transfer modules
scopedIBCK := app.capabilityKeeper.ScopeToModule(ibchost.ModuleName)
scopedTransferK := app.capabilityKeeper.ScopeToModule(ibctransfertypes.ModuleName)
scopedIBCK := capabilityKeeper.ScopeToModule(ibchost.ModuleName)
scopedTransferK := capabilityKeeper.ScopeToModule(ibctransfertypes.ModuleName)

// Create IBC Keeper
app.ibcKeeper = ibckeeper.NewKeeper(
ibcKeeper := ibckeeper.NewKeeper(
appCodec, keys[ibchost.StoreKey], app.getSubspace(ibchost.ModuleName), app.stakingKeeper, upgradeK, scopedIBCK,
)

// Custom axelarnet/evm/nexus keepers
axelarnetK := axelarnetKeeper.NewKeeper(
appCodec, keys[axelarnetTypes.StoreKey], app.getSubspace(axelarnetTypes.ModuleName), app.ibcKeeper.ChannelKeeper, app.feegrantKeeper,
appCodec, keys[axelarnetTypes.StoreKey], app.getSubspace(axelarnetTypes.ModuleName), ibcKeeper.ChannelKeeper, feegrantK,
)

evmK := evmKeeper.NewKeeper(
Expand All @@ -385,7 +367,7 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
// After this, the wasm keeper is required to be set on WasmHooks

// Create IBC rate limiter
rateLimiter := axelarnet.NewRateLimiter(axelarnetK, app.ibcKeeper.ChannelKeeper, nexusK)
rateLimiter := axelarnet.NewRateLimiter(axelarnetK, ibcKeeper.ChannelKeeper, nexusK)
var ibcHooksMiddleware ibchooks.ICS4Middleware
var ics4Wrapper ibctransfertypes.ICS4Wrapper
var wasmHooks ibchooks.WasmHooks
Expand All @@ -407,24 +389,24 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
}

// Create Transfer Keepers
app.transferKeeper = ibctransferkeeper.NewKeeper(
transferKeeper := ibctransferkeeper.NewKeeper(
appCodec, keys[ibctransfertypes.StoreKey], app.getSubspace(ibctransfertypes.ModuleName),
// Use the IBC middleware stack
ics4Wrapper,
app.ibcKeeper.ChannelKeeper, &app.ibcKeeper.PortKeeper,
ibcKeeper.ChannelKeeper, &ibcKeeper.PortKeeper,
accountK, bankK, scopedTransferK,
)

// IBC Transfer Stack: RecvPacket
//
// Packet originates from core IBC and goes down to app, the flow is the other way
// channel.RecvPacket -> axelarnet.OnRecvPacket (transfer, GMP, and rate limit handler) -> ibc_hooks.OnRecvPacket -> transfer.OnRecvPacket
var transferStack porttypes.IBCModule = transfer.NewIBCModule(app.transferKeeper)
var transferStack porttypes.IBCModule = transfer.NewIBCModule(transferKeeper)
if IsWasmEnabled() {
transferStack = ibchooks.NewIBCMiddleware(transferStack, &ibcHooksMiddleware)
}

ibcK := axelarnetKeeper.NewIBCKeeper(axelarnetK, app.transferKeeper, app.ibcKeeper.ChannelKeeper)
ibcK := axelarnetKeeper.NewIBCKeeper(axelarnetK, transferKeeper, ibcKeeper.ChannelKeeper)
axelarnetModule := axelarnet.NewAppModule(axelarnetK, nexusK, axelarbankkeeper.NewBankKeeper(bankK), accountK, ibcK, transferStack, rateLimiter, logger)

// Create static IBC router, add axelarnet module as the IBC transfer route, and seal it
Expand Down Expand Up @@ -468,7 +450,7 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
panic(fmt.Sprintf("error while reading wasm config: %s", err))
}

scopedWasmK := app.capabilityKeeper.ScopeToModule(wasm.ModuleName)
scopedWasmK := capabilityKeeper.ScopeToModule(wasm.ModuleName)
// The last arguments can contain custom message handlers, and custom query handlers,
// if we want to allow any custom callbacks
wasmOpts = append(wasmOpts, wasmkeeper.WithMessageHandlerDecorator(func(old wasmkeeper.Messenger) wasmkeeper.Messenger {
Expand All @@ -482,11 +464,11 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
bankK,
stakingK,
distrK,
app.ibcKeeper.ChannelKeeper,
app.ibcKeeper.ChannelKeeper,
&app.ibcKeeper.PortKeeper,
ibcKeeper.ChannelKeeper,
ibcKeeper.ChannelKeeper,
&ibcKeeper.PortKeeper,
scopedWasmK,
app.transferKeeper,
transferKeeper,
app.MsgServiceRouter(),
app.GRPCQueryRouter(),
wasmDir,
Expand All @@ -501,23 +483,23 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
}

// Create wasm ibc stack
var wasmStack porttypes.IBCModule = wasm.NewIBCHandler(wasmK, app.ibcKeeper.ChannelKeeper, app.ibcKeeper.ChannelKeeper)
var wasmStack porttypes.IBCModule = wasm.NewIBCHandler(wasmK, ibcKeeper.ChannelKeeper, ibcKeeper.ChannelKeeper)
ibcRouter.AddRoute(wasm.ModuleName, wasmStack)

// set the contract keeper for the Ics20WasmHooks
wasmHooks.ContractKeeper = wasmkeeper.NewDefaultPermissionKeeper(wasmK)
}

// Finalize the IBC router
app.ibcKeeper.SetRouter(ibcRouter)
ibcKeeper.SetRouter(ibcRouter)

// Add governance proposal hooks
govRouter := govtypes.NewRouter()
govRouter.AddRoute(govtypes.RouterKey, govtypes.ProposalHandler).
AddRoute(paramproposal.RouterKey, params.NewParamChangeProposalHandler(paramsK)).
AddRoute(distrtypes.RouterKey, distr.NewCommunityPoolSpendProposalHandler(distrK)).
AddRoute(upgradetypes.RouterKey, upgrade.NewSoftwareUpgradeProposalHandler(upgradeK)).
AddRoute(ibcclienttypes.RouterKey, ibcclient.NewClientProposalHandler(app.ibcKeeper.ClientKeeper)).
AddRoute(ibcclienttypes.RouterKey, ibcclient.NewClientProposalHandler(ibcKeeper.ClientKeeper)).
AddRoute(axelarnetTypes.RouterKey, axelarnet.NewProposalHandler(axelarnetK, nexusK, accountK))

if IsWasmEnabled() {
Expand All @@ -540,10 +522,12 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
panic(fmt.Errorf("invalid app version %s", app.Version()))
}

// todo: change order of commands so this doesn't have to be defined before initialization
var configurator module.Configurator
upgradeK.SetUpgradeHandler(
upgradeName,
func(ctx sdk.Context, _ upgradetypes.Plan, fromVM module.VersionMap) (module.VersionMap, error) {
return app.mm.RunMigrations(ctx, app.configurator, fromVM)
return app.mm.RunMigrations(ctx, configurator, fromVM)
},
)
app.upgradeKeeper = upgradeK
Expand Down Expand Up @@ -589,7 +573,7 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
upgrade.NewAppModule(upgradeK),
evidence.NewAppModule(*evidenceK),
params.NewAppModule(paramsK),
capability.NewAppModule(appCodec, *app.capabilityKeeper),
capability.NewAppModule(appCodec, *capabilityKeeper),
}

// wasm module needs to be added in a specific order
Expand All @@ -602,17 +586,17 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
}

appModules = append(appModules, []module.AppModule{
evidence.NewAppModule(app.evidenceKeeper),
ibc.NewAppModule(app.ibcKeeper),
transfer.NewAppModule(app.transferKeeper),
evidence.NewAppModule(*evidenceK),
ibc.NewAppModule(ibcKeeper),
transfer.NewAppModule(transferKeeper),
feegrantmodule.NewAppModule(appCodec, accountK, bankK, feegrantK, app.interfaceRegistry),

snapshot.NewAppModule(snapK),
multisig.NewAppModule(multisigK, stakingK, slashingK, snapK, rewardK, nexusK),
tss.NewAppModule(tssK, snapK, nexusK, stakingK, multisigK),
vote.NewAppModule(votingK),
nexus.NewAppModule(nexusK, snapK, slashingK, stakingK, axelarnetK, rewardK),
evm.NewAppModule(evmK, votingK, nexusK, snapK, stakingK, slashingK, multisigK, logger),
evm.NewAppModule(evmK, votingK, nexusK, snapK, stakingK, slashingK, multisigK),
axelarnetModule,
reward.NewAppModule(rewardK, nexusK, mintK, stakingK, slashingK, multisigK, snapK, bankK, bApp.MsgServiceRouter(), bApp.Router()),
permission.NewAppModule(permissionK),
Expand Down Expand Up @@ -796,8 +780,8 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest

// register all module routes and module queriers
app.mm.RegisterRoutes(app.Router(), app.QueryRouter(), legacyAmino)
app.configurator = module.NewConfigurator(app.appCodec, app.MsgServiceRouter(), app.GRPCQueryRouter())
app.mm.RegisterServices(app.configurator)
configurator = module.NewConfigurator(app.appCodec, app.MsgServiceRouter(), app.GRPCQueryRouter())
app.mm.RegisterServices(configurator)

// initialize stores
app.MountKVStores(keys)
Expand Down Expand Up @@ -839,7 +823,7 @@ func NewAxelarApp(logger log.Logger, db dbm.DB, traceStore io.Writer, loadLatest
ante.NewCheckRefundFeeDecorator(app.interfaceRegistry, accountK, stakingK, snapK, rewardK),
ante.NewCheckProxy(snapK),
ante.NewRestrictedTx(permissionK),
ibcante.NewAnteDecorator(app.ibcKeeper),
ibcante.NewAnteDecorator(ibcKeeper),
)

anteHandler := sdk.ChainAnteDecorators(
Expand Down Expand Up @@ -931,14 +915,6 @@ func (app *AxelarApp) LoadHeight(height int64) error {
return app.LoadVersion(height)
}

// LegacyAmino returns AxelarApp's amino codec.
//
// NOTE: This is solely to be used for testing purposes as it may be desirable
// for modules to register their own custom testing types.
func (app *AxelarApp) LegacyAmino() *codec.LegacyAmino {
return app.legacyAmino
}

// AppCodec returns AxelarApp's app codec.
//
// NOTE: This is solely to be used for testing purposes as it may be desirable
Expand Down Expand Up @@ -1008,7 +984,7 @@ func GetModuleBasics() module.BasicManager {
return ModuleBasics
}

wasmProposals := []govclient.ProposalHandler{}
var wasmProposals []govclient.ProposalHandler
if IsWasmEnabled() {
wasmProposals = wasmclient.ProposalHandlers
}
Expand Down
24 changes: 6 additions & 18 deletions x/evm/module.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,11 @@ import (
"encoding/json"
"fmt"

"github.com/axelarnetwork/axelar-core/utils"
"github.com/axelarnetwork/axelar-core/x/evm/client/cli"
"github.com/axelarnetwork/axelar-core/x/evm/client/rest"
"github.com/axelarnetwork/axelar-core/x/evm/keeper"
"github.com/axelarnetwork/axelar-core/x/evm/types"
"github.com/cosmos/cosmos-sdk/client"
"github.com/cosmos/cosmos-sdk/codec"
cdctypes "github.com/cosmos/cosmos-sdk/codec/types"
Expand All @@ -14,13 +19,6 @@ import (
"github.com/grpc-ecosystem/grpc-gateway/runtime"
"github.com/spf13/cobra"
abci "github.com/tendermint/tendermint/abci/types"
"github.com/tendermint/tendermint/libs/log"

"github.com/axelarnetwork/axelar-core/utils"
"github.com/axelarnetwork/axelar-core/x/evm/client/cli"
"github.com/axelarnetwork/axelar-core/x/evm/client/rest"
"github.com/axelarnetwork/axelar-core/x/evm/keeper"
"github.com/axelarnetwork/axelar-core/x/evm/types"
)

var (
Expand Down Expand Up @@ -87,7 +85,6 @@ func (AppModuleBasic) GetQueryCmd() *cobra.Command {
// AppModule implements module.AppModule
type AppModule struct {
AppModuleBasic
logger log.Logger
keeper *keeper.BaseKeeper
voter types.Voter
nexus types.Nexus
Expand All @@ -98,18 +95,9 @@ type AppModule struct {
}

// NewAppModule creates a new AppModule object
func NewAppModule(
k *keeper.BaseKeeper,
voter types.Voter,
nexus types.Nexus,
snapshotter types.Snapshotter,
staking types.StakingKeeper,
slashing types.SlashingKeeper,
multisig types.MultisigKeeper,
logger log.Logger) AppModule {
func NewAppModule(k *keeper.BaseKeeper, voter types.Voter, nexus types.Nexus, snapshotter types.Snapshotter, staking types.StakingKeeper, slashing types.SlashingKeeper, multisig types.MultisigKeeper) AppModule {
return AppModule{
AppModuleBasic: AppModuleBasic{},
logger: logger,
keeper: k,
voter: voter,
nexus: nexus,
Expand Down

0 comments on commit 02b39fb

Please sign in to comment.