Skip to content

Latest commit

 

History

History
115 lines (77 loc) · 5 KB

Token lock and time lock.md

File metadata and controls

115 lines (77 loc) · 5 KB

代币锁和时间锁

代币锁和时间锁是很多 Defi 项目常用的技术解决方案,主要用于增强安全性和实现复杂的交易条件。

一.代币锁

1.基础理论

代币锁是一种机制,用于将代币锁定在智能合约中,直到满足特定条件后才能解锁和使用。这些条件通常包括:

  • 时间条件:代币在特定的时间段内无法转移或使用。例如,可以设置代币在一定时间后才能被转移,以确保项目的资金在特定时间内不会被动用。
  • 事件条件:只有在特定事件发生后才能解锁代币。例如,在众筹项目中,只有当项目达到融资目标后,投资者的代币才会被解锁。
  • 多重签名条件:代币的解锁需要多个签名的确认,这种机制通常用于增强交易的安全性,防止单个用户对资金的滥用。

代币锁的主要应用包括但不限于:

  • ICO 和众筹:确保项目资金在募资完成前无法使用。
  • 团队和顾问的代币分配:防止团队成员在项目初期就抛售大量代币。
  • 质押和奖励:在DeFi项目中,用户将代币锁定以获得奖励。

二.时间锁

时间锁是一种用于确保某些操作只能在特定时间后进行的机制。时间锁主要有以下几种实现方式:

  • Unix时间戳:基于绝对时间,操作在达到特定的Unix时间戳后才能执行。例如,可以设置一笔交易在特定时间点后才能被确认。
  • 区块高度:基于区块链的区块高度,操作在达到特定区块高度后才能执行。这种方式更适合区块链系统,因为它不依赖于外部时间,而是依赖于区块链的内部状态。
  • 相对时间锁:操作在一段相对时间后才能执行。例如,交易在被创建后的特定时间段(例如10分钟后)才能被确认。

时间锁的主要应用包括:

  • 延迟交易:确保某些交易或操作在一段时间后才能执行,增加安全性。
  • 定时支付:实现定时支付功能,在特定时间点自动执行支付操作。
  • 合约执行:在智能合约中设置延迟执行的条件,确保合约在特定时间后自动执行某些操作。

三.代码案例:锁定一定时间的代币锁合约实例

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

import "@openzeppelin/contracts/token/ERC20/IERC20.sol";

contract TokenLock {
    IERC20 public token;
    address public beneficiary;
    uint256 public releaseTime;
    uint256 public lockedAmount;

    event TokensLocked(address indexed beneficiary, uint256 amount, uint256 releaseTime);
    event TokensReleased(address indexed beneficiary, uint256 amount);

    constructor(IERC20 _token, address _beneficiary, uint256 _releaseTime) {
        require(_releaseTime > block.timestamp, "Release time must be in the future");
        token = _token;
        beneficiary = _beneficiary;
        releaseTime = _releaseTime;
    }

    function lockTokens(uint256 amount) external {
        require(amount > 0, "Amount must be greater than 0");
        require(token.transferFrom(msg.sender, address(this), amount), "Token transfer failed");

        lockedAmount += amount;

        emit TokensLocked(beneficiary, amount, releaseTime);
    }

    function releaseTokens() external {
        require(block.timestamp >= releaseTime, "Current time is before release time");
        require(lockedAmount > 0, "No tokens to release");

        uint256 amount = lockedAmount;
        lockedAmount = 0;

        require(token.transfer(beneficiary, amount), "Token transfer failed");

        emit TokensReleased(beneficiary, amount);
    }
}

2.1.合约说明

合约状态变量

  • token: 代币的合约地址,使用IERC20接口。
  • beneficiary: 受益人的地址,解锁后可以领取代币。
  • releaseTime: 代币的解锁时间戳,Unix时间格式。
  • lockedAmount: 已锁定的代币数量。

事件

  • TokensLocked: 代币锁定时触发的事件,记录受益人地址、锁定数量和解锁时间。
  • TokensReleased: 代币解锁时触发的事件,记录受益人地址和解锁数量。

构造函数

  • 初始化代币合约地址、受益人地址和解锁时间。确保解锁时间在未来。

lockTokens 函数

  • 用于将代币锁定在合约中。调用者需要先批准合约可以转移其代币。
  • 检查锁定数量是否大于0,执行代币转移并记录锁定数量,触发TokensLocked事件。

releaseTokens 函数

  • 用于在达到解锁时间后释放代币。
  • 检查当前时间是否已经超过解锁时间,且锁定数量大于0。
  • 将锁定的代币转移给受益人并重置锁定数量,触发TokensReleased事件。

2.2.使用步骤

  • 部署合约:传递 ERC20 代币地址、受益人地址和解锁时间作为参数。
  • 锁定代币:调用lockTokens函数,并确保调用者已经批准合约可以转移其代币。
  • 释放代币:在达到解锁时间后,受益人可以调用releaseTokens函数来提取代币。