9 stable releases
1.3.0 | Dec 3, 2024 |
---|---|
1.2.6 | Dec 3, 2024 |
1.2.0 | Nov 30, 2024 |
1.1.0 | Oct 6, 2024 |
#85 in #contracts
19KB
215 lines
CW83: Smart Account Registry
An interface for CosmWasm based smart contracts defining interaction with smart account registries used for creating smart contract based account defined in CW82
Queries
All CW83-compliant registries must define a message with the following variants in for their query endpoint
enum QueryMsg {
...
#[returns(AccountInfoResponse)]
AccountInfo(AccountQuery)
...
}
Where AccountQuery is defined in the following manner
struct AccountQuery<T = Empty> {
pub query: T
}
Different implementations are free to customise the query in any desirable manner to link an account to a username, a non-fungible token, credential info and so on.
The response type enforces the contracts implementing the standard to return a smart account address corresponsing to the query and leave a room to customize for returning addition info related to the account
struct AccountInfoResponse<T = Empty> {
pub address: String,
pub info: Option<T>
}
Messages
The only required message variant for the execute endpoint is `CreateAccount``:
enum ExecuteMsg {
...
CreateAccount(CreateAccountMsg)
...
}
where CreateAccountMsg is defined in the following manner:
struct CreateAccountMsg<T = Binary> {
pub code_id: u64,
pub chain_id: String,
pub msg: T
}
allowing contracts to define payload needed for validation in the registry and also for generating an instantiation message for smart account contracts
Usage
A contract that wishes to follow the standard must add the variants described above to their query and execute messages. This package exposes a helper macro attribute registry_query
that injects it automatically:
#[registry_query] // <- Must be before #[cw_serde]
#[cw_serde]
#[derive(QueryResponses)]
enum QueryMsg {}
Modules using the message must ether import AccountQuery
from cw83 package or to define it manually. Here is an example of customising it from token bound account registry:
use cw83::AccountQuery as AccountQueryBase;
#[cw_serde]
pub struct TokenInfo {
pub collection: String,
pub id: String,
}
pub type AccountQuery = AccountQueryBase<TokenInfo>;
Defining execute message can also happen through a helper
#[registry_execute]
#[cw_serde]
pub enum Cw83ExecuteMsg {}
Note: AccountQuery
must also be imported
Same scenario must be repeated for CreateAccountMsg
. An example of customizing a message from the tba-registry:
use cw83::CreateAccountMsg as CreateAccountMsgBase
#[cw_serde]
pub struct CreateInitMsg {
pub token_info: TokenInfo,
pub pubkey: Binary,
}
pub type CreateAccountMsg = CreateAccountMsgBase<CreateInitMsg>;
If a contract doesn't define additional variants it can directly use Cw83QueryMsg
and Cw83ExecuteMsg
from the package directly
Examples
Example contracts can be found in this repository and are prefixed with cw83-
Contract | Description |
---|---|
cw83-tba-registry |
A Registry of token bound accounts |
Dependencies
~4–6MB
~126K SLoC