From 6314f631840472cf9222ef6bd9662f0832093914 Mon Sep 17 00:00:00 2001 From: Dmitry Yakimov Date: Tue, 3 Dec 2024 20:48:46 +0000 Subject: [PATCH] Add architecture overview --- book/SUMMARY.md | 1 + .../ton-whales-contract-first-iteration.svg | 135 +++++++++++++++++ .../workflow-recover-stake.svg | 134 +++++++++++++++++ .../workflow-send-stake.svg | 137 ++++++++++++++++++ .../ton-pool-architecture/workflow-stake.svg | 125 ++++++++++++++++ .../workflow-withdraw.svg | 127 ++++++++++++++++ .../ton/ton-pool/architecture.md | 103 +++++++++++++ .../ton/ton-pool/overview.md | 11 +- 8 files changed, 772 insertions(+), 1 deletion(-) create mode 100644 book/assets/ton-pool-architecture/ton-whales-contract-first-iteration.svg create mode 100644 book/assets/ton-pool-architecture/workflow-recover-stake.svg create mode 100644 book/assets/ton-pool-architecture/workflow-send-stake.svg create mode 100644 book/assets/ton-pool-architecture/workflow-stake.svg create mode 100644 book/assets/ton-pool-architecture/workflow-withdraw.svg create mode 100644 book/build-your-staking-dapp/ton/ton-pool/architecture.md 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.svg b/book/assets/ton-pool-architecture/ton-whales-contract-first-iteration.svg new file mode 100644 index 0000000..e3acfe8 --- /dev/null +++ b/book/assets/ton-pool-architecture/ton-whales-contract-first-iteration.svg @@ -0,0 +1,135 @@ + + + + + + + + +Nominator(staker)C1 Staking FrontendC1 PoolC1 ValidatorsTON Governance contractsC1 Pool Queue 1on work chainC1 Pool Queue 2on work chainValidator 1(TON Full Node)Election, pool & validator ControllerConfig contracton master chainElectors contracton master chainC1 Proxy contracton master chainC1 Proxy contracton master chain Stake or withdraw funds calls to Electors contract calls to Electors contract proxying calls proxying calls Update validator sets after elections + + + + + + + + + + + + + + + + + + + + + diff --git a/book/assets/ton-pool-architecture/workflow-recover-stake.svg b/book/assets/ton-pool-architecture/workflow-recover-stake.svg new file mode 100644 index 0000000..68980c0 --- /dev/null +++ b/book/assets/ton-pool-architecture/workflow-recover-stake.svg @@ -0,0 +1,134 @@ + + + + + + + + +C1 ValidatorsWork chainMaster chainElection, pool & validator ControllerC1 PoolproxiesTON governance contractsC1 Pool Queue 1on work chainC1 Pool Queue 2on work chainC1 Proxy contracton master chainElectors contracton master chainConfig contracton master chainC1 Proxy contracton master chain 1. Send stake recover message 2. Forward recover message 5. Send stake + rewards 3. Forward recover message 4. Send stake + rewards + + + + + + + + + + + + + + + + + + + + diff --git a/book/assets/ton-pool-architecture/workflow-send-stake.svg b/book/assets/ton-pool-architecture/workflow-send-stake.svg new file mode 100644 index 0000000..f6b4853 --- /dev/null +++ b/book/assets/ton-pool-architecture/workflow-send-stake.svg @@ -0,0 +1,137 @@ + + + + + + + + +C1 ValidatorsWork chainMaster chainValidator 1(TON Full Node)Election, pool & validator ControllerC1 PoolproxiesTON Governance contractsC1 Pool Queue 1on work chainC1 Pool Queue 2on work chainC1 Proxy contracton master chainElectors contracton master chainConfig contracton master chainC1 Proxy contracton master chain 1. Manage election keys 2. Sendelection bid 3. lock contractand forwardelection bid 6. Accept election bid 6. Update validatorsets after election 5. Accept nelection bid 4. Forward election bid + + + + + + + + + + + + + + + + + + + + + + + diff --git a/book/assets/ton-pool-architecture/workflow-stake.svg b/book/assets/ton-pool-architecture/workflow-stake.svg new file mode 100644 index 0000000..cd551cf --- /dev/null +++ b/book/assets/ton-pool-architecture/workflow-stake.svg @@ -0,0 +1,125 @@ + + + + + + + + +Nominator(staker)C1 Staking FrontendWork chainC1 Pool ControllerC1 Pool Queue 1on work chainC1 Pool Queue 2on work chain 1. Stake 1. Stake 2. Accept Stake + + + + + + + + + + + diff --git a/book/assets/ton-pool-architecture/workflow-withdraw.svg b/book/assets/ton-pool-architecture/workflow-withdraw.svg new file mode 100644 index 0000000..94061ef --- /dev/null +++ b/book/assets/ton-pool-architecture/workflow-withdraw.svg @@ -0,0 +1,127 @@ + + + + + + + + +Nominator(staker)C1 Staking FrontendWork chainC1 Pool ControllerC1 Pool Queue 1on work chainC1 Pool Queue 2on work chain 1. Unstake 4. Withdraw 2. Unstake 5. Withdraw 3. Accept Withdraw + + + + + + + + + + + + + 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..3aaeab7 --- /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.svg?raw=true) + +## 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.svg?raw=true) + +### 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.svg?raw=true) + +### 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.svg?raw=true) + +### 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.svg?raw=true) + +## 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..b2c32d3 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,15 @@ 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. +{% 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 +183,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)