| Crates.io | abstract-standalone |
| lib.rs | abstract-standalone |
| version | 0.26.1 |
| created_at | 2024-07-16 09:50:55.207411+00 |
| updated_at | 2025-06-09 08:27:57.881693+00 |
| description | base standalone contract implementation |
| homepage | |
| repository | |
| max_upload_size | |
| id | 1304886 |
| size | 100,155 |
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"))
}