Nominator pool source code for TON.
Adding stake is two step process: first you send a stake and eventually pool need accept it. Nominator Pool is free to NOT accept your stake for any reason.
All pools have different deposit fees and minimum stake amounts, check out information about current deposit fees.
To send stake send a message with a comment Stake (capitalization is important) with value of desired stake + deposit fee.
Withdrawal also two step process: first you need to request withdrawal and then when withdrawal solidify, you can repeat command to withdraw result. Sometimes you can withdraw immediatelly.
All pools have different withdraw fees, check out information about current withdraw fees.
To withdraw stake send a message with a comment Withdraw (capitalization is important) with value of withdraw fee.
This contract has almost full testing coverage, but it is not open source.
Nominator pool is combination of several contracts:
- Owner - owner is a arbitrary contract (wallet or dao) that could make critical updates to the contract: change fees, start/stop pool and even update code. Owner also receives all profits from fees.
- Controller - controller is arbitrary contract (wallet or dao) that issue staking commands for validation and/or voting. Controller pays for this operations and can get "unowned" balances to restore it's balance and continue working. We recommend to top ~1000 TONs for uninterrupted work.
- Proxy - proxy contract is the only one that is masterchain and represent validation pool there. It performs simple proxying between pool and elector.
- Pool - main contract that contains all records of all stakes and performs staking itself.
Before deployment you need to have Owner and Controller contracts ready and deployed and generated two vanity contracts - one for proxy in masterchain and one for pool in basic workchain.
GNU v3