I've been relearning Solidity recently to strengthen some details and write a "WTF Solidity Quick Start" for beginners (programming experts can find other tutorials), updated weekly with 1-3 lessons.
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 introduce time locks and time lock contracts. The code is based on the simplified version of the Timelock contract of Compound.
Timelock
data:image/s3,"s3://crabby-images/02a6a/02a6a741f83a75212eec840e1aae11c2a2629ff1" alt="Timelock"
A timelock is a locking mechanism commonly found in bank vaults and other high-security containers. It is a timer designed to prevent a safe or vault from being opened before a predetermined time, even if the person unlocking it knows the correct password.
In blockchain, timelocks are widely used in DeFi and DAO. It is a piece of code that can lock certain functions of a smart contract for a period of time. It can greatly improve the security of a smart contract. For example, if a hacker hacks the multi-signature of Uniswap and intends to withdraw the funds from the vault, but the vault contract has a timelock of 2 days, the hacker needs to wait for 2 days from creating the withdrawal transaction to actually withdraw the money. During this period, the project party can find countermeasures, and investors can sell tokens in advance to reduce losses.
Timelock contract
Next, we will introduce the Timelock contract. Its logic is not complicated:
-
When creating a Timelock contract, the project party can set the lock-in period and set the contract's administrator to itself.
-
The Timelock mainly has three functions:
- Create a transaction and add it to the timelock queue.
- Execute the transaction after the lock-in period of the transaction.
- Regret, cancel some transactions in the timelock queue.
-
The project party generally sets the timelock contract as the administrator of important contracts, such as the vault contract, and then operates them through the timelock.
-
The administrator of a timelock contract is usually a multi-signature wallet of the project, ensuring decentralization.
Events
There are 4 events in the Timelock
contract.
QueueTransaction
: Event when a transaction is created and enters the timelock queue.ExecuteTransaction
: Event when a transaction is executed after the lockup period ends.CancelTransaction
: Event when a transaction is cancelled.NewAdmin
: Event when the administrator's address is modified.
State Variables
There are a total of 4 state variables in the Timelock
contract.
admin
: The address of the administrator.delay
: The lock up period.GRACE_PERIOD
: The time period until a transaction expires. If a transaction is scheduled to be executed but it is not executed withinGRACE_PERIOD
, it will expire.queuedTransactions
: A mapping oftxHash
identifier tobool
that records all the transactions in the timelock queue.
Modifiers
There are 2
modifiers in the Timelock
contract.
onlyOwner()
: the function it modifies can only be executed by the administrator.onlyTimelock()
: the function it modifies can only be executed by the timelock contract.
Functions
There are a total of 7 functions in the Timelock
contract.
- Constructor: Initializes the transaction locking time (in seconds) and the administrator address.
queueTransaction()
: Creates a transaction and adds it to the time lock queue. The parameters are complicated because they describe a complete transaction:target
: the target contract addressvalue
: the amount of ETH sentsignature
: the function signature being calleddata
: the call data of the transactionexecuteTime
: the blockchain timestamp when the transaction will be executed. When calling this function, it is necessary to ensure that the expected execution timeexecuteTime
is greater than the current blockchain timestamp + the lock timedelay
. The unique identifier for the transaction is the hash value of all the parameters, calculated using thegetTxHash()
function. Transactions that enter the queue will update thequeuedTransactions
variable and release aQueueTransaction
event.
executeTransaction()
: Executes a transaction. Its parameters are the same asqueueTransaction()
. The transaction to be executed must be in the time lock queue, reach its execution time, and not be expired. Thecall
member function ofsolidity
is used to execute the transaction, which was introduced in Lesson 22.cancelTransaction()
: Cancels a transaction. Its parameters are the same asqueueTransaction()
. The transaction to be cancelled must be in the queue. ThequeuedTransactions
will be updated and aCancelTransaction
event will be released.changeAdmin()
: Changes the administrator address and can only be called by theTimelock
contract.getBlockTimestamp()
: Gets the current blockchain timestamp.getTxHash()
: Returns the identifier of the transaction, which is thehash
of many transaction parameters.
Remix
Demo
1. Deploy the Timelock
contract with a lockup period of 120
seconds
data:image/s3,"s3://crabby-images/e142a/e142aa43ab999b61f56b83085b0a1104d553c456" alt="Remix Demo"
2. Calling changeAdmin()
directly will result in an error
data:image/s3,"s3://crabby-images/e21c9/e21c97ac17c01d38f7f15a6035a9e298dc5c4c11" alt="Remix Demo"
3. Creating a transaction to change the administrator
To construct the transaction, we need to fill in the following parameters: address target, uint256 value, string memory signature, bytes memory data, uint256 executeTime
-
target
: Since we are calling a function ofTimelock
, we fill in the contract address. -
value
: No need to transfer ETH, fill in0
here. -
signature
: The function signature ofchangeAdmin()
is:"changeAdmin(address)"
. -
data
: Fill in the parameter to be passed, which is the address of the new administrator. But the address needs to be padded to 32 bytes of data to meet the Ethereum ABI Encoding Standard. You can use the hashex website to encode the parameters to ABI. Example: -
executeTime
: First, callgetBlockTimestamp()
to obtain the current time of the blockchain, and then add 150 seconds to it and fill it in.
4. Call queueTransaction
to add the transaction to the time-lock queue
data:image/s3,"s3://crabby-images/ef009/ef0091d8380c2cf7228107fe1270855849749363" alt="Remix Demo"
5. Calling executeTransaction
within the locking period will fail
data:image/s3,"s3://crabby-images/d870b/d870b79765392fe3ed5faf676f42f03f1f94a42e" alt="Remix Demo"
6. Calling executeTransaction
after the locking period has expired will result in a successful transaction
data:image/s3,"s3://crabby-images/c9192/c919217ee97d8e80efdb3291eb03c63338416c0a" alt="Remix Demo"
7. Check the new admin
address
data:image/s3,"s3://crabby-images/03bac/03bacf7f50ec4e9ecc04803d652ae3adb115a265" alt="Remix Demo"
Conclusion
A time lock can lock certain functions of a smart contract for a period of time, greatly reducing the chance of rug pulls and hacking attacks by project parties, and increasing the security of decentralized applications. It has been widely adopted by DeFi and DAO, including Uniswap and Compound. Does the project you are investing in use a time lock?