ETH Price: $2,911.26 (+3.07%)
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

Token Holdings

More Info

Private Name Tags

Multichain Info

No addresses found
Age:7D
Reset Filter

Transaction Hash
Method
Block
From
To

There are no matching entries

Please try again later

Age:7D
Reset Filter

Advanced mode:
Parent Transaction Hash Method Block
From
To

There are no matching entries

Update your filters to view other transactions

View All Internal Transactions
Loading...
Loading
Cross-Chain Transactions

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
CandyPresale

Compiler Version
v0.8.23+commit.f704f362

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license
/**
 *Submitted for verification at Etherscan.io on 2024-01-21
*/

// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

library SafeMath {
    function tryAdd(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    function trySub(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    function tryMul(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (a == 0) return (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    function tryDiv(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    function tryMod(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        return a + b;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return a - b;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return a % b;
    }

    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}

pragma solidity ^0.8.0;

interface IERC20 {
    function totalSupply() external view returns (uint256);

    function balanceOf(address account) external view returns (uint256);

    function transfer(
        address recipient,
        uint256 amount
    ) external returns (bool);

    function allowance(
        address owner,
        address spender
    ) external view returns (uint256);

    function approve(address spender, uint256 amount) external returns (bool);

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    event Transfer(address indexed from, address indexed to, uint256 value);

    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
}

pragma solidity ^0.8.0;

abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

pragma solidity ^0.8.0;

abstract contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(
        address indexed previousOwner,
        address indexed newOwner
    );

    constructor() {
        _transferOwnership(_msgSender());
    }

    function owner() public view virtual returns (address) {
        return _owner;
    }

    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(
            newOwner != address(0),
            "Ownable: new owner is the zero address"
        );
        _transferOwnership(newOwner);
    }

    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

pragma solidity ^0.8.0;

contract OwnerWithdrawable is Ownable {
    using SafeMath for uint256;
    using SafeERC20 for IERC20;

    receive() external payable {}

    fallback() external payable {}

    function withdraw(address token, uint256 amt) public onlyOwner {
        IERC20(token).safeTransfer(msg.sender, amt);
    }

    function withdrawAll(address token) public onlyOwner {
        uint256 amt = IERC20(token).balanceOf(address(this));
        withdraw(token, amt);
    }

    function withdrawCurrency(uint256 amt) public onlyOwner {
        payable(msg.sender).transfer(amt);
    }

    // function deposit(address token, uint256 amt) public onlyOwner {
    //     uint256 allowance = IERC20(token).allowance(msg.sender, address(this));
    //     require(allowance >= amt, "Check the token allowance");
    //     IERC20(token).transferFrom(owner(), address(this), amt);
    // }
}

pragma solidity ^0.8.0;

library Address {
    function isContract(address account) internal view returns (bool) {
        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

    function sendValue(address payable recipient, uint256 amount) internal {
        require(
            address(this).balance >= amount,
            "Address: insufficient balance"
        );

        (bool success, ) = recipient.call{value: amount}("");
        require(
            success,
            "Address: unable to send value, recipient may have reverted"
        );
    }

    function functionCall(
        address target,
        bytes memory data
    ) internal returns (bytes memory) {
        return functionCall(target, data, "Address: low-level call failed");
    }

    function functionCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value
    ) internal returns (bytes memory) {
        return
            functionCallWithValue(
                target,
                data,
                value,
                "Address: low-level call with value failed"
            );
    }

    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(
            address(this).balance >= value,
            "Address: insufficient balance for call"
        );
        require(isContract(target), "Address: call to non-contract");

        (bool success, bytes memory returndata) = target.call{value: value}(
            data
        );
        return verifyCallResult(success, returndata, errorMessage);
    }

    function functionStaticCall(
        address target,
        bytes memory data
    ) internal view returns (bytes memory) {
        return
            functionStaticCall(
                target,
                data,
                "Address: low-level static call failed"
            );
    }

    function functionStaticCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        (bool success, bytes memory returndata) = target.staticcall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    function functionDelegateCall(
        address target,
        bytes memory data
    ) internal returns (bytes memory) {
        return
            functionDelegateCall(
                target,
                data,
                "Address: low-level delegate call failed"
            );
    }

    function functionDelegateCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        (bool success, bytes memory returndata) = target.delegatecall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    function verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal pure returns (bytes memory) {
        if (success) {
            return returndata;
        } else {
            if (returndata.length > 0) {
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

pragma solidity ^0.8.0;

library SafeERC20 {
    using Address for address;

    function safeTransfer(IERC20 token, address to, uint256 value) internal {
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.transfer.selector, to, value)
        );
    }

    function safeTransferFrom(
        IERC20 token,
        address from,
        address to,
        uint256 value
    ) internal {
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.transferFrom.selector, from, to, value)
        );
    }

    function safeApprove(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        require(
            (value == 0) || (token.allowance(address(this), spender) == 0),
            "SafeERC20: approve from non-zero to non-zero allowance"
        );
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.approve.selector, spender, value)
        );
    }

    function safeIncreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        uint256 newAllowance = token.allowance(address(this), spender) + value;
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(
                token.approve.selector,
                spender,
                newAllowance
            )
        );
    }

    function safeDecreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        unchecked {
            uint256 oldAllowance = token.allowance(address(this), spender);
            require(
                oldAllowance >= value,
                "SafeERC20: decreased allowance below zero"
            );
            uint256 newAllowance = oldAllowance - value;
            _callOptionalReturn(
                token,
                abi.encodeWithSelector(
                    token.approve.selector,
                    spender,
                    newAllowance
                )
            );
        }
    }

    function _callOptionalReturn(IERC20 token, bytes memory data) private {
        bytes memory returndata = address(token).functionCall(
            data,
            "SafeERC20: low-level call failed"
        );
        if (returndata.length > 0) {
            require(
                abi.decode(returndata, (bool)),
                "SafeERC20: ERC20 operation did not succeed"
            );
        }
    }
}

pragma solidity ^0.8.0;

interface IERC20Metadata is IERC20 {
    function name() external view returns (string memory);

    function symbol() external view returns (string memory);

    function decimals() external view returns (uint8);
}

pragma solidity ^0.8.0;

contract CandyPresale is OwnerWithdrawable {
    using SafeMath for uint256;
    using SafeERC20 for IERC20;
    using SafeERC20 for IERC20Metadata;

    uint256 public rate;

    address public saleToken;

    uint public saleTokenDec;

    uint256 public totalTokensforSale;

    mapping(address => bool) public payableTokens;

    mapping(address => uint256) public tokenPrices;

    bool public saleStatus;

    address[] public buyers;

    mapping(address => BuyerDetails) public buyerDetails;

    uint256 public totalTokensSold;

    bool public unlockingStatus;

    uint public bonusPercent = 10; // = 0.01% in bps;

    struct BuyerDetails {
        uint amount;
        bool exists;
        uint reward;
        uint lastVestTime;
    }

    constructor() {}

    modifier saleEnabled() {
        require(saleStatus == true, "Error: is not enabled");
        _;
    }

    modifier saleStoped() {
        require(saleStatus == false, "Error: is not stopped");
        _;
    }

    modifier unlockEnabled() {
        require(
            unlockingStatus == true,
            "Error: unlocking token is not enabled"
        );
        _;
    }

    modifier unlockStoped() {
        require(
            unlockingStatus == false,
            "Error: unlocking token is not stopped"
        );
        _;
    }

    function setBonusPercent(uint _bonusPercent) external onlyOwner {
        bonusPercent = _bonusPercent;
    }

    function setSaleParams(
        address _saleToken,
        uint256 _totalTokensforSale,
        uint256 _rate,
        bool _saleStatus
    ) external onlyOwner {
        require(_rate != 0);
        rate = _rate;
        saleToken = _saleToken;
        saleStatus = _saleStatus;
        saleTokenDec = IERC20Metadata(saleToken).decimals();
        totalTokensforSale = _totalTokensforSale;
        IERC20(saleToken).safeTransferFrom(
            msg.sender,
            address(this),
            totalTokensforSale
        );
    }

    function stopSale() external onlyOwner saleEnabled {
        saleStatus = false;
    }

    function resumeSale() external onlyOwner saleStoped {
        saleStatus = true;
        unlockingStatus = false;
    }

    function startUnlocking() external onlyOwner {
        saleStatus = false;
        unlockingStatus = true;
    }

    function stopUnlocking() external onlyOwner unlockEnabled {
        unlockingStatus = false;
    }

    function addPayableTokens(
        address[] memory _tokens,
        uint256[] memory _prices
    ) external onlyOwner {
        require(
            _tokens.length == _prices.length,
            "Error: tokens & prices arrays length mismatch"
        );

        for (uint256 i = 0; i < _tokens.length; i++) {
            require(_prices[i] != 0);
            payableTokens[_tokens[i]] = true;
            tokenPrices[_tokens[i]] = _prices[i];
        }
    }

    function payableTokenStatus(
        address _token,
        bool _status
    ) external onlyOwner {
        require(payableTokens[_token] != _status);

        payableTokens[_token] = _status;
    }

    function updateCandyRate(
        address[] memory _tokens,
        uint256[] memory _prices,
        uint256 _rate
    ) external onlyOwner {
        require(
            _tokens.length == _prices.length,
            "Error: tokens & prices arrays length mismatch"
        );

        if (_rate != 0) {
            rate = _rate;
        }

        for (uint256 i = 0; i < _tokens.length; i += 1) {
            require(payableTokens[_tokens[i]] == true);
            require(_prices[i] != 0);
            tokenPrices[_tokens[i]] = _prices[i];
        }
    }

    function getTokenAmount(
        address token,
        uint256 amount
    ) public view returns (uint256) {
        uint256 amtOut;
        if (token != address(0)) {
            require(payableTokens[token] == true);
            uint256 price = tokenPrices[token];
            amtOut = amount.mul(10 ** saleTokenDec).div(price);
        } else {
            amtOut = amount.mul(10 ** saleTokenDec).div(rate);
        }
        return amtOut;
    }

    function transferETH() private {
        payable(owner()).transfer(msg.value);
    }

    function transferToken(address _token, uint256 _amount) private {
        IERC20(_token).safeTransferFrom(msg.sender, owner(), _amount);
    }

    function calculateReward(
        uint _amount,
        uint _lastVestTime
    ) public view returns (uint256) {
        uint256 daysPassed = block.timestamp.sub(_lastVestTime).div(1 days);

        return _amount.mul(bonusPercent).mul(daysPassed).div(10000);
    }

    function buyCandy(
        address _token,
        uint256 _amount
    ) external payable saleEnabled {
        uint256 saleTokenAmt;
        if (_token != address(0)) {
            require(_amount > 0);
            require(payableTokens[_token] == true, "Error: Token not allowed");

            saleTokenAmt = getTokenAmount(_token, _amount);
            require(
                (totalTokensSold + saleTokenAmt) < totalTokensforSale,
                "Error: Not enough tokens to be sale"
            );
            transferToken(_token, _amount);
        } else {
            saleTokenAmt = getTokenAmount(address(0), msg.value);
            require((totalTokensSold + saleTokenAmt) < totalTokensforSale);
            transferETH();
        }
        totalTokensSold += saleTokenAmt;
        if (!buyerDetails[msg.sender].exists) {
            buyers.push(msg.sender);
            buyerDetails[msg.sender].exists = true;
        }

        if (buyerDetails[msg.sender].amount > 0) {
            buyerDetails[msg.sender].reward += calculateReward(
                buyerDetails[msg.sender].amount,
                buyerDetails[msg.sender].lastVestTime
            );
        }

        buyerDetails[msg.sender].amount += saleTokenAmt;
        buyerDetails[msg.sender].lastVestTime = block.timestamp;
    }

    function getUnlockAmountWithBonus(
        address _user
    ) public view returns (uint256) {
        BuyerDetails storage buyer = buyerDetails[_user];
        return
            buyer.amount +
            buyer.reward +
            calculateReward(buyer.amount, buyer.lastVestTime);
    }

    function unwrappedCandy() external unlockEnabled {
        BuyerDetails storage buyer = buyerDetails[msg.sender];
        require(buyer.amount > 0, "Error: You don't have tokens to claim");

        uint256 amountWithBonus = getUnlockAmountWithBonus(msg.sender);

        IERC20(saleToken).safeTransfer(msg.sender, amountWithBonus);

        buyerDetails[msg.sender].amount = 0;
        buyerDetails[msg.sender].reward = 0;
    }
}

Contract Security Audit

Contract ABI

API
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"stateMutability":"payable","type":"fallback"},{"inputs":[{"internalType":"address[]","name":"_tokens","type":"address[]"},{"internalType":"uint256[]","name":"_prices","type":"uint256[]"}],"name":"addPayableTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"bonusPercent","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"buyCandy","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"buyerDetails","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"bool","name":"exists","type":"bool"},{"internalType":"uint256","name":"reward","type":"uint256"},{"internalType":"uint256","name":"lastVestTime","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"buyers","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"uint256","name":"_lastVestTime","type":"uint256"}],"name":"calculateReward","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"getTokenAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_user","type":"address"}],"name":"getUnlockAmountWithBonus","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"},{"internalType":"bool","name":"_status","type":"bool"}],"name":"payableTokenStatus","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"payableTokens","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rate","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"resumeSale","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"saleStatus","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"saleToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"saleTokenDec","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_bonusPercent","type":"uint256"}],"name":"setBonusPercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_saleToken","type":"address"},{"internalType":"uint256","name":"_totalTokensforSale","type":"uint256"},{"internalType":"uint256","name":"_rate","type":"uint256"},{"internalType":"bool","name":"_saleStatus","type":"bool"}],"name":"setSaleParams","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startUnlocking","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"stopSale","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"stopUnlocking","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"tokenPrices","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":"totalTokensforSale","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":"unlockingStatus","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"unwrappedCandy","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"_tokens","type":"address[]"},{"internalType":"uint256[]","name":"_prices","type":"uint256[]"},{"internalType":"uint256","name":"_rate","type":"uint256"}],"name":"updateCandyRate","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"amt","type":"uint256"}],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"withdrawAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amt","type":"uint256"}],"name":"withdrawCurrency","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

6080604052600a600c55348015610014575f80fd5b5061001e33610023565b610072565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b611bc68061007f5f395ff3fe6080604052600436106101cd575f3560e01c80636bcedf9c116100f5578063e20570371161008e578063f2fde38b11610060578063f2fde38b14610548578063f3fef3a314610567578063f9020e3314610586578063fa09e6301461059f57005b8063e2057037146104d7578063e36b0b37146104f6578063e985e3671461050a578063f2aa82181461052957005b80638f6dd6c4116100c75780638f6dd6c414610480578063ace1741c14610499578063b5b0763c146104ae578063becf3add146104c257005b80636bcedf9c146103e9578063715018a6146103fe57806380655eef146104125780638da5cb5b1461045057005b806333e364cb116101675780635413c1c8116101395780635413c1c8146103775780635b6e17ce1461039657806362bd689c146103b557806363b20117146103d457005b806333e364cb146102cc5780633b43937c146102e05780633c00a36c146102f45780634fe85e0c1461031357005b8063204120bc116101a0578063204120bc1461025957806329d429a8146102845780632a95c24c146102a35780632c4e722e146102b757005b8062820eba146101d6578063107c81cb146101e9578063115ece4c1461021b57806313ed08461461023a57005b366101d457005b005b6101d46101e436600461159b565b6105be565b3480156101f4575f80fd5b506102086102033660046115c3565b61086f565b6040519081526020015b60405180910390f35b348015610226575f80fd5b5061020861023536600461159b565b6108b9565b348015610245575f80fd5b506102086102543660046115dc565b610962565b348015610264575f80fd5b506102086102733660046115c3565b60066020525f908152604090205481565b34801561028f575f80fd5b506101d461029e366004611609565b6109a4565b3480156102ae575f80fd5b506101d4610a22565b3480156102c2575f80fd5b5061020860015481565b3480156102d7575f80fd5b506101d4610a66565b3480156102eb575f80fd5b506101d4610af5565b3480156102ff575f80fd5b506101d461030e36600461163e565b610bc3565b34801561031e575f80fd5b5061035761032d3660046115c3565b60096020525f90815260409020805460018201546002830154600390930154919260ff9091169184565b604080519485529215156020850152918301526060820152608001610212565b348015610382575f80fd5b506101d461039136600461178c565b610c1a565b3480156103a1575f80fd5b506101d46103b03660046117ec565b610d46565b3480156103c0575f80fd5b506101d46103cf36600461163e565b610e7d565b3480156103df575f80fd5b50610208600a5481565b3480156103f4575f80fd5b5061020860045481565b348015610409575f80fd5b506101d4610eab565b34801561041d575f80fd5b5061044061042c3660046115c3565b60056020525f908152604090205460ff1681565b6040519015158152602001610212565b34801561045b575f80fd5b505f546001600160a01b03165b6040516001600160a01b039091168152602001610212565b34801561048b575f80fd5b50600b546104409060ff1681565b3480156104a4575f80fd5b5061020860035481565b3480156104b9575f80fd5b506101d4610edf565b3480156104cd575f80fd5b50610208600c5481565b3480156104e2575f80fd5b506101d46104f1366004611854565b610f3b565b348015610501575f80fd5b506101d4611020565b348015610515575f80fd5b50600254610468906001600160a01b031681565b348015610534575f80fd5b5061046861054336600461163e565b6110a4565b348015610553575f80fd5b506101d46105623660046115c3565b6110cc565b348015610572575f80fd5b506101d461058136600461159b565b611166565b348015610591575f80fd5b506007546104409060ff1681565b3480156105aa575f80fd5b506101d46105b93660046115c3565b6111a3565b60075460ff1615156001146106125760405162461bcd60e51b8152602060048201526015602482015274115c9c9bdc8e881a5cc81b9bdd08195b98589b1959605a1b60448201526064015b60405180910390fd5b5f6001600160a01b0383161561071e575f821161062d575f80fd5b6001600160a01b0383165f9081526005602052604090205460ff1615156001146106995760405162461bcd60e51b815260206004820152601860248201527f4572726f723a20546f6b656e206e6f7420616c6c6f77656400000000000000006044820152606401610609565b6106a383836108b9565b905060045481600a546106b691906118ad565b1061070f5760405162461bcd60e51b815260206004820152602360248201527f4572726f723a204e6f7420656e6f75676820746f6b656e7320746f2062652073604482015262616c6560e81b6064820152608401610609565b6107198383611240565b61074c565b6107285f346108b9565b905060045481600a5461073b91906118ad565b10610744575f80fd5b61074c611267565b80600a5f82825461075d91906118ad565b9091555050335f9081526009602052604090206001015460ff166107d7576008805460018181019092557ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee30180546001600160a01b031916339081179091555f9081526009602052604090208101805460ff191690911790555b335f908152600960205260409020541561083257335f908152600960205260409020805460039091015461080b9190610962565b335f908152600960205260408120600201805490919061082c9084906118ad565b90915550505b335f90815260096020526040812080548392906108509084906118ad565b9091555050335f90815260096020526040902042600390910155505050565b6001600160a01b0381165f908152600960205260408120805460038201546108979190610962565b600282015482546108a891906118ad565b6108b291906118ad565b9392505050565b5f806001600160a01b03841615610937576001600160a01b0384165f9081526005602052604090205460ff1615156001146108f2575f80fd5b6001600160a01b0384165f9081526006602052604090205460035461092f9082906109299061092290600a6119a0565b879061129e565b906112a9565b915050610959565b610956600154610929600354600a61094f91906119a0565b869061129e565b90505b90505b92915050565b5f806109756201518061092942866112b4565b905061099c61271061092983610996600c548961129e90919063ffffffff16565b9061129e565b949350505050565b5f546001600160a01b031633146109cd5760405162461bcd60e51b8152600401610609906119ab565b6001600160a01b0382165f9081526005602052604090205481151560ff9091161515036109f8575f80fd5b6001600160a01b03919091165f908152600560205260409020805460ff1916911515919091179055565b5f546001600160a01b03163314610a4b5760405162461bcd60e51b8152600401610609906119ab565b6007805460ff19908116909155600b80549091166001179055565b5f546001600160a01b03163314610a8f5760405162461bcd60e51b8152600401610609906119ab565b60075460ff1615610ada5760405162461bcd60e51b8152602060048201526015602482015274115c9c9bdc8e881a5cc81b9bdd081cdd1bdc1c1959605a1b6044820152606401610609565b6007805460ff19908116600117909155600b80549091169055565b600b5460ff161515600114610b1c5760405162461bcd60e51b8152600401610609906119e0565b335f9081526009602052604090208054610b865760405162461bcd60e51b815260206004820152602560248201527f4572726f723a20596f7520646f6e2774206861766520746f6b656e7320746f20604482015264636c61696d60d81b6064820152608401610609565b5f610b903361086f565b600254909150610baa906001600160a01b031633836112bf565b5050335f90815260096020526040812081815560020155565b5f546001600160a01b03163314610bec5760405162461bcd60e51b8152600401610609906119ab565b604051339082156108fc029083905f818181858888f19350505050158015610c16573d5f803e3d5ffd5b5050565b5f546001600160a01b03163314610c435760405162461bcd60e51b8152600401610609906119ab565b8051825114610c645760405162461bcd60e51b815260040161060990611a25565b5f5b8251811015610d4157818181518110610c8157610c81611a72565b60200260200101515f03610c93575f80fd5b600160055f858481518110610caa57610caa611a72565b60200260200101516001600160a01b03166001600160a01b031681526020019081526020015f205f6101000a81548160ff021916908315150217905550818181518110610cf957610cf9611a72565b602002602001015160065f858481518110610d1657610d16611a72565b6020908102919091018101516001600160a01b031682528101919091526040015f2055600101610c66565b505050565b5f546001600160a01b03163314610d6f5760405162461bcd60e51b8152600401610609906119ab565b8151835114610d905760405162461bcd60e51b815260040161060990611a25565b8015610d9c5760018190555b5f5b8351811015610e775760055f858381518110610dbc57610dbc611a72565b6020908102919091018101516001600160a01b031682528101919091526040015f205460ff161515600114610def575f80fd5b828181518110610e0157610e01611a72565b60200260200101515f03610e13575f80fd5b828181518110610e2557610e25611a72565b602002602001015160065f868481518110610e4257610e42611a72565b6020908102919091018101516001600160a01b031682528101919091526040015f2055610e706001826118ad565b9050610d9e565b50505050565b5f546001600160a01b03163314610ea65760405162461bcd60e51b8152600401610609906119ab565b600c55565b5f546001600160a01b03163314610ed45760405162461bcd60e51b8152600401610609906119ab565b610edd5f611322565b565b5f546001600160a01b03163314610f085760405162461bcd60e51b8152600401610609906119ab565b600b5460ff161515600114610f2f5760405162461bcd60e51b8152600401610609906119e0565b600b805460ff19169055565b5f546001600160a01b03163314610f645760405162461bcd60e51b8152600401610609906119ab565b815f03610f6f575f80fd5b6001829055600280546001600160a01b0319166001600160a01b0386169081179091556007805460ff19168315151790556040805163313ce56760e01b8152905163313ce567916004808201926020929091908290030181865afa158015610fd9573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ffd9190611a86565b60ff166003556004839055600254610e77906001600160a01b0316333086611371565b5f546001600160a01b031633146110495760405162461bcd60e51b8152600401610609906119ab565b60075460ff1615156001146110985760405162461bcd60e51b8152602060048201526015602482015274115c9c9bdc8e881a5cc81b9bdd08195b98589b1959605a1b6044820152606401610609565b6007805460ff19169055565b600881815481106110b3575f80fd5b5f918252602090912001546001600160a01b0316905081565b5f546001600160a01b031633146110f55760405162461bcd60e51b8152600401610609906119ab565b6001600160a01b03811661115a5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610609565b61116381611322565b50565b5f546001600160a01b0316331461118f5760405162461bcd60e51b8152600401610609906119ab565b610c166001600160a01b03831633836112bf565b5f546001600160a01b031633146111cc5760405162461bcd60e51b8152600401610609906119ab565b6040516370a0823160e01b81523060048201525f906001600160a01b038316906370a0823190602401602060405180830381865afa158015611210573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906112349190611aa6565b9050610c168282611166565b610c16336112555f546001600160a01b031690565b6001600160a01b038516919084611371565b5f80546040516001600160a01b03909116913480156108fc02929091818181858888f19350505050158015611163573d5f803e3d5ffd5b5f6109598284611abd565b5f6109598284611ad4565b5f6109598284611af3565b6040516001600160a01b038316602482015260448101829052610d4190849063a9059cbb60e01b906064015b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b0319909316929092179091526113a9565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6040516001600160a01b0380851660248301528316604482015260648101829052610e779085906323b872dd60e01b906084016112eb565b5f6113fd826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661147a9092919063ffffffff16565b805190915015610d41578080602001905181019061141b9190611b06565b610d415760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610609565b606061099c84845f8585843b6114d25760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610609565b5f80866001600160a01b031685876040516114ed9190611b43565b5f6040518083038185875af1925050503d805f8114611527576040519150601f19603f3d011682016040523d82523d5f602084013e61152c565b606091505b509150915061153c828286611547565b979650505050505050565b606083156115565750816108b2565b8251156115665782518084602001fd5b8160405162461bcd60e51b81526004016106099190611b5e565b80356001600160a01b0381168114611596575f80fd5b919050565b5f80604083850312156115ac575f80fd5b6115b583611580565b946020939093013593505050565b5f602082840312156115d3575f80fd5b61095982611580565b5f80604083850312156115ed575f80fd5b50508035926020909101359150565b8015158114611163575f80fd5b5f806040838503121561161a575f80fd5b61162383611580565b91506020830135611633816115fc565b809150509250929050565b5f6020828403121561164e575f80fd5b5035919050565b634e487b7160e01b5f52604160045260245ffd5b604051601f8201601f1916810167ffffffffffffffff8111828210171561169257611692611655565b604052919050565b5f67ffffffffffffffff8211156116b3576116b3611655565b5060051b60200190565b5f82601f8301126116cc575f80fd5b813560206116e16116dc8361169a565b611669565b8083825260208201915060208460051b870101935086841115611702575f80fd5b602086015b848110156117255761171881611580565b8352918301918301611707565b509695505050505050565b5f82601f83011261173f575f80fd5b8135602061174f6116dc8361169a565b8083825260208201915060208460051b870101935086841115611770575f80fd5b602086015b848110156117255780358352918301918301611775565b5f806040838503121561179d575f80fd5b823567ffffffffffffffff808211156117b4575f80fd5b6117c0868387016116bd565b935060208501359150808211156117d5575f80fd5b506117e285828601611730565b9150509250929050565b5f805f606084860312156117fe575f80fd5b833567ffffffffffffffff80821115611815575f80fd5b611821878388016116bd565b94506020860135915080821115611836575f80fd5b5061184386828701611730565b925050604084013590509250925092565b5f805f8060808587031215611867575f80fd5b61187085611580565b93506020850135925060408501359150606085013561188e816115fc565b939692955090935050565b634e487b7160e01b5f52601160045260245ffd5b8082018082111561095c5761095c611899565b600181815b808511156118fa57815f19048211156118e0576118e0611899565b808516156118ed57918102915b93841c93908002906118c5565b509250929050565b5f826119105750600161095c565b8161191c57505f61095c565b8160018114611932576002811461193c57611958565b600191505061095c565b60ff84111561194d5761194d611899565b50506001821b61095c565b5060208310610133831016604e8410600b841016171561197b575081810a61095c565b61198583836118c0565b805f190482111561199857611998611899565b029392505050565b5f6109598383611902565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526025908201527f4572726f723a20756e6c6f636b696e6720746f6b656e206973206e6f7420656e60408201526418589b195960da1b606082015260800190565b6020808252602d908201527f4572726f723a20746f6b656e7320262070726963657320617272617973206c6560408201526c0dccee8d040dad2e6dac2e8c6d609b1b606082015260800190565b634e487b7160e01b5f52603260045260245ffd5b5f60208284031215611a96575f80fd5b815160ff81168114610959575f80fd5b5f60208284031215611ab6575f80fd5b5051919050565b808202811582820484141761095c5761095c611899565b5f82611aee57634e487b7160e01b5f52601260045260245ffd5b500490565b8181038181111561095c5761095c611899565b5f60208284031215611b16575f80fd5b8151610959816115fc565b5f5b83811015611b3b578181015183820152602001611b23565b50505f910152565b5f8251611b54818460208701611b21565b9190910192915050565b602081525f8251806020840152611b7c816040850160208701611b21565b601f01601f1916919091016040019291505056fea26469706673582212203844fe45722ffa424e2b8921dea65ddffa81f49f8741ddbb33a5bdafad63352f64736f6c63430008170033

Deployed Bytecode

0x6080604052600436106101cd575f3560e01c80636bcedf9c116100f5578063e20570371161008e578063f2fde38b11610060578063f2fde38b14610548578063f3fef3a314610567578063f9020e3314610586578063fa09e6301461059f57005b8063e2057037146104d7578063e36b0b37146104f6578063e985e3671461050a578063f2aa82181461052957005b80638f6dd6c4116100c75780638f6dd6c414610480578063ace1741c14610499578063b5b0763c146104ae578063becf3add146104c257005b80636bcedf9c146103e9578063715018a6146103fe57806380655eef146104125780638da5cb5b1461045057005b806333e364cb116101675780635413c1c8116101395780635413c1c8146103775780635b6e17ce1461039657806362bd689c146103b557806363b20117146103d457005b806333e364cb146102cc5780633b43937c146102e05780633c00a36c146102f45780634fe85e0c1461031357005b8063204120bc116101a0578063204120bc1461025957806329d429a8146102845780632a95c24c146102a35780632c4e722e146102b757005b8062820eba146101d6578063107c81cb146101e9578063115ece4c1461021b57806313ed08461461023a57005b366101d457005b005b6101d46101e436600461159b565b6105be565b3480156101f4575f80fd5b506102086102033660046115c3565b61086f565b6040519081526020015b60405180910390f35b348015610226575f80fd5b5061020861023536600461159b565b6108b9565b348015610245575f80fd5b506102086102543660046115dc565b610962565b348015610264575f80fd5b506102086102733660046115c3565b60066020525f908152604090205481565b34801561028f575f80fd5b506101d461029e366004611609565b6109a4565b3480156102ae575f80fd5b506101d4610a22565b3480156102c2575f80fd5b5061020860015481565b3480156102d7575f80fd5b506101d4610a66565b3480156102eb575f80fd5b506101d4610af5565b3480156102ff575f80fd5b506101d461030e36600461163e565b610bc3565b34801561031e575f80fd5b5061035761032d3660046115c3565b60096020525f90815260409020805460018201546002830154600390930154919260ff9091169184565b604080519485529215156020850152918301526060820152608001610212565b348015610382575f80fd5b506101d461039136600461178c565b610c1a565b3480156103a1575f80fd5b506101d46103b03660046117ec565b610d46565b3480156103c0575f80fd5b506101d46103cf36600461163e565b610e7d565b3480156103df575f80fd5b50610208600a5481565b3480156103f4575f80fd5b5061020860045481565b348015610409575f80fd5b506101d4610eab565b34801561041d575f80fd5b5061044061042c3660046115c3565b60056020525f908152604090205460ff1681565b6040519015158152602001610212565b34801561045b575f80fd5b505f546001600160a01b03165b6040516001600160a01b039091168152602001610212565b34801561048b575f80fd5b50600b546104409060ff1681565b3480156104a4575f80fd5b5061020860035481565b3480156104b9575f80fd5b506101d4610edf565b3480156104cd575f80fd5b50610208600c5481565b3480156104e2575f80fd5b506101d46104f1366004611854565b610f3b565b348015610501575f80fd5b506101d4611020565b348015610515575f80fd5b50600254610468906001600160a01b031681565b348015610534575f80fd5b5061046861054336600461163e565b6110a4565b348015610553575f80fd5b506101d46105623660046115c3565b6110cc565b348015610572575f80fd5b506101d461058136600461159b565b611166565b348015610591575f80fd5b506007546104409060ff1681565b3480156105aa575f80fd5b506101d46105b93660046115c3565b6111a3565b60075460ff1615156001146106125760405162461bcd60e51b8152602060048201526015602482015274115c9c9bdc8e881a5cc81b9bdd08195b98589b1959605a1b60448201526064015b60405180910390fd5b5f6001600160a01b0383161561071e575f821161062d575f80fd5b6001600160a01b0383165f9081526005602052604090205460ff1615156001146106995760405162461bcd60e51b815260206004820152601860248201527f4572726f723a20546f6b656e206e6f7420616c6c6f77656400000000000000006044820152606401610609565b6106a383836108b9565b905060045481600a546106b691906118ad565b1061070f5760405162461bcd60e51b815260206004820152602360248201527f4572726f723a204e6f7420656e6f75676820746f6b656e7320746f2062652073604482015262616c6560e81b6064820152608401610609565b6107198383611240565b61074c565b6107285f346108b9565b905060045481600a5461073b91906118ad565b10610744575f80fd5b61074c611267565b80600a5f82825461075d91906118ad565b9091555050335f9081526009602052604090206001015460ff166107d7576008805460018181019092557ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee30180546001600160a01b031916339081179091555f9081526009602052604090208101805460ff191690911790555b335f908152600960205260409020541561083257335f908152600960205260409020805460039091015461080b9190610962565b335f908152600960205260408120600201805490919061082c9084906118ad565b90915550505b335f90815260096020526040812080548392906108509084906118ad565b9091555050335f90815260096020526040902042600390910155505050565b6001600160a01b0381165f908152600960205260408120805460038201546108979190610962565b600282015482546108a891906118ad565b6108b291906118ad565b9392505050565b5f806001600160a01b03841615610937576001600160a01b0384165f9081526005602052604090205460ff1615156001146108f2575f80fd5b6001600160a01b0384165f9081526006602052604090205460035461092f9082906109299061092290600a6119a0565b879061129e565b906112a9565b915050610959565b610956600154610929600354600a61094f91906119a0565b869061129e565b90505b90505b92915050565b5f806109756201518061092942866112b4565b905061099c61271061092983610996600c548961129e90919063ffffffff16565b9061129e565b949350505050565b5f546001600160a01b031633146109cd5760405162461bcd60e51b8152600401610609906119ab565b6001600160a01b0382165f9081526005602052604090205481151560ff9091161515036109f8575f80fd5b6001600160a01b03919091165f908152600560205260409020805460ff1916911515919091179055565b5f546001600160a01b03163314610a4b5760405162461bcd60e51b8152600401610609906119ab565b6007805460ff19908116909155600b80549091166001179055565b5f546001600160a01b03163314610a8f5760405162461bcd60e51b8152600401610609906119ab565b60075460ff1615610ada5760405162461bcd60e51b8152602060048201526015602482015274115c9c9bdc8e881a5cc81b9bdd081cdd1bdc1c1959605a1b6044820152606401610609565b6007805460ff19908116600117909155600b80549091169055565b600b5460ff161515600114610b1c5760405162461bcd60e51b8152600401610609906119e0565b335f9081526009602052604090208054610b865760405162461bcd60e51b815260206004820152602560248201527f4572726f723a20596f7520646f6e2774206861766520746f6b656e7320746f20604482015264636c61696d60d81b6064820152608401610609565b5f610b903361086f565b600254909150610baa906001600160a01b031633836112bf565b5050335f90815260096020526040812081815560020155565b5f546001600160a01b03163314610bec5760405162461bcd60e51b8152600401610609906119ab565b604051339082156108fc029083905f818181858888f19350505050158015610c16573d5f803e3d5ffd5b5050565b5f546001600160a01b03163314610c435760405162461bcd60e51b8152600401610609906119ab565b8051825114610c645760405162461bcd60e51b815260040161060990611a25565b5f5b8251811015610d4157818181518110610c8157610c81611a72565b60200260200101515f03610c93575f80fd5b600160055f858481518110610caa57610caa611a72565b60200260200101516001600160a01b03166001600160a01b031681526020019081526020015f205f6101000a81548160ff021916908315150217905550818181518110610cf957610cf9611a72565b602002602001015160065f858481518110610d1657610d16611a72565b6020908102919091018101516001600160a01b031682528101919091526040015f2055600101610c66565b505050565b5f546001600160a01b03163314610d6f5760405162461bcd60e51b8152600401610609906119ab565b8151835114610d905760405162461bcd60e51b815260040161060990611a25565b8015610d9c5760018190555b5f5b8351811015610e775760055f858381518110610dbc57610dbc611a72565b6020908102919091018101516001600160a01b031682528101919091526040015f205460ff161515600114610def575f80fd5b828181518110610e0157610e01611a72565b60200260200101515f03610e13575f80fd5b828181518110610e2557610e25611a72565b602002602001015160065f868481518110610e4257610e42611a72565b6020908102919091018101516001600160a01b031682528101919091526040015f2055610e706001826118ad565b9050610d9e565b50505050565b5f546001600160a01b03163314610ea65760405162461bcd60e51b8152600401610609906119ab565b600c55565b5f546001600160a01b03163314610ed45760405162461bcd60e51b8152600401610609906119ab565b610edd5f611322565b565b5f546001600160a01b03163314610f085760405162461bcd60e51b8152600401610609906119ab565b600b5460ff161515600114610f2f5760405162461bcd60e51b8152600401610609906119e0565b600b805460ff19169055565b5f546001600160a01b03163314610f645760405162461bcd60e51b8152600401610609906119ab565b815f03610f6f575f80fd5b6001829055600280546001600160a01b0319166001600160a01b0386169081179091556007805460ff19168315151790556040805163313ce56760e01b8152905163313ce567916004808201926020929091908290030181865afa158015610fd9573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ffd9190611a86565b60ff166003556004839055600254610e77906001600160a01b0316333086611371565b5f546001600160a01b031633146110495760405162461bcd60e51b8152600401610609906119ab565b60075460ff1615156001146110985760405162461bcd60e51b8152602060048201526015602482015274115c9c9bdc8e881a5cc81b9bdd08195b98589b1959605a1b6044820152606401610609565b6007805460ff19169055565b600881815481106110b3575f80fd5b5f918252602090912001546001600160a01b0316905081565b5f546001600160a01b031633146110f55760405162461bcd60e51b8152600401610609906119ab565b6001600160a01b03811661115a5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610609565b61116381611322565b50565b5f546001600160a01b0316331461118f5760405162461bcd60e51b8152600401610609906119ab565b610c166001600160a01b03831633836112bf565b5f546001600160a01b031633146111cc5760405162461bcd60e51b8152600401610609906119ab565b6040516370a0823160e01b81523060048201525f906001600160a01b038316906370a0823190602401602060405180830381865afa158015611210573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906112349190611aa6565b9050610c168282611166565b610c16336112555f546001600160a01b031690565b6001600160a01b038516919084611371565b5f80546040516001600160a01b03909116913480156108fc02929091818181858888f19350505050158015611163573d5f803e3d5ffd5b5f6109598284611abd565b5f6109598284611ad4565b5f6109598284611af3565b6040516001600160a01b038316602482015260448101829052610d4190849063a9059cbb60e01b906064015b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b0319909316929092179091526113a9565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6040516001600160a01b0380851660248301528316604482015260648101829052610e779085906323b872dd60e01b906084016112eb565b5f6113fd826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661147a9092919063ffffffff16565b805190915015610d41578080602001905181019061141b9190611b06565b610d415760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610609565b606061099c84845f8585843b6114d25760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610609565b5f80866001600160a01b031685876040516114ed9190611b43565b5f6040518083038185875af1925050503d805f8114611527576040519150601f19603f3d011682016040523d82523d5f602084013e61152c565b606091505b509150915061153c828286611547565b979650505050505050565b606083156115565750816108b2565b8251156115665782518084602001fd5b8160405162461bcd60e51b81526004016106099190611b5e565b80356001600160a01b0381168114611596575f80fd5b919050565b5f80604083850312156115ac575f80fd5b6115b583611580565b946020939093013593505050565b5f602082840312156115d3575f80fd5b61095982611580565b5f80604083850312156115ed575f80fd5b50508035926020909101359150565b8015158114611163575f80fd5b5f806040838503121561161a575f80fd5b61162383611580565b91506020830135611633816115fc565b809150509250929050565b5f6020828403121561164e575f80fd5b5035919050565b634e487b7160e01b5f52604160045260245ffd5b604051601f8201601f1916810167ffffffffffffffff8111828210171561169257611692611655565b604052919050565b5f67ffffffffffffffff8211156116b3576116b3611655565b5060051b60200190565b5f82601f8301126116cc575f80fd5b813560206116e16116dc8361169a565b611669565b8083825260208201915060208460051b870101935086841115611702575f80fd5b602086015b848110156117255761171881611580565b8352918301918301611707565b509695505050505050565b5f82601f83011261173f575f80fd5b8135602061174f6116dc8361169a565b8083825260208201915060208460051b870101935086841115611770575f80fd5b602086015b848110156117255780358352918301918301611775565b5f806040838503121561179d575f80fd5b823567ffffffffffffffff808211156117b4575f80fd5b6117c0868387016116bd565b935060208501359150808211156117d5575f80fd5b506117e285828601611730565b9150509250929050565b5f805f606084860312156117fe575f80fd5b833567ffffffffffffffff80821115611815575f80fd5b611821878388016116bd565b94506020860135915080821115611836575f80fd5b5061184386828701611730565b925050604084013590509250925092565b5f805f8060808587031215611867575f80fd5b61187085611580565b93506020850135925060408501359150606085013561188e816115fc565b939692955090935050565b634e487b7160e01b5f52601160045260245ffd5b8082018082111561095c5761095c611899565b600181815b808511156118fa57815f19048211156118e0576118e0611899565b808516156118ed57918102915b93841c93908002906118c5565b509250929050565b5f826119105750600161095c565b8161191c57505f61095c565b8160018114611932576002811461193c57611958565b600191505061095c565b60ff84111561194d5761194d611899565b50506001821b61095c565b5060208310610133831016604e8410600b841016171561197b575081810a61095c565b61198583836118c0565b805f190482111561199857611998611899565b029392505050565b5f6109598383611902565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526025908201527f4572726f723a20756e6c6f636b696e6720746f6b656e206973206e6f7420656e60408201526418589b195960da1b606082015260800190565b6020808252602d908201527f4572726f723a20746f6b656e7320262070726963657320617272617973206c6560408201526c0dccee8d040dad2e6dac2e8c6d609b1b606082015260800190565b634e487b7160e01b5f52603260045260245ffd5b5f60208284031215611a96575f80fd5b815160ff81168114610959575f80fd5b5f60208284031215611ab6575f80fd5b5051919050565b808202811582820484141761095c5761095c611899565b5f82611aee57634e487b7160e01b5f52601260045260245ffd5b500490565b8181038181111561095c5761095c611899565b5f60208284031215611b16575f80fd5b8151610959816115fc565b5f5b83811015611b3b578181015183820152602001611b23565b50505f910152565b5f8251611b54818460208701611b21565b9190910192915050565b602081525f8251806020840152611b7c816040850160208701611b21565b601f01601f1916919091016040019291505056fea26469706673582212203844fe45722ffa424e2b8921dea65ddffa81f49f8741ddbb33a5bdafad63352f64736f6c63430008170033

Deployed Bytecode Sourcemap

12597:6899:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17399:1341;;;;;;:::i;:::-;;:::i;18748:298::-;;;;;;;;;;-1:-1:-1;18748:298:0;;;;;:::i;:::-;;:::i;:::-;;;788:25:1;;;776:2;761:18;18748:298:0;;;;;;;;16403:462;;;;;;;;;;-1:-1:-1;16403:462:0;;;;;:::i;:::-;;:::i;17119:272::-;;;;;;;;;;-1:-1:-1;17119:272:0;;;;;:::i;:::-;;:::i;12946:46::-;;;;;;;;;;-1:-1:-1;12946:46:0;;;;;:::i;:::-;;;;;;;;;;;;;;15604:206;;;;;;;;;;-1:-1:-1;15604:206:0;;;;;:::i;:::-;;:::i;14891:115::-;;;;;;;;;;;;;:::i;12756:19::-;;;;;;;;;;;;;;;;14761:122;;;;;;;;;;;;;:::i;19054:439::-;;;;;;;;;;;;;:::i;5289:108::-;;;;;;;;;;-1:-1:-1;5289:108:0;;;;;:::i;:::-;;:::i;13064:52::-;;;;;;;;;;-1:-1:-1;13064:52:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;1930:25:1;;;1998:14;;1991:22;1986:2;1971:18;;1964:50;2030:18;;;2023:34;2088:2;2073:18;;2066:34;1917:3;1902:19;13064:52:0;1705:401:1;15122:474:0;;;;;;;;;;-1:-1:-1;15122:474:0;;;;;:::i;:::-;;:::i;15818:577::-;;;;;;;;;;-1:-1:-1;15818:577:0;;;;;:::i;:::-;;:::i;13987:111::-;;;;;;;;;;-1:-1:-1;13987:111:0;;;;;:::i;:::-;;:::i;13125:30::-;;;;;;;;;;;;;;;;12850:33;;;;;;;;;;;;;;;;4223:103;;;;;;;;;;;;;:::i;12892:45::-;;;;;;;;;;-1:-1:-1;12892:45:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;5496:14:1;;5489:22;5471:41;;5459:2;5444:18;12892:45:0;5331:187:1;4000:87:0;;;;;;;;;;-1:-1:-1;4046:7:0;4073:6;-1:-1:-1;;;;;4073:6:0;4000:87;;;-1:-1:-1;;;;;5687:32:1;;;5669:51;;5657:2;5642:18;4000:87:0;5523:203:1;13164:27:0;;;;;;;;;;-1:-1:-1;13164:27:0;;;;;;;;12817:24;;;;;;;;;;;;;;;;15014:100;;;;;;;;;;;;;:::i;13200:29::-;;;;;;;;;;;;;;;;14106:551;;;;;;;;;;-1:-1:-1;14106:551:0;;;;;:::i;:::-;;:::i;14665:88::-;;;;;;;;;;;;;:::i;12784:24::-;;;;;;;;;;-1:-1:-1;12784:24:0;;;;-1:-1:-1;;;;;12784:24:0;;;13032:23;;;;;;;;;;-1:-1:-1;13032:23:0;;;;;:::i;:::-;;:::i;4334:238::-;;;;;;;;;;-1:-1:-1;4334:238:0;;;;;:::i;:::-;;:::i;4993:125::-;;;;;;;;;;-1:-1:-1;4993:125:0;;;;;:::i;:::-;;:::i;13001:22::-;;;;;;;;;;-1:-1:-1;13001:22:0;;;;;;;;5126:155;;;;;;;;;;-1:-1:-1;5126:155:0;;;;;:::i;:::-;;:::i;17399:1341::-;13453:10;;;;:18;;:10;:18;13445:52;;;;-1:-1:-1;;;13445:52:0;;6390:2:1;13445:52:0;;;6372:21:1;6429:2;6409:18;;;6402:30;-1:-1:-1;;;6448:18:1;;;6441:51;6509:18;;13445:52:0;;;;;;;;;17515:20:::1;-1:-1:-1::0;;;;;17550:20:0;::::1;::::0;17546:617:::1;;17605:1;17595:7;:11;17587:20;;;::::0;::::1;;-1:-1:-1::0;;;;;17630:21:0;::::1;;::::0;;;:13:::1;:21;::::0;;;;;::::1;;:29;;:21:::0;:29:::1;17622:66;;;::::0;-1:-1:-1;;;17622:66:0;;6740:2:1;17622:66:0::1;::::0;::::1;6722:21:1::0;6779:2;6759:18;;;6752:30;6818:26;6798:18;;;6791:54;6862:18;;17622:66:0::1;6538:348:1::0;17622:66:0::1;17720:31;17735:6;17743:7;17720:14;:31::i;:::-;17705:46;;17827:18;;17811:12;17793:15;;:30;;;;:::i;:::-;17792:53;17766:150;;;::::0;-1:-1:-1;;;17766:150:0;;7355:2:1;17766:150:0::1;::::0;::::1;7337:21:1::0;7394:2;7374:18;;;7367:30;7433:34;7413:18;;;7406:62;-1:-1:-1;;;7484:18:1;;;7477:33;7527:19;;17766:150:0::1;7153:399:1::0;17766:150:0::1;17931:30;17945:6;17953:7;17931:13;:30::i;:::-;17546:617;;;18009:37;18032:1;18036:9;18009:14;:37::i;:::-;17994:52;;18104:18;;18088:12;18070:15;;:30;;;;:::i;:::-;18069:53;18061:62;;;::::0;::::1;;18138:13;:11;:13::i;:::-;18192:12;18173:15;;:31;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;;18233:10:0::1;18220:24;::::0;;;:12:::1;:24;::::0;;;;:31:::1;;::::0;::::1;;18215:141;;18268:6;:23:::0;;::::1;::::0;;::::1;::::0;;;;::::1;::::0;;-1:-1:-1;;;;;;18268:23:0::1;18280:10;18268:23:::0;;::::1;::::0;;;-1:-1:-1;18306:24:0;;;:12:::1;18268:23;18306:24:::0;;;;:31;::::1;:38:::0;;-1:-1:-1;;18306:38:0::1;::::0;;::::1;::::0;;18215:141:::1;18385:10;18406:1;18372:24:::0;;;:12:::1;:24;::::0;;;;:31;:35;18368:239:::1;;18506:10;18493:24;::::0;;;:12:::1;:24;::::0;;;;:31;;18543:37:::1;::::0;;::::1;::::0;18459:136:::1;::::0;18493:31;18459:15:::1;:136::i;:::-;18437:10;18424:24;::::0;;;:12:::1;:24;::::0;;;;:31:::1;;:171:::0;;:31;;:24;:171:::1;::::0;;;::::1;:::i;:::-;::::0;;;-1:-1:-1;;18368:239:0::1;18632:10;18619:24;::::0;;;:12:::1;:24;::::0;;;;:47;;18654:12;;18619:24;:47:::1;::::0;18654:12;;18619:47:::1;:::i;:::-;::::0;;;-1:-1:-1;;18690:10:0::1;18677:24;::::0;;;:12:::1;:24;::::0;;;;18717:15:::1;18677:37;::::0;;::::1;:55:::0;-1:-1:-1;;;17399:1341:0:o;18748:298::-;-1:-1:-1;;;;;18883:19:0;;18834:7;18883:19;;;:12;:19;;;;;19005:12;;19019:18;;;;18989:49;;19005:12;18989:15;:49::i;:::-;18961:12;;;;18933;;:40;;18961:12;18933:40;:::i;:::-;:105;;;;:::i;:::-;18913:125;18748:298;-1:-1:-1;;;18748:298:0:o;16403:462::-;16504:7;;-1:-1:-1;;;;;16553:19:0;;;16549:285;;-1:-1:-1;;;;;16597:20:0;;;;;;:13;:20;;;;;;;;:28;;:20;:28;16589:37;;;;;;-1:-1:-1;;;;;16657:18:0;;16641:13;16657:18;;;:11;:18;;;;;;16716:12;;16699:41;;16657:18;;16699:30;;16710:18;;:2;:18;:::i;:::-;16699:6;;:10;:30::i;:::-;:34;;:41::i;:::-;16690:50;;16574:178;16549:285;;;16782:40;16817:4;;16782:30;16799:12;;16793:2;:18;;;;:::i;:::-;16782:6;;:10;:30::i;:40::-;16773:49;;16549:285;16851:6;-1:-1:-1;16403:462:0;;;;;:::o;17119:272::-;17224:7;;17265:46;17304:6;17265:34;:15;17285:13;17265:19;:34::i;:46::-;17244:67;;17331:52;17377:5;17331:41;17361:10;17331:25;17343:12;;17331:7;:11;;:25;;;;:::i;:::-;:29;;:41::i;:52::-;17324:59;17119:272;-1:-1:-1;;;;17119:272:0:o;15604:206::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;15725:21:0;::::1;;::::0;;;:13:::1;:21;::::0;;;;;:32;::::1;;:21;::::0;;::::1;:32;;::::0;15717:41:::1;;;::::0;::::1;;-1:-1:-1::0;;;;;15771:21:0;;;::::1;;::::0;;;:13:::1;:21;::::0;;;;:31;;-1:-1:-1;;15771:31:0::1;::::0;::::1;;::::0;;;::::1;::::0;;15604:206::o;14891:115::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;14947:10:::1;:18:::0;;-1:-1:-1;;14947:18:0;;::::1;::::0;;;14976:15:::1;:22:::0;;;;::::1;14947:18:::0;14976:22:::1;::::0;;14891:115::o;14761:122::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;13566:10:::1;::::0;::::1;;:19;13558:53;;;::::0;-1:-1:-1;;;13558:53:0;;9488:2:1;13558:53:0::1;::::0;::::1;9470:21:1::0;9527:2;9507:18;;;9500:30;-1:-1:-1;;;9546:18:1;;;9539:51;9607:18;;13558:53:0::1;9286:345:1::0;13558:53:0::1;14824:10:::2;:17:::0;;-1:-1:-1;;14824:17:0;;::::2;14837:4;14824:17;::::0;;;14852:15:::2;:23:::0;;;;::::2;::::0;;14761:122::o;19054:439::-;13697:15;;;;:23;;:15;:23;13675:110;;;;-1:-1:-1;;;13675:110:0;;;;;;;:::i;:::-;19156:10:::1;19114:26;19143:24:::0;;;:12:::1;:24;::::0;;;;19186:12;;19178:66:::1;;;::::0;-1:-1:-1;;;19178:66:0;;10244:2:1;19178:66:0::1;::::0;::::1;10226:21:1::0;10283:2;10263:18;;;10256:30;10322:34;10302:18;;;10295:62;-1:-1:-1;;;10373:18:1;;;10366:35;10418:19;;19178:66:0::1;10042:401:1::0;19178:66:0::1;19257:23;19283:36;19308:10;19283:24;:36::i;:::-;19339:9;::::0;19257:62;;-1:-1:-1;19332:59:0::1;::::0;-1:-1:-1;;;;;19339:9:0::1;19363:10;19257:62:::0;19332:30:::1;:59::i;:::-;-1:-1:-1::0;;19417:10:0::1;19438:1;19404:24:::0;;;:12:::1;:24;::::0;;;;:35;;;19450:31:::1;;:35:::0;19054:439::o;5289:108::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;5356:33:::1;::::0;5364:10:::1;::::0;5356:33;::::1;;;::::0;5385:3;;5356:33:::1;::::0;;;5385:3;5364:10;5356:33;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;5289:108:::0;:::o;15122:474::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;15295:7:::1;:14;15277:7;:14;:32;15255:127;;;;-1:-1:-1::0;;;15255:127:0::1;;;;;;;:::i;:::-;15400:9;15395:194;15419:7;:14;15415:1;:18;15395:194;;;15463:7;15471:1;15463:10;;;;;;;;:::i;:::-;;;;;;;15477:1;15463:15:::0;15455:24:::1;;;::::0;::::1;;15522:4;15494:13;:25;15508:7;15516:1;15508:10;;;;;;;;:::i;:::-;;;;;;;-1:-1:-1::0;;;;;15494:25:0::1;-1:-1:-1::0;;;;;15494:25:0::1;;;;;;;;;;;;;:32;;;;;;;;;;;;;;;;;;15567:7;15575:1;15567:10;;;;;;;;:::i;:::-;;;;;;;15541:11;:23;15553:7;15561:1;15553:10;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;15541:23:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;15541:23:0;:36;15435:3:::1;;15395:194;;;;15122:474:::0;;:::o;15818:577::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;16014:7:::1;:14;15996:7;:14;:32;15974:127;;;;-1:-1:-1::0;;;15974:127:0::1;;;;;;;:::i;:::-;16118:10:::0;;16114:55:::1;;16145:4;:12:::0;;;16114:55:::1;16186:9;16181:207;16205:7;:14;16201:1;:18;16181:207;;;16252:13;:25;16266:7;16274:1;16266:10;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;16252:25:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;16252:25:0;;::::1;;:33;;:25:::0;:33:::1;16244:42;;;::::0;::::1;;16309:7;16317:1;16309:10;;;;;;;;:::i;:::-;;;;;;;16323:1;16309:15:::0;16301:24:::1;;;::::0;::::1;;16366:7;16374:1;16366:10;;;;;;;;:::i;:::-;;;;;;;16340:11;:23;16352:7;16360:1;16352:10;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;16340:23:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;16340:23:0;:36;16221:6:::1;16226:1;16221:6:::0;::::1;:::i;:::-;;;16181:207;;;;15818:577:::0;;;:::o;13987:111::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;14062:12:::1;:28:::0;13987:111::o;4223:103::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;4288:30:::1;4315:1;4288:18;:30::i;:::-;4223:103::o:0;15014:100::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;13697:15:::1;::::0;::::1;;:23;;:15:::0;:23:::1;13675:110;;;;-1:-1:-1::0;;;13675:110:0::1;;;;;;;:::i;:::-;15083:15:::2;:23:::0;;-1:-1:-1;;15083:23:0::2;::::0;;15014:100::o;14106:551::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;14292:5:::1;14301:1;14292:10:::0;14284:19:::1;;;::::0;::::1;;14314:4;:12:::0;;;14337:9:::1;:22:::0;;-1:-1:-1;;;;;;14337:22:0::1;-1:-1:-1::0;;;;;14337:22:0;::::1;::::0;;::::1;::::0;;;14370:10:::1;:24:::0;;-1:-1:-1;;14370:24:0::1;::::0;::::1;;;::::0;;14420:36:::1;::::0;;-1:-1:-1;;;14420:36:0;;;;:34:::1;::::0;:36:::1;::::0;;::::1;::::0;::::1;::::0;;;;;;;;;14337:22;14420:36:::1;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;14405:51;;:12;:51:::0;14467:18:::1;:40:::0;;;14525:9:::1;::::0;14518:131:::1;::::0;-1:-1:-1;;;;;14525:9:0::1;14567:10;14600:4;14488:19:::0;14518:34:::1;:131::i;14665:88::-:0;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;13453:10:::1;::::0;::::1;;:18;;:10:::0;:18:::1;13445:52;;;::::0;-1:-1:-1;;;13445:52:0;;6390:2:1;13445:52:0::1;::::0;::::1;6372:21:1::0;6429:2;6409:18;;;6402:30;-1:-1:-1;;;6448:18:1;;;6441:51;6509:18;;13445:52:0::1;6188:345:1::0;13445:52:0::1;14727:10:::2;:18:::0;;-1:-1:-1;;14727:18:0::2;::::0;;14665:88::o;13032:23::-;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;13032:23:0;;-1:-1:-1;13032:23:0;:::o;4334:238::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;4437:22:0;::::1;4415:110;;;::::0;-1:-1:-1;;;4415:110:0;;11474:2:1;4415:110:0::1;::::0;::::1;11456:21:1::0;11513:2;11493:18;;;11486:30;11552:34;11532:18;;;11525:62;-1:-1:-1;;;11603:18:1;;;11596:36;11649:19;;4415:110:0::1;11272:402:1::0;4415:110:0::1;4536:28;4555:8;4536:18;:28::i;:::-;4334:238:::0;:::o;4993:125::-;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;5067:43:::1;-1:-1:-1::0;;;;;5067:26:0;::::1;5094:10;5106:3:::0;5067:26:::1;:43::i;5126:155::-:0;4046:7;4073:6;-1:-1:-1;;;;;4073:6:0;3574:10;4135:23;4127:68;;;;-1:-1:-1;;;4127:68:0;;;;;;;:::i;:::-;5204:38:::1;::::0;-1:-1:-1;;;5204:38:0;;5236:4:::1;5204:38;::::0;::::1;5669:51:1::0;5190:11:0::1;::::0;-1:-1:-1;;;;;5204:23:0;::::1;::::0;::::1;::::0;5642:18:1;;5204:38:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;5190:52;;5253:20;5262:5;5269:3;5253:8;:20::i;16967:144::-:0;17042:61;17074:10;17086:7;4046;4073:6;-1:-1:-1;;;;;4073:6:0;;4000:87;17086:7;-1:-1:-1;;;;;17042:31:0;;;:61;17095:7;17042:31;:61::i;16873:86::-;4046:7;4073:6;;16915:36;;-1:-1:-1;;;;;4073:6:0;;;;16941:9;16915:36;;;;;16941:9;;16915:36;4046:7;16915:36;16941:9;4073:6;16915:36;;;;;;;;;;;;;;;;;;;1539:98;1597:7;1624:5;1628:1;1624;:5;:::i;1645:98::-;1703:7;1730:5;1734:1;1730;:5;:::i;1433:98::-;1491:7;1518:5;1522:1;1518;:5;:::i;9823:214::-;9960:58;;-1:-1:-1;;;;;12588:32:1;;9960:58:0;;;12570:51:1;12637:18;;;12630:34;;;9906:123:0;;9940:5;;-1:-1:-1;;;9983:23:0;12543:18:1;;9960:58:0;;;;-1:-1:-1;;9960:58:0;;;;;;;;;;;;;;-1:-1:-1;;;;;9960:58:0;-1:-1:-1;;;;;;9960:58:0;;;;;;;;;;9906:19;:123::i;4580:191::-;4654:16;4673:6;;-1:-1:-1;;;;;4690:17:0;;;-1:-1:-1;;;;;;4690:17:0;;;;;;4723:40;;4673:6;;;;;;;4723:40;;4654:16;4723:40;4643:128;4580:191;:::o;10045:285::-;10243:68;;-1:-1:-1;;;;;12933:15:1;;;10243:68:0;;;12915:34:1;12985:15;;12965:18;;;12958:43;13017:18;;;13010:34;;;10189:133:0;;10223:5;;-1:-1:-1;;;10266:27:0;12850:18:1;;10243:68:0;12675:375:1;11892:419:0;11973:23;11999:106;12041:4;11999:106;;;;;;;;;;;;;;;;;12007:5;-1:-1:-1;;;;;11999:27:0;;;:106;;;;;:::i;:::-;12120:17;;11973:132;;-1:-1:-1;12120:21:0;12116:188;;12195:10;12184:30;;;;;;;;;;;;:::i;:::-;12158:134;;;;-1:-1:-1;;;12158:134:0;;13507:2:1;12158:134:0;;;13489:21:1;13546:2;13526:18;;;13519:30;13585:34;13565:18;;;13558:62;-1:-1:-1;;;13636:18:1;;;13629:40;13686:19;;12158:134:0;13305:406:1;6570:229:0;6707:12;6739:52;6761:6;6769:4;6775:1;6778:12;6707;5891:20;;7495:60;;;;-1:-1:-1;;;7495:60:0;;14325:2:1;7495:60:0;;;14307:21:1;14364:2;14344:18;;;14337:30;14403:31;14383:18;;;14376:59;14452:18;;7495:60:0;14123:353:1;7495:60:0;7569:12;7583:23;7610:6;-1:-1:-1;;;;;7610:11:0;7629:5;7650:4;7610:55;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7568:97;;;;7683:51;7700:7;7709:10;7721:12;7683:16;:51::i;:::-;7676:58;7171:571;-1:-1:-1;;;;;;;7171:571:0:o;9180:550::-;9330:12;9359:7;9355:368;;;-1:-1:-1;9390:10:0;9383:17;;9355:368;9437:17;;:21;9433:279;;9540:10;9534:17;9601:15;9588:10;9584:2;9580:19;9573:44;9433:279;9683:12;9676:20;;-1:-1:-1;;;9676:20:0;;;;;;;;:::i;14:173:1:-;82:20;;-1:-1:-1;;;;;131:31:1;;121:42;;111:70;;177:1;174;167:12;111:70;14:173;;;:::o;192:254::-;260:6;268;321:2;309:9;300:7;296:23;292:32;289:52;;;337:1;334;327:12;289:52;360:29;379:9;360:29;:::i;:::-;350:39;436:2;421:18;;;;408:32;;-1:-1:-1;;;192:254:1:o;451:186::-;510:6;563:2;551:9;542:7;538:23;534:32;531:52;;;579:1;576;569:12;531:52;602:29;621:9;602:29;:::i;824:248::-;892:6;900;953:2;941:9;932:7;928:23;924:32;921:52;;;969:1;966;959:12;921:52;-1:-1:-1;;992:23:1;;;1062:2;1047:18;;;1034:32;;-1:-1:-1;824:248:1:o;1077:118::-;1163:5;1156:13;1149:21;1142:5;1139:32;1129:60;;1185:1;1182;1175:12;1200:315;1265:6;1273;1326:2;1314:9;1305:7;1301:23;1297:32;1294:52;;;1342:1;1339;1332:12;1294:52;1365:29;1384:9;1365:29;:::i;:::-;1355:39;;1444:2;1433:9;1429:18;1416:32;1457:28;1479:5;1457:28;:::i;:::-;1504:5;1494:15;;;1200:315;;;;;:::o;1520:180::-;1579:6;1632:2;1620:9;1611:7;1607:23;1603:32;1600:52;;;1648:1;1645;1638:12;1600:52;-1:-1:-1;1671:23:1;;1520:180;-1:-1:-1;1520:180:1:o;2111:127::-;2172:10;2167:3;2163:20;2160:1;2153:31;2203:4;2200:1;2193:15;2227:4;2224:1;2217:15;2243:275;2314:2;2308:9;2379:2;2360:13;;-1:-1:-1;;2356:27:1;2344:40;;2414:18;2399:34;;2435:22;;;2396:62;2393:88;;;2461:18;;:::i;:::-;2497:2;2490:22;2243:275;;-1:-1:-1;2243:275:1:o;2523:183::-;2583:4;2616:18;2608:6;2605:30;2602:56;;;2638:18;;:::i;:::-;-1:-1:-1;2683:1:1;2679:14;2695:4;2675:25;;2523:183::o;2711:674::-;2765:5;2818:3;2811:4;2803:6;2799:17;2795:27;2785:55;;2836:1;2833;2826:12;2785:55;2872:6;2859:20;2898:4;2922:60;2938:43;2978:2;2938:43;:::i;:::-;2922:60;:::i;:::-;3004:3;3028:2;3023:3;3016:15;3056:4;3051:3;3047:14;3040:21;;3113:4;3107:2;3104:1;3100:10;3092:6;3088:23;3084:34;3070:48;;3141:3;3133:6;3130:15;3127:35;;;3158:1;3155;3148:12;3127:35;3194:4;3186:6;3182:17;3208:148;3224:6;3219:3;3216:15;3208:148;;;3290:23;3309:3;3290:23;:::i;:::-;3278:36;;3334:12;;;;3241;;3208:148;;;-1:-1:-1;3374:5:1;2711:674;-1:-1:-1;;;;;;2711:674:1:o;3390:668::-;3444:5;3497:3;3490:4;3482:6;3478:17;3474:27;3464:55;;3515:1;3512;3505:12;3464:55;3551:6;3538:20;3577:4;3601:60;3617:43;3657:2;3617:43;:::i;3601:60::-;3683:3;3707:2;3702:3;3695:15;3735:4;3730:3;3726:14;3719:21;;3792:4;3786:2;3783:1;3779:10;3771:6;3767:23;3763:34;3749:48;;3820:3;3812:6;3809:15;3806:35;;;3837:1;3834;3827:12;3806:35;3873:4;3865:6;3861:17;3887:142;3903:6;3898:3;3895:15;3887:142;;;3969:17;;3957:30;;4007:12;;;;3920;;3887:142;;4063:595;4181:6;4189;4242:2;4230:9;4221:7;4217:23;4213:32;4210:52;;;4258:1;4255;4248:12;4210:52;4298:9;4285:23;4327:18;4368:2;4360:6;4357:14;4354:34;;;4384:1;4381;4374:12;4354:34;4407:61;4460:7;4451:6;4440:9;4436:22;4407:61;:::i;:::-;4397:71;;4521:2;4510:9;4506:18;4493:32;4477:48;;4550:2;4540:8;4537:16;4534:36;;;4566:1;4563;4556:12;4534:36;;4589:63;4644:7;4633:8;4622:9;4618:24;4589:63;:::i;:::-;4579:73;;;4063:595;;;;;:::o;4663:663::-;4790:6;4798;4806;4859:2;4847:9;4838:7;4834:23;4830:32;4827:52;;;4875:1;4872;4865:12;4827:52;4915:9;4902:23;4944:18;4985:2;4977:6;4974:14;4971:34;;;5001:1;4998;4991:12;4971:34;5024:61;5077:7;5068:6;5057:9;5053:22;5024:61;:::i;:::-;5014:71;;5138:2;5127:9;5123:18;5110:32;5094:48;;5167:2;5157:8;5154:16;5151:36;;;5183:1;5180;5173:12;5151:36;;5206:63;5261:7;5250:8;5239:9;5235:24;5206:63;:::i;:::-;5196:73;;;5316:2;5305:9;5301:18;5288:32;5278:42;;4663:663;;;;;:::o;5731:452::-;5814:6;5822;5830;5838;5891:3;5879:9;5870:7;5866:23;5862:33;5859:53;;;5908:1;5905;5898:12;5859:53;5931:29;5950:9;5931:29;:::i;:::-;5921:39;;6007:2;5996:9;5992:18;5979:32;5969:42;;6058:2;6047:9;6043:18;6030:32;6020:42;;6112:2;6101:9;6097:18;6084:32;6125:28;6147:5;6125:28;:::i;:::-;5731:452;;;;-1:-1:-1;5731:452:1;;-1:-1:-1;;5731:452:1:o;6891:127::-;6952:10;6947:3;6943:20;6940:1;6933:31;6983:4;6980:1;6973:15;7007:4;7004:1;6997:15;7023:125;7088:9;;;7109:10;;;7106:36;;;7122:18;;:::i;7557:416::-;7646:1;7683:5;7646:1;7697:270;7718:7;7708:8;7705:21;7697:270;;;7777:4;7773:1;7769:6;7765:17;7759:4;7756:27;7753:53;;;7786:18;;:::i;:::-;7836:7;7826:8;7822:22;7819:55;;;7856:16;;;;7819:55;7935:22;;;;7895:15;;;;7697:270;;;7701:3;7557:416;;;;;:::o;7978:806::-;8027:5;8057:8;8047:80;;-1:-1:-1;8098:1:1;8112:5;;8047:80;8146:4;8136:76;;-1:-1:-1;8183:1:1;8197:5;;8136:76;8228:4;8246:1;8241:59;;;;8314:1;8309:130;;;;8221:218;;8241:59;8271:1;8262:10;;8285:5;;;8309:130;8346:3;8336:8;8333:17;8330:43;;;8353:18;;:::i;:::-;-1:-1:-1;;8409:1:1;8395:16;;8424:5;;8221:218;;8523:2;8513:8;8510:16;8504:3;8498:4;8495:13;8491:36;8485:2;8475:8;8472:16;8467:2;8461:4;8458:12;8454:35;8451:77;8448:159;;;-1:-1:-1;8560:19:1;;;8592:5;;8448:159;8639:34;8664:8;8658:4;8639:34;:::i;:::-;8709:6;8705:1;8701:6;8697:19;8688:7;8685:32;8682:58;;;8720:18;;:::i;:::-;8758:20;;7978:806;-1:-1:-1;;;7978:806:1:o;8789:131::-;8849:5;8878:36;8905:8;8899:4;8878:36;:::i;8925:356::-;9127:2;9109:21;;;9146:18;;;9139:30;9205:34;9200:2;9185:18;;9178:62;9272:2;9257:18;;8925:356::o;9636:401::-;9838:2;9820:21;;;9877:2;9857:18;;;9850:30;9916:34;9911:2;9896:18;;9889:62;-1:-1:-1;;;9982:2:1;9967:18;;9960:35;10027:3;10012:19;;9636:401::o;10448:409::-;10650:2;10632:21;;;10689:2;10669:18;;;10662:30;10728:34;10723:2;10708:18;;10701:62;-1:-1:-1;;;10794:2:1;10779:18;;10772:43;10847:3;10832:19;;10448:409::o;10862:127::-;10923:10;10918:3;10914:20;10911:1;10904:31;10954:4;10951:1;10944:15;10978:4;10975:1;10968:15;10994:273;11062:6;11115:2;11103:9;11094:7;11090:23;11086:32;11083:52;;;11131:1;11128;11121:12;11083:52;11163:9;11157:16;11213:4;11206:5;11202:16;11195:5;11192:27;11182:55;;11233:1;11230;11223:12;11679:184;11749:6;11802:2;11790:9;11781:7;11777:23;11773:32;11770:52;;;11818:1;11815;11808:12;11770:52;-1:-1:-1;11841:16:1;;11679:184;-1:-1:-1;11679:184:1:o;11868:168::-;11941:9;;;11972;;11989:15;;;11983:22;;11969:37;11959:71;;12010:18;;:::i;12041:217::-;12081:1;12107;12097:132;;12151:10;12146:3;12142:20;12139:1;12132:31;12186:4;12183:1;12176:15;12214:4;12211:1;12204:15;12097:132;-1:-1:-1;12243:9:1;;12041:217::o;12263:128::-;12330:9;;;12351:11;;;12348:37;;;12365:18;;:::i;13055:245::-;13122:6;13175:2;13163:9;13154:7;13150:23;13146:32;13143:52;;;13191:1;13188;13181:12;13143:52;13223:9;13217:16;13242:28;13264:5;13242:28;:::i;14481:250::-;14566:1;14576:113;14590:6;14587:1;14584:13;14576:113;;;14666:11;;;14660:18;14647:11;;;14640:39;14612:2;14605:10;14576:113;;;-1:-1:-1;;14723:1:1;14705:16;;14698:27;14481:250::o;14736:287::-;14865:3;14903:6;14897:13;14919:66;14978:6;14973:3;14966:4;14958:6;14954:17;14919:66;:::i;:::-;15001:16;;;;;14736:287;-1:-1:-1;;14736:287:1:o;15028:396::-;15177:2;15166:9;15159:21;15140:4;15209:6;15203:13;15252:6;15247:2;15236:9;15232:18;15225:34;15268:79;15340:6;15335:2;15324:9;15320:18;15315:2;15307:6;15303:15;15268:79;:::i;:::-;15408:2;15387:15;-1:-1:-1;;15383:29:1;15368:45;;;;15415:2;15364:54;;15028:396;-1:-1:-1;;15028:396:1:o

Swarm Source

ipfs://3844fe45722ffa424e2b8921dea65ddffa81f49f8741ddbb33a5bdafad63352f

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading
Loading...
Loading

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.