More Info
Private Name Tags
ContractCreator
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
0xd0d55c5c64aaf19521e28b0a1a0cdd00028ee330c841411c21f4772f3ae30177 | Claim | (pending) | 2 days ago | IN | 0 ETH | (Pending) | |||
0x4ec0ed346a45a6b59ba8fd5e96143603fe287117b16fddae715c4a592ca67993 | Claim | (pending) | 2 days ago | IN | 0 ETH | (Pending) | |||
0xccd0ba972ab4ba0efeaab872e551b812843285e2c59ffe67cce8c715997b9b61 | Claim | (pending) | 2 days ago | IN | 0 ETH | (Pending) | |||
0x59f285333f6038af35310181875f30540772e30d6290f74623380829b56b1000 | Claim | (pending) | 2 days ago | IN | 0 ETH | (Pending) | |||
0x1ca813be7d0f31d98a0ac55e4287daed738095dea05be11e81fd1d2da09267dd | Claim | (pending) | 3 days ago | IN | 0 ETH | (Pending) | |||
0xdfe77e9178de1166dfd51e23e3eafb4a55edd41fa4e384a7dd8086bf54f8a64c | Claim | (pending) | 3 days ago | IN | 0 ETH | (Pending) | |||
Claim | 20318450 | 27 hrs ago | IN | 0 ETH | 0.00044116 | ||||
Claim | 20310673 | 2 days ago | IN | 0 ETH | 0.00029618 | ||||
Claim | 20303457 | 3 days ago | IN | 0 ETH | 0.00033118 | ||||
Claim | 20303059 | 3 days ago | IN | 0 ETH | 0.00027914 | ||||
Claim | 20282854 | 6 days ago | IN | 0 ETH | 0.00042866 | ||||
Claim | 20269507 | 7 days ago | IN | 0 ETH | 0.00068178 | ||||
Claim | 20266442 | 8 days ago | IN | 0 ETH | 0.00016508 | ||||
Claim | 20263163 | 8 days ago | IN | 0 ETH | 0.00065127 | ||||
Claim | 20262423 | 8 days ago | IN | 0 ETH | 0.00197236 | ||||
Claim | 20249851 | 10 days ago | IN | 0 ETH | 0.00012615 | ||||
Claim | 20248893 | 10 days ago | IN | 0 ETH | 0.00027812 | ||||
Claim | 20229410 | 13 days ago | IN | 0 ETH | 0.00026359 | ||||
Claim | 20221452 | 14 days ago | IN | 0 ETH | 0.00064162 | ||||
Claim | 20218915 | 15 days ago | IN | 0 ETH | 0.00061594 | ||||
Claim | 20204824 | 16 days ago | IN | 0 ETH | 0.00042031 | ||||
Claim | 20203547 | 17 days ago | IN | 0 ETH | 0.00022909 | ||||
Claim | 20202049 | 17 days ago | IN | 0 ETH | 0.00015199 | ||||
Claim | 20192643 | 18 days ago | IN | 0 ETH | 0.00022655 | ||||
Claim | 20192249 | 18 days ago | IN | 0 ETH | 0.00019401 |
Latest 25 internal transactions (View All)
Advanced mode:
Parent Transaction Hash | Block | From | To | |||
---|---|---|---|---|---|---|
18760425 | 219 days ago | 0.00070162 ETH | ||||
18760425 | 219 days ago | 0.06529837 ETH | ||||
18760385 | 219 days ago | 0.00075817 ETH | ||||
18760385 | 219 days ago | 0.11024182 ETH | ||||
18760321 | 219 days ago | 0.00136503 ETH | ||||
18760321 | 219 days ago | 0.22363496 ETH | ||||
18760293 | 219 days ago | 0.00118216 ETH | ||||
18760293 | 219 days ago | 0.11181783 ETH | ||||
18760265 | 219 days ago | 0.00075971 ETH | ||||
18760265 | 219 days ago | 0.46024028 ETH | ||||
18760258 | 219 days ago | 0.00077822 ETH | ||||
18760258 | 219 days ago | 0.07022177 ETH | ||||
18760255 | 219 days ago | 0.00077822 ETH | ||||
18760255 | 219 days ago | 0.07022177 ETH | ||||
18760249 | 219 days ago | 0.00066168 ETH | ||||
18760249 | 219 days ago | 0.01833831 ETH | ||||
18760237 | 219 days ago | 0.00091017 ETH | ||||
18760237 | 219 days ago | 0.19008982 ETH | ||||
18760164 | 219 days ago | 0.00077437 ETH | ||||
18760164 | 219 days ago | 0.05322562 ETH | ||||
18760089 | 219 days ago | 0.00149912 ETH | ||||
18760089 | 219 days ago | 0.11950087 ETH | ||||
18760006 | 219 days ago | 0.00077596 ETH | ||||
18760006 | 219 days ago | 0.04522403 ETH | ||||
18759798 | 219 days ago | 0.00086054 ETH |
Loading...
Loading
Contract Name:
ChimpzeePresale
Compiler Version
v0.8.18+commit.87f61d96
Optimization Enabled:
Yes with 200 runs
Other Settings:
default evmVersion
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: MIT /** ______ ____ ____ _____ ____ ____ _______ ________ ________ ________ * .' ___ ||_ || _||_ _||_ \ / _||_ __ \ | __ _||_ __ ||_ __ | * / .' \_| | |__| | | | | \/ | | |__) ||_/ / / | |_ \_| | |_ \_| * | | | __ | | | | |\ /| | | ___/ .'.' _ | _| _ | _| _ * \ `.___.'\ _| | | |_ _| |_ _| |_\/_| |_ _| |_ _/ /__/ | _| |__/ | _| |__/ | * `.____ .'|____||____||_____||_____||_____||_____| |________||________||________| */ pragma solidity 0.8.18; import "@openzeppelin/contracts/token/ERC20/IERC20.sol"; import "@openzeppelin/contracts/security/ReentrancyGuard.sol"; import "@openzeppelin/contracts/security/Pausable.sol"; import "@openzeppelin/contracts/access/Ownable.sol"; import "@openzeppelin/contracts/utils/Context.sol"; import "@chainlink/contracts/src/v0.8/interfaces/AggregatorV3Interface.sol"; contract ChimpzeePresale is Ownable, Pausable, ReentrancyGuard { uint256 public totalTokensSold = 0; uint256 public totalTokensSoldWithBonus = 0; uint256 public totalUsdRaised = 0; uint256 public startTime; uint256 public endTime; uint256 public claimStart; uint256 public baseDecimals = (10**18); uint256 public maxTokensToBuy = 50_000_000; uint256 public minUsdAmountToBuy = 24900000000000000000; uint256 public currentStage = 0; uint256 public checkPoint = 0; uint256[][3] public stages; uint256[][2] public bonuses = [[uint256(75), 150, 250, 500], [uint256(25), 50, 75, 100]]; address public saleTokenAdress; IERC20 public USDTInterface = IERC20(0xdAC17F958D2ee523a2206206994597C13D831ec7); AggregatorV3Interface internal priceFeed = AggregatorV3Interface(0x5f4eC3Df9cbd43714FE2740f5E3616155c5b8419); mapping(address => uint256) public userDeposits; mapping(address => bool) public hasClaimed; mapping(address => uint256) public userStage; event SaleTimeSet(uint256 _start, uint256 _end, uint256 timestamp); event SaleTimeUpdated(bytes32 indexed key, uint256 prevValue, uint256 newValue, uint256 timestamp); event TokensBought(address indexed user, uint256 indexed tokensBought, uint256 bonusTokens, uint256 totalTokens, address indexed purchaseToken, uint256 amountPaid, uint256 usdEq, uint256 timestamp); event TokensAdded(address indexed token, uint256 noOfTokens, uint256 timestamp); event TokensClaimed(address indexed user, uint256 amount, uint256 timestamp); event ClaimStartUpdated(uint256 prevValue, uint256 newValue, uint256 timestamp); /** * @dev Initializes the contract and sets key parameters * @param _startTime start time of the presale * @param _endTime end time of the presale * @param _stages stage data */ constructor (uint256 _startTime, uint256 _endTime, uint256[][3] memory _stages) { require(_startTime > block.timestamp && _endTime > _startTime, "Invalid time"); startTime = _startTime; endTime = _endTime; stages = _stages; emit SaleTimeSet(startTime, endTime, block.timestamp); } /** * @dev To pause the presale */ function pause() external onlyOwner { _pause(); } /** * @dev To unpause the presale */ function unpause() external onlyOwner { _unpause(); } /** * @dev To change maxTokensToBuy amount * @param _maxTokensToBuy New max token amount */ function changeMaxTokensToBuy(uint256 _maxTokensToBuy) external onlyOwner { require(_maxTokensToBuy > 0, 'Zero max tokens to buy value'); maxTokensToBuy = _maxTokensToBuy; } /** * @dev To change minUsdAmountToBuy. If zero, there is no min limit. * @param _minUsdAmount New min USD amount */ function changeMinUsdAmountToBuy(uint256 _minUsdAmount) external onlyOwner { minUsdAmountToBuy = _minUsdAmount; } /** * @dev To change stages data * @param _stages New stage data */ function changeStages(uint256[][3] memory _stages) external onlyOwner { stages = _stages; } /** * @dev To change bonus data * @param _bonuses New bonus data */ function changeBonuses(uint256[][2] memory _bonuses) external onlyOwner { bonuses = _bonuses; } /** * @dev To change USDT interface * @param _address Address of the USDT interface */ function changeUSDTInterface(address _address) external onlyOwner { USDTInterface = IERC20(_address); } /** * @dev To change aggregator interface * @param _address Address of the aggregator interface */ function changeAggregatorInterface(address _address) external onlyOwner { priceFeed = AggregatorV3Interface(_address); } modifier checkSaleState(uint256 amount) { require( block.timestamp >= startTime && block.timestamp <= endTime, "Invalid time for buying" ); require(amount > 0, "Invalid sale amount"); _; } /** * @dev To calculate the price in USD for given amount of tokens. * @param _amount No of tokens */ function calculatePrice(uint256 _amount) public view returns (uint256) { uint256 USDTAmount; uint256 total = checkPoint == 0 ? totalTokensSold : checkPoint; require(_amount <= maxTokensToBuy, 'Amount exceeds max tokens to buy'); if (_amount + total > stages[0][currentStage] || block.timestamp >= stages[2][currentStage]) { require(currentStage < (stages[0].length - 1), 'Not valid'); if (block.timestamp >= stages[2][currentStage]) { require(stages[0][currentStage] + _amount <= stages[0][currentStage + 1], ''); USDTAmount = _amount * stages[1][currentStage + 1]; } else { uint256 tokenAmountForCurrentPrice = stages[0][currentStage] - total; USDTAmount = tokenAmountForCurrentPrice * stages[1][currentStage] + (_amount - tokenAmountForCurrentPrice) * stages[1][currentStage + 1]; } } else USDTAmount = _amount * stages[1][currentStage]; return USDTAmount; } /** * @dev To calculate rewards in CHMPZ coin for given amount of tokens and usd price. * @param _amount No of tokens * @param _usdAmount usd price */ function calculateBonus(uint256 _amount, uint256 _usdAmount) public view returns (uint256) { uint256 bonusCoins; require(_usdAmount >= minUsdAmountToBuy, 'Min usd not reached'); for (uint i = bonuses[0].length; i > 0; i--) { if (_usdAmount >= (bonuses[0][i - 1] * baseDecimals)) { bonusCoins = ((bonuses[1][i - 1] * 100) * _amount) / 10_000; break; } else bonusCoins = 0; } return bonusCoins; } /** * @dev To update the sale times * @param _startTime New start time * @param _endTime New end time */ function changeSaleTimes(uint256 _startTime, uint256 _endTime) external onlyOwner { require(_startTime > 0 || _endTime > 0, 'Invalid parameters'); if (_startTime > 0) { uint256 prevValue = startTime; startTime = _startTime; emit SaleTimeUpdated(bytes32('START'), prevValue, _startTime, block.timestamp); } if (_endTime > 0) { uint256 prevValue = endTime; endTime = _endTime; emit SaleTimeUpdated(bytes32('END'), prevValue, _endTime, block.timestamp); } } /** * @dev To get latest ETH price in 10**18 format */ function getLatestPrice() public view returns (uint256) { (, int256 price, , , ) = priceFeed.latestRoundData(); price = (price * (10**10)); return uint256(price); } /** * @dev To buy into a presale using USDT * @param amount No of tokens to buy */ function buyWithUSDT(uint256 amount) external checkSaleState(amount) whenNotPaused returns (bool) { uint256 usdPrice = calculatePrice(amount); uint256 bonusCoins = calculateBonus(amount, usdPrice); uint256 newAmount = amount + bonusCoins; totalTokensSold += amount; totalTokensSoldWithBonus += newAmount; if (usdPrice >= (bonuses[0][0] * baseDecimals) && userStage[_msgSender()] == 0) userStage[_msgSender()] = currentStage + 1; if (checkPoint != 0) checkPoint += amount; uint256 total = totalTokensSold > checkPoint ? totalTokensSold : checkPoint; if (total > stages[0][currentStage] || block.timestamp >= stages[2][currentStage]) { if (block.timestamp >= stages[2][currentStage]) { checkPoint = stages[0][currentStage] + amount; } currentStage += 1; } userDeposits[_msgSender()] += (newAmount * baseDecimals); totalUsdRaised += usdPrice; uint256 ourAllowance = USDTInterface.allowance(_msgSender(), address(this)); uint256 price = usdPrice / (10 ** 12); require(price <= ourAllowance, 'Not enough allowance'); (bool success, ) = address(USDTInterface).call(abi.encodeWithSignature('transferFrom(address,address,uint256)', _msgSender(), owner(), price)); require(success, 'Token payment failed'); emit TokensBought(_msgSender(), amount, bonusCoins, newAmount, address(USDTInterface), usdPrice, usdPrice, block.timestamp); return true; } /** * @dev To buy into a presale using ETH * @param amount No of tokens to buy */ function buyWithEth(uint256 amount) external payable checkSaleState(amount) whenNotPaused nonReentrant returns (bool) { uint256 usdPrice = calculatePrice(amount); uint256 ethAmount = (usdPrice * baseDecimals) / getLatestPrice(); require(msg.value >= ethAmount, 'Less payment'); uint256 bonusCoins = calculateBonus(amount, usdPrice); uint256 newAmount = amount + bonusCoins; uint256 excess = msg.value - ethAmount; totalTokensSold += amount; totalTokensSoldWithBonus += newAmount; if (usdPrice >= (bonuses[0][0] * baseDecimals) && userStage[_msgSender()] == 0) userStage[_msgSender()] = currentStage + 1; if (checkPoint != 0) checkPoint += amount; uint256 total = totalTokensSold > checkPoint ? totalTokensSold : checkPoint; if (total > stages[0][currentStage] || block.timestamp >= stages[2][currentStage]) { if (block.timestamp >= stages[2][currentStage]) { checkPoint = stages[0][currentStage] + amount; } currentStage += 1; } userDeposits[_msgSender()] += (newAmount * baseDecimals); totalUsdRaised += usdPrice; sendValue(payable(owner()), ethAmount); if (excess > 0) sendValue(payable(_msgSender()), excess); emit TokensBought(_msgSender(), amount, bonusCoins, newAmount, address(0), ethAmount, usdPrice, block.timestamp); return true; } function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Low balance"); (bool success, ) = recipient.call{value: amount}(""); require(success, "ETH Payment failed"); } /** * @dev To set the claim start time and sale token address by the owner * @param _claimStart claim start time * @param noOfTokens Number of tokens to add to the contract * @param _saleTokenAdress sale token address */ function startClaim(uint256 _claimStart, uint256 noOfTokens, address _saleTokenAdress) external onlyOwner returns (bool) { require(_claimStart > endTime && _claimStart > block.timestamp, "Invalid claim start time"); require(noOfTokens >= (totalTokensSoldWithBonus * baseDecimals), "Tokens less than sold"); require(_saleTokenAdress != address(0), "Zero token address"); require(claimStart == 0, "Claim already set"); claimStart = _claimStart; saleTokenAdress = _saleTokenAdress; bool success = IERC20(_saleTokenAdress).transferFrom(_msgSender(), address(this), noOfTokens); require(success, "Token transfer failed"); emit TokensAdded(saleTokenAdress, noOfTokens, block.timestamp); return true; } /** * @dev To change the claim start time by the owner * @param _claimStart new claim start time */ function changeClaimStartTime(uint256 _claimStart) external onlyOwner returns (bool) { require(claimStart > 0, "Initial claim data not set"); require(_claimStart > endTime, "Sale in progress"); require(_claimStart > block.timestamp, "Claim start in past"); uint256 prevValue = claimStart; claimStart = _claimStart; emit ClaimStartUpdated(prevValue, _claimStart, block.timestamp); return true; } /** * @dev To claim tokens after claiming starts */ function claim() external whenNotPaused returns (bool) { require(saleTokenAdress != address(0), "Sale token not added"); require(block.timestamp >= claimStart, "Claim has not started yet"); require(!hasClaimed[_msgSender()], "Already claimed"); hasClaimed[_msgSender()] = true; uint256 amount = userDeposits[_msgSender()]; require(amount > 0, "Nothing to claim"); delete userDeposits[_msgSender()]; bool success = IERC20(saleTokenAdress).transfer(_msgSender(), amount); require(success, "Token transfer failed"); emit TokensClaimed(_msgSender(), amount, block.timestamp); return true; } /** * @dev To manualy increment stage */ function incrementCurrentStage() external onlyOwner { currentStage++; checkPoint = stages[0][currentStage]; } /** * @dev Helper funtion to get stage information */ function getStages() external view returns (uint256[][3] memory) { return stages; } /** * @dev Helper funtion to get bonus information */ function getBonuses() external view returns (uint256[][2] memory) { return bonuses; } function manualBuy(address _to, uint256 amount) external onlyOwner { uint256 usdPrice = calculatePrice(amount); uint256 bonusCoins = calculateBonus(amount, usdPrice); uint256 newAmount = amount + bonusCoins; totalTokensSold += amount; totalTokensSoldWithBonus += newAmount; if (usdPrice >= (bonuses[0][0] * baseDecimals) && userStage[_to] == 0) userStage[_to] = currentStage + 1; userDeposits[_to] += (newAmount * baseDecimals); totalUsdRaised += usdPrice; } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; interface AggregatorV3Interface { function decimals() external view returns (uint8); function description() external view returns (string memory); function version() external view returns (uint256); function getRoundData(uint80 _roundId) external view returns ( uint80 roundId, int256 answer, uint256 startedAt, uint256 updatedAt, uint80 answeredInRound ); function latestRoundData() external view returns ( uint80 roundId, int256 answer, uint256 startedAt, uint256 updatedAt, uint80 answeredInRound ); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol) pragma solidity ^0.8.0; import "../utils/Context.sol"; /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ abstract contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() { _transferOwnership(_msgSender()); } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { _checkOwner(); _; } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if the sender is not the owner. */ function _checkOwner() internal view virtual { require(owner() == _msgSender(), "Ownable: caller is not the owner"); } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _transferOwnership(address(0)); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Internal function without access restriction. */ function _transferOwnership(address newOwner) internal virtual { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol) pragma solidity ^0.8.0; import "../utils/Context.sol"; /** * @dev Contract module which allows children to implement an emergency stop * mechanism that can be triggered by an authorized account. * * This module is used through inheritance. It will make available the * modifiers `whenNotPaused` and `whenPaused`, which can be applied to * the functions of your contract. Note that they will not be pausable by * simply including this module, only once the modifiers are put in place. */ abstract contract Pausable is Context { /** * @dev Emitted when the pause is triggered by `account`. */ event Paused(address account); /** * @dev Emitted when the pause is lifted by `account`. */ event Unpaused(address account); bool private _paused; /** * @dev Initializes the contract in unpaused state. */ constructor() { _paused = false; } /** * @dev Modifier to make a function callable only when the contract is not paused. * * Requirements: * * - The contract must not be paused. */ modifier whenNotPaused() { _requireNotPaused(); _; } /** * @dev Modifier to make a function callable only when the contract is paused. * * Requirements: * * - The contract must be paused. */ modifier whenPaused() { _requirePaused(); _; } /** * @dev Returns true if the contract is paused, and false otherwise. */ function paused() public view virtual returns (bool) { return _paused; } /** * @dev Throws if the contract is paused. */ function _requireNotPaused() internal view virtual { require(!paused(), "Pausable: paused"); } /** * @dev Throws if the contract is not paused. */ function _requirePaused() internal view virtual { require(paused(), "Pausable: not paused"); } /** * @dev Triggers stopped state. * * Requirements: * * - The contract must not be paused. */ function _pause() internal virtual whenNotPaused { _paused = true; emit Paused(_msgSender()); } /** * @dev Returns to normal state. * * Requirements: * * - The contract must be paused. */ function _unpause() internal virtual whenPaused { _paused = false; emit Unpaused(_msgSender()); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.8.0) (security/ReentrancyGuard.sol) pragma solidity ^0.8.0; /** * @dev Contract module that helps prevent reentrant calls to a function. * * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier * available, which can be applied to functions to make sure there are no nested * (reentrant) calls to them. * * Note that because there is a single `nonReentrant` guard, functions marked as * `nonReentrant` may not call one another. This can be worked around by making * those functions `private`, and then adding `external` `nonReentrant` entry * points to them. * * TIP: If you would like to learn more about reentrancy and alternative ways * to protect against it, check out our blog post * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul]. */ abstract contract ReentrancyGuard { // Booleans are more expensive than uint256 or any type that takes up a full // word because each write operation emits an extra SLOAD to first read the // slot's contents, replace the bits taken up by the boolean, and then write // back. This is the compiler's defense against contract upgrades and // pointer aliasing, and it cannot be disabled. // The values being non-zero value makes deployment a bit more expensive, // but in exchange the refund on every call to nonReentrant will be lower in // amount. Since refunds are capped to a percentage of the total // transaction's gas, it is best to keep them low in cases like this one, to // increase the likelihood of the full refund coming into effect. uint256 private constant _NOT_ENTERED = 1; uint256 private constant _ENTERED = 2; uint256 private _status; constructor() { _status = _NOT_ENTERED; } /** * @dev Prevents a contract from calling itself, directly or indirectly. * Calling a `nonReentrant` function from another `nonReentrant` * function is not supported. It is possible to prevent this from happening * by making the `nonReentrant` function external, and making it call a * `private` function that does the actual work. */ modifier nonReentrant() { _nonReentrantBefore(); _; _nonReentrantAfter(); } function _nonReentrantBefore() private { // On the first call to nonReentrant, _status will be _NOT_ENTERED require(_status != _ENTERED, "ReentrancyGuard: reentrant call"); // Any calls to nonReentrant after this point will fail _status = _ENTERED; } function _nonReentrantAfter() private { // By storing the original value once again, a refund is triggered (see // https://eips.ethereum.org/EIPS/eip-2200) _status = _NOT_ENTERED; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol) pragma solidity ^0.8.0; /** * @dev Interface of the ERC20 standard as defined in the EIP. */ interface IERC20 { /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); /** * @dev Returns the amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the amount of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves `amount` tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 amount) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance(address owner, address spender) external view returns (uint256); /** * @dev Sets `amount` as the allowance of `spender` over the caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 amount) external returns (bool); /** * @dev Moves `amount` tokens from `from` to `to` using the * allowance mechanism. `amount` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom( address from, address to, uint256 amount ) external returns (bool); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/Context.sol) pragma solidity ^0.8.0; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } }
{ "optimizer": { "enabled": true, "runs": 200 }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "libraries": {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"uint256","name":"_startTime","type":"uint256"},{"internalType":"uint256","name":"_endTime","type":"uint256"},{"internalType":"uint256[][3]","name":"_stages","type":"uint256[][3]"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"prevValue","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"newValue","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"timestamp","type":"uint256"}],"name":"ClaimStartUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"_start","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"_end","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"timestamp","type":"uint256"}],"name":"SaleTimeSet","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"key","type":"bytes32"},{"indexed":false,"internalType":"uint256","name":"prevValue","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"newValue","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"timestamp","type":"uint256"}],"name":"SaleTimeUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"token","type":"address"},{"indexed":false,"internalType":"uint256","name":"noOfTokens","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"timestamp","type":"uint256"}],"name":"TokensAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokensBought","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"bonusTokens","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"totalTokens","type":"uint256"},{"indexed":true,"internalType":"address","name":"purchaseToken","type":"address"},{"indexed":false,"internalType":"uint256","name":"amountPaid","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"usdEq","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"timestamp","type":"uint256"}],"name":"TokensBought","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"timestamp","type":"uint256"}],"name":"TokensClaimed","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"inputs":[],"name":"USDTInterface","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"baseDecimals","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"bonuses","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"buyWithEth","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"buyWithUSDT","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"uint256","name":"_usdAmount","type":"uint256"}],"name":"calculateBonus","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"calculatePrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"changeAggregatorInterface","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256[][2]","name":"_bonuses","type":"uint256[][2]"}],"name":"changeBonuses","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_claimStart","type":"uint256"}],"name":"changeClaimStartTime","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_maxTokensToBuy","type":"uint256"}],"name":"changeMaxTokensToBuy","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_minUsdAmount","type":"uint256"}],"name":"changeMinUsdAmountToBuy","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_startTime","type":"uint256"},{"internalType":"uint256","name":"_endTime","type":"uint256"}],"name":"changeSaleTimes","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256[][3]","name":"_stages","type":"uint256[][3]"}],"name":"changeStages","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"changeUSDTInterface","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"checkPoint","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"claim","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"claimStart","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"currentStage","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"endTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getBonuses","outputs":[{"internalType":"uint256[][2]","name":"","type":"uint256[][2]"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getLatestPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getStages","outputs":[{"internalType":"uint256[][3]","name":"","type":"uint256[][3]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"hasClaimed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"incrementCurrentStage","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"manualBuy","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"maxTokensToBuy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minUsdAmountToBuy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"saleTokenAdress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"stages","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_claimStart","type":"uint256"},{"internalType":"uint256","name":"noOfTokens","type":"uint256"},{"internalType":"address","name":"_saleTokenAdress","type":"address"}],"name":"startClaim","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalTokensSold","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalTokensSoldWithBonus","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalUsdRaised","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unpause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"userDeposits","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"userStage","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"}]
Contract Creation Code
6000600281815560038290556004829055670de0b6b3a76400006008556302faf0806009556801598e9212fb3a0000600a55600b829055600c91909155604b60c0818152609660e05260fa610100526101f46101205260809081526101c060405260196101409081526032610160526101809290925260646101a05260a0919091526200009091601091906200022c565b50601380546001600160a01b031990811673dac17f958d2ee523a2206206994597c13d831ec71790915560148054909116735f4ec3df9cbd43714fe2740f5e3616155c5b8419179055348015620000e657600080fd5b5060405162002fe438038062002fe48339810160408190526200010991620003dd565b6200011433620001dc565b6000805460ff60a01b191690556001805542831180156200013457508282115b620001745760405162461bcd60e51b815260206004820152600c60248201526b496e76616c69642074696d6560a01b604482015260640160405180910390fd5b600583905560068290556200018d600d8260036200027d565b506005546006546040805192835260208301919091524282820152517f23f6ad8232d75562dd1c6b37dfc895af6bfc1ecd0fb3b88722c6a5e6b4dc9a209181900360600190a150505062000500565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b82600281019282156200026b579160200282015b828111156200026b5782516200025a9083906004620002c2565b509160200191906001019062000240565b50620002799291506200030e565b5090565b82600381019282156200026b579160200282015b828111156200026b5782518051620002b1918491602090910190620002c2565b509160200191906001019062000291565b82805482825590600052602060002090810192821562000300579160200282015b8281111562000300578251825591602001919060010190620002e3565b50620002799291506200032f565b808211156200027957600062000325828262000346565b506001016200030e565b5b8082111562000279576000815560010162000330565b50805460008255906000526020600020908101906200036691906200032f565b50565b634e487b7160e01b600052604160045260246000fd5b604051606081016001600160401b0381118282101715620003a457620003a462000369565b60405290565b604051601f8201601f191681016001600160401b0381118282101715620003d557620003d562000369565b604052919050565b600080600060608486031215620003f357600080fd5b835160208086015160408701519295509350906001600160401b03808211156200041c57600080fd5b818701915087601f8301126200043157600080fd5b6200043b6200037f565b80896060850111156200044d57600080fd5b835b60608501811015620004f0578051848111156200046b57600080fd5b8501601f81018c136200047d57600080fd5b80518581111562000492576200049262000369565b8060051b620004a3898201620003aa565b918252828101890191898101908f841115620004be57600080fd5b938a01935b83851015620004de5784518252938a0193908a0190620004c3565b8752505050928601925085016200044f565b5080955050505050509250925092565b612ad480620005106000396000f3fe60806040526004361061025c5760003560e01c806379655bd011610144578063b446a6e2116100b6578063eaad96971161007a578063eaad9697146106c1578063edb47e8d146106e1578063f04d688f146106f6578063f2fde38b1461070c578063f597573f1461072c578063f8c05c211461074c57600080fd5b8063b446a6e21461062b578063bc9955a21461064b578063bf39f7cd1461066b578063cff805ab1461068b578063e1858f1d146106a157600080fd5b80639ca8340e116101085780639ca8340e146105725780639cfa0f7c1461059f578063a7c60160146105b5578063a8e92a44146105d5578063ae104265146105eb578063b2caaebd1461060b57600080fd5b806379655bd0146104e85780638456cb591461050a5780638da5cb5b1461051f5780638e15f4731461053d578063921c67b41461055257600080fd5b8063537234fc116101dd5780636597a076116101a15780636597a076146104385780636f72fd201461045a578063715018a61461047a57806373b2e80e1461048f5780637649b957146104bf57806378e97925146104d257600080fd5b8063537234fc1461039f5780635a3e4435146103b55780635bf5d54c146103ed5780635c975abb1461040357806363b201171461042257600080fd5b80633197cbb6116102245780633197cbb61461032957806333f761781461033f57806339c38266146103555780633f4ba83a146103755780634e71d92d1461038a57600080fd5b80630ba36dcd146102615780630dc9c838146102a15780631345ee5d146102c3578063278c278b146102f35780632cea944214610313575b600080fd5b34801561026d57600080fd5b5061028e61027c366004612521565b60156020526000908152604090205481565b6040519081526020015b60405180910390f35b3480156102ad57600080fd5b506102c16102bc366004612543565b61076c565b005b3480156102cf57600080fd5b506102e36102de366004612565565b61087f565b6040519015158152602001610298565b3480156102ff57600080fd5b506102c161030e366004612565565b6109b6565b34801561031f57600080fd5b5061028e60045481565b34801561033557600080fd5b5061028e60065481565b34801561034b57600080fd5b5061028e60085481565b34801561036157600080fd5b506102c161037036600461257e565b610a13565b34801561038157600080fd5b506102c1610b4b565b34801561039657600080fd5b506102e3610b5d565b3480156103ab57600080fd5b5061028e60035481565b3480156103c157600080fd5b506012546103d5906001600160a01b031681565b6040516001600160a01b039091168152602001610298565b3480156103f957600080fd5b5061028e600b5481565b34801561040f57600080fd5b50600054600160a01b900460ff166102e3565b34801561042e57600080fd5b5061028e60025481565b34801561044457600080fd5b5061044d610dd9565b60405161029891906125a8565b34801561046657600080fd5b5061028e610475366004612543565b610e65565b34801561048657600080fd5b506102c1610f68565b34801561049b57600080fd5b506102e36104aa366004612521565b60166020526000908152604090205460ff1681565b6102e36104cd366004612565565b610f7a565b3480156104de57600080fd5b5061028e60055481565b3480156104f457600080fd5b506104fd611345565b604051610298919061261d565b34801561051657600080fd5b506102c16113c9565b34801561052b57600080fd5b506000546001600160a01b03166103d5565b34801561054957600080fd5b5061028e6113d9565b34801561055e57600080fd5b5061028e61056d366004612543565b61146a565b34801561057e57600080fd5b5061028e61058d366004612521565b60176020526000908152604090205481565b3480156105ab57600080fd5b5061028e60095481565b3480156105c157600080fd5b506102e36105d0366004612565565b61149e565b3480156105e157600080fd5b5061028e600a5481565b3480156105f757600080fd5b5061028e610606366004612565565b6119ab565b34801561061757600080fd5b506102e3610626366004612685565b611cac565b34801561063757600080fd5b506102c16106463660046127b7565b611f34565b34801561065757600080fd5b5061028e610666366004612543565b611f49565b34801561067757600080fd5b506102c1610686366004612521565b611f59565b34801561069757600080fd5b5061028e600c5481565b3480156106ad57600080fd5b506102c16106bc366004612565565b611f83565b3480156106cd57600080fd5b506102c16106dc366004612521565b611f90565b3480156106ed57600080fd5b506102c1611fba565b34801561070257600080fd5b5061028e60075481565b34801561071857600080fd5b506102c1610727366004612521565b612001565b34801561073857600080fd5b506013546103d5906001600160a01b031681565b34801561075857600080fd5b506102c1610767366004612852565b61207a565b61077461208f565b60008211806107835750600081115b6107c95760405162461bcd60e51b8152602060048201526012602482015271496e76616c696420706172616d657465727360701b60448201526064015b60405180910390fd5b81156108235760058054908390556040805182815260208101859052428183015290516414d510549560da1b917fddd2ed237e6993c9380182683f2c8bec486aaaa429528852cd74dbdb96cea0b2919081900360600190a2505b801561087b5760068054908290556040805182815260208101849052428183015290516211539160ea1b917fddd2ed237e6993c9380182683f2c8bec486aaaa429528852cd74dbdb96cea0b2919081900360600190a2505b5050565b600061088961208f565b6000600754116108db5760405162461bcd60e51b815260206004820152601a60248201527f496e697469616c20636c61696d2064617461206e6f742073657400000000000060448201526064016107c0565b600654821161091f5760405162461bcd60e51b815260206004820152601060248201526f53616c6520696e2070726f677265737360801b60448201526064016107c0565b4282116109645760405162461bcd60e51b815260206004820152601360248201527210db185a5b481cdd185c9d081a5b881c185cdd606a1b60448201526064016107c0565b60078054908390556040805182815260208101859052428183015290517f5f3a900c85949962b4cc192dd3714dae64071dc2e907049ec720b023270905a49181900360600190a160019150505b919050565b6109be61208f565b60008111610a0e5760405162461bcd60e51b815260206004820152601c60248201527f5a65726f206d617820746f6b656e7320746f206275792076616c75650000000060448201526064016107c0565b600955565b610a1b61208f565b6000610a26826119ab565b90506000610a348383610e65565b90506000610a4282856128f5565b90508360026000828254610a5691906128f5565b925050819055508060036000828254610a6f91906128f5565b909155505060085460108054600090610a8a57610a8a612908565b9060005260206000200154610a9f919061291e565b8310158015610ac457506001600160a01b038516600090815260176020526040902054155b15610af157600b54610ad79060016128f5565b6001600160a01b0386166000908152601760205260409020555b600854610afe908261291e565b6001600160a01b03861660009081526015602052604081208054909190610b269084906128f5565b925050819055508260046000828254610b3f91906128f5565b90915550505050505050565b610b5361208f565b610b5b6120e9565b565b6000610b6761213e565b6012546001600160a01b0316610bb65760405162461bcd60e51b815260206004820152601460248201527314d85b19481d1bdad95b881b9bdd08185919195960621b60448201526064016107c0565b600754421015610c085760405162461bcd60e51b815260206004820152601960248201527f436c61696d20686173206e6f742073746172746564207965740000000000000060448201526064016107c0565b3360009081526016602052604090205460ff1615610c5a5760405162461bcd60e51b815260206004820152600f60248201526e105b1c9958591e4818db185a5b5959608a1b60448201526064016107c0565b336000908152601660209081526040808320805460ff19166001179055601590915290205480610cbf5760405162461bcd60e51b815260206004820152601060248201526f4e6f7468696e6720746f20636c61696d60801b60448201526064016107c0565b336000818152601560209081526040808320839055601254815163a9059cbb60e01b8152600481019590955260248501869052905192936001600160a01b039091169263a9059cbb92604480840193919291829003018187875af1158015610d2b573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d4f9190612935565b905080610d965760405162461bcd60e51b8152602060048201526015602482015274151bdad95b881d1c985b9cd9995c8819985a5b1959605a1b60448201526064016107c0565b6040805183815242602082015233917f9923b4306c6c030f2bdfbf156517d5983b87e15b96176da122cd4f2effa4ba7b910160405180910390a260019250505090565b610de16123a2565b60408051808201909152601060026000835b82821015610e5c57838201805480602002602001604051908101604052809291908181526020018280548015610e4857602002820191906000526020600020905b815481526020019060010190808311610e34575b505050505081526020019060010190610df3565b50505050905090565b600080600a54831015610eb05760405162461bcd60e51b8152602060048201526013602482015272135a5b881d5cd9081b9bdd081c995858da1959606a1b60448201526064016107c0565b6010545b8015610f5e576008546010610eca600184612957565b81548110610eda57610eda612908565b9060005260206000200154610eef919061291e565b8410610f4857612710856011610f06600185612957565b81548110610f1657610f16612908565b90600052602060002001546064610f2d919061291e565b610f37919061291e565b610f41919061296a565b9150610f5e565b6000915080610f568161298c565b915050610eb4565b5090505b92915050565b610f7061208f565b610b5b600061218b565b6000816005544210158015610f9157506006544211155b610fd75760405162461bcd60e51b8152602060048201526017602482015276496e76616c69642074696d6520666f7220627579696e6760481b60448201526064016107c0565b6000811161101d5760405162461bcd60e51b8152602060048201526013602482015272125b9d985b1a59081cd85b1948185b5bdd5b9d606a1b60448201526064016107c0565b61102561213e565b61102d6121db565b6000611038846119ab565b905060006110446113d9565b600854611051908461291e565b61105b919061296a565b90508034101561109c5760405162461bcd60e51b815260206004820152600c60248201526b13195cdcc81c185e5b595b9d60a21b60448201526064016107c0565b60006110a88684610e65565b905060006110b682886128f5565b905060006110c48434612957565b905087600260008282546110d891906128f5565b9250508190555081600360008282546110f191906128f5565b90915550506008546010805460009061110c5761110c612908565b9060005260206000200154611121919061291e565b851015801561113d575033600090815260176020526040902054155b1561116157600b546111509060016128f5565b336000908152601760205260409020555b600c54156111815787600c600082825461117b91906128f5565b90915550505b6000600c546002541161119657600c5461119a565b6002545b9050600d600001600b54815481106111b4576111b4612908565b90600052602060002001548111806111ee5750600d600201600b54815481106111df576111df612908565b90600052602060002001544210155b1561126757600d600201600b548154811061120b5761120b612908565b9060005260206000200154421061124e5788600d600001600b548154811061123557611235612908565b906000526020600020015461124a91906128f5565b600c555b6001600b600082825461126191906128f5565b90915550505b600854611274908461291e565b33600090815260156020526040812080549091906112939084906128f5565b9250508190555085600460008282546112ac91906128f5565b90915550506000546112c7906001600160a01b031686612234565b81156112d7576112d73383612234565b60408051858152602081018590528082018790526060810188905242608082015290516000918b9133917fb3d2a2da49a1402d79cbdc48802ed94f04bd61691ea829292e3c195296972da8919081900360a00190a46001975050505050505061133f60018055565b50919050565b61134d6123c9565b6040805160608101909152600d60036000835b82821015610e5c578382018054806020026020016040519081016040528092919081815260200182805480156113b557602002820191906000526020600020905b8154815260200190600101908083116113a1575b505050505081526020019060010190611360565b6113d161208f565b610b5b61230f565b600080601460009054906101000a90046001600160a01b03166001600160a01b031663feaf968c6040518163ffffffff1660e01b815260040160a060405180830381865afa15801561142f573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061145391906129bd565b505050915050806402540be400610f629190612a0d565b600d826003811061147a57600080fd5b01818154811061148957600080fd5b90600052602060002001600091509150505481565b60008160055442101580156114b557506006544211155b6114fb5760405162461bcd60e51b8152602060048201526017602482015276496e76616c69642074696d6520666f7220627579696e6760481b60448201526064016107c0565b600081116115415760405162461bcd60e51b8152602060048201526013602482015272125b9d985b1a59081cd85b1948185b5bdd5b9d606a1b60448201526064016107c0565b61154961213e565b6000611554846119ab565b905060006115628583610e65565b9050600061157082876128f5565b9050856002600082825461158491906128f5565b92505081905550806003600082825461159d91906128f5565b9091555050600854601080546000906115b8576115b8612908565b90600052602060002001546115cd919061291e565b83101580156115e9575033600090815260176020526040902054155b1561160d57600b546115fc9060016128f5565b336000908152601760205260409020555b600c541561162d5785600c600082825461162791906128f5565b90915550505b6000600c546002541161164257600c54611646565b6002545b9050600d600001600b548154811061166057611660612908565b906000526020600020015481118061169a5750600d600201600b548154811061168b5761168b612908565b90600052602060002001544210155b1561171357600d600201600b54815481106116b7576116b7612908565b906000526020600020015442106116fa5786600d600001600b54815481106116e1576116e1612908565b90600052602060002001546116f691906128f5565b600c555b6001600b600082825461170d91906128f5565b90915550505b600854611720908361291e565b336000908152601560205260408120805490919061173f9084906128f5565b92505081905550836004600082825461175891906128f5565b90915550506013546000906001600160a01b031663dd62ed3e336040516001600160e01b031960e084901b1681526001600160a01b039091166004820152306024820152604401602060405180830381865afa1580156117bc573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117e09190612a3d565b905060006117f364e8d4a510008761296a565b90508181111561183c5760405162461bcd60e51b81526020600482015260146024820152734e6f7420656e6f75676820616c6c6f77616e636560601b60448201526064016107c0565b6013546000906001600160a01b0316336000546001600160a01b03166040516001600160a01b039283166024820152911660448201526064810184905260840160408051601f198184030181529181526020820180516001600160e01b03166323b872dd60e01b179052516118b19190612a56565b6000604051808303816000865af19150503d80600081146118ee576040519150601f19603f3d011682016040523d82523d6000602084013e6118f3565b606091505b505090508061193b5760405162461bcd60e51b8152602060048201526014602482015273151bdad95b881c185e5b595b9d0819985a5b195960621b60448201526064016107c0565b60135460408051888152602081018890528082018a9052606081018a905242608082015290516001600160a01b03909216918c9133917fb3d2a2da49a1402d79cbdc48802ed94f04bd61691ea829292e3c195296972da89181900360a00190a45060019998505050505050505050565b6000806000600c546000146119c257600c546119c6565b6002545b9050600954841115611a1a5760405162461bcd60e51b815260206004820181905260248201527f416d6f756e742065786365656473206d617820746f6b656e7320746f2062757960448201526064016107c0565b600d600001600b5481548110611a3257611a32612908565b90600052602060002001548185611a4991906128f5565b1180611a775750600d600201600b5481548110611a6857611a68612908565b90600052602060002001544210155b15611c7457600d54611a8b90600190612957565b600b5410611ac75760405162461bcd60e51b8152602060048201526009602482015268139bdd081d985b1a5960ba1b60448201526064016107c0565b600d600201600b5481548110611adf57611adf612908565b90600052602060002001544210611bc057600b54600d90611b019060016128f5565b81548110611b1157611b11612908565b906000526020600020015484600d600060038110611b3157611b31612908565b01600b5481548110611b4557611b45612908565b9060005260206000200154611b5a91906128f5565b1115611b825760405162461bcd60e51b815260206004820152600060248201526044016107c0565b600b54600e90611b939060016128f5565b81548110611ba357611ba3612908565b906000526020600020015484611bb9919061291e565b9150611ca5565b600081600d8201600b5481548110611bda57611bda612908565b9060005260206000200154611bef9190612957565b600b54909150600e90611c039060016128f5565b81548110611c1357611c13612908565b90600052602060002001548186611c2a9190612957565b611c34919061291e565b600d600101600b5481548110611c4c57611c4c612908565b906000526020600020015482611c62919061291e565b611c6c91906128f5565b925050611ca5565b600d600101600b5481548110611c8c57611c8c612908565b906000526020600020015484611ca2919061291e565b91505b5092915050565b6000611cb661208f565b60065484118015611cc657504284115b611d125760405162461bcd60e51b815260206004820152601860248201527f496e76616c696420636c61696d2073746172742074696d65000000000000000060448201526064016107c0565b600854600354611d22919061291e565b831015611d695760405162461bcd60e51b8152602060048201526015602482015274151bdad95b9cc81b195cdcc81d1a185b881cdbdb19605a1b60448201526064016107c0565b6001600160a01b038216611db45760405162461bcd60e51b81526020600482015260126024820152715a65726f20746f6b656e206164647265737360701b60448201526064016107c0565b60075415611df85760405162461bcd60e51b815260206004820152601160248201527010db185a5b48185b1c9958591e481cd95d607a1b60448201526064016107c0565b6007849055601280546001600160a01b0319166001600160a01b0384169081179091556000906323b872dd336040516001600160e01b031960e084901b1681526001600160a01b039091166004820152306024820152604481018790526064016020604051808303816000875af1158015611e77573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e9b9190612935565b905080611ee25760405162461bcd60e51b8152602060048201526015602482015274151bdad95b881d1c985b9cd9995c8819985a5b1959605a1b60448201526064016107c0565b601254604080518681524260208201526001600160a01b03909216917fdc9670dbabdd488b372eb16ebe49a39b3124a12cdffdcefbc89834a408bf8ff8910160405180910390a2506001949350505050565b611f3c61208f565b61087b600d8260036123e3565b6010826002811061147a57600080fd5b611f6161208f565b601380546001600160a01b0319166001600160a01b0392909216919091179055565b611f8b61208f565b600a55565b611f9861208f565b601480546001600160a01b0319166001600160a01b0392909216919091179055565b611fc261208f565b600b8054906000611fd283612a85565b90915550600d9050600001600b5481548110611ff057611ff0612908565b600091825260209091200154600c55565b61200961208f565b6001600160a01b03811661206e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107c0565b6120778161218b565b50565b61208261208f565b61087b6010826002612433565b6000546001600160a01b03163314610b5b5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016107c0565b6120f1612352565b6000805460ff60a01b191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa335b6040516001600160a01b03909116815260200160405180910390a1565b600054600160a01b900460ff1615610b5b5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b60448201526064016107c0565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60026001540361222d5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016107c0565b6002600155565b804710156122725760405162461bcd60e51b815260206004820152600b60248201526a4c6f772062616c616e636560a81b60448201526064016107c0565b6000826001600160a01b03168260405160006040518083038185875af1925050503d80600081146122bf576040519150601f19603f3d011682016040523d82523d6000602084013e6122c4565b606091505b505090508061230a5760405162461bcd60e51b81526020600482015260126024820152711155120814185e5b595b9d0819985a5b195960721b60448201526064016107c0565b505050565b61231761213e565b6000805460ff60a01b1916600160a01b1790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2586121213390565b600054600160a01b900460ff16610b5b5760405162461bcd60e51b815260206004820152601460248201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b60448201526064016107c0565b60405180604001604052806002905b60608152602001906001900390816123b15790505090565b6040805160608082019092529081526002602082016123b1565b8260038101928215612423579160200282015b828111156124235782518051612413918491602090910190612473565b50916020019190600101906123f6565b5061242f9291506124ba565b5090565b8260028101928215612423579160200282015b828111156124235782518051612463918491602090910190612473565b5091602001919060010190612446565b8280548282559060005260206000209081019282156124ae579160200282015b828111156124ae578251825591602001919060010190612493565b5061242f9291506124d7565b8082111561242f5760006124ce82826124ec565b506001016124ba565b5b8082111561242f57600081556001016124d8565b508054600082559060005260206000209081019061207791906124d7565b80356001600160a01b03811681146109b157600080fd5b60006020828403121561253357600080fd5b61253c8261250a565b9392505050565b6000806040838503121561255657600080fd5b50508035926020909101359150565b60006020828403121561257757600080fd5b5035919050565b6000806040838503121561259157600080fd5b61259a8361250a565b946020939093013593505050565b6020808252600090606083018382018584805b600281101561261057878503601f19018452825180518087529087019087870190845b818110156125fa578351835292890192918901916001016125de565b50909650505092850192918501916001016125bb565b5092979650505050505050565b6020808252600090608083018382018584805b600381101561261057878503601f19018452825180518087529087019087870190845b8181101561266f57835183529289019291890191600101612653565b5090965050509285019291850191600101612630565b60008060006060848603121561269a57600080fd5b83359250602084013591506126b16040850161250a565b90509250925092565b634e487b7160e01b600052604160045260246000fd5b6040516060810167ffffffffffffffff811182821017156126f3576126f36126ba565b60405290565b6040805190810167ffffffffffffffff811182821017156126f3576126f36126ba565b600082601f83011261272d57600080fd5b8135602067ffffffffffffffff8083111561274a5761274a6126ba565b8260051b604051601f19603f8301168101818110848211171561276f5761276f6126ba565b60405293845285810183019383810192508785111561278d57600080fd5b83870191505b848210156127ac57813583529183019190830190612793565b979650505050505050565b600060208083850312156127ca57600080fd5b823567ffffffffffffffff808211156127e257600080fd5b818501915085601f8301126127f657600080fd5b6127fe6126d0565b80606084018881111561281057600080fd5b845b818110156128445780358581111561282a5760008081fd5b6128368b82890161271c565b855250928601928601612812565b509098975050505050505050565b6000602080838503121561286557600080fd5b823567ffffffffffffffff8082111561287d57600080fd5b818501915085601f83011261289157600080fd5b6128996126f9565b8060408401888111156128ab57600080fd5b845b81811015612844578035858111156128c55760008081fd5b6128d18b82890161271c565b8552509286019286016128ad565b634e487b7160e01b600052601160045260246000fd5b80820180821115610f6257610f626128df565b634e487b7160e01b600052603260045260246000fd5b8082028115828204841417610f6257610f626128df565b60006020828403121561294757600080fd5b8151801515811461253c57600080fd5b81810381811115610f6257610f626128df565b60008261298757634e487b7160e01b600052601260045260246000fd5b500490565b60008161299b5761299b6128df565b506000190190565b805169ffffffffffffffffffff811681146109b157600080fd5b600080600080600060a086880312156129d557600080fd5b6129de866129a3565b9450602086015193506040860151925060608601519150612a01608087016129a3565b90509295509295909350565b80820260008212600160ff1b84141615612a2957612a296128df565b8181058314821517610f6257610f626128df565b600060208284031215612a4f57600080fd5b5051919050565b6000825160005b81811015612a775760208186018101518583015201612a5d565b506000920191825250919050565b600060018201612a9757612a976128df565b506001019056fea26469706673582212207d07077bd98c8a973c7424cca144c0a4951c6b8dd28953b6ff836c729337d78c64736f6c63430008120033000000000000000000000000000000000000000000000000000000006417def000000000000000000000000000000000000000000000000000000000655aa18000000000000000000000000000000000000000000000000000000000000000600000000000000000000000000000000000000000000000000000000000000060000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001a00000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000037e11d6000000000000000000000000000000000000000000000000000000000649534e000000000000000000000000000000000000000000000000000000000826299e0000000000000000000000000000000000000000000000000000000009502f900000000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000001c6bf5263400000000000000000000000000000000000000000000000000000027ca57357c000000000000000000000000000000000000000000000000000000360051c8960000000000000000000000000000000000000000000000000000003e871b540c00000000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000064680d800000000000000000000000000000000000000000000000000000000064b8790000000000000000000000000000000000000000000000000000000000650a360000000000000000000000000000000000000000000000000000000000655aa180
Deployed Bytecode
0x60806040526004361061025c5760003560e01c806379655bd011610144578063b446a6e2116100b6578063eaad96971161007a578063eaad9697146106c1578063edb47e8d146106e1578063f04d688f146106f6578063f2fde38b1461070c578063f597573f1461072c578063f8c05c211461074c57600080fd5b8063b446a6e21461062b578063bc9955a21461064b578063bf39f7cd1461066b578063cff805ab1461068b578063e1858f1d146106a157600080fd5b80639ca8340e116101085780639ca8340e146105725780639cfa0f7c1461059f578063a7c60160146105b5578063a8e92a44146105d5578063ae104265146105eb578063b2caaebd1461060b57600080fd5b806379655bd0146104e85780638456cb591461050a5780638da5cb5b1461051f5780638e15f4731461053d578063921c67b41461055257600080fd5b8063537234fc116101dd5780636597a076116101a15780636597a076146104385780636f72fd201461045a578063715018a61461047a57806373b2e80e1461048f5780637649b957146104bf57806378e97925146104d257600080fd5b8063537234fc1461039f5780635a3e4435146103b55780635bf5d54c146103ed5780635c975abb1461040357806363b201171461042257600080fd5b80633197cbb6116102245780633197cbb61461032957806333f761781461033f57806339c38266146103555780633f4ba83a146103755780634e71d92d1461038a57600080fd5b80630ba36dcd146102615780630dc9c838146102a15780631345ee5d146102c3578063278c278b146102f35780632cea944214610313575b600080fd5b34801561026d57600080fd5b5061028e61027c366004612521565b60156020526000908152604090205481565b6040519081526020015b60405180910390f35b3480156102ad57600080fd5b506102c16102bc366004612543565b61076c565b005b3480156102cf57600080fd5b506102e36102de366004612565565b61087f565b6040519015158152602001610298565b3480156102ff57600080fd5b506102c161030e366004612565565b6109b6565b34801561031f57600080fd5b5061028e60045481565b34801561033557600080fd5b5061028e60065481565b34801561034b57600080fd5b5061028e60085481565b34801561036157600080fd5b506102c161037036600461257e565b610a13565b34801561038157600080fd5b506102c1610b4b565b34801561039657600080fd5b506102e3610b5d565b3480156103ab57600080fd5b5061028e60035481565b3480156103c157600080fd5b506012546103d5906001600160a01b031681565b6040516001600160a01b039091168152602001610298565b3480156103f957600080fd5b5061028e600b5481565b34801561040f57600080fd5b50600054600160a01b900460ff166102e3565b34801561042e57600080fd5b5061028e60025481565b34801561044457600080fd5b5061044d610dd9565b60405161029891906125a8565b34801561046657600080fd5b5061028e610475366004612543565b610e65565b34801561048657600080fd5b506102c1610f68565b34801561049b57600080fd5b506102e36104aa366004612521565b60166020526000908152604090205460ff1681565b6102e36104cd366004612565565b610f7a565b3480156104de57600080fd5b5061028e60055481565b3480156104f457600080fd5b506104fd611345565b604051610298919061261d565b34801561051657600080fd5b506102c16113c9565b34801561052b57600080fd5b506000546001600160a01b03166103d5565b34801561054957600080fd5b5061028e6113d9565b34801561055e57600080fd5b5061028e61056d366004612543565b61146a565b34801561057e57600080fd5b5061028e61058d366004612521565b60176020526000908152604090205481565b3480156105ab57600080fd5b5061028e60095481565b3480156105c157600080fd5b506102e36105d0366004612565565b61149e565b3480156105e157600080fd5b5061028e600a5481565b3480156105f757600080fd5b5061028e610606366004612565565b6119ab565b34801561061757600080fd5b506102e3610626366004612685565b611cac565b34801561063757600080fd5b506102c16106463660046127b7565b611f34565b34801561065757600080fd5b5061028e610666366004612543565b611f49565b34801561067757600080fd5b506102c1610686366004612521565b611f59565b34801561069757600080fd5b5061028e600c5481565b3480156106ad57600080fd5b506102c16106bc366004612565565b611f83565b3480156106cd57600080fd5b506102c16106dc366004612521565b611f90565b3480156106ed57600080fd5b506102c1611fba565b34801561070257600080fd5b5061028e60075481565b34801561071857600080fd5b506102c1610727366004612521565b612001565b34801561073857600080fd5b506013546103d5906001600160a01b031681565b34801561075857600080fd5b506102c1610767366004612852565b61207a565b61077461208f565b60008211806107835750600081115b6107c95760405162461bcd60e51b8152602060048201526012602482015271496e76616c696420706172616d657465727360701b60448201526064015b60405180910390fd5b81156108235760058054908390556040805182815260208101859052428183015290516414d510549560da1b917fddd2ed237e6993c9380182683f2c8bec486aaaa429528852cd74dbdb96cea0b2919081900360600190a2505b801561087b5760068054908290556040805182815260208101849052428183015290516211539160ea1b917fddd2ed237e6993c9380182683f2c8bec486aaaa429528852cd74dbdb96cea0b2919081900360600190a2505b5050565b600061088961208f565b6000600754116108db5760405162461bcd60e51b815260206004820152601a60248201527f496e697469616c20636c61696d2064617461206e6f742073657400000000000060448201526064016107c0565b600654821161091f5760405162461bcd60e51b815260206004820152601060248201526f53616c6520696e2070726f677265737360801b60448201526064016107c0565b4282116109645760405162461bcd60e51b815260206004820152601360248201527210db185a5b481cdd185c9d081a5b881c185cdd606a1b60448201526064016107c0565b60078054908390556040805182815260208101859052428183015290517f5f3a900c85949962b4cc192dd3714dae64071dc2e907049ec720b023270905a49181900360600190a160019150505b919050565b6109be61208f565b60008111610a0e5760405162461bcd60e51b815260206004820152601c60248201527f5a65726f206d617820746f6b656e7320746f206275792076616c75650000000060448201526064016107c0565b600955565b610a1b61208f565b6000610a26826119ab565b90506000610a348383610e65565b90506000610a4282856128f5565b90508360026000828254610a5691906128f5565b925050819055508060036000828254610a6f91906128f5565b909155505060085460108054600090610a8a57610a8a612908565b9060005260206000200154610a9f919061291e565b8310158015610ac457506001600160a01b038516600090815260176020526040902054155b15610af157600b54610ad79060016128f5565b6001600160a01b0386166000908152601760205260409020555b600854610afe908261291e565b6001600160a01b03861660009081526015602052604081208054909190610b269084906128f5565b925050819055508260046000828254610b3f91906128f5565b90915550505050505050565b610b5361208f565b610b5b6120e9565b565b6000610b6761213e565b6012546001600160a01b0316610bb65760405162461bcd60e51b815260206004820152601460248201527314d85b19481d1bdad95b881b9bdd08185919195960621b60448201526064016107c0565b600754421015610c085760405162461bcd60e51b815260206004820152601960248201527f436c61696d20686173206e6f742073746172746564207965740000000000000060448201526064016107c0565b3360009081526016602052604090205460ff1615610c5a5760405162461bcd60e51b815260206004820152600f60248201526e105b1c9958591e4818db185a5b5959608a1b60448201526064016107c0565b336000908152601660209081526040808320805460ff19166001179055601590915290205480610cbf5760405162461bcd60e51b815260206004820152601060248201526f4e6f7468696e6720746f20636c61696d60801b60448201526064016107c0565b336000818152601560209081526040808320839055601254815163a9059cbb60e01b8152600481019590955260248501869052905192936001600160a01b039091169263a9059cbb92604480840193919291829003018187875af1158015610d2b573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d4f9190612935565b905080610d965760405162461bcd60e51b8152602060048201526015602482015274151bdad95b881d1c985b9cd9995c8819985a5b1959605a1b60448201526064016107c0565b6040805183815242602082015233917f9923b4306c6c030f2bdfbf156517d5983b87e15b96176da122cd4f2effa4ba7b910160405180910390a260019250505090565b610de16123a2565b60408051808201909152601060026000835b82821015610e5c57838201805480602002602001604051908101604052809291908181526020018280548015610e4857602002820191906000526020600020905b815481526020019060010190808311610e34575b505050505081526020019060010190610df3565b50505050905090565b600080600a54831015610eb05760405162461bcd60e51b8152602060048201526013602482015272135a5b881d5cd9081b9bdd081c995858da1959606a1b60448201526064016107c0565b6010545b8015610f5e576008546010610eca600184612957565b81548110610eda57610eda612908565b9060005260206000200154610eef919061291e565b8410610f4857612710856011610f06600185612957565b81548110610f1657610f16612908565b90600052602060002001546064610f2d919061291e565b610f37919061291e565b610f41919061296a565b9150610f5e565b6000915080610f568161298c565b915050610eb4565b5090505b92915050565b610f7061208f565b610b5b600061218b565b6000816005544210158015610f9157506006544211155b610fd75760405162461bcd60e51b8152602060048201526017602482015276496e76616c69642074696d6520666f7220627579696e6760481b60448201526064016107c0565b6000811161101d5760405162461bcd60e51b8152602060048201526013602482015272125b9d985b1a59081cd85b1948185b5bdd5b9d606a1b60448201526064016107c0565b61102561213e565b61102d6121db565b6000611038846119ab565b905060006110446113d9565b600854611051908461291e565b61105b919061296a565b90508034101561109c5760405162461bcd60e51b815260206004820152600c60248201526b13195cdcc81c185e5b595b9d60a21b60448201526064016107c0565b60006110a88684610e65565b905060006110b682886128f5565b905060006110c48434612957565b905087600260008282546110d891906128f5565b9250508190555081600360008282546110f191906128f5565b90915550506008546010805460009061110c5761110c612908565b9060005260206000200154611121919061291e565b851015801561113d575033600090815260176020526040902054155b1561116157600b546111509060016128f5565b336000908152601760205260409020555b600c54156111815787600c600082825461117b91906128f5565b90915550505b6000600c546002541161119657600c5461119a565b6002545b9050600d600001600b54815481106111b4576111b4612908565b90600052602060002001548111806111ee5750600d600201600b54815481106111df576111df612908565b90600052602060002001544210155b1561126757600d600201600b548154811061120b5761120b612908565b9060005260206000200154421061124e5788600d600001600b548154811061123557611235612908565b906000526020600020015461124a91906128f5565b600c555b6001600b600082825461126191906128f5565b90915550505b600854611274908461291e565b33600090815260156020526040812080549091906112939084906128f5565b9250508190555085600460008282546112ac91906128f5565b90915550506000546112c7906001600160a01b031686612234565b81156112d7576112d73383612234565b60408051858152602081018590528082018790526060810188905242608082015290516000918b9133917fb3d2a2da49a1402d79cbdc48802ed94f04bd61691ea829292e3c195296972da8919081900360a00190a46001975050505050505061133f60018055565b50919050565b61134d6123c9565b6040805160608101909152600d60036000835b82821015610e5c578382018054806020026020016040519081016040528092919081815260200182805480156113b557602002820191906000526020600020905b8154815260200190600101908083116113a1575b505050505081526020019060010190611360565b6113d161208f565b610b5b61230f565b600080601460009054906101000a90046001600160a01b03166001600160a01b031663feaf968c6040518163ffffffff1660e01b815260040160a060405180830381865afa15801561142f573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061145391906129bd565b505050915050806402540be400610f629190612a0d565b600d826003811061147a57600080fd5b01818154811061148957600080fd5b90600052602060002001600091509150505481565b60008160055442101580156114b557506006544211155b6114fb5760405162461bcd60e51b8152602060048201526017602482015276496e76616c69642074696d6520666f7220627579696e6760481b60448201526064016107c0565b600081116115415760405162461bcd60e51b8152602060048201526013602482015272125b9d985b1a59081cd85b1948185b5bdd5b9d606a1b60448201526064016107c0565b61154961213e565b6000611554846119ab565b905060006115628583610e65565b9050600061157082876128f5565b9050856002600082825461158491906128f5565b92505081905550806003600082825461159d91906128f5565b9091555050600854601080546000906115b8576115b8612908565b90600052602060002001546115cd919061291e565b83101580156115e9575033600090815260176020526040902054155b1561160d57600b546115fc9060016128f5565b336000908152601760205260409020555b600c541561162d5785600c600082825461162791906128f5565b90915550505b6000600c546002541161164257600c54611646565b6002545b9050600d600001600b548154811061166057611660612908565b906000526020600020015481118061169a5750600d600201600b548154811061168b5761168b612908565b90600052602060002001544210155b1561171357600d600201600b54815481106116b7576116b7612908565b906000526020600020015442106116fa5786600d600001600b54815481106116e1576116e1612908565b90600052602060002001546116f691906128f5565b600c555b6001600b600082825461170d91906128f5565b90915550505b600854611720908361291e565b336000908152601560205260408120805490919061173f9084906128f5565b92505081905550836004600082825461175891906128f5565b90915550506013546000906001600160a01b031663dd62ed3e336040516001600160e01b031960e084901b1681526001600160a01b039091166004820152306024820152604401602060405180830381865afa1580156117bc573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117e09190612a3d565b905060006117f364e8d4a510008761296a565b90508181111561183c5760405162461bcd60e51b81526020600482015260146024820152734e6f7420656e6f75676820616c6c6f77616e636560601b60448201526064016107c0565b6013546000906001600160a01b0316336000546001600160a01b03166040516001600160a01b039283166024820152911660448201526064810184905260840160408051601f198184030181529181526020820180516001600160e01b03166323b872dd60e01b179052516118b19190612a56565b6000604051808303816000865af19150503d80600081146118ee576040519150601f19603f3d011682016040523d82523d6000602084013e6118f3565b606091505b505090508061193b5760405162461bcd60e51b8152602060048201526014602482015273151bdad95b881c185e5b595b9d0819985a5b195960621b60448201526064016107c0565b60135460408051888152602081018890528082018a9052606081018a905242608082015290516001600160a01b03909216918c9133917fb3d2a2da49a1402d79cbdc48802ed94f04bd61691ea829292e3c195296972da89181900360a00190a45060019998505050505050505050565b6000806000600c546000146119c257600c546119c6565b6002545b9050600954841115611a1a5760405162461bcd60e51b815260206004820181905260248201527f416d6f756e742065786365656473206d617820746f6b656e7320746f2062757960448201526064016107c0565b600d600001600b5481548110611a3257611a32612908565b90600052602060002001548185611a4991906128f5565b1180611a775750600d600201600b5481548110611a6857611a68612908565b90600052602060002001544210155b15611c7457600d54611a8b90600190612957565b600b5410611ac75760405162461bcd60e51b8152602060048201526009602482015268139bdd081d985b1a5960ba1b60448201526064016107c0565b600d600201600b5481548110611adf57611adf612908565b90600052602060002001544210611bc057600b54600d90611b019060016128f5565b81548110611b1157611b11612908565b906000526020600020015484600d600060038110611b3157611b31612908565b01600b5481548110611b4557611b45612908565b9060005260206000200154611b5a91906128f5565b1115611b825760405162461bcd60e51b815260206004820152600060248201526044016107c0565b600b54600e90611b939060016128f5565b81548110611ba357611ba3612908565b906000526020600020015484611bb9919061291e565b9150611ca5565b600081600d8201600b5481548110611bda57611bda612908565b9060005260206000200154611bef9190612957565b600b54909150600e90611c039060016128f5565b81548110611c1357611c13612908565b90600052602060002001548186611c2a9190612957565b611c34919061291e565b600d600101600b5481548110611c4c57611c4c612908565b906000526020600020015482611c62919061291e565b611c6c91906128f5565b925050611ca5565b600d600101600b5481548110611c8c57611c8c612908565b906000526020600020015484611ca2919061291e565b91505b5092915050565b6000611cb661208f565b60065484118015611cc657504284115b611d125760405162461bcd60e51b815260206004820152601860248201527f496e76616c696420636c61696d2073746172742074696d65000000000000000060448201526064016107c0565b600854600354611d22919061291e565b831015611d695760405162461bcd60e51b8152602060048201526015602482015274151bdad95b9cc81b195cdcc81d1a185b881cdbdb19605a1b60448201526064016107c0565b6001600160a01b038216611db45760405162461bcd60e51b81526020600482015260126024820152715a65726f20746f6b656e206164647265737360701b60448201526064016107c0565b60075415611df85760405162461bcd60e51b815260206004820152601160248201527010db185a5b48185b1c9958591e481cd95d607a1b60448201526064016107c0565b6007849055601280546001600160a01b0319166001600160a01b0384169081179091556000906323b872dd336040516001600160e01b031960e084901b1681526001600160a01b039091166004820152306024820152604481018790526064016020604051808303816000875af1158015611e77573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e9b9190612935565b905080611ee25760405162461bcd60e51b8152602060048201526015602482015274151bdad95b881d1c985b9cd9995c8819985a5b1959605a1b60448201526064016107c0565b601254604080518681524260208201526001600160a01b03909216917fdc9670dbabdd488b372eb16ebe49a39b3124a12cdffdcefbc89834a408bf8ff8910160405180910390a2506001949350505050565b611f3c61208f565b61087b600d8260036123e3565b6010826002811061147a57600080fd5b611f6161208f565b601380546001600160a01b0319166001600160a01b0392909216919091179055565b611f8b61208f565b600a55565b611f9861208f565b601480546001600160a01b0319166001600160a01b0392909216919091179055565b611fc261208f565b600b8054906000611fd283612a85565b90915550600d9050600001600b5481548110611ff057611ff0612908565b600091825260209091200154600c55565b61200961208f565b6001600160a01b03811661206e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107c0565b6120778161218b565b50565b61208261208f565b61087b6010826002612433565b6000546001600160a01b03163314610b5b5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016107c0565b6120f1612352565b6000805460ff60a01b191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa335b6040516001600160a01b03909116815260200160405180910390a1565b600054600160a01b900460ff1615610b5b5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b60448201526064016107c0565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60026001540361222d5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016107c0565b6002600155565b804710156122725760405162461bcd60e51b815260206004820152600b60248201526a4c6f772062616c616e636560a81b60448201526064016107c0565b6000826001600160a01b03168260405160006040518083038185875af1925050503d80600081146122bf576040519150601f19603f3d011682016040523d82523d6000602084013e6122c4565b606091505b505090508061230a5760405162461bcd60e51b81526020600482015260126024820152711155120814185e5b595b9d0819985a5b195960721b60448201526064016107c0565b505050565b61231761213e565b6000805460ff60a01b1916600160a01b1790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2586121213390565b600054600160a01b900460ff16610b5b5760405162461bcd60e51b815260206004820152601460248201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b60448201526064016107c0565b60405180604001604052806002905b60608152602001906001900390816123b15790505090565b6040805160608082019092529081526002602082016123b1565b8260038101928215612423579160200282015b828111156124235782518051612413918491602090910190612473565b50916020019190600101906123f6565b5061242f9291506124ba565b5090565b8260028101928215612423579160200282015b828111156124235782518051612463918491602090910190612473565b5091602001919060010190612446565b8280548282559060005260206000209081019282156124ae579160200282015b828111156124ae578251825591602001919060010190612493565b5061242f9291506124d7565b8082111561242f5760006124ce82826124ec565b506001016124ba565b5b8082111561242f57600081556001016124d8565b508054600082559060005260206000209081019061207791906124d7565b80356001600160a01b03811681146109b157600080fd5b60006020828403121561253357600080fd5b61253c8261250a565b9392505050565b6000806040838503121561255657600080fd5b50508035926020909101359150565b60006020828403121561257757600080fd5b5035919050565b6000806040838503121561259157600080fd5b61259a8361250a565b946020939093013593505050565b6020808252600090606083018382018584805b600281101561261057878503601f19018452825180518087529087019087870190845b818110156125fa578351835292890192918901916001016125de565b50909650505092850192918501916001016125bb565b5092979650505050505050565b6020808252600090608083018382018584805b600381101561261057878503601f19018452825180518087529087019087870190845b8181101561266f57835183529289019291890191600101612653565b5090965050509285019291850191600101612630565b60008060006060848603121561269a57600080fd5b83359250602084013591506126b16040850161250a565b90509250925092565b634e487b7160e01b600052604160045260246000fd5b6040516060810167ffffffffffffffff811182821017156126f3576126f36126ba565b60405290565b6040805190810167ffffffffffffffff811182821017156126f3576126f36126ba565b600082601f83011261272d57600080fd5b8135602067ffffffffffffffff8083111561274a5761274a6126ba565b8260051b604051601f19603f8301168101818110848211171561276f5761276f6126ba565b60405293845285810183019383810192508785111561278d57600080fd5b83870191505b848210156127ac57813583529183019190830190612793565b979650505050505050565b600060208083850312156127ca57600080fd5b823567ffffffffffffffff808211156127e257600080fd5b818501915085601f8301126127f657600080fd5b6127fe6126d0565b80606084018881111561281057600080fd5b845b818110156128445780358581111561282a5760008081fd5b6128368b82890161271c565b855250928601928601612812565b509098975050505050505050565b6000602080838503121561286557600080fd5b823567ffffffffffffffff8082111561287d57600080fd5b818501915085601f83011261289157600080fd5b6128996126f9565b8060408401888111156128ab57600080fd5b845b81811015612844578035858111156128c55760008081fd5b6128d18b82890161271c565b8552509286019286016128ad565b634e487b7160e01b600052601160045260246000fd5b80820180821115610f6257610f626128df565b634e487b7160e01b600052603260045260246000fd5b8082028115828204841417610f6257610f626128df565b60006020828403121561294757600080fd5b8151801515811461253c57600080fd5b81810381811115610f6257610f626128df565b60008261298757634e487b7160e01b600052601260045260246000fd5b500490565b60008161299b5761299b6128df565b506000190190565b805169ffffffffffffffffffff811681146109b157600080fd5b600080600080600060a086880312156129d557600080fd5b6129de866129a3565b9450602086015193506040860151925060608601519150612a01608087016129a3565b90509295509295909350565b80820260008212600160ff1b84141615612a2957612a296128df565b8181058314821517610f6257610f626128df565b600060208284031215612a4f57600080fd5b5051919050565b6000825160005b81811015612a775760208186018101518583015201612a5d565b506000920191825250919050565b600060018201612a9757612a976128df565b506001019056fea26469706673582212207d07077bd98c8a973c7424cca144c0a4951c6b8dd28953b6ff836c729337d78c64736f6c63430008120033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
000000000000000000000000000000000000000000000000000000006417def000000000000000000000000000000000000000000000000000000000655aa18000000000000000000000000000000000000000000000000000000000000000600000000000000000000000000000000000000000000000000000000000000060000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001a00000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000037e11d6000000000000000000000000000000000000000000000000000000000649534e000000000000000000000000000000000000000000000000000000000826299e0000000000000000000000000000000000000000000000000000000009502f900000000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000001c6bf5263400000000000000000000000000000000000000000000000000000027ca57357c000000000000000000000000000000000000000000000000000000360051c8960000000000000000000000000000000000000000000000000000003e871b540c00000000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000064680d800000000000000000000000000000000000000000000000000000000064b8790000000000000000000000000000000000000000000000000000000000650a360000000000000000000000000000000000000000000000000000000000655aa180
-----Decoded View---------------
Arg [0] : _startTime (uint256): 1679286000
Arg [1] : _endTime (uint256): 1700438400
Arg [2] : _stages (uint256[][3]): System.Collections.Generic.List`1[System.Numerics.BigInteger],System.Collections.Generic.List`1[System.Numerics.BigInteger],System.Collections.Generic.List`1[System.Numerics.BigInteger]
-----Encoded View---------------
21 Constructor Arguments found :
Arg [0] : 000000000000000000000000000000000000000000000000000000006417def0
Arg [1] : 00000000000000000000000000000000000000000000000000000000655aa180
Arg [2] : 0000000000000000000000000000000000000000000000000000000000000060
Arg [3] : 0000000000000000000000000000000000000000000000000000000000000060
Arg [4] : 0000000000000000000000000000000000000000000000000000000000000100
Arg [5] : 00000000000000000000000000000000000000000000000000000000000001a0
Arg [6] : 0000000000000000000000000000000000000000000000000000000000000004
Arg [7] : 000000000000000000000000000000000000000000000000000000037e11d600
Arg [8] : 0000000000000000000000000000000000000000000000000000000649534e00
Arg [9] : 0000000000000000000000000000000000000000000000000000000826299e00
Arg [10] : 00000000000000000000000000000000000000000000000000000009502f9000
Arg [11] : 0000000000000000000000000000000000000000000000000000000000000004
Arg [12] : 0000000000000000000000000000000000000000000000000001c6bf52634000
Arg [13] : 00000000000000000000000000000000000000000000000000027ca57357c000
Arg [14] : 000000000000000000000000000000000000000000000000000360051c896000
Arg [15] : 0000000000000000000000000000000000000000000000000003e871b540c000
Arg [16] : 0000000000000000000000000000000000000000000000000000000000000004
Arg [17] : 0000000000000000000000000000000000000000000000000000000064680d80
Arg [18] : 0000000000000000000000000000000000000000000000000000000064b87900
Arg [19] : 00000000000000000000000000000000000000000000000000000000650a3600
Arg [20] : 00000000000000000000000000000000000000000000000000000000655aa180
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 26 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|---|---|---|---|---|
BSC | 100.00% | $574.09 | 0.043 | $24.69 |
[ Download: CSV Export ]
[ Download: CSV Export ]
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.