CCIP Number | 004 |
---|---|
Title | CityCoins Stacking |
Author(s) | Jason Schrader jason@joinfreehold.com |
Consideration | Technical |
Type | Standard |
Status | Ratified |
Created | 2022-03-16 |
License | BSD-2-Clause |
The Stacks blockchain is a Layer 1 blockchain connected to Bitcoin, in which miners spend Bitcoin to bid for and win a fixed amount of Stacks tokens. Stackers have the option to lock up Stacks tokens for a specified amount of time, and in turn, receive a portion of the Bitcoin spent by miners proportionate to the amount Stacked1.
Taking this concept a level further, a new token (a "CityCoin") is created on the Stacks blockchain, following the SIP-010 fungible token standard2, such that CityCoins can be mined and Stacked per the methods stated above except a portion of the miner's bid would be redirected to the city's wallet overseen by a trusted third party custodian.
CityCoins leverage similar properties from the Proof of Transfer (PoX) consensus mechanism3 of the Stacks blockchain, programmed through a smart contract in Clarity.
This proposal describes the stacking functionality for a CityCoin.
Anyone can Stack CityCoins by temporarily locking them in a CityCoins smart contract for a selected number of reward cycles. By doing so, stackers receive a portion of the remaining 70% of the STX sent by miners.
Stacking occurs over cycles that are 2,100 Stacks blocks in length, starting from the activation block height of the CityCoin core contract.
More information about Activation can be found in CCIP-002.
Through the stack-tokens
function, a principal can submit:
- the amount of CityCoins to be stacked
- the number of reward cycles to participate in
A stacker can participate in up to a maximum of 32 reward cycles at a time. Using the average block time of ten minutes per block, a single reward cycle is about two weeks in length and the maximum lock-up time is about sixteen months.
Stacking always begins in the next reward cycle, and after the stacking cycles are complete the principal will be ineligible to stack for one cycle, or a "cool down period".
Stacked CityCoins are transferred to the contract, and can be reclaimed when the selected number of reward cycles have passed.
Within the core contract are variables to track:
- the maximum amount of reward cycles
- a list used as the reward cycle index
- how long a reward cycle is in Stacks blocks
- the stacking statistics for a given cycle
- the stacker statistics for a given cycle and user ID
When a principal submits CityCoins for stacking, the contract then:
- obtains the user ID for the principal, or creates one if it does not already exist
- verifies the contract is activated
- verifies the amount of CityCoins is greater than 0
- transfers the CityCoins to the contract
- updates the stacking statistics and stacker statistics for the number of cycles selected
After a stacking cycle has completed a principal can claim the stacking rewards from that cycle, and if the total cycles selected are complete, the principal can reclaim their CityCoins.
The amount of STX a principal can claim is determined during a given cycle based on the amount stacked by the principal R
, the total STX reward S
, and the total stacked by all principals T
using the formula:
STX Rewards = (R * S) / T
Through the get-entitled-stacking-reward
function, the value of uSTX the principal can claim is returned if:
- the current block height is in a subsequent reward cycle
- the stacker actually locked up tokens in the target reward cycle
- the stacker locked up enough tokens to get at least one uSTX
It is possible to Stack CityCoins and not receive uSTX if:
- no miners commit during this reward cycle
- the amount stacked by user is too few that you'd be entitled to less than 1 uSTX
Through the get-stacker-at-cycle
function, the amount of CityCoins the principal can claim is returned as the toReturn
value.
Through the claim-stacking-reward
function, a principal can submit the target cycle to claim, and the contract will:
- verify that the reward cycle is complete, or continue if contract is shut down
- verify there are either STX or CityCoins to claim
- updates the stacker statistics to clear the values
- transfers the eligible STX and CityCoins to the principal
None, this is the initial implementation.
None, this is the initial implementation.
MiamiCoin Contracts:
miamicoin-core-v1
deployed on the Stacks mainnet4, implementing:- the
get-stacker-at-cycle
function on lines 574-576 - the
get-entitled-stacking-reward
function on lines 613-642 - the
stack-tokens
function on lines 646-654 - the
claim-stacking-reward
function on lines 750-756
- the
NewYorkCityCoin Contracts:
newyorkcitycoin-core-v1
deployed on the Stacks mainnet5, implementing:- the
get-stacker-at-cycle
function on lines 579-581 - the
get-entitled-stacking-reward
function on lines 618-647 - the
stack-tokens
function on lines 651-659 - the
claim-stacking-reward
function on lines 759-765
- the
Footnotes
-
https://github.com/stacksgov/sips/blob/main/sips/sip-010/sip-010-fungible-token-standard.md ↩
-
https://docs.stacks.co/understand-stacks/proof-of-transfer ↩
-
https://explorer.stacks.co/txid/SP466FNC0P7JWTNM2R9T199QRZN1MYEDTAR0KP27.miamicoin-core-v1?chain=mainnet ↩
-
https://explorer.stacks.co/txid/SP2H8PY27SEZ03MWRKS5XABZYQN17ETGQS3527SA5.newyorkcitycoin-core-v1?chain=mainnet ↩