An evm and solana system to play chicken pools.
contracts - contains the solidity smart contracts programs - contains the solana programs test - contains the tests for the both evm and solana programs lib - contains the libraries used by the solidity smart contracts and libraries for the solana programs script - cotains the foundry scripts used to deploy the contracts
Chicken Pools aim to enhance holding times for meme coins by introducing time-based pools where participants strategically plan their exits within incentivized time frames. This shift focuses on "when to sell" rather than simply "holding for long periods," allowing for higher engagement and reward opportunities over intervals ranging from 15 minutes to 5 days.
In designing Chicken Pools, the project team is addressing several unique pool mechanics to encourage active participation without relying on prolonged engagement. Key design elements include:
-
Reward and Payout Models: The team is evaluating whether to use time-based rewards that distribute payouts based on participant timing or a binary winner/loser approach. Additionally, different payout triggers are being explored, such as selling thresholds at 50% or 75% of initial pool deposits, to create predictable yet strategic incentives.
-
Creator Incentives: To boost pool creation, creators are allowed to contribute initial deposits and potentially receive additional incentives. These incentives make starting new pools attractive and provide a wider selection of options for players.
Chicken Pools encourage faster-paced decision making, appealing to users interested in short-term, high-engagement scenarios where timing and exit strategy are key.
Key aspects of the technical architecture include:
-
Smart Contract-Based Actions: All player actions, including deposits, withdrawals, and claims, are processed through the smart contract, eliminating the need for complex wallet monitoring. This allows the contract itself to manage all relevant checks, validations, and balances.
-
Multi-Interface Support: The contract will support integration with multiple interfaces, including web-based UI, in-app functionality, and Telegram. This multi-interface approach ensures accessibility across various platforms, allowing users to interact with Chicken Pools from wherever is most convenient.
The project’s overall goal is to provide a reliable, high-engagement experience for meme coin holders, emphasizing short-term rewards and active decision-making. Chicken Pools aims to create a vibrant ecosystem where participants can focus on strategic timing without the need for extensive holding periods or complex monitoring. This approach intends to tap into the rapid cycles of meme coin popularity, aligning with user interests in shorter, strategic trading windows.
The "Chicken Pools" smart contract provides a decentralized pool structure where participants (players) can join timed pools with a designated start and end block. Key features include entry requirements, reward distribution, penalty for early exit, and a 1% protocol fee. Players have the opportunity to claim rewards by being the "last player standing" or waiting until the pool closes.
-
Pool Creation:
- Each pool (referred to as a "chicken pool") is created with a start and end block, a specified reward amount, and a minimum deposit requirement.
- The pool creator must transfer the reward amount plus a 1% protocol fee to the contract.
- Pools are identified by a unique
chickenId
and stored in thechickens
mapping.
-
Deposit and Join Mechanism:
- Players can join a pool by depositing tokens before the start block.
- The deposited amount must meet or exceed the minimum deposit requirement.
- Multiple deposits from the same player are allowed, and each player’s balance is tracked within the pool.
-
Reward Distribution and Claim:
- Reward distribution follows a "last player standing" model.
- A player can claim the reward after the pool ends or if they are the last remaining player.
- If the pool ends naturally, rewards are distributed proportionally based on each player’s deposit.
- Players who exit the pool early face penalties and forfeit rewards.
-
Early Exit Penalty (Chicken Out):
- Players can withdraw their deposits before the pool’s end block but do not receive any portion of the reward.
- Exiting early (referred to as "chickening out") triggers a deduction from the total deposits in the pool.
-
Protocol Fee:
- A 1% protocol fee, deducted from the reward amount, is required for pool creation.
- The protocol can withdraw accumulated fees periodically.
-
Escrow Model:
- A full token escrow model is implemented, where the contract holds all tokens until they are distributed.
- The protocol does not support partial deposits or withdrawal tracking outside of the pool's lifecycle.
-
SPAM Mitigation:
- Effective spam mitigation is essential within the Chicken Pools framework. To this end, each pool creator is required to post a native token bond as a deterrent against misuse. This bond serves as a stake entitling the creator to initiate unlimited pools.
At any chosen time, a creator may request the withdrawal of their bond; however, a timelock mechanism will enforce a 7-day delay before the bond can be retrieved. This approach ensures that the bond amount is substantial enough to discourage malicious behavior while remaining accessible to legitimate users, balancing deterrence with usability.
-
Data Structures:
- Chicken Struct: Stores all relevant pool data, including reward amount, total deposits, start and end blocks, and individual player balances.
- Player Management: Utilizes an
AddressSet
to maintain a unique list of players within each pool.
-
Events:
- Events are emitted to track key actions, including pool creation, player joins, reward claims, early exits, and protocol fee adjustments.
-
Error Handling:
- The contract includes specific error messages to provide clarity on failed actions (e.g.,
ChickenMustStartInFuture
,PlayerIsNotInChickenPool
).
- The contract includes specific error messages to provide clarity on failed actions (e.g.,
-
Chain Compatibility: The contract is designed for compatibility with both EVM and Solana, allowing flexibility for deployment on either chain.
-
Monorepo Structure: Development will proceed in a monorepo structure to unify contract logic and facilitate streamlined testing and deployment.
-
Economic Modeling:
- The current economic model imposes a full penalty for early withdrawals.
- The "last person standing" rule incentivizes strategic exit timing and potentially maximizes returns for patient participants.
- Consideration is given to automating USDC conversion on withdrawal for a stable payout option.
-
UI and Simulator Development:
- The UI, developed in React, will provide a user-friendly interface for managing and monitoring chicken pools.
- An enhanced simulator will include features such as volatile token price modeling, exponential decay patterns, and market shock scenarios.
-
Future Extensions:
- Considerations for social trading features, cross-pool incentives, and interactive UI components for longer-term pools may be integrated based on user feedback and market demands.
A script is provided to fully support automated deployment of this Chicken Pool
For every step, an RPC node provider and a gas fee paying EOA should be setup as follows:
- set an environment variable
RPC_URL
to the address of your RPC node provider - set an environment variable
PRIVATE_KEY
to the address of your deployment EOA
- Deploy a ChickenPool with TransparentUpgradeableProxy pattern
- set an environment variable
CHICKEN_POOL_ADMIN
to the address of the pool administrator, a multisig or timelock is recommended - set an environment variable
PROTOCOL_ADMIN
to the administrator of the protocol - Notes:
CHICKEN_POOL_ADMIN
will be able to perform upgrades, whilePROTOCOL_ADMIN
will be able to make protocol changes.
The EOA that invokes this call will pay the gas fees. Be sure to make a note of theProxyAdmin
that is created by the Transparent Proxy.
- set an environment variable
$ forge script ./script/PlayChicken.s.sol:DeployPlayChickenScript --sig 'deployTransparentProxy()' --legacy --slow --broadcast --rpc-url ${RPC_URL} --private-key ${PRIVATE_KEY}
- Optional: Upgrade ChickenPool with the latest contract version
- set an environment variable
PROXY_ADMIN
to the admin created previously (Step 1) - set an environment variable
PLAY_CHICKEN_PROXY
to the address of the proxy deployed previously (Step 1) - Notes: Only the
CHICKEN_POOL_ADMIN
may perform this operation
- set an environment variable
$ forge script ./script/PlayChicken.s.sol:DeployPlayChickenScript --sig 'upgradeTransparentProxy()' --legacy --slow --broadcast --rpc-url ${RPC_URL} --private-key ${PRIVATE_KEY}
Network | Address | Contract | Notes | Verified |
---|---|---|---|---|
Sepolia | 0x271826c84B5Fc4017B5B0809e3A7CD8fC5C02354 | ProxyAdmin | Play Chicken Pool Proxy Delegate | https://sepolia.etherscan.io/address/0x271826c84B5Fc4017B5B0809e3A7CD8fC5C02354 |
Sepolia | 0x9ee040266605a8b0b65d859cfa6e2b7d5f34c163 | TransparentUpgradeableProxy | Play Chicken Proxy | https://sepolia.etherscan.io/address/0x9ee040266605a8b0b65d859cfa6e2b7d5f34c163 |
Sepolia | 0xba8c13bd4462ae9405cd0749c07f41cecde943ab | PlayChicken | Play Chicken Implementation | https://sepolia.etherscan.io/address/0xba8c13bd4462ae9405cd0749c07f41cecde943ab |
Sepolia | 0x1255a805E0764bEA83688104e1E235cF63db0f75 | ProxyAdmin | Reward Pool Proxy Delegate | https://sepolia.etherscan.io/address/0x1255a805E0764bEA83688104e1E235cF63db0f75 |
Sepolia | 0xf31799A6893EE2508B2b12eab12b9146B074A5f3 | TransparentUpgradeableProxy | Reward Pool Proxy | https://sepolia.etherscan.io/address/0xf31799A6893EE2508B2b12eab12b9146B074A5f3 |
Sepolia | 0x95E73594C15F4276892DE91c9982018cf63eF359 | RewardChicken | Reward Pool Implementation | https://sepolia.etherscan.io/address/0x95E73594C15F4276892DE91c9982018cf63eF359 |
Sepolia | 0xe27FA48f938913c70a6b02587D003078e786c74c | ProxyAdmin | Launcher Proxy Delegate | https://sepolia.etherscan.io/address/0xe27fa48f938913c70a6b02587d003078e786c74c |
Sepolia | 0x4db097b90530f111e88325e514c9a0d59392db9e | TransparentUpgradeableProxy | Launcher Pool Proxy | https://sepolia.etherscan.io/address/0x4db097b90530f111e88325e514c9a0d59392db9e |
Sepolia | 0xAb24873BF6b7f14d3f8Ae0716193Da701Ab61a9F | ChickenLauncher | Launcher implementation | https://sepolia.etherscan.io/address/0xab24873bf6b7f14d3f8ae0716193da701ab61a9f |
Sepolia | 0x40c5215E1A69B7934948E9c28FCE20046208702E | ChickenTokenUpgradeable | Chicken Token | https://sepolia.etherscan.io/address/0x40c5215e1a69b7934948e9c28fce20046208702e |
- Forge: Ethereum testing framework (like Truffle, Hardhat and DappTools).
- Cast: Swiss army knife for interacting with EVM smart contracts, sending transactions and getting chain data.
- Anvil: Local Ethereum node, akin to Ganache, Hardhat Network.
- Chisel: Fast, utilitarian, and verbose solidity REPL.
$ forge build
$ forge test
$ forge fmt
$ forge snapshot
$ anvil
$ forge script ./script/PlayChicken.s.sol:DeployPlayChickenScript --sig 'deployProxyAdmin()' --legacy --slow --broadcast --rpc-url ${RPC_URL} --private-key ${PRIVATE_KEY}
$ cast <subcommand>
$ forge --help
$ anvil --help
$ cast --help