CCIP Number | 022 |
---|---|
Title | CityCoins Treasury Redemption NYC |
Author(s) | Raphael R. Sierra [email protected] |
Jason Schrader [email protected] | |
Consideration | Governance |
Type | Standard |
Status | Ratified |
Created | 2024-04-23 |
License | BSD-2-Clause |
Supplements | CCIP-020 |
With the execution of CCIP-020 Graceful Protocol Shutdown1 the functions for mining and stacking CityCoins are disabled.
Following that, this CCIP proposes a redemption mechanism for NYC token holders to be fairly compensated by redeeming their NYC for a portion of the STX held in the NYC mining treasury2.
This CCIP will implement a new redemption extension for NYC.
The redemption extension will:
- receive and hold funds from the NYC mining treasury contract2
- record the combined total supply of NYC at the time of initialization
- calculate the ratio of NYC to STX based on the total supply and contract balance
- allow users to burn NYC in exchange for their portion of STX
- track and return the redemption information for the contract and its users
The NYC mining treasury2 currently holds 15.5M STX and upon successful execution of this proposal the entire balance will be transferred to the redemption extension.
Following the transfer and upon initialization from the proposal, the redemption extension will:
- get the total supply for NYC V13 and NYC V24
- add the total supplies accounting for decimal differences
- NYC V1 has 0 decimals
- NYC V2 has 6 decimals
- get the balance of the redemption contract itself
- set variables representing all data gathered above
- create a redemption ratio from
balance / total supply
- set a variable that redemption is enabled, allowing access
The redemption extension then exposes a public function that:
- calculates amount to transfer based on
balance * redemption ratio
- verify that redemption is enabled
- verify there is something to burn (NYC V1 or V2)
- verify there is something to redeem
- burn the NYC balance for the user
- transfer the redemption STX to the user from the contract
- store redemption info for the user and the contract
- print the redemption info from the read only functions
This CCIP is supplemental to CCIP-0201 and not backwards compatible.
This CCIP will be voted on using a vote contract that adheres to CCIP-0155 using the last two active stacking cycles for the protocol.
- MIA cycles 82 and 83
- NYC cycles 82 and 83
No scale factor is required.
Voting will begin when the contract is deployed and continue until the proposal is executed.
This CCIP follows the same voting format as CCIP-0201 except only NYC votes are counted.
- the votes are tallied and available in read-only functions
- the proposal will not pass unless 25% of NYC have participated
- CCIP-022 Proposal: ccip022-citycoins-treasury-redemption-nyc.clar6
- CCD-012 Redemption Extension: ccd012-redemption-nyc.clar7
Footnotes
-
https://github.com/citycoins/governance/blob/main/ccips/ccip-020/ccip-020-graceful-protocol-shutdown.md ↩ ↩2 ↩3
-
https://explorer.hiro.so/txid/SP8A9HZ3PKST0S42VM9523Z9NV42SZ026V4K39WH.ccd002-treasury-nyc-mining-v2?chain=mainnet ↩ ↩2 ↩3
-
https://explorer.hiro.so/txid/SP2H8PY27SEZ03MWRKS5XABZYQN17ETGQS3527SA5.newyorkcitycoin-token?chain=mainnet ↩
-
https://explorer.stacks.co/txid/SPSCWDV3RKV5ZRN1FQD84YE1NQFEDJ9R1F4DYQ11.newyorkcitycoin-token-v2?chain=mainnet ↩
-
https://github.com/citycoins/governance/blob/main/ccips/ccip-015/ccip-015-community-proposal-voting-process.md ↩
-
https://github.com/citycoins/protocol/blob/fix/implement-ccip-022/contracts/proposals/ccip022-citycoins-treasury-redemption-nyc.clar ↩
-
https://github.com/citycoins/protocol/blob/fix/implement-ccip-022/contracts/extensions/ccd012-redemption-nyc.clar ↩