15 releases (8 breaking)
0.10.0 | Apr 4, 2023 |
---|---|
0.9.0 | Mar 25, 2023 |
0.8.0 | Mar 9, 2023 |
0.3.0 | Dec 16, 2022 |
0.2.0-rc.1 | Nov 29, 2022 |
#21 in #entry-point
Used in 7 crates
130KB
3K
SLoC
BOOT
Multi-environment CosmWasm smart-contract scripting library. Documentation is available at boot.abstract.money.
BOOT is inspired by terra-rust-api and uses cosmos-rust for protocol buffer gRPC communication.
boot-cw-plus uses BOOT to provide standard type-safe interfaces for interacting with cw-plus contracts.
BOOT makes it easier to quickly deploy and iterate on your contracts. It provides a set of macros that allow you to define your contracts in a way that is more similar to how you would write them in Rust. This allows you to use the full power of Rust's type system to ensure that you are not sending invalid messages to your contracts. .
How it works
Interacting with a CosmWasm is possible through the contract's endpoints using the appropriate message for that endpoint (ExecuteMsg
,InstantiateMsg
, QueryMsg
, MigrateMsg
, etc.).
In order to perform actions on the contract you can define an interface to your contract, passing the contract's entry point types into the contract
macro:
#[contract(InstantiateMsg, ExecuteMsg, QueryMsg, MigrateMsg)]
pub struct MyContract;
The macro implements a set of traits for the struct. These traits contain functions that can then be used to interact with the contract and they prevent us from executing a faulty message on a contract.
As an example you can have a look at the the implementation for a CW20 token here.
You can then use this interface to interact with the contract:
...
let cw20_base: Cw20<Chain> = Cw20::new("my_token", chain);
// instantiate a CW20 token instance
let cw20_init_msg = cw20_base::msg::InstantiateMsg {
decimals: 6,
name: "Test Token".to_string(),
initial_balances: vec![Cw20Coin {
address: sender.to_string(),
amount: 1000000u128.into(),
}],
marketing: None,
mint: None,
symbol: "TEST".to_string(),
};
cw20_base.instantiate(&cw20_init_msg, None, None)?;
// query balance
// notice that this query is generated by a macro and not defined in the object itself!
let balance = cw20_base.balance(sender.to_string())?;
You can find the full cw20 implementation here. An example of how to interact with a contract in cw-multi-test
can be found here while the same interaction on a real node can be found here.
Advanced features
BOOT provides two additional macros that can be used to improve the scripting experience.
ExecuteFns
The ExecuteFns
macro can be added to the ExecuteMsg
definition of your contract. It will generate a trait that allows you to call the variants of the message directly without the need to construct the struct yourself.
Example:
#[cw_serde]
#[derive(ExecuteFns)]
pub enum ExecuteMsg{
/// Freeze will make a mutable contract immutable, must be called by an admin
Freeze {},
/// UpdateAdmins will change the admin set of the contract, must be called by an existing admin,
/// and only works if the contract is mutable
UpdateAdmins { admins: Vec<String> },
/// the `payable` attribute will add a `coins` argument to the generated function
#[payable]
Deposit {}
}
#[contract(Empty,ExecuteMsg,Empty,Empty)]
struct Cw1
impl<Chain: CwEnv> Cw1<Chain> {
pub fn test_macro(&self) {
self.freeze().unwrap();
self.update_admins(vec![]).unwrap();
self.deposit(&[Coin::new(13,"juno")]).unwrap();
}
}
We recommend shielding the
ExecuteMsgFns
macro behind a feature flag to avoid pulling inboot-core
by default. The resulting derive would look like this:#[cfg_attr(feature = "boot", derive(boot_core::ExecuteFns))]
For nested execute messages you can add an impl_into
attribute. This expects the message to implement the Into
trait for the provided type.
QueryFns
The QueryFns
derive macro works in the same way as the ExecuteFns
macro but it also uses the #[returns(QueryResponse)]
attribute from cosmwasm-schema
to generate the queries with the correct response types.
Contributing
We'd really appreciate your help! Please read our contributing guidelines to get started.
Documentation
The documentation is generated using mdbook. Edit the files in the docs/src
folder and run
cd docs && mdbook serve --open --port 5000
to view the changes.
References
Enjoy scripting your smart contracts with ease? Build your contracts with ease by using Abstract.
Disclaimer
This software is provided as-is without any guarantees.
Dependencies
~9–28MB
~471K SLoC