pub enum StdAck {
    Success(Binary),
    Error(String),
}Expand description
This is a standard IBC acknowledgement type. IBC application are free to use any acknowledgement format they want. However, for compatibility purposes it is recommended to use this.
The original proto definition can be found at https://github.com/cosmos/cosmos-sdk/blob/v0.42.0/proto/ibc/core/channel/v1/channel.proto#L141-L147 and https://github.com/cosmos/ibc/tree/ed849c7bac/spec/core/ics-004-channel-and-packet-semantics#acknowledgement-envelope.
In contrast to the original idea, ICS-20 and CosmWasm IBC protocols use JSON instead of a protobuf serialization.
For compatibility, we use the field name “result” for the success case in JSON. However, all Rust APIs use the term “success” for clarity and discriminability from Result.
If ibc_receive_packet returns Err(), then x/wasm runtime will rollback the state and return an error message in this format.
§Examples
For your convenience, there are success and error constructors.
use cosmwasm_std::StdAck;
let ack1 = StdAck::success(b"\x01"); // 0x01 is a FungibleTokenPacketSuccess from ICS-20.
assert!(ack1.is_success());
let ack2 = StdAck::error("kaputt"); // Some free text error message
assert!(ack2.is_error());Variants§
Implementations§
Source§impl StdAck
 
impl StdAck
pub const fn is_success(&self) -> bool
pub const fn is_error(&self) -> bool
Sourcepub fn to_binary(&self) -> Binary
 
pub fn to_binary(&self) -> Binary
Serialized the ack to binary using JSON. This used for setting the acknowledgement field in IbcReceiveResponse.
§Examples
Show how the acknowledgement looks on the write:
let ack1 = StdAck::success(b"\x01"); // 0x01 is a FungibleTokenPacketSuccess from ICS-20.
assert_eq!(ack1.to_binary(), br#"{"result":"AQ=="}"#);
let ack2 = StdAck::error("kaputt"); // Some free text error message
assert_eq!(ack2.to_binary(), br#"{"error":"kaputt"}"#);Set acknowledgement field in IbcReceiveResponse:
use cosmwasm_std::{StdAck, IbcReceiveResponse};
let ack = StdAck::success(b"\x01"); // 0x01 is a FungibleTokenPacketSuccess from ICS-20.
let res: IbcReceiveResponse = IbcReceiveResponse::new().set_ack(ack.to_binary());
let res: IbcReceiveResponse = IbcReceiveResponse::new().set_ack(ack); // Does the same but consumes the instancepub fn unwrap(self) -> Binary
pub fn unwrap_err(self) -> String
Trait Implementations§
Source§impl<'de> Deserialize<'de> for StdAck
 
impl<'de> Deserialize<'de> for StdAck
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
    __D: Deserializer<'de>,
 
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
    __D: Deserializer<'de>,
Source§impl JsonSchema for StdAck
 
impl JsonSchema for StdAck
Source§fn schema_name() -> String
 
fn schema_name() -> String
Source§fn schema_id() -> Cow<'static, str>
 
fn schema_id() -> Cow<'static, str>
Source§fn json_schema(gen: &mut SchemaGenerator) -> Schema
 
fn json_schema(gen: &mut SchemaGenerator) -> Schema
Source§fn is_referenceable() -> bool
 
fn is_referenceable() -> bool
$ref keyword. Read more