dev-resources.site
for different kinds of informations.
Smartcontract with CosmWasm (Part 5)
Introduction
I come back after work personal. Thanks to everyone following and supporting me and that's the end of the series.
Build the contract
We need to define the schema of the contract in the file examples/schema.rs
. Import all schemas we have from previous part as: State
, InstantiateMsg
, ExecuteMsg
, QueryMsg
, ExecuteResponse
, QueryResponse
:
use std::env::current_dir;
use std::fs::create_dir_all;
use cosmwasm_schema::{export_schema, remove_schemas, schema_for};
use cw_starter::msg::{ExecuteMsg, ExecuteResponse, InstantiateMsg, QueryMsg, QueryResponse};
use cw_starter::state::State;
fn main() {
let mut out_dir = current_dir().unwrap();
out_dir.push("schema");
create_dir_all(&out_dir).unwrap();
remove_schemas(&out_dir).unwrap();
export_schema(&schema_for!(State), &out_dir);
export_schema(&schema_for!(InstantiateMsg), &out_dir);
export_schema(&schema_for!(ExecuteMsg), &out_dir);
export_schema(&schema_for!(ExecuteResponse), &out_dir);
export_schema(&schema_for!(QueryMsg), &out_dir);
export_schema(&schema_for!(QueryResponse), &out_dir);
}
We push all json
schema to the schema
directory. Now, we generate our schemas
Run command in the terminal in the root our folder:
cargo schema
After the command runs successfully, we will see the json schemas in the schema
folder.
The preparation step is alright. Next, build the smart contract with CosmWasm IDE
.
Open the file src/contract.rs
and click Build CosmWasm
in the status bar and wait for the extension to build our contract. After the building has been done, we find a new file: artifacts/cw-starter.wasm
and the UI of the extension will appear. This is our contract:
Note: We are using these dependencies in Cargo.toml
, so we need to choose the chain support our contract as: Malaga
, Osmosis Testnet
, Osmosis Mainnet
and CosmosHub Testnet
and add your mnemonic to the file .env
in the root project for extension to read mnemonic and interact with your wallet.
[dependencies]
cosmwasm-std = "1.0.0"
cosmwasm-storage = "1.0.0"
cw-storage-plus = "0.13.2"
cw2 = "0.13.2"
schemars = "0.8.8"
serde = { version = "1.0.137", default-features = false, features = ["derive"] }
thiserror = { version = "1.0.31" }
Alright, we move to the next step: Deploy the contract on the chain.
Deploy the contract
First of all, select the chain, I will choose the Osmosis Testnet
.
We need complete all fields when deploying the contract. In our case, the InstantiateMsg
doesn't need any field, so we only need to input the label of the contract or you can ignore it.
Let's deploy with the Deploy CosmWasm
and wait for our contract StoreCode
and Instantiate
to the chain. After deployment success, we have a contract address.
Execute the contract
Open the select box and choose Execute
, input the contract address we get from the above step and the following message in the Execute Message
input.
Need input your mnemonic in the wallet mnemonic(optional)
(I know that is confusing, but it is required).
{"update":{}}
Press the Execute
button. The extension will execute our contract and return the transaction containing msg execute the contract.
Query the contract
Same execute the contract, I will move fast:
Select the Query, input our contract address and input the Query Message
:
{"counter":{}}
Press the Query
button and tada! And the current state of the contract will appear.
Summary
That's the end of the series. I hope after this series, we have a simple term, development code and interact with CosmWasm Smart Contract.
Thanks for reading.
Reference
Featured ones: