ETH Price: $3,093.33 (+1.06%)
Gas: 4 Gwei

Token

DRAGON (DRAGON)
 

Overview

Max Total Supply

420,000,000,000 DRAGON

Holders

317

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
7,148,703.868434179114713796 DRAGON

Value
$0.00
0x3b6813d37178880e07cd9919ab5204868cff80f8
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:
DRAGON

Compiler Version
v0.8.9+commit.e5eed63a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-10-09
*/

// SPDX-License-Identifier: MIT                                                                               
                                                    
pragma solidity ^0.8.9;

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

    function _msgData() internal view virtual returns (bytes calldata) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

interface IUniswapV2Pair {
    event Approval(address indexed owner, address indexed spender, uint value);
    event Transfer(address indexed from, address indexed to, uint value);

    function name() external pure returns (string memory);
    function symbol() external pure returns (string memory);
    function decimals() external pure returns (uint8);
    function totalSupply() external view returns (uint);
    function balanceOf(address owner) external view returns (uint);
    function allowance(address owner, address spender) external view returns (uint);

    function approve(address spender, uint value) external returns (bool);
    function transfer(address to, uint value) external returns (bool);
    function transferFrom(address from, address to, uint value) external returns (bool);

    function DOMAIN_SEPARATOR() external view returns (bytes32);
    function PERMIT_TYPEHASH() external pure returns (bytes32);
    function nonces(address owner) external view returns (uint);

    function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;

    event Mint(address indexed sender, uint amount0, uint amount1);
    event Burn(address indexed sender, uint amount0, uint amount1, address indexed to);
    event Swap(
        address indexed sender,
        uint amount0In,
        uint amount1In,
        uint amount0Out,
        uint amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);

    function MINIMUM_LIQUIDITY() external pure returns (uint);
    function factory() external view returns (address);
    function token0() external view returns (address);
    function token1() external view returns (address);
    function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast);
    function price0CumulativeLast() external view returns (uint);
    function price1CumulativeLast() external view returns (uint);
    function kLast() external view returns (uint);

    function mint(address to) external returns (uint liquidity);
    function burn(address to) external returns (uint amount0, uint amount1);
    function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
    function skim(address to) external;
    function sync() external;

    function initialize(address, address) external;
}

interface IUniswapV2Factory {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);

    function feeTo() external view returns (address);
    function feeToSetter() external view returns (address);

    function getPair(address tokenA, address tokenB) external view returns (address pair);
    function allPairs(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);

    function createPair(address tokenA, address tokenB) external returns (address pair);

    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}

interface IERC20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);
}

interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

    /**
     * @dev Returns the symbol of the token.
     */
    function symbol() external view returns (string memory);

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);
}


contract ERC20 is Context, IERC20, IERC20Metadata {
    using SafeMath for uint256;

    mapping(address => uint256) private _balances;

    mapping(address => mapping(address => uint256)) private _allowances;

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

    /**
     * @dev Sets the values for {name} and {symbol}.
     *
     * The default value of {decimals} is 18. To select a different value for
     * {decimals} you should overload it.
     *
     * All two of these values are immutable: they can only be set once during
     * construction.
     */
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5,05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless this function is
     * overridden;
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account) public view virtual override returns (uint256) {
        return _balances[account];
    }

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }

    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
        return true;
    }

    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
        return true;
    }

    /**
     * @dev Moves tokens `amount` from `sender` to `recipient`.
     *
     * This is internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

        _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
    }

    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

        _beforeTokenTransfer(address(0), account, amount);

        _totalSupply = _totalSupply.add(amount);
        _balances[account] = _balances[account].add(amount);
        emit Transfer(address(0), account, amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, reducing the
     * total supply.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     * - `account` must have at least `amount` tokens.
     */
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
        _totalSupply = _totalSupply.sub(amount);
        emit Transfer(account, address(0), amount);
    }

    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be to transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

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.
     */
    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.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        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.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
    
    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}



library SafeMathInt {
    int256 private constant MIN_INT256 = int256(1) << 255;
    int256 private constant MAX_INT256 = ~(int256(1) << 255);

    /**
     * @dev Multiplies two int256 variables and fails on overflow.
     */
    function mul(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a * b;

        // Detect overflow when multiplying MIN_INT256 with -1
        require(c != MIN_INT256 || (a & MIN_INT256) != (b & MIN_INT256));
        require((b == 0) || (c / b == a));
        return c;
    }

    /**
     * @dev Division of two int256 variables and fails on overflow.
     */
    function div(int256 a, int256 b) internal pure returns (int256) {
        // Prevent overflow when dividing MIN_INT256 by -1
        require(b != -1 || a != MIN_INT256);

        // Solidity already throws when dividing by 0.
        return a / b;
    }

    /**
     * @dev Subtracts two int256 variables and fails on overflow.
     */
    function sub(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a - b;
        require((b >= 0 && c <= a) || (b < 0 && c > a));
        return c;
    }

    /**
     * @dev Adds two int256 variables and fails on overflow.
     */
    function add(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a + b;
        require((b >= 0 && c >= a) || (b < 0 && c < a));
        return c;
    }

    /**
     * @dev Converts to absolute value, and fails on overflow.
     */
    function abs(int256 a) internal pure returns (int256) {
        require(a != MIN_INT256);
        return a < 0 ? -a : a;
    }


    function toUint256Safe(int256 a) internal pure returns (uint256) {
        require(a >= 0);
        return uint256(a);
    }
}

library SafeMathUint {
  function toInt256Safe(uint256 a) internal pure returns (int256) {
    int256 b = int256(a);
    require(b >= 0);
    return b;
  }
}


interface IUniswapV2Router01 {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);
    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountToken, uint amountETH);
    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);
    function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);

    function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
    function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
    function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
    function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
    function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);
    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountETH);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}

contract DRAGON is ERC20, Ownable {
    using SafeMath for uint256;

    IUniswapV2Router02 public immutable uniswapV2Router;
    address public immutable uniswapV2Pair;
    address public constant deadAddress = address(0xdead);

    bool private swapping;

    address private marketingWallet;
    
    uint8 private _decimals;

    bool public tradingActive = false;
    bool public swapEnabled = false;
            
    uint256 public buyTotalFees;
    
    uint256 public sellTotalFees;

    uint256 public transferTotalFees;
    
    uint256 public minimumSwapBalance;
    
    /******************/

    // exlcude from fees and max transaction amount
    mapping (address => bool) private _isExcludedFromFees;

    // store addresses that a automatic market maker pairs. Any transfer *to* these addresses
    // could be subject to a maximum transfer amount
    mapping (address => bool) public automatedMarketMakerPairs;

    event UpdateUniswapV2Router(address indexed newAddress, address indexed oldAddress);

    event ExcludeFromFees(address indexed account, bool isExcluded);

    event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);

    event marketingWalletUpdated(address indexed newWallet, address indexed oldWallet);    

    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiquidity
    );

    event RewardTriggered(uint256 amount);
    
    event OwnerForcedSwapBack(uint256 timestamp);

    constructor() ERC20("DRAGON", "DRAGON") {

        address _owner = 0xb1FFA9Ef1b8243229eA0F645566632220D6598B8;

        _decimals = 18;

        uint256 totalSupply = 420000000000 * (10**_decimals);
        
        buyTotalFees = 5;
        
        sellTotalFees = 5;

        transferTotalFees = 0;

        marketingWallet = address(0xCf6b1bFF2F5f719B59887aaa6489FEDE4DE18d40); // set as marketing wallet

        minimumSwapBalance = 42000000 * (10**_decimals);

        address currentRouter;

        //Adding Variables for all the routers for easier deployment for our customers.
        if (block.chainid == 56) {
            currentRouter = 0x10ED43C718714eb63d5aA57B78B54704E256024E; // PCS Router
        } else if (block.chainid == 97) {
            currentRouter = 0xD99D1c33F9fC3444f8101754aBC46c52416550D1; // PCS Testnet
        } else if (block.chainid == 43114) {
            currentRouter = 0x60aE616a2155Ee3d9A68541Ba4544862310933d4; //Avax Mainnet
        } else if (block.chainid == 137) {
            currentRouter = 0xa5E0829CaCEd8fFDD4De3c43696c57F7D7A678ff; //Polygon Ropsten
        } else if (block.chainid == 250) {
            currentRouter = 0xF491e7B69E4244ad4002BC14e878a34207E38c29; //SpookySwap FTM
        } else if (block.chainid == 3) {
            currentRouter = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D; //Ropsten
        } else if (block.chainid == 1 || block.chainid == 4) {
            currentRouter = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D; //Mainnet
        } else {
            currentRouter = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D; //Mainnet
            //            revert();
        }

        //End of Router Variables.

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(currentRouter);

        uniswapV2Router = _uniswapV2Router;
        
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        _setAutomatedMarketMakerPair(address(uniswapV2Pair), true);

        // exclude from paying fees or having max transaction amount
        excludeFromFees(_owner, true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);
                
        /*
            _mint is an internal function in ERC20.sol that is only called here,
            and CANNOT be called ever again
        */
        _mint(_owner, totalSupply);
        transferOwnership(_owner);
    }

    receive() external payable {

  	}

    // once enabled, can never be turned off
    function enableTrading() external onlyOwner {
        tradingActive = true;
        swapEnabled = true;
    }
    
    function airdropToWallets(address[] memory airdropWallets, uint256[] memory amounts) external onlyOwner returns (bool){
        require(!tradingActive, "Trading is already active, cannot airdrop after launch.");
        require(airdropWallets.length == amounts.length, "arrays must be the same length");
        require(airdropWallets.length < 200, "Can only airdrop 200 wallets per txn due to gas limits"); // allows for airdrop + launch at the same exact time, reducing delays and reducing sniper input.
        for(uint256 i = 0; i < airdropWallets.length; i++){
            address wallet = airdropWallets[i];
            uint256 amount = amounts[i];
            _transfer(msg.sender, wallet, amount);
        }
        return true;
    }
    
    function decimals() public view override returns (uint8) {
        return _decimals;
    }
    
    // only use to disable contract sales if absolutely necessary (emergency use only)
    function updateSwapEnabled(bool enabled) external onlyOwner(){
        swapEnabled = enabled;
    }
    
    function updateBFees(uint256 _marketingFee) external onlyOwner {
        buyTotalFees = _marketingFee;
        require(buyTotalFees <= 5, "Must keep fees at 10% or less");
    }
    
    function updateSFees(uint256 _marketingFee) external onlyOwner {
        sellTotalFees = _marketingFee;
        require(sellTotalFees <= 5, "Must keep fees at 10% or less");
    }

    function updateTransferFees(uint256 _marketingFee) external onlyOwner {
        transferTotalFees = _marketingFee ;
        require(transferTotalFees <= 5, "Must keep fees at 10% or less");
    }

    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
        emit ExcludeFromFees(account, excluded);
    }

    function setAutomatedMarketMakerPair(address pair, bool value) external onlyOwner {
        require(pair != uniswapV2Pair, "The pair cannot be removed from automatedMarketMakerPairs");

        _setAutomatedMarketMakerPair(pair, value);
    }
    
    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        automatedMarketMakerPairs[pair] = value;

        emit SetAutomatedMarketMakerPair(pair, value);
    }

    function updateMarketingWallet(address newMarketingWallet) external onlyOwner {
        emit marketingWalletUpdated(newMarketingWallet, marketingWallet);
        marketingWallet = newMarketingWallet;
    }
    
    function isExcludedFromFees(address account) external view returns(bool) {
        return _isExcludedFromFees[account];
    }

    function updateMinimumSwapBalance(uint256 newBalance) public onlyOwner {
        minimumSwapBalance = newBalance;
    }
    
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        if(!tradingActive){
            require(_isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading is not active.");
        }
         if(amount == 0) {
            super._transfer(from, to, 0);
            return;
        }
                
		uint256 contractTokenBalance = balanceOf(address(this));
        
        bool canSwap = contractTokenBalance > minimumSwapBalance;

        if( 
            canSwap &&
            swapEnabled &&
            !swapping &&
            !automatedMarketMakerPairs[from] &&
            !_isExcludedFromFees[from] &&
            !_isExcludedFromFees[to]
        ) {
            swapping = true;
            
            swapBack();

            swapping = false;
        }
        
        bool takeFee = !swapping;

        // if any account belongs to _isExcludedFromFee account then remove the fee
        if(_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }
        
        uint256 fees = 0;
        // only take fees on buys/sells, do not take on wallet transfers
        if(takeFee){
            
            if (automatedMarketMakerPairs[to]){
                if (sellTotalFees > 0){
                    fees = amount.mul(sellTotalFees).div(100);
                }
            }
            // on buy
            else if(automatedMarketMakerPairs[from]) {
                if (buyTotalFees > 0){
                    fees = amount.mul(buyTotalFees).div(100);
                }

            } else {
                if (transferTotalFees > 0){
                    fees = amount.mul(transferTotalFees).div(100);
                }
            }
            
            if(fees > 0){    
                super._transfer(from, address(this), fees);
            }
        	
        	amount -= fees;
        }

        super._transfer(from, to, amount);
    }

    function swapTokensForEth(uint256 tokenAmount) private {

        // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();

        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // make the swap
        try uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        ) {} catch {}
        
    }
    
    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // add the liquidity
        try uniswapV2Router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            deadAddress,
            block.timestamp
        ) {} catch {}
    }


    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        
        if(contractBalance == 0) {return;}
        
        swapTokensForEth(contractBalance); 

        bool success;        
        (success,) = address(marketingWallet).call{value: address(this).balance}("");
        
    }
}

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":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"timestamp","type":"uint256"}],"name":"OwnerForcedSwapBack","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"RewardTriggered","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiquidity","type":"uint256"}],"name":"SwapAndLiquify","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":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdateUniswapV2Router","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldWallet","type":"address"}],"name":"marketingWalletUpdated","type":"event"},{"inputs":[{"internalType":"address[]","name":"airdropWallets","type":"address[]"},{"internalType":"uint256[]","name":"amounts","type":"uint256[]"}],"name":"airdropToWallets","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","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":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"deadAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","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":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minimumSwapBalance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sellTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","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":[],"name":"tradingActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","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":"transferTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_marketingFee","type":"uint256"}],"name":"updateBFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newMarketingWallet","type":"address"}],"name":"updateMarketingWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newBalance","type":"uint256"}],"name":"updateMinimumSwapBalance","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_marketingFee","type":"uint256"}],"name":"updateSFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enabled","type":"bool"}],"name":"updateSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_marketingFee","type":"uint256"}],"name":"updateTransferFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c06040526006805461ffff60a81b191690553480156200001f57600080fd5b50604080518082018252600680825265222920a3a7a760d11b602080840182815285518087019096529285528401528151919291620000619160039162000810565b5080516200007790600490602084019062000810565b50505060006200008c620004a560201b60201c565b600580546001600160a01b0319166001600160a01b0383169081179091556040519192509060009060008051602062002a38833981519152908290a3506006805460ff60a01b1916600960a11b179081905573b1ffa9ef1b8243229ea0f645566632220d6598b8906000906200010f9060ff600160a01b90910416600a620009c9565b62000120906461c9f36800620009e1565b600560078190556008556000600955600680546001600160a01b03191673cf6b1bff2f5f719b59887aaa6489fede4de18d401790819055909150620001729060ff600160a01b90910416600a620009c9565b6200018290630280de80620009e1565b600a5560006038461415620001ad57507310ed43c718714eb63d5aa57b78b54704e256024e620002b5565b4660611415620001d3575073d99d1c33f9fc3444f8101754abc46c52416550d1620002b5565b4661a86a1415620001fa57507360ae616a2155ee3d9a68541ba4544862310933d4620002b5565b466089141562000220575073a5e0829caced8ffdd4de3c43696c57f7d7a678ff620002b5565b4660fa141562000246575073f491e7b69e4244ad4002bc14e878a34207e38c29620002b5565b46600314156200026c5750737a250d5630b4cf539739df2c5dacb4c659f2488d620002b5565b46600114806200027c5750466004145b156200029e5750737a250d5630b4cf539739df2c5dacb4c659f2488d620002b5565b50737a250d5630b4cf539739df2c5dacb4c659f2488d5b6001600160a01b03811660808190526040805163c45a015560e01b8152905183929163c45a0155916004808301926020929190829003018186803b158015620002fd57600080fd5b505afa15801562000312573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000338919062000a03565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156200038157600080fd5b505afa15801562000396573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620003bc919062000a03565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200040557600080fd5b505af11580156200041a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000440919062000a03565b6001600160a01b031660a08190526200045b906001620004a9565b62000468846001620004fd565b62000475306001620004fd565b6200048461dead6001620004fd565b620004908484620005ab565b6200049b84620006a7565b5050505062000a86565b3390565b6001600160a01b0382166000818152600c6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6005546001600160a01b031633146200054c5760405162461bcd60e51b8152602060048201819052602482015260008051602062002a1883398151915260448201526064015b60405180910390fd5b6001600160a01b0382166000818152600b6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b038216620006035760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640162000543565b6200061f81600254620007a460201b62000f7a1790919060201c565b6002556001600160a01b038216600090815260208181526040909120546200065291839062000f7a620007a4821b17901c565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6005546001600160a01b03163314620006f25760405162461bcd60e51b8152602060048201819052602482015260008051602062002a18833981519152604482015260640162000543565b6001600160a01b038116620007595760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840162000543565b6005546040516001600160a01b0380841692169060008051602062002a3883398151915290600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080620007b3838562000a2e565b905083811015620008075760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640162000543565b90505b92915050565b8280546200081e9062000a49565b90600052602060002090601f0160209004810192826200084257600085556200088d565b82601f106200085d57805160ff19168380011785556200088d565b828001600101855582156200088d579182015b828111156200088d57825182559160200191906001019062000870565b506200089b9291506200089f565b5090565b5b808211156200089b5760008155600101620008a0565b634e487b7160e01b600052601160045260246000fd5b600181815b808511156200090d578160001904821115620008f157620008f1620008b6565b80851615620008ff57918102915b93841c9390800290620008d1565b509250929050565b60008262000926575060016200080a565b8162000935575060006200080a565b81600181146200094e5760028114620009595762000979565b60019150506200080a565b60ff8411156200096d576200096d620008b6565b50506001821b6200080a565b5060208310610133831016604e8410600b84101617156200099e575081810a6200080a565b620009aa8383620008cc565b8060001904821115620009c157620009c1620008b6565b029392505050565b6000620009da60ff84168362000915565b9392505050565b6000816000190483118215151615620009fe57620009fe620008b6565b500290565b60006020828403121562000a1657600080fd5b81516001600160a01b03811681146200080757600080fd5b6000821982111562000a445762000a44620008b6565b500190565b600181811c9082168062000a5e57607f821691505b6020821081141562000a8057634e487b7160e01b600052602260045260246000fd5b50919050565b60805160a051611f5062000ac8600039600081816103c60152610bcf0152600081816102810152818161174d0152818161181501526118510152611f506000f3fe6080604052600436106102085760003560e01c80638a8c523c11610118578063b4443f5b116100a0578063d85ba0631161006f578063d85ba0631461063c578063dd62ed3e14610652578063e3c4818d14610698578063e4b4d155146106ae578063f2fde38b146106ce57600080fd5b8063b4443f5b146105ab578063b62496f5146105cb578063bbc0c742146105fb578063c02466681461061c57600080fd5b806395d89b41116100e757806395d89b41146105165780639a7a23d61461052b578063a457c2d71461054b578063a9059cbb1461056b578063aacebbe31461058b57600080fd5b80638a8c523c146104a35780638da5cb5b146104b8578063924de9b7146104d657806393c1bc24146104f657600080fd5b80632b4bcdc61161019b5780634fbee1931161016a5780634fbee193146103e85780636a486a8e146104215780636ddd17131461043757806370a0823114610458578063715018a61461048e57600080fd5b80632b4bcdc614610346578063313ce56714610368578063395093511461039457806349bd5a5e146103b457600080fd5b80632307b441116101d75780632307b441146102da57806323b872dd146102fa578063258bb6e11461031a57806327c8f8351461033057600080fd5b806306fdde0314610214578063095ea7b31461023f5780631694505e1461026f57806318160ddd146102bb57600080fd5b3661020f57005b600080fd5b34801561022057600080fd5b506102296106ee565b60405161023691906118f0565b60405180910390f35b34801561024b57600080fd5b5061025f61025a36600461195a565b610780565b6040519015158152602001610236565b34801561027b57600080fd5b506102a37f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610236565b3480156102c757600080fd5b506002545b604051908152602001610236565b3480156102e657600080fd5b5061025f6102f5366004611a5c565b610797565b34801561030657600080fd5b5061025f610315366004611b1e565b610980565b34801561032657600080fd5b506102cc600a5481565b34801561033c57600080fd5b506102a361dead81565b34801561035257600080fd5b50610366610361366004611b5f565b6109df565b005b34801561037457600080fd5b50600654600160a01b900460ff1660405160ff9091168152602001610236565b3480156103a057600080fd5b5061025f6103af36600461195a565b610a32565b3480156103c057600080fd5b506102a37f000000000000000000000000000000000000000000000000000000000000000081565b3480156103f457600080fd5b5061025f610403366004611b78565b6001600160a01b03166000908152600b602052604090205460ff1690565b34801561042d57600080fd5b506102cc60085481565b34801561044357600080fd5b5060065461025f90600160b01b900460ff1681565b34801561046457600080fd5b506102cc610473366004611b78565b6001600160a01b031660009081526020819052604090205490565b34801561049a57600080fd5b50610366610a68565b3480156104af57600080fd5b50610366610adc565b3480156104c457600080fd5b506005546001600160a01b03166102a3565b3480156104e257600080fd5b506103666104f1366004611baa565b610b1d565b34801561050257600080fd5b50610366610511366004611b5f565b610b65565b34801561052257600080fd5b50610229610b94565b34801561053757600080fd5b50610366610546366004611bc5565b610ba3565b34801561055757600080fd5b5061025f61056636600461195a565b610c83565b34801561057757600080fd5b5061025f61058636600461195a565b610cd2565b34801561059757600080fd5b506103666105a6366004611b78565b610cdf565b3480156105b757600080fd5b506103666105c6366004611b5f565b610d66565b3480156105d757600080fd5b5061025f6105e6366004611b78565b600c6020526000908152604090205460ff1681565b34801561060757600080fd5b5060065461025f90600160a81b900460ff1681565b34801561062857600080fd5b50610366610637366004611bc5565b610db6565b34801561064857600080fd5b506102cc60075481565b34801561065e57600080fd5b506102cc61066d366004611bfa565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156106a457600080fd5b506102cc60095481565b3480156106ba57600080fd5b506103666106c9366004611b5f565b610e3f565b3480156106da57600080fd5b506103666106e9366004611b78565b610e8f565b6060600380546106fd90611c33565b80601f016020809104026020016040519081016040528092919081815260200182805461072990611c33565b80156107765780601f1061074b57610100808354040283529160200191610776565b820191906000526020600020905b81548152906001019060200180831161075957829003601f168201915b5050505050905090565b600061078d338484610fe0565b5060015b92915050565b6005546000906001600160a01b031633146107cd5760405162461bcd60e51b81526004016107c490611c6e565b60405180910390fd5b600654600160a81b900460ff161561084d5760405162461bcd60e51b815260206004820152603760248201527f54726164696e6720697320616c7265616479206163746976652c2063616e6e6f60448201527f742061697264726f70206166746572206c61756e63682e00000000000000000060648201526084016107c4565b815183511461089e5760405162461bcd60e51b815260206004820152601e60248201527f617272617973206d757374206265207468652073616d65206c656e677468000060448201526064016107c4565b60c883511061090e5760405162461bcd60e51b815260206004820152603660248201527f43616e206f6e6c792061697264726f70203230302077616c6c657473207065726044820152752074786e2064756520746f20676173206c696d69747360501b60648201526084016107c4565b60005b835181101561097657600084828151811061092e5761092e611ca3565b60200260200101519050600084838151811061094c5761094c611ca3565b60200260200101519050610961338383611105565b5050808061096e90611ccf565b915050610911565b5060019392505050565b600061098d848484611105565b61097684336109da85604051806060016040528060288152602001611ece602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611424565b610fe0565b6005546001600160a01b03163314610a095760405162461bcd60e51b81526004016107c490611c6e565b60078190556005811115610a2f5760405162461bcd60e51b81526004016107c490611cea565b50565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161078d9185906109da9086610f7a565b6005546001600160a01b03163314610a925760405162461bcd60e51b81526004016107c490611c6e565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610b065760405162461bcd60e51b81526004016107c490611c6e565b6006805461ffff60a81b191661010160a81b179055565b6005546001600160a01b03163314610b475760405162461bcd60e51b81526004016107c490611c6e565b60068054911515600160b01b0260ff60b01b19909216919091179055565b6005546001600160a01b03163314610b8f5760405162461bcd60e51b81526004016107c490611c6e565b600a55565b6060600480546106fd90611c33565b6005546001600160a01b03163314610bcd5760405162461bcd60e51b81526004016107c490611c6e565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b03161415610c755760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b657250616972730000000000000060648201526084016107c4565b610c7f828261145e565b5050565b600061078d33846109da85604051806060016040528060258152602001611ef6602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611424565b600061078d338484611105565b6005546001600160a01b03163314610d095760405162461bcd60e51b81526004016107c490611c6e565b6006546040516001600160a01b03918216918316907fa751787977eeb3902e30e1d19ca00c6ad274a1f622c31a206e32366700b0567490600090a3600680546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610d905760405162461bcd60e51b81526004016107c490611c6e565b60098190556005811115610a2f5760405162461bcd60e51b81526004016107c490611cea565b6005546001600160a01b03163314610de05760405162461bcd60e51b81526004016107c490611c6e565b6001600160a01b0382166000818152600b6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610e695760405162461bcd60e51b81526004016107c490611c6e565b60088190556005811115610a2f5760405162461bcd60e51b81526004016107c490611cea565b6005546001600160a01b03163314610eb95760405162461bcd60e51b81526004016107c490611c6e565b6001600160a01b038116610f1e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107c4565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610f878385611d21565b905083811015610fd95760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107c4565b9392505050565b6001600160a01b0383166110425760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107c4565b6001600160a01b0382166110a35760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107c4565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661112b5760405162461bcd60e51b81526004016107c490611d39565b6001600160a01b0382166111515760405162461bcd60e51b81526004016107c490611d7e565b600654600160a81b900460ff166111e6576001600160a01b0383166000908152600b602052604090205460ff16806111a157506001600160a01b0382166000908152600b602052604090205460ff165b6111e65760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016107c4565b806111fc576111f7838360006114b2565b505050565b30600090815260208190526040902054600a5481118080156112275750600654600160b01b900460ff165b801561123d5750600554600160a01b900460ff16155b801561126257506001600160a01b0385166000908152600c602052604090205460ff16155b801561128757506001600160a01b0385166000908152600b602052604090205460ff16155b80156112ac57506001600160a01b0384166000908152600b602052604090205460ff16155b156112da576005805460ff60a01b1916600160a01b1790556112cc6115bb565b6005805460ff60a01b191690555b6005546001600160a01b0386166000908152600b602052604090205460ff600160a01b90920482161591168061132857506001600160a01b0385166000908152600b602052604090205460ff165b15611331575060005b60008115611410576001600160a01b0386166000908152600c602052604090205460ff161561138a576008541561138557611382606461137c6008548861163590919063ffffffff16565b906116b4565b90505b6113f2565b6001600160a01b0387166000908152600c602052604090205460ff16156113cd576007541561138557611382606461137c6007548861163590919063ffffffff16565b600954156113f2576113ef606461137c6009548861163590919063ffffffff16565b90505b8015611403576114038730836114b2565b61140d8186611dc1565b94505b61141b8787876114b2565b50505050505050565b600081848411156114485760405162461bcd60e51b81526004016107c491906118f0565b5060006114558486611dc1565b95945050505050565b6001600160a01b0382166000818152600c6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b0383166114d85760405162461bcd60e51b81526004016107c490611d39565b6001600160a01b0382166114fe5760405162461bcd60e51b81526004016107c490611d7e565b61153b81604051806060016040528060268152602001611ea8602691396001600160a01b0386166000908152602081905260409020549190611424565b6001600160a01b03808516600090815260208190526040808220939093559084168152205461156a9082610f7a565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91016110f8565b30600090815260208190526040902054806115d35750565b6115dc816116f6565b6006546040516000916001600160a01b03169047908381818185875af1925050503d8060008114611629576040519150601f19603f3d011682016040523d82523d6000602084013e61162e565b606091505b5050505050565b60008261164457506000610791565b60006116508385611dd8565b90508261165d8583611df7565b14610fd95760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107c4565b6000610fd983836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506118c2565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061172b5761172b611ca3565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156117a457600080fd5b505afa1580156117b8573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117dc9190611e19565b816001815181106117ef576117ef611ca3565b60200260200101906001600160a01b031690816001600160a01b03168152505061183a307f000000000000000000000000000000000000000000000000000000000000000084610fe0565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac9479061188f908590600090869030904290600401611e36565b600060405180830381600087803b1580156118a957600080fd5b505af19250505080156118ba575060015b610c7f575050565b600081836118e35760405162461bcd60e51b81526004016107c491906118f0565b5060006114558486611df7565b600060208083528351808285015260005b8181101561191d57858101830151858201604001528201611901565b8181111561192f576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610a2f57600080fd5b6000806040838503121561196d57600080fd5b823561197881611945565b946020939093013593505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff811182821017156119c5576119c5611986565b604052919050565b600067ffffffffffffffff8211156119e7576119e7611986565b5060051b60200190565b600082601f830112611a0257600080fd5b81356020611a17611a12836119cd565b61199c565b82815260059290921b84018101918181019086841115611a3657600080fd5b8286015b84811015611a515780358352918301918301611a3a565b509695505050505050565b60008060408385031215611a6f57600080fd5b823567ffffffffffffffff80821115611a8757600080fd5b818501915085601f830112611a9b57600080fd5b81356020611aab611a12836119cd565b82815260059290921b84018101918181019089841115611aca57600080fd5b948201945b83861015611af1578535611ae281611945565b82529482019490820190611acf565b96505086013592505080821115611b0757600080fd5b50611b14858286016119f1565b9150509250929050565b600080600060608486031215611b3357600080fd5b8335611b3e81611945565b92506020840135611b4e81611945565b929592945050506040919091013590565b600060208284031215611b7157600080fd5b5035919050565b600060208284031215611b8a57600080fd5b8135610fd981611945565b80358015158114611ba557600080fd5b919050565b600060208284031215611bbc57600080fd5b610fd982611b95565b60008060408385031215611bd857600080fd5b8235611be381611945565b9150611bf160208401611b95565b90509250929050565b60008060408385031215611c0d57600080fd5b8235611c1881611945565b91506020830135611c2881611945565b809150509250929050565b600181811c90821680611c4757607f821691505b60208210811415611c6857634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600019821415611ce357611ce3611cb9565b5060010190565b6020808252601d908201527f4d757374206b656570206665657320617420313025206f72206c657373000000604082015260600190565b60008219821115611d3457611d34611cb9565b500190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015611dd357611dd3611cb9565b500390565b6000816000190483118215151615611df257611df2611cb9565b500290565b600082611e1457634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215611e2b57600080fd5b8151610fd981611945565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611e865784516001600160a01b031683529383019391830191600101611e61565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220e61bbcb90fab11410bc2c90ed07686fb0a984b71435035e87697d1abe136556764736f6c634300080900334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65728be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0

Deployed Bytecode

0x6080604052600436106102085760003560e01c80638a8c523c11610118578063b4443f5b116100a0578063d85ba0631161006f578063d85ba0631461063c578063dd62ed3e14610652578063e3c4818d14610698578063e4b4d155146106ae578063f2fde38b146106ce57600080fd5b8063b4443f5b146105ab578063b62496f5146105cb578063bbc0c742146105fb578063c02466681461061c57600080fd5b806395d89b41116100e757806395d89b41146105165780639a7a23d61461052b578063a457c2d71461054b578063a9059cbb1461056b578063aacebbe31461058b57600080fd5b80638a8c523c146104a35780638da5cb5b146104b8578063924de9b7146104d657806393c1bc24146104f657600080fd5b80632b4bcdc61161019b5780634fbee1931161016a5780634fbee193146103e85780636a486a8e146104215780636ddd17131461043757806370a0823114610458578063715018a61461048e57600080fd5b80632b4bcdc614610346578063313ce56714610368578063395093511461039457806349bd5a5e146103b457600080fd5b80632307b441116101d75780632307b441146102da57806323b872dd146102fa578063258bb6e11461031a57806327c8f8351461033057600080fd5b806306fdde0314610214578063095ea7b31461023f5780631694505e1461026f57806318160ddd146102bb57600080fd5b3661020f57005b600080fd5b34801561022057600080fd5b506102296106ee565b60405161023691906118f0565b60405180910390f35b34801561024b57600080fd5b5061025f61025a36600461195a565b610780565b6040519015158152602001610236565b34801561027b57600080fd5b506102a37f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b039091168152602001610236565b3480156102c757600080fd5b506002545b604051908152602001610236565b3480156102e657600080fd5b5061025f6102f5366004611a5c565b610797565b34801561030657600080fd5b5061025f610315366004611b1e565b610980565b34801561032657600080fd5b506102cc600a5481565b34801561033c57600080fd5b506102a361dead81565b34801561035257600080fd5b50610366610361366004611b5f565b6109df565b005b34801561037457600080fd5b50600654600160a01b900460ff1660405160ff9091168152602001610236565b3480156103a057600080fd5b5061025f6103af36600461195a565b610a32565b3480156103c057600080fd5b506102a37f0000000000000000000000007ca83d8a231591323400af7cb2a77804f3ca205481565b3480156103f457600080fd5b5061025f610403366004611b78565b6001600160a01b03166000908152600b602052604090205460ff1690565b34801561042d57600080fd5b506102cc60085481565b34801561044357600080fd5b5060065461025f90600160b01b900460ff1681565b34801561046457600080fd5b506102cc610473366004611b78565b6001600160a01b031660009081526020819052604090205490565b34801561049a57600080fd5b50610366610a68565b3480156104af57600080fd5b50610366610adc565b3480156104c457600080fd5b506005546001600160a01b03166102a3565b3480156104e257600080fd5b506103666104f1366004611baa565b610b1d565b34801561050257600080fd5b50610366610511366004611b5f565b610b65565b34801561052257600080fd5b50610229610b94565b34801561053757600080fd5b50610366610546366004611bc5565b610ba3565b34801561055757600080fd5b5061025f61056636600461195a565b610c83565b34801561057757600080fd5b5061025f61058636600461195a565b610cd2565b34801561059757600080fd5b506103666105a6366004611b78565b610cdf565b3480156105b757600080fd5b506103666105c6366004611b5f565b610d66565b3480156105d757600080fd5b5061025f6105e6366004611b78565b600c6020526000908152604090205460ff1681565b34801561060757600080fd5b5060065461025f90600160a81b900460ff1681565b34801561062857600080fd5b50610366610637366004611bc5565b610db6565b34801561064857600080fd5b506102cc60075481565b34801561065e57600080fd5b506102cc61066d366004611bfa565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156106a457600080fd5b506102cc60095481565b3480156106ba57600080fd5b506103666106c9366004611b5f565b610e3f565b3480156106da57600080fd5b506103666106e9366004611b78565b610e8f565b6060600380546106fd90611c33565b80601f016020809104026020016040519081016040528092919081815260200182805461072990611c33565b80156107765780601f1061074b57610100808354040283529160200191610776565b820191906000526020600020905b81548152906001019060200180831161075957829003601f168201915b5050505050905090565b600061078d338484610fe0565b5060015b92915050565b6005546000906001600160a01b031633146107cd5760405162461bcd60e51b81526004016107c490611c6e565b60405180910390fd5b600654600160a81b900460ff161561084d5760405162461bcd60e51b815260206004820152603760248201527f54726164696e6720697320616c7265616479206163746976652c2063616e6e6f60448201527f742061697264726f70206166746572206c61756e63682e00000000000000000060648201526084016107c4565b815183511461089e5760405162461bcd60e51b815260206004820152601e60248201527f617272617973206d757374206265207468652073616d65206c656e677468000060448201526064016107c4565b60c883511061090e5760405162461bcd60e51b815260206004820152603660248201527f43616e206f6e6c792061697264726f70203230302077616c6c657473207065726044820152752074786e2064756520746f20676173206c696d69747360501b60648201526084016107c4565b60005b835181101561097657600084828151811061092e5761092e611ca3565b60200260200101519050600084838151811061094c5761094c611ca3565b60200260200101519050610961338383611105565b5050808061096e90611ccf565b915050610911565b5060019392505050565b600061098d848484611105565b61097684336109da85604051806060016040528060288152602001611ece602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611424565b610fe0565b6005546001600160a01b03163314610a095760405162461bcd60e51b81526004016107c490611c6e565b60078190556005811115610a2f5760405162461bcd60e51b81526004016107c490611cea565b50565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161078d9185906109da9086610f7a565b6005546001600160a01b03163314610a925760405162461bcd60e51b81526004016107c490611c6e565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610b065760405162461bcd60e51b81526004016107c490611c6e565b6006805461ffff60a81b191661010160a81b179055565b6005546001600160a01b03163314610b475760405162461bcd60e51b81526004016107c490611c6e565b60068054911515600160b01b0260ff60b01b19909216919091179055565b6005546001600160a01b03163314610b8f5760405162461bcd60e51b81526004016107c490611c6e565b600a55565b6060600480546106fd90611c33565b6005546001600160a01b03163314610bcd5760405162461bcd60e51b81526004016107c490611c6e565b7f0000000000000000000000007ca83d8a231591323400af7cb2a77804f3ca20546001600160a01b0316826001600160a01b03161415610c755760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b657250616972730000000000000060648201526084016107c4565b610c7f828261145e565b5050565b600061078d33846109da85604051806060016040528060258152602001611ef6602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611424565b600061078d338484611105565b6005546001600160a01b03163314610d095760405162461bcd60e51b81526004016107c490611c6e565b6006546040516001600160a01b03918216918316907fa751787977eeb3902e30e1d19ca00c6ad274a1f622c31a206e32366700b0567490600090a3600680546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610d905760405162461bcd60e51b81526004016107c490611c6e565b60098190556005811115610a2f5760405162461bcd60e51b81526004016107c490611cea565b6005546001600160a01b03163314610de05760405162461bcd60e51b81526004016107c490611c6e565b6001600160a01b0382166000818152600b6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610e695760405162461bcd60e51b81526004016107c490611c6e565b60088190556005811115610a2f5760405162461bcd60e51b81526004016107c490611cea565b6005546001600160a01b03163314610eb95760405162461bcd60e51b81526004016107c490611c6e565b6001600160a01b038116610f1e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107c4565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610f878385611d21565b905083811015610fd95760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107c4565b9392505050565b6001600160a01b0383166110425760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107c4565b6001600160a01b0382166110a35760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107c4565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661112b5760405162461bcd60e51b81526004016107c490611d39565b6001600160a01b0382166111515760405162461bcd60e51b81526004016107c490611d7e565b600654600160a81b900460ff166111e6576001600160a01b0383166000908152600b602052604090205460ff16806111a157506001600160a01b0382166000908152600b602052604090205460ff165b6111e65760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016107c4565b806111fc576111f7838360006114b2565b505050565b30600090815260208190526040902054600a5481118080156112275750600654600160b01b900460ff165b801561123d5750600554600160a01b900460ff16155b801561126257506001600160a01b0385166000908152600c602052604090205460ff16155b801561128757506001600160a01b0385166000908152600b602052604090205460ff16155b80156112ac57506001600160a01b0384166000908152600b602052604090205460ff16155b156112da576005805460ff60a01b1916600160a01b1790556112cc6115bb565b6005805460ff60a01b191690555b6005546001600160a01b0386166000908152600b602052604090205460ff600160a01b90920482161591168061132857506001600160a01b0385166000908152600b602052604090205460ff165b15611331575060005b60008115611410576001600160a01b0386166000908152600c602052604090205460ff161561138a576008541561138557611382606461137c6008548861163590919063ffffffff16565b906116b4565b90505b6113f2565b6001600160a01b0387166000908152600c602052604090205460ff16156113cd576007541561138557611382606461137c6007548861163590919063ffffffff16565b600954156113f2576113ef606461137c6009548861163590919063ffffffff16565b90505b8015611403576114038730836114b2565b61140d8186611dc1565b94505b61141b8787876114b2565b50505050505050565b600081848411156114485760405162461bcd60e51b81526004016107c491906118f0565b5060006114558486611dc1565b95945050505050565b6001600160a01b0382166000818152600c6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b0383166114d85760405162461bcd60e51b81526004016107c490611d39565b6001600160a01b0382166114fe5760405162461bcd60e51b81526004016107c490611d7e565b61153b81604051806060016040528060268152602001611ea8602691396001600160a01b0386166000908152602081905260409020549190611424565b6001600160a01b03808516600090815260208190526040808220939093559084168152205461156a9082610f7a565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91016110f8565b30600090815260208190526040902054806115d35750565b6115dc816116f6565b6006546040516000916001600160a01b03169047908381818185875af1925050503d8060008114611629576040519150601f19603f3d011682016040523d82523d6000602084013e61162e565b606091505b5050505050565b60008261164457506000610791565b60006116508385611dd8565b90508261165d8583611df7565b14610fd95760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107c4565b6000610fd983836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506118c2565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061172b5761172b611ca3565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156117a457600080fd5b505afa1580156117b8573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117dc9190611e19565b816001815181106117ef576117ef611ca3565b60200260200101906001600160a01b031690816001600160a01b03168152505061183a307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610fe0565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac9479061188f908590600090869030904290600401611e36565b600060405180830381600087803b1580156118a957600080fd5b505af19250505080156118ba575060015b610c7f575050565b600081836118e35760405162461bcd60e51b81526004016107c491906118f0565b5060006114558486611df7565b600060208083528351808285015260005b8181101561191d57858101830151858201604001528201611901565b8181111561192f576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610a2f57600080fd5b6000806040838503121561196d57600080fd5b823561197881611945565b946020939093013593505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff811182821017156119c5576119c5611986565b604052919050565b600067ffffffffffffffff8211156119e7576119e7611986565b5060051b60200190565b600082601f830112611a0257600080fd5b81356020611a17611a12836119cd565b61199c565b82815260059290921b84018101918181019086841115611a3657600080fd5b8286015b84811015611a515780358352918301918301611a3a565b509695505050505050565b60008060408385031215611a6f57600080fd5b823567ffffffffffffffff80821115611a8757600080fd5b818501915085601f830112611a9b57600080fd5b81356020611aab611a12836119cd565b82815260059290921b84018101918181019089841115611aca57600080fd5b948201945b83861015611af1578535611ae281611945565b82529482019490820190611acf565b96505086013592505080821115611b0757600080fd5b50611b14858286016119f1565b9150509250929050565b600080600060608486031215611b3357600080fd5b8335611b3e81611945565b92506020840135611b4e81611945565b929592945050506040919091013590565b600060208284031215611b7157600080fd5b5035919050565b600060208284031215611b8a57600080fd5b8135610fd981611945565b80358015158114611ba557600080fd5b919050565b600060208284031215611bbc57600080fd5b610fd982611b95565b60008060408385031215611bd857600080fd5b8235611be381611945565b9150611bf160208401611b95565b90509250929050565b60008060408385031215611c0d57600080fd5b8235611c1881611945565b91506020830135611c2881611945565b809150509250929050565b600181811c90821680611c4757607f821691505b60208210811415611c6857634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600019821415611ce357611ce3611cb9565b5060010190565b6020808252601d908201527f4d757374206b656570206665657320617420313025206f72206c657373000000604082015260600190565b60008219821115611d3457611d34611cb9565b500190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015611dd357611dd3611cb9565b500390565b6000816000190483118215151615611df257611df2611cb9565b500290565b600082611e1457634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215611e2b57600080fd5b8151610fd981611945565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611e865784516001600160a01b031683529383019391830191600101611e61565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220e61bbcb90fab11410bc2c90ed07686fb0a984b71435035e87697d1abe136556764736f6c63430008090033

Deployed Bytecode Sourcemap

29434:10778:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7590:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;9757:169;;;;;;;;;;-1:-1:-1;9757:169:0;;;;;:::i;:::-;;:::i;:::-;;;1237:14:1;;1230:22;1212:41;;1200:2;1185:18;9757:169:0;1072:187:1;29510:51:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;1455:32:1;;;1437:51;;1425:2;1410:18;29510:51:0;1264:230:1;8710:108:0;;;;;;;;;;-1:-1:-1;8798:12:0;;8710:108;;;1645:25:1;;;1633:2;1618:18;8710:108:0;1499:177:1;33718:752:0;;;;;;;;;;-1:-1:-1;33718:752:0;;;;;:::i;:::-;;:::i;10408:355::-;;;;;;;;;;-1:-1:-1;10408:355:0;;;;;:::i;:::-;;:::i;29995:33::-;;;;;;;;;;;;;;;;29613:53;;;;;;;;;;;;29659:6;29613:53;;34787:180;;;;;;;;;;-1:-1:-1;34787:180:0;;;;;:::i;:::-;;:::i;:::-;;34482:92;;;;;;;;;;-1:-1:-1;34557:9:0;;-1:-1:-1;;;34557:9:0;;;;34482:92;;5194:4:1;5182:17;;;5164:36;;5152:2;5137:18;34482:92:0;5022:184:1;11172:218:0;;;;;;;;;;-1:-1:-1;11172:218:0;;;;;:::i;:::-;;:::i;29568:38::-;;;;;;;;;;;;;;;36239:127;;;;;;;;;;-1:-1:-1;36239:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;36330:28:0;36306:4;36330:28;;;:19;:28;;;;;;;;;36239:127;29913:28;;;;;;;;;;;;;;;;29821:31;;;;;;;;;;-1:-1:-1;29821:31:0;;;;-1:-1:-1;;;29821:31:0;;;;;;8881:127;;;;;;;;;;-1:-1:-1;8881:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;8982:18:0;8955:7;8982:18;;;;;;;;;;;;8881:127;22055:148;;;;;;;;;;;;;:::i;33594:112::-;;;;;;;;;;;;;:::i;21413:79::-;;;;;;;;;;-1:-1:-1;21478:6:0;;-1:-1:-1;;;;;21478:6:0;21413:79;;34674:101;;;;;;;;;;-1:-1:-1;34674:101:0;;;;;:::i;:::-;;:::i;36374:121::-;;;;;;;;;;-1:-1:-1;36374:121:0;;;;;:::i;:::-;;:::i;7809:104::-;;;;;;;;;;;;;:::i;35565:246::-;;;;;;;;;;-1:-1:-1;35565:246:0;;;;;:::i;:::-;;:::i;11893:269::-;;;;;;;;;;-1:-1:-1;11893:269:0;;;;;:::i;:::-;;:::i;9221:175::-;;;;;;;;;;-1:-1:-1;9221:175:0;;;;;:::i;:::-;;:::i;36019:208::-;;;;;;;;;;-1:-1:-1;36019:208:0;;;;;:::i;:::-;;:::i;35169:198::-;;;;;;;;;;-1:-1:-1;35169:198:0;;;;;:::i;:::-;;:::i;30333:58::-;;;;;;;;;;-1:-1:-1;30333:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29781:33;;;;;;;;;;-1:-1:-1;29781:33:0;;;;-1:-1:-1;;;29781:33:0;;;;;;35375:182;;;;;;;;;;-1:-1:-1;35375:182:0;;;;;:::i;:::-;;:::i;29873:27::-;;;;;;;;;;;;;;;;9459:151;;;;;;;;;;-1:-1:-1;9459:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;9575:18:0;;;9548:7;9575:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9459:151;29950:32;;;;;;;;;;;;;;;;34979:182;;;;;;;;;;-1:-1:-1;34979:182:0;;;;;:::i;:::-;;:::i;22358:244::-;;;;;;;;;;-1:-1:-1;22358:244:0;;;;;:::i;:::-;;:::i;7590:100::-;7644:13;7677:5;7670:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7590:100;:::o;9757:169::-;9840:4;9857:39;306:10;9880:7;9889:6;9857:8;:39::i;:::-;-1:-1:-1;9914:4:0;9757:169;;;;;:::o;33718:752::-;21625:6;;33831:4;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;;;;;;;;;33856:13:::1;::::0;-1:-1:-1;;;33856:13:0;::::1;;;33855:14;33847:82;;;::::0;-1:-1:-1;;;33847:82:0;;7474:2:1;33847:82:0::1;::::0;::::1;7456:21:1::0;7513:2;7493:18;;;7486:30;7552:34;7532:18;;;7525:62;7623:25;7603:18;;;7596:53;7666:19;;33847:82:0::1;7272:419:1::0;33847:82:0::1;33973:7;:14;33948;:21;:39;33940:82;;;::::0;-1:-1:-1;;;33940:82:0;;7898:2:1;33940:82:0::1;::::0;::::1;7880:21:1::0;7937:2;7917:18;;;7910:30;7976:32;7956:18;;;7949:60;8026:18;;33940:82:0::1;7696:354:1::0;33940:82:0::1;34065:3;34041:14;:21;:27;34033:94;;;::::0;-1:-1:-1;;;34033:94:0;;8257:2:1;34033:94:0::1;::::0;::::1;8239:21:1::0;8296:2;8276:18;;;8269:30;8335:34;8315:18;;;8308:62;-1:-1:-1;;;8386:18:1;;;8379:52;8448:19;;34033:94:0::1;8055:418:1::0;34033:94:0::1;34240:9;34236:205;34259:14;:21;34255:1;:25;34236:205;;;34301:14;34318;34333:1;34318:17;;;;;;;;:::i;:::-;;;;;;;34301:34;;34350:14;34367:7;34375:1;34367:10;;;;;;;;:::i;:::-;;;;;;;34350:27;;34392:37;34402:10;34414:6;34422;34392:9;:37::i;:::-;34286:155;;34282:3;;;;;:::i;:::-;;;;34236:205;;;-1:-1:-1::0;34458:4:0::1;::::0;33718:752;-1:-1:-1;;;33718:752:0:o;10408:355::-;10548:4;10565:36;10575:6;10583:9;10594:6;10565:9;:36::i;:::-;10612:121;10621:6;306:10;10643:89;10681:6;10643:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10643:19:0;;;;;;:11;:19;;;;;;;;306:10;10643:33;;;;;;;;;;:37;:89::i;:::-;10612:8;:121::i;34787:180::-;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;34861:12:::1;:28:::0;;;34924:1:::1;34908:17:::0;::::1;;34900:59;;;;-1:-1:-1::0;;;34900:59:0::1;;;;;;;:::i;:::-;34787:180:::0;:::o;11172:218::-;306:10;11260:4;11309:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11309:34:0;;;;;;;;;;11260:4;;11277:83;;11300:7;;11309:50;;11348:10;11309:38;:50::i;22055:148::-;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;22146:6:::1;::::0;22125:40:::1;::::0;22162:1:::1;::::0;-1:-1:-1;;;;;22146:6:0::1;::::0;22125:40:::1;::::0;22162:1;;22125:40:::1;22176:6;:19:::0;;-1:-1:-1;;;;;;22176:19:0::1;::::0;;22055:148::o;33594:112::-;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;33649:13:::1;:20:::0;;-1:-1:-1;;;;33680:18:0;-1:-1:-1;;;33680:18:0;;;33594:112::o;34674:101::-;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;34746:11:::1;:21:::0;;;::::1;;-1:-1:-1::0;;;34746:21:0::1;-1:-1:-1::0;;;;34746:21:0;;::::1;::::0;;;::::1;::::0;;34674:101::o;36374:121::-;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;36456:18:::1;:31:::0;36374:121::o;7809:104::-;7865:13;7898:7;7891:14;;;;;:::i;35565:246::-;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;35674:13:::1;-1:-1:-1::0;;;;;35666:21:0::1;:4;-1:-1:-1::0;;;;;35666:21:0::1;;;35658:91;;;::::0;-1:-1:-1;;;35658:91:0;;9442:2:1;35658:91:0::1;::::0;::::1;9424:21:1::0;9481:2;9461:18;;;9454:30;9520:34;9500:18;;;9493:62;9591:27;9571:18;;;9564:55;9636:19;;35658:91:0::1;9240:421:1::0;35658:91:0::1;35762:41;35791:4;35797:5;35762:28;:41::i;:::-;35565:246:::0;;:::o;11893:269::-;11986:4;12003:129;306:10;12026:7;12035:96;12074:15;12035:96;;;;;;;;;;;;;;;;;306:10;12035:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;12035:34:0;;;;;;;;;;;;:38;:96::i;9221:175::-;9307:4;9324:42;306:10;9348:9;9359:6;9324:9;:42::i;36019:208::-;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;36156:15:::1;::::0;36113:59:::1;::::0;-1:-1:-1;;;;;36156:15:0;;::::1;::::0;36113:59;::::1;::::0;::::1;::::0;36156:15:::1;::::0;36113:59:::1;36183:15;:36:::0;;-1:-1:-1;;;;;;36183:36:0::1;-1:-1:-1::0;;;;;36183:36:0;;;::::1;::::0;;;::::1;::::0;;36019:208::o;35169:198::-;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;35250:17:::1;:33:::0;;;35324:1:::1;35303:22:::0;::::1;;35295:64;;;;-1:-1:-1::0;;;35295:64:0::1;;;;;;;:::i;35375:182::-:0;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35460:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;35460:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;35515:34;;1212:41:1;;;35515:34:0::1;::::0;1185:18:1;35515:34:0::1;;;;;;;35375:182:::0;;:::o;34979:::-;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;35053:13:::1;:29:::0;;;35118:1:::1;35101:18:::0;::::1;;35093:60;;;;-1:-1:-1::0;;;35093:60:0::1;;;;;;;:::i;22358:244::-:0;21625:6;;-1:-1:-1;;;;;21625:6:0;306:10;21625:22;21617:67;;;;-1:-1:-1;;;21617:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22447:22:0;::::1;22439:73;;;::::0;-1:-1:-1;;;22439:73:0;;9868:2:1;22439:73:0::1;::::0;::::1;9850:21:1::0;9907:2;9887:18;;;9880:30;9946:34;9926:18;;;9919:62;-1:-1:-1;;;9997:18:1;;;9990:36;10043:19;;22439:73:0::1;9666:402:1::0;22439:73:0::1;22549:6;::::0;22528:38:::1;::::0;-1:-1:-1;;;;;22528:38:0;;::::1;::::0;22549:6:::1;::::0;22528:38:::1;::::0;22549:6:::1;::::0;22528:38:::1;22577:6;:17:::0;;-1:-1:-1;;;;;;22577:17:0::1;-1:-1:-1::0;;;;;22577:17:0;;;::::1;::::0;;;::::1;::::0;;22358:244::o;16457:181::-;16515:7;;16547:5;16551:1;16547;:5;:::i;:::-;16535:17;;16576:1;16571;:6;;16563:46;;;;-1:-1:-1;;;16563:46:0;;10408:2:1;16563:46:0;;;10390:21:1;10447:2;10427:18;;;10420:30;10486:29;10466:18;;;10459:57;10533:18;;16563:46:0;10206:351:1;16563:46:0;16629:1;16457:181;-1:-1:-1;;;16457:181:0:o;15079:380::-;-1:-1:-1;;;;;15215:19:0;;15207:68;;;;-1:-1:-1;;;15207:68:0;;10764:2:1;15207:68:0;;;10746:21:1;10803:2;10783:18;;;10776:30;10842:34;10822:18;;;10815:62;-1:-1:-1;;;10893:18:1;;;10886:34;10937:19;;15207:68:0;10562:400:1;15207:68:0;-1:-1:-1;;;;;15294:21:0;;15286:68;;;;-1:-1:-1;;;15286:68:0;;11169:2:1;15286:68:0;;;11151:21:1;11208:2;11188:18;;;11181:30;11247:34;11227:18;;;11220:62;-1:-1:-1;;;11298:18:1;;;11291:32;11340:19;;15286:68:0;10967:398:1;15286:68:0;-1:-1:-1;;;;;15367:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15419:32;;1645:25:1;;;15419:32:0;;1618:18:1;15419:32:0;;;;;;;;15079:380;;;:::o;36507:2188::-;-1:-1:-1;;;;;36639:18:0;;36631:68;;;;-1:-1:-1;;;36631:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;36718:16:0;;36710:64;;;;-1:-1:-1;;;36710:64:0;;;;;;;:::i;:::-;36789:13;;-1:-1:-1;;;36789:13:0;;;;36785:132;;-1:-1:-1;;;;;36826:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;36855:23:0;;;;;;:19;:23;;;;;;;;36826:52;36818:87;;;;-1:-1:-1;;;36818:87:0;;12382:2:1;36818:87:0;;;12364:21:1;12421:2;12401:18;;;12394:30;-1:-1:-1;;;12440:18:1;;;12433:52;12502:18;;36818:87:0;12180:346:1;36818:87:0;36931:11;36928:92;;36959:28;36975:4;36981:2;36985:1;36959:15;:28::i;:::-;36507:2188;;;:::o;36928:92::-;37091:4;37042:28;8982:18;;;;;;;;;;;37156;;37133:41;;;37205:35;;;;-1:-1:-1;37229:11:0;;-1:-1:-1;;;37229:11:0;;;;37205:35;:61;;;;-1:-1:-1;37258:8:0;;-1:-1:-1;;;37258:8:0;;;;37257:9;37205:61;:110;;;;-1:-1:-1;;;;;;37284:31:0;;;;;;:25;:31;;;;;;;;37283:32;37205:110;:153;;;;-1:-1:-1;;;;;;37333:25:0;;;;;;:19;:25;;;;;;;;37332:26;37205:153;:194;;;;-1:-1:-1;;;;;;37376:23:0;;;;;;:19;:23;;;;;;;;37375:24;37205:194;37187:338;;;37426:8;:15;;-1:-1:-1;;;;37426:15:0;-1:-1:-1;;;37426:15:0;;;37470:10;:8;:10::i;:::-;37497:8;:16;;-1:-1:-1;;;;37497:16:0;;;37187:338;37561:8;;-1:-1:-1;;;;;37670:25:0;;37545:12;37670:25;;;:19;:25;;;;;;37561:8;-1:-1:-1;;;37561:8:0;;;;;37560:9;;37670:25;;:52;;-1:-1:-1;;;;;;37699:23:0;;;;;;:19;:23;;;;;;;;37670:52;37667:99;;;-1:-1:-1;37749:5:0;37667:99;37786:12;37890:7;37887:755;;;-1:-1:-1;;;;;37931:29:0;;;;;;:25;:29;;;;;;;;37927:546;;;37984:13;;:17;37980:106;;38032:34;38062:3;38032:25;38043:13;;38032:6;:10;;:25;;;;:::i;:::-;:29;;:34::i;:::-;38025:41;;37980:106;37927:546;;;-1:-1:-1;;;;;38146:31:0;;;;;;:25;:31;;;;;;;;38143:330;;;38202:12;;:16;38198:104;;38249:33;38278:3;38249:24;38260:12;;38249:6;:10;;:24;;;;:::i;38143:330::-;38348:17;;:21;38344:114;;38400:38;38434:3;38400:29;38411:17;;38400:6;:10;;:29;;;;:::i;:38::-;38393:45;;38344:114;38504:8;;38501:93;;38536:42;38552:4;38566;38573;38536:15;:42::i;:::-;38616:14;38626:4;38616:14;;:::i;:::-;;;37887:755;38654:33;38670:4;38676:2;38680:6;38654:15;:33::i;:::-;36620:2075;;;;36507:2188;;;:::o;17360:192::-;17446:7;17482:12;17474:6;;;;17466:29;;;;-1:-1:-1;;;17466:29:0;;;;;;;;:::i;:::-;-1:-1:-1;17506:9:0;17518:5;17522:1;17518;:5;:::i;:::-;17506:17;17360:192;-1:-1:-1;;;;;17360:192:0:o;35823:188::-;-1:-1:-1;;;;;35906:31:0;;;;;;:25;:31;;;;;;:39;;-1:-1:-1;;35906:39:0;;;;;;;;;;35963:40;;35906:39;;:31;35963:40;;;35823:188;;:::o;12652:573::-;-1:-1:-1;;;;;12792:20:0;;12784:70;;;;-1:-1:-1;;;12784:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12873:23:0;;12865:71;;;;-1:-1:-1;;;12865:71:0;;;;;;;:::i;:::-;13029;13051:6;13029:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;13029:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;13009:17:0;;;:9;:17;;;;;;;;;;;:91;;;;13134:20;;;;;;;:32;;13159:6;13134:24;:32::i;:::-;-1:-1:-1;;;;;13111:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;13182:35;1645:25:1;;;13111:20:0;;13182:35;;;;;;1618:18:1;13182:35:0;1499:177:1;39873:336:0;39956:4;39912:23;8982:18;;;;;;;;;;;;39983:34;;40009:7;39873:336::o;39983:34::-;40037:33;40054:15;40037:16;:33::i;:::-;40136:15;;40128:63;;40084:12;;-1:-1:-1;;;;;40136:15:0;;40165:21;;40084:12;40128:63;40084:12;40128:63;40165:21;40136:15;40128:63;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;39873:336:0:o;17811:471::-;17869:7;18114:6;18110:47;;-1:-1:-1;18144:1:0;18137:8;;18110:47;18169:9;18181:5;18185:1;18181;:5;:::i;:::-;18169:17;-1:-1:-1;18214:1:0;18205:5;18209:1;18169:17;18205:5;:::i;:::-;:10;18197:56;;;;-1:-1:-1;;;18197:56:0;;13468:2:1;18197:56:0;;;13450:21:1;13507:2;13487:18;;;13480:30;13546:34;13526:18;;;13519:62;-1:-1:-1;;;13597:18:1;;;13590:31;13638:19;;18197:56:0;13266:397:1;18758:132:0;18816:7;18843:39;18847:1;18850;18843:39;;;;;;;;;;;;;;;;;:3;:39::i;38703:616::-;38855:16;;;38869:1;38855:16;;;;;;;;38831:21;;38855:16;;;;;;;;;;-1:-1:-1;38855:16:0;38831:40;;38900:4;38882;38887:1;38882:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;38882:23:0;;;-1:-1:-1;;;;;38882:23:0;;;;;38926:15;-1:-1:-1;;;;;38926:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;38916:4;38921:1;38916:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;38916:32:0;;;-1:-1:-1;;;;;38916:32:0;;;;;38961:62;38978:4;38993:15;39011:11;38961:8;:62::i;:::-;39066:224;;-1:-1:-1;;;39066:224:0;;-1:-1:-1;;;;;39066:15:0;:66;;;;:224;;39147:11;;39173:1;;39217:4;;39244;;39264:15;;39066:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;39062:240;;35565:246;;:::o;19386:278::-;19472:7;19507:12;19500:5;19492:28;;;;-1:-1:-1;;;19492:28:0;;;;;;;;:::i;:::-;-1:-1:-1;19531:9:0;19543:5;19547:1;19543;:5;:::i;14:597:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;452:6;449:1;446:13;443:91;;;522:1;517:2;508:6;497:9;493:22;489:31;482:42;443:91;-1:-1:-1;595:2:1;574:15;-1:-1:-1;;570:29:1;555:45;;;;602:2;551:54;;14:597;-1:-1:-1;;;14:597:1:o;616:131::-;-1:-1:-1;;;;;691:31:1;;681:42;;671:70;;737:1;734;727:12;752:315;820:6;828;881:2;869:9;860:7;856:23;852:32;849:52;;;897:1;894;887:12;849:52;936:9;923:23;955:31;980:5;955:31;:::i;:::-;1005:5;1057:2;1042:18;;;;1029:32;;-1:-1:-1;;;752:315:1:o;1681:127::-;1742:10;1737:3;1733:20;1730:1;1723:31;1773:4;1770:1;1763:15;1797:4;1794:1;1787:15;1813:275;1884:2;1878:9;1949:2;1930:13;;-1:-1:-1;;1926:27:1;1914:40;;1984:18;1969:34;;2005:22;;;1966:62;1963:88;;;2031:18;;:::i;:::-;2067:2;2060:22;1813:275;;-1:-1:-1;1813:275:1:o;2093:183::-;2153:4;2186:18;2178:6;2175:30;2172:56;;;2208:18;;:::i;:::-;-1:-1:-1;2253:1:1;2249:14;2265:4;2245:25;;2093:183::o;2281:662::-;2335:5;2388:3;2381:4;2373:6;2369:17;2365:27;2355:55;;2406:1;2403;2396:12;2355:55;2442:6;2429:20;2468:4;2492:60;2508:43;2548:2;2508:43;:::i;:::-;2492:60;:::i;:::-;2586:15;;;2672:1;2668:10;;;;2656:23;;2652:32;;;2617:12;;;;2696:15;;;2693:35;;;2724:1;2721;2714:12;2693:35;2760:2;2752:6;2748:15;2772:142;2788:6;2783:3;2780:15;2772:142;;;2854:17;;2842:30;;2892:12;;;;2805;;2772:142;;;-1:-1:-1;2932:5:1;2281:662;-1:-1:-1;;;;;;2281:662:1:o;2948:1215::-;3066:6;3074;3127:2;3115:9;3106:7;3102:23;3098:32;3095:52;;;3143:1;3140;3133:12;3095:52;3183:9;3170:23;3212:18;3253:2;3245:6;3242:14;3239:34;;;3269:1;3266;3259:12;3239:34;3307:6;3296:9;3292:22;3282:32;;3352:7;3345:4;3341:2;3337:13;3333:27;3323:55;;3374:1;3371;3364:12;3323:55;3410:2;3397:16;3432:4;3456:60;3472:43;3512:2;3472:43;:::i;3456:60::-;3550:15;;;3632:1;3628:10;;;;3620:19;;3616:28;;;3581:12;;;;3656:19;;;3653:39;;;3688:1;3685;3678:12;3653:39;3712:11;;;;3732:217;3748:6;3743:3;3740:15;3732:217;;;3828:3;3815:17;3845:31;3870:5;3845:31;:::i;:::-;3889:18;;3765:12;;;;3927;;;;3732:217;;;3968:5;-1:-1:-1;;4011:18:1;;3998:32;;-1:-1:-1;;4042:16:1;;;4039:36;;;4071:1;4068;4061:12;4039:36;;4094:63;4149:7;4138:8;4127:9;4123:24;4094:63;:::i;:::-;4084:73;;;2948:1215;;;;;:::o;4168:456::-;4245:6;4253;4261;4314:2;4302:9;4293:7;4289:23;4285:32;4282:52;;;4330:1;4327;4320:12;4282:52;4369:9;4356:23;4388:31;4413:5;4388:31;:::i;:::-;4438:5;-1:-1:-1;4495:2:1;4480:18;;4467:32;4508:33;4467:32;4508:33;:::i;:::-;4168:456;;4560:7;;-1:-1:-1;;;4614:2:1;4599:18;;;;4586:32;;4168:456::o;4837:180::-;4896:6;4949:2;4937:9;4928:7;4924:23;4920:32;4917:52;;;4965:1;4962;4955:12;4917:52;-1:-1:-1;4988:23:1;;4837:180;-1:-1:-1;4837:180:1:o;5211:247::-;5270:6;5323:2;5311:9;5302:7;5298:23;5294:32;5291:52;;;5339:1;5336;5329:12;5291:52;5378:9;5365:23;5397:31;5422:5;5397:31;:::i;5463:160::-;5528:20;;5584:13;;5577:21;5567:32;;5557:60;;5613:1;5610;5603:12;5557:60;5463:160;;;:::o;5628:180::-;5684:6;5737:2;5725:9;5716:7;5712:23;5708:32;5705:52;;;5753:1;5750;5743:12;5705:52;5776:26;5792:9;5776:26;:::i;5813:315::-;5878:6;5886;5939:2;5927:9;5918:7;5914:23;5910:32;5907:52;;;5955:1;5952;5945:12;5907:52;5994:9;5981:23;6013:31;6038:5;6013:31;:::i;:::-;6063:5;-1:-1:-1;6087:35:1;6118:2;6103:18;;6087:35;:::i;:::-;6077:45;;5813:315;;;;;:::o;6133:388::-;6201:6;6209;6262:2;6250:9;6241:7;6237:23;6233:32;6230:52;;;6278:1;6275;6268:12;6230:52;6317:9;6304:23;6336:31;6361:5;6336:31;:::i;:::-;6386:5;-1:-1:-1;6443:2:1;6428:18;;6415:32;6456:33;6415:32;6456:33;:::i;:::-;6508:7;6498:17;;;6133:388;;;;;:::o;6526:380::-;6605:1;6601:12;;;;6648;;;6669:61;;6723:4;6715:6;6711:17;6701:27;;6669:61;6776:2;6768:6;6765:14;6745:18;6742:38;6739:161;;;6822:10;6817:3;6813:20;6810:1;6803:31;6857:4;6854:1;6847:15;6885:4;6882:1;6875:15;6739:161;;6526:380;;;:::o;6911:356::-;7113:2;7095:21;;;7132:18;;;7125:30;7191:34;7186:2;7171:18;;7164:62;7258:2;7243:18;;6911:356::o;8478:127::-;8539:10;8534:3;8530:20;8527:1;8520:31;8570:4;8567:1;8560:15;8594:4;8591:1;8584:15;8610:127;8671:10;8666:3;8662:20;8659:1;8652:31;8702:4;8699:1;8692:15;8726:4;8723:1;8716:15;8742:135;8781:3;-1:-1:-1;;8802:17:1;;8799:43;;;8822:18;;:::i;:::-;-1:-1:-1;8869:1:1;8858:13;;8742:135::o;8882:353::-;9084:2;9066:21;;;9123:2;9103:18;;;9096:30;9162:31;9157:2;9142:18;;9135:59;9226:2;9211:18;;8882:353::o;10073:128::-;10113:3;10144:1;10140:6;10137:1;10134:13;10131:39;;;10150:18;;:::i;:::-;-1:-1:-1;10186:9:1;;10073:128::o;11370:401::-;11572:2;11554:21;;;11611:2;11591:18;;;11584:30;11650:34;11645:2;11630:18;;11623:62;-1:-1:-1;;;11716:2:1;11701:18;;11694:35;11761:3;11746:19;;11370:401::o;11776:399::-;11978:2;11960:21;;;12017:2;11997:18;;;11990:30;12056:34;12051:2;12036:18;;12029:62;-1:-1:-1;;;12122:2:1;12107:18;;12100:33;12165:3;12150:19;;11776:399::o;12531:125::-;12571:4;12599:1;12596;12593:8;12590:34;;;12604:18;;:::i;:::-;-1:-1:-1;12641:9:1;;12531:125::o;12871:168::-;12911:7;12977:1;12973;12969:6;12965:14;12962:1;12959:21;12954:1;12947:9;12940:17;12936:45;12933:71;;;12984:18;;:::i;:::-;-1:-1:-1;13024:9:1;;12871:168::o;13044:217::-;13084:1;13110;13100:132;;13154:10;13149:3;13145:20;13142:1;13135:31;13189:4;13186:1;13179:15;13217:4;13214:1;13207:15;13100:132;-1:-1:-1;13246:9:1;;13044:217::o;13668:251::-;13738:6;13791:2;13779:9;13770:7;13766:23;13762:32;13759:52;;;13807:1;13804;13797:12;13759:52;13839:9;13833:16;13858:31;13883:5;13858:31;:::i;13924:980::-;14186:4;14234:3;14223:9;14219:19;14265:6;14254:9;14247:25;14291:2;14329:6;14324:2;14313:9;14309:18;14302:34;14372:3;14367:2;14356:9;14352:18;14345:31;14396:6;14431;14425:13;14462:6;14454;14447:22;14500:3;14489:9;14485:19;14478:26;;14539:2;14531:6;14527:15;14513:29;;14560:1;14570:195;14584:6;14581:1;14578:13;14570:195;;;14649:13;;-1:-1:-1;;;;;14645:39:1;14633:52;;14740:15;;;;14705:12;;;;14681:1;14599:9;14570:195;;;-1:-1:-1;;;;;;;14821:32:1;;;;14816:2;14801:18;;14794:60;-1:-1:-1;;;14885:3:1;14870:19;14863:35;14782:3;13924:980;-1:-1:-1;;;13924:980:1:o

Swarm Source

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