ETH Price: $3,410.19 (+4.66%)

Token

MileVerse (MVC)
 

Overview

Max Total Supply

3,000,000,000 MVC

Holders

1,459 (0.00%)

Market

Price

$0.01 @ 0.000002 ETH (+1.18%)

Onchain Market Cap

$18,606,270.00

Circulating Supply Market Cap

$16,700,914.00

Other Info

Token Contract (WITH 18 Decimals)

Balance
310 MVC

Value
$1.92 ( ~0.000563018569458076 Eth) [0.0000%]
0x74eccbd2526d0f0af6fbb9acba04bbfcbaedce86
Loading...
Loading
Loading...
Loading
Loading...
Loading

OVERVIEW

MileVerse is a mileage exchange/integration payment platform that applies Blockchain technology to build an integrated mileage ecosystem that benefits everyone from corporations and customers to affiliated stores.

Market

Volume (24H):$4,899,093.00
Market Capitalization:$16,700,914.00
Circulating Supply:2,692,797,831.00 MVC
Market Data Source: Coinmarketcap

# Exchange Pair Price  24H Volume % Volume
1
Bithumb
MVC-KRW$0.0062
0.0000018 Eth
$4,861,944.00
788,477,022.236 MVC
99.9028%
2
Coinone
MVC-KRW$0.0061
0.0000018 Eth
$4,699.74
767,395.074 MVC
0.0972%

Contract Source Code Verified (Exact Match)

Contract Name:
MileVerseToken

Compiler Version
v0.6.10+commit.00c0fcaf

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2020-06-24
*/

// File: contracts\library\SafeMath.sol

pragma solidity 0.6.10;

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     * - Subtraction cannot overflow.
     *
     * _Available since v2.4.0._
     */
    function sub(uint256 a, uint256 b, string memory errorMessage)
        internal
        pure
        returns (uint256)
    {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");

        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     * - The divisor cannot be zero.
     *
     * _Available since v2.4.0._
     */
    function div(uint256 a, uint256 b, string memory errorMessage)
        internal
        pure
        returns (uint256)
    {
        // Solidity only automatically asserts when dividing by 0
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     * - The divisor cannot be zero.
     *
     * _Available since v2.4.0._
     */
    function mod(uint256 a, uint256 b, string memory errorMessage)
        internal
        pure
        returns (uint256)
    {
        require(b != 0, errorMessage);
        return a % b;
    }
}

// File: contracts\erc20\ERC20.sol

pragma solidity 0.6.10;


abstract contract ERC20 {
    using SafeMath for uint256;

    uint256 private _totalSupply;
    mapping(address => uint256) internal _balances;
    mapping(address => mapping(address => uint256)) internal _allowances;

    event Transfer(address indexed from, address indexed to, uint256 amount);
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 amount
    );

    /*
   * Internal Functions for ERC20 standard logics
   */

    function _transfer(address from, address to, uint256 amount)
        internal
        returns (bool success)
    {
        _balances[from] = _balances[from].sub(
            amount,
            "ERC20/transfer : cannot transfer more than token owner balance"
        );
        _balances[to] = _balances[to].add(amount);
        emit Transfer(from, to, amount);
        success = true;
    }

    function _approve(address owner, address spender, uint256 amount)
        internal
        returns (bool success)
    {
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
        success = true;
    }

    function _mint(address recipient, uint256 amount)
        internal
        returns (bool success)
    {
        _totalSupply = _totalSupply.add(amount);
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(address(0), recipient, amount);
        success = true;
    }

    function _burn(address burned, uint256 amount)
        internal
        returns (bool success)
    {
        _balances[burned] = _balances[burned].sub(
            amount,
            "ERC20Burnable/burn : Cannot burn more than user's balance"
        );
        _totalSupply = _totalSupply.sub(
            amount,
            "ERC20Burnable/burn : Cannot burn more than totalSupply"
        );
        emit Transfer(burned, address(0), amount);
        success = true;
    }

    /*
   * public view functions to view common data
   */

    function totalSupply() external view returns (uint256 total) {
        total = _totalSupply;
    }
    function balanceOf(address owner) external view returns (uint256 balance) {
        balance = _balances[owner];
    }

    function allowance(address owner, address spender)
        external
        view
        returns (uint256 remaining)
    {
        remaining = _allowances[owner][spender];
    }

    /*
   * External view Function Interface to implement on final contract
   */
    function name() virtual external view returns (string memory tokenName);
    function symbol() virtual external view returns (string memory tokenSymbol);
    function decimals() virtual external view returns (uint8 tokenDecimals);

    /*
   * External Function Interface to implement on final contract
   */
    function transfer(address to, uint256 amount)
        virtual
        external
        returns (bool success);
    function transferFrom(address from, address to, uint256 amount)
        virtual
        external
        returns (bool success);
    function approve(address spender, uint256 amount)
        virtual
        external
        returns (bool success);
}

// File: contracts\library\Ownable.sol

pragma solidity 0.6.10;

contract Ownable {
    address internal _owner;

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

    constructor() internal {
        _owner = msg.sender;
        emit OwnershipTransferred(address(0), msg.sender);
    }

    modifier onlyOwner() {
        require(
            msg.sender == _owner,
            "Ownable : Function called by unauthorized user."
        );
        _;
    }

    function owner() external view returns (address ownerAddress) {
        ownerAddress = _owner;
    }

    function transferOwnership(address newOwner)
        public
        onlyOwner
        returns (bool success)
    {
        require(newOwner != address(0), "Ownable/transferOwnership : cannot transfer ownership to zero address");
        success = _transferOwnership(newOwner);
    }

    function renounceOwnership() external onlyOwner returns (bool success) {
        success = _transferOwnership(address(0));
    }

    function _transferOwnership(address newOwner) internal returns (bool success) {
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
        success = true;
    }
}

// File: contracts\erc20\ERC20Lockable.sol

pragma solidity 0.6.10;



abstract contract ERC20Lockable is ERC20, Ownable {
    struct LockInfo {
        uint256 amount;
        uint256 due;
    }

    mapping(address => LockInfo[]) internal _locks;
    mapping(address => uint256) internal _totalLocked;

    event Lock(address indexed from, uint256 amount, uint256 due);
    event Unlock(address indexed from, uint256 amount);

    modifier checkLock(address from, uint256 amount) {
        require(_balances[from] >= _totalLocked[from].add(amount), "ERC20Lockable/Cannot send more than unlocked amount");
        _;
    }

    function _lock(address from, uint256 amount, uint256 due)
        internal
        returns (bool success)
    {
        require(due > now, "ERC20Lockable/lock : Cannot set due to past");
        require(
            _balances[from] >= amount.add(_totalLocked[from]),
            "ERC20Lockable/lock : locked total should be smaller than balance"
        );
        _totalLocked[from] = _totalLocked[from].add(amount);
        _locks[from].push(LockInfo(amount, due));
        emit Lock(from, amount, due);
        success = true;
    }

    function _unlock(address from, uint256 index) internal returns (bool success) {
        LockInfo storage lock = _locks[from][index];
        _totalLocked[from] = _totalLocked[from].sub(lock.amount);
        emit Unlock(from, lock.amount);
        _locks[from][index] = _locks[from][_locks[from].length - 1];
        _locks[from].pop();
        success = true;
    }

    function unlock(address from) external returns (bool success) {
        for(uint256 i = 0; i < _locks[from].length; i++){
            if(_locks[from][i].due < now){
                _unlock(from, i);
            }
        }
        success = true;
    }

    function releaseLock(address from)
        external
        onlyOwner
        returns (bool success)
    {
        for(uint256 i = 0; i < _locks[from].length; i++){
            _unlock(from, i);
        }
        success = true;
    }

    function transferWithLockUp(address recipient, uint256 amount, uint256 due)
        external
        onlyOwner
        returns (bool success)
    {
        require(
            recipient != address(0),
            "ERC20Lockable/transferWithLockUp : Cannot send to zero address"
        );
        _transfer(msg.sender, recipient, amount);
        _lock(recipient, amount, due);
        success = true;
    }

    function lockInfo(address locked, uint256 index)
        external
        view
        returns (uint256 amount, uint256 due)
    {
        LockInfo memory lock = _locks[locked][index];
        amount = lock.amount;
        due = lock.due;
    }

    function totalLocked(address locked) external view returns(uint256 amount, uint256 length){
        amount = _totalLocked[locked];
        length = _locks[locked].length;
    }
}

// File: contracts\library\Pausable.sol

pragma solidity 0.6.10;


contract Pausable is Ownable {
    bool internal _paused;

    event Paused();
    event Unpaused();

    modifier whenPaused() {
        require(_paused, "Paused : This function can only be called when paused");
        _;
    }

    modifier whenNotPaused() {
        require(!_paused, "Paused : This function can only be called when not paused");
        _;
    }

    function pause() external onlyOwner whenNotPaused returns (bool success) {
        _paused = true;
        emit Paused();
        success = true;
    }

    function unPause() external onlyOwner whenPaused returns (bool success) {
        _paused = false;
        emit Unpaused();
        success = true;
    }

    function paused() external view returns (bool) {
        return _paused;
    }
}

// File: contracts\library\Freezable.sol

pragma solidity 0.6.10;


contract Freezable is Ownable {
    mapping(address => bool) private _frozen;

    event Freeze(address indexed target);
    event Unfreeze(address indexed target);

    modifier whenNotFrozen(address target) {
        require(!_frozen[target], "Freezable : target is frozen");
        _;
    }

    function freeze(address target) external onlyOwner returns (bool success) {
        _frozen[target] = true;
        emit Freeze(target);
        success = true;
    }

    function unFreeze(address target)
        external
        onlyOwner
        returns (bool success)
    {
        _frozen[target] = false;
        emit Unfreeze(target);
        success = true;
    }

    function isFrozen(address target)
        external
        view
        returns (bool frozen)
    {
        return _frozen[target];
    }
}

// File: contracts\MileVerseToken.sol

pragma solidity 0.6.10;




contract MileVerseToken is
    ERC20Lockable,
    Pausable,
    Freezable
{
    string constant private _name = "MileVerse";
    string constant private _symbol = "MVC";
    uint8 constant private _decimals = 18;
    uint256 constant private _initial_supply = 3_000_000_000;

    constructor() public Ownable() {
        _mint(msg.sender, _initial_supply * (10**uint256(_decimals)));
    }

    function transfer(address to, uint256 amount)
        override
        external
        whenNotFrozen(msg.sender)
        whenNotPaused
        checkLock(msg.sender, amount)
        returns (bool success)
    {
        require(
            to != address(0),
            "SAM/transfer : Should not send to zero address"
        );
        _transfer(msg.sender, to, amount);
        success = true;
    }

    function transferFrom(address from, address to, uint256 amount)
        override
        external
        whenNotFrozen(from)
        whenNotPaused
        checkLock(from, amount)
        returns (bool success)
    {
        require(
            to != address(0),
            "SAM/transferFrom : Should not send to zero address"
        );
        _transfer(from, to, amount);
        _approve(
            from,
            msg.sender,
            _allowances[from][msg.sender].sub(
                amount,
                "SAM/transferFrom : Cannot send more than allowance"
            )
        );
        success = true;
    }

    function approve(address spender, uint256 amount)
        override
        external
        returns (bool success)
    {
        require(
            spender != address(0),
            "SAM/approve : Should not approve zero address"
        );
        _approve(msg.sender, spender, amount);
        success = true;
    }

    function name() override external view returns (string memory tokenName) {
        tokenName = _name;
    }

    function symbol() override external view returns (string memory tokenSymbol) {
        tokenSymbol = _symbol;
    }

    function decimals() override external view returns (uint8 tokenDecimals) {
        tokenDecimals = _decimals;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"target","type":"address"}],"name":"Freeze","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"due","type":"uint256"}],"name":"Lock","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"currentOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"target","type":"address"}],"name":"Unfreeze","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Unlock","type":"event"},{"anonymous":false,"inputs":[],"name":"Unpaused","type":"event"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"remaining","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"balance","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"tokenDecimals","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"target","type":"address"}],"name":"freeze","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"target","type":"address"}],"name":"isFrozen","outputs":[{"internalType":"bool","name":"frozen","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"locked","type":"address"},{"internalType":"uint256","name":"index","type":"uint256"}],"name":"lockInfo","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"due","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"tokenName","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"ownerAddress","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pause","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"}],"name":"releaseLock","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"tokenSymbol","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"locked","type":"address"}],"name":"totalLocked","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"length","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"total","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"due","type":"uint256"}],"name":"transferWithLockUp","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"target","type":"address"}],"name":"unFreeze","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unPause","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"}],"name":"unlock","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"}]

60806040523480156200001157600080fd5b50600380546001600160a01b031916339081179091556040516000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a362000073336b09b18ab5df7180b6b80000006001600160e01b036200007a16565b506200018b565b600062000098826000546200012960201b62000f5f1790919060201c565b60009081556001600160a01b038416815260016020908152604090912054620000cc91849062000f5f62000129821b17901c565b6001600160a01b03841660008181526001602090815260408083209490945583518681529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a350600192915050565b60008282018381101562000184576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b61185d806200019b6000396000f3fe608060405234801561001057600080fd5b506004361061014d5760003560e01c80638456cb59116100c3578063d1c469161161007c578063d1c46916146103fc578063d8fb933714610422578063dd62ed3e14610448578063e583983614610476578063f2fde38b1461049c578063f7b188a5146104c25761014d565b80638456cb59146103315780638d1fdf2f146103395780638da5cb5b1461035f57806395d89b4114610383578063a9059cbb1461038b578063b2520a7c146103b75761014d565b8063313ce56711610115578063313ce5671461028557806338b82092146102a35780635c975abb146102d557806370a08231146102dd578063715018a61461030357806383cfab421461030b5761014d565b806306fdde0314610152578063095ea7b3146101cf57806318160ddd1461020f57806323b872dd146102295780632f6c493c1461025f575b600080fd5b61015a6104ca565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561019457818101518382015260200161017c565b50505050905090810190601f1680156101c15780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6101fb600480360360408110156101e557600080fd5b506001600160a01b0381351690602001356104ed565b604080519115158252519081900360200190f35b610217610549565b60408051918252519081900360200190f35b6101fb6004803603606081101561023f57600080fd5b506001600160a01b0381358116916020810135909116906040013561054f565b6101fb6004803603602081101561027557600080fd5b50356001600160a01b031661073b565b61028d6107bb565b6040805160ff9092168252519081900360200190f35b6101fb600480360360608110156102b957600080fd5b506001600160a01b0381351690602081013590604001356107c0565b6101fb610873565b610217600480360360208110156102f357600080fd5b50356001600160a01b031661087c565b6101fb610897565b6101fb6004803603602081101561032157600080fd5b50356001600160a01b03166108f2565b6101fb61098c565b6101fb6004803603602081101561034f57600080fd5b50356001600160a01b0316610a56565b610367610af3565b604080516001600160a01b039092168252519081900360200190f35b61015a610b02565b6101fb600480360360408110156103a157600080fd5b506001600160a01b038135169060200135610b1f565b6103e3600480360360408110156103cd57600080fd5b506001600160a01b038135169060200135610c9e565b6040805192835260208301919091528051918290030190f35b6101fb6004803603602081101561041257600080fd5b50356001600160a01b0316610d06565b6103e36004803603602081101561043857600080fd5b50356001600160a01b0316610d88565b6102176004803603604081101561045e57600080fd5b506001600160a01b0381358116916020013516610db0565b6101fb6004803603602081101561048c57600080fd5b50356001600160a01b0316610ddb565b6101fb600480360360208110156104b257600080fd5b50356001600160a01b0316610df9565b6101fb610e99565b6040805180820190915260098152684d696c65566572736560b81b602082015290565b60006001600160a01b0383166105345760405162461bcd60e51b815260040180806020018281038252602d815260200180611781602d913960400191505060405180910390fd5b61053f338484610fc0565b5060019392505050565b60005490565b6001600160a01b038316600090815260076020526040812054849060ff16156105bf576040805162461bcd60e51b815260206004820152601c60248201527f467265657a61626c65203a207461726765742069732066726f7a656e00000000604482015290519081900360640190fd5b60065460ff16156106015760405162461bcd60e51b81526004018080602001828103825260398152602001806116486039913960400191505060405180910390fd5b6001600160a01b0385166000908152600560205260409020548590849061062e908263ffffffff610f5f16565b6001600160a01b03831660009081526001602052604090205410156106845760405162461bcd60e51b815260040180806020018281038252603381526020018061174e6033913960400191505060405180910390fd5b6001600160a01b0386166106c95760405162461bcd60e51b81526004018080602001828103825260328152602001806116af6032913960400191505060405180910390fd5b6106d487878761102b565b5061072d873361072888604051806060016040528060328152602001611616603291396001600160a01b038d166000908152600260209081526040808320338452909152902054919063ffffffff61110616565b610fc0565b506001979650505050505050565b6000805b6001600160a01b0383166000908152600460205260409020548110156107b2576001600160a01b038316600090815260046020526040902080544291908390811061078657fe5b90600052602060002090600202016001015410156107aa576107a8838261119d565b505b60010161073f565b50600192915050565b601290565b6003546000906001600160a01b0316331461080c5760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b6001600160a01b0384166108515760405162461bcd60e51b815260040180806020018281038252603e81526020018061156d603e913960400191505060405180910390fd5b61085c33858561102b565b50610868848484611328565b506001949350505050565b60065460ff1690565b6001600160a01b031660009081526001602052604090205490565b6003546000906001600160a01b031633146108e35760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b6108ed60006114ad565b905090565b6003546000906001600160a01b0316331461093e5760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b6001600160a01b038216600081815260076020526040808220805460ff19169055517fca5069937e68fd197927055037f59d7c90bf75ac104e6e375539ef480c3ad6ee9190a2506001919050565b6003546000906001600160a01b031633146109d85760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b60065460ff1615610a1a5760405162461bcd60e51b81526004018080602001828103825260398152602001806116486039913960400191505060405180910390fd5b6006805460ff191660011790556040517f9e87fac88ff661f02d44f95383c817fece4bce600a3dab7a54406878b965e75290600090a150600190565b6003546000906001600160a01b03163314610aa25760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b6001600160a01b038216600081815260076020526040808220805460ff19166001179055517faf85b60d26151edd11443b704d424da6c43d0468f2235ebae3d1904dbc3230499190a2506001919050565b6003546001600160a01b031690565b6040805180820190915260038152624d564360e81b602082015290565b3360008181526007602052604081205490919060ff1615610b87576040805162461bcd60e51b815260206004820152601c60248201527f467265657a61626c65203a207461726765742069732066726f7a656e00000000604482015290519081900360640190fd5b60065460ff1615610bc95760405162461bcd60e51b81526004018080602001828103825260398152602001806116486039913960400191505060405180910390fd5b336000818152600560205260409020548490610beb908263ffffffff610f5f16565b6001600160a01b0383166000908152600160205260409020541015610c415760405162461bcd60e51b815260040180806020018281038252603381526020018061174e6033913960400191505060405180910390fd5b6001600160a01b038616610c865760405162461bcd60e51b815260040180806020018281038252602e815260200180611681602e913960400191505060405180910390fd5b610c9133878761102b565b5060019695505050505050565b600080610ca9611552565b6001600160a01b0385166000908152600460205260409020805485908110610ccd57fe5b60009182526020918290206040805180820190915260029092020180548083526001909101549190920181905290969095509350505050565b6003546000906001600160a01b03163314610d525760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b60005b6001600160a01b0383166000908152600460205260409020548110156107b257610d7f838261119d565b50600101610d55565b6001600160a01b03166000908152600560209081526040808320546004909252909120549091565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b6001600160a01b031660009081526007602052604090205460ff1690565b6003546000906001600160a01b03163314610e455760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b6001600160a01b038216610e8a5760405162461bcd60e51b81526004018080602001828103825260458152602001806117e36045913960600191505060405180910390fd5b610e93826114ad565b92915050565b6003546000906001600160a01b03163314610ee55760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b60065460ff16610f265760405162461bcd60e51b81526004018080602001828103825260358152602001806117ae6035913960400191505060405180910390fd5b6006805460ff191690556040517fa45f47fdea8a1efdd9029a5691c7f759c32b7c698632b563573e155625d1693390600090a150600190565b600082820183811015610fb9576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b6001600160a01b03808416600081815260026020908152604080832094871680845294825280832086905580518681529051929493927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a35060019392505050565b6000611070826040518060600160405280603e81526020016116e1603e91396001600160a01b038716600090815260016020526040902054919063ffffffff61110616565b6001600160a01b0380861660009081526001602052604080822093909355908516815220546110a5908363ffffffff610f5f16565b6001600160a01b0380851660008181526001602090815260409182902094909455805186815290519193928816927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a35060019392505050565b600081848411156111955760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561115a578181015183820152602001611142565b50505050905090810190601f1680156111875780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6001600160a01b03821660009081526004602052604081208054829190849081106111c457fe5b60009182526020808320600290920290910180546001600160a01b03881684526005909252604090922054919250611202919063ffffffff61151016565b6001600160a01b0385166000818152600560209081526040918290209390935583548151908152905191927f6381d9813cabeb57471b5a7e05078e64845ccdb563146a6911d536f24ce960f192918290030190a26001600160a01b03841660009081526004602052604090208054600019810190811061127e57fe5b906000526020600020906002020160046000866001600160a01b03166001600160a01b0316815260200190815260200160002084815481106112bc57fe5b60009182526020808320845460029093020191825560019384015493909101929092556001600160a01b03861681526004909152604090208054806112fd57fe5b6000828152602081206002600019909301928302018181556001908101919091559155949350505050565b60004282116113685760405162461bcd60e51b815260040180806020018281038252602b8152602001806115eb602b913960400191505060405180910390fd5b6001600160a01b03841660009081526005602052604090205461139290849063ffffffff610f5f16565b6001600160a01b03851660009081526001602052604090205410156113e85760405162461bcd60e51b81526004018080602001828103825260408152602001806115ab6040913960400191505060405180910390fd5b6001600160a01b038416600090815260056020526040902054611411908463ffffffff610f5f16565b6001600160a01b03851660008181526005602090815260408083209490945560048152838220845180860186528881528083018881528254600181810185559386529484902091516002909502909101938455519201919091558251868152908101859052825191927f49eaf4942f1237055eb4cfa5f31c9dfe50d5b4ade01e021f7de8be2fbbde557b92918290030190a25060019392505050565b6003546040516000916001600160a01b03808516929116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908490a350600380546001600160a01b0319166001600160a01b0392909216919091179055600190565b6000610fb983836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611106565b60405180604001604052806000815260200160008152509056fe45524332304c6f636b61626c652f7472616e73666572576974684c6f636b5570203a2043616e6e6f742073656e6420746f207a65726f206164647265737345524332304c6f636b61626c652f6c6f636b203a206c6f636b656420746f74616c2073686f756c6420626520736d616c6c6572207468616e2062616c616e636545524332304c6f636b61626c652f6c6f636b203a2043616e6e6f74207365742064756520746f207061737453414d2f7472616e7366657246726f6d203a2043616e6e6f742073656e64206d6f7265207468616e20616c6c6f77616e6365506175736564203a20546869732066756e6374696f6e2063616e206f6e6c792062652063616c6c6564207768656e206e6f742070617573656453414d2f7472616e73666572203a2053686f756c64206e6f742073656e6420746f207a65726f206164647265737353414d2f7472616e7366657246726f6d203a2053686f756c64206e6f742073656e6420746f207a65726f206164647265737345524332302f7472616e73666572203a2063616e6e6f74207472616e73666572206d6f7265207468616e20746f6b656e206f776e65722062616c616e63654f776e61626c65203a2046756e6374696f6e2063616c6c656420627920756e617574686f72697a656420757365722e45524332304c6f636b61626c652f43616e6e6f742073656e64206d6f7265207468616e20756e6c6f636b656420616d6f756e7453414d2f617070726f7665203a2053686f756c64206e6f7420617070726f7665207a65726f2061646472657373506175736564203a20546869732066756e6374696f6e2063616e206f6e6c792062652063616c6c6564207768656e207061757365644f776e61626c652f7472616e736665724f776e657273686970203a2063616e6e6f74207472616e73666572206f776e65727368697020746f207a65726f2061646472657373a26469706673582212200b1fa1469a16cdc6fd366824911912122122f0acc9e228337d2284cc19e3ac9664736f6c634300060a0033

Deployed Bytecode

0x608060405234801561001057600080fd5b506004361061014d5760003560e01c80638456cb59116100c3578063d1c469161161007c578063d1c46916146103fc578063d8fb933714610422578063dd62ed3e14610448578063e583983614610476578063f2fde38b1461049c578063f7b188a5146104c25761014d565b80638456cb59146103315780638d1fdf2f146103395780638da5cb5b1461035f57806395d89b4114610383578063a9059cbb1461038b578063b2520a7c146103b75761014d565b8063313ce56711610115578063313ce5671461028557806338b82092146102a35780635c975abb146102d557806370a08231146102dd578063715018a61461030357806383cfab421461030b5761014d565b806306fdde0314610152578063095ea7b3146101cf57806318160ddd1461020f57806323b872dd146102295780632f6c493c1461025f575b600080fd5b61015a6104ca565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561019457818101518382015260200161017c565b50505050905090810190601f1680156101c15780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6101fb600480360360408110156101e557600080fd5b506001600160a01b0381351690602001356104ed565b604080519115158252519081900360200190f35b610217610549565b60408051918252519081900360200190f35b6101fb6004803603606081101561023f57600080fd5b506001600160a01b0381358116916020810135909116906040013561054f565b6101fb6004803603602081101561027557600080fd5b50356001600160a01b031661073b565b61028d6107bb565b6040805160ff9092168252519081900360200190f35b6101fb600480360360608110156102b957600080fd5b506001600160a01b0381351690602081013590604001356107c0565b6101fb610873565b610217600480360360208110156102f357600080fd5b50356001600160a01b031661087c565b6101fb610897565b6101fb6004803603602081101561032157600080fd5b50356001600160a01b03166108f2565b6101fb61098c565b6101fb6004803603602081101561034f57600080fd5b50356001600160a01b0316610a56565b610367610af3565b604080516001600160a01b039092168252519081900360200190f35b61015a610b02565b6101fb600480360360408110156103a157600080fd5b506001600160a01b038135169060200135610b1f565b6103e3600480360360408110156103cd57600080fd5b506001600160a01b038135169060200135610c9e565b6040805192835260208301919091528051918290030190f35b6101fb6004803603602081101561041257600080fd5b50356001600160a01b0316610d06565b6103e36004803603602081101561043857600080fd5b50356001600160a01b0316610d88565b6102176004803603604081101561045e57600080fd5b506001600160a01b0381358116916020013516610db0565b6101fb6004803603602081101561048c57600080fd5b50356001600160a01b0316610ddb565b6101fb600480360360208110156104b257600080fd5b50356001600160a01b0316610df9565b6101fb610e99565b6040805180820190915260098152684d696c65566572736560b81b602082015290565b60006001600160a01b0383166105345760405162461bcd60e51b815260040180806020018281038252602d815260200180611781602d913960400191505060405180910390fd5b61053f338484610fc0565b5060019392505050565b60005490565b6001600160a01b038316600090815260076020526040812054849060ff16156105bf576040805162461bcd60e51b815260206004820152601c60248201527f467265657a61626c65203a207461726765742069732066726f7a656e00000000604482015290519081900360640190fd5b60065460ff16156106015760405162461bcd60e51b81526004018080602001828103825260398152602001806116486039913960400191505060405180910390fd5b6001600160a01b0385166000908152600560205260409020548590849061062e908263ffffffff610f5f16565b6001600160a01b03831660009081526001602052604090205410156106845760405162461bcd60e51b815260040180806020018281038252603381526020018061174e6033913960400191505060405180910390fd5b6001600160a01b0386166106c95760405162461bcd60e51b81526004018080602001828103825260328152602001806116af6032913960400191505060405180910390fd5b6106d487878761102b565b5061072d873361072888604051806060016040528060328152602001611616603291396001600160a01b038d166000908152600260209081526040808320338452909152902054919063ffffffff61110616565b610fc0565b506001979650505050505050565b6000805b6001600160a01b0383166000908152600460205260409020548110156107b2576001600160a01b038316600090815260046020526040902080544291908390811061078657fe5b90600052602060002090600202016001015410156107aa576107a8838261119d565b505b60010161073f565b50600192915050565b601290565b6003546000906001600160a01b0316331461080c5760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b6001600160a01b0384166108515760405162461bcd60e51b815260040180806020018281038252603e81526020018061156d603e913960400191505060405180910390fd5b61085c33858561102b565b50610868848484611328565b506001949350505050565b60065460ff1690565b6001600160a01b031660009081526001602052604090205490565b6003546000906001600160a01b031633146108e35760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b6108ed60006114ad565b905090565b6003546000906001600160a01b0316331461093e5760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b6001600160a01b038216600081815260076020526040808220805460ff19169055517fca5069937e68fd197927055037f59d7c90bf75ac104e6e375539ef480c3ad6ee9190a2506001919050565b6003546000906001600160a01b031633146109d85760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b60065460ff1615610a1a5760405162461bcd60e51b81526004018080602001828103825260398152602001806116486039913960400191505060405180910390fd5b6006805460ff191660011790556040517f9e87fac88ff661f02d44f95383c817fece4bce600a3dab7a54406878b965e75290600090a150600190565b6003546000906001600160a01b03163314610aa25760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b6001600160a01b038216600081815260076020526040808220805460ff19166001179055517faf85b60d26151edd11443b704d424da6c43d0468f2235ebae3d1904dbc3230499190a2506001919050565b6003546001600160a01b031690565b6040805180820190915260038152624d564360e81b602082015290565b3360008181526007602052604081205490919060ff1615610b87576040805162461bcd60e51b815260206004820152601c60248201527f467265657a61626c65203a207461726765742069732066726f7a656e00000000604482015290519081900360640190fd5b60065460ff1615610bc95760405162461bcd60e51b81526004018080602001828103825260398152602001806116486039913960400191505060405180910390fd5b336000818152600560205260409020548490610beb908263ffffffff610f5f16565b6001600160a01b0383166000908152600160205260409020541015610c415760405162461bcd60e51b815260040180806020018281038252603381526020018061174e6033913960400191505060405180910390fd5b6001600160a01b038616610c865760405162461bcd60e51b815260040180806020018281038252602e815260200180611681602e913960400191505060405180910390fd5b610c9133878761102b565b5060019695505050505050565b600080610ca9611552565b6001600160a01b0385166000908152600460205260409020805485908110610ccd57fe5b60009182526020918290206040805180820190915260029092020180548083526001909101549190920181905290969095509350505050565b6003546000906001600160a01b03163314610d525760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b60005b6001600160a01b0383166000908152600460205260409020548110156107b257610d7f838261119d565b50600101610d55565b6001600160a01b03166000908152600560209081526040808320546004909252909120549091565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b6001600160a01b031660009081526007602052604090205460ff1690565b6003546000906001600160a01b03163314610e455760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b6001600160a01b038216610e8a5760405162461bcd60e51b81526004018080602001828103825260458152602001806117e36045913960600191505060405180910390fd5b610e93826114ad565b92915050565b6003546000906001600160a01b03163314610ee55760405162461bcd60e51b815260040180806020018281038252602f81526020018061171f602f913960400191505060405180910390fd5b60065460ff16610f265760405162461bcd60e51b81526004018080602001828103825260358152602001806117ae6035913960400191505060405180910390fd5b6006805460ff191690556040517fa45f47fdea8a1efdd9029a5691c7f759c32b7c698632b563573e155625d1693390600090a150600190565b600082820183811015610fb9576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b6001600160a01b03808416600081815260026020908152604080832094871680845294825280832086905580518681529051929493927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a35060019392505050565b6000611070826040518060600160405280603e81526020016116e1603e91396001600160a01b038716600090815260016020526040902054919063ffffffff61110616565b6001600160a01b0380861660009081526001602052604080822093909355908516815220546110a5908363ffffffff610f5f16565b6001600160a01b0380851660008181526001602090815260409182902094909455805186815290519193928816927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a35060019392505050565b600081848411156111955760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561115a578181015183820152602001611142565b50505050905090810190601f1680156111875780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6001600160a01b03821660009081526004602052604081208054829190849081106111c457fe5b60009182526020808320600290920290910180546001600160a01b03881684526005909252604090922054919250611202919063ffffffff61151016565b6001600160a01b0385166000818152600560209081526040918290209390935583548151908152905191927f6381d9813cabeb57471b5a7e05078e64845ccdb563146a6911d536f24ce960f192918290030190a26001600160a01b03841660009081526004602052604090208054600019810190811061127e57fe5b906000526020600020906002020160046000866001600160a01b03166001600160a01b0316815260200190815260200160002084815481106112bc57fe5b60009182526020808320845460029093020191825560019384015493909101929092556001600160a01b03861681526004909152604090208054806112fd57fe5b6000828152602081206002600019909301928302018181556001908101919091559155949350505050565b60004282116113685760405162461bcd60e51b815260040180806020018281038252602b8152602001806115eb602b913960400191505060405180910390fd5b6001600160a01b03841660009081526005602052604090205461139290849063ffffffff610f5f16565b6001600160a01b03851660009081526001602052604090205410156113e85760405162461bcd60e51b81526004018080602001828103825260408152602001806115ab6040913960400191505060405180910390fd5b6001600160a01b038416600090815260056020526040902054611411908463ffffffff610f5f16565b6001600160a01b03851660008181526005602090815260408083209490945560048152838220845180860186528881528083018881528254600181810185559386529484902091516002909502909101938455519201919091558251868152908101859052825191927f49eaf4942f1237055eb4cfa5f31c9dfe50d5b4ade01e021f7de8be2fbbde557b92918290030190a25060019392505050565b6003546040516000916001600160a01b03808516929116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908490a350600380546001600160a01b0319166001600160a01b0392909216919091179055600190565b6000610fb983836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611106565b60405180604001604052806000815260200160008152509056fe45524332304c6f636b61626c652f7472616e73666572576974684c6f636b5570203a2043616e6e6f742073656e6420746f207a65726f206164647265737345524332304c6f636b61626c652f6c6f636b203a206c6f636b656420746f74616c2073686f756c6420626520736d616c6c6572207468616e2062616c616e636545524332304c6f636b61626c652f6c6f636b203a2043616e6e6f74207365742064756520746f207061737453414d2f7472616e7366657246726f6d203a2043616e6e6f742073656e64206d6f7265207468616e20616c6c6f77616e6365506175736564203a20546869732066756e6374696f6e2063616e206f6e6c792062652063616c6c6564207768656e206e6f742070617573656453414d2f7472616e73666572203a2053686f756c64206e6f742073656e6420746f207a65726f206164647265737353414d2f7472616e7366657246726f6d203a2053686f756c64206e6f742073656e6420746f207a65726f206164647265737345524332302f7472616e73666572203a2063616e6e6f74207472616e73666572206d6f7265207468616e20746f6b656e206f776e65722062616c616e63654f776e61626c65203a2046756e6374696f6e2063616c6c656420627920756e617574686f72697a656420757365722e45524332304c6f636b61626c652f43616e6e6f742073656e64206d6f7265207468616e20756e6c6f636b656420616d6f756e7453414d2f617070726f7665203a2053686f756c64206e6f7420617070726f7665207a65726f2061646472657373506175736564203a20546869732066756e6374696f6e2063616e206f6e6c792062652063616c6c6564207768656e207061757365644f776e61626c652f7472616e736665724f776e657273686970203a2063616e6e6f74207472616e73666572206f776e65727368697020746f207a65726f2061646472657373a26469706673582212200b1fa1469a16cdc6fd366824911912122122f0acc9e228337d2284cc19e3ac9664736f6c634300060a0033

Deployed Bytecode Sourcemap

15065:2195:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16898:109;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16559:331;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;16559:331:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;7708:100;;;:::i;:::-;;;;;;;;;;;;;;;;15898:653;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;15898:653:0;;;;;;;;;;;;;;;;;:::i;11797:259::-;;;;;;;;;;;;;;;;-1:-1:-1;11797:259:0;-1:-1:-1;;;;;11797:259:0;;:::i;17140:117::-;;;:::i;:::-;;;;;;;;;;;;;;;;;;;12315:420;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;12315:420:0;;;;;;;;;;;;;:::i;13977:80::-;;;:::i;7814:119::-;;;;;;;;;;;;;;;;-1:-1:-1;7814:119:0;-1:-1:-1;;;;;7814:119:0;;:::i;9871:130::-;;;:::i;14626:207::-;;;;;;;;;;;;;;;;-1:-1:-1;14626:207:0;-1:-1:-1;;;;;14626:207:0;;:::i;13649:155::-;;;:::i;14448:170::-;;;;;;;;;;;;;;;;-1:-1:-1;14448:170:0;-1:-1:-1;;;;;14448:170:0;;:::i;9464:102::-;;;:::i;:::-;;;;-1:-1:-1;;;;;9464:102:0;;;;;;;;;;;;;;17015:117;;;:::i;15474:416::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;15474:416:0;;;;;;;;:::i;12743:252::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;12743:252:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;12064:243;;;;;;;;;;;;;;;;-1:-1:-1;12064:243:0;-1:-1:-1;;;;;12064:243:0;;:::i;13003:179::-;;;;;;;;;;;;;;;;-1:-1:-1;13003:179:0;-1:-1:-1;;;;;13003:179:0;;:::i;7941:183::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;7941:183:0;;;;;;;;;;:::i;14841:143::-;;;;;;;;;;;;;;;;-1:-1:-1;14841:143:0;-1:-1:-1;;;;;14841:143:0;;:::i;9574:289::-;;;;;;;;;;;;;;;;-1:-1:-1;9574:289:0;-1:-1:-1;;;;;9574:289:0;;:::i;13812:157::-;;;:::i;16898:109::-;16994:5;;;;;;;;;;;;-1:-1:-1;;;16994:5:0;;;;;16898:109::o;16559:331::-;16663:12;-1:-1:-1;;;;;16715:21:0;;16693:116;;;;-1:-1:-1;;;16693:116:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16820:37;16829:10;16841:7;16850:6;16820:8;:37::i;:::-;-1:-1:-1;16878:4:0;;16559:331;-1:-1:-1;;;16559:331:0:o;7708:100::-;7754:13;7788:12;;7708:100::o;15898:653::-;-1:-1:-1;;;;;14372:15:0;;16101:12;14372:15;;;:7;:15;;;;;;16021:4;;14372:15;;14371:16;14363:57;;;;;-1:-1:-1;;;14363:57:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;13552:7:::1;::::0;::::1;;13551:8;13543:78;;;;-1:-1:-1::0;;;13543:78:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1::0;;;;;10747:18:0;::::2;;::::0;;;:12:::2;:18;::::0;;;;;16069:4;;16075:6;;10747:30:::2;::::0;16075:6;10747:30:::2;:22;:30;:::i;:::-;-1:-1:-1::0;;;;;10728:15:0;::::2;;::::0;;;:9:::2;:15;::::0;;;;;:49:::2;;10720:113;;;;-1:-1:-1::0;;;10720:113:0::2;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1::0;;;;;16153:16:0;::::3;16131:116;;;;-1:-1:-1::0;;;16131:116:0::3;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16258:27;16268:4;16274:2;16278:6;16258:9;:27::i;:::-;;16296:222;16319:4;16338:10;16363:144;16415:6;16363:144;;;;;;;;;;;;;;;;;-1:-1:-1::0;;;;;16363:17:0;::::3;;::::0;;;:11:::3;:17;::::0;;;;;;;16381:10:::3;16363:29:::0;;;;;;;;;:144;::::3;:33;:144;:::i;:::-;16296:8;:222::i;:::-;-1:-1:-1::0;16539:4:0::3;::::0;15898:653;-1:-1:-1;;;;;;;15898:653:0:o;11797:259::-;11845:12;;11870:154;-1:-1:-1;;;;;11893:12:0;;;;;;:6;:12;;;;;:19;11889:23;;11870:154;;;-1:-1:-1;;;;;11936:12:0;;;;;;:6;:12;;;;;:15;;11958:3;;11936:12;11949:1;;11936:15;;;;;;;;;;;;;;;;:19;;;:25;11933:80;;;11981:16;11989:4;11995:1;11981:7;:16::i;:::-;;11933:80;11914:3;;11870:154;;;-1:-1:-1;12044:4:0;;11797:259;-1:-1:-1;;11797:259:0:o;17140:117::-;15281:2;;17140:117::o;12315:420::-;9355:6;;12446:12;;-1:-1:-1;;;;;9355:6:0;9341:10;:20;9319:117;;;;-1:-1:-1;;;9319:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;12498:23:0;::::1;12476:135;;;;-1:-1:-1::0;;;12476:135:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12622:40;12632:10;12644:9;12655:6;12622:9;:40::i;:::-;;12673:29;12679:9;12690:6;12698:3;12673:5;:29::i;:::-;-1:-1:-1::0;12723:4:0::1;::::0;12315:420;-1:-1:-1;;;;12315:420:0:o;13977:80::-;14042:7;;;;13977:80;:::o;7814:119::-;-1:-1:-1;;;;;7909:16:0;7871:15;7909:16;;;:9;:16;;;;;;;7814:119::o;9871:130::-;9355:6;;9928:12;;-1:-1:-1;;;;;9355:6:0;9341:10;:20;9319:117;;;;-1:-1:-1;;;9319:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9963:30:::1;9990:1;9963:18;:30::i;:::-;9953:40;;9871:130:::0;:::o;14626:207::-;9355:6;;14715:12;;-1:-1:-1;;;;;9355:6:0;9341:10;:20;9319:117;;;;-1:-1:-1;;;9319:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;14745:15:0;::::1;14763:5;14745:15:::0;;;:7:::1;:15;::::0;;;;;:23;;-1:-1:-1;;14745:23:0::1;::::0;;14784:16;::::1;::::0;14763:5;14784:16:::1;-1:-1:-1::0;14821:4:0::1;::::0;14626:207;-1:-1:-1;14626:207:0:o;13649:155::-;9355:6;;13708:12;;-1:-1:-1;;;;;9355:6:0;9341:10;:20;9319:117;;;;-1:-1:-1;;;9319:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13552:7:::1;::::0;::::1;;13551:8;13543:78;;;;-1:-1:-1::0;;;13543:78:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13733:7:::2;:14:::0;;-1:-1:-1;;13733:14:0::2;13743:4;13733:14;::::0;;13763:8:::2;::::0;::::2;::::0;13733:7:::2;::::0;13763:8:::2;-1:-1:-1::0;13792:4:0::2;::::0;13649:155::o;14448:170::-;9355:6;;14508:12;;-1:-1:-1;;;;;9355:6:0;9341:10;:20;9319:117;;;;-1:-1:-1;;;9319:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;14533:15:0;::::1;;::::0;;;:7:::1;:15;::::0;;;;;:22;;-1:-1:-1;;14533:22:0::1;14551:4;14533:22;::::0;;14571:14;::::1;::::0;14533:15;14571:14:::1;-1:-1:-1::0;14606:4:0::1;::::0;14448:170;-1:-1:-1;14448:170:0:o;9464:102::-;9552:6;;-1:-1:-1;;;;;9552:6:0;;9464:102::o;17015:117::-;17117:7;;;;;;;;;;;;-1:-1:-1;;;17117:7:0;;;;;17015:117::o;15474:416::-;15579:10;15671:12;14372:15;;;:7;:15;;;;;;15671:12;;15579:10;14372:15;;14371:16;14363:57;;;;;-1:-1:-1;;;14363:57:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;13552:7:::1;::::0;::::1;;13551:8;13543:78;;;;-1:-1:-1::0;;;13543:78:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15633:10:::2;10747:18;::::0;;;:12:::2;:18;::::0;;;;;15645:6;;10747:30:::2;::::0;15645:6;10747:30:::2;:22;:30;:::i;:::-;-1:-1:-1::0;;;;;10728:15:0;::::2;;::::0;;;:9:::2;:15;::::0;;;;;:49:::2;;10720:113;;;;-1:-1:-1::0;;;10720:113:0::2;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1::0;;;;;15723:16:0;::::3;15701:112;;;;-1:-1:-1::0;;;15701:112:0::3;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15824:33;15834:10;15846:2;15850:6;15824:9;:33::i;:::-;-1:-1:-1::0;15878:4:0::3;::::0;15474:416;-1:-1:-1;;;;;;15474:416:0:o;12743:252::-;12842:14;12858:11;12887:20;;:::i;:::-;-1:-1:-1;;;;;12910:14:0;;;;;;:6;:14;;;;;:21;;12925:5;;12910:21;;;;;;;;;;;;;;;12887:44;;;;;;;;;12910:21;;;;;12887:44;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;12743:252:0;-1:-1:-1;;;;12743:252:0:o;12064:243::-;9355:6;;12154:12;;-1:-1:-1;;;;;9355:6:0;9341:10;:20;9319:117;;;;-1:-1:-1;;;9319:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12188:9:::1;12184:91;-1:-1:-1::0;;;;;12207:12:0;::::1;;::::0;;;:6:::1;:12;::::0;;;;:19;12203:23;::::1;12184:91;;;12247:16;12255:4;12261:1;12247:7;:16::i;:::-;-1:-1:-1::0;12228:3:0::1;;12184:91;;13003:179:::0;-1:-1:-1;;;;;13113:20:0;13062:14;13113:20;;;:12;:20;;;;;;;;;13153:6;:14;;;;;;:21;13113:20;;13003:179::o;7941:183::-;-1:-1:-1;;;;;8089:18:0;;;8042:17;8089:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;7941:183::o;14841:143::-;-1:-1:-1;;;;;14961:15:0;14925:11;14961:15;;;:7;:15;;;;;;;;;14841:143::o;9574:289::-;9355:6;;9672:12;;-1:-1:-1;;;;;9355:6:0;9341:10;:20;9319:117;;;;-1:-1:-1;;;9319:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;9710:22:0;::::1;9702:104;;;;-1:-1:-1::0;;;9702:104:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9827:28;9846:8;9827:18;:28::i;:::-;9817:38:::0;9574:289;-1:-1:-1;;9574:289:0:o;13812:157::-;9355:6;;13870:12;;-1:-1:-1;;;;;9355:6:0;9341:10;:20;9319:117;;;;-1:-1:-1;;;9319:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13414:7:::1;::::0;::::1;;13406:73;;;;-1:-1:-1::0;;;13406:73:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13895:7:::2;:15:::0;;-1:-1:-1;;13895:15:0::2;::::0;;13926:10:::2;::::0;::::2;::::0;13905:5:::2;::::0;13926:10:::2;-1:-1:-1::0;13957:4:0::2;::::0;13812:157::o;902:181::-;960:7;992:5;;;1016:6;;;;1008:46;;;;;-1:-1:-1;;;1008:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;1074:1;902:181;-1:-1:-1;;;902:181:0:o;6571:249::-;-1:-1:-1;;;;;6703:18:0;;;6673:12;6703:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;:36;;;6755:32;;;;;;;6673:12;;6703:27;:18;6755:32;;;;;;;;;;;-1:-1:-1;6808:4:0;;6571:249;-1:-1:-1;;;6571:249:0:o;6161:402::-;6258:12;6306:130;6340:6;6306:130;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;6306:15:0;;;;;;:9;:15;;;;;;;:130;;:19;:130;:::i;:::-;-1:-1:-1;;;;;6288:15:0;;;;;;;:9;:15;;;;;;:148;;;;6463:13;;;;;;;:25;;6481:6;6463:25;:17;:25;:::i;:::-;-1:-1:-1;;;;;6447:13:0;;;;;;;:9;:13;;;;;;;;;:41;;;;6504:26;;;;;;;6447:13;;6504:26;;;;;;;;;;;;;-1:-1:-1;6551:4:0;;6161:402;-1:-1:-1;;;6161:402:0:o;1831:224::-;1944:7;1985:12;1977:6;;;;1969:29;;;;-1:-1:-1;;;1969:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;2021:5:0;;;1831:224::o;11417:372::-;-1:-1:-1;;;;;11530:12:0;;11481;11530;;;:6;:12;;;;;:19;;11481:12;;11530;11543:5;;11530:19;;;;;;;;;;;;;;;;;;;;;11604:11;;-1:-1:-1;;;;;11581:18:0;;;;:12;:18;;;;;;;;11530:19;;-1:-1:-1;11581:35:0;;:18;:35;:22;:35;:::i;:::-;-1:-1:-1;;;;;11560:18:0;;;;;;:12;:18;;;;;;;;;:56;;;;11645:11;;11632:25;;;;;;;11560:18;;11632:25;;;;;;;;;-1:-1:-1;;;;;11690:12:0;;;;;;:6;:12;;;;;11703:19;;-1:-1:-1;;11703:23:0;;;11690:37;;;;;;;;;;;;;;;;11668:6;:12;11675:4;-1:-1:-1;;;;;11668:12:0;-1:-1:-1;;;;;11668:12:0;;;;;;;;;;;;11681:5;11668:19;;;;;;;;;;;;;;;;:59;;:19;;;;;:59;;;;;;;;;;;;;;;;-1:-1:-1;;;;;11738:12:0;;;;:6;:12;;;;;;:18;;;;;;;;;;;;;;;-1:-1:-1;;11738:18:0;;;;;;;;;;;;;;;;;;;;;11417:372;-1:-1:-1;;;;11417:372:0:o;10861:548::-;10955:12;10999:3;10993;:9;10985:65;;;;-1:-1:-1;;;10985:65:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;11113:18:0;;;;;;:12;:18;;;;;;11102:30;;:6;;:30;:10;:30;:::i;:::-;-1:-1:-1;;;;;11083:15:0;;;;;;:9;:15;;;;;;:49;;11061:163;;;;-1:-1:-1;;;11061:163:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;11256:18:0;;;;;;:12;:18;;;;;;:30;;11279:6;11256:30;:22;:30;:::i;:::-;-1:-1:-1;;;;;11235:18:0;;;;;;:12;:18;;;;;;;;:51;;;;11297:6;:12;;;;;11315:21;;;;;;;;;;;;;;;;11297:40;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;11353:23;;;;;;;;;;;;;11235:18;;11353:23;;;;;;;;;-1:-1:-1;11397:4:0;;10861:548;-1:-1:-1;;;10861:548:0:o;10009:193::-;10124:6;;10103:38;;10073:12;;-1:-1:-1;;;;;10103:38:0;;;;10124:6;;;10103:38;;10073:12;;10103:38;-1:-1:-1;10152:6:0;:17;;-1:-1:-1;;;;;;10152:17:0;-1:-1:-1;;;;;10152:17:0;;;;;;;;;;-1:-1:-1;;10009:193:0:o;1358:136::-;1416:7;1443:43;1447:1;1450;1443:43;;;;;;;;;;;;;;;;;:3;:43::i;-1:-1:-1:-;;;;;;;;;;;;;;;;;;;:::o

Swarm Source

ipfs://0b1fa1469a16cdc6fd366824911912122122f0acc9e228337d2284cc19e3ac96
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.