diff --git a/examples/contracts/custom/src/contract.rs b/examples/contracts/custom/src/contract.rs index df0806a7..4890aa2d 100644 --- a/examples/contracts/custom/src/contract.rs +++ b/examples/contracts/custom/src/contract.rs @@ -1,5 +1,6 @@ use cosmwasm_std::{CosmosMsg, QueryRequest, Response, StdResult}; -use sylvia::types::{ExecCtx, InstantiateCtx, QueryCtx}; +use cw_storage_plus::Item; +use sylvia::types::{ExecCtx, InstantiateCtx, QueryCtx, SudoCtx}; use sylvia::{contract, schemars}; #[cfg(not(feature = "library"))] @@ -7,7 +8,9 @@ use sylvia::entry_points; use crate::messages::{CountResponse, CounterMsg, CounterQuery}; -pub struct CustomContract; +pub struct CustomContract { + pub(crate) sudo_counter: Item<'static, u64>, +} #[cfg_attr(not(feature = "library"), entry_points)] #[contract] @@ -15,14 +18,17 @@ pub struct CustomContract; #[sv::custom(query=CounterQuery, msg=CounterMsg)] impl CustomContract { pub const fn new() -> Self { - Self + Self { + sudo_counter: Item::new("sudo_counter"), + } } #[msg(instantiate)] pub fn instantiate( &self, - _ctx: InstantiateCtx, + ctx: InstantiateCtx, ) -> StdResult> { + self.sudo_counter.save(ctx.deps.storage, &0)?; Ok(Response::default()) } @@ -42,4 +48,21 @@ impl CustomContract { Ok(resp) } + + #[msg(query)] + pub fn sudo_counter(&self, ctx: QueryCtx) -> StdResult { + let count = self.sudo_counter.load(ctx.deps.storage)?; + + Ok(CountResponse { count }) + } + + #[msg(sudo)] + pub fn increment_sudo_counter( + &self, + ctx: SudoCtx, + ) -> StdResult> { + self.sudo_counter + .update(ctx.deps.storage, |value| -> StdResult<_> { Ok(value + 1) })?; + Ok(Response::new()) + } } diff --git a/examples/contracts/custom/src/multitest/tests.rs b/examples/contracts/custom/src/multitest/tests.rs index 566ee7ff..6edc9eb9 100644 --- a/examples/contracts/custom/src/multitest/tests.rs +++ b/examples/contracts/custom/src/multitest/tests.rs @@ -24,4 +24,9 @@ fn test_custom() { let count = contract.query_custom().unwrap().count; assert_eq!(count, 1); + + contract.increment_sudo_counter().unwrap(); + + let count = contract.sudo_counter().unwrap().count; + assert_eq!(count, 1); } diff --git a/sylvia-derive/src/message.rs b/sylvia-derive/src/message.rs index 603f5672..0ed9212d 100644 --- a/sylvia-derive/src/message.rs +++ b/sylvia-derive/src/message.rs @@ -777,7 +777,6 @@ impl<'a> MsgVariant<'a> { fn #name (&self, #(#params,)* ) -> Result<#return_type, #error_type>; } } - , MsgType::Sudo => quote! { fn #name (&self, #(#params,)* ) -> Result< #sylvia ::cw_multi_test::AppResponse, #error_type>; },