ETH Price: $3,159.35 (-3.35%)

Token

Dogecoin (DOGE)
 

Overview

Max Total Supply

43,027,241.33418359 DOGE

Holders

3,662

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 8 Decimals)

Balance
2,882.35866471 DOGE

Value
$0.00
0x299d68c560f8dd5f1a29895a1fe81021404c698d
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
Dogecoin

Compiler Version
v0.8.0+commit.c7dfd78e

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity Multiple files format)

File 2 of 8: Dogecoin.sol
// SPDX-License-Identifier: DOGE WORLD
pragma solidity ^0.8.0;

import "../ERC20.sol";
import "../SafelyOwned.sol";
import "./IDogecoin.sol";

contract Dogecoin is ERC20("Dogecoin", "DOGE", 8), SafelyOwned, IDogecoin
{
    string public constant url = "https://doge.gay";

    mapping (uint256 => bool) public override instructionFulfilled;
    mapping (address => bool) public override minters;

    bytes32 private constant joinPartyTypeHash = keccak256("JoinParty(address to,uint256 amount,uint256 instructionId)");

    function setMinter(address _minter, bool _canMint) public ownerOnly()
    {
        minters[_minter] = _canMint;
        emit Minter(_minter, _canMint);
    }
    
    function joinParty(address _to, uint256 _amount, uint256 _instructionId, uint8 _v, bytes32 _r, bytes32 _s) public override
    {
        require (!instructionFulfilled[_instructionId], "Instruction already fulfilled");
        bytes32 hash = getSigningHash(keccak256(abi.encode(joinPartyTypeHash, _to, _amount, _instructionId)));
        address signer = ecrecover(hash, _v, _r, _s);
        require(minters[signer], "Not signed by a minter");

        mintCore(_to, _amount);
        
        instructionFulfilled[_instructionId] = true;
        emit DogeJoinedTheParty(_instructionId, _to, _amount);
    }

    function multiJoinParty(JoinPartyInstruction[] calldata _instructions) public override
    {
        uint256 len = _instructions.length;
        bool anySuccess = false;

        for (uint256 x=0; x<len; ++x) {
            uint256 instructionId = _instructions[x].instructionId;
            if (instructionFulfilled[instructionId]) { continue; }

            address to = _instructions[x].to;
            uint256 amount = _instructions[x].amount;
            bytes32 hash = getSigningHash(keccak256(abi.encode(joinPartyTypeHash, to, amount, instructionId)));
            address signer = ecrecover(hash, _instructions[x].v, _instructions[x].r, _instructions[x].s);
            if (!minters[signer]) { continue; }

            mintCore(to, amount);

            instructionFulfilled[instructionId] = true;
            anySuccess = true;
            emit DogeJoinedTheParty(instructionId, to, amount);
        }
        require (anySuccess, "No success");
    }

    function crossBridge(address _controller, uint256 _amount) public override
    {
        burnCore(msg.sender, _amount);
        emit DogeCrossingBridge(_controller, _amount);
    }

    function transfer(address _to, uint256 _amount) public override returns (bool)
    {
        if (_to == address(this)) {
            crossBridge(msg.sender, _amount);
            return true;
        }
        return super.transfer(_to, _amount);
    }

    function transferFrom(address _from, address _to, uint256 _amount) public override returns (bool)
    {
        require(_to != address(this), "Use crossBridge() or transfer() to transfer DOGE back to the bridge");
        return super.transferFrom(_from, _to, _amount);
    }
}

File 1 of 8: Address.sol
// SPDX-License-Identifier: DOGE WORLD
pragma solidity ^0.8.0;

/**
 * @dev Collection of functions related to the address type
 */
library Address 
{
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        // solhint-disable-next-line no-inline-assembly
        assembly { size := extcodesize(account) }
        return size > 0;
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success, ) = recipient.call{ value: amount }("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain`call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
      return functionCall(target, data, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    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");
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    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");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{ value: value }(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
        return functionStaticCall(target, data, "Address: low-level static call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data, string memory errorMessage) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.staticcall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.3._
     */
    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionDelegateCall(target, data, "Address: low-level delegate call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.3._
     */
    function functionDelegateCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    function _verifyCallResult(bool success, bytes memory returndata, string memory errorMessage) private pure returns(bytes memory) {
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

File 3 of 8: ERC20.sol
// SPDX-License-Identifier: DOGE WORLD
pragma solidity ^0.8.0;

import "./IERC20.sol";

abstract contract ERC20 is IERC20
{
    string public override name;
    string public override symbol;
    uint8 public immutable override decimals;

    uint256 public override totalSupply;
    mapping (address => uint256) public override balanceOf;
    mapping (address => mapping(address => uint256)) public override allowance;
    mapping (address => uint256) public override nonces;

    bytes32 private immutable cachedDomainSeparator;
    uint256 private immutable cachedChainId = block.chainid;
    bytes32 private constant permitTypeHash = keccak256("Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)");
    bytes32 private constant eip712DomainHash = keccak256("EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)");
    bytes32 private constant versionDomainHash = keccak256(bytes("1"));
    bytes32 private immutable nameDomainHash;

    constructor(string memory _name, string memory _symbol, uint8 _decimals)
    {
        name = _name;
        symbol = _symbol;
        decimals = _decimals;

        bytes32 _nameDomainHash = keccak256(bytes(_name));
        nameDomainHash = _nameDomainHash;
        cachedDomainSeparator = keccak256(abi.encode(
            eip712DomainHash,
            _nameDomainHash,
            versionDomainHash,
            block.chainid,
            address(this)));
    }

    function approveCore(address _owner, address _spender, uint256 _amount) internal virtual returns (bool)
    {
        allowance[_owner][_spender] = _amount;
        emit Approval(_owner, _spender, _amount);
        return true;
    }

    function approve(address _spender, uint256 _amount) public virtual override returns (bool)
    {
        return approveCore(msg.sender, _spender, _amount);
    }

    function increaseAllowance(address _spender, uint256 _toAdd) public virtual override returns (bool)
    {
        return approve(_spender, allowance[msg.sender][_spender] + _toAdd);
    }
    
    function decreaseAllowance(address _spender, uint256 _toRemove) public virtual override returns (bool)
    {
        return approve(_spender, allowance[msg.sender][_spender] - _toRemove);
    }

    function transfer(address _to, uint256 _amount) public virtual override returns (bool)
    {
        return transferCore(msg.sender, _to, _amount);
    }

    function transferFrom(address _from, address _to, uint256 _amount) public virtual override returns (bool)
    {
        uint256 oldAllowance = allowance[_from][msg.sender];
        require (oldAllowance >= _amount, "Insufficient allowance");
        if (oldAllowance != type(uint256).max) {
            allowance[_from][msg.sender] = oldAllowance - _amount;
        }
        return transferCore(_from, _to, _amount);
    }

    function transferCore(address _from, address _to, uint256 _amount) internal virtual returns (bool)
    {
        require (_from != address(0));
        if (_to == address(0)) {
            burnCore(_from, _amount);
            return true;
        }
        uint256 oldBalance = balanceOf[_from];
        require (oldBalance >= _amount, "Insufficient balance");
        balanceOf[_from] = oldBalance - _amount;
        balanceOf[_to] += _amount;
        emit Transfer(_from, _to, _amount);
        return true;
    }

    function mintCore(address _to, uint256 _amount) internal virtual
    {
        require (_to != address(0));

        totalSupply += _amount;
        balanceOf[_to] += _amount;
        emit Transfer(address(0), _to, _amount);
    }

    function burnCore(address _from, uint256 _amount) internal virtual
    {
        uint256 oldBalance = balanceOf[_from];
        require (oldBalance >= _amount, "Insufficient balance");
        balanceOf[_from] = oldBalance - _amount;
        totalSupply -= _amount;
        emit Transfer(_from, address(0), _amount);
    }

    function burn(uint256 _amount) public override
    {
        burnCore(msg.sender, _amount);
    }

    function DOMAIN_SEPARATOR() public override view returns (bytes32) 
    {
        if (block.chainid == cachedChainId) {
            return cachedDomainSeparator;
        }
        return keccak256(abi.encode(
            eip712DomainHash,
            nameDomainHash,
            versionDomainHash,
            block.chainid,
            address(this)));
    }

    function getSigningHash(bytes32 _dataHash) internal view returns (bytes32) 
    {
        return keccak256(abi.encodePacked("\x19\x01", DOMAIN_SEPARATOR(), _dataHash));
    }

    function permit(address _owner, address _spender, uint256 _amount, uint256 _deadline, uint8 _v, bytes32 _r, bytes32 _s) public virtual override
    {
        require (block.timestamp <= _deadline, "Deadline expired");

        uint256 nonce = nonces[_owner];
        bytes32 hash = getSigningHash(keccak256(abi.encode(permitTypeHash, _owner, _spender, _amount, nonce, _deadline)));
        address signer = ecrecover(hash, _v, _r, _s);
        require (signer == _owner, "Invalid signature");
        nonces[_owner] = nonce + 1;
        approveCore(_owner, _spender, _amount);
    }
}

File 4 of 8: IDogecoin.sol
// SPDX-License-Identifier: DOGE WORLD
pragma solidity ^0.8.0;

struct JoinPartyInstruction
{
    uint256 amount;
    uint256 instructionId;
    address to;
    uint8 v;
    bytes32 r;
    bytes32 s;
}

interface IDogecoin
{
    event DogeCrossingBridge(address indexed controller, uint256 amount);
    event DogeJoinedTheParty(uint256 indexed instructionId, address indexed recipient, uint256 amount);
    event Minter(address indexed minter, bool canMint);

    function instructionFulfilled(uint256 _instructionId) external view returns (bool);
    function minters(address _minter) external view returns (bool);

    function joinParty(address _to, uint256 _amount, uint256 _instructionId, uint8 _v, bytes32 _r, bytes32 _s) external;
    function multiJoinParty(JoinPartyInstruction[] calldata _instructions) external;
    function crossBridge(address _controller, uint256 _amount) external;
}

File 5 of 8: IERC20.sol
// SPDX-License-Identifier: DOGE WORLD
pragma solidity ^0.8.0;

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

    function name() external view returns (string memory);
    function symbol() external view returns (string memory);
    function decimals() external view returns (uint8);
    function DOMAIN_SEPARATOR() external view returns (bytes32);

    function totalSupply() external view returns (uint256);
    function balanceOf(address _account) external view returns (uint256);
    function allowance(address _owner, address _spender) external view returns (uint256);
    function nonces(address _owner) external view returns (uint256);

    function approve(address _spender, uint256 _amount) external returns (bool);
    function transfer(address _to, uint256 _amount) external returns (bool);
    function transferFrom(address _from, address _to, uint256 _amount) external returns (bool);
    function increaseAllowance(address _spender, uint256 _toAdd) external returns (bool);
    function decreaseAllowance(address _spender, uint256 _toRemove) external returns (bool);
    function burn(uint256 _amount) external;
    function permit(address _owner, address _spender, uint256 _amount, uint256 _deadline, uint8 _v, bytes32 _r, bytes32 _s) external;
}

File 6 of 8: ISafelyOwned.sol
// SPDX-License-Identifier: DOGE WORLD
pragma solidity ^0.8.0;

import "./IERC20.sol";

interface ISafelyOwned
{
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    function owner() external view returns (address);

    function transferOwnership(address _newOwner) external;
    function claimOwnership() external;
    function recoverTokens(IERC20 _token) external;
    function recoverETH() external;
}

File 7 of 8: SafeERC20.sol
// SPDX-License-Identifier: DOGE WORLD
pragma solidity ^0.8.0;

import "./IERC20.sol";
import "./Address.sol";

/**
 * @title SafeERC20
 * @dev Wrappers around ERC20 operations that throw on failure (when the token
 * contract returns false). Tokens that return no value (and instead revert or
 * throw on failure) are also supported, non-reverting calls are assumed to be
 * successful.
 * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
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));
    }

    /**
     * @dev Deprecated. This function has issues similar to the ones found in
     * {IERC20-approve}, and its usage is discouraged.
     *
     * Whenever possible, use {safeIncreaseAllowance} and
     * {safeDecreaseAllowance} instead.
     */
    function safeApprove(IERC20 token, address spender, uint256 value) internal {        
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value));
    }

    /**
     * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement
     * on the return value: the return value is optional (but if data is returned, it must not be false).
     * @param token The token targeted by the call.
     * @param data The call data (encoded using abi.encode or one of its variants).
     */
    function _callOptionalReturn(IERC20 token, bytes memory data) private {
        // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since
        // we're implementing it ourselves. We use {Address.functionCall} to perform this call, which verifies that
        // the target address contains contract code and also asserts for success in the low-level call.

        bytes memory returndata = address(token).functionCall(data, "SafeERC20: low-level call failed");
        if (returndata.length > 0) { // Return data is optional
            // solhint-disable-next-line max-line-length
            require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed");
        }
    }
}

File 8 of 8: SafelyOwned.sol
// SPDX-License-Identifier: DOGE WORLD
pragma solidity ^0.8.0;

import "./ISafelyOwned.sol";
import "./SafeERC20.sol";

abstract contract SafelyOwned is ISafelyOwned
{
    using SafeERC20 for IERC20;
    
    address public override owner = msg.sender;
    address internal pendingOwner;

    modifier ownerOnly()
    {
        require (msg.sender == owner, "Owner only");
        _;
    }

    function transferOwnership(address _newOwner) public override ownerOnly()
    {
        pendingOwner = _newOwner;
    }

    function claimOwnership() public override
    {
        require (pendingOwner == msg.sender);
        pendingOwner = address(0);
        emit OwnershipTransferred(owner, msg.sender);
        owner = msg.sender;
    }

    function recoverTokens(IERC20 _token) public override ownerOnly() 
    {
        require (canRecoverTokens(_token));
        _token.safeTransfer(msg.sender, _token.balanceOf(address(this)));
    }

    function canRecoverTokens(IERC20 _token) internal virtual view returns (bool) 
    { 
        return address(_token) != address(this); 
    }

    function recoverETH() public override ownerOnly()
    {
        require (canRecoverETH());
        (bool success,) = msg.sender.call{ value: address(this).balance }("");
        require (success, "Transfer fail");
    }

    function canRecoverETH() internal virtual view returns (bool) 
    {
        return true;
    }
}

Contract Security Audit

Contract ABI

[{"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":"controller","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"DogeCrossingBridge","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"instructionId","type":"uint256"},{"indexed":true,"internalType":"address","name":"recipient","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"DogeJoinedTheParty","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"minter","type":"address"},{"indexed":false,"internalType":"bool","name":"canMint","type":"bool"}],"name":"Minter","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":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"},{"inputs":[],"name":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","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":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"claimOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_controller","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"crossBridge","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_spender","type":"address"},{"internalType":"uint256","name":"_toRemove","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_spender","type":"address"},{"internalType":"uint256","name":"_toAdd","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"instructionFulfilled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"uint256","name":"_instructionId","type":"uint256"},{"internalType":"uint8","name":"_v","type":"uint8"},{"internalType":"bytes32","name":"_r","type":"bytes32"},{"internalType":"bytes32","name":"_s","type":"bytes32"}],"name":"joinParty","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"minters","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"components":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"instructionId","type":"uint256"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"internalType":"struct JoinPartyInstruction[]","name":"_instructions","type":"tuple[]"}],"name":"multiJoinParty","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"nonces","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":"_owner","type":"address"},{"internalType":"address","name":"_spender","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"uint256","name":"_deadline","type":"uint256"},{"internalType":"uint8","name":"_v","type":"uint8"},{"internalType":"bytes32","name":"_r","type":"bytes32"},{"internalType":"bytes32","name":"_s","type":"bytes32"}],"name":"permit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"recoverETH","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"_token","type":"address"}],"name":"recoverTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_minter","type":"address"},{"internalType":"bool","name":"_canMint","type":"bool"}],"name":"setMinter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","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":"","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":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"url","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"}]

6101006040524660c052600680546001600160a01b031916331790553480156200002857600080fd5b506040805180820182526008808252672237b3b2b1b7b4b760c11b602080840191825284518086019095526004855263444f474560e01b90850152825192939262000076916000916200015c565b5081516200008c9060019060208501906200015c565b507fff0000000000000000000000000000000000000000000000000000000000000060f882901b16608052825160208085019190912060e081905260408051808201825260018152603160f81b9084015251909162000136917f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f9184917fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc691469130910162000202565b60408051601f19818403018152919052805160209091012060a052506200026b92505050565b8280546200016a906200022e565b90600052602060002090601f0160209004810192826200018e5760008555620001d9565b82601f10620001a957805160ff1916838001178555620001d9565b82800160010185558215620001d9579182015b82811115620001d9578251825591602001919060010190620001bc565b50620001e7929150620001eb565b5090565b5b80821115620001e75760008155600101620001ec565b9485526020850193909352604084019190915260608301526001600160a01b0316608082015260a00190565b6002810460018216806200024357607f821691505b602082108114156200026557634e487b7160e01b600052602260045260246000fd5b50919050565b60805160f81c60a05160c05160e051611cb7620002a860003960006106de0152600061064f01526000610678015260006106290152611cb76000f3fe608060405234801561001057600080fd5b50600436106101a95760003560e01c806370a08231116100f9578063ac1217eb11610097578063d505accf11610071578063d505accf1461034c578063dd62ed3e1461035f578063f2fde38b14610372578063f46eccc414610385576101a9565b8063ac1217eb14610313578063ce277ece14610326578063cf456ae714610339576101a9565b806395d89b41116100d357806395d89b41146102d2578063a1f6b2a7146102da578063a457c2d7146102ed578063a9059cbb14610300576101a9565b806370a08231146102975780637ecebe00146102aa5780638da5cb5b146102bd576101a9565b806323b872dd116101665780633950935111610140578063395093511461026157806342966c68146102745780634e71e0c8146102875780635600f04f1461028f576101a9565b806323b872dd14610231578063313ce567146102445780633644e51514610259576101a9565b80630614117a146101ae57806306fdde03146101b8578063095ea7b3146101d6578063148e7133146101f657806316114acd1461020957806318160ddd1461021c575b600080fd5b6101b6610398565b005b6101c061045b565b6040516101cd91906118e3565b60405180910390f35b6101e96101e436600461166f565b6104e9565b6040516101cd919061182d565b6101e961020436600461177f565b6104ff565b6101b6610217366004611541565b610514565b6102246105e1565b6040516101cd9190611838565b6101e961023f366004611595565b6105e7565b61024c610627565b6040516101cd9190611b89565b61022461064b565b6101e961026f36600461166f565b610746565b6101b661028236600461177f565b61077b565b6101b6610785565b6101c06107f8565b6102246102a5366004611541565b610824565b6102246102b8366004611541565b610836565b6102c5610848565b6040516101cd9190611800565b6101c0610857565b6101b66102e836600461169a565b610864565b6101e96102fb36600461166f565b6109ed565b6101e961030e36600461166f565b610a22565b6101b661032136600461166f565b610a51565b6101b66103343660046116f3565b610aa0565b6101b6610347366004611642565b610d5a565b6101b661035a3660046115d5565b610dd8565b61022461036d36600461155d565b610f15565b6101b6610380366004611541565b610f32565b6101e9610393366004611541565b610f7e565b6006546001600160a01b031633146103cb5760405162461bcd60e51b81526004016103c290611ab4565b60405180910390fd5b6103d3610f93565b6103dc57600080fd5b6000336001600160a01b0316476040516103f590610743565b60006040518083038185875af1925050503d8060008114610432576040519150601f19603f3d011682016040523d82523d6000602084013e610437565b606091505b50509050806104585760405162461bcd60e51b81526004016103c29061194d565b50565b6000805461046890611bf2565b80601f016020809104026020016040519081016040528092919081815260200182805461049490611bf2565b80156104e15780601f106104b6576101008083540402835291602001916104e1565b820191906000526020600020905b8154815290600101906020018083116104c457829003601f168201915b505050505081565b60006104f6338484610f98565b90505b92915050565b60086020526000908152604090205460ff1681565b6006546001600160a01b0316331461053e5760405162461bcd60e51b81526004016103c290611ab4565b61054781611008565b61055057600080fd5b61045833826001600160a01b03166370a08231306040518263ffffffff1660e01b81526004016105809190611800565b60206040518083038186803b15801561059857600080fd5b505afa1580156105ac573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906105d09190611797565b6001600160a01b038416919061101b565b60025481565b60006001600160a01b0383163014156106125760405162461bcd60e51b81526004016103c290611974565b61061d848484611076565b90505b9392505050565b7f000000000000000000000000000000000000000000000000000000000000000081565b60007f000000000000000000000000000000000000000000000000000000000000000046141561069c57507f0000000000000000000000000000000000000000000000000000000000000000610743565b60408051808201825260018152603160f81b602091820152905161072a917f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f917f0000000000000000000000000000000000000000000000000000000000000000917fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6914691309101611899565b6040516020818303038152906040528051906020012090505b90565b3360009081526004602090815260408083206001600160a01b03861684529091528120546104f69084906101e4908590611b97565b6104583382611106565b6007546001600160a01b0316331461079c57600080fd5b600780546001600160a01b031916905560065460405133916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600680546001600160a01b03191633179055565b6040518060400160405280601081526020016f68747470733a2f2f646f67652e67617960801b81525081565b60036020526000908152604090205481565b60056020526000908152604090205481565b6006546001600160a01b031681565b6001805461046890611bf2565b60008481526008602052604090205460ff16156108935760405162461bcd60e51b81526004016103c290611916565b60006108ea7f035c6f290d8c384f56de9d82994e71a65abeec130c683387e94b06260631633a8888886040516020016108cf9493929190611875565b604051602081830303815290604052805190602001206111c7565b905060006001828686866040516000815260200160405260405161091194939291906118c5565b6020604051602081039080840390855afa158015610933573d6000803e3d6000fd5b505060408051601f1901516001600160a01b03811660009081526009602052919091205490925060ff16905061097b5760405162461bcd60e51b81526004016103c290611b0f565b6109858888611200565b60008681526008602052604090819020805460ff19166001179055516001600160a01b0389169087907f246b335ff653677f0265d2c996ae2bf3c388b8103f39929758eda76493c6a508906109db908b90611838565b60405180910390a35050505050505050565b3360009081526004602090815260408083206001600160a01b03861684529091528120546104f69084906101e4908590611baf565b60006001600160a01b038316301415610a4757610a3f3383610a51565b5060016104f9565b6104f683836112a1565b610a5b3382611106565b816001600160a01b03167f31c2da40163e9552aab7b639958e037ef260cc96264c57ea4dd19e9884c44d9182604051610a949190611838565b60405180910390a25050565b806000805b82811015610d36576000858583818110610acf57634e487b7160e01b600052603260045260246000fd5b602060c090910292909201820135600081815260089093526040909220549192505060ff1615610aff5750610d26565b6000868684818110610b2157634e487b7160e01b600052603260045260246000fd5b905060c002016040016020810190610b399190611541565b90506000878785818110610b5d57634e487b7160e01b600052603260045260246000fd5b905060c002016000013590506000610ba57f035c6f290d8c384f56de9d82994e71a65abeec130c683387e94b06260631633a8484876040516020016108cf9493929190611875565b905060006001828b8b89818110610bcc57634e487b7160e01b600052603260045260246000fd5b905060c002016060016020810190610be491906117af565b8c8c8a818110610c0457634e487b7160e01b600052603260045260246000fd5b905060c00201608001358d8d8b818110610c2e57634e487b7160e01b600052603260045260246000fd5b905060c0020160a0013560405160008152602001604052604051610c5594939291906118c5565b6020604051602081039080840390855afa158015610c77573d6000803e3d6000fd5b505060408051601f1901516001600160a01b03811660009081526009602052919091205490925060ff169050610cb1575050505050610d26565b610cbb8484611200565b60008581526008602052604090819020805460ff1916600190811790915590519097506001600160a01b0385169086907f246b335ff653677f0265d2c996ae2bf3c388b8103f39929758eda76493c6a50890610d18908790611838565b60405180910390a350505050505b610d2f81611c2d565b9050610aa5565b5080610d545760405162461bcd60e51b81526004016103c290611a90565b50505050565b6006546001600160a01b03163314610d845760405162461bcd60e51b81526004016103c290611ab4565b6001600160a01b03821660008181526009602052604090819020805460ff1916841515179055517fff452b3b9159b024a9098f0058c63eccd90d36b3584608202800d662f962bb6090610a9490849061182d565b83421115610df85760405162461bcd60e51b81526004016103c290611a66565b6001600160a01b0387166000908152600560209081526040808320549051909291610e53916108cf917f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9918d918d918d9189918e9101611841565b9050600060018287878760405160008152602001604052604051610e7a94939291906118c5565b6020604051602081039080840390855afa158015610e9c573d6000803e3d6000fd5b505050602060405103519050896001600160a01b0316816001600160a01b031614610ed95760405162461bcd60e51b81526004016103c290611a3b565b610ee4836001611b97565b6001600160a01b038b16600090815260056020526040902055610f088a8a8a610f98565b5050505050505050505050565b600460209081526000928352604080842090915290825290205481565b6006546001600160a01b03163314610f5c5760405162461bcd60e51b81526004016103c290611ab4565b600780546001600160a01b0319166001600160a01b0392909216919091179055565b60096020526000908152604090205460ff1681565b600190565b6001600160a01b0380841660008181526004602090815260408083209487168084529490915280822085905551909291907f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92590610ff6908690611838565b60405180910390a35060019392505050565b6001600160a01b0381163014155b919050565b6110718363a9059cbb60e01b848460405160240161103a929190611814565b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b0319909316929092179091526112ae565b505050565b6001600160a01b0383166000908152600460209081526040808320338452909152812054828110156110ba5760405162461bcd60e51b81526004016103c2906119dd565b60001981146110f2576110cd8382611baf565b6001600160a01b03861660009081526004602090815260408083203384529091529020555b6110fd85858561133d565b95945050505050565b6001600160a01b0382166000908152600360205260409020548181101561113f5760405162461bcd60e51b81526004016103c290611a0d565b6111498282611baf565b6001600160a01b03841660009081526003602052604081209190915560028054849290611177908490611baf565b90915550506040516000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906111ba908690611838565b60405180910390a3505050565b60006111d161064b565b826040516020016111e39291906117e5565b604051602081830303815290604052805190602001209050919050565b6001600160a01b03821661121357600080fd5b80600260008282546112259190611b97565b90915550506001600160a01b03821660009081526003602052604081208054839290611252908490611b97565b90915550506040516001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90611295908590611838565b60405180910390a35050565b60006104f633848461133d565b6000611303826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166114489092919063ffffffff16565b80519091501561107157808060200190518101906113219190611763565b6110715760405162461bcd60e51b81526004016103c290611b3f565b60006001600160a01b03841661135257600080fd5b6001600160a01b0383166113725761136a8483611106565b506001610620565b6001600160a01b038416600090815260036020526040902054828110156113ab5760405162461bcd60e51b81526004016103c290611a0d565b6113b58382611baf565b6001600160a01b0380871660009081526003602052604080822093909355908616815290812080548592906113eb908490611b97565b92505081905550836001600160a01b0316856001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef856040516114359190611838565b60405180910390a3506001949350505050565b606061061d84846000858561145c856114f1565b6114785760405162461bcd60e51b81526004016103c290611ad8565b600080866001600160a01b0316858760405161149491906117c9565b60006040518083038185875af1925050503d80600081146114d1576040519150601f19603f3d011682016040523d82523d6000602084013e6114d6565b606091505b50915091506114e68282866114f7565b979650505050505050565b3b151590565b60608315611506575081610620565b8251156115165782518084602001fd5b8160405162461bcd60e51b81526004016103c291906118e3565b803560ff8116811461101657600080fd5b600060208284031215611552578081fd5b813561062081611c5e565b6000806040838503121561156f578081fd5b823561157a81611c5e565b9150602083013561158a81611c5e565b809150509250929050565b6000806000606084860312156115a9578081fd5b83356115b481611c5e565b925060208401356115c481611c5e565b929592945050506040919091013590565b600080600080600080600060e0888a0312156115ef578283fd5b87356115fa81611c5e565b9650602088013561160a81611c5e565b9550604088013594506060880135935061162660808901611530565b925060a0880135915060c0880135905092959891949750929550565b60008060408385031215611654578182fd5b823561165f81611c5e565b9150602083013561158a81611c73565b60008060408385031215611681578182fd5b823561168c81611c5e565b946020939093013593505050565b60008060008060008060c087890312156116b2578182fd5b86356116bd81611c5e565b955060208701359450604087013593506116d960608801611530565b92506080870135915060a087013590509295509295509295565b60008060208385031215611705578182fd5b823567ffffffffffffffff8082111561171c578384fd5b818501915085601f83011261172f578384fd5b81358181111561173d578485fd5b86602060c083028501011115611751578485fd5b60209290920196919550909350505050565b600060208284031215611774578081fd5b815161062081611c73565b600060208284031215611790578081fd5b5035919050565b6000602082840312156117a8578081fd5b5051919050565b6000602082840312156117c0578081fd5b6104f682611530565b600082516117db818460208701611bc6565b9190910192915050565b61190160f01b81526002810192909252602282015260420190565b6001600160a01b0391909116815260200190565b6001600160a01b03929092168252602082015260400190565b901515815260200190565b90815260200190565b9586526001600160a01b0394851660208701529290931660408501526060840152608083019190915260a082015260c00190565b9384526001600160a01b039290921660208401526040830152606082015260800190565b9485526020850193909352604084019190915260608301526001600160a01b0316608082015260a00190565b93845260ff9290921660208401526040830152606082015260800190565b6000602082528251806020840152611902816040850160208701611bc6565b601f01601f19169190910160400192915050565b6020808252601d908201527f496e737472756374696f6e20616c72656164792066756c66696c6c6564000000604082015260600190565b6020808252600d908201526c151c985b9cd9995c8819985a5b609a1b604082015260600190565b60208082526043908201527f5573652063726f73734272696467652829206f72207472616e7366657228292060408201527f746f207472616e7366657220444f4745206261636b20746f207468652062726960608201526264676560e81b608082015260a00190565b602080825260169082015275496e73756666696369656e7420616c6c6f77616e636560501b604082015260600190565b602080825260149082015273496e73756666696369656e742062616c616e636560601b604082015260600190565b602080825260119082015270496e76616c6964207369676e617475726560781b604082015260600190565b60208082526010908201526f111958591b1a5b9948195e1c1a5c995960821b604082015260600190565b6020808252600a90820152694e6f207375636365737360b01b604082015260600190565b6020808252600a90820152694f776e6572206f6e6c7960b01b604082015260600190565b6020808252601d908201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604082015260600190565b6020808252601690820152752737ba1039b4b3b732b210313c90309036b4b73a32b960511b604082015260600190565b6020808252602a908201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6040820152691bdd081cdd58d8d9595960b21b606082015260800190565b60ff91909116815260200190565b60008219821115611baa57611baa611c48565b500190565b600082821015611bc157611bc1611c48565b500390565b60005b83811015611be1578181015183820152602001611bc9565b83811115610d545750506000910152565b600281046001821680611c0657607f821691505b60208210811415611c2757634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415611c4157611c41611c48565b5060010190565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b038116811461045857600080fd5b801515811461045857600080fdfea2646970667358221220e339e9a7d3b9f0aa7491fc9390f9a8c9ed67e7f2dfaa963e986f116efdd9325564736f6c63430008000033

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101a95760003560e01c806370a08231116100f9578063ac1217eb11610097578063d505accf11610071578063d505accf1461034c578063dd62ed3e1461035f578063f2fde38b14610372578063f46eccc414610385576101a9565b8063ac1217eb14610313578063ce277ece14610326578063cf456ae714610339576101a9565b806395d89b41116100d357806395d89b41146102d2578063a1f6b2a7146102da578063a457c2d7146102ed578063a9059cbb14610300576101a9565b806370a08231146102975780637ecebe00146102aa5780638da5cb5b146102bd576101a9565b806323b872dd116101665780633950935111610140578063395093511461026157806342966c68146102745780634e71e0c8146102875780635600f04f1461028f576101a9565b806323b872dd14610231578063313ce567146102445780633644e51514610259576101a9565b80630614117a146101ae57806306fdde03146101b8578063095ea7b3146101d6578063148e7133146101f657806316114acd1461020957806318160ddd1461021c575b600080fd5b6101b6610398565b005b6101c061045b565b6040516101cd91906118e3565b60405180910390f35b6101e96101e436600461166f565b6104e9565b6040516101cd919061182d565b6101e961020436600461177f565b6104ff565b6101b6610217366004611541565b610514565b6102246105e1565b6040516101cd9190611838565b6101e961023f366004611595565b6105e7565b61024c610627565b6040516101cd9190611b89565b61022461064b565b6101e961026f36600461166f565b610746565b6101b661028236600461177f565b61077b565b6101b6610785565b6101c06107f8565b6102246102a5366004611541565b610824565b6102246102b8366004611541565b610836565b6102c5610848565b6040516101cd9190611800565b6101c0610857565b6101b66102e836600461169a565b610864565b6101e96102fb36600461166f565b6109ed565b6101e961030e36600461166f565b610a22565b6101b661032136600461166f565b610a51565b6101b66103343660046116f3565b610aa0565b6101b6610347366004611642565b610d5a565b6101b661035a3660046115d5565b610dd8565b61022461036d36600461155d565b610f15565b6101b6610380366004611541565b610f32565b6101e9610393366004611541565b610f7e565b6006546001600160a01b031633146103cb5760405162461bcd60e51b81526004016103c290611ab4565b60405180910390fd5b6103d3610f93565b6103dc57600080fd5b6000336001600160a01b0316476040516103f590610743565b60006040518083038185875af1925050503d8060008114610432576040519150601f19603f3d011682016040523d82523d6000602084013e610437565b606091505b50509050806104585760405162461bcd60e51b81526004016103c29061194d565b50565b6000805461046890611bf2565b80601f016020809104026020016040519081016040528092919081815260200182805461049490611bf2565b80156104e15780601f106104b6576101008083540402835291602001916104e1565b820191906000526020600020905b8154815290600101906020018083116104c457829003601f168201915b505050505081565b60006104f6338484610f98565b90505b92915050565b60086020526000908152604090205460ff1681565b6006546001600160a01b0316331461053e5760405162461bcd60e51b81526004016103c290611ab4565b61054781611008565b61055057600080fd5b61045833826001600160a01b03166370a08231306040518263ffffffff1660e01b81526004016105809190611800565b60206040518083038186803b15801561059857600080fd5b505afa1580156105ac573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906105d09190611797565b6001600160a01b038416919061101b565b60025481565b60006001600160a01b0383163014156106125760405162461bcd60e51b81526004016103c290611974565b61061d848484611076565b90505b9392505050565b7f000000000000000000000000000000000000000000000000000000000000000881565b60007f000000000000000000000000000000000000000000000000000000000000000146141561069c57507fbe2230ba266e24f77b0ddb0484b1240c345cab917242c0986c6bc1637a49f9a8610743565b60408051808201825260018152603160f81b602091820152905161072a917f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f917fa286d16c849222012b8b270d9284588c7595afada7de839f1c205ea6563930b6917fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6914691309101611899565b6040516020818303038152906040528051906020012090505b90565b3360009081526004602090815260408083206001600160a01b03861684529091528120546104f69084906101e4908590611b97565b6104583382611106565b6007546001600160a01b0316331461079c57600080fd5b600780546001600160a01b031916905560065460405133916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600680546001600160a01b03191633179055565b6040518060400160405280601081526020016f68747470733a2f2f646f67652e67617960801b81525081565b60036020526000908152604090205481565b60056020526000908152604090205481565b6006546001600160a01b031681565b6001805461046890611bf2565b60008481526008602052604090205460ff16156108935760405162461bcd60e51b81526004016103c290611916565b60006108ea7f035c6f290d8c384f56de9d82994e71a65abeec130c683387e94b06260631633a8888886040516020016108cf9493929190611875565b604051602081830303815290604052805190602001206111c7565b905060006001828686866040516000815260200160405260405161091194939291906118c5565b6020604051602081039080840390855afa158015610933573d6000803e3d6000fd5b505060408051601f1901516001600160a01b03811660009081526009602052919091205490925060ff16905061097b5760405162461bcd60e51b81526004016103c290611b0f565b6109858888611200565b60008681526008602052604090819020805460ff19166001179055516001600160a01b0389169087907f246b335ff653677f0265d2c996ae2bf3c388b8103f39929758eda76493c6a508906109db908b90611838565b60405180910390a35050505050505050565b3360009081526004602090815260408083206001600160a01b03861684529091528120546104f69084906101e4908590611baf565b60006001600160a01b038316301415610a4757610a3f3383610a51565b5060016104f9565b6104f683836112a1565b610a5b3382611106565b816001600160a01b03167f31c2da40163e9552aab7b639958e037ef260cc96264c57ea4dd19e9884c44d9182604051610a949190611838565b60405180910390a25050565b806000805b82811015610d36576000858583818110610acf57634e487b7160e01b600052603260045260246000fd5b602060c090910292909201820135600081815260089093526040909220549192505060ff1615610aff5750610d26565b6000868684818110610b2157634e487b7160e01b600052603260045260246000fd5b905060c002016040016020810190610b399190611541565b90506000878785818110610b5d57634e487b7160e01b600052603260045260246000fd5b905060c002016000013590506000610ba57f035c6f290d8c384f56de9d82994e71a65abeec130c683387e94b06260631633a8484876040516020016108cf9493929190611875565b905060006001828b8b89818110610bcc57634e487b7160e01b600052603260045260246000fd5b905060c002016060016020810190610be491906117af565b8c8c8a818110610c0457634e487b7160e01b600052603260045260246000fd5b905060c00201608001358d8d8b818110610c2e57634e487b7160e01b600052603260045260246000fd5b905060c0020160a0013560405160008152602001604052604051610c5594939291906118c5565b6020604051602081039080840390855afa158015610c77573d6000803e3d6000fd5b505060408051601f1901516001600160a01b03811660009081526009602052919091205490925060ff169050610cb1575050505050610d26565b610cbb8484611200565b60008581526008602052604090819020805460ff1916600190811790915590519097506001600160a01b0385169086907f246b335ff653677f0265d2c996ae2bf3c388b8103f39929758eda76493c6a50890610d18908790611838565b60405180910390a350505050505b610d2f81611c2d565b9050610aa5565b5080610d545760405162461bcd60e51b81526004016103c290611a90565b50505050565b6006546001600160a01b03163314610d845760405162461bcd60e51b81526004016103c290611ab4565b6001600160a01b03821660008181526009602052604090819020805460ff1916841515179055517fff452b3b9159b024a9098f0058c63eccd90d36b3584608202800d662f962bb6090610a9490849061182d565b83421115610df85760405162461bcd60e51b81526004016103c290611a66565b6001600160a01b0387166000908152600560209081526040808320549051909291610e53916108cf917f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9918d918d918d9189918e9101611841565b9050600060018287878760405160008152602001604052604051610e7a94939291906118c5565b6020604051602081039080840390855afa158015610e9c573d6000803e3d6000fd5b505050602060405103519050896001600160a01b0316816001600160a01b031614610ed95760405162461bcd60e51b81526004016103c290611a3b565b610ee4836001611b97565b6001600160a01b038b16600090815260056020526040902055610f088a8a8a610f98565b5050505050505050505050565b600460209081526000928352604080842090915290825290205481565b6006546001600160a01b03163314610f5c5760405162461bcd60e51b81526004016103c290611ab4565b600780546001600160a01b0319166001600160a01b0392909216919091179055565b60096020526000908152604090205460ff1681565b600190565b6001600160a01b0380841660008181526004602090815260408083209487168084529490915280822085905551909291907f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92590610ff6908690611838565b60405180910390a35060019392505050565b6001600160a01b0381163014155b919050565b6110718363a9059cbb60e01b848460405160240161103a929190611814565b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b0319909316929092179091526112ae565b505050565b6001600160a01b0383166000908152600460209081526040808320338452909152812054828110156110ba5760405162461bcd60e51b81526004016103c2906119dd565b60001981146110f2576110cd8382611baf565b6001600160a01b03861660009081526004602090815260408083203384529091529020555b6110fd85858561133d565b95945050505050565b6001600160a01b0382166000908152600360205260409020548181101561113f5760405162461bcd60e51b81526004016103c290611a0d565b6111498282611baf565b6001600160a01b03841660009081526003602052604081209190915560028054849290611177908490611baf565b90915550506040516000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906111ba908690611838565b60405180910390a3505050565b60006111d161064b565b826040516020016111e39291906117e5565b604051602081830303815290604052805190602001209050919050565b6001600160a01b03821661121357600080fd5b80600260008282546112259190611b97565b90915550506001600160a01b03821660009081526003602052604081208054839290611252908490611b97565b90915550506040516001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90611295908590611838565b60405180910390a35050565b60006104f633848461133d565b6000611303826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166114489092919063ffffffff16565b80519091501561107157808060200190518101906113219190611763565b6110715760405162461bcd60e51b81526004016103c290611b3f565b60006001600160a01b03841661135257600080fd5b6001600160a01b0383166113725761136a8483611106565b506001610620565b6001600160a01b038416600090815260036020526040902054828110156113ab5760405162461bcd60e51b81526004016103c290611a0d565b6113b58382611baf565b6001600160a01b0380871660009081526003602052604080822093909355908616815290812080548592906113eb908490611b97565b92505081905550836001600160a01b0316856001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef856040516114359190611838565b60405180910390a3506001949350505050565b606061061d84846000858561145c856114f1565b6114785760405162461bcd60e51b81526004016103c290611ad8565b600080866001600160a01b0316858760405161149491906117c9565b60006040518083038185875af1925050503d80600081146114d1576040519150601f19603f3d011682016040523d82523d6000602084013e6114d6565b606091505b50915091506114e68282866114f7565b979650505050505050565b3b151590565b60608315611506575081610620565b8251156115165782518084602001fd5b8160405162461bcd60e51b81526004016103c291906118e3565b803560ff8116811461101657600080fd5b600060208284031215611552578081fd5b813561062081611c5e565b6000806040838503121561156f578081fd5b823561157a81611c5e565b9150602083013561158a81611c5e565b809150509250929050565b6000806000606084860312156115a9578081fd5b83356115b481611c5e565b925060208401356115c481611c5e565b929592945050506040919091013590565b600080600080600080600060e0888a0312156115ef578283fd5b87356115fa81611c5e565b9650602088013561160a81611c5e565b9550604088013594506060880135935061162660808901611530565b925060a0880135915060c0880135905092959891949750929550565b60008060408385031215611654578182fd5b823561165f81611c5e565b9150602083013561158a81611c73565b60008060408385031215611681578182fd5b823561168c81611c5e565b946020939093013593505050565b60008060008060008060c087890312156116b2578182fd5b86356116bd81611c5e565b955060208701359450604087013593506116d960608801611530565b92506080870135915060a087013590509295509295509295565b60008060208385031215611705578182fd5b823567ffffffffffffffff8082111561171c578384fd5b818501915085601f83011261172f578384fd5b81358181111561173d578485fd5b86602060c083028501011115611751578485fd5b60209290920196919550909350505050565b600060208284031215611774578081fd5b815161062081611c73565b600060208284031215611790578081fd5b5035919050565b6000602082840312156117a8578081fd5b5051919050565b6000602082840312156117c0578081fd5b6104f682611530565b600082516117db818460208701611bc6565b9190910192915050565b61190160f01b81526002810192909252602282015260420190565b6001600160a01b0391909116815260200190565b6001600160a01b03929092168252602082015260400190565b901515815260200190565b90815260200190565b9586526001600160a01b0394851660208701529290931660408501526060840152608083019190915260a082015260c00190565b9384526001600160a01b039290921660208401526040830152606082015260800190565b9485526020850193909352604084019190915260608301526001600160a01b0316608082015260a00190565b93845260ff9290921660208401526040830152606082015260800190565b6000602082528251806020840152611902816040850160208701611bc6565b601f01601f19169190910160400192915050565b6020808252601d908201527f496e737472756374696f6e20616c72656164792066756c66696c6c6564000000604082015260600190565b6020808252600d908201526c151c985b9cd9995c8819985a5b609a1b604082015260600190565b60208082526043908201527f5573652063726f73734272696467652829206f72207472616e7366657228292060408201527f746f207472616e7366657220444f4745206261636b20746f207468652062726960608201526264676560e81b608082015260a00190565b602080825260169082015275496e73756666696369656e7420616c6c6f77616e636560501b604082015260600190565b602080825260149082015273496e73756666696369656e742062616c616e636560601b604082015260600190565b602080825260119082015270496e76616c6964207369676e617475726560781b604082015260600190565b60208082526010908201526f111958591b1a5b9948195e1c1a5c995960821b604082015260600190565b6020808252600a90820152694e6f207375636365737360b01b604082015260600190565b6020808252600a90820152694f776e6572206f6e6c7960b01b604082015260600190565b6020808252601d908201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604082015260600190565b6020808252601690820152752737ba1039b4b3b732b210313c90309036b4b73a32b960511b604082015260600190565b6020808252602a908201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6040820152691bdd081cdd58d8d9595960b21b606082015260800190565b60ff91909116815260200190565b60008219821115611baa57611baa611c48565b500190565b600082821015611bc157611bc1611c48565b500390565b60005b83811015611be1578181015183820152602001611bc9565b83811115610d545750506000910152565b600281046001821680611c0657607f821691505b60208210811415611c2757634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415611c4157611c41611c48565b5060010190565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b038116811461045857600080fd5b801515811461045857600080fdfea2646970667358221220e339e9a7d3b9f0aa7491fc9390f9a8c9ed67e7f2dfaa963e986f116efdd9325564736f6c63430008000033

Deployed Bytecode Sourcemap

150:2920:1:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;1134:224:7;;;:::i;:::-;;135:27:2;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;1758:164;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;288:62:1:-;;;;;;:::i;:::-;;:::i;774:200:7:-;;;;;;:::i;:::-;;:::i;254:35:2:-;;;:::i;:::-;;;;;;;:::i;2788:279:1:-;;;;;;:::i;:::-;;:::i;205:40:2:-;;;:::i;:::-;;;;;;;:::i;4166:370::-;;;:::i;1930:190::-;;;;;;:::i;:::-;;:::i;4058:100::-;;;;;;:::i;:::-;;:::i;544:222:7:-;;;:::i;232:47:1:-;;;:::i;296:54:2:-;;;;;;:::i;:::-;;:::i;438:51::-;;;;;;:::i;:::-;;:::i;219:42:7:-;;;:::i;:::-;;;;;;;:::i;169:29:2:-;;;:::i;714:618:1:-;;;;;;:::i;:::-;;:::i;2132:196:2:-;;;;;;:::i;:::-;;:::i;2521:259:1:-;;;;;;:::i;:::-;;:::i;2329:184::-;;;;;;:::i;:::-;;:::i;1340:981::-;;;;;;:::i;:::-;;:::i;540:162::-;;;;;;:::i;:::-;;:::i;4729:592:2:-;;;;;;:::i;:::-;;:::i;357:74::-;;;;;;:::i;:::-;;:::i;414:122:7:-;;;;;;:::i;:::-;;:::i;357:49:1:-;;;;;;:::i;:::-;;:::i;1134:224:7:-;366:5;;-1:-1:-1;;;;;366:5:7;352:10;:19;343:43;;;;-1:-1:-1;;;343:43:7;;;;;;;:::i;:::-;;;;;;;;;1209:15:::1;:13;:15::i;:::-;1200:25;;;::::0;::::1;;1237:12;1254:10;-1:-1:-1::0;;;;;1254:15:7::1;1278:21;1254:51;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;1236:69;;;1325:7;1316:34;;;;-1:-1:-1::0;;;1316:34:7::1;;;;;;;:::i;:::-;397:1;1134:224::o:0;135:27:2:-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;1758:164::-;1843:4;1872:42;1884:10;1896:8;1906:7;1872:11;:42::i;:::-;1865:49;;1758:164;;;;;:::o;288:62:1:-;;;;;;;;;;;;;;;:::o;774:200:7:-;366:5;;-1:-1:-1;;;;;366:5:7;352:10;:19;343:43;;;;-1:-1:-1;;;343:43:7;;;;;;;:::i;:::-;866:24:::1;883:6;866:16;:24::i;:::-;857:34;;;::::0;::::1;;902:64;922:10;934:6;-1:-1:-1::0;;;;;934:16:7::1;;959:4;934:31;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;902:19:7;::::1;::::0;:64;:19:::1;:64::i;254:35:2:-:0;;;;:::o;2788:279:1:-;2880:4;-1:-1:-1;;;;;2910:20:1;;2925:4;2910:20;;2902:100;;;;-1:-1:-1;;;2902:100:1;;;;;;;:::i;:::-;3020:39;3039:5;3046:3;3051:7;3020:18;:39::i;:::-;3013:46;;2788:279;;;;;;:::o;205:40:2:-;;;:::o;4166:370::-;4224:7;4271:13;4254;:30;4250:91;;;-1:-1:-1;4308:21:2;4301:28;;4250:91;959:10;;;;;;;;;;;-1:-1:-1;;;959:10:2;;;;;4368:159;;;;802:95;;4424:14;;949:21;;4485:13;;4521:4;;4368:159;;:::i;:::-;;;;;;;;;;;;;4358:170;;;;;;4351:177;;4166:370;;:::o;1930:190::-;2081:10;2024:4;2071:21;;;:9;:21;;;;;;;;-1:-1:-1;;;;;2071:31:2;;;;;;;;;;2053:59;;2061:8;;2071:40;;2105:6;;2071:40;:::i;4058:100::-;4121:29;4130:10;4142:7;4121:8;:29::i;544:222:7:-;611:12;;-1:-1:-1;;;;;611:12:7;627:10;611:26;602:36;;;;;;649:12;:25;;-1:-1:-1;;;;;;649:25:7;;;711:5;;690:39;;718:10;;-1:-1:-1;;;;;711:5:7;;690:39;;672:1;;690:39;740:5;:18;;-1:-1:-1;;;;;;740:18:7;748:10;740:18;;;544:222::o;232:47:1:-;;;;;;;;;;;;;;-1:-1:-1;;;232:47:1;;;;:::o;296:54:2:-;;;;;;;;;;;;;:::o;438:51::-;;;;;;;;;;;;;:::o;219:42:7:-;;;-1:-1:-1;;;;;219:42:7;;:::o;169:29:2:-;;;;;;;:::i;714:618:1:-;863:36;;;;:20;:36;;;;;;;;862:37;853:80;;;;-1:-1:-1;;;853:80:1;;;;;;;:::i;:::-;944:12;959:86;460:71;1014:3;1019:7;1028:14;984:59;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;974:70;;;;;;959:14;:86::i;:::-;944:101;;1056:14;1073:27;1083:4;1089:2;1093;1097;1073:27;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;1073:27:1;;;-1:-1:-1;;1073:27:1;;-1:-1:-1;;;;;1119:15:1;;;;;;:7;1073:27;1119:15;;;;;;1073:27;;-1:-1:-1;1119:15:1;;;-1:-1:-1;1111:50:1;;;;-1:-1:-1;;;1111:50:1;;;;;;;:::i;:::-;1174:22;1183:3;1188:7;1174:8;:22::i;:::-;1217:36;;;;:20;:36;;;;;;;:43;;-1:-1:-1;;1217:43:1;1256:4;1217:43;;;1276:48;-1:-1:-1;;;;;1276:48:1;;;1238:14;;1276:48;;;;1316:7;;1276:48;:::i;:::-;;;;;;;;714:618;;;;;;;;:::o;2132:196:2:-;2286:10;2229:4;2276:21;;;:9;:21;;;;;;;;-1:-1:-1;;;;;2276:31:2;;;;;;;;;;2258:62;;2266:8;;2276:43;;2310:9;;2276:43;:::i;2521:259:1:-;2594:4;-1:-1:-1;;;;;2620:20:1;;2635:4;2620:20;2616:111;;;2657:32;2669:10;2681:7;2657:11;:32::i;:::-;-1:-1:-1;2711:4:1;2704:11;;2616:111;2744:28;2759:3;2764:7;2744:14;:28::i;2329:184::-;2420:29;2429:10;2441:7;2420:8;:29::i;:::-;2484:11;-1:-1:-1;;;;;2465:40:1;;2497:7;2465:40;;;;;;:::i;:::-;;;;;;;;2329:184;;:::o;1340:981::-;1457:13;1443:11;;1524:745;1544:3;1542:1;:5;1524:745;;;1569:21;1593:13;;1607:1;1593:16;;;;;-1:-1:-1;;;1593:16:1;;;;;;;;;:30;:16;;;;;;;;:30;;;1642:35;;;;:20;:35;;;;;;;;1593:30;;-1:-1:-1;;1642:35:1;;1638:54;;;1681:8;;;1638:54;1708:10;1721:13;;1735:1;1721:16;;;;;-1:-1:-1;;;1721:16:1;;;;;;;;;;;;;;:19;;;;;;;;;;:::i;:::-;1708:32;;1755:14;1772:13;;1786:1;1772:16;;;;;-1:-1:-1;;;1772:16:1;;;;;;;;;;;;;;:23;;;1755:40;;1810:12;1825:83;460:71;1880:2;1884:6;1892:13;1850:56;;;;;;;;;;;:::i;1825:83::-;1810:98;;1923:14;1940:75;1950:4;1956:13;;1970:1;1956:16;;;;;-1:-1:-1;;;1956:16:1;;;;;;;;;;;;;;:18;;;;;;;;;;:::i;:::-;1976:13;;1990:1;1976:16;;;;;-1:-1:-1;;;1976:16:1;;;;;;;;;;;;;;:18;;;1996:13;;2010:1;1996:16;;;;;-1:-1:-1;;;1996:16:1;;;;;;;;;;;;;;:18;;;1940:75;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;1940:75:1;;;-1:-1:-1;;1940:75:1;;-1:-1:-1;;;;;2035:15:1;;;;;;:7;1940:75;2035:15;;;;;;1940:75;;-1:-1:-1;2035:15:1;;;-1:-1:-1;2030:35:1;;2054:8;;;;;;;2030:35;2081:20;2090:2;2094:6;2081:8;:20::i;:::-;2118:35;;;;:20;:35;;;;;;;:42;;-1:-1:-1;;2118:42:1;2156:4;2118:42;;;;;;2212:45;;2156:4;;-1:-1:-1;;;;;;2212:45:1;;;2139:13;;2212:45;;;;2250:6;;2212:45;:::i;:::-;;;;;;;;1524:745;;;;;;1549:3;;;:::i;:::-;;;1524:745;;;;2288:10;2279:34;;;;-1:-1:-1;;;2279:34:1;;;;;;;:::i;:::-;1340:981;;;;:::o;540:162::-;366:5:7;;-1:-1:-1;;;;;366:5:7;352:10;:19;343:43;;;;-1:-1:-1;;;343:43:7;;;;;;;:::i;:::-;-1:-1:-1;;;;;626:16:1;::::1;;::::0;;;:7:::1;:16;::::0;;;;;;:27;;-1:-1:-1;;626:27:1::1;::::0;::::1;;;::::0;;669:25;::::1;::::0;::::1;::::0;626:27;;669:25:::1;:::i;4729:592:2:-:0;4917:9;4898:15;:28;;4889:58;;;;-1:-1:-1;;;4889:58:2;;;;;;;:::i;:::-;-1:-1:-1;;;;;4976:14:2;;4960:13;4976:14;;;:6;:14;;;;;;;;;5041:71;;4976:14;;4960:13;5016:98;;5041:71;;656:95;;4983:6;;5076:8;;5086:7;;4976:14;;5102:9;;5041:71;;:::i;5016:98::-;5001:113;;5125:14;5142:27;5152:4;5158:2;5162;5166;5142:27;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5125:44;;5199:6;-1:-1:-1;;;;;5189:16:2;:6;-1:-1:-1;;;;;5189:16:2;;5180:47;;;;-1:-1:-1;;;5180:47:2;;;;;;;:::i;:::-;5255:9;:5;5263:1;5255:9;:::i;:::-;-1:-1:-1;;;;;5238:14:2;;;;;;:6;:14;;;;;:26;5275:38;5245:6;5295:8;5305:7;5275:11;:38::i;:::-;;4729:592;;;;;;;;;;:::o;357:74::-;;;;;;;;;;;;;;;;;;;;;;;;:::o;414:122:7:-;366:5;;-1:-1:-1;;;;;366:5:7;352:10;:19;343:43;;;;-1:-1:-1;;;343:43:7;;;;;;;:::i;:::-;504:12:::1;:24:::0;;-1:-1:-1;;;;;;504:24:7::1;-1:-1:-1::0;;;;;504:24:7;;;::::1;::::0;;;::::1;::::0;;414:122::o;357:49:1:-;;;;;;;;;;;;;;;:::o;1366:98:7:-;1452:4;1366:98;:::o;1512:238:2:-;-1:-1:-1;;;;;1632:17:2;;;1610:4;1632:17;;;:9;:17;;;;;;;;:27;;;;;;;;;;;;;:37;;;1685:35;1610:4;;1632:27;:17;1685:35;;;;1662:7;;1685:35;:::i;:::-;;;;;;;;-1:-1:-1;1738:4:2;1512:238;;;;;:::o;982:144:7:-;-1:-1:-1;;;;;1085:32:7;;1112:4;1085:32;;982:144;;;;:::o;646:177:6:-;729:86;749:5;779:23;;;804:2;808:5;756:58;;;;;;;;;:::i;:::-;;;;-1:-1:-1;;756:58:6;;;;;;;;;;;;;;-1:-1:-1;;;;;756:58:6;-1:-1:-1;;;;;;756:58:6;;;;;;;;;;729:19;:86::i;:::-;646:177;;;:::o;2500:431:2:-;-1:-1:-1;;;;;2645:16:2;;2600:4;2645:16;;;:9;:16;;;;;;;;2662:10;2645:28;;;;;;;;2693:23;;;;2684:59;;;;-1:-1:-1;;;2684:59:2;;;;;;;:::i;:::-;-1:-1:-1;;2758:12:2;:33;2754:119;;2839:22;2854:7;2839:12;:22;:::i;:::-;-1:-1:-1;;;;;2808:16:2;;;;;;:9;:16;;;;;;;;2825:10;2808:28;;;;;;;:53;2754:119;2890:33;2903:5;2910:3;2915:7;2890:12;:33::i;:::-;2883:40;2500:431;-1:-1:-1;;;;;2500:431:2:o;3721:329::-;-1:-1:-1;;;;;3825:16:2;;3804:18;3825:16;;;:9;:16;;;;;;3861:21;;;;3852:55;;;;-1:-1:-1;;;3852:55:2;;;;;;;:::i;:::-;3937:20;3950:7;3937:10;:20;:::i;:::-;-1:-1:-1;;;;;3918:16:2;;;;;;:9;:16;;;;;:39;;;;3968:11;:22;;3983:7;;3918:16;3968:22;;3983:7;;3968:22;:::i;:::-;;;;-1:-1:-1;;4006:36:2;;4030:1;;-1:-1:-1;;;;;4006:36:2;;;;;;;4034:7;;4006:36;:::i;:::-;;;;;;;;3721:329;;;:::o;4544:177::-;4610:7;4682:18;:16;:18::i;:::-;4702:9;4653:59;;;;;;;;;:::i;:::-;;;;;;;;;;;;;4643:70;;;;;;4636:77;;4544:177;;;:::o;3476:237::-;-1:-1:-1;;;;;3566:17:2;;3557:27;;;;;;3612:7;3597:11;;:22;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;;;3630:14:2;;;;;;:9;:14;;;;;:25;;3648:7;;3630:14;:25;;3648:7;;3630:25;:::i;:::-;;;;-1:-1:-1;;3671:34:2;;-1:-1:-1;;;;;3671:34:2;;;3688:1;;3671:34;;;;3697:7;;3671:34;:::i;:::-;;;;;;;;3476:237;;:::o;2336:156::-;2417:4;2446:38;2459:10;2471:3;2476:7;2446:12;:38::i;1889:761:6:-;2313:23;2339:69;2367:4;2339:69;;;;;;;;;;;;;;;;;2347:5;-1:-1:-1;;;;;2339:27:6;;;:69;;;;;:::i;:::-;2423:17;;2313:95;;-1:-1:-1;2423:21:6;2419:224;;2565:10;2554:30;;;;;;;;;;;;:::i;:::-;2546:85;;;;-1:-1:-1;;;2546:85:6;;;;;;;:::i;2939:529:2:-;3032:4;-1:-1:-1;;;;;3063:19:2;;3054:29;;;;;;-1:-1:-1;;;;;3098:17:2;;3094:100;;3132:24;3141:5;3148:7;3132:8;:24::i;:::-;-1:-1:-1;3178:4:2;3171:11;;3094:100;-1:-1:-1;;;;;3225:16:2;;3204:18;3225:16;;;:9;:16;;;;;;3261:21;;;;3252:55;;;;-1:-1:-1;;;3252:55:2;;;;;;;:::i;:::-;3337:20;3350:7;3337:10;:20;:::i;:::-;-1:-1:-1;;;;;3318:16:2;;;;;;;:9;:16;;;;;;:39;;;;3368:14;;;;;;;;:25;;3386:7;;3318:16;3368:25;;3386:7;;3368:25;:::i;:::-;;;;;;;;3425:3;-1:-1:-1;;;;;3409:29:2;3418:5;-1:-1:-1;;;;;3409:29:2;;3430:7;3409:29;;;;;;:::i;:::-;;;;;;;;-1:-1:-1;3456:4:2;;2939:529;-1:-1:-1;;;;2939:529:2:o;3668:195:0:-;3771:12;3803:52;3825:6;3833:4;3839:1;3842:12;3771;4972:18;4983:6;4972:10;:18::i;:::-;4964:60;;;;-1:-1:-1;;;4964:60:0;;;;;;;:::i;:::-;5098:12;5112:23;5139:6;-1:-1:-1;;;;;5139:11:0;5159:5;5167:4;5139:33;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5097:75;;;;5190:52;5208:7;5217:10;5229:12;5190:17;:52::i;:::-;5183:59;4720:530;-1:-1:-1;;;;;;;4720:530:0:o;750:422::-;1117:20;1156:8;;;750:422::o;7260:742::-;7375:12;7404:7;7400:595;;;-1:-1:-1;7435:10:0;7428:17;;7400:595;7549:17;;:21;7545:439;;7812:10;7806:17;7873:15;7860:10;7856:2;7852:19;7845:44;7760:148;7955:12;7948:20;;-1:-1:-1;;;7948:20:0;;;;;;;;:::i;14:158:8:-;82:20;;142:4;131:16;;121:27;;111:2;;162:1;159;152:12;177:259;;289:2;277:9;268:7;264:23;260:32;257:2;;;310:6;302;295:22;257:2;354:9;341:23;373:33;400:5;373:33;:::i;441:402::-;;;570:2;558:9;549:7;545:23;541:32;538:2;;;591:6;583;576:22;538:2;635:9;622:23;654:33;681:5;654:33;:::i;:::-;706:5;-1:-1:-1;763:2:8;748:18;;735:32;776:35;735:32;776:35;:::i;:::-;830:7;820:17;;;528:315;;;;;:::o;848:470::-;;;;994:2;982:9;973:7;969:23;965:32;962:2;;;1015:6;1007;1000:22;962:2;1059:9;1046:23;1078:33;1105:5;1078:33;:::i;:::-;1130:5;-1:-1:-1;1187:2:8;1172:18;;1159:32;1200:35;1159:32;1200:35;:::i;:::-;952:366;;1254:7;;-1:-1:-1;;;1308:2:8;1293:18;;;;1280:32;;952:366::o;1323:750::-;;;;;;;;1535:3;1523:9;1514:7;1510:23;1506:33;1503:2;;;1557:6;1549;1542:22;1503:2;1601:9;1588:23;1620:33;1647:5;1620:33;:::i;:::-;1672:5;-1:-1:-1;1729:2:8;1714:18;;1701:32;1742:35;1701:32;1742:35;:::i;:::-;1796:7;-1:-1:-1;1850:2:8;1835:18;;1822:32;;-1:-1:-1;1901:2:8;1886:18;;1873:32;;-1:-1:-1;1924:39:8;1958:3;1943:19;;1924:39;:::i;:::-;1914:49;;2010:3;1999:9;1995:19;1982:33;1972:43;;2062:3;2051:9;2047:19;2034:33;2024:43;;1493:580;;;;;;;;;;:::o;2078:396::-;;;2204:2;2192:9;2183:7;2179:23;2175:32;2172:2;;;2225:6;2217;2210:22;2172:2;2269:9;2256:23;2288:33;2315:5;2288:33;:::i;:::-;2340:5;-1:-1:-1;2397:2:8;2382:18;;2369:32;2410;2369;2410;:::i;2479:327::-;;;2608:2;2596:9;2587:7;2583:23;2579:32;2576:2;;;2629:6;2621;2614:22;2576:2;2673:9;2660:23;2692:33;2719:5;2692:33;:::i;:::-;2744:5;2796:2;2781:18;;;;2768:32;;-1:-1:-1;;;2566:240:8:o;2811:606::-;;;;;;;3006:3;2994:9;2985:7;2981:23;2977:33;2974:2;;;3028:6;3020;3013:22;2974:2;3072:9;3059:23;3091:33;3118:5;3091:33;:::i;:::-;3143:5;-1:-1:-1;3195:2:8;3180:18;;3167:32;;-1:-1:-1;3246:2:8;3231:18;;3218:32;;-1:-1:-1;3269:38:8;3303:2;3288:18;;3269:38;:::i;:::-;3259:48;;3354:3;3343:9;3339:19;3326:33;3316:43;;3406:3;3395:9;3391:19;3378:33;3368:43;;2964:453;;;;;;;;:::o;3422:708::-;;;3609:2;3597:9;3588:7;3584:23;3580:32;3577:2;;;3630:6;3622;3615:22;3577:2;3675:9;3662:23;3704:18;3745:2;3737:6;3734:14;3731:2;;;3766:6;3758;3751:22;3731:2;3809:6;3798:9;3794:22;3784:32;;3854:7;3847:4;3843:2;3839:13;3835:27;3825:2;;3881:6;3873;3866:22;3825:2;3926;3913:16;3952:2;3944:6;3941:14;3938:2;;;3973:6;3965;3958:22;3938:2;4034:7;4029:2;4021:4;4013:6;4009:17;4005:2;4001:26;3997:35;3994:48;3991:2;;;4060:6;4052;4045:22;3991:2;4096;4088:11;;;;;4118:6;;-1:-1:-1;3567:563:8;;-1:-1:-1;;;;3567:563:8:o;4135:257::-;;4255:2;4243:9;4234:7;4230:23;4226:32;4223:2;;;4276:6;4268;4261:22;4223:2;4313:9;4307:16;4332:30;4356:5;4332:30;:::i;4676:190::-;;4788:2;4776:9;4767:7;4763:23;4759:32;4756:2;;;4809:6;4801;4794:22;4756:2;-1:-1:-1;4837:23:8;;4746:120;-1:-1:-1;4746:120:8:o;4871:194::-;;4994:2;4982:9;4973:7;4969:23;4965:32;4962:2;;;5015:6;5007;5000:22;4962:2;-1:-1:-1;5043:16:8;;4952:113;-1:-1:-1;4952:113:8:o;5070:194::-;;5180:2;5168:9;5159:7;5155:23;5151:32;5148:2;;;5201:6;5193;5186:22;5148:2;5229:29;5248:9;5229:29;:::i;5269:274::-;;5436:6;5430:13;5452:53;5498:6;5493:3;5486:4;5478:6;5474:17;5452:53;:::i;:::-;5521:16;;;;;5406:137;-1:-1:-1;;5406:137:8:o;5548:392::-;-1:-1:-1;;;5806:27:8;;5858:1;5849:11;;5842:27;;;;5894:2;5885:12;;5878:28;5931:2;5922:12;;5796:144::o;6155:203::-;-1:-1:-1;;;;;6319:32:8;;;;6301:51;;6289:2;6274:18;;6256:102::o;6363:274::-;-1:-1:-1;;;;;6555:32:8;;;;6537:51;;6619:2;6604:18;;6597:34;6525:2;6510:18;;6492:145::o;6642:187::-;6807:14;;6800:22;6782:41;;6770:2;6755:18;;6737:92::o;6834:177::-;6980:25;;;6968:2;6953:18;;6935:76::o;7016:591::-;7303:25;;;-1:-1:-1;;;;;7402:15:8;;;7397:2;7382:18;;7375:43;7454:15;;;;7449:2;7434:18;;7427:43;7501:2;7486:18;;7479:34;7544:3;7529:19;;7522:35;;;;7355:3;7573:19;;7566:35;7290:3;7275:19;;7257:350::o;7612:417::-;7843:25;;;-1:-1:-1;;;;;7904:32:8;;;;7899:2;7884:18;;7877:60;7968:2;7953:18;;7946:34;8011:2;7996:18;;7989:34;7830:3;7815:19;;7797:232::o;8034:489::-;8293:25;;;8349:2;8334:18;;8327:34;;;;8392:2;8377:18;;8370:34;;;;8435:2;8420:18;;8413:34;-1:-1:-1;;;;;8484:32:8;8478:3;8463:19;;8456:61;8280:3;8265:19;;8247:276::o;8528:398::-;8755:25;;;8828:4;8816:17;;;;8811:2;8796:18;;8789:45;8865:2;8850:18;;8843:34;8908:2;8893:18;;8886:34;8742:3;8727:19;;8709:217::o;8931:383::-;;9080:2;9069:9;9062:21;9112:6;9106:13;9155:6;9150:2;9139:9;9135:18;9128:34;9171:66;9230:6;9225:2;9214:9;9210:18;9205:2;9197:6;9193:15;9171:66;:::i;:::-;9298:2;9277:15;-1:-1:-1;;9273:29:8;9258:45;;;;9305:2;9254:54;;9052:262;-1:-1:-1;;9052:262:8:o;9319:353::-;9521:2;9503:21;;;9560:2;9540:18;;;9533:30;9599:31;9594:2;9579:18;;9572:59;9663:2;9648:18;;9493:179::o;9677:337::-;9879:2;9861:21;;;9918:2;9898:18;;;9891:30;-1:-1:-1;;;9952:2:8;9937:18;;9930:43;10005:2;9990:18;;9851:163::o;10019:471::-;10221:2;10203:21;;;10260:2;10240:18;;;10233:30;10299:34;10294:2;10279:18;;10272:62;10370:34;10365:2;10350:18;;10343:62;-1:-1:-1;;;10436:3:8;10421:19;;10414:34;10480:3;10465:19;;10193:297::o;10495:346::-;10697:2;10679:21;;;10736:2;10716:18;;;10709:30;-1:-1:-1;;;10770:2:8;10755:18;;10748:52;10832:2;10817:18;;10669:172::o;10846:344::-;11048:2;11030:21;;;11087:2;11067:18;;;11060:30;-1:-1:-1;;;11121:2:8;11106:18;;11099:50;11181:2;11166:18;;11020:170::o;11195:341::-;11397:2;11379:21;;;11436:2;11416:18;;;11409:30;-1:-1:-1;;;11470:2:8;11455:18;;11448:47;11527:2;11512:18;;11369:167::o;11948:340::-;12150:2;12132:21;;;12189:2;12169:18;;;12162:30;-1:-1:-1;;;12223:2:8;12208:18;;12201:46;12279:2;12264:18;;12122:166::o;12293:334::-;12495:2;12477:21;;;12534:2;12514:18;;;12507:30;-1:-1:-1;;;12568:2:8;12553:18;;12546:40;12618:2;12603:18;;12467:160::o;12632:334::-;12834:2;12816:21;;;12873:2;12853:18;;;12846:30;-1:-1:-1;;;12907:2:8;12892:18;;12885:40;12957:2;12942:18;;12806:160::o;12971:353::-;13173:2;13155:21;;;13212:2;13192:18;;;13185:30;13251:31;13246:2;13231:18;;13224:59;13315:2;13300:18;;13145:179::o;13329:346::-;13531:2;13513:21;;;13570:2;13550:18;;;13543:30;-1:-1:-1;;;13604:2:8;13589:18;;13582:52;13666:2;13651:18;;13503:172::o;13680:406::-;13882:2;13864:21;;;13921:2;13901:18;;;13894:30;13960:34;13955:2;13940:18;;13933:62;-1:-1:-1;;;14026:2:8;14011:18;;14004:40;14076:3;14061:19;;13854:232::o;14273:184::-;14445:4;14433:17;;;;14415:36;;14403:2;14388:18;;14370:87::o;14462:128::-;;14533:1;14529:6;14526:1;14523:13;14520:2;;;14539:18;;:::i;:::-;-1:-1:-1;14575:9:8;;14510:80::o;14595:125::-;;14663:1;14660;14657:8;14654:2;;;14668:18;;:::i;:::-;-1:-1:-1;14705:9:8;;14644:76::o;14725:258::-;14797:1;14807:113;14821:6;14818:1;14815:13;14807:113;;;14897:11;;;14891:18;14878:11;;;14871:39;14843:2;14836:10;14807:113;;;14938:6;14935:1;14932:13;14929:2;;;-1:-1:-1;;14973:1:8;14955:16;;14948:27;14778:205::o;14988:380::-;15073:1;15063:12;;15120:1;15110:12;;;15131:2;;15185:4;15177:6;15173:17;15163:27;;15131:2;15238;15230:6;15227:14;15207:18;15204:38;15201:2;;;15284:10;15279:3;15275:20;15272:1;15265:31;15319:4;15316:1;15309:15;15347:4;15344:1;15337:15;15201:2;;15043:325;;;:::o;15373:135::-;;-1:-1:-1;;15433:17:8;;15430:2;;;15453:18;;:::i;:::-;-1:-1:-1;15500:1:8;15489:13;;15420:88::o;15513:127::-;15574:10;15569:3;15565:20;15562:1;15555:31;15605:4;15602:1;15595:15;15629:4;15626:1;15619:15;15645:133;-1:-1:-1;;;;;15722:31:8;;15712:42;;15702:2;;15768:1;15765;15758:12;15783:120;15871:5;15864:13;15857:21;15850:5;15847:32;15837:2;;15893:1;15890;15883:12

Swarm Source

ipfs://e339e9a7d3b9f0aa7491fc9390f9a8c9ed67e7f2dfaa963e986f116efdd93255
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.