-
Notifications
You must be signed in to change notification settings - Fork 359
/
Copy pathreceiver.rs
37 lines (31 loc) · 1.01 KB
/
receiver.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
use cosmwasm_schema::cw_serde;
use cosmwasm_std::{to_json_binary, Binary, CosmosMsg, StdResult, Uint128, WasmMsg};
/// Cw20ReceiveMsg should be de/serialized under `Receive()` variant in a ExecuteMsg
#[cw_serde]
pub struct Cw20ReceiveMsg {
pub sender: String,
pub amount: Uint128,
pub msg: Binary,
}
impl Cw20ReceiveMsg {
/// serializes the message
pub fn into_json_binary(self) -> StdResult<Binary> {
let msg = ReceiverExecuteMsg::Receive(self);
to_json_binary(&msg)
}
/// creates a cosmos_msg sending this struct to the named contract
pub fn into_cosmos_msg<T: Into<String>>(self, contract_addr: T) -> StdResult<CosmosMsg> {
let msg = self.into_json_binary()?;
let execute = WasmMsg::Execute {
contract_addr: contract_addr.into(),
msg,
funds: vec![],
};
Ok(execute.into())
}
}
// This is just a helper to properly serialize the above message
#[cw_serde]
enum ReceiverExecuteMsg {
Receive(Cw20ReceiveMsg),
}