12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- // SPDX-License-Identifier: MIT
- // OpenZeppelin Contracts v4.4.0-rc.0 (token/ERC20/utils/TokenTimelock.sol)
- pragma solidity ^0.8.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 immutable _token;
- // beneficiary of tokens after they are released
- address private immutable _beneficiary;
- // timestamp when token release is enabled
- uint256 private immutable _releaseTime;
- constructor(
- IERC20 token_,
- address beneficiary_,
- uint256 releaseTime_
- ) {
- 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 virtual returns (IERC20) {
- return _token;
- }
- /**
- * @return the beneficiary of the tokens.
- */
- function beneficiary() public view virtual returns (address) {
- return _beneficiary;
- }
- /**
- * @return the time when the tokens are released.
- */
- function releaseTime() public view virtual returns (uint256) {
- return _releaseTime;
- }
- /**
- * @notice Transfers tokens held by timelock to beneficiary.
- */
- function release() public virtual {
- 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);
- }
- }
|