Canister Developer Kit for the Internet Computer.
On the Internet Computer, smart contracts come in the form of canisters which are WebAssembly modules.
Canisters expose entry points which can be called both by other canisters and by parties external to the IC.
This library aims to provide a Rust-ergonomic abstraction to implement Canister entry points.
ic-cdk
In Cargo.toml:
[lib]
crate-type = ["cdylib"]
[dependencies]
ic-cdk = "0.15"
candid = "0.10" # required if you want to define Candid data types
Then in Rust source code:
#[ic_cdk::query]
fn hello() -> String {
"world".to_string()
}
This will register a query entry point named hello
.
This library re-exports macros defined in ic-cdk-macros
crate.
The macros fall into two categories:
These macros are directly related to the Internet Computer Specification.
Check Generating Candid files for Rust canisters for more details.
ic-cdk
API.Using the ic_cdk::storage::{stable_save, stable_restore}
API is easy but it doesn’t scale well.
ic-stable-structures
is recommended when you are dealing with multiple data structures with larger datasets.
get_candid_pointer
method so that dfx
can execute it to extract candid definition.canister_heartbeat
entry point of a canister.canister_init
entry point of a canister.canister_inspect_message
entry point of a canister.canister_on_low_wasm_memory
entry point of a canister.canister_post_upgrade
entry point of a canister.canister_pre_upgrade
entry point of a canister.