Documentation ¶
Index ¶
- Constants
- Variables
- func IsConsumerProposalAllowlisted(content govtypes.Content) bool
- func MakeEncodingConfig() params.EncodingConfig
- func NewAnteHandler(options HandlerOptions, logger log.Logger) (sdk.AnteHandler, error)
- func NewPostHandler(options PostHandlerOptions) (sdk.PostHandler, error)
- type App
- func (app *App) AppCodec() codec.Codec
- func (app *App) AutoCLIOpts(initClientCtx client.Context) autocli.AppOptions
- func (app *App) AutoCliOpts() autocli.AppOptions
- func (app *App) BeginBlocker(ctx sdk.Context) (sdk.BeginBlock, error)
- func (app *App) BlockedAddrs() map[string]bool
- func (app *App) CheckTx(req *abci.RequestCheckTx) (*abci.ResponseCheckTx, error)
- func (app *App) CreateLanes() *blocksdkbase.BaseLane
- func (app *App) EndBlocker(ctx sdk.Context) (sdk.EndBlock, error)
- func (app *App) ExportAppStateAndValidators(forZeroHeight bool, jailAllowedAddrs, modulesToExport []string) (servertypes.ExportedApp, error)
- func (app *App) GetBaseApp() *baseapp.BaseApp
- func (app *App) GetConsumerKeeper() ccvconsumerkeeper.Keeper
- func (app *App) GetIBCKeeper() *ibckeeper.Keeper
- func (app *App) GetKey(storeKey string) *storetypes.KVStoreKey
- func (app *App) GetMemKey(storeKey string) *storetypes.MemoryStoreKey
- func (app *App) GetScopedIBCKeeper() capabilitykeeper.ScopedKeeper
- func (app *App) GetStakingKeeper() ibctestingtypes.StakingKeeper
- func (app *App) GetSubspace(moduleName string) paramstypes.Subspace
- func (app *App) GetTKey(storeKey string) *storetypes.TransientStoreKey
- func (app *App) GetTestAccountKeeper() integration.TestAccountKeeper
- func (app *App) GetTestBankKeeper() integration.TestBankKeeper
- func (app *App) GetTestEvidenceKeeper() evidencekeeper.Keeper
- func (app *App) GetTestSlashingKeeper() integration.TestSlashingKeeper
- func (app *App) GetTxConfig() client.TxConfig
- func (app *App) GetValidatorSet(ctx sdk.Context) ([]tmtypes.GenesisValidator, error)
- func (app *App) InitChainer(ctx sdk.Context, req *abci.RequestInitChain) (*abci.ResponseInitChain, error)
- func (app *App) LegacyAmino() *codec.LegacyAmino
- func (app *App) LoadHeight(height int64) error
- func (app *App) LoadLatest()
- func (app *App) ModuleAccountAddrs() map[string]bool
- func (app *App) Name() string
- func (app *App) RegisterAPIRoutes(apiSvr *api.Server, apiConfig config.APIConfig)
- func (app *App) RegisterNodeService(clientCtx client.Context, cfg config.Config)
- func (app *App) RegisterSwaggerUI(apiSvr *api.Server)
- func (app *App) RegisterTendermintService(clientCtx client.Context)
- func (app *App) RegisterTxService(clientCtx client.Context)
- func (app *App) SetCheckTx(handler checktx.CheckTx)
- func (app *App) SimulationManager() *module.SimulationManager
- func (app *App) TestInitChainer(ctx sdk.Context, req *abci.RequestInitChain) (*abci.ResponseInitChain, error)
- func (app *App) WireICS20PreWasmKeeper(appCodec codec.Codec)
- type FeeDecoratorWithSwitch
- type GenesisState
- type HandlerOptions
- type PostHandlerOptions
Constants ¶
const (
MaxTxsForDefaultLane = 3000 // maximal number of txs that can be stored in this lane at any point in time
)
const (
Name = "neutrond"
)
const SkipCcvMsgFilter = false
Variables ¶
var ( Upgrades = []upgrades.Upgrade{ v500.Upgrade, } // DefaultNodeHome default home directories for the application daemon DefaultNodeHome string // ModuleBasics defines the module BasicManager is in charge of setting up basic, // non-dependant module elements, such as codec registration // and genesis verification. ModuleBasics = module.NewBasicManager( auth.AppModuleBasic{}, authzmodule.AppModuleBasic{}, bank.AppModuleBasic{}, capability.AppModuleBasic{}, genutil.NewAppModuleBasic(genutiltypes.DefaultMessageValidator), params.AppModuleBasic{}, crisis.AppModuleBasic{}, slashing.AppModuleBasic{}, feegrantmodule.AppModuleBasic{}, ibc.AppModuleBasic{}, ica.AppModuleBasic{}, tendermint.AppModuleBasic{}, upgrade.AppModuleBasic{}, evidence.AppModuleBasic{}, transferSudo.AppModuleBasic{}, vesting.AppModuleBasic{}, ccvconsumer.AppModuleBasic{}, wasm.AppModuleBasic{}, tokenfactory.AppModuleBasic{}, interchainqueries.AppModuleBasic{}, interchaintxs.AppModuleBasic{}, feerefunder.AppModuleBasic{}, feeburner.AppModuleBasic{}, contractmanager.AppModuleBasic{}, cron.AppModuleBasic{}, adminmodule.NewAppModuleBasic( govclient.NewProposalHandler( adminmodulecli.NewSubmitParamChangeProposalTxCmd, ), govclient.NewProposalHandler( adminmodulecli.NewCmdSubmitUpgradeProposal, ), govclient.NewProposalHandler( adminmodulecli.NewCmdSubmitCancelUpgradeProposal, ), ), ibchooks.AppModuleBasic{}, packetforward.AppModuleBasic{}, ibcratelimit.AppModuleBasic{}, auction.AppModuleBasic{}, globalfee.AppModule{}, feemarket.AppModuleBasic{}, dex.AppModuleBasic{}, oracle.AppModuleBasic{}, marketmap.AppModuleBasic{}, dynamicfees.AppModuleBasic{}, consensus.AppModuleBasic{}, ) )
var FeeDenom = "untrn"
var MaxBlockspaceForDefaultLane = math.LegacyMustNewDecFromStr("1") // maximal fraction of blockMaxBytes / gas that can be used by this lane at any point in time (100%)
var WhitelistedParams = map[paramChangeKey]struct{}{}
Functions ¶
func MakeEncodingConfig ¶
func MakeEncodingConfig() params.EncodingConfig
MakeEncodingConfig creates an EncodingConfig for testing
func NewAnteHandler ¶
func NewAnteHandler(options HandlerOptions, logger log.Logger) (sdk.AnteHandler, error)
func NewPostHandler ¶
func NewPostHandler(options PostHandlerOptions) (sdk.PostHandler, error)
NewPostHandler returns a PostHandler chain with the fee deduct decorator.
Types ¶
type App ¶
type App struct { *baseapp.BaseApp // keepers AccountKeeper authkeeper.AccountKeeper AdminmoduleKeeper adminmodulekeeper.Keeper AuthzKeeper authzkeeper.Keeper BankKeeper bankkeeper.BaseKeeper // AuctionKeeper handles the processing of bid-txs, the selection of winners per height, and the distribution of rewards. AuctionKeeper auctionkeeper.Keeper CapabilityKeeper *capabilitykeeper.Keeper SlashingKeeper slashingkeeper.Keeper CrisisKeeper crisiskeeper.Keeper UpgradeKeeper upgradekeeper.Keeper ParamsKeeper paramskeeper.Keeper IBCKeeper *ibckeeper.Keeper // IBC Keeper must be a pointer in the app, so we can SetRouter on it correctly ICAControllerKeeper icacontrollerkeeper.Keeper ICAHostKeeper icahostkeeper.Keeper EvidenceKeeper evidencekeeper.Keeper TransferKeeper wrapkeeper.KeeperTransferWrapper FeeGrantKeeper feegrantkeeper.Keeper FeeMarkerKeeper *feemarketkeeper.Keeper DynamicFeesKeeper *dynamicfeeskeeper.Keeper FeeKeeper *feekeeper.Keeper FeeBurnerKeeper *feeburnerkeeper.Keeper ConsumerKeeper ccvconsumerkeeper.Keeper TokenFactoryKeeper *tokenfactorykeeper.Keeper CronKeeper cronkeeper.Keeper PFMKeeper *pfmkeeper.Keeper DexKeeper dexkeeper.Keeper GlobalFeeKeeper globalfeekeeper.Keeper PFMModule packetforward.AppModule TransferStack *ibchooks.IBCMiddleware Ics20WasmHooks *ibchooks.WasmHooks RateLimitingICS4Wrapper *ibcratelimit.ICS4Wrapper HooksICS4Wrapper ibchooks.ICS4Middleware // make scoped keepers public for test purposes ScopedIBCKeeper capabilitykeeper.ScopedKeeper ScopedTransferKeeper capabilitykeeper.ScopedKeeper ScopedWasmKeeper capabilitykeeper.ScopedKeeper ScopedInterTxKeeper capabilitykeeper.ScopedKeeper ScopedCCVConsumerKeeper capabilitykeeper.ScopedKeeper InterchainQueriesKeeper interchainqueriesmodulekeeper.Keeper InterchainTxsKeeper interchaintxskeeper.Keeper ContractManagerKeeper contractmanagermodulekeeper.Keeper ConsensusParamsKeeper consensusparamkeeper.Keeper WasmKeeper wasmkeeper.Keeper ContractKeeper *wasmkeeper.PermissionedKeeper // slinky MarketMapKeeper *marketmapkeeper.Keeper OracleKeeper *oraclekeeper.Keeper // contains filtered or unexported fields }
App extends an ABCI application, but with most of its parameters exported. They are exported for convenience in creating helper functions, as object capabilities aren't needed for testing.
func New ¶
func New( logger log.Logger, db db.DB, traceStore io.Writer, loadLatest bool, skipUpgradeHeights map[int64]bool, homePath string, invCheckPeriod uint, encodingConfig appparams.EncodingConfig, appOpts servertypes.AppOptions, wasmOpts []wasmkeeper.Option, baseAppOptions ...func(*baseapp.BaseApp), ) *App
New returns a reference to an initialized blockchain app
func (*App) AppCodec ¶
AppCodec returns an app 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) AutoCLIOpts ¶
func (app *App) AutoCLIOpts(initClientCtx client.Context) autocli.AppOptions
AutoCLIOpts returns options based upon the modules in the neutron v5 app.
func (*App) AutoCliOpts ¶
func (app *App) AutoCliOpts() autocli.AppOptions
func (*App) BeginBlocker ¶
BeginBlocker application updates every begin block
func (*App) BlockedAddrs ¶
BlockedAddrs returns the set of addresses that are not allowed to send and receive funds
func (*App) CheckTx ¶
func (app *App) CheckTx(req *abci.RequestCheckTx) (*abci.ResponseCheckTx, error)
CheckTx will check the transaction with the provided checkTxHandler. We override the default handler so that we can verify bid transactions before they are inserted into the mempool. With the Block-SDK CheckTx, we can verify the bid transaction and all of the bundled transactions before inserting the bid transaction into the mempool.
func (*App) CreateLanes ¶
func (app *App) CreateLanes() *blocksdkbase.BaseLane
CreateLanes creates a LaneMempool containing MEV, default lanes (in that order)
func (*App) EndBlocker ¶
EndBlocker application updates every end block
func (*App) ExportAppStateAndValidators ¶
func (app *App) ExportAppStateAndValidators( forZeroHeight bool, jailAllowedAddrs, modulesToExport []string, ) (servertypes.ExportedApp, error)
ExportAppStateAndValidators exports the state of the application for a genesis file.
func (*App) GetBaseApp ¶
GetBaseApp returns the base app of the application
func (*App) GetConsumerKeeper ¶
func (app *App) GetConsumerKeeper() ccvconsumerkeeper.Keeper
GetConsumerKeeper implements the ConsumerApp interface.
func (*App) GetIBCKeeper ¶
GetIBCKeeper implements the TestingApp interface.
func (*App) GetKey ¶
func (app *App) GetKey(storeKey string) *storetypes.KVStoreKey
GetKey returns the KVStoreKey for the provided store key.
NOTE: This is solely to be used for testing purposes.
func (*App) GetMemKey ¶
func (app *App) GetMemKey(storeKey string) *storetypes.MemoryStoreKey
GetMemKey returns the MemStoreKey for the provided mem key.
NOTE: This is solely used for testing purposes.
func (*App) GetScopedIBCKeeper ¶
func (app *App) GetScopedIBCKeeper() capabilitykeeper.ScopedKeeper
GetScopedIBCKeeper implements the TestingApp interface.
func (*App) GetStakingKeeper ¶
func (app *App) GetStakingKeeper() ibctestingtypes.StakingKeeper
GetStakingKeeper implements the TestingApp interface.
func (*App) GetSubspace ¶
func (app *App) GetSubspace(moduleName string) paramstypes.Subspace
GetSubspace returns a param subspace for a given module name.
NOTE: This is solely to be used for testing purposes.
func (*App) GetTKey ¶
func (app *App) GetTKey(storeKey string) *storetypes.TransientStoreKey
GetTKey returns the TransientStoreKey for the provided store key.
NOTE: This is solely to be used for testing purposes.
func (*App) GetTestAccountKeeper ¶
func (app *App) GetTestAccountKeeper() integration.TestAccountKeeper
func (*App) GetTestBankKeeper ¶
func (app *App) GetTestBankKeeper() integration.TestBankKeeper
func (*App) GetTestEvidenceKeeper ¶
func (app *App) GetTestEvidenceKeeper() evidencekeeper.Keeper
func (*App) GetTestSlashingKeeper ¶
func (app *App) GetTestSlashingKeeper() integration.TestSlashingKeeper
func (*App) GetTxConfig ¶
GetTxConfig implements the TestingApp interface.
func (*App) GetValidatorSet ¶
GetValidatorSet returns a slice of bonded validators.
func (*App) InitChainer ¶
func (app *App) InitChainer(ctx sdk.Context, req *abci.RequestInitChain) (*abci.ResponseInitChain, error)
InitChainer application update at chain initialization
func (*App) LegacyAmino ¶
func (app *App) LegacyAmino() *codec.LegacyAmino
LegacyAmino returns SimApp'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) LoadHeight ¶
LoadHeight loads a particular height
func (*App) LoadLatest ¶
func (app *App) LoadLatest()
func (*App) ModuleAccountAddrs ¶
ModuleAccountAddrs returns all the app's module account addresses.
func (*App) RegisterAPIRoutes ¶
RegisterAPIRoutes registers all application module routes with the provided API server.
func (*App) RegisterNodeService ¶
func (*App) RegisterSwaggerUI ¶
func (*App) RegisterTendermintService ¶
RegisterTendermintService implements the Application.RegisterTendermintService method.
func (*App) RegisterTxService ¶
RegisterTxService implements the Application.RegisterTxService method.
func (*App) SetCheckTx ¶
SetCheckTx sets the checkTxHandler for the app.
func (*App) SimulationManager ¶
func (app *App) SimulationManager() *module.SimulationManager
SimulationManager implements the SimulationApp interface
func (*App) TestInitChainer ¶
func (app *App) TestInitChainer(ctx sdk.Context, req *abci.RequestInitChain) (*abci.ResponseInitChain, error)
InitChainer application update at chain initialization ONLY FOR TESTING PURPOSES
func (*App) WireICS20PreWasmKeeper ¶
WireICS20PreWasmKeeper Create the IBC Transfer Stack from bottom to top: * SendPacket. Originates from the transferKeeper and goes up the stack: transferKeeper.SendPacket -> ibc_rate_limit.SendPacket -> ibc_hooks.SendPacket -> channel.SendPacket * RecvPacket, message that originates from core IBC and goes down to app, the flow is the other way channel.RecvPacket -> ibc_hooks.OnRecvPacket -> ibc_rate_limit.OnRecvPacket -> gmp.OnRecvPacket -> pfm.OnRecvPacket -> transfer.OnRecvPacket
Note that the forward middleware is only integrated on the "receive" direction. It can be safely skipped when sending. Note also that the forward middleware is called "router", but we are using the name "pfm" (packet forward middleware) for clarity This may later be renamed upstream: https://github.com/ibc-apps/middleware/packet-forward-middleware/issues/10
After this, the wasm keeper is required to be set on both app.Ics20WasmHooks AND app.RateLimitingICS4Wrapper
type FeeDecoratorWithSwitch ¶
type FeeDecoratorWithSwitch struct {
// contains filtered or unexported fields
}
FeeDecoratorWithSwitch is a fee ante decorator which switches between globalfee ante handler and feemarket's one, depending on the `params.Enabled` field feemarket's module. If feemarket is enabled, we don't need to perform checks for min gas prices, since they are handled by feemarket so we switch the execution directly to feemarket ante handler If feemarket is disabled, we call globalfee + native cosmos fee ante handler where min gas prices will be checked via globalfee and then they will be deducted via native cosmos fee ante handler.
func NewFeeDecoratorWithSwitch ¶
func NewFeeDecoratorWithSwitch(options HandlerOptions) FeeDecoratorWithSwitch
func (FeeDecoratorWithSwitch) AnteHandle ¶
type GenesisState ¶
type GenesisState map[string]json.RawMessage
GenesisState is the genesis state of the blockchain represented here as a map of raw json messages key'd by a identifier string. The identifier is used to determine which module genesis information belongs to so it may be appropriately routed during init chain. Within this application default genesis information is retrieved from the ModuleBasicManager which populates json from each BasicModule object provided to it during init.
func NewDefaultGenesisState ¶
func NewDefaultGenesisState(cdc codec.JSONCodec) GenesisState
NewDefaultGenesisState generates the default state for the application.
type HandlerOptions ¶
type HandlerOptions struct { ante.HandlerOptions BankKeeper bankkeeper.Keeper AccountKeeper feemarketante.AccountKeeper IBCKeeper *ibckeeper.Keeper ConsumerKeeper ibcconsumerkeeper.Keeper GlobalFeeKeeper globalfeekeeper.Keeper WasmConfig *wasmTypes.WasmConfig TXCounterStoreService corestoretypes.KVStoreService FeeMarketKeeper feemarketante.FeeMarketKeeper }
HandlerOptions extend the SDK's AnteHandler options by requiring the IBC channel keeper.
type PostHandlerOptions ¶
type PostHandlerOptions struct { AccountKeeper feemarketpost.AccountKeeper BankKeeper feemarketpost.BankKeeper FeeMarketKeeper feemarketpost.FeeMarketKeeper }
PostHandlerOptions are the options required for constructing a FeeMarket PostHandler.