ETH Price: $3,206.08 (-1.17%)

Token

Boomer Coin (BOOMER)
 

Overview

Max Total Supply

96,192,917,152.127517351436591821 BOOMER

Holders

580

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
0.000000000000000001 BOOMER

Value
$0.00
0xe37e799d5077682fa0a244d46e5649f71457bd09
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:
Boomer

Compiler Version
v0.8.18+commit.87f61d96

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-05-16
*/

pragma solidity ^0.8.0;
/*
Twitter: 
twitter.com/boomer_coin_eth

Tg:
t.me/boomer_coin_eth
*/

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

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

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

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

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

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

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

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







pragma solidity ^0.8.0;

/**
 * @dev Interface for the optional metadata functions from the ERC20 standard.
 *
 * _Available since v4.1._
 */
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);
}







pragma solidity ^0.8.0;

/**
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

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







pragma solidity ^0.8.0;



/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 * For a generic mechanism see {ERC20PresetMinterPauser}.
 *
 * TIP: For a detailed writeup see our guide
 * https:
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin Contracts guidelines: functions revert
 * instead returning `false` on failure. This behavior is nonetheless
 * conventional and does not conflict with the expectations of ERC20
 * applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 *
 * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
 * functions have been added to mitigate the well-known issues around setting
 * allowances. See {IERC20-approve}.
 */
contract ERC20 is Context, IERC20, IERC20Metadata {
    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:
     *
     * - `to` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address to, uint256 amount) public virtual override returns (bool) {
        address owner = _msgSender();
        _transfer(owner, to, 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}.
     *
     * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on
     * `transferFrom`. This is semantically equivalent to an infinite approval.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        address owner = _msgSender();
        _approve(owner, 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}.
     *
     * NOTE: Does not update the allowance if the current allowance
     * is the maximum `uint256`.
     *
     * Requirements:
     *
     * - `from` and `to` cannot be the zero address.
     * - `from` must have a balance of at least `amount`.
     * - the caller must have allowance for ``from``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address from,
        address to,
        uint256 amount
    ) public virtual override returns (bool) {
        address spender = _msgSender();
        _spendAllowance(from, spender, amount);
        _transfer(from, to, amount);
        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) {
        address owner = _msgSender();
        _approve(owner, spender, allowance(owner, spender) + 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) {
        address owner = _msgSender();
        uint256 currentAllowance = allowance(owner, spender);
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        unchecked {
            _approve(owner, spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    /**
     * @dev Moves `amount` of tokens from `from` to `to`.
     *
     * This 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:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `from` must have a balance of at least `amount`.
     */
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(from, to, amount);

        uint256 fromBalance = _balances[from];
        require(fromBalance >= amount, "ERC20: transfer amount exceeds balance");
        unchecked {
            _balances[from] = fromBalance - amount;
        }
        _balances[to] += amount;

        emit Transfer(from, to, amount);

        _afterTokenTransfer(from, to, 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 += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);

        _afterTokenTransfer(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);

        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        unchecked {
            _balances[account] = accountBalance - amount;
        }
        _totalSupply -= amount;

        emit Transfer(account, address(0), amount);

        _afterTokenTransfer(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 Updates `owner` s allowance for `spender` based on spent `amount`.
     *
     * Does not update the allowance amount in case of infinite allowance.
     * Revert if not enough allowance is available.
     *
     * Might emit an {Approval} event.
     */
    function _spendAllowance(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        uint256 currentAllowance = allowance(owner, spender);
        if (currentAllowance != type(uint256).max) {
            require(currentAllowance >= amount, "ERC20: insufficient allowance");
            unchecked {
                _approve(owner, spender, currentAllowance - 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 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 {}

    /**
     * @dev Hook that is called after any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * has been transferred to `to`.
     * - when `from` is zero, `amount` tokens have been minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens have been 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 _afterTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}







pragma solidity ^0.8.0;


/**
 * @dev Extension of {ERC20} that allows token holders to destroy both their own
 * tokens and those that they have an allowance for, in a way that can be
 * recognized off-chain (via event analysis).
 */
abstract contract ERC20Burnable is Context, ERC20 {
    /**
     * @dev Destroys `amount` tokens from the caller.
     *
     * See {ERC20-_burn}.
     */
    function burn(uint256 amount) public virtual {
        _burn(_msgSender(), amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, deducting from the caller's
     * allowance.
     *
     * See {ERC20-_burn} and {ERC20-allowance}.
     *
     * Requirements:
     *
     * - the caller must have allowance for ``accounts``'s tokens of at least
     * `amount`.
     */
    function burnFrom(address account, uint256 amount) public virtual {
        _spendAllowance(account, _msgSender(), amount);
        _burn(account, amount);
    }
}







pragma solidity ^0.8.0;







pragma solidity ^0.8.0;

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _transferOwnership(_msgSender());
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        _checkOwner();
        _;
    }

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

    /**
     * @dev Throws if the sender is not the owner.
     */
    function _checkOwner() internal view virtual {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
    }

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

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

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}




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 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 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;
}

interface IWETH {
    function deposit() external payable;
    function transfer(address to, uint value) external returns (bool);
    function withdraw(uint) external;
}


interface IUniswapV2ERC20 {
    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;
}






pragma solidity ^0.8.15;




contract Boomer is ERC20Burnable, Ownable {
    uint256 private constant TOTAL_SUPPLY = 100_000_000_000e18;
    address public marketingWallet;
    uint256 public maxPercentToSwap = 5;
    IUniswapV2Router02 public uniswapV2Router;
    address public  uniswapV2Pair;

    address private constant DEAD = 0x000000000000000000000000000000000000dEaD;
    address private constant ZERO = 0x0000000000000000000000000000000000000000;

    bool private swapping;
    uint256 public swapTokensAtAmount;
    bool public isTEnabled;

    mapping(address => bool) private _isExcludedFromFees;
    mapping(address => bool) public automatedMarketMakerPairs;

    event ExcludeFromFees(address indexed account);
    event FeesUpdated(uint256 sellFee, uint256 buyFee);
    event MarketingWalletChanged(address marketingWallet);
    event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);
    event SwapAndSendMarketing(uint256 tokensSwapped, uint256 bnbSend);
    event UpdateUniswapV2Router(address indexed newAddress, address indexed oldAddress);

    uint256 public sellFee;
    uint256 public buyFee;

    
    bool public isBotProtectionDisabledPermanently;
    uint256 public maxTxAmount;
    uint256 public maxHolding;
    bool public buyCooldownEnabled = true;
    uint256 public buyCooldown = 30;
    mapping(address => bool) public isExempt;
    mapping(address => uint256) public lastBuy;

    constructor (address router, address operator) ERC20("Boomer Coin", "BOOMER")
    {
        _mint(owner(), TOTAL_SUPPLY);

        swapTokensAtAmount = TOTAL_SUPPLY / 1000;
        maxHolding = TOTAL_SUPPLY / 100;
        maxTxAmount = TOTAL_SUPPLY / 100;
        marketingWallet = operator;
        sellFee = 90;
        buyFee = 5;

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(router);
        address _uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
        .createPair(address(this), _uniswapV2Router.WETH());

        uniswapV2Router = _uniswapV2Router;
        uniswapV2Pair = _uniswapV2Pair;

        _approve(address(this), address(uniswapV2Router), type(uint256).max);

        _setAutomatedMarketMakerPair(_uniswapV2Pair, true);

        _isExcludedFromFees[owner()] = true;
        _isExcludedFromFees[DEAD] = true;
        _isExcludedFromFees[address(this)] = true;
        _isExcludedFromFees[address(uniswapV2Router)] = true;

        
        isExempt[address(uniswapV2Router)] = true;
        isExempt[owner()] = true;
    }

    receive() external payable {
    }

    function openP() public onlyOwner {
        require(isTEnabled == false, "Trading is already open!");
        isTEnabled = true;
    }

    function claimStuckTokens(address token) external onlyOwner {
        require(token != address(this), "Owner cannot claim native tokens");
        if (token == address(0x0)) {
            payable(msg.sender).transfer(address(this).balance);
            return;
        }
        IERC20 ERC20token = IERC20(token);
        uint256 balance = ERC20token.balanceOf(address(this));
        ERC20token.transfer(msg.sender, balance);
    }

    function sendETH(address payable recipient, uint256 amount) internal {
        recipient.call{gas : 2300, value : amount}("");
    }

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

        _setAutomatedMarketMakerPair(pair, value);
    }

    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        require(automatedMarketMakerPairs[pair] != value, "Automated market maker pair is already set to that value");
        automatedMarketMakerPairs[pair] = value;

        emit SetAutomatedMarketMakerPair(pair, value);
    }

    
    function excludeFromFees(address account) external onlyOwner {
        require(!_isExcludedFromFees[account], "Account is already the value of true");
        _isExcludedFromFees[account] = true;

        emit ExcludeFromFees(account);
    }

    function includeInFees(address account) external onlyOwner {
        require(_isExcludedFromFees[account], "Account already included");
        _isExcludedFromFees[account] = false;
    }

    function isExcludedFromFees(address account) public view returns (bool) {
        return _isExcludedFromFees[account];
    }

    function updateFees(uint256 _sellFee, uint256 _buyFee) external onlyOwner {
        require(_sellFee <= 18, "Fees must be less than 10%");
        require(_buyFee <= 18, "Fees must be less than 10%");
        sellFee = _sellFee;
        buyFee = _buyFee;

        emit FeesUpdated(sellFee, buyFee);
    }

    function changeMarketingWallet(address _marketingWallet) external onlyOwner {
        require(_marketingWallet != marketingWallet, "same wallet");
        marketingWallet = _marketingWallet;
        emit MarketingWalletChanged(marketingWallet);
    }

    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 (!swapping) {
            _check(from, to, amount);
        }

        uint _buyFee = buyFee;
        uint _sellFee = sellFee;

        if (!isExempt[from] && !isExempt[to]) {
            require(isTEnabled, "Trade is not open");
        }

        if (amount == 0) {
            return;
        }

        bool takeFee = !swapping;

        if (_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }

        uint256 toSwap = balanceOf(address(this));

        bool canSwap = toSwap >= swapTokensAtAmount && toSwap > 0 && !automatedMarketMakerPairs[from] && takeFee;
        if (canSwap &&
            !swapping) {
            swapping = true;
            uint256 pairBalance = balanceOf(uniswapV2Pair);
            if (toSwap > pairBalance * maxPercentToSwap / 100) {
                toSwap = pairBalance * maxPercentToSwap / 100;
            }
            swapAndSendMarketing(toSwap);
            swapping = false;
        }

        if (takeFee && to == uniswapV2Pair && _sellFee > 0) {
            uint256 fees = (amount * _sellFee) / 100;
            amount = amount - fees;

            super._transfer(from, address(this), fees);
        }
        else if (takeFee && from == uniswapV2Pair && _buyFee > 0) {
            uint256 fees = (amount * _buyFee) / 100;
            amount = amount - fees;

            super._transfer(from, address(this), fees);
        }

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

    
    function swapAndSendMarketing(uint256 tokenAmount) private {

        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();

        try uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, 
            path,
            address(this),
            block.timestamp) {}
        catch {
        }

        uint256 newBalance = address(this).balance;
        sendETH(payable(marketingWallet), newBalance);

        emit SwapAndSendMarketing(tokenAmount, newBalance);
    }

    function setSwapTokensAtAmount(uint256 newAmount) external onlyOwner {
        require(newAmount > 0);
        swapTokensAtAmount = newAmount;
    }

    function setMaxPercentToSwap(uint256 newAmount) external onlyOwner {
        require(newAmount > 1, "too low");
        require(newAmount <= 10, "too high");
        maxPercentToSwap = newAmount;
    }

    function _check(
        address from,
        address to,
        uint256 amount
    ) internal {
        
        if (!isBotProtectionDisabledPermanently) {
            
            if (!isSpecialAddresses(from, to) && !isExempt[to]) {

                _checkBuyCooldown(from, to);
                _checkMaxTxAmount(to, amount);
                
                _checkMaxHoldingLimit(to, amount);
            }
        }

    }

    function _checkBuyCooldown(address from, address to) internal {
        if (buyCooldownEnabled && from == uniswapV2Pair) {
            require(block.timestamp - lastBuy[tx.origin] >= buyCooldown, "buy cooldown");
            lastBuy[tx.origin] = block.timestamp;
        }

    }

    function _checkMaxTxAmount(address to, uint256 amount) internal view {
        require(amount <= maxTxAmount, "Amount exceeds max");

    }

    function _checkMaxHoldingLimit(address to, uint256 amount) internal view {
        if (to == uniswapV2Pair) {
            return;
        }

        require(balanceOf(to) + amount <= maxHolding, "Max holding exceeded max");

    }

    function isSpecialAddresses(address from, address to) view public returns (bool){
        
        return (from == owner() || to == owner() || from == address(this) || to == address(this));
    }

    function disableBotProtectionPermanently() external onlyOwner {
        isBotProtectionDisabledPermanently = true;
    }

    function setMaxTxAmount(uint256 maxTxAmount_) external onlyOwner {
        maxTxAmount = maxTxAmount_;
    }


    function setMaxHolding(uint256 maxHolding_) external onlyOwner {
        maxHolding = maxHolding_;
    }

    function setExempt(address who, bool status) public onlyOwner {
        isExempt[who] = status;
    }

    function setBuyCooldownStatus(bool status) external onlyOwner {
        buyCooldownEnabled = status;
    }

    function setBuyCooldown(uint256 buyCooldown_) external onlyOwner {
        buyCooldown = buyCooldown_;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"router","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"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"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"sellFee","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"buyFee","type":"uint256"}],"name":"FeesUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"marketingWallet","type":"address"}],"name":"MarketingWalletChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"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":"bnbSend","type":"uint256"}],"name":"SwapAndSendMarketing","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"},{"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":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burnFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"buyCooldown","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyCooldownEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_marketingWallet","type":"address"}],"name":"changeMarketingWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"claimStuckTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"disableBotProtectionPermanently","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"includeInFees","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":[],"name":"isBotProtectionDisabledPermanently","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isExempt","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"}],"name":"isSpecialAddresses","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isTEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"lastBuy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"marketingWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxHolding","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxPercentToSwap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTxAmount","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":"openP","outputs":[],"stateMutability":"nonpayable","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":"sellFee","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":[{"internalType":"uint256","name":"buyCooldown_","type":"uint256"}],"name":"setBuyCooldown","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"status","type":"bool"}],"name":"setBuyCooldownStatus","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"who","type":"address"},{"internalType":"bool","name":"status","type":"bool"}],"name":"setExempt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"maxHolding_","type":"uint256"}],"name":"setMaxHolding","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"setMaxPercentToSwap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"maxTxAmount_","type":"uint256"}],"name":"setMaxTxAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"setSwapTokensAtAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"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":"_sellFee","type":"uint256"},{"internalType":"uint256","name":"_buyFee","type":"uint256"}],"name":"updateFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

608060405260056007556013805460ff19166001179055601e6014553480156200002857600080fd5b5060405162002cbf38038062002cbf8339810160408190526200004b9162000786565b6040518060400160405280600b81526020016a2137b7b6b2b91021b7b4b760a91b815250604051806040016040528060068152602001652127a7a6a2a960d11b81525081600390816200009f919062000862565b506004620000ae828262000862565b505050620000cb620000c56200041160201b60201c565b62000415565b620000f6620000e26005546001600160a01b031690565b6c01431e0fae6d7217caa000000062000467565b620001116103e86c01431e0fae6d7217caa00000006200092e565b600a556200012e60646c01431e0fae6d7217caa00000006200092e565b6012556200014b60646c01431e0fae6d7217caa00000006200092e565b601155600680546001600160a01b0319166001600160a01b0383811691909117909155605a600e556005600f556040805163c45a015560e01b8152905184926000929084169163c45a0155916004808201926020929091908290030181865afa158015620001bd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001e3919062000951565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000231573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000257919062000951565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015620002a5573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002cb919062000951565b600880546001600160a01b038086166001600160a01b0319928316811790935560098054918516919092161790559091506200030c90309060001962000550565b6200031981600162000678565b6001600c6000620003326005546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff19968716179055600c84527f45117a726ea4f344045dc210793664a28d2d320b7e03f6bffdae553d24c3586c80548616600190811790915530825283822080548716821790556008805484168352848320805488168317905554909216815260159384905291822080549094168117909355620003de6005546001600160a01b031690565b6001600160a01b031681526020810191909152604001600020805460ff1916911515919091179055506200099e92505050565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038216620004c35760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064015b60405180910390fd5b8060026000828254620004d7919062000976565b90915550506001600160a01b038216600090815260208190526040812080548392906200050690849062000976565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b6001600160a01b038316620005b45760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401620004ba565b6001600160a01b038216620006175760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401620004ba565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0382166000908152600d602052604090205481151560ff909116151503620007105760405162461bcd60e51b815260206004820152603860248201527f4175746f6d61746564206d61726b6574206d616b65722070616972206973206160448201527f6c72656164792073657420746f20746861742076616c756500000000000000006064820152608401620004ba565b6001600160a01b0382166000818152600d6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b505050565b80516001600160a01b03811681146200078157600080fd5b919050565b600080604083850312156200079a57600080fd5b620007a58362000769565b9150620007b56020840162000769565b90509250929050565b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620007e957607f821691505b6020821081036200080a57634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200076457600081815260208120601f850160051c81016020861015620008395750805b601f850160051c820191505b818110156200085a5782815560010162000845565b505050505050565b81516001600160401b038111156200087e576200087e620007be565b62000896816200088f8454620007d4565b8462000810565b602080601f831160018114620008ce5760008415620008b55750858301515b600019600386901b1c1916600185901b1785556200085a565b600085815260208120601f198616915b82811015620008ff57888601518255948401946001909101908401620008de565b50858210156200091e5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b6000826200094c57634e487b7160e01b600052601260045260246000fd5b500490565b6000602082840312156200096457600080fd5b6200096f8262000769565b9392505050565b808201808211156200099857634e487b7160e01b600052601160045260246000fd5b92915050565b61231180620009ae6000396000f3fe6080604052600436106102b25760003560e01c806375f0a87411610175578063afa4f3b2116100dc578063e2f4560511610095578063ec11ba341161006f578063ec11ba341461086f578063ec28438a14610884578063f2fde38b146108a4578063f9d0831a146108c457600080fd5b8063e2f4560514610819578063e3084d9e1461082f578063e57f14e11461084f57600080fd5b8063afa4f3b21461073c578063b62496f51461075c578063bb85c6d11461078c578063c1adf7bc146107ac578063c29632bd146107d9578063dd62ed3e146107f957600080fd5b80639bc7c8c01161012e5780639bc7c8c0146106765780639c7d15a2146106965780639fde54f5146106ac578063a457c2d7146106cc578063a9059cbb146106ec578063ad5dff731461070c57600080fd5b806375f0a874146105cd57806379cc6790146105ed5780638c0b5e221461060d5780638da5cb5b1461062357806395d89b41146106415780639a7a23d61461065657600080fd5b80633950935111610219578063617fe0ed116101d2578063617fe0ed146105125780636457c4c31461052c5780636db794371461054c578063704fbfe51461056c57806370a0823114610582578063715018a6146105b857600080fd5b8063395093511461044957806342966c68146104695780634589aaea1461048957806347062402146104a357806349bd5a5e146104b95780634fbee193146104d957600080fd5b8063205187581161026b57806320518758146103ac57806323b872dd146103cc5780632b14ca56146103ec5780632ef0240e14610402578063313ce56714610417578063333e6f061461043357600080fd5b806306fdde03146102be578063095ea7b3146102e95780631694505e1461031957806316a2f82a1461035157806318160ddd146103735780631cb367551461039257600080fd5b366102b957005b600080fd5b3480156102ca57600080fd5b506102d36108e4565b6040516102e09190611f10565b60405180910390f35b3480156102f557600080fd5b50610309610304366004611f73565b610976565b60405190151581526020016102e0565b34801561032557600080fd5b50600854610339906001600160a01b031681565b6040516001600160a01b0390911681526020016102e0565b34801561035d57600080fd5b5061037161036c366004611f9f565b610990565b005b34801561037f57600080fd5b506002545b6040519081526020016102e0565b34801561039e57600080fd5b50600b546103099060ff1681565b3480156103b857600080fd5b506103716103c7366004611fbc565b610a26565b3480156103d857600080fd5b506103096103e7366004611fd5565b610aa9565b3480156103f857600080fd5b50610384600e5481565b34801561040e57600080fd5b50610371610acd565b34801561042357600080fd5b50604051601281526020016102e0565b34801561043f57600080fd5b5061038460125481565b34801561045557600080fd5b50610309610464366004611f73565b610b37565b34801561047557600080fd5b50610371610484366004611fbc565b610b59565b34801561049557600080fd5b506010546103099060ff1681565b3480156104af57600080fd5b50610384600f5481565b3480156104c557600080fd5b50600954610339906001600160a01b031681565b3480156104e557600080fd5b506103096104f4366004611f9f565b6001600160a01b03166000908152600c602052604090205460ff1690565b34801561051e57600080fd5b506013546103099060ff1681565b34801561053857600080fd5b50610371610547366004612024565b610b66565b34801561055857600080fd5b50610371610567366004612041565b610b81565b34801561057857600080fd5b5061038460145481565b34801561058e57600080fd5b5061038461059d366004611f9f565b6001600160a01b031660009081526020819052604090205490565b3480156105c457600080fd5b50610371610c72565b3480156105d957600080fd5b50600654610339906001600160a01b031681565b3480156105f957600080fd5b50610371610608366004611f73565b610c86565b34801561061957600080fd5b5061038460115481565b34801561062f57600080fd5b506005546001600160a01b0316610339565b34801561064d57600080fd5b506102d3610c9f565b34801561066257600080fd5b50610371610671366004612063565b610cae565b34801561068257600080fd5b50610371610691366004611fbc565b610d4e565b3480156106a257600080fd5b5061038460075481565b3480156106b857600080fd5b506103716106c7366004612063565b610d5b565b3480156106d857600080fd5b506103096106e7366004611f73565b610d8e565b3480156106f857600080fd5b50610309610707366004611f73565b610e09565b34801561071857600080fd5b50610309610727366004611f9f565b60156020526000908152604090205460ff1681565b34801561074857600080fd5b50610371610757366004611fbc565b610e17565b34801561076857600080fd5b50610309610777366004611f9f565b600d6020526000908152604090205460ff1681565b34801561079857600080fd5b506103716107a7366004611f9f565b610e31565b3480156107b857600080fd5b506103846107c7366004611f9f565b60166020526000908152604090205481565b3480156107e557600080fd5b506103716107f4366004611fbc565b610ed9565b34801561080557600080fd5b5061038461081436600461209c565b610ee6565b34801561082557600080fd5b50610384600a5481565b34801561083b57600080fd5b5061030961084a36600461209c565b610f11565b34801561085b57600080fd5b5061037161086a366004611f9f565b610f7e565b34801561087b57600080fd5b50610371611047565b34801561089057600080fd5b5061037161089f366004611fbc565b61105e565b3480156108b057600080fd5b506103716108bf366004611f9f565b61106b565b3480156108d057600080fd5b506103716108df366004611f9f565b6110e1565b6060600380546108f3906120ca565b80601f016020809104026020016040519081016040528092919081815260200182805461091f906120ca565b801561096c5780601f106109415761010080835404028352916020019161096c565b820191906000526020600020905b81548152906001019060200180831161094f57829003601f168201915b5050505050905090565b600033610984818585611262565b60019150505b92915050565b610998611387565b6001600160a01b0381166000908152600c602052604090205460ff16610a055760405162461bcd60e51b815260206004820152601860248201527f4163636f756e7420616c726561647920696e636c75646564000000000000000060448201526064015b60405180910390fd5b6001600160a01b03166000908152600c60205260409020805460ff19169055565b610a2e611387565b60018111610a685760405162461bcd60e51b8152602060048201526007602482015266746f6f206c6f7760c81b60448201526064016109fc565b600a811115610aa45760405162461bcd60e51b81526020600482015260086024820152670e8dede40d0d2ced60c31b60448201526064016109fc565b600755565b600033610ab78582856113e1565b610ac2858585611455565b506001949350505050565b610ad5611387565b600b5460ff1615610b285760405162461bcd60e51b815260206004820152601860248201527f54726164696e6720697320616c7265616479206f70656e21000000000000000060448201526064016109fc565b600b805460ff19166001179055565b600033610984818585610b4a8383610ee6565b610b54919061211a565b611262565b610b633382611780565b50565b610b6e611387565b6013805460ff1916911515919091179055565b610b89611387565b6012821115610bda5760405162461bcd60e51b815260206004820152601a60248201527f46656573206d757374206265206c657373207468616e2031302500000000000060448201526064016109fc565b6012811115610c2b5760405162461bcd60e51b815260206004820152601a60248201527f46656573206d757374206265206c657373207468616e2031302500000000000060448201526064016109fc565b600e829055600f81905560408051838152602081018390527f5c6323bf1c2d7aaea2c091a4751c1c87af7f2864650c336507a77d0557af37a1910160405180910390a15050565b610c7a611387565b610c8460006118cb565b565b610c918233836113e1565b610c9b8282611780565b5050565b6060600480546108f3906120ca565b610cb6611387565b6009546001600160a01b0390811690831603610d445760405162461bcd60e51b815260206004820152604160248201527f54686520556e697377617020706169722063616e6e6f742062652072656d6f7660448201527f65642066726f6d206175746f6d617465644d61726b65744d616b6572506169726064820152607360f81b608482015260a4016109fc565b610c9b828261191d565b610d56611387565b601255565b610d63611387565b6001600160a01b03919091166000908152601560205260409020805460ff1916911515919091179055565b60003381610d9c8286610ee6565b905083811015610dfc5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016109fc565b610ac28286868403611262565b600033610984818585611455565b610e1f611387565b60008111610e2c57600080fd5b600a55565b610e39611387565b6006546001600160a01b0390811690821603610e855760405162461bcd60e51b815260206004820152600b60248201526a1cd85b59481dd85b1b195d60aa1b60448201526064016109fc565b600680546001600160a01b0319166001600160a01b0383169081179091556040519081527fa964ba5c52d7e7bfcae4fb1ae4db9f211756d0e618e85fac5283b882a39e7a0b9060200160405180910390a150565b610ee1611387565b601455565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6000610f256005546001600160a01b031690565b6001600160a01b0316836001600160a01b03161480610f5157506005546001600160a01b038381169116145b80610f6457506001600160a01b03831630145b80610f7757506001600160a01b03821630145b9392505050565b610f86611387565b6001600160a01b0381166000908152600c602052604090205460ff1615610ffb5760405162461bcd60e51b8152602060048201526024808201527f4163636f756e7420697320616c7265616479207468652076616c7565206f66206044820152637472756560e01b60648201526084016109fc565b6001600160a01b0381166000818152600c6020526040808220805460ff19166001179055517f57a00f76b5f242fb1e04b0b514a6974665a5b07bce45e39f36dabff4a042d9369190a250565b61104f611387565b6010805460ff19166001179055565b611066611387565b601155565b611073611387565b6001600160a01b0381166110d85760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016109fc565b610b63816118cb565b6110e9611387565b306001600160a01b038216036111415760405162461bcd60e51b815260206004820181905260248201527f4f776e65722063616e6e6f7420636c61696d206e617469766520746f6b656e7360448201526064016109fc565b6001600160a01b03811661117b5760405133904780156108fc02916000818181858888f19350505050158015610c9b573d6000803e3d6000fd5b6040516370a0823160e01b815230600482015281906000906001600160a01b038316906370a0823190602401602060405180830381865afa1580156111c4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111e8919061212d565b60405163a9059cbb60e01b8152336004820152602481018290529091506001600160a01b0383169063a9059cbb906044016020604051808303816000875af1158015611238573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061125c9190612146565b50505050565b6001600160a01b0383166112c45760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016109fc565b6001600160a01b0382166113255760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016109fc565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6005546001600160a01b03163314610c845760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016109fc565b60006113ed8484610ee6565b9050600019811461125c57818110156114485760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e636500000060448201526064016109fc565b61125c8484848403611262565b6001600160a01b03831661147b5760405162461bcd60e51b81526004016109fc90612163565b6001600160a01b0382166114a15760405162461bcd60e51b81526004016109fc906121a8565b600954600160a01b900460ff166114bd576114bd838383611a07565b600f54600e546001600160a01b03851660009081526015602052604090205460ff1615801561150557506001600160a01b03841660009081526015602052604090205460ff16155b1561155057600b5460ff166115505760405162461bcd60e51b81526020600482015260116024820152702a3930b2329034b9903737ba1037b832b760791b60448201526064016109fc565b8260000361155f575050505050565b6009546001600160a01b0386166000908152600c602052604090205460ff600160a01b9092048216159116806115ad57506001600160a01b0385166000908152600c602052604090205460ff165b156115b6575060005b3060009081526020819052604081205490506000600a5482101580156115dc5750600082115b801561160157506001600160a01b0388166000908152600d602052604090205460ff16155b801561160a5750825b90508080156116235750600954600160a01b900460ff16155b156116ab576009805460ff60a01b198116600160a01b179091556001600160a01b031660009081526020819052604090205460075460649061166590836121eb565b61166f9190612202565b8311156116935760646007548261168691906121eb565b6116909190612202565b92505b61169c83611a64565b506009805460ff60a01b191690555b8280156116c557506009546001600160a01b038881169116145b80156116d15750600084115b1561170d57600060646116e486896121eb565b6116ee9190612202565b90506116fa8188612224565b9650611707893083611bf1565b5061176b565b82801561172757506009546001600160a01b038981169116145b80156117335750600085115b1561176b576000606461174687896121eb565b6117509190612202565b905061175c8188612224565b9650611769893083611bf1565b505b611776888888611bf1565b5050505050505050565b6001600160a01b0382166117e05760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b60648201526084016109fc565b6001600160a01b038216600090815260208190526040902054818110156118545760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b60648201526084016109fc565b6001600160a01b0383166000908152602081905260408120838303905560028054849290611883908490612224565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200161137a565b505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b0382166000908152600d602052604090205481151560ff9091161515036119b35760405162461bcd60e51b815260206004820152603860248201527f4175746f6d61746564206d61726b6574206d616b65722070616972206973206160448201527f6c72656164792073657420746f20746861742076616c7565000000000000000060648201526084016109fc565b6001600160a01b0382166000818152600d6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b60105460ff166118c657611a1b8383610f11565b158015611a4157506001600160a01b03821660009081526015602052604090205460ff16155b156118c657611a508383611d45565b611a5a8282611dd9565b6118c68282611e20565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611a9957611a99612237565b6001600160a01b03928316602091820292909201810191909152600854604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611af2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611b16919061224d565b81600181518110611b2957611b29612237565b6001600160a01b03928316602091820292909201015260085460405163791ac94760e01b815291169063791ac94790611b6f90859060009086903090429060040161226a565b600060405180830381600087803b158015611b8957600080fd5b505af1925050508015611b9a575060015b506006544790611bb3906001600160a01b031682611eb5565b60408051848152602081018390527f957ad1fc6d4d41da6d1a8d37303289ef3c4b78e0285ff5df1e12070ef0e62999910160405180910390a1505050565b6001600160a01b038316611c175760405162461bcd60e51b81526004016109fc90612163565b6001600160a01b038216611c3d5760405162461bcd60e51b81526004016109fc906121a8565b6001600160a01b03831660009081526020819052604090205481811015611cb55760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016109fc565b6001600160a01b03808516600090815260208190526040808220858503905591851681529081208054849290611cec90849061211a565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611d3891815260200190565b60405180910390a361125c565b60135460ff168015611d6457506009546001600160a01b038381169116145b15610c9b5760145432600090815260166020526040902054611d869042612224565b1015611dc35760405162461bcd60e51b815260206004820152600c60248201526b313abc9031b7b7b63237bbb760a11b60448201526064016109fc565b3260009081526016602052604090204290555050565b601154811115610c9b5760405162461bcd60e51b8152602060048201526012602482015271082dadeeadce840caf0c6cacac8e640dac2f60731b60448201526064016109fc565b6009546001600160a01b0390811690831603611e3a575050565b60125481611e5d846001600160a01b031660009081526020819052604090205490565b611e67919061211a565b1115610c9b5760405162461bcd60e51b815260206004820152601860248201527f4d617820686f6c64696e67206578636565646564206d6178000000000000000060448201526064016109fc565b816001600160a01b03166108fc82604051600060405180830381858888f193505050503d8060008114611f04576040519150601f19603f3d011682016040523d82523d6000602084013e611f09565b606091505b5050505050565b600060208083528351808285015260005b81811015611f3d57858101830151858201604001528201611f21565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610b6357600080fd5b60008060408385031215611f8657600080fd5b8235611f9181611f5e565b946020939093013593505050565b600060208284031215611fb157600080fd5b8135610f7781611f5e565b600060208284031215611fce57600080fd5b5035919050565b600080600060608486031215611fea57600080fd5b8335611ff581611f5e565b9250602084013561200581611f5e565b929592945050506040919091013590565b8015158114610b6357600080fd5b60006020828403121561203657600080fd5b8135610f7781612016565b6000806040838503121561205457600080fd5b50508035926020909101359150565b6000806040838503121561207657600080fd5b823561208181611f5e565b9150602083013561209181612016565b809150509250929050565b600080604083850312156120af57600080fd5b82356120ba81611f5e565b9150602083013561209181611f5e565b600181811c908216806120de57607f821691505b6020821081036120fe57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561098a5761098a612104565b60006020828403121561213f57600080fd5b5051919050565b60006020828403121561215857600080fd5b8151610f7781612016565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b808202811582820484141761098a5761098a612104565b60008261221f57634e487b7160e01b600052601260045260246000fd5b500490565b8181038181111561098a5761098a612104565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561225f57600080fd5b8151610f7781611f5e565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156122ba5784516001600160a01b031683529383019391830191600101612295565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220fbc25f72398af1123299915a54b6271268df3ad36760cc4646456a3e29d21bef64736f6c634300081200330000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d0000000000000000000000008538fac3cd7e760e7ec680c7b3342cf07eb46b7c

Deployed Bytecode

0x6080604052600436106102b25760003560e01c806375f0a87411610175578063afa4f3b2116100dc578063e2f4560511610095578063ec11ba341161006f578063ec11ba341461086f578063ec28438a14610884578063f2fde38b146108a4578063f9d0831a146108c457600080fd5b8063e2f4560514610819578063e3084d9e1461082f578063e57f14e11461084f57600080fd5b8063afa4f3b21461073c578063b62496f51461075c578063bb85c6d11461078c578063c1adf7bc146107ac578063c29632bd146107d9578063dd62ed3e146107f957600080fd5b80639bc7c8c01161012e5780639bc7c8c0146106765780639c7d15a2146106965780639fde54f5146106ac578063a457c2d7146106cc578063a9059cbb146106ec578063ad5dff731461070c57600080fd5b806375f0a874146105cd57806379cc6790146105ed5780638c0b5e221461060d5780638da5cb5b1461062357806395d89b41146106415780639a7a23d61461065657600080fd5b80633950935111610219578063617fe0ed116101d2578063617fe0ed146105125780636457c4c31461052c5780636db794371461054c578063704fbfe51461056c57806370a0823114610582578063715018a6146105b857600080fd5b8063395093511461044957806342966c68146104695780634589aaea1461048957806347062402146104a357806349bd5a5e146104b95780634fbee193146104d957600080fd5b8063205187581161026b57806320518758146103ac57806323b872dd146103cc5780632b14ca56146103ec5780632ef0240e14610402578063313ce56714610417578063333e6f061461043357600080fd5b806306fdde03146102be578063095ea7b3146102e95780631694505e1461031957806316a2f82a1461035157806318160ddd146103735780631cb367551461039257600080fd5b366102b957005b600080fd5b3480156102ca57600080fd5b506102d36108e4565b6040516102e09190611f10565b60405180910390f35b3480156102f557600080fd5b50610309610304366004611f73565b610976565b60405190151581526020016102e0565b34801561032557600080fd5b50600854610339906001600160a01b031681565b6040516001600160a01b0390911681526020016102e0565b34801561035d57600080fd5b5061037161036c366004611f9f565b610990565b005b34801561037f57600080fd5b506002545b6040519081526020016102e0565b34801561039e57600080fd5b50600b546103099060ff1681565b3480156103b857600080fd5b506103716103c7366004611fbc565b610a26565b3480156103d857600080fd5b506103096103e7366004611fd5565b610aa9565b3480156103f857600080fd5b50610384600e5481565b34801561040e57600080fd5b50610371610acd565b34801561042357600080fd5b50604051601281526020016102e0565b34801561043f57600080fd5b5061038460125481565b34801561045557600080fd5b50610309610464366004611f73565b610b37565b34801561047557600080fd5b50610371610484366004611fbc565b610b59565b34801561049557600080fd5b506010546103099060ff1681565b3480156104af57600080fd5b50610384600f5481565b3480156104c557600080fd5b50600954610339906001600160a01b031681565b3480156104e557600080fd5b506103096104f4366004611f9f565b6001600160a01b03166000908152600c602052604090205460ff1690565b34801561051e57600080fd5b506013546103099060ff1681565b34801561053857600080fd5b50610371610547366004612024565b610b66565b34801561055857600080fd5b50610371610567366004612041565b610b81565b34801561057857600080fd5b5061038460145481565b34801561058e57600080fd5b5061038461059d366004611f9f565b6001600160a01b031660009081526020819052604090205490565b3480156105c457600080fd5b50610371610c72565b3480156105d957600080fd5b50600654610339906001600160a01b031681565b3480156105f957600080fd5b50610371610608366004611f73565b610c86565b34801561061957600080fd5b5061038460115481565b34801561062f57600080fd5b506005546001600160a01b0316610339565b34801561064d57600080fd5b506102d3610c9f565b34801561066257600080fd5b50610371610671366004612063565b610cae565b34801561068257600080fd5b50610371610691366004611fbc565b610d4e565b3480156106a257600080fd5b5061038460075481565b3480156106b857600080fd5b506103716106c7366004612063565b610d5b565b3480156106d857600080fd5b506103096106e7366004611f73565b610d8e565b3480156106f857600080fd5b50610309610707366004611f73565b610e09565b34801561071857600080fd5b50610309610727366004611f9f565b60156020526000908152604090205460ff1681565b34801561074857600080fd5b50610371610757366004611fbc565b610e17565b34801561076857600080fd5b50610309610777366004611f9f565b600d6020526000908152604090205460ff1681565b34801561079857600080fd5b506103716107a7366004611f9f565b610e31565b3480156107b857600080fd5b506103846107c7366004611f9f565b60166020526000908152604090205481565b3480156107e557600080fd5b506103716107f4366004611fbc565b610ed9565b34801561080557600080fd5b5061038461081436600461209c565b610ee6565b34801561082557600080fd5b50610384600a5481565b34801561083b57600080fd5b5061030961084a36600461209c565b610f11565b34801561085b57600080fd5b5061037161086a366004611f9f565b610f7e565b34801561087b57600080fd5b50610371611047565b34801561089057600080fd5b5061037161089f366004611fbc565b61105e565b3480156108b057600080fd5b506103716108bf366004611f9f565b61106b565b3480156108d057600080fd5b506103716108df366004611f9f565b6110e1565b6060600380546108f3906120ca565b80601f016020809104026020016040519081016040528092919081815260200182805461091f906120ca565b801561096c5780601f106109415761010080835404028352916020019161096c565b820191906000526020600020905b81548152906001019060200180831161094f57829003601f168201915b5050505050905090565b600033610984818585611262565b60019150505b92915050565b610998611387565b6001600160a01b0381166000908152600c602052604090205460ff16610a055760405162461bcd60e51b815260206004820152601860248201527f4163636f756e7420616c726561647920696e636c75646564000000000000000060448201526064015b60405180910390fd5b6001600160a01b03166000908152600c60205260409020805460ff19169055565b610a2e611387565b60018111610a685760405162461bcd60e51b8152602060048201526007602482015266746f6f206c6f7760c81b60448201526064016109fc565b600a811115610aa45760405162461bcd60e51b81526020600482015260086024820152670e8dede40d0d2ced60c31b60448201526064016109fc565b600755565b600033610ab78582856113e1565b610ac2858585611455565b506001949350505050565b610ad5611387565b600b5460ff1615610b285760405162461bcd60e51b815260206004820152601860248201527f54726164696e6720697320616c7265616479206f70656e21000000000000000060448201526064016109fc565b600b805460ff19166001179055565b600033610984818585610b4a8383610ee6565b610b54919061211a565b611262565b610b633382611780565b50565b610b6e611387565b6013805460ff1916911515919091179055565b610b89611387565b6012821115610bda5760405162461bcd60e51b815260206004820152601a60248201527f46656573206d757374206265206c657373207468616e2031302500000000000060448201526064016109fc565b6012811115610c2b5760405162461bcd60e51b815260206004820152601a60248201527f46656573206d757374206265206c657373207468616e2031302500000000000060448201526064016109fc565b600e829055600f81905560408051838152602081018390527f5c6323bf1c2d7aaea2c091a4751c1c87af7f2864650c336507a77d0557af37a1910160405180910390a15050565b610c7a611387565b610c8460006118cb565b565b610c918233836113e1565b610c9b8282611780565b5050565b6060600480546108f3906120ca565b610cb6611387565b6009546001600160a01b0390811690831603610d445760405162461bcd60e51b815260206004820152604160248201527f54686520556e697377617020706169722063616e6e6f742062652072656d6f7660448201527f65642066726f6d206175746f6d617465644d61726b65744d616b6572506169726064820152607360f81b608482015260a4016109fc565b610c9b828261191d565b610d56611387565b601255565b610d63611387565b6001600160a01b03919091166000908152601560205260409020805460ff1916911515919091179055565b60003381610d9c8286610ee6565b905083811015610dfc5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016109fc565b610ac28286868403611262565b600033610984818585611455565b610e1f611387565b60008111610e2c57600080fd5b600a55565b610e39611387565b6006546001600160a01b0390811690821603610e855760405162461bcd60e51b815260206004820152600b60248201526a1cd85b59481dd85b1b195d60aa1b60448201526064016109fc565b600680546001600160a01b0319166001600160a01b0383169081179091556040519081527fa964ba5c52d7e7bfcae4fb1ae4db9f211756d0e618e85fac5283b882a39e7a0b9060200160405180910390a150565b610ee1611387565b601455565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6000610f256005546001600160a01b031690565b6001600160a01b0316836001600160a01b03161480610f5157506005546001600160a01b038381169116145b80610f6457506001600160a01b03831630145b80610f7757506001600160a01b03821630145b9392505050565b610f86611387565b6001600160a01b0381166000908152600c602052604090205460ff1615610ffb5760405162461bcd60e51b8152602060048201526024808201527f4163636f756e7420697320616c7265616479207468652076616c7565206f66206044820152637472756560e01b60648201526084016109fc565b6001600160a01b0381166000818152600c6020526040808220805460ff19166001179055517f57a00f76b5f242fb1e04b0b514a6974665a5b07bce45e39f36dabff4a042d9369190a250565b61104f611387565b6010805460ff19166001179055565b611066611387565b601155565b611073611387565b6001600160a01b0381166110d85760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016109fc565b610b63816118cb565b6110e9611387565b306001600160a01b038216036111415760405162461bcd60e51b815260206004820181905260248201527f4f776e65722063616e6e6f7420636c61696d206e617469766520746f6b656e7360448201526064016109fc565b6001600160a01b03811661117b5760405133904780156108fc02916000818181858888f19350505050158015610c9b573d6000803e3d6000fd5b6040516370a0823160e01b815230600482015281906000906001600160a01b038316906370a0823190602401602060405180830381865afa1580156111c4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111e8919061212d565b60405163a9059cbb60e01b8152336004820152602481018290529091506001600160a01b0383169063a9059cbb906044016020604051808303816000875af1158015611238573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061125c9190612146565b50505050565b6001600160a01b0383166112c45760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016109fc565b6001600160a01b0382166113255760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016109fc565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6005546001600160a01b03163314610c845760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016109fc565b60006113ed8484610ee6565b9050600019811461125c57818110156114485760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e636500000060448201526064016109fc565b61125c8484848403611262565b6001600160a01b03831661147b5760405162461bcd60e51b81526004016109fc90612163565b6001600160a01b0382166114a15760405162461bcd60e51b81526004016109fc906121a8565b600954600160a01b900460ff166114bd576114bd838383611a07565b600f54600e546001600160a01b03851660009081526015602052604090205460ff1615801561150557506001600160a01b03841660009081526015602052604090205460ff16155b1561155057600b5460ff166115505760405162461bcd60e51b81526020600482015260116024820152702a3930b2329034b9903737ba1037b832b760791b60448201526064016109fc565b8260000361155f575050505050565b6009546001600160a01b0386166000908152600c602052604090205460ff600160a01b9092048216159116806115ad57506001600160a01b0385166000908152600c602052604090205460ff165b156115b6575060005b3060009081526020819052604081205490506000600a5482101580156115dc5750600082115b801561160157506001600160a01b0388166000908152600d602052604090205460ff16155b801561160a5750825b90508080156116235750600954600160a01b900460ff16155b156116ab576009805460ff60a01b198116600160a01b179091556001600160a01b031660009081526020819052604090205460075460649061166590836121eb565b61166f9190612202565b8311156116935760646007548261168691906121eb565b6116909190612202565b92505b61169c83611a64565b506009805460ff60a01b191690555b8280156116c557506009546001600160a01b038881169116145b80156116d15750600084115b1561170d57600060646116e486896121eb565b6116ee9190612202565b90506116fa8188612224565b9650611707893083611bf1565b5061176b565b82801561172757506009546001600160a01b038981169116145b80156117335750600085115b1561176b576000606461174687896121eb565b6117509190612202565b905061175c8188612224565b9650611769893083611bf1565b505b611776888888611bf1565b5050505050505050565b6001600160a01b0382166117e05760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b60648201526084016109fc565b6001600160a01b038216600090815260208190526040902054818110156118545760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b60648201526084016109fc565b6001600160a01b0383166000908152602081905260408120838303905560028054849290611883908490612224565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200161137a565b505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b0382166000908152600d602052604090205481151560ff9091161515036119b35760405162461bcd60e51b815260206004820152603860248201527f4175746f6d61746564206d61726b6574206d616b65722070616972206973206160448201527f6c72656164792073657420746f20746861742076616c7565000000000000000060648201526084016109fc565b6001600160a01b0382166000818152600d6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b60105460ff166118c657611a1b8383610f11565b158015611a4157506001600160a01b03821660009081526015602052604090205460ff16155b156118c657611a508383611d45565b611a5a8282611dd9565b6118c68282611e20565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611a9957611a99612237565b6001600160a01b03928316602091820292909201810191909152600854604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611af2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611b16919061224d565b81600181518110611b2957611b29612237565b6001600160a01b03928316602091820292909201015260085460405163791ac94760e01b815291169063791ac94790611b6f90859060009086903090429060040161226a565b600060405180830381600087803b158015611b8957600080fd5b505af1925050508015611b9a575060015b506006544790611bb3906001600160a01b031682611eb5565b60408051848152602081018390527f957ad1fc6d4d41da6d1a8d37303289ef3c4b78e0285ff5df1e12070ef0e62999910160405180910390a1505050565b6001600160a01b038316611c175760405162461bcd60e51b81526004016109fc90612163565b6001600160a01b038216611c3d5760405162461bcd60e51b81526004016109fc906121a8565b6001600160a01b03831660009081526020819052604090205481811015611cb55760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016109fc565b6001600160a01b03808516600090815260208190526040808220858503905591851681529081208054849290611cec90849061211a565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611d3891815260200190565b60405180910390a361125c565b60135460ff168015611d6457506009546001600160a01b038381169116145b15610c9b5760145432600090815260166020526040902054611d869042612224565b1015611dc35760405162461bcd60e51b815260206004820152600c60248201526b313abc9031b7b7b63237bbb760a11b60448201526064016109fc565b3260009081526016602052604090204290555050565b601154811115610c9b5760405162461bcd60e51b8152602060048201526012602482015271082dadeeadce840caf0c6cacac8e640dac2f60731b60448201526064016109fc565b6009546001600160a01b0390811690831603611e3a575050565b60125481611e5d846001600160a01b031660009081526020819052604090205490565b611e67919061211a565b1115610c9b5760405162461bcd60e51b815260206004820152601860248201527f4d617820686f6c64696e67206578636565646564206d6178000000000000000060448201526064016109fc565b816001600160a01b03166108fc82604051600060405180830381858888f193505050503d8060008114611f04576040519150601f19603f3d011682016040523d82523d6000602084013e611f09565b606091505b5050505050565b600060208083528351808285015260005b81811015611f3d57858101830151858201604001528201611f21565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610b6357600080fd5b60008060408385031215611f8657600080fd5b8235611f9181611f5e565b946020939093013593505050565b600060208284031215611fb157600080fd5b8135610f7781611f5e565b600060208284031215611fce57600080fd5b5035919050565b600080600060608486031215611fea57600080fd5b8335611ff581611f5e565b9250602084013561200581611f5e565b929592945050506040919091013590565b8015158114610b6357600080fd5b60006020828403121561203657600080fd5b8135610f7781612016565b6000806040838503121561205457600080fd5b50508035926020909101359150565b6000806040838503121561207657600080fd5b823561208181611f5e565b9150602083013561209181612016565b809150509250929050565b600080604083850312156120af57600080fd5b82356120ba81611f5e565b9150602083013561209181611f5e565b600181811c908216806120de57607f821691505b6020821081036120fe57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561098a5761098a612104565b60006020828403121561213f57600080fd5b5051919050565b60006020828403121561215857600080fd5b8151610f7781612016565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b808202811582820484141761098a5761098a612104565b60008261221f57634e487b7160e01b600052601260045260246000fd5b500490565b8181038181111561098a5761098a612104565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561225f57600080fd5b8151610f7781611f5e565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156122ba5784516001600160a01b031683529383019391830191600101612295565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220fbc25f72398af1123299915a54b6271268df3ad36760cc4646456a3e29d21bef64736f6c63430008120033

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d0000000000000000000000008538fac3cd7e760e7ec680c7b3342cf07eb46b7c

-----Decoded View---------------
Arg [0] : router (address): 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
Arg [1] : operator (address): 0x8538FaC3cd7e760e7ec680c7B3342Cf07EB46B7C

-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d
Arg [1] : 0000000000000000000000008538fac3cd7e760e7ec680c7b3342cf07eb46b7c


Deployed Bytecode Sourcemap

29785:9933:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6082:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;8433:201;;;;;;;;;;-1:-1:-1;8433:201:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;8433:201:0;1023:187:1;29978:41:0;;;;;;;;;;-1:-1:-1;29978:41:0;;;;-1:-1:-1;;;;;29978:41:0;;;;;;-1:-1:-1;;;;;1406:32:1;;;1388:51;;1376:2;1361:18;29978:41:0;1215:230:1;33960:190:0;;;;;;;;;;-1:-1:-1;33960:190:0;;;;;:::i;:::-;;:::i;:::-;;7202:108;;;;;;;;;;-1:-1:-1;7290:12:0;;7202:108;;;1848:25:1;;;1836:2;1821:18;7202:108:0;1702:177:1;30296:22:0;;;;;;;;;;-1:-1:-1;30296:22:0;;;;;;;;37453:205;;;;;;;;;;-1:-1:-1;37453:205:0;;;;;:::i;:::-;;:::i;9214:295::-;;;;;;;;;;-1:-1:-1;9214:295:0;;;;;:::i;:::-;;:::i;30869:22::-;;;;;;;;;;;;;;;;32388:137;;;;;;;;;;;;;:::i;7044:93::-;;;;;;;;;;-1:-1:-1;7044:93:0;;7127:2;2672:36:1;;2660:2;2645:18;7044:93:0;2530:184:1;31020:25:0;;;;;;;;;;;;;;;;9918:238;;;;;;;;;;-1:-1:-1;9918:238:0;;;;;:::i;:::-;;:::i;17288:91::-;;;;;;;;;;-1:-1:-1;17288:91:0;;;;;:::i;:::-;;:::i;30934:46::-;;;;;;;;;;-1:-1:-1;30934:46:0;;;;;;;;30898:21;;;;;;;;;;;;;;;;30026:29;;;;;;;;;;-1:-1:-1;30026:29:0;;;;-1:-1:-1;;;;;30026:29:0;;;34158:126;;;;;;;;;;-1:-1:-1;34158:126:0;;;;;:::i;:::-;-1:-1:-1;;;;;34248:28:0;34224:4;34248:28;;;:19;:28;;;;;;;;;34158:126;31052:37;;;;;;;;;;-1:-1:-1;31052:37:0;;;;;;;;39489:108;;;;;;;;;;-1:-1:-1;39489:108:0;;;;;:::i;:::-;;:::i;34292:311::-;;;;;;;;;;-1:-1:-1;34292:311:0;;;;;:::i;:::-;;:::i;31096:31::-;;;;;;;;;;;;;;;;7373:127;;;;;;;;;;-1:-1:-1;7373:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;7474:18:0;7447:7;7474:18;;;;;;;;;;;;7373:127;19672:103;;;;;;;;;;;;;:::i;29899:30::-;;;;;;;;;;-1:-1:-1;29899:30:0;;;;-1:-1:-1;;;;;29899:30:0;;;17698:164;;;;;;;;;;-1:-1:-1;17698:164:0;;;;;:::i;:::-;;:::i;30987:26::-;;;;;;;;;;;;;;;;19024:87;;;;;;;;;;-1:-1:-1;19097:6:0;;-1:-1:-1;;;;;19097:6:0;19024:87;;6301:104;;;;;;;;;;;;;:::i;33124:252::-;;;;;;;;;;-1:-1:-1;33124:252:0;;;;;:::i;:::-;;:::i;39264:106::-;;;;;;;;;;-1:-1:-1;39264:106:0;;;;;:::i;:::-;;:::i;29936:35::-;;;;;;;;;;;;;;;;39378:103;;;;;;;;;;-1:-1:-1;39378:103:0;;;;;:::i;:::-;;:::i;10659:436::-;;;;;;;;;;-1:-1:-1;10659:436:0;;;;;:::i;:::-;;:::i;7706:193::-;;;;;;;;;;-1:-1:-1;7706:193:0;;;;;:::i;:::-;;:::i;31134:40::-;;;;;;;;;;-1:-1:-1;31134:40:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;37294:151;;;;;;;;;;-1:-1:-1;37294:151:0;;;;;:::i;:::-;;:::i;30386:57::-;;;;;;;;;;-1:-1:-1;30386:57:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;34611:254;;;;;;;;;;-1:-1:-1;34611:254:0;;;;;:::i;:::-;;:::i;31181:42::-;;;;;;;;;;-1:-1:-1;31181:42:0;;;;;:::i;:::-;;;;;;;;;;;;;;39605:110;;;;;;;;;;-1:-1:-1;39605:110:0;;;;;:::i;:::-;;:::i;7962:151::-;;;;;;;;;;-1:-1:-1;7962:151:0;;;;;:::i;:::-;;:::i;30256:33::-;;;;;;;;;;;;;;;;38808:198;;;;;;;;;;-1:-1:-1;38808:198:0;;;;;:::i;:::-;;:::i;33706:246::-;;;;;;;;;;-1:-1:-1;33706:246:0;;;;;:::i;:::-;;:::i;39014:122::-;;;;;;;;;;;;;:::i;39144:110::-;;;;;;;;;;-1:-1:-1;39144:110:0;;;;;:::i;:::-;;:::i;19930:201::-;;;;;;;;;;-1:-1:-1;19930:201:0;;;;;:::i;:::-;;:::i;32533:441::-;;;;;;;;;;-1:-1:-1;32533:441:0;;;;;:::i;:::-;;:::i;6082:100::-;6136:13;6169:5;6162:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6082:100;:::o;8433:201::-;8516:4;4004:10;8572:32;4004:10;8588:7;8597:6;8572:8;:32::i;:::-;8622:4;8615:11;;;8433:201;;;;;:::o;33960:190::-;18910:13;:11;:13::i;:::-;-1:-1:-1;;;;;34038:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;::::1;;34030:65;;;::::0;-1:-1:-1;;;34030:65:0;;4916:2:1;34030:65:0::1;::::0;::::1;4898:21:1::0;4955:2;4935:18;;;4928:30;4994:26;4974:18;;;4967:54;5038:18;;34030:65:0::1;;;;;;;;;-1:-1:-1::0;;;;;34106:28:0::1;34137:5;34106:28:::0;;;:19:::1;:28;::::0;;;;:36;;-1:-1:-1;;34106:36:0::1;::::0;;33960:190::o;37453:205::-;18910:13;:11;:13::i;:::-;37551:1:::1;37539:9;:13;37531:33;;;::::0;-1:-1:-1;;;37531:33:0;;5269:2:1;37531:33:0::1;::::0;::::1;5251:21:1::0;5308:1;5288:18;;;5281:29;-1:-1:-1;;;5326:18:1;;;5319:37;5373:18;;37531:33:0::1;5067:330:1::0;37531:33:0::1;37596:2;37583:9;:15;;37575:36;;;::::0;-1:-1:-1;;;37575:36:0;;5604:2:1;37575:36:0::1;::::0;::::1;5586:21:1::0;5643:1;5623:18;;;5616:29;-1:-1:-1;;;5661:18:1;;;5654:38;5709:18;;37575:36:0::1;5402:331:1::0;37575:36:0::1;37622:16;:28:::0;37453:205::o;9214:295::-;9345:4;4004:10;9403:38;9419:4;4004:10;9434:6;9403:15;:38::i;:::-;9452:27;9462:4;9468:2;9472:6;9452:9;:27::i;:::-;-1:-1:-1;9497:4:0;;9214:295;-1:-1:-1;;;;9214:295:0:o;32388:137::-;18910:13;:11;:13::i;:::-;32441:10:::1;::::0;::::1;;:19;32433:56;;;::::0;-1:-1:-1;;;32433:56:0;;5940:2:1;32433:56:0::1;::::0;::::1;5922:21:1::0;5979:2;5959:18;;;5952:30;6018:26;5998:18;;;5991:54;6062:18;;32433:56:0::1;5738:348:1::0;32433:56:0::1;32500:10;:17:::0;;-1:-1:-1;;32500:17:0::1;32513:4;32500:17;::::0;;32388:137::o;9918:238::-;10006:4;4004:10;10062:64;4004:10;10078:7;10115:10;10087:25;4004:10;10078:7;10087:9;:25::i;:::-;:38;;;;:::i;:::-;10062:8;:64::i;17288:91::-;17344:27;4004:10;17364:6;17344:5;:27::i;:::-;17288:91;:::o;39489:108::-;18910:13;:11;:13::i;:::-;39562:18:::1;:27:::0;;-1:-1:-1;;39562:27:0::1;::::0;::::1;;::::0;;;::::1;::::0;;39489:108::o;34292:311::-;18910:13;:11;:13::i;:::-;34397:2:::1;34385:8;:14;;34377:53;;;::::0;-1:-1:-1;;;34377:53:0;;6555:2:1;34377:53:0::1;::::0;::::1;6537:21:1::0;6594:2;6574:18;;;6567:30;6633:28;6613:18;;;6606:56;6679:18;;34377:53:0::1;6353:350:1::0;34377:53:0::1;34460:2;34449:7;:13;;34441:52;;;::::0;-1:-1:-1;;;34441:52:0;;6555:2:1;34441:52:0::1;::::0;::::1;6537:21:1::0;6594:2;6574:18;;;6567:30;6633:28;6613:18;;;6606:56;6679:18;;34441:52:0::1;6353:350:1::0;34441:52:0::1;34504:7;:18:::0;;;34533:6:::1;:16:::0;;;34567:28:::1;::::0;;6882:25:1;;;6938:2;6923:18;;6916:34;;;34567:28:0::1;::::0;6855:18:1;34567:28:0::1;;;;;;;34292:311:::0;;:::o;19672:103::-;18910:13;:11;:13::i;:::-;19737:30:::1;19764:1;19737:18;:30::i;:::-;19672:103::o:0;17698:164::-;17775:46;17791:7;4004:10;17814:6;17775:15;:46::i;:::-;17832:22;17838:7;17847:6;17832:5;:22::i;:::-;17698:164;;:::o;6301:104::-;6357:13;6390:7;6383:14;;;;;:::i;33124:252::-;18910:13;:11;:13::i;:::-;33231::::1;::::0;-1:-1:-1;;;;;33231:13:0;;::::1;33223:21:::0;;::::1;::::0;33215:99:::1;;;::::0;-1:-1:-1;;;33215:99:0;;7163:2:1;33215:99:0::1;::::0;::::1;7145:21:1::0;7202:2;7182:18;;;7175:30;7241:34;7221:18;;;7214:62;7312:34;7292:18;;;7285:62;-1:-1:-1;;;7363:19:1;;;7356:32;7405:19;;33215:99:0::1;6961:469:1::0;33215:99:0::1;33327:41;33356:4;33362:5;33327:28;:41::i;39264:106::-:0;18910:13;:11;:13::i;:::-;39338:10:::1;:24:::0;39264:106::o;39378:103::-;18910:13;:11;:13::i;:::-;-1:-1:-1;;;;;39451:13:0;;;::::1;;::::0;;;:8:::1;:13;::::0;;;;:22;;-1:-1:-1;;39451:22:0::1;::::0;::::1;;::::0;;;::::1;::::0;;39378:103::o;10659:436::-;10752:4;4004:10;10752:4;10835:25;4004:10;10852:7;10835:9;:25::i;:::-;10808:52;;10899:15;10879:16;:35;;10871:85;;;;-1:-1:-1;;;10871:85:0;;7637:2:1;10871:85:0;;;7619:21:1;7676:2;7656:18;;;7649:30;7715:34;7695:18;;;7688:62;-1:-1:-1;;;7766:18:1;;;7759:35;7811:19;;10871:85:0;7435:401:1;10871:85:0;10992:60;11001:5;11008:7;11036:15;11017:16;:34;10992:8;:60::i;7706:193::-;7785:4;4004:10;7841:28;4004:10;7858:2;7862:6;7841:9;:28::i;37294:151::-;18910:13;:11;:13::i;:::-;37394:1:::1;37382:9;:13;37374:22;;;::::0;::::1;;37407:18;:30:::0;37294:151::o;34611:254::-;18910:13;:11;:13::i;:::-;34726:15:::1;::::0;-1:-1:-1;;;;;34726:15:0;;::::1;34706:35:::0;;::::1;::::0;34698:59:::1;;;::::0;-1:-1:-1;;;34698:59:0;;8043:2:1;34698:59:0::1;::::0;::::1;8025:21:1::0;8082:2;8062:18;;;8055:30;-1:-1:-1;;;8101:18:1;;;8094:41;8152:18;;34698:59:0::1;7841:335:1::0;34698:59:0::1;34768:15;:34:::0;;-1:-1:-1;;;;;;34768:34:0::1;-1:-1:-1::0;;;;;34768:34:0;::::1;::::0;;::::1;::::0;;;34818:39:::1;::::0;1388:51:1;;;34818:39:0::1;::::0;1376:2:1;1361:18;34818:39:0::1;;;;;;;34611:254:::0;:::o;39605:110::-;18910:13;:11;:13::i;:::-;39681:11:::1;:26:::0;39605:110::o;7962:151::-;-1:-1:-1;;;;;8078:18:0;;;8051:7;8078:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;7962:151::o;38808:198::-;38883:4;38925:7;19097:6;;-1:-1:-1;;;;;19097:6:0;;19024:87;38925:7;-1:-1:-1;;;;;38917:15:0;:4;-1:-1:-1;;;;;38917:15:0;;:32;;;-1:-1:-1;19097:6:0;;-1:-1:-1;;;;;38936:13:0;;;19097:6;;38936:13;38917:32;:57;;;-1:-1:-1;;;;;;38953:21:0;;38969:4;38953:21;38917:57;:80;;;-1:-1:-1;;;;;;38978:19:0;;38992:4;38978:19;38917:80;38909:89;38808:198;-1:-1:-1;;;38808:198:0:o;33706:246::-;18910:13;:11;:13::i;:::-;-1:-1:-1;;;;;33787:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;::::1;;33786:29;33778:78;;;::::0;-1:-1:-1;;;33778:78:0;;8383:2:1;33778:78:0::1;::::0;::::1;8365:21:1::0;8422:2;8402:18;;;8395:30;8461:34;8441:18;;;8434:62;-1:-1:-1;;;8512:18:1;;;8505:34;8556:19;;33778:78:0::1;8181:400:1::0;33778:78:0::1;-1:-1:-1::0;;;;;33867:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;:35;;-1:-1:-1;;33867:35:0::1;33898:4;33867:35;::::0;;33920:24;::::1;::::0;33867:28;33920:24:::1;33706:246:::0;:::o;39014:122::-;18910:13;:11;:13::i;:::-;39087:34:::1;:41:::0;;-1:-1:-1;;39087:41:0::1;39124:4;39087:41;::::0;;39014:122::o;39144:110::-;18910:13;:11;:13::i;:::-;39220:11:::1;:26:::0;39144:110::o;19930:201::-;18910:13;:11;:13::i;:::-;-1:-1:-1;;;;;20019:22:0;::::1;20011:73;;;::::0;-1:-1:-1;;;20011:73:0;;8788:2:1;20011:73:0::1;::::0;::::1;8770:21:1::0;8827:2;8807:18;;;8800:30;8866:34;8846:18;;;8839:62;-1:-1:-1;;;8917:18:1;;;8910:36;8963:19;;20011:73:0::1;8586:402:1::0;20011:73:0::1;20095:28;20114:8;20095:18;:28::i;32533:441::-:0;18910:13;:11;:13::i;:::-;32629:4:::1;-1:-1:-1::0;;;;;32612:22:0;::::1;::::0;32604:67:::1;;;::::0;-1:-1:-1;;;32604:67:0;;9195:2:1;32604:67:0::1;::::0;::::1;9177:21:1::0;;;9214:18;;;9207:30;9273:34;9253:18;;;9246:62;9325:18;;32604:67:0::1;8993:356:1::0;32604:67:0::1;-1:-1:-1::0;;;;;32686:21:0;::::1;32682:126;;32724:51;::::0;32732:10:::1;::::0;32753:21:::1;32724:51:::0;::::1;;;::::0;::::1;::::0;;;32753:21;32732:10;32724:51;::::1;;;;;;;;;;;;;::::0;::::1;;;;32682:126;32880:35;::::0;-1:-1:-1;;;32880:35:0;;32909:4:::1;32880:35;::::0;::::1;1388:51:1::0;32845:5:0;;32818:17:::1;::::0;-1:-1:-1;;;;;32880:20:0;::::1;::::0;::::1;::::0;1361:18:1;;32880:35:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;32926:40;::::0;-1:-1:-1;;;32926:40:0;;32946:10:::1;32926:40;::::0;::::1;9717:51:1::0;9784:18;;;9777:34;;;32862:53:0;;-1:-1:-1;;;;;;32926:19:0;::::1;::::0;::::1;::::0;9690:18:1;;32926:40:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;32593:381;;32533:441:::0;:::o;14284:380::-;-1:-1:-1;;;;;14420:19:0;;14412:68;;;;-1:-1:-1;;;14412:68:0;;10274:2:1;14412:68:0;;;10256:21:1;10313:2;10293:18;;;10286:30;10352:34;10332:18;;;10325:62;-1:-1:-1;;;10403:18:1;;;10396:34;10447:19;;14412:68:0;10072:400:1;14412:68:0;-1:-1:-1;;;;;14499:21:0;;14491:68;;;;-1:-1:-1;;;14491:68:0;;10679:2:1;14491:68:0;;;10661:21:1;10718:2;10698:18;;;10691:30;10757:34;10737:18;;;10730:62;-1:-1:-1;;;10808:18:1;;;10801:32;10850:19;;14491:68:0;10477:398:1;14491:68:0;-1:-1:-1;;;;;14572:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;14624:32;;1848:25:1;;;14624:32:0;;1821:18:1;14624:32:0;;;;;;;;14284:380;;;:::o;19189:132::-;19097:6;;-1:-1:-1;;;;;19097:6:0;4004:10;19253:23;19245:68;;;;-1:-1:-1;;;19245:68:0;;11082:2:1;19245:68:0;;;11064:21:1;;;11101:18;;;11094:30;11160:34;11140:18;;;11133:62;11212:18;;19245:68:0;10880:356:1;14955:453:0;15090:24;15117:25;15127:5;15134:7;15117:9;:25::i;:::-;15090:52;;-1:-1:-1;;15157:16:0;:37;15153:248;;15239:6;15219:16;:26;;15211:68;;;;-1:-1:-1;;;15211:68:0;;11443:2:1;15211:68:0;;;11425:21:1;11482:2;11462:18;;;11455:30;11521:31;11501:18;;;11494:59;11570:18;;15211:68:0;11241:353:1;15211:68:0;15323:51;15332:5;15339:7;15367:6;15348:16;:25;15323:8;:51::i;34873:1794::-;-1:-1:-1;;;;;35005:18:0;;34997:68;;;;-1:-1:-1;;;34997:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35084:16:0;;35076:64;;;;-1:-1:-1;;;35076:64:0;;;;;;;:::i;:::-;35158:8;;-1:-1:-1;;;35158:8:0;;;;35153:66;;35183:24;35190:4;35196:2;35200:6;35183;:24::i;:::-;35246:6;;35279:7;;-1:-1:-1;;;;;35304:14:0;;35231:12;35304:14;;;:8;:14;;;;;;;;35303:15;:32;;;;-1:-1:-1;;;;;;35323:12:0;;;;;;:8;:12;;;;;;;;35322:13;35303:32;35299:105;;;35360:10;;;;35352:40;;;;-1:-1:-1;;;35352:40:0;;12611:2:1;35352:40:0;;;12593:21:1;12650:2;12630:18;;;12623:30;-1:-1:-1;;;12669:18:1;;;12662:47;12726:18;;35352:40:0;12409:341:1;35352:40:0;35420:6;35430:1;35420:11;35416:50;;35448:7;;34873:1794;;;:::o;35416:50::-;35494:8;;-1:-1:-1;;;;;35519:25:0;;35478:12;35519:25;;;:19;:25;;;;;;35494:8;-1:-1:-1;;;35494:8:0;;;;;35493:9;;35519:25;;:52;;-1:-1:-1;;;;;;35548:23:0;;;;;;:19;:23;;;;;;;;35519:52;35515:100;;;-1:-1:-1;35598:5:0;35515:100;35662:4;35627:14;7474:18;;;;;;;;;;;35627:41;;35681:12;35706:18;;35696:6;:28;;:42;;;;;35737:1;35728:6;:10;35696:42;:78;;;;-1:-1:-1;;;;;;35743:31:0;;;;;;:25;:31;;;;;;;;35742:32;35696:78;:89;;;;;35778:7;35696:89;35681:104;;35800:7;:33;;;;-1:-1:-1;35825:8:0;;-1:-1:-1;;;35825:8:0;;;;35824:9;35800:33;35796:361;;;35850:8;:15;;-1:-1:-1;;;;35850:15:0;;-1:-1:-1;;;35850:15:0;;;;-1:-1:-1;;;;;35912:13:0;-1:-1:-1;7474:18:0;;;;;;;;;;;35968:16;;35987:3;;35954:30;;7474:18;35954:30;:::i;:::-;:36;;;;:::i;:::-;35945:6;:45;35941:131;;;36053:3;36034:16;;36020:11;:30;;;;:::i;:::-;:36;;;;:::i;:::-;36011:45;;35941:131;36086:28;36107:6;36086:20;:28::i;:::-;-1:-1:-1;36129:8:0;:16;;-1:-1:-1;;;;36129:16:0;;;35796:361;36173:7;:30;;;;-1:-1:-1;36190:13:0;;-1:-1:-1;;;;;36184:19:0;;;36190:13;;36184:19;36173:30;:46;;;;;36218:1;36207:8;:12;36173:46;36169:445;;;36236:12;36273:3;36252:17;36261:8;36252:6;:17;:::i;:::-;36251:25;;;;:::i;:::-;36236:40;-1:-1:-1;36300:13:0;36236:40;36300:6;:13;:::i;:::-;36291:22;;36330:42;36346:4;36360;36367;36330:15;:42::i;:::-;36221:163;36169:445;;;36403:7;:32;;;;-1:-1:-1;36422:13:0;;-1:-1:-1;;;;;36414:21:0;;;36422:13;;36414:21;36403:32;:47;;;;;36449:1;36439:7;:11;36403:47;36399:215;;;36467:12;36503:3;36483:16;36492:7;36483:6;:16;:::i;:::-;36482:24;;;;:::i;:::-;36467:39;-1:-1:-1;36530:13:0;36467:39;36530:6;:13;:::i;:::-;36521:22;;36560:42;36576:4;36590;36597;36560:15;:42::i;:::-;36452:162;36399:215;36626:33;36642:4;36648:2;36652:6;36626:15;:33::i;:::-;34986:1681;;;;;34873:1794;;;:::o;13255:591::-;-1:-1:-1;;;;;13339:21:0;;13331:67;;;;-1:-1:-1;;;13331:67:0;;13485:2:1;13331:67:0;;;13467:21:1;13524:2;13504:18;;;13497:30;13563:34;13543:18;;;13536:62;-1:-1:-1;;;13614:18:1;;;13607:31;13655:19;;13331:67:0;13283:397:1;13331:67:0;-1:-1:-1;;;;;13498:18:0;;13473:22;13498:18;;;;;;;;;;;13535:24;;;;13527:71;;;;-1:-1:-1;;;13527:71:0;;13887:2:1;13527:71:0;;;13869:21:1;13926:2;13906:18;;;13899:30;13965:34;13945:18;;;13938:62;-1:-1:-1;;;14016:18:1;;;14009:32;14058:19;;13527:71:0;13685:398:1;13527:71:0;-1:-1:-1;;;;;13634:18:0;;:9;:18;;;;;;;;;;13655:23;;;13634:44;;13700:12;:22;;13672:6;;13634:9;13700:22;;13672:6;;13700:22;:::i;:::-;;;;-1:-1:-1;;13740:37:0;;1848:25:1;;;13766:1:0;;-1:-1:-1;;;;;13740:37:0;;;;;1836:2:1;1821:18;13740:37:0;1702:177:1;13790:48:0;13320:526;13255:591;;:::o;20291:191::-;20384:6;;;-1:-1:-1;;;;;20401:17:0;;;-1:-1:-1;;;;;;20401:17:0;;;;;;;20434:40;;20384:6;;;20401:17;20384:6;;20434:40;;20365:16;;20434:40;20354:128;20291:191;:::o;33384:308::-;-1:-1:-1;;;;;33475:31:0;;;;;;:25;:31;;;;;;:40;;;:31;;;;:40;;;33467:109;;;;-1:-1:-1;;;33467:109:0;;14290:2:1;33467:109:0;;;14272:21:1;14329:2;14309:18;;;14302:30;14368:34;14348:18;;;14341:62;14439:26;14419:18;;;14412:54;14483:19;;33467:109:0;14088:420:1;33467:109:0;-1:-1:-1;;;;;33587:31:0;;;;;;:25;:31;;;;;;:39;;-1:-1:-1;;33587:39:0;;;;;;;;;;33644:40;;33587:39;;:31;33644:40;;;33384:308;;:::o;37666:446::-;37793:34;;;;37788:315;;37863:28;37882:4;37888:2;37863:18;:28::i;:::-;37862:29;:46;;;;-1:-1:-1;;;;;;37896:12:0;;;;;;:8;:12;;;;;;;;37895:13;37862:46;37858:234;;;37931:27;37949:4;37955:2;37931:17;:27::i;:::-;37977:29;37995:2;37999:6;37977:17;:29::i;:::-;38043:33;38065:2;38069:6;38043:21;:33::i;36681:605::-;36777:16;;;36791:1;36777:16;;;;;;;;36753:21;;36777:16;;;;;;;;;;-1:-1:-1;36777:16:0;36753:40;;36822:4;36804;36809:1;36804:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;36804:23:0;;;:7;;;;;;;;;;:23;;;;36848:15;;:22;;;-1:-1:-1;;;36848:22:0;;;;:15;;;;;:20;;:22;;;;;36804:7;;36848:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;36838:4;36843:1;36838:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;36838:32:0;;;:7;;;;;;;;;:32;36887:15;;:187;;-1:-1:-1;;;36887:187:0;;:15;;;:66;;:187;;36968:11;;36887:15;;37011:4;;37038;;37058:15;;36887:187;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;36883:222;37186:15;;37138:21;;37170:45;;-1:-1:-1;;;;;37186:15:0;37138:21;37170:7;:45::i;:::-;37233;;;6882:25:1;;;6938:2;6923:18;;6916:34;;;37233:45:0;;6855:18:1;37233:45:0;;;;;;;36740:546;;36681:605;:::o;11565:671::-;-1:-1:-1;;;;;11696:18:0;;11688:68;;;;-1:-1:-1;;;11688:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;11775:16:0;;11767:64;;;;-1:-1:-1;;;11767:64:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;11917:15:0;;11895:19;11917:15;;;;;;;;;;;11951:21;;;;11943:72;;;;-1:-1:-1;;;11943:72:0;;16220:2:1;11943:72:0;;;16202:21:1;16259:2;16239:18;;;16232:30;16298:34;16278:18;;;16271:62;-1:-1:-1;;;16349:18:1;;;16342:36;16395:19;;11943:72:0;16018:402:1;11943:72:0;-1:-1:-1;;;;;12051:15:0;;;:9;:15;;;;;;;;;;;12069:20;;;12051:38;;12111:13;;;;;;;;:23;;12083:6;;12051:9;12111:23;;12083:6;;12111:23;:::i;:::-;;;;;;;;12167:2;-1:-1:-1;;;;;12152:26:0;12161:4;-1:-1:-1;;;;;12152:26:0;;12171:6;12152:26;;;;1848:25:1;;1836:2;1821:18;;1702:177;12152:26:0;;;;;;;;12191:37;13255:591;38120:285;38197:18;;;;:43;;;;-1:-1:-1;38227:13:0;;-1:-1:-1;;;;;38219:21:0;;;38227:13;;38219:21;38197:43;38193:203;;;38305:11;;38291:9;38283:18;;;;:7;:18;;;;;;38265:36;;:15;:36;:::i;:::-;:51;;38257:76;;;;-1:-1:-1;;;38257:76:0;;16627:2:1;38257:76:0;;;16609:21:1;16666:2;16646:18;;;16639:30;-1:-1:-1;;;16685:18:1;;;16678:42;16737:18;;38257:76:0;16425:336:1;38257:76:0;38356:9;38348:18;;;;:7;:18;;;;;38369:15;38348:36;;38120:285;;:::o;38413:142::-;38511:11;;38501:6;:21;;38493:52;;;;-1:-1:-1;;;38493:52:0;;16968:2:1;38493:52:0;;;16950:21:1;17007:2;16987:18;;;16980:30;-1:-1:-1;;;17026:18:1;;;17019:48;17084:18;;38493:52:0;16766:342:1;38563:237:0;38657:13;;-1:-1:-1;;;;;38657:13:0;;;38651:19;;;;38647:58;;38563:237;;:::o;38647:58::-;38751:10;;38741:6;38725:13;38735:2;-1:-1:-1;;;;;7474:18:0;7447:7;7474:18;;;;;;;;;;;;7373:127;38725:13;:22;;;;:::i;:::-;:36;;38717:73;;;;-1:-1:-1;;;38717:73:0;;17315:2:1;38717:73:0;;;17297:21:1;17354:2;17334:18;;;17327:30;17393:26;17373:18;;;17366:54;17437:18;;38717:73:0;17113:348:1;32982:134:0;33062:9;-1:-1:-1;;;;;33062:14:0;33083:4;33097:6;33062:46;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32982:134;;:::o;14:548: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;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:131::-;-1:-1:-1;;;;;642:31:1;;632:42;;622:70;;688:1;685;678:12;703:315;771:6;779;832:2;820:9;811:7;807:23;803:32;800:52;;;848:1;845;838:12;800:52;887:9;874:23;906:31;931:5;906:31;:::i;:::-;956:5;1008:2;993:18;;;;980:32;;-1:-1:-1;;;703:315:1:o;1450:247::-;1509:6;1562:2;1550:9;1541:7;1537:23;1533:32;1530:52;;;1578:1;1575;1568:12;1530:52;1617:9;1604:23;1636:31;1661:5;1636:31;:::i;1884:180::-;1943:6;1996:2;1984:9;1975:7;1971:23;1967:32;1964:52;;;2012:1;2009;2002:12;1964:52;-1:-1:-1;2035:23:1;;1884:180;-1:-1:-1;1884:180:1:o;2069:456::-;2146:6;2154;2162;2215:2;2203:9;2194:7;2190:23;2186:32;2183:52;;;2231:1;2228;2221:12;2183:52;2270:9;2257:23;2289:31;2314:5;2289:31;:::i;:::-;2339:5;-1:-1:-1;2396:2:1;2381:18;;2368:32;2409:33;2368:32;2409:33;:::i;:::-;2069:456;;2461:7;;-1:-1:-1;;;2515:2:1;2500:18;;;;2487:32;;2069:456::o;2927:118::-;3013:5;3006:13;2999:21;2992:5;2989:32;2979:60;;3035:1;3032;3025:12;3050:241;3106:6;3159:2;3147:9;3138:7;3134:23;3130:32;3127:52;;;3175:1;3172;3165:12;3127:52;3214:9;3201:23;3233:28;3255:5;3233:28;:::i;3296:248::-;3364:6;3372;3425:2;3413:9;3404:7;3400:23;3396:32;3393:52;;;3441:1;3438;3431:12;3393:52;-1:-1:-1;;3464:23:1;;;3534:2;3519:18;;;3506:32;;-1:-1:-1;3296:248:1:o;3549:382::-;3614:6;3622;3675:2;3663:9;3654:7;3650:23;3646:32;3643:52;;;3691:1;3688;3681:12;3643:52;3730:9;3717:23;3749:31;3774:5;3749:31;:::i;:::-;3799:5;-1:-1:-1;3856:2:1;3841:18;;3828:32;3869:30;3828:32;3869:30;:::i;:::-;3918:7;3908:17;;;3549:382;;;;;:::o;3936:388::-;4004:6;4012;4065:2;4053:9;4044:7;4040:23;4036:32;4033:52;;;4081:1;4078;4071:12;4033:52;4120:9;4107:23;4139:31;4164:5;4139:31;:::i;:::-;4189:5;-1:-1:-1;4246:2:1;4231:18;;4218:32;4259:33;4218:32;4259:33;:::i;4329:380::-;4408:1;4404:12;;;;4451;;;4472:61;;4526:4;4518:6;4514:17;4504:27;;4472:61;4579:2;4571:6;4568:14;4548:18;4545:38;4542:161;;4625:10;4620:3;4616:20;4613:1;4606:31;4660:4;4657:1;4650:15;4688:4;4685:1;4678:15;4542:161;;4329:380;;;:::o;6091:127::-;6152:10;6147:3;6143:20;6140:1;6133:31;6183:4;6180:1;6173:15;6207:4;6204:1;6197:15;6223:125;6288:9;;;6309:10;;;6306:36;;;6322:18;;:::i;9354:184::-;9424:6;9477:2;9465:9;9456:7;9452:23;9448:32;9445:52;;;9493:1;9490;9483:12;9445:52;-1:-1:-1;9516:16:1;;9354:184;-1:-1:-1;9354:184:1:o;9822:245::-;9889:6;9942:2;9930:9;9921:7;9917:23;9913:32;9910:52;;;9958:1;9955;9948:12;9910:52;9990:9;9984:16;10009:28;10031:5;10009:28;:::i;11599:401::-;11801:2;11783:21;;;11840:2;11820:18;;;11813:30;11879:34;11874:2;11859:18;;11852:62;-1:-1:-1;;;11945:2:1;11930:18;;11923:35;11990:3;11975:19;;11599:401::o;12005:399::-;12207:2;12189:21;;;12246:2;12226:18;;;12219:30;12285:34;12280:2;12265:18;;12258:62;-1:-1:-1;;;12351:2:1;12336:18;;12329:33;12394:3;12379:19;;12005:399::o;12755:168::-;12828:9;;;12859;;12876:15;;;12870:22;;12856:37;12846:71;;12897:18;;:::i;12928:217::-;12968:1;12994;12984:132;;13038:10;13033:3;13029:20;13026:1;13019:31;13073:4;13070:1;13063:15;13101:4;13098:1;13091:15;12984:132;-1:-1:-1;13130:9:1;;12928:217::o;13150:128::-;13217:9;;;13238:11;;;13235:37;;;13252:18;;:::i;14645:127::-;14706:10;14701:3;14697:20;14694:1;14687:31;14737:4;14734:1;14727:15;14761:4;14758:1;14751:15;14777:251;14847:6;14900:2;14888:9;14879:7;14875:23;14871:32;14868:52;;;14916:1;14913;14906:12;14868:52;14948:9;14942:16;14967:31;14992:5;14967:31;:::i;15033:980::-;15295:4;15343:3;15332:9;15328:19;15374:6;15363:9;15356:25;15400:2;15438:6;15433:2;15422:9;15418:18;15411:34;15481:3;15476:2;15465:9;15461:18;15454:31;15505:6;15540;15534:13;15571:6;15563;15556:22;15609:3;15598:9;15594:19;15587:26;;15648:2;15640:6;15636:15;15622:29;;15669:1;15679:195;15693:6;15690:1;15687:13;15679:195;;;15758:13;;-1:-1:-1;;;;;15754:39:1;15742:52;;15849:15;;;;15814:12;;;;15790:1;15708:9;15679:195;;;-1:-1:-1;;;;;;;15930:32:1;;;;15925:2;15910:18;;15903:60;-1:-1:-1;;;15994:3:1;15979:19;15972:35;15891:3;15033:980;-1:-1:-1;;;15033:980:1:o

Swarm Source

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