26 releases (12 breaking)

0.17.1 Jan 26, 2023
0.16.0 Dec 16, 2022
0.15.1 Sep 22, 2022
0.13.0 Jul 26, 2022
0.8.1 Mar 29, 2022

#2290 in Magic Beans


Used in 2 crates

Apache-2.0

195KB
4K SLoC

TG4 Stake

This is a second implementation of the tg4_spec. It fulfills all elements of the spec, including the raw query lookups, and is designed to be used as a backing storage for tg3 compliant contracts.

It provides a similar API to tg4-engagement (which handles elected membership), but rather than appointing members (by admin or multisig), their membership and points are based on the number of tokens they have staked. This is similar to many DAOs.

Only one denom can be bonded with both min_bond as the minimum amount that must be sent by one address to enter, as well as tokens_per_point, which can be used to normalize the points (e.g. if the token is uatom, and you want 1 points per ATOM, you can set tokens_per_point = 1_000_000).

There is also an unbonding period (Duration) which sets how long the tokens are frozen before being released. These frozen tokens can neither be used for voting, nor claimed by the original owner. Only after the period can you get your tokens back. This liquidity loss is the "skin in the game" provided by staking to this contract.

Instantiation

TODO

To create it, you must pass in a list of members, as well as an optional admin, if you wish it to be mutable.

pub struct InstantiateMsg {
    /// denom of the token to stake
    pub stake: String,
    pub tokens_per_points: u64,
    pub min_bond: Uint128,
    pub unbonding_period: Duration,
}

Members are defined by an address and a points. This is transformed and stored under their CanonicalAddr, in a format defined in tg4 raw queries.

Note that 0 is an allowed number of points. This doesn't give any voting rights, but it does define this address is part of the group, which may be meaningful in some circumstances.

The points of the members will be computed as the funds they send (in tokens) divided by tokens_per_points, rounded down to the nearest whole number (i.e. using integer division). If the total sent is less than min_bond, the stake will remain, but they will not be counted as a member. If min_bond is higher than tokens_per_points, you cannot have any member with 0 points.

Messages

Most messages and queries are defined by the tg4 spec. Please refer to it for more info.

The following messages have been added to handle un/staking tokens:

Bond{} - bond all staking tokens sent with the message and update membership points

Unbond{tokens} - starts the unbonding process for the given number of tokens. The sender immediately loses points from these tokens, and can claim them back to his wallet after unbonding_period. tokens is a structure of { amount: token_amount, denom: token_denom }.

Claim{} - used to claim your native tokens that you previously "unbonded" after the contract-defined waiting period (e.g. 1 week)

And the corresponding queries:

Claims{address} - Claims shows the tokens in process of unbonding for this address

Staked{address} - Show the number of tokens currently staked by this address.

Dependencies

~4.5–6.5MB
~134K SLoC