56 releases (6 stable)

2.0.0 Mar 26, 2024
1.1.2 Nov 23, 2023
1.1.0 Jun 19, 2023
1.0.1 Dec 19, 2022
0.3.2 Oct 28, 2020

#4 in #staked

Download history 232/week @ 2025-08-17 379/week @ 2025-08-24 547/week @ 2025-08-31 403/week @ 2025-09-07 478/week @ 2025-09-14 408/week @ 2025-09-21 623/week @ 2025-09-28 307/week @ 2025-10-05 287/week @ 2025-10-12 397/week @ 2025-10-19 307/week @ 2025-10-26 260/week @ 2025-11-02 307/week @ 2025-11-09 326/week @ 2025-11-16 424/week @ 2025-11-23 224/week @ 2025-11-30

1,322 downloads per month
Used in 33 crates (5 directly)

Apache-2.0

8KB
64 lines

CW1 Spec: Proxy Contracts

CW1 is a specification for proxy contracts based on CosmWasm. It is a very simple, but flexible interface designed for the case where one contract is meant to hold assets (or rights) on behalf of other contracts.

The simplest example is a contract that will accept messages from the creator and resend them from its address. Simply by making this transferable, you can then begin to transfer non-transferable assets (eg. staked tokens, voting power, etc).

You can imagine more complex examples, such as a "1 of N" multisig, or conditional approval, where "sub-accounts" have the right to spend a limited amount of funds from this account, with a "admin account" retaining full control.

The common denominator is that they allow you to immediately execute arbitrary CosmosMsg in the same transaction.

Messages

Execute{msgs} - This accepts Vec<CosmosMsg> and checks permissions before re-dispatching all those messages from the contract address. It emits the following attributes:

Key Value
"action" "execute"
"owner" [msg sender]

Queries

CanExecute{sender, msg} - This accepts one CosmosMsg and checks permissions, returning true or false based on the permissions. If CanExecute returns true then a call to Execute from that sender, with the same message, before any further state changes, should also succeed. This can be used to dynamically provide some client info on a generic cw1 contract without knowing the extension details. (eg. detect if they can send coins or stake)

Dependencies

~4–7.5MB
~154K SLoC