From a1910c3cc39d2dad8074878d6ba5c41d7e0c7eec Mon Sep 17 00:00:00 2001 From: Tomasz Kulik Date: Fri, 13 Dec 2024 09:00:53 +0100 Subject: [PATCH] feat: Add TransferV2 --- packages/std/src/ibc.rs | 48 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) diff --git a/packages/std/src/ibc.rs b/packages/std/src/ibc.rs index 5612cf5eb..a3cb91c63 100644 --- a/packages/std/src/ibc.rs +++ b/packages/std/src/ibc.rs @@ -18,6 +18,22 @@ mod transfer_msg_builder; pub use callbacks::*; pub use transfer_msg_builder::*; +pub struct Token { + base: String, + trace: Vec, + amount: uint256, +} + +pub struct Forwarding { + hops: Vec, + memo: String, +} + +pub struct Hop { + port_id: String, + channel_id: String, +} + /// These are messages in the IBC lifecycle. Only usable by IBC-enabled contracts /// (contracts that directly speak the IBC protocol via 6 entry points) #[non_exhaustive] @@ -52,6 +68,38 @@ pub enum IbcMsg { /// protobuf encoder instead. memo: Option, }, + /// Sends bank tokens owned by the contract to the given address on another chain. + /// The channel must already be established between the ibctransfer module on this chain + /// and a matching module on the remote chain. + /// We cannot select the port_id, this is whatever the local chain has bound the ibctransfer + /// module to. + TransferV2 { + /// existing channel to send the tokens over + channel_id: String, + /// address on the remote chain to receive these tokens + to_address: String, + /// packet data only supports one coin + /// https://github.com/cosmos/cosmos-sdk/blob/v0.40.0/proto/ibc/applications/transfer/v1/transfer.proto#L11-L20 + tokens: Vec, + /// when packet times out, measured on remote chain + timeout: IbcTimeout, + /// An optional memo. See the blog post + /// ["Moving Beyond Simple Token Transfers"](https://medium.com/the-interchain-foundation/moving-beyond-simple-token-transfers-d42b2b1dc29b) + /// for more information. + /// + /// There is no difference between setting this to `None` or an empty string. + /// + /// This field is only supported on chains with CosmWasm >= 2.0 and silently + /// ignored on older chains. + /// If you need support for both 1.x and 2.x chain with the same codebase, + /// it is recommended to use `CosmosMsg::Stargate` with a custom MsgTransfer + /// protobuf encoder instead. + memo: Option, + // a struct containing the list of next hops, + // determining where the tokens must be forwarded next, + // and the memo for the final hop + forwarding: Forwarding, + }, /// Sends an IBC packet with given data over the existing channel. /// Data should be encoded in a format defined by the channel version, /// and the module on the other side should know how to parse this.