Crates.io | abstract-standalone |
lib.rs | abstract-standalone |
version | 0.24.1 |
source | src |
created_at | 2024-07-16 09:50:55.207411 |
updated_at | 2024-10-25 16:17:57.1542 |
description | base standalone contract implementation |
homepage | |
repository | |
max_upload_size | |
id | 1304886 |
size | 99,542 |
This crate contains a StandaloneContract
struct that can be used to interact with the abstract on-chain infrastructure.S
First, import the crate in your Cargo.toml
.
[dependencies]
abstract-standalone = "<latest version>"
You can then define the contract's constant:
pub const CONTRACT_ID: &str = "my-namespace:my-contract";
pub const VERSION: &str = env!("CARGO_PKG_VERSION");
pub const MY_CONTRACT: MockStandaloneContract =
MockStandaloneContract::new(CONTRACT_ID, VERSION, None);
Next, include the StandaloneInstantiateMsg
struct in your contract's instantiate message. We'll need this data to instantiate the MY_CONTRACT
state.
use abstract_standlone::StandaloneInstantiateMsg;
#[cosmwasm_schema::cw_serde]
pub struct InstantiateMsg {
pub base: StandaloneInstantiateMsg,
// .. Your custom fields here.
}
Then, use the StandaloneInstantiateMsg
struct to instantiate the state.
#[cosmwasm_std::entry_point]
pub fn instantiate(
deps: DepsMut,
env: Env,
info: MessageInfo,
msg: InstantiateMsg,
) -> Result<Response, MockError> {
MY_CONTRACT.instantiate(deps, info, msg.base, true)?;
// Your custom logic here.
}
Finally, you can use the MY_CONTRACT
const to interact with the Abstract on-chain infrastructure through our APIs.
#[cosmwasm_std::entry_point]
pub fn execute(
deps: DepsMut,
env: Env,
info: MessageInfo,
msg: ExecuteMsg,
) -> Result<Response, MockError> {
// Example of using an Abstract API.
let bank: Bank<StandaloneContract> = MY_CONTRACT.bank(deps.as_ref());
let account_balance: Coin = bank_api.balance(&AssetEntry::new("abstract"))?;
// ...
Ok(MY_CONTRACT.response("mock_exec"))
}