diff --git a/book/SUMMARY.md b/book/SUMMARY.md index c8362d2..b4274f2 100644 --- a/book/SUMMARY.md +++ b/book/SUMMARY.md @@ -28,6 +28,7 @@ - [TON Pool](build-your-staking-dapp/ton/ton-pool/README.md) - [Overview](build-your-staking-dapp/ton/ton-pool/overview.md) - [Methods](build-your-staking-dapp/ton/ton-pool/methods.md) + - [Architecture](build-your-staking-dapp/ton/ton-pool/architecture.md) - [Nominator](build-your-staking-dapp/ton/nominator/README.md) - [Overview](build-your-staking-dapp/ton/nominator/overview.md) - [Methods](build-your-staking-dapp/ton/nominator/methods.md) diff --git a/book/assets/ton-pool-architecture/ton-whales-contract-first-iteration.png b/book/assets/ton-pool-architecture/ton-whales-contract-first-iteration.png new file mode 100644 index 0000000..833400d Binary files /dev/null and b/book/assets/ton-pool-architecture/ton-whales-contract-first-iteration.png differ diff --git a/book/assets/ton-pool-architecture/workflow-recover-stake.png b/book/assets/ton-pool-architecture/workflow-recover-stake.png new file mode 100644 index 0000000..5eed405 Binary files /dev/null and b/book/assets/ton-pool-architecture/workflow-recover-stake.png differ diff --git a/book/assets/ton-pool-architecture/workflow-send-stake.png b/book/assets/ton-pool-architecture/workflow-send-stake.png new file mode 100644 index 0000000..0478837 Binary files /dev/null and b/book/assets/ton-pool-architecture/workflow-send-stake.png differ diff --git a/book/assets/ton-pool-architecture/workflow-stake.png b/book/assets/ton-pool-architecture/workflow-stake.png new file mode 100644 index 0000000..67150d3 Binary files /dev/null and b/book/assets/ton-pool-architecture/workflow-stake.png differ diff --git a/book/assets/ton-pool-architecture/workflow-withdraw.png b/book/assets/ton-pool-architecture/workflow-withdraw.png new file mode 100644 index 0000000..0a913a1 Binary files /dev/null and b/book/assets/ton-pool-architecture/workflow-withdraw.png differ diff --git a/book/build-your-staking-dapp/ton/overview.md b/book/build-your-staking-dapp/ton/overview.md index c2c4d22..4ac1d2c 100644 --- a/book/build-your-staking-dapp/ton/overview.md +++ b/book/build-your-staking-dapp/ton/overview.md @@ -18,7 +18,7 @@ Before you start developing your staking application, you need to decide which p | - | - | - |- | | Recommended | ✅ | | | | Best for | Most use cases | Large delegators | Single delegators | -| Delegators | ∞ | 40 Max | 1 | +| Delegators | Unlimited | 40 Max | 1 | | Minimal Stake | 10 TON | 10,000 TON | 400,000 TON | | Partial Withdrawal | ✅ | ❌ Must withdraw all funds | ✅| | Pool creation | ✅ Not needed | ❌ Per request | ❌ Per request | diff --git a/book/build-your-staking-dapp/ton/ton-pool/architecture.md b/book/build-your-staking-dapp/ton/ton-pool/architecture.md new file mode 100644 index 0000000..41c0820 --- /dev/null +++ b/book/build-your-staking-dapp/ton/ton-pool/architecture.md @@ -0,0 +1,103 @@ +# TON Pool: Architecture + +**TON Pool** provides efficient staking solution on the TON blockchain by utilizing the two-queue smart contract system from the [TON Whales](https://tonwhales.com/) project. +By using two queues, the TON Pool ensures optimal resource use and enables 100% validator efficiency (With a single queue, double the number of validators would be needed). + +To support these smart contracts, **TON Pool** employs a set of controllers that run directly on the node. These include the **Pool Controller** for managing customer interactions, the **Election Controller** for validator participation, and the **Validator Controller** for secure key management. Together, they enable efficient staking and ensure secure, reliable performance across each validation cycle. + +![](../../../assets/ton-pool-architecture/ton-whales-contract-first-iteration.png) + +## Controllers + +The solution includes several key components for managing staking workflows: + +- **Pool controller**: Responsible for accepting stakes and withdrawals from customers. +- **Election controller**: Responsible for participating in validator elections to get our + validators into the top 100 validator list. This controller interacts with the Validator Controller to secure the necessary public keys. +- **Validator controller**: Responsible for generating new key pairs for each election and + integrating with the TON validator software on each individual validator. + +The **Pool** and **Election controllers** can be run together in the same binary, this makes it easier to accept stakes and withdrawals before we start participating in an election. + +## Validators + +Validators, as full nodes, automatically start validating when their public key is included in the current validator set. This information is retrieved from the Elector contract or Chain Config. The pool and election controllers run independently of the validators. + +The [validation cycle](https://tonscan.com/validation) is split into **odd** and **even** cycles. Each cycle has four phases: + + - **Election**: 6-7 hours + - **Delay**: 2-3 hours + - **Validation**: 18 hours + - **Hold**: 9 hours (overlaps with the Election phase of the next cycle) + +## Workflows + +**TON Pool** includes four main workflows using the TON Whales Pool contract: + +1. **Staking**: Customers deposit TON to the pool contract. +2. **Unstaking**: Customers withdraw TON from the pool contract. +3. **Stake Submission**: Validator bids are sent to participate in the upcoming election. +4. **Stake Retrieval**: Previous bids and rewards are reclaimed from the last validation cycle. + +### Staking + +1. A customer submits a stake message to the Pool contract through the **TON Pool** frontend, which adds the deposited TON as a pending stake. +2. At the start of the next election cycle, when the pool unlocks, the controller processes the pending stake. Only one contract can accept new stakes during each cycle, determined by alternating between contracts. + - The controller first checks both contracts’ statuses to identify which one has ProxyStakeAt set to 0, indicating it can accept stakes. + - It then verifies if there are pending deposits for this contract. If so, the pool contract processes these deposits by sending an acceptance message. + +![](../../../assets/ton-pool-architecture/workflow-stake.png) + +### Unstaking + +1. **Unstake Request**: Customers initiate an unstake request through a **TON Pool** frontend. + - If the contract is **unlocked**, customers receive their full stake immediately. + - If the contract is **locked**, they receive as much of their stake as possible based on the available balance in the Pending Stake. Any remaining amount is added as a pending request. +2. **Processing Pending Withdrawals**: The controller processes any pending withdrawals at the start of the next election cycle. +3. **Final Withdrawal**: Once processed, customers can retrieve any remaining stake by sending another withdrawal request. + +![](../../../assets/ton-pool-architecture/workflow-withdraw.png) + +### Stake Submission + +This process occurs every other cycle for each **TON Pool** contract. + +1. The Validator Controller generates validator keys for the next election. +2. The Election Controller creates and sends an election bid to the Pool contract. +3. The Pool contract processes and forwards the bid to the proxy contract, locking the pool. +4. The Proxy contract submits the bid to the Elector contract. +5. The Elector contract approves or rejects the bid +6. The Elector contract updates the Config contract with the new validator set after elections. + +![](../../../assets/ton-pool-architecture/workflow-send-stake.png) + +### Stake Retrieval + +This process also occurs every other cycle for each **TON Pool** contract. + +1. The Election Controller sends a recover stake message to the Pool contract. +2. The Pool contract relays this message to the Elector contract through the proxy. +3. The Elector contract returns the stake and rewards to the pool through the proxy. + +![](../../../assets/ton-pool-architecture/workflow-recover-stake.png) + +## Efficient On-Chain Operations + +To optimize gas costs, all main operations are consolidated to occur once per election cycle: + +- Stake and withdrawal actions are processed once per election cycle. +- Election bids (stake bids) are placed once per cycle. +- This approach includes tracking the long-term ADNL key for election bids and generating election keys once per cycle. +- Stake and reward retrieval are also conducted once per cycle. + + +## Further Reading + +- [TON Docs](https://docs.ton.org/develop/overview) +- [TON Whales contract](https://github.com/tonwhales/ton-nominators/) +- [FunC standard library](https://docs.ton.org/develop/func/stdlib) +- [TVM exit codes](https://docs.ton.org/learn/tvm-instructions/tvm-exit-codes) +- [TL-B (Type Language - Binary) definitions](https://github.com/ton-blockchain/ton/blob/master/crypto/block/block.tlb) +- [TON Elector contract](https://github.com/ton-blockchain/ton/blob/master/crypto/smartcont/elector-code.fc) +- [TON Config](https://tonviewer.com/config) +- [Validation Cycle Live](https://tonscan.com/validation) diff --git a/book/build-your-staking-dapp/ton/ton-pool/overview.md b/book/build-your-staking-dapp/ton/ton-pool/overview.md index 5e2840d..57ee6e5 100644 --- a/book/build-your-staking-dapp/ton/ton-pool/overview.md +++ b/book/build-your-staking-dapp/ton/ton-pool/overview.md @@ -19,6 +19,18 @@ The methods provided in this documentation are compatible with popular TON libra The **TON Pool** is powered by [TON Whales contracts](https://tonwhales.com/), a robust and proven technology that has operated reliably in the TON ecosystem for several years. These contracts have been tested extensively in real-world conditions, providing a solid foundation for secure and efficient staking operations. +![](../../../assets/ton-pool-architecture/ton-whales-contract-first-iteration.png) + + +{% hint style="info" %} + +**Architecture Overview** + +To learn more about the architecture of the TON Pool and the underlying TON Whales contracts, refer to the [Architecture](architecture.md) section. + +{% endhint %} + + ## Two Validator Pool Addresses To ensure uninterrupted network participation, TON Pool utilizes two validator pool addresses: one for odd cycles and another for even cycles. These pools alternate between cycles to enable seamless staking and validation without downtime. This design ensures continuous operation and smooth participation in the TON blockchain’s validation process. @@ -174,6 +186,6 @@ In this section you learned how to set up the Chorus One SDK for the TON network - To learn more about the available methods on `TonPoolStaker`, continue to the [Methods](methods.md) section. ## Further Reading - +- [TON Pool Architecture](architecture.md) - [TonPoolStaker API Reference](../../../docs/classes/ton_src.TonPoolStaker.md) - [What is a Signer?](../../../signers-explained/what-is-a-signer.md)