|
|
|
|
@@ -87,21 +87,13 @@ func EncodeBankMsg(sender sdk.AccAddress, msg *wasmTypes.BankMsg) ([]sdk.Msg, er
|
|
|
|
|
if len(msg.Send.Amount) == 0 {
|
|
|
|
|
return nil, nil
|
|
|
|
|
}
|
|
|
|
|
fromAddr, stderr := sdk.AccAddressFromBech32(msg.Send.FromAddress)
|
|
|
|
|
if stderr != nil {
|
|
|
|
|
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, msg.Send.FromAddress)
|
|
|
|
|
}
|
|
|
|
|
toAddr, stderr := sdk.AccAddressFromBech32(msg.Send.ToAddress)
|
|
|
|
|
if stderr != nil {
|
|
|
|
|
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, msg.Send.ToAddress)
|
|
|
|
|
}
|
|
|
|
|
toSend, err := convertWasmCoinsToSdkCoins(msg.Send.Amount)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
sdkMsg := banktypes.MsgSend{
|
|
|
|
|
FromAddress: fromAddr.String(),
|
|
|
|
|
ToAddress: toAddr.String(),
|
|
|
|
|
FromAddress: msg.Send.FromAddress,
|
|
|
|
|
ToAddress: msg.Send.ToAddress,
|
|
|
|
|
Amount: toSend,
|
|
|
|
|
}
|
|
|
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
|
|
|
@@ -112,87 +104,65 @@ func NoCustomMsg(sender sdk.AccAddress, msg json.RawMessage) ([]sdk.Msg, error)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func EncodeStakingMsg(sender sdk.AccAddress, msg *wasmTypes.StakingMsg) ([]sdk.Msg, error) {
|
|
|
|
|
if msg.Delegate != nil {
|
|
|
|
|
validator, err := sdk.ValAddressFromBech32(msg.Delegate.Validator)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, msg.Delegate.Validator)
|
|
|
|
|
}
|
|
|
|
|
switch {
|
|
|
|
|
case msg.Delegate != nil:
|
|
|
|
|
coin, err := convertWasmCoinToSdkCoin(msg.Delegate.Amount)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
sdkMsg := stakingtypes.MsgDelegate{
|
|
|
|
|
DelegatorAddress: sender.String(),
|
|
|
|
|
ValidatorAddress: validator.String(),
|
|
|
|
|
ValidatorAddress: msg.Delegate.Validator,
|
|
|
|
|
Amount: coin,
|
|
|
|
|
}
|
|
|
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
|
|
|
}
|
|
|
|
|
if msg.Redelegate != nil {
|
|
|
|
|
src, err := sdk.ValAddressFromBech32(msg.Redelegate.SrcValidator)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, msg.Redelegate.SrcValidator)
|
|
|
|
|
}
|
|
|
|
|
dst, err := sdk.ValAddressFromBech32(msg.Redelegate.DstValidator)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, msg.Redelegate.DstValidator)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
case msg.Redelegate != nil:
|
|
|
|
|
coin, err := convertWasmCoinToSdkCoin(msg.Redelegate.Amount)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
sdkMsg := stakingtypes.MsgBeginRedelegate{
|
|
|
|
|
DelegatorAddress: sender.String(),
|
|
|
|
|
ValidatorSrcAddress: src.String(),
|
|
|
|
|
ValidatorDstAddress: dst.String(),
|
|
|
|
|
ValidatorSrcAddress: msg.Redelegate.SrcValidator,
|
|
|
|
|
ValidatorDstAddress: msg.Redelegate.DstValidator,
|
|
|
|
|
Amount: coin,
|
|
|
|
|
}
|
|
|
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
|
|
|
}
|
|
|
|
|
if msg.Undelegate != nil {
|
|
|
|
|
validator, err := sdk.ValAddressFromBech32(msg.Undelegate.Validator)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, msg.Undelegate.Validator)
|
|
|
|
|
}
|
|
|
|
|
case msg.Undelegate != nil:
|
|
|
|
|
coin, err := convertWasmCoinToSdkCoin(msg.Undelegate.Amount)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
sdkMsg := stakingtypes.MsgUndelegate{
|
|
|
|
|
DelegatorAddress: sender.String(),
|
|
|
|
|
ValidatorAddress: validator.String(),
|
|
|
|
|
ValidatorAddress: msg.Undelegate.Validator,
|
|
|
|
|
Amount: coin,
|
|
|
|
|
}
|
|
|
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
|
|
|
}
|
|
|
|
|
if msg.Withdraw != nil {
|
|
|
|
|
var err error
|
|
|
|
|
rcpt := sender
|
|
|
|
|
case msg.Withdraw != nil:
|
|
|
|
|
senderAddr := sender.String()
|
|
|
|
|
rcpt := senderAddr
|
|
|
|
|
if len(msg.Withdraw.Recipient) != 0 {
|
|
|
|
|
rcpt, err = sdk.AccAddressFromBech32(msg.Withdraw.Recipient)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, msg.Withdraw.Recipient)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
validator, err := sdk.ValAddressFromBech32(msg.Withdraw.Validator)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, msg.Withdraw.Validator)
|
|
|
|
|
rcpt = msg.Withdraw.Recipient
|
|
|
|
|
}
|
|
|
|
|
setMsg := distributiontypes.MsgSetWithdrawAddress{
|
|
|
|
|
DelegatorAddress: sender.String(),
|
|
|
|
|
WithdrawAddress: rcpt.String(),
|
|
|
|
|
DelegatorAddress: senderAddr,
|
|
|
|
|
WithdrawAddress: rcpt,
|
|
|
|
|
}
|
|
|
|
|
withdrawMsg := distributiontypes.MsgWithdrawDelegatorReward{
|
|
|
|
|
DelegatorAddress: sender.String(),
|
|
|
|
|
ValidatorAddress: validator.String(),
|
|
|
|
|
DelegatorAddress: senderAddr,
|
|
|
|
|
ValidatorAddress: msg.Withdraw.Validator,
|
|
|
|
|
}
|
|
|
|
|
return []sdk.Msg{&setMsg, &withdrawMsg}, nil
|
|
|
|
|
default:
|
|
|
|
|
return nil, sdkerrors.Wrap(types.ErrInvalidMsg, "Unknown variant of Staking")
|
|
|
|
|
}
|
|
|
|
|
return nil, sdkerrors.Wrap(types.ErrInvalidMsg, "Unknown variant of Staking")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func EncodeWasmMsg(sender sdk.AccAddress, msg *wasmTypes.WasmMsg) ([]sdk.Msg, error) {
|
|
|
|
|
if msg.Execute != nil {
|
|
|
|
|
switch {
|
|
|
|
|
case msg.Execute != nil:
|
|
|
|
|
contractAddr, err := sdk.AccAddressFromBech32(msg.Execute.ContractAddr)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, msg.Execute.ContractAddr)
|
|
|
|
|
@@ -209,8 +179,7 @@ func EncodeWasmMsg(sender sdk.AccAddress, msg *wasmTypes.WasmMsg) ([]sdk.Msg, er
|
|
|
|
|
SentFunds: coins,
|
|
|
|
|
}
|
|
|
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
|
|
|
}
|
|
|
|
|
if msg.Instantiate != nil {
|
|
|
|
|
case msg.Instantiate != nil:
|
|
|
|
|
coins, err := convertWasmCoinsToSdkCoins(msg.Instantiate.Send)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
@@ -225,8 +194,9 @@ func EncodeWasmMsg(sender sdk.AccAddress, msg *wasmTypes.WasmMsg) ([]sdk.Msg, er
|
|
|
|
|
InitFunds: coins,
|
|
|
|
|
}
|
|
|
|
|
return []sdk.Msg{&sdkMsg}, nil
|
|
|
|
|
default:
|
|
|
|
|
return nil, sdkerrors.Wrap(types.ErrInvalidMsg, "Unknown variant of Wasm")
|
|
|
|
|
}
|
|
|
|
|
return nil, sdkerrors.Wrap(types.ErrInvalidMsg, "Unknown variant of Wasm")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (h MessageHandler) Dispatch(ctx sdk.Context, contractAddr sdk.AccAddress, msg wasmTypes.CosmosMsg) error {
|
|
|
|
|
@@ -243,6 +213,9 @@ func (h MessageHandler) Dispatch(ctx sdk.Context, contractAddr sdk.AccAddress, m
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (h MessageHandler) handleSdkMessage(ctx sdk.Context, contractAddr sdk.Address, msg sdk.Msg) error {
|
|
|
|
|
if err := msg.ValidateBasic(); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
// make sure this account can send it
|
|
|
|
|
for _, acct := range msg.GetSigners() {
|
|
|
|
|
if !acct.Equals(contractAddr) {
|
|
|
|
|
|