12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- // SPDX-License-Identifier: MIT
- pragma solidity ^0.7.0;
- import "./SafeERC20.sol";
- /**
- * @dev A token holder contract that will allow a beneficiary to extract the
- * tokens after a given release time.
- *
- * Useful for simple vesting schedules like "advisors get all of their tokens
- * after 1 year".
- */
- contract TokenTimelock {
- using SafeERC20 for IERC20;
- // ERC20 basic token contract being held
- IERC20 private _token;
- // beneficiary of tokens after they are released
- address private _beneficiary;
- // timestamp when token release is enabled
- uint256 private _releaseTime;
- constructor (IERC20 token_, address beneficiary_, uint256 releaseTime_) {
- // solhint-disable-next-line not-rely-on-time
- require(releaseTime_ > block.timestamp, "TokenTimelock: release time is before current time");
- _token = token_;
- _beneficiary = beneficiary_;
- _releaseTime = releaseTime_;
- }
- /**
- * @return the token being held.
- */
- function token() public view returns (IERC20) {
- return _token;
- }
- /**
- * @return the beneficiary of the tokens.
- */
- function beneficiary() public view returns (address) {
- return _beneficiary;
- }
- /**
- * @return the time when the tokens are released.
- */
- function releaseTime() public view returns (uint256) {
- return _releaseTime;
- }
- /**
- * @notice Transfers tokens held by timelock to beneficiary.
- */
- function release() public virtual {
- // solhint-disable-next-line not-rely-on-time
- require(block.timestamp >= _releaseTime, "TokenTimelock: current time is before release time");
- uint256 amount = _token.balanceOf(address(this));
- require(amount > 0, "TokenTimelock: no tokens to release");
- _token.safeTransfer(_beneficiary, amount);
- }
- }
|