* Start cosmos-sdk v0.47 integration (#1136) * Upgrade to sdk v0.47 branch * More integration work * SDK version upgrade; fixes * More fixes * Fixes * Deactivate failing tests * SDK + ibc-go version upgrades * limix gas fix (cherry picked from commit f7f841768e5051d96d243b42ce4f231a33020326) * with valset in bench (cherry picked from commit 35b2a8fd2c23d6160fca540771fd348913f7f143) * Revert staking query handler; fix tests * Minor cleanup * Rebased * Address linter issues * Set legacy router proper * Deactivate failing test. Race condition needs to handled in SDK * Address some code smells * Bump sdk version * Use gov v1 internally for votes * Activate test after sdk fix * Add group test * Add config template for wasm fields * Add Rust backtrace flag for more debug output on simulations * Set unique node folder for tests * Revert "Add Rust backtrace flag for more debug output on simulations" This reverts commit 218c3c6ce137dc02f7bc38391408d3460fb27e6f. * Simulations * Run also im/export + deterministic sims * Add package prefix to interfaces * Add signer annotation (https://github.com/cosmos/cosmos-sdk/issues/10933), minor cleanup * Bump sdk version * Review comments Co-authored-by: vuong <nguyenvuong1122000@gmail.com> * Bump bufbuild/buf-setup-action from 1.11.0 to 1.12.0 Bumps [bufbuild/buf-setup-action](https://github.com/bufbuild/buf-setup-action) from 1.11.0 to 1.12.0. - [Release notes](https://github.com/bufbuild/buf-setup-action/releases) - [Commits](https://github.com/bufbuild/buf-setup-action/compare/v1.11.0...v1.12.0) --- updated-dependencies: - dependency-name: bufbuild/buf-setup-action dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> (cherry picked from commitf4905955b5) * Remove intertx for vanilla ICA * fix msg format in EVENTS.md (cherry picked from commit38d466adfd) * Better to sdk coin convertion (#1164) * Better to sdk coin convertion * Review feedback (cherry picked from commita925a9ed61) * Disallow only address permission (#1163) * Remove AccessTypeOnlyAddress for store msg * Remove AccessTypeOnlyAddress for update config msg * Review feedback Co-authored-by: Simon Warta <2603011+webmaster128@users.noreply.github.com> Co-authored-by: Simon Warta <2603011+webmaster128@users.noreply.github.com> (cherry picked from commit8991633de2) * Integrate wasmvm v1.2.0 (backport #1161) (#1175) * Integrate wasmvm v1.2.0 (#1161) * Bump wasmvm version * Bump wasm test contracts * Encode weighted votes * Encode instantiate2 * Handle code info query; better wasmvm errors * Fix readme * Make linter happy * add non cgo build * Review comments * Bump wasmvm to release version Co-authored-by: jhernandezb <contact@jhernandez.me> (cherry picked from commit957b38e0a5) # Conflicts: # x/wasm/keeper/handler_plugin_encoders.go # x/wasm/keeper/handler_plugin_encoders_test.go # x/wasm/keeper/keeper.go # x/wasm/keeper/keeper_test.go * Adress merge conflicts Co-authored-by: Alexander Peters <alpe@users.noreply.github.com> * Bump bufbuild/buf-setup-action from 1.12.0 to 1.13.0 Bumps [bufbuild/buf-setup-action](https://github.com/bufbuild/buf-setup-action) from 1.12.0 to 1.13.0. - [Release notes](https://github.com/bufbuild/buf-setup-action/releases) - [Commits](https://github.com/bufbuild/buf-setup-action/compare/v1.12.0...v1.13.0) --- updated-dependencies: - dependency-name: bufbuild/buf-setup-action dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> (cherry picked from commitffa0e5e5e1) * Emit events for setContractAdmin + setAccessConfig (#1179) (cherry picked from commitc9e7830ac1) * Dependency upgrades (#1172) * Bump sdk version to lastest * Bump ibc-go version to lastest * Remove channel hack * Update to ibc-go v7 + protoVer=0.11.5 * Bump bufbuild/buf-setup-action from 1.13.0 to 1.13.1 Bumps [bufbuild/buf-setup-action](https://github.com/bufbuild/buf-setup-action) from 1.13.0 to 1.13.1. - [Release notes](https://github.com/bufbuild/buf-setup-action/releases) - [Commits](https://github.com/bufbuild/buf-setup-action/compare/v1.13.0...v1.13.1) --- updated-dependencies: - dependency-name: bufbuild/buf-setup-action dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> (cherry picked from commitde27e7f82f) * Fix typos (backport #1185) (#1194) * Fix typos (cherry picked from commitc88b8194cb) # Conflicts: # proto/cosmwasm/wasm/v1/tx.proto * Fix merge conflict --------- Co-authored-by: Alex Peters <alpe@users.noreply.github.com> * Bump bufbuild/buf-setup-action from 1.13.1 to 1.14.0 (#1200) Bumps [bufbuild/buf-setup-action](https://github.com/bufbuild/buf-setup-action) from 1.13.1 to 1.14.0. - [Release notes](https://github.com/bufbuild/buf-setup-action/releases) - [Commits](https://github.com/bufbuild/buf-setup-action/compare/v1.13.1...v1.14.0) --- updated-dependencies: - dependency-name: bufbuild/buf-setup-action dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> (cherry picked from commitf3fc31c386) * list-contract-by-code bugfix (cherry picked from commit2ccffed778) * fix: stargate querier does not reset the state (cherry picked from commitfd0323541d) * test: add unit test (cherry picked from commit6d8018ac59) * Add Windows client support (#1197) * Add Windows client support * Separate server and windows client --------- Co-authored-by: Alex Peters <alpe@users.noreply.github.com> (cherry picked from commit8a20779518) * Bump bufbuild/buf-setup-action from 1.14.0 to 1.15.0 Bumps [bufbuild/buf-setup-action](https://github.com/bufbuild/buf-setup-action) from 1.14.0 to 1.15.0. - [Release notes](https://github.com/bufbuild/buf-setup-action/releases) - [Commits](https://github.com/bufbuild/buf-setup-action/compare/v1.14.0...v1.15.0) --- updated-dependencies: - dependency-name: bufbuild/buf-setup-action dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> (cherry picked from commite5fab3da5a) * Rename windows client binary (cherry picked from commitde09c7fe2b) * Return IBC packet sequence number (backport #1225) (#1233) * Return IBC packet sequence number (#1225) * Return IBC packet sequence number * Fix review feedbacks * Remove names to return values in DispatchMsg method * Fix comments (cherry picked from commit4f1c57fc12) # Conflicts: # x/wasm/keeper/handler_plugin.go * Fix merge conflict --------- Co-authored-by: pinosu <95283998+pinosu@users.noreply.github.com> Co-authored-by: Alex Peters <alpe@users.noreply.github.com> * Test rust panic for regression (cherry picked from commita52e604966) * Fix client checksum verification (#1234) * Fix client checksum verification * Review comments (cherry picked from commit1a8019b380) # Conflicts: # x/wasm/client/cli/gov_tx.go * Fix merge conflict * Fix linters * Configure sonarcloud analysis (cherry picked from commit85cf1614fb) * Bump bufbuild/buf-setup-action from 1.15.0 to 1.15.1 Bumps [bufbuild/buf-setup-action](https://github.com/bufbuild/buf-setup-action) from 1.15.0 to 1.15.1. - [Release notes](https://github.com/bufbuild/buf-setup-action/releases) - [Commits](https://github.com/bufbuild/buf-setup-action/compare/v1.15.0...v1.15.1) --- updated-dependencies: - dependency-name: bufbuild/buf-setup-action dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> (cherry picked from commit730ea5a1cf) * Make `CaptureIbcEvents` in ibctesting public. Before this change, it wasn't possible to implement the `chain.SendMsgs` method without [copying](https://github.com/public-awesome/ics721/blob/main/e2e/suite_helpers.go#L81-L98) them over. (cherry picked from commitb64fa078a3) * Upgrade to wasmvm 1.2.1 (backport #1245) (#1254) * Upgrade to wasmvm 1.2.1 (#1245) * Use wasmvm store adapter * Bump wasmvm to v1.2.1 (cherry picked from commit850f901b2e) # Conflicts: # go.mod # go.sum # x/wasm/keeper/keeper.go * Resolve conflicts --------- Co-authored-by: Alexander Peters <alpe@users.noreply.github.com> * WIP All cometbft (#1244) * Dep upgrade; use CometBft * Remove duplicte message events * Add changelog for v0.31.0 (#1188) * Start changelog for v0.31.0 * Add ICA upgrade * Add proto version link to buf.build * Update changelog (#1239) * Update changelog * Update changelog with latest changes * Set release date --------- Co-authored-by: pinosu <95283998+pinosu@users.noreply.github.com> (cherry picked from commitbc0e817912) * Remove new message type event * Support msg update params gov proposal (#1247) * Add MsgUpdateParams support * Implement UpdateParams msg * Fix test UpdateParams * Add migration test * Fix * Fix lint issues * Revert changes according to review feedback * Remove more x/params dependencies * Remove x/params from genesis test * Formatting * Restore old changes * fix lint * Fix tests and restructure migrations * Rename alias for convention --------- Co-authored-by: Alex Peters <alpe@users.noreply.github.com> * Fix test data generator (#1263) * linting 47 pr (#1261) * lint cosmwasm for sdk 47 * fix * remove setGenesis * remove additional unused functions * pass tests * use SDK's errors module * unecessary conversions * unnecessary conversions * remove unneeded event manager * complete linting of tests for 47 * add test for reimportation * check errors * Update x/wasm/keeper/proposal_integration_test.go Co-authored-by: Alexander Peters <alpe@users.noreply.github.com> * apply suggestion * suggestions * lints * don't return error in when making new transactions * no todo's in the code * Fix test data generator * Update x/wasm/types/genesis_test.go Co-authored-by: Alexander Peters <alpe@users.noreply.github.com> * use the full string invalid address (2 words) always --------- Co-authored-by: Alexander Peters <alpe@users.noreply.github.com> * Regenerate from proto; remove dead code; polish code * Set SDK version to v0.47x.0 (#1262) * Set SDK version to v0.47x.0 * Set chainID * Minor updates * Set chainID for simulations * Buf mod update * Use sdk tag instead of hash in buf * Bump ibc-go to v7.0.0 * faddat/re merge main (#1274) undefined --------- Co-authored-by: vuong <nguyenvuong1122000@gmail.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: llllllluc <58892938+llllllluc@users.noreply.github.com> Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com> Co-authored-by: Gjermund Garaba <gjermund@garaba.net> Co-authored-by: Nikhil Suri <nikhilsuri@comcast.net> Co-authored-by: Paul <p22626262@gmail.com> Co-authored-by: pinosu <95283998+pinosu@users.noreply.github.com> Co-authored-by: ekez <zekemedley@gmail.com> Co-authored-by: Jacob Gadikian <jacobgadikian@gmail.com>
396 lines
13 KiB
Go
396 lines
13 KiB
Go
package keeper
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
|
|
errorsmod "cosmossdk.io/errors"
|
|
v1 "github.com/cosmos/cosmos-sdk/x/gov/types/v1"
|
|
|
|
wasmvmtypes "github.com/CosmWasm/wasmvm/types"
|
|
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
|
|
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
|
|
distributiontypes "github.com/cosmos/cosmos-sdk/x/distribution/types"
|
|
stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types"
|
|
ibctransfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
|
|
ibcclienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
|
|
channeltypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
|
|
|
|
"github.com/CosmWasm/wasmd/x/wasm/types"
|
|
)
|
|
|
|
type (
|
|
BankEncoder func(sender sdk.AccAddress, msg *wasmvmtypes.BankMsg) ([]sdk.Msg, error)
|
|
CustomEncoder func(sender sdk.AccAddress, msg json.RawMessage) ([]sdk.Msg, error)
|
|
DistributionEncoder func(sender sdk.AccAddress, msg *wasmvmtypes.DistributionMsg) ([]sdk.Msg, error)
|
|
StakingEncoder func(sender sdk.AccAddress, msg *wasmvmtypes.StakingMsg) ([]sdk.Msg, error)
|
|
StargateEncoder func(sender sdk.AccAddress, msg *wasmvmtypes.StargateMsg) ([]sdk.Msg, error)
|
|
WasmEncoder func(sender sdk.AccAddress, msg *wasmvmtypes.WasmMsg) ([]sdk.Msg, error)
|
|
IBCEncoder func(ctx sdk.Context, sender sdk.AccAddress, contractIBCPortID string, msg *wasmvmtypes.IBCMsg) ([]sdk.Msg, error)
|
|
)
|
|
|
|
type MessageEncoders struct {
|
|
Bank func(sender sdk.AccAddress, msg *wasmvmtypes.BankMsg) ([]sdk.Msg, error)
|
|
Custom func(sender sdk.AccAddress, msg json.RawMessage) ([]sdk.Msg, error)
|
|
Distribution func(sender sdk.AccAddress, msg *wasmvmtypes.DistributionMsg) ([]sdk.Msg, error)
|
|
IBC func(ctx sdk.Context, sender sdk.AccAddress, contractIBCPortID string, msg *wasmvmtypes.IBCMsg) ([]sdk.Msg, error)
|
|
Staking func(sender sdk.AccAddress, msg *wasmvmtypes.StakingMsg) ([]sdk.Msg, error)
|
|
Stargate func(sender sdk.AccAddress, msg *wasmvmtypes.StargateMsg) ([]sdk.Msg, error)
|
|
Wasm func(sender sdk.AccAddress, msg *wasmvmtypes.WasmMsg) ([]sdk.Msg, error)
|
|
Gov func(sender sdk.AccAddress, msg *wasmvmtypes.GovMsg) ([]sdk.Msg, error)
|
|
}
|
|
|
|
func DefaultEncoders(unpacker codectypes.AnyUnpacker, portSource types.ICS20TransferPortSource) MessageEncoders {
|
|
return MessageEncoders{
|
|
Bank: EncodeBankMsg,
|
|
Custom: NoCustomMsg,
|
|
Distribution: EncodeDistributionMsg,
|
|
IBC: EncodeIBCMsg(portSource),
|
|
Staking: EncodeStakingMsg,
|
|
Stargate: EncodeStargateMsg(unpacker),
|
|
Wasm: EncodeWasmMsg,
|
|
Gov: EncodeGovMsg,
|
|
}
|
|
}
|
|
|
|
func (e MessageEncoders) Merge(o *MessageEncoders) MessageEncoders {
|
|
if o == nil {
|
|
return e
|
|
}
|
|
if o.Bank != nil {
|
|
e.Bank = o.Bank
|
|
}
|
|
if o.Custom != nil {
|
|
e.Custom = o.Custom
|
|
}
|
|
if o.Distribution != nil {
|
|
e.Distribution = o.Distribution
|
|
}
|
|
if o.IBC != nil {
|
|
e.IBC = o.IBC
|
|
}
|
|
if o.Staking != nil {
|
|
e.Staking = o.Staking
|
|
}
|
|
if o.Stargate != nil {
|
|
e.Stargate = o.Stargate
|
|
}
|
|
if o.Wasm != nil {
|
|
e.Wasm = o.Wasm
|
|
}
|
|
if o.Gov != nil {
|
|
e.Gov = o.Gov
|
|
}
|
|
return e
|
|
}
|
|
|
|
func (e MessageEncoders) Encode(ctx sdk.Context, contractAddr sdk.AccAddress, contractIBCPortID string, msg wasmvmtypes.CosmosMsg) ([]sdk.Msg, error) {
|
|
switch {
|
|
case msg.Bank != nil:
|
|
return e.Bank(contractAddr, msg.Bank)
|
|
case msg.Custom != nil:
|
|
return e.Custom(contractAddr, msg.Custom)
|
|
case msg.Distribution != nil:
|
|
return e.Distribution(contractAddr, msg.Distribution)
|
|
case msg.IBC != nil:
|
|
return e.IBC(ctx, contractAddr, contractIBCPortID, msg.IBC)
|
|
case msg.Staking != nil:
|
|
return e.Staking(contractAddr, msg.Staking)
|
|
case msg.Stargate != nil:
|
|
return e.Stargate(contractAddr, msg.Stargate)
|
|
case msg.Wasm != nil:
|
|
return e.Wasm(contractAddr, msg.Wasm)
|
|
case msg.Gov != nil:
|
|
return EncodeGovMsg(contractAddr, msg.Gov)
|
|
}
|
|
return nil, errorsmod.Wrap(types.ErrUnknownMsg, "unknown variant of Wasm")
|
|
}
|
|
|
|
func EncodeBankMsg(sender sdk.AccAddress, msg *wasmvmtypes.BankMsg) ([]sdk.Msg, error) {
|
|
if msg.Send == nil {
|
|
return nil, errorsmod.Wrap(types.ErrUnknownMsg, "unknown variant of Bank")
|
|
}
|
|
if len(msg.Send.Amount) == 0 {
|
|
return nil, nil
|
|
}
|
|
toSend, err := ConvertWasmCoinsToSdkCoins(msg.Send.Amount)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
sdkMsg := banktypes.MsgSend{
|
|
FromAddress: sender.String(),
|
|
ToAddress: msg.Send.ToAddress,
|
|
Amount: toSend,
|
|
}
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
}
|
|
|
|
func NoCustomMsg(_ sdk.AccAddress, _ json.RawMessage) ([]sdk.Msg, error) {
|
|
return nil, errorsmod.Wrap(types.ErrUnknownMsg, "custom variant not supported")
|
|
}
|
|
|
|
func EncodeDistributionMsg(sender sdk.AccAddress, msg *wasmvmtypes.DistributionMsg) ([]sdk.Msg, error) {
|
|
switch {
|
|
case msg.SetWithdrawAddress != nil:
|
|
setMsg := distributiontypes.MsgSetWithdrawAddress{
|
|
DelegatorAddress: sender.String(),
|
|
WithdrawAddress: msg.SetWithdrawAddress.Address,
|
|
}
|
|
return []sdk.Msg{&setMsg}, nil
|
|
case msg.WithdrawDelegatorReward != nil:
|
|
withdrawMsg := distributiontypes.MsgWithdrawDelegatorReward{
|
|
DelegatorAddress: sender.String(),
|
|
ValidatorAddress: msg.WithdrawDelegatorReward.Validator,
|
|
}
|
|
return []sdk.Msg{&withdrawMsg}, nil
|
|
default:
|
|
return nil, errorsmod.Wrap(types.ErrUnknownMsg, "unknown variant of Distribution")
|
|
}
|
|
}
|
|
|
|
func EncodeStakingMsg(sender sdk.AccAddress, msg *wasmvmtypes.StakingMsg) ([]sdk.Msg, error) {
|
|
switch {
|
|
case msg.Delegate != nil:
|
|
coin, err := ConvertWasmCoinToSdkCoin(msg.Delegate.Amount)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
sdkMsg := stakingtypes.MsgDelegate{
|
|
DelegatorAddress: sender.String(),
|
|
ValidatorAddress: msg.Delegate.Validator,
|
|
Amount: coin,
|
|
}
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
|
|
case msg.Redelegate != nil:
|
|
coin, err := ConvertWasmCoinToSdkCoin(msg.Redelegate.Amount)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
sdkMsg := stakingtypes.MsgBeginRedelegate{
|
|
DelegatorAddress: sender.String(),
|
|
ValidatorSrcAddress: msg.Redelegate.SrcValidator,
|
|
ValidatorDstAddress: msg.Redelegate.DstValidator,
|
|
Amount: coin,
|
|
}
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
case msg.Undelegate != nil:
|
|
coin, err := ConvertWasmCoinToSdkCoin(msg.Undelegate.Amount)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
sdkMsg := stakingtypes.MsgUndelegate{
|
|
DelegatorAddress: sender.String(),
|
|
ValidatorAddress: msg.Undelegate.Validator,
|
|
Amount: coin,
|
|
}
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
default:
|
|
return nil, errorsmod.Wrap(types.ErrUnknownMsg, "unknown variant of Staking")
|
|
}
|
|
}
|
|
|
|
func EncodeStargateMsg(unpacker codectypes.AnyUnpacker) StargateEncoder {
|
|
return func(sender sdk.AccAddress, msg *wasmvmtypes.StargateMsg) ([]sdk.Msg, error) {
|
|
codecAny := codectypes.Any{
|
|
TypeUrl: msg.TypeURL,
|
|
Value: msg.Value,
|
|
}
|
|
var sdkMsg sdk.Msg
|
|
if err := unpacker.UnpackAny(&codecAny, &sdkMsg); err != nil {
|
|
return nil, errorsmod.Wrap(types.ErrInvalidMsg, fmt.Sprintf("Cannot unpack proto message with type URL: %s", msg.TypeURL))
|
|
}
|
|
if err := codectypes.UnpackInterfaces(sdkMsg, unpacker); err != nil {
|
|
return nil, errorsmod.Wrap(types.ErrInvalidMsg, fmt.Sprintf("UnpackInterfaces inside msg: %s", err))
|
|
}
|
|
return []sdk.Msg{sdkMsg}, nil
|
|
}
|
|
}
|
|
|
|
func EncodeWasmMsg(sender sdk.AccAddress, msg *wasmvmtypes.WasmMsg) ([]sdk.Msg, error) {
|
|
switch {
|
|
case msg.Execute != nil:
|
|
coins, err := ConvertWasmCoinsToSdkCoins(msg.Execute.Funds)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
sdkMsg := types.MsgExecuteContract{
|
|
Sender: sender.String(),
|
|
Contract: msg.Execute.ContractAddr,
|
|
Msg: msg.Execute.Msg,
|
|
Funds: coins,
|
|
}
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
case msg.Instantiate != nil:
|
|
coins, err := ConvertWasmCoinsToSdkCoins(msg.Instantiate.Funds)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
sdkMsg := types.MsgInstantiateContract{
|
|
Sender: sender.String(),
|
|
CodeID: msg.Instantiate.CodeID,
|
|
Label: msg.Instantiate.Label,
|
|
Msg: msg.Instantiate.Msg,
|
|
Admin: msg.Instantiate.Admin,
|
|
Funds: coins,
|
|
}
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
case msg.Instantiate2 != nil:
|
|
coins, err := ConvertWasmCoinsToSdkCoins(msg.Instantiate2.Funds)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
sdkMsg := types.MsgInstantiateContract2{
|
|
Sender: sender.String(),
|
|
Admin: msg.Instantiate2.Admin,
|
|
CodeID: msg.Instantiate2.CodeID,
|
|
Label: msg.Instantiate2.Label,
|
|
Msg: msg.Instantiate2.Msg,
|
|
Funds: coins,
|
|
Salt: msg.Instantiate2.Salt,
|
|
// FixMsg is discouraged, see: https://medium.com/cosmwasm/dev-note-3-limitations-of-instantiate2-and-how-to-deal-with-them-a3f946874230
|
|
FixMsg: false,
|
|
}
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
case msg.Migrate != nil:
|
|
sdkMsg := types.MsgMigrateContract{
|
|
Sender: sender.String(),
|
|
Contract: msg.Migrate.ContractAddr,
|
|
CodeID: msg.Migrate.NewCodeID,
|
|
Msg: msg.Migrate.Msg,
|
|
}
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
case msg.ClearAdmin != nil:
|
|
sdkMsg := types.MsgClearAdmin{
|
|
Sender: sender.String(),
|
|
Contract: msg.ClearAdmin.ContractAddr,
|
|
}
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
case msg.UpdateAdmin != nil:
|
|
sdkMsg := types.MsgUpdateAdmin{
|
|
Sender: sender.String(),
|
|
Contract: msg.UpdateAdmin.ContractAddr,
|
|
NewAdmin: msg.UpdateAdmin.Admin,
|
|
}
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
default:
|
|
return nil, errorsmod.Wrap(types.ErrUnknownMsg, "unknown variant of Wasm")
|
|
}
|
|
}
|
|
|
|
func EncodeIBCMsg(portSource types.ICS20TransferPortSource) func(ctx sdk.Context, sender sdk.AccAddress, contractIBCPortID string, msg *wasmvmtypes.IBCMsg) ([]sdk.Msg, error) {
|
|
return func(ctx sdk.Context, sender sdk.AccAddress, contractIBCPortID string, msg *wasmvmtypes.IBCMsg) ([]sdk.Msg, error) {
|
|
switch {
|
|
case msg.CloseChannel != nil:
|
|
return []sdk.Msg{&channeltypes.MsgChannelCloseInit{
|
|
PortId: PortIDForContract(sender),
|
|
ChannelId: msg.CloseChannel.ChannelID,
|
|
Signer: sender.String(),
|
|
}}, nil
|
|
case msg.Transfer != nil:
|
|
amount, err := ConvertWasmCoinToSdkCoin(msg.Transfer.Amount)
|
|
if err != nil {
|
|
return nil, errorsmod.Wrap(err, "amount")
|
|
}
|
|
msg := &ibctransfertypes.MsgTransfer{
|
|
SourcePort: portSource.GetPort(ctx),
|
|
SourceChannel: msg.Transfer.ChannelID,
|
|
Token: amount,
|
|
Sender: sender.String(),
|
|
Receiver: msg.Transfer.ToAddress,
|
|
TimeoutHeight: ConvertWasmIBCTimeoutHeightToCosmosHeight(msg.Transfer.Timeout.Block),
|
|
TimeoutTimestamp: msg.Transfer.Timeout.Timestamp,
|
|
}
|
|
return []sdk.Msg{msg}, nil
|
|
default:
|
|
return nil, errorsmod.Wrap(types.ErrUnknownMsg, "unknown variant of IBC")
|
|
}
|
|
}
|
|
}
|
|
|
|
func EncodeGovMsg(sender sdk.AccAddress, msg *wasmvmtypes.GovMsg) ([]sdk.Msg, error) {
|
|
switch {
|
|
case msg.Vote != nil:
|
|
voteOption, err := convertVoteOption(msg.Vote.Vote)
|
|
if err != nil {
|
|
return nil, errorsmod.Wrap(err, "vote option")
|
|
}
|
|
m := v1.NewMsgVote(sender, msg.Vote.ProposalId, voteOption, "")
|
|
return []sdk.Msg{m}, nil
|
|
case msg.VoteWeighted != nil:
|
|
opts := make([]*v1.WeightedVoteOption, len(msg.VoteWeighted.Options))
|
|
for i, v := range msg.VoteWeighted.Options {
|
|
weight, err := sdk.NewDecFromStr(v.Weight)
|
|
if err != nil {
|
|
return nil, errorsmod.Wrapf(err, "weight for vote %d", i+1)
|
|
}
|
|
voteOption, err := convertVoteOption(v.Option)
|
|
if err != nil {
|
|
return nil, errorsmod.Wrap(err, "vote option")
|
|
}
|
|
opts[i] = &v1.WeightedVoteOption{Option: voteOption, Weight: weight.String()}
|
|
}
|
|
m := v1.NewMsgVoteWeighted(sender, msg.VoteWeighted.ProposalId, opts, "")
|
|
return []sdk.Msg{m}, nil
|
|
|
|
default:
|
|
return nil, types.ErrUnknownMsg.Wrap("unknown variant of gov")
|
|
}
|
|
}
|
|
|
|
func convertVoteOption(s interface{}) (v1.VoteOption, error) {
|
|
var option v1.VoteOption
|
|
switch s {
|
|
case wasmvmtypes.Yes:
|
|
option = v1.OptionYes
|
|
case wasmvmtypes.No:
|
|
option = v1.OptionNo
|
|
case wasmvmtypes.NoWithVeto:
|
|
option = v1.OptionNoWithVeto
|
|
case wasmvmtypes.Abstain:
|
|
option = v1.OptionAbstain
|
|
default:
|
|
return v1.OptionEmpty, types.ErrInvalid
|
|
}
|
|
return option, nil
|
|
}
|
|
|
|
// ConvertWasmIBCTimeoutHeightToCosmosHeight converts a wasmvm type ibc timeout height to ibc module type height
|
|
func ConvertWasmIBCTimeoutHeightToCosmosHeight(ibcTimeoutBlock *wasmvmtypes.IBCTimeoutBlock) ibcclienttypes.Height {
|
|
if ibcTimeoutBlock == nil {
|
|
return ibcclienttypes.NewHeight(0, 0)
|
|
}
|
|
return ibcclienttypes.NewHeight(ibcTimeoutBlock.Revision, ibcTimeoutBlock.Height)
|
|
}
|
|
|
|
// ConvertWasmCoinsToSdkCoins converts the wasm vm type coins to sdk type coins
|
|
func ConvertWasmCoinsToSdkCoins(coins []wasmvmtypes.Coin) (sdk.Coins, error) {
|
|
var toSend sdk.Coins
|
|
for _, coin := range coins {
|
|
c, err := ConvertWasmCoinToSdkCoin(coin)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
toSend = toSend.Add(c)
|
|
}
|
|
return toSend.Sort(), nil
|
|
}
|
|
|
|
// ConvertWasmCoinToSdkCoin converts a wasm vm type coin to sdk type coin
|
|
func ConvertWasmCoinToSdkCoin(coin wasmvmtypes.Coin) (sdk.Coin, error) {
|
|
amount, ok := sdk.NewIntFromString(coin.Amount)
|
|
if !ok {
|
|
return sdk.Coin{}, errorsmod.Wrap(sdkerrors.ErrInvalidCoins, coin.Amount+coin.Denom)
|
|
}
|
|
r := sdk.Coin{
|
|
Denom: coin.Denom,
|
|
Amount: amount,
|
|
}
|
|
return r, r.Validate()
|
|
}
|