I am currently re-learning Solidity to consolidate my understanding of the details and to create a "Simplified Solidity for Beginners" guide for newbies (programming experts can find other tutorials). I update this guide with 1-3 lessons per week.
Twitter: @0xAA_Science
Community: Discord|WeChat Group|wtf.academy
All code and tutorials are open-sourced on GitHub: github.com/AmazingAng/WTF-Solidity
In this lesson, we will introduce token vesting clauses and write a contract for linearly releasing ERC20 tokens. The code is simplified from OpenZeppelin's VestingWallet contract.
Token Vesting Clauses
In traditional finance, some companies provide equity to employees and management. However, a large amount of equity released at the same time can create selling pressure in the short term, dragging down the stock price. Therefore, companies typically introduce a vesting period to delay ownership of committed assets. Similarly, in the blockchain field, Web3 startups allocate tokens to their teams and also sell tokens at a low price to venture capital and private equity. If they simultaneously bring these low-cost tokens to the exchange for liquidity, the token price will be crushed, making retail investors the bag holders.
So, project teams generally agree on token vesting clauses, gradually releasing tokens during the vesting period to reduce selling pressure and prevent teams and capital parties from going out too early.
Linear Release
Linear release refers to the constant release of tokens during the vesting period. For example, if a private equity holds 365,000 ICU tokens with a vesting period of 1 year (365 days), 1,000 tokens will be released every day.
Now, let's write a contract TokenVesting for locking and linearly releasing ERC20 tokens. Its logic is simple:
- The project team specifies the start time, vesting period, and beneficiary of the linear release.
- The project team transfers the ERC20 tokens to be locked to the TokenVesting contract.
- The beneficiary can call the release function to withdraw the released tokens from the contract.
Events
There is 1
event in the Linear Release contract.
ERC20Released
: withdrawal event, triggered when the beneficiary withdraws the released tokens.
State Variables
There are 4
state variables in the linear release contract.
beneficiary
: the beneficiary address.start
: the starting timestamp of the vesting period.duration
: the duration of the vesting period in seconds.erc20Released
: a mapping of token address to the amount released, which records the amount of tokens the beneficiary has already claimed.
Functions
There are 3
functions in the LinearVesting contract.
- Constructor: initializes the beneficiary address, duration in seconds and starting timestamp. The constructor takes
beneficiaryAddress
anddurationSeconds
as input parameters. The starting timestamp is set to the deployment blockchain timestampblock.timestamp
for convenience. release()
: transfers the vested tokens to the beneficiary address. This function callsvestedAmount()
to calculate the amount of vested tokens, emits theERC20Released
event, and then calls thetransfer
function to transfer tokens to the beneficiary. The token address is passed as an input parametertoken
.vestedAmount()
: calculates the number of vested tokens based on the linear vesting formula. Developers can modify this function to implement a customized vesting schedule. The function takestoken
andtimestamp
as input parameters.
Remix
Demo
1. Deploy the ERC20
contract in Lesson 31, and mint yourself 1000
tokens.
data:image/s3,"s3://crabby-images/9e7b6/9e7b66ec7d7a979718de6e70ab3d0e11ffa8e1ff" alt="Deploy ERC20"
data:image/s3,"s3://crabby-images/cbcea/cbceae6aaba5c44c517f6f5fb1708ed52f9a1c22" alt="Mint 1000 tokens"
2. Deploy the TokenVesting
contract for linear release, set yourself as the beneficiary, and set the vesting period to 100
seconds.
data:image/s3,"s3://crabby-images/60461/604614cb0dd4e6b732b8790af4de974fa1203572" alt="Deploy TokenVesting"
3. Transfer 1000
ERC20
tokens to the linear release contract.
data:image/s3,"s3://crabby-images/21661/216617a0a97d06e074f32edd449c723d1f299100" alt="Transfer tokens"
4. Call the release()
function to extract the tokens.
data:image/s3,"s3://crabby-images/bfa10/bfa10382726747b58591b44c12f523fcf60885f9" alt="Release tokens"
Summary
A large amount of token unlocking in the short term can cause huge pressure on the token price, while agreed-upon token ownership terms can alleviate selling pressure and prevent the team and capital parties from exiting too early. In this lesson, we introduced token ownership terms and wrote a contract for the linear release of ERC20 tokens.