sv::payload attribute

Use sv::payload to specify if the SubMsg::payload should be forwarded as Binary. Exactly ONE reply method parameter can be marked with the sv::payload attribute. If missing, Sylvia will deserialize the payload to types defined after the sv::data parameter.

💡

To use sv::payload attribute pre Sylvia 2.0.0, you need to enable the replies feature using the sv::features.

Macros

List of macros supporting the sv::data attribute:

Usage

#[cw_serde]
pub struct ReplyPayload {
    pub receiver: Addr,
    pub coins: Coin,
}
 
pub struct Contract;
 
#[cfg_attr(feature = "library", sylvia::entry_points)]
#[contract]
#[sv::features(replies)]
impl Contract {
    pub const fn new() -> Self {
        Self
    }
 
    #[sv::msg(instantiate)]
    fn instantiate(&self, ctx: InstantiateCtx) -> StdResult<Response> {
        Ok(Response::new())
    }
 
    #[sv::msg(reply, reply_on=success)]
    fn success_handler(
        &self,
        ctx: ReplyCtx,
        #[sv::payload(raw)] payload: Binary,
    ) -> StdResult<Response> {
        Ok(Response::new())
    }
 
    #[sv::msg(reply, reply_on=error)]
    fn error_handler(
        &self,
        ctx: ReplyCtx,
        error: String,
        payload: ReplyPayload,
    ) -> StdResult<Response> {
        Ok(Response::new())
    }
 
    #[sv::msg(reply, reply_on=always)]
    fn always_handler(
        &self,
        ctx: ReplyCtx,
        result: SubMsgResult,
        receiver: Addr,
        coins: Coin,
    ) -> StdResult<Response> {
        Ok(Response::new())
    }
}

Sylvia uses the from_json to deserialize the payload field, so it has to be serialized do JSON.