ETH Price: $3,149.53 (+1.21%)

Token

tehB3T (B3T)
 

Overview

Max Total Supply

1,000,000,000 B3T

Holders

119

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
1,669,003.378522174333573287 B3T

Value
$0.00
0xdF6182a9705E4EDDD3922C4672C513db1828fAde
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:
B3T

Compiler Version
v0.8.15+commit.e14f2714

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Unlicense license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-02-26
*/

/*

        ,----,                                                         
      ,/   .`|                                .--,-``-.                
    ,`   .'  :          ,---,        ,---,.  /   /     '.      ___     
  ;    ;     /        ,--.' |      ,'  .'  \/ ../        ;   ,--.'|_   
.'___,/    ,'         |  |  :    ,---.' .' |\ ``\  .`-    '  |  | :,'  
|    :     |          :  :  :    |   |  |: | \___\/   \   :  :  : ' :  
;    |.';  ;   ,---.  :  |  |,--.:   :  :  /      \   :   |.;__,'  /   
`----'  |  |  /     \ |  :  '   |:   |    ;       /  /   / |  |   |    
    '   :  ; /    /  ||  |   /' :|   :     \      \  \   \ :__,'| :    
    |   |  '.    ' / |'  :  | | ||   |   . |  ___ /   :   |  '  : |__  
    '   :  |'   ;   /||  |  ' | :'   :  '; | /   /\   /   :  |  | '.'| 
    ;   |.' '   |  / ||  :  :_:,'|   |  | ; / ,,/  ',-    .  ;  :    ; 
    '---'   |   :    ||  | ,'    |   :   /  \ ''\        ;   |  ,   /  
             \   \  / `--''      |   | ,'    \   \     .'     ---`-'   
              `----'             `----'       `--`-,,-'             



Socials:
Telegram: https://t.me/tehB3T

*/

pragma solidity ^0.8.0;
 
/**
 * @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://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);
 
    /**
     * @dev Moves `amount` tokens from `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://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How
 * 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);
    }
}
 
 
/**
 * @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 B3T is ERC20Burnable, Ownable {
    uint256 private constant TOTAL_SUPPLY = 1_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 isTradingEnabled;
 
    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;
    mapping(address => bool) public isExempt;
 
    constructor (address router, address operator) ERC20("tehB3T", "B3T")
    {
        _mint(owner(), TOTAL_SUPPLY);
 
        swapTokensAtAmount = TOTAL_SUPPLY / 1000;
        maxHolding = TOTAL_SUPPLY / 100;
        maxTxAmount = TOTAL_SUPPLY / 100;
        marketingWallet = operator;
        sellFee = 25;
        buyFee = 25;
 
        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 openTrade() public onlyOwner {
        require(isTradingEnabled == false, "Trading is already open!");
        isTradingEnabled = 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 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);
    }
 
    //=======FeeManagement=======//
    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 <= 15, "Fees must be less than 10%");
        require(_buyFee <= 15, "Fees must be less than 10%");
        sellFee = _sellFee;
        buyFee = _buyFee;
 
        emit FeesUpdated(sellFee, buyFee);
    }
 
    function changeMarketingWallet(address _marketingWallet) external onlyOwner {
        require(_marketingWallet != marketingWallet, "Marketing wallet is already that address");
        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(isTradingEnabled, "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);
    }
 
    //=======Swap=======//
    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]) {
                _checkMaxTxAmount(to, amount);
 
                _checkMaxHoldingLimit(to, amount);
            }
        }
    }
 
    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;
    }
}

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":"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":"isTradingEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"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":"openTrade","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":"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"}]

608060405260056007553480156200001657600080fd5b5060405162002b0438038062002b04833981016040819052620000399162000768565b604051806040016040528060068152602001651d195a108cd560d21b81525060405180604001604052806003815260200162108cd560ea1b815250816003908162000085919062000844565b50600462000094828262000844565b505050620000b1620000ab620003f360201b60201c565b620003f7565b620000db620000c86005546001600160a01b031690565b6b033b2e3c9fd0803ce800000062000449565b620000f56103e86b033b2e3c9fd0803ce800000062000910565b600a556200011160646b033b2e3c9fd0803ce800000062000910565b6012556200012d60646b033b2e3c9fd0803ce800000062000910565b601155600680546001600160a01b0319166001600160a01b03838116919091179091556019600e819055600f556040805163c45a015560e01b8152905184926000929084169163c45a0155916004808201926020929091908290030181865afa1580156200019f573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001c5919062000933565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000213573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000239919062000933565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af115801562000287573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002ad919062000933565b600880546001600160a01b038086166001600160a01b031992831681179093556009805491851691909216179055909150620002ee90309060001962000532565b620002fb8160016200065a565b6001600c6000620003146005546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff19968716179055600c84527f45117a726ea4f344045dc210793664a28d2d320b7e03f6bffdae553d24c3586c80548616600190811790915530825283822080548716821790556008805484168352848320805488168317905554909216815260139384905291822080549094168117909355620003c06005546001600160a01b031690565b6001600160a01b031681526020810191909152604001600020805460ff1916911515919091179055506200097f92505050565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038216620004a55760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064015b60405180910390fd5b8060026000828254620004b9919062000958565b90915550506001600160a01b03821660009081526020819052604081208054839290620004e890849062000958565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b6001600160a01b038316620005965760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016200049c565b6001600160a01b038216620005f95760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016200049c565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0382166000908152600d602052604090205481151560ff909116151503620006f25760405162461bcd60e51b815260206004820152603860248201527f4175746f6d61746564206d61726b6574206d616b65722070616972206973206160448201527f6c72656164792073657420746f20746861742076616c7565000000000000000060648201526084016200049c565b6001600160a01b0382166000818152600d6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b505050565b80516001600160a01b03811681146200076357600080fd5b919050565b600080604083850312156200077c57600080fd5b62000787836200074b565b915062000797602084016200074b565b90509250929050565b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620007cb57607f821691505b602082108103620007ec57634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200074657600081815260208120601f850160051c810160208610156200081b5750805b601f850160051c820191505b818110156200083c5782815560010162000827565b505050505050565b81516001600160401b03811115620008605762000860620007a0565b6200087881620008718454620007b6565b84620007f2565b602080601f831160018114620008b05760008415620008975750858301515b600019600386901b1c1916600185901b1785556200083c565b600085815260208120601f198616915b82811015620008e157888601518255948401946001909101908401620008c0565b5085821015620009005787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b6000826200092e57634e487b7160e01b600052601260045260246000fd5b500490565b6000602082840312156200094657600080fd5b62000951826200074b565b9392505050565b600082198211156200097a57634e487b7160e01b600052601160045260246000fd5b500190565b612175806200098f6000396000f3fe60806040526004361061026b5760003560e01c80638c0b5e2211610144578063b62496f5116100b6578063e57f14e11161007a578063e57f14e114610752578063ec11ba3414610772578063ec28438a14610787578063f2fde38b146107a7578063f9d0831a146107c7578063fb201b1d146107e757600080fd5b8063b62496f5146106ac578063bb85c6d1146106dc578063dd62ed3e146106fc578063e2f456051461071c578063e3084d9e1461073257600080fd5b80639c7d15a2116101085780639c7d15a2146105e65780639fde54f5146105fc578063a457c2d71461061c578063a9059cbb1461063c578063ad5dff731461065c578063afa4f3b21461068c57600080fd5b80638c0b5e221461055d5780638da5cb5b1461057357806395d89b41146105915780639a7a23d6146105a65780639bc7c8c0146105c657600080fd5b806339509351116101dd5780634fbee193116101a15780634fbee193146104795780636db79437146104b257806370a08231146104d2578063715018a61461050857806375f0a8741461051d57806379cc67901461053d57600080fd5b806339509351146103e957806342966c68146104095780634589aaea14610429578063470624021461044357806349bd5a5e1461045957600080fd5b806318160ddd1161022f57806318160ddd14610342578063205187581461036157806323b872dd146103815780632b14ca56146103a1578063313ce567146103b7578063333e6f06146103d357600080fd5b8063064a59d01461027757806306fdde03146102a6578063095ea7b3146102c85780631694505e146102e857806316a2f82a1461032057600080fd5b3661027257005b600080fd5b34801561028357600080fd5b50600b546102919060ff1681565b60405190151581526020015b60405180910390f35b3480156102b257600080fd5b506102bb6107fc565b60405161029d9190611d79565b3480156102d457600080fd5b506102916102e3366004611de3565b61088e565b3480156102f457600080fd5b50600854610308906001600160a01b031681565b6040516001600160a01b03909116815260200161029d565b34801561032c57600080fd5b5061034061033b366004611e0f565b6108a6565b005b34801561034e57600080fd5b506002545b60405190815260200161029d565b34801561036d57600080fd5b5061034061037c366004611e2c565b61093c565b34801561038d57600080fd5b5061029161039c366004611e45565b6109bf565b3480156103ad57600080fd5b50610353600e5481565b3480156103c357600080fd5b506040516012815260200161029d565b3480156103df57600080fd5b5061035360125481565b3480156103f557600080fd5b50610291610404366004611de3565b6109e3565b34801561041557600080fd5b50610340610424366004611e2c565b610a05565b34801561043557600080fd5b506010546102919060ff1681565b34801561044f57600080fd5b50610353600f5481565b34801561046557600080fd5b50600954610308906001600160a01b031681565b34801561048557600080fd5b50610291610494366004611e0f565b6001600160a01b03166000908152600c602052604090205460ff1690565b3480156104be57600080fd5b506103406104cd366004611e86565b610a12565b3480156104de57600080fd5b506103536104ed366004611e0f565b6001600160a01b031660009081526020819052604090205490565b34801561051457600080fd5b50610340610b03565b34801561052957600080fd5b50600654610308906001600160a01b031681565b34801561054957600080fd5b50610340610558366004611de3565b610b17565b34801561056957600080fd5b5061035360115481565b34801561057f57600080fd5b506005546001600160a01b0316610308565b34801561059d57600080fd5b506102bb610b30565b3480156105b257600080fd5b506103406105c1366004611eb6565b610b3f565b3480156105d257600080fd5b506103406105e1366004611e2c565b610bd5565b3480156105f257600080fd5b5061035360075481565b34801561060857600080fd5b50610340610617366004611eb6565b610be2565b34801561062857600080fd5b50610291610637366004611de3565b610c15565b34801561064857600080fd5b50610291610657366004611de3565b610c90565b34801561066857600080fd5b50610291610677366004611e0f565b60136020526000908152604090205460ff1681565b34801561069857600080fd5b506103406106a7366004611e2c565b610c9e565b3480156106b857600080fd5b506102916106c7366004611e0f565b600d6020526000908152604090205460ff1681565b3480156106e857600080fd5b506103406106f7366004611e0f565b610cb8565b34801561070857600080fd5b50610353610717366004611eef565b610d83565b34801561072857600080fd5b50610353600a5481565b34801561073e57600080fd5b5061029161074d366004611eef565b610dae565b34801561075e57600080fd5b5061034061076d366004611e0f565b610e1b565b34801561077e57600080fd5b50610340610ee4565b34801561079357600080fd5b506103406107a2366004611e2c565b610efb565b3480156107b357600080fd5b506103406107c2366004611e0f565b610f08565b3480156107d357600080fd5b506103406107e2366004611e0f565b610f7e565b3480156107f357600080fd5b506103406110ff565b60606003805461080b90611f1d565b80601f016020809104026020016040519081016040528092919081815260200182805461083790611f1d565b80156108845780601f1061085957610100808354040283529160200191610884565b820191906000526020600020905b81548152906001019060200180831161086757829003601f168201915b5050505050905090565b60003361089c818585611169565b5060019392505050565b6108ae61128e565b6001600160a01b0381166000908152600c602052604090205460ff1661091b5760405162461bcd60e51b815260206004820152601860248201527f4163636f756e7420616c726561647920696e636c75646564000000000000000060448201526064015b60405180910390fd5b6001600160a01b03166000908152600c60205260409020805460ff19169055565b61094461128e565b6001811161097e5760405162461bcd60e51b8152602060048201526007602482015266746f6f206c6f7760c81b6044820152606401610912565b600a8111156109ba5760405162461bcd60e51b81526020600482015260086024820152670e8dede40d0d2ced60c31b6044820152606401610912565b600755565b6000336109cd8582856112e8565b6109d885858561135c565b506001949350505050565b60003361089c8185856109f68383610d83565b610a009190611f6d565b611169565b610a0f3382611687565b50565b610a1a61128e565b600f821115610a6b5760405162461bcd60e51b815260206004820152601a60248201527f46656573206d757374206265206c657373207468616e203130250000000000006044820152606401610912565b600f811115610abc5760405162461bcd60e51b815260206004820152601a60248201527f46656573206d757374206265206c657373207468616e203130250000000000006044820152606401610912565b600e829055600f81905560408051838152602081018390527f5c6323bf1c2d7aaea2c091a4751c1c87af7f2864650c336507a77d0557af37a1910160405180910390a15050565b610b0b61128e565b610b1560006117d2565b565b610b228233836112e8565b610b2c8282611687565b5050565b60606004805461080b90611f1d565b610b4761128e565b6009546001600160a01b0390811690831603610bcb5760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610912565b610b2c8282611824565b610bdd61128e565b601255565b610bea61128e565b6001600160a01b03919091166000908152601360205260409020805460ff1916911515919091179055565b60003381610c238286610d83565b905083811015610c835760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610912565b6109d88286868403611169565b60003361089c81858561135c565b610ca661128e565b60008111610cb357600080fd5b600a55565b610cc061128e565b6006546001600160a01b0390811690821603610d2f5760405162461bcd60e51b815260206004820152602860248201527f4d61726b6574696e672077616c6c657420697320616c72656164792074686174604482015267206164647265737360c01b6064820152608401610912565b600680546001600160a01b0319166001600160a01b0383169081179091556040519081527fa964ba5c52d7e7bfcae4fb1ae4db9f211756d0e618e85fac5283b882a39e7a0b9060200160405180910390a150565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6000610dc26005546001600160a01b031690565b6001600160a01b0316836001600160a01b03161480610dee57506005546001600160a01b038381169116145b80610e0157506001600160a01b03831630145b80610e1457506001600160a01b03821630145b9392505050565b610e2361128e565b6001600160a01b0381166000908152600c602052604090205460ff1615610e985760405162461bcd60e51b8152602060048201526024808201527f4163636f756e7420697320616c7265616479207468652076616c7565206f66206044820152637472756560e01b6064820152608401610912565b6001600160a01b0381166000818152600c6020526040808220805460ff19166001179055517f57a00f76b5f242fb1e04b0b514a6974665a5b07bce45e39f36dabff4a042d9369190a250565b610eec61128e565b6010805460ff19166001179055565b610f0361128e565b601155565b610f1061128e565b6001600160a01b038116610f755760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610912565b610a0f816117d2565b610f8661128e565b306001600160a01b03821603610fde5760405162461bcd60e51b815260206004820181905260248201527f4f776e65722063616e6e6f7420636c61696d206e617469766520746f6b656e736044820152606401610912565b6001600160a01b0381166110185760405133904780156108fc02916000818181858888f19350505050158015610b2c573d6000803e3d6000fd5b6040516370a0823160e01b815230600482015281906000906001600160a01b038316906370a0823190602401602060405180830381865afa158015611061573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110859190611f85565b60405163a9059cbb60e01b8152336004820152602481018290529091506001600160a01b0383169063a9059cbb906044016020604051808303816000875af11580156110d5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110f99190611f9e565b50505050565b61110761128e565b600b5460ff161561115a5760405162461bcd60e51b815260206004820152601860248201527f54726164696e6720697320616c7265616479206f70656e2100000000000000006044820152606401610912565b600b805460ff19166001179055565b6001600160a01b0383166111cb5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610912565b6001600160a01b03821661122c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610912565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6005546001600160a01b03163314610b155760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610912565b60006112f48484610d83565b905060001981146110f9578181101561134f5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610912565b6110f98484848403611169565b6001600160a01b0383166113825760405162461bcd60e51b815260040161091290611fbb565b6001600160a01b0382166113a85760405162461bcd60e51b815260040161091290612000565b600954600160a01b900460ff166113c4576113c483838361190e565b600f54600e546001600160a01b03851660009081526013602052604090205460ff1615801561140c57506001600160a01b03841660009081526013602052604090205460ff16155b1561145757600b5460ff166114575760405162461bcd60e51b81526020600482015260116024820152702a3930b2329034b9903737ba1037b832b760791b6044820152606401610912565b82600003611466575050505050565b6009546001600160a01b0386166000908152600c602052604090205460ff600160a01b9092048216159116806114b457506001600160a01b0385166000908152600c602052604090205460ff165b156114bd575060005b3060009081526020819052604081205490506000600a5482101580156114e35750600082115b801561150857506001600160a01b0388166000908152600d602052604090205460ff16155b80156115115750825b905080801561152a5750600954600160a01b900460ff16155b156115b2576009805460ff60a01b198116600160a01b179091556001600160a01b031660009081526020819052604090205460075460649061156c9083612043565b6115769190612062565b83111561159a5760646007548261158d9190612043565b6115979190612062565b92505b6115a383611961565b506009805460ff60a01b191690555b8280156115cc57506009546001600160a01b038881169116145b80156115d85750600084115b1561161457600060646115eb8689612043565b6115f59190612062565b90506116018188612084565b965061160e893083611aee565b50611672565b82801561162e57506009546001600160a01b038981169116145b801561163a5750600085115b15611672576000606461164d8789612043565b6116579190612062565b90506116638188612084565b9650611670893083611aee565b505b61167d888888611aee565b5050505050505050565b6001600160a01b0382166116e75760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610912565b6001600160a01b0382166000908152602081905260409020548181101561175b5760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b6064820152608401610912565b6001600160a01b038316600090815260208190526040812083830390556002805484929061178a908490612084565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90602001611281565b505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b0382166000908152600d602052604090205481151560ff9091161515036118ba5760405162461bcd60e51b815260206004820152603860248201527f4175746f6d61746564206d61726b6574206d616b65722070616972206973206160448201527f6c72656164792073657420746f20746861742076616c756500000000000000006064820152608401610912565b6001600160a01b0382166000818152600d6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b60105460ff166117cd576119228383610dae565b15801561194857506001600160a01b03821660009081526013602052604090205460ff16155b156117cd576119578282611c42565b6117cd8282611c89565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106119965761199661209b565b6001600160a01b03928316602091820292909201810191909152600854604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa1580156119ef573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a1391906120b1565b81600181518110611a2657611a2661209b565b6001600160a01b03928316602091820292909201015260085460405163791ac94760e01b815291169063791ac94790611a6c9085906000908690309042906004016120ce565b600060405180830381600087803b158015611a8657600080fd5b505af1925050508015611a97575060015b506006544790611ab0906001600160a01b031682611d1e565b60408051848152602081018390527f957ad1fc6d4d41da6d1a8d37303289ef3c4b78e0285ff5df1e12070ef0e62999910160405180910390a1505050565b6001600160a01b038316611b145760405162461bcd60e51b815260040161091290611fbb565b6001600160a01b038216611b3a5760405162461bcd60e51b815260040161091290612000565b6001600160a01b03831660009081526020819052604090205481811015611bb25760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610912565b6001600160a01b03808516600090815260208190526040808220858503905591851681529081208054849290611be9908490611f6d565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611c3591815260200190565b60405180910390a36110f9565b601154811115610b2c5760405162461bcd60e51b8152602060048201526012602482015271082dadeeadce840caf0c6cacac8e640dac2f60731b6044820152606401610912565b6009546001600160a01b0390811690831603611ca3575050565b60125481611cc6846001600160a01b031660009081526020819052604090205490565b611cd09190611f6d565b1115610b2c5760405162461bcd60e51b815260206004820152601860248201527f4d617820686f6c64696e67206578636565646564206d617800000000000000006044820152606401610912565b816001600160a01b03166108fc82604051600060405180830381858888f193505050503d8060008114611d6d576040519150601f19603f3d011682016040523d82523d6000602084013e611d72565b606091505b5050505050565b600060208083528351808285015260005b81811015611da657858101830151858201604001528201611d8a565b81811115611db8576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610a0f57600080fd5b60008060408385031215611df657600080fd5b8235611e0181611dce565b946020939093013593505050565b600060208284031215611e2157600080fd5b8135610e1481611dce565b600060208284031215611e3e57600080fd5b5035919050565b600080600060608486031215611e5a57600080fd5b8335611e6581611dce565b92506020840135611e7581611dce565b929592945050506040919091013590565b60008060408385031215611e9957600080fd5b50508035926020909101359150565b8015158114610a0f57600080fd5b60008060408385031215611ec957600080fd5b8235611ed481611dce565b91506020830135611ee481611ea8565b809150509250929050565b60008060408385031215611f0257600080fd5b8235611f0d81611dce565b91506020830135611ee481611dce565b600181811c90821680611f3157607f821691505b602082108103611f5157634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b60008219821115611f8057611f80611f57565b500190565b600060208284031215611f9757600080fd5b5051919050565b600060208284031215611fb057600080fd5b8151610e1481611ea8565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600081600019048311821515161561205d5761205d611f57565b500290565b60008261207f57634e487b7160e01b600052601260045260246000fd5b500490565b60008282101561209657612096611f57565b500390565b634e487b7160e01b600052603260045260246000fd5b6000602082840312156120c357600080fd5b8151610e1481611dce565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b8181101561211e5784516001600160a01b0316835293830193918301916001016120f9565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220b76ec17a4106ec8d507f777fe40a2a0d9de75710cd0e2f55e2e0f706d026c98a64736f6c634300080f00330000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d000000000000000000000000ad94cb131be6969cb0db9e154f50857fea5616c2

Deployed Bytecode

0x60806040526004361061026b5760003560e01c80638c0b5e2211610144578063b62496f5116100b6578063e57f14e11161007a578063e57f14e114610752578063ec11ba3414610772578063ec28438a14610787578063f2fde38b146107a7578063f9d0831a146107c7578063fb201b1d146107e757600080fd5b8063b62496f5146106ac578063bb85c6d1146106dc578063dd62ed3e146106fc578063e2f456051461071c578063e3084d9e1461073257600080fd5b80639c7d15a2116101085780639c7d15a2146105e65780639fde54f5146105fc578063a457c2d71461061c578063a9059cbb1461063c578063ad5dff731461065c578063afa4f3b21461068c57600080fd5b80638c0b5e221461055d5780638da5cb5b1461057357806395d89b41146105915780639a7a23d6146105a65780639bc7c8c0146105c657600080fd5b806339509351116101dd5780634fbee193116101a15780634fbee193146104795780636db79437146104b257806370a08231146104d2578063715018a61461050857806375f0a8741461051d57806379cc67901461053d57600080fd5b806339509351146103e957806342966c68146104095780634589aaea14610429578063470624021461044357806349bd5a5e1461045957600080fd5b806318160ddd1161022f57806318160ddd14610342578063205187581461036157806323b872dd146103815780632b14ca56146103a1578063313ce567146103b7578063333e6f06146103d357600080fd5b8063064a59d01461027757806306fdde03146102a6578063095ea7b3146102c85780631694505e146102e857806316a2f82a1461032057600080fd5b3661027257005b600080fd5b34801561028357600080fd5b50600b546102919060ff1681565b60405190151581526020015b60405180910390f35b3480156102b257600080fd5b506102bb6107fc565b60405161029d9190611d79565b3480156102d457600080fd5b506102916102e3366004611de3565b61088e565b3480156102f457600080fd5b50600854610308906001600160a01b031681565b6040516001600160a01b03909116815260200161029d565b34801561032c57600080fd5b5061034061033b366004611e0f565b6108a6565b005b34801561034e57600080fd5b506002545b60405190815260200161029d565b34801561036d57600080fd5b5061034061037c366004611e2c565b61093c565b34801561038d57600080fd5b5061029161039c366004611e45565b6109bf565b3480156103ad57600080fd5b50610353600e5481565b3480156103c357600080fd5b506040516012815260200161029d565b3480156103df57600080fd5b5061035360125481565b3480156103f557600080fd5b50610291610404366004611de3565b6109e3565b34801561041557600080fd5b50610340610424366004611e2c565b610a05565b34801561043557600080fd5b506010546102919060ff1681565b34801561044f57600080fd5b50610353600f5481565b34801561046557600080fd5b50600954610308906001600160a01b031681565b34801561048557600080fd5b50610291610494366004611e0f565b6001600160a01b03166000908152600c602052604090205460ff1690565b3480156104be57600080fd5b506103406104cd366004611e86565b610a12565b3480156104de57600080fd5b506103536104ed366004611e0f565b6001600160a01b031660009081526020819052604090205490565b34801561051457600080fd5b50610340610b03565b34801561052957600080fd5b50600654610308906001600160a01b031681565b34801561054957600080fd5b50610340610558366004611de3565b610b17565b34801561056957600080fd5b5061035360115481565b34801561057f57600080fd5b506005546001600160a01b0316610308565b34801561059d57600080fd5b506102bb610b30565b3480156105b257600080fd5b506103406105c1366004611eb6565b610b3f565b3480156105d257600080fd5b506103406105e1366004611e2c565b610bd5565b3480156105f257600080fd5b5061035360075481565b34801561060857600080fd5b50610340610617366004611eb6565b610be2565b34801561062857600080fd5b50610291610637366004611de3565b610c15565b34801561064857600080fd5b50610291610657366004611de3565b610c90565b34801561066857600080fd5b50610291610677366004611e0f565b60136020526000908152604090205460ff1681565b34801561069857600080fd5b506103406106a7366004611e2c565b610c9e565b3480156106b857600080fd5b506102916106c7366004611e0f565b600d6020526000908152604090205460ff1681565b3480156106e857600080fd5b506103406106f7366004611e0f565b610cb8565b34801561070857600080fd5b50610353610717366004611eef565b610d83565b34801561072857600080fd5b50610353600a5481565b34801561073e57600080fd5b5061029161074d366004611eef565b610dae565b34801561075e57600080fd5b5061034061076d366004611e0f565b610e1b565b34801561077e57600080fd5b50610340610ee4565b34801561079357600080fd5b506103406107a2366004611e2c565b610efb565b3480156107b357600080fd5b506103406107c2366004611e0f565b610f08565b3480156107d357600080fd5b506103406107e2366004611e0f565b610f7e565b3480156107f357600080fd5b506103406110ff565b60606003805461080b90611f1d565b80601f016020809104026020016040519081016040528092919081815260200182805461083790611f1d565b80156108845780601f1061085957610100808354040283529160200191610884565b820191906000526020600020905b81548152906001019060200180831161086757829003601f168201915b5050505050905090565b60003361089c818585611169565b5060019392505050565b6108ae61128e565b6001600160a01b0381166000908152600c602052604090205460ff1661091b5760405162461bcd60e51b815260206004820152601860248201527f4163636f756e7420616c726561647920696e636c75646564000000000000000060448201526064015b60405180910390fd5b6001600160a01b03166000908152600c60205260409020805460ff19169055565b61094461128e565b6001811161097e5760405162461bcd60e51b8152602060048201526007602482015266746f6f206c6f7760c81b6044820152606401610912565b600a8111156109ba5760405162461bcd60e51b81526020600482015260086024820152670e8dede40d0d2ced60c31b6044820152606401610912565b600755565b6000336109cd8582856112e8565b6109d885858561135c565b506001949350505050565b60003361089c8185856109f68383610d83565b610a009190611f6d565b611169565b610a0f3382611687565b50565b610a1a61128e565b600f821115610a6b5760405162461bcd60e51b815260206004820152601a60248201527f46656573206d757374206265206c657373207468616e203130250000000000006044820152606401610912565b600f811115610abc5760405162461bcd60e51b815260206004820152601a60248201527f46656573206d757374206265206c657373207468616e203130250000000000006044820152606401610912565b600e829055600f81905560408051838152602081018390527f5c6323bf1c2d7aaea2c091a4751c1c87af7f2864650c336507a77d0557af37a1910160405180910390a15050565b610b0b61128e565b610b1560006117d2565b565b610b228233836112e8565b610b2c8282611687565b5050565b60606004805461080b90611f1d565b610b4761128e565b6009546001600160a01b0390811690831603610bcb5760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610912565b610b2c8282611824565b610bdd61128e565b601255565b610bea61128e565b6001600160a01b03919091166000908152601360205260409020805460ff1916911515919091179055565b60003381610c238286610d83565b905083811015610c835760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610912565b6109d88286868403611169565b60003361089c81858561135c565b610ca661128e565b60008111610cb357600080fd5b600a55565b610cc061128e565b6006546001600160a01b0390811690821603610d2f5760405162461bcd60e51b815260206004820152602860248201527f4d61726b6574696e672077616c6c657420697320616c72656164792074686174604482015267206164647265737360c01b6064820152608401610912565b600680546001600160a01b0319166001600160a01b0383169081179091556040519081527fa964ba5c52d7e7bfcae4fb1ae4db9f211756d0e618e85fac5283b882a39e7a0b9060200160405180910390a150565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6000610dc26005546001600160a01b031690565b6001600160a01b0316836001600160a01b03161480610dee57506005546001600160a01b038381169116145b80610e0157506001600160a01b03831630145b80610e1457506001600160a01b03821630145b9392505050565b610e2361128e565b6001600160a01b0381166000908152600c602052604090205460ff1615610e985760405162461bcd60e51b8152602060048201526024808201527f4163636f756e7420697320616c7265616479207468652076616c7565206f66206044820152637472756560e01b6064820152608401610912565b6001600160a01b0381166000818152600c6020526040808220805460ff19166001179055517f57a00f76b5f242fb1e04b0b514a6974665a5b07bce45e39f36dabff4a042d9369190a250565b610eec61128e565b6010805460ff19166001179055565b610f0361128e565b601155565b610f1061128e565b6001600160a01b038116610f755760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610912565b610a0f816117d2565b610f8661128e565b306001600160a01b03821603610fde5760405162461bcd60e51b815260206004820181905260248201527f4f776e65722063616e6e6f7420636c61696d206e617469766520746f6b656e736044820152606401610912565b6001600160a01b0381166110185760405133904780156108fc02916000818181858888f19350505050158015610b2c573d6000803e3d6000fd5b6040516370a0823160e01b815230600482015281906000906001600160a01b038316906370a0823190602401602060405180830381865afa158015611061573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110859190611f85565b60405163a9059cbb60e01b8152336004820152602481018290529091506001600160a01b0383169063a9059cbb906044016020604051808303816000875af11580156110d5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110f99190611f9e565b50505050565b61110761128e565b600b5460ff161561115a5760405162461bcd60e51b815260206004820152601860248201527f54726164696e6720697320616c7265616479206f70656e2100000000000000006044820152606401610912565b600b805460ff19166001179055565b6001600160a01b0383166111cb5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610912565b6001600160a01b03821661122c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610912565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6005546001600160a01b03163314610b155760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610912565b60006112f48484610d83565b905060001981146110f9578181101561134f5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610912565b6110f98484848403611169565b6001600160a01b0383166113825760405162461bcd60e51b815260040161091290611fbb565b6001600160a01b0382166113a85760405162461bcd60e51b815260040161091290612000565b600954600160a01b900460ff166113c4576113c483838361190e565b600f54600e546001600160a01b03851660009081526013602052604090205460ff1615801561140c57506001600160a01b03841660009081526013602052604090205460ff16155b1561145757600b5460ff166114575760405162461bcd60e51b81526020600482015260116024820152702a3930b2329034b9903737ba1037b832b760791b6044820152606401610912565b82600003611466575050505050565b6009546001600160a01b0386166000908152600c602052604090205460ff600160a01b9092048216159116806114b457506001600160a01b0385166000908152600c602052604090205460ff165b156114bd575060005b3060009081526020819052604081205490506000600a5482101580156114e35750600082115b801561150857506001600160a01b0388166000908152600d602052604090205460ff16155b80156115115750825b905080801561152a5750600954600160a01b900460ff16155b156115b2576009805460ff60a01b198116600160a01b179091556001600160a01b031660009081526020819052604090205460075460649061156c9083612043565b6115769190612062565b83111561159a5760646007548261158d9190612043565b6115979190612062565b92505b6115a383611961565b506009805460ff60a01b191690555b8280156115cc57506009546001600160a01b038881169116145b80156115d85750600084115b1561161457600060646115eb8689612043565b6115f59190612062565b90506116018188612084565b965061160e893083611aee565b50611672565b82801561162e57506009546001600160a01b038981169116145b801561163a5750600085115b15611672576000606461164d8789612043565b6116579190612062565b90506116638188612084565b9650611670893083611aee565b505b61167d888888611aee565b5050505050505050565b6001600160a01b0382166116e75760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610912565b6001600160a01b0382166000908152602081905260409020548181101561175b5760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b6064820152608401610912565b6001600160a01b038316600090815260208190526040812083830390556002805484929061178a908490612084565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90602001611281565b505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b0382166000908152600d602052604090205481151560ff9091161515036118ba5760405162461bcd60e51b815260206004820152603860248201527f4175746f6d61746564206d61726b6574206d616b65722070616972206973206160448201527f6c72656164792073657420746f20746861742076616c756500000000000000006064820152608401610912565b6001600160a01b0382166000818152600d6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b60105460ff166117cd576119228383610dae565b15801561194857506001600160a01b03821660009081526013602052604090205460ff16155b156117cd576119578282611c42565b6117cd8282611c89565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106119965761199661209b565b6001600160a01b03928316602091820292909201810191909152600854604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa1580156119ef573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a1391906120b1565b81600181518110611a2657611a2661209b565b6001600160a01b03928316602091820292909201015260085460405163791ac94760e01b815291169063791ac94790611a6c9085906000908690309042906004016120ce565b600060405180830381600087803b158015611a8657600080fd5b505af1925050508015611a97575060015b506006544790611ab0906001600160a01b031682611d1e565b60408051848152602081018390527f957ad1fc6d4d41da6d1a8d37303289ef3c4b78e0285ff5df1e12070ef0e62999910160405180910390a1505050565b6001600160a01b038316611b145760405162461bcd60e51b815260040161091290611fbb565b6001600160a01b038216611b3a5760405162461bcd60e51b815260040161091290612000565b6001600160a01b03831660009081526020819052604090205481811015611bb25760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610912565b6001600160a01b03808516600090815260208190526040808220858503905591851681529081208054849290611be9908490611f6d565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611c3591815260200190565b60405180910390a36110f9565b601154811115610b2c5760405162461bcd60e51b8152602060048201526012602482015271082dadeeadce840caf0c6cacac8e640dac2f60731b6044820152606401610912565b6009546001600160a01b0390811690831603611ca3575050565b60125481611cc6846001600160a01b031660009081526020819052604090205490565b611cd09190611f6d565b1115610b2c5760405162461bcd60e51b815260206004820152601860248201527f4d617820686f6c64696e67206578636565646564206d617800000000000000006044820152606401610912565b816001600160a01b03166108fc82604051600060405180830381858888f193505050503d8060008114611d6d576040519150601f19603f3d011682016040523d82523d6000602084013e611d72565b606091505b5050505050565b600060208083528351808285015260005b81811015611da657858101830151858201604001528201611d8a565b81811115611db8576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610a0f57600080fd5b60008060408385031215611df657600080fd5b8235611e0181611dce565b946020939093013593505050565b600060208284031215611e2157600080fd5b8135610e1481611dce565b600060208284031215611e3e57600080fd5b5035919050565b600080600060608486031215611e5a57600080fd5b8335611e6581611dce565b92506020840135611e7581611dce565b929592945050506040919091013590565b60008060408385031215611e9957600080fd5b50508035926020909101359150565b8015158114610a0f57600080fd5b60008060408385031215611ec957600080fd5b8235611ed481611dce565b91506020830135611ee481611ea8565b809150509250929050565b60008060408385031215611f0257600080fd5b8235611f0d81611dce565b91506020830135611ee481611dce565b600181811c90821680611f3157607f821691505b602082108103611f5157634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b60008219821115611f8057611f80611f57565b500190565b600060208284031215611f9757600080fd5b5051919050565b600060208284031215611fb057600080fd5b8151610e1481611ea8565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600081600019048311821515161561205d5761205d611f57565b500290565b60008261207f57634e487b7160e01b600052601260045260246000fd5b500490565b60008282101561209657612096611f57565b500390565b634e487b7160e01b600052603260045260246000fd5b6000602082840312156120c357600080fd5b8151610e1481611dce565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b8181101561211e5784516001600160a01b0316835293830193918301916001016120f9565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220b76ec17a4106ec8d507f777fe40a2a0d9de75710cd0e2f55e2e0f706d026c98a64736f6c634300080f0033

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

0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d000000000000000000000000ad94cb131be6969cb0db9e154f50857fea5616c2

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

-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d
Arg [1] : 000000000000000000000000ad94cb131be6969cb0db9e154f50857fea5616c2


Deployed Bytecode Sourcemap

31052:9326:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31560:28;;;;;;;;;;-1:-1:-1;31560:28:0;;;;;;;;;;;179:14:1;;172:22;154:41;;142:2;127:18;31560:28:0;;;;;;;;7336:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;9694:201::-;;;;;;;;;;-1:-1:-1;9694:201:0;;;;;:::i;:::-;;:::i;31240:41::-;;;;;;;;;;-1:-1:-1;31240:41:0;;;;-1:-1:-1;;;;;31240:41:0;;;;;;-1:-1:-1;;;;;1455:32:1;;;1437:51;;1425:2;1410:18;31240:41:0;1264:230:1;35147:190:0;;;;;;;;;;-1:-1:-1;35147:190:0;;;;;:::i;:::-;;:::i;:::-;;8459:108;;;;;;;;;;-1:-1:-1;8547:12:0;;8459:108;;;1897:25:1;;;1885:2;1870:18;8459:108:0;1751:177:1;38721:205:0;;;;;;;;;;-1:-1:-1;38721:205:0;;;;;:::i;:::-;;:::i;10476:295::-;;;;;;;;;;-1:-1:-1;10476:295:0;;;;;:::i;:::-;;:::i;32142:22::-;;;;;;;;;;;;;;;;8300:93;;;;;;;;;;-1:-1:-1;8300:93:0;;8383:2;2721:36:1;;2709:2;2694:18;8300:93:0;2579:184:1;32291:25:0;;;;;;;;;;;;;;;;11181:238;;;;;;;;;;-1:-1:-1;11181:238:0;;;;;:::i;:::-;;:::i;18581:91::-;;;;;;;;;;-1:-1:-1;18581:91:0;;;;;:::i;:::-;;:::i;32205:46::-;;;;;;;;;;-1:-1:-1;32205:46:0;;;;;;;;32171:21;;;;;;;;;;;;;;;;31288:29;;;;;;;;;;-1:-1:-1;31288:29:0;;;;-1:-1:-1;;;;;31288:29:0;;;35346:126;;;;;;;;;;-1:-1:-1;35346:126:0;;;;;:::i;:::-;-1:-1:-1;;;;;35436:28:0;35412:4;35436:28;;;:19;:28;;;;;;;;;35346:126;35481:312;;;;;;;;;;-1:-1:-1;35481:312:0;;;;;:::i;:::-;;:::i;8631:127::-;;;;;;;;;;-1:-1:-1;8631:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;8732:18:0;8705:7;8732:18;;;;;;;;;;;;8631:127;20898:103;;;;;;;;;;;;;:::i;31161:30::-;;;;;;;;;;-1:-1:-1;31161:30:0;;;;-1:-1:-1;;;;;31161:30:0;;;18992:164;;;;;;;;;;-1:-1:-1;18992:164:0;;;;;:::i;:::-;;:::i;32258:26::-;;;;;;;;;;;;;;;;20248:87;;;;;;;;;;-1:-1:-1;20321:6:0;;-1:-1:-1;;;;;20321:6:0;20248:87;;7556:104;;;;;;;;;;;;;:::i;34282:245::-;;;;;;;;;;-1:-1:-1;34282:245:0;;;;;:::i;:::-;;:::i;40157:106::-;;;;;;;;;;-1:-1:-1;40157:106:0;;;;;:::i;:::-;;:::i;31198:35::-;;;;;;;;;;;;;;;;40272:103;;;;;;;;;;-1:-1:-1;40272:103:0;;;;;:::i;:::-;;:::i;11923:437::-;;;;;;;;;;-1:-1:-1;11923:437:0;;;;;:::i;:::-;;:::i;8965:193::-;;;;;;;;;;-1:-1:-1;8965:193:0;;;;;:::i;:::-;;:::i;32323:40::-;;;;;;;;;;-1:-1:-1;32323:40:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;38561:151;;;;;;;;;;-1:-1:-1;38561:151:0;;;;;:::i;:::-;;:::i;31657:57::-;;;;;;;;;;-1:-1:-1;31657:57:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;35802:283;;;;;;;;;;-1:-1:-1;35802:283:0;;;;;:::i;:::-;;:::i;9222:151::-;;;;;;;;;;-1:-1:-1;9222:151:0;;;;;:::i;:::-;;:::i;31520:33::-;;;;;;;;;;;;;;;;39707:191;;;;;;;;;;-1:-1:-1;39707:191:0;;;;;:::i;:::-;;:::i;34891:247::-;;;;;;;;;;-1:-1:-1;34891:247:0;;;;;:::i;:::-;;:::i;39907:122::-;;;;;;;;;;;;;:::i;40038:110::-;;;;;;;;;;-1:-1:-1;40038:110:0;;;;;:::i;:::-;;:::i;21157:201::-;;;;;;;;;;-1:-1:-1;21157:201:0;;;;;:::i;:::-;;:::i;33686:441::-;;;;;;;;;;-1:-1:-1;33686:441:0;;;;;:::i;:::-;;:::i;33524:153::-;;;;;;;;;;;;;:::i;7336:100::-;7390:13;7423:5;7416:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7336:100;:::o;9694:201::-;9777:4;5165:10;9833:32;5165:10;9849:7;9858:6;9833:8;:32::i;:::-;-1:-1:-1;9883:4:0;;9694:201;-1:-1:-1;;;9694:201:0:o;35147:190::-;20133:13;:11;:13::i;:::-;-1:-1:-1;;;;;35225:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;::::1;;35217:65;;;::::0;-1:-1:-1;;;35217:65:0;;4719:2:1;35217:65:0::1;::::0;::::1;4701:21:1::0;4758:2;4738:18;;;4731:30;4797:26;4777:18;;;4770:54;4841:18;;35217:65:0::1;;;;;;;;;-1:-1:-1::0;;;;;35293:28:0::1;35324:5;35293:28:::0;;;:19:::1;:28;::::0;;;;:36;;-1:-1:-1;;35293:36:0::1;::::0;;35147:190::o;38721:205::-;20133:13;:11;:13::i;:::-;38819:1:::1;38807:9;:13;38799:33;;;::::0;-1:-1:-1;;;38799:33:0;;5072:2:1;38799:33:0::1;::::0;::::1;5054:21:1::0;5111:1;5091:18;;;5084:29;-1:-1:-1;;;5129:18:1;;;5122:37;5176:18;;38799:33:0::1;4870:330:1::0;38799:33:0::1;38864:2;38851:9;:15;;38843:36;;;::::0;-1:-1:-1;;;38843:36:0;;5407:2:1;38843:36:0::1;::::0;::::1;5389:21:1::0;5446:1;5426:18;;;5419:29;-1:-1:-1;;;5464:18:1;;;5457:38;5512:18;;38843:36:0::1;5205:331:1::0;38843:36:0::1;38890:16;:28:::0;38721:205::o;10476:295::-;10607:4;5165:10;10665:38;10681:4;5165:10;10696:6;10665:15;:38::i;:::-;10714:27;10724:4;10730:2;10734:6;10714:9;:27::i;:::-;-1:-1:-1;10759:4:0;;10476:295;-1:-1:-1;;;;10476:295:0:o;11181:238::-;11269:4;5165:10;11325:64;5165:10;11341:7;11378:10;11350:25;5165:10;11341:7;11350:9;:25::i;:::-;:38;;;;:::i;:::-;11325:8;:64::i;18581:91::-;18637:27;5165:10;18657:6;18637:5;:27::i;:::-;18581:91;:::o;35481:312::-;20133:13;:11;:13::i;:::-;35586:2:::1;35574:8;:14;;35566:53;;;::::0;-1:-1:-1;;;35566:53:0;;6008:2:1;35566:53:0::1;::::0;::::1;5990:21:1::0;6047:2;6027:18;;;6020:30;6086:28;6066:18;;;6059:56;6132:18;;35566:53:0::1;5806:350:1::0;35566:53:0::1;35649:2;35638:7;:13;;35630:52;;;::::0;-1:-1:-1;;;35630:52:0;;6008:2:1;35630:52:0::1;::::0;::::1;5990:21:1::0;6047:2;6027:18;;;6020:30;6086:28;6066:18;;;6059:56;6132:18;;35630:52:0::1;5806:350:1::0;35630:52:0::1;35693:7;:18:::0;;;35722:6:::1;:16:::0;;;35757:28:::1;::::0;;6335:25:1;;;6391:2;6376:18;;6369:34;;;35757:28:0::1;::::0;6308:18:1;35757:28:0::1;;;;;;;35481:312:::0;;:::o;20898:103::-;20133:13;:11;:13::i;:::-;20963:30:::1;20990:1;20963:18;:30::i;:::-;20898:103::o:0;18992:164::-;19069:46;19085:7;5165:10;19108:6;19069:15;:46::i;:::-;19126:22;19132:7;19141:6;19126:5;:22::i;:::-;18992:164;;:::o;7556:104::-;7612:13;7645:7;7638:14;;;;;:::i;34282:245::-;20133:13;:11;:13::i;:::-;34389::::1;::::0;-1:-1:-1;;;;;34389:13:0;;::::1;34381:21:::0;;::::1;::::0;34373:91:::1;;;::::0;-1:-1:-1;;;34373:91:0;;6616:2:1;34373:91:0::1;::::0;::::1;6598:21:1::0;6655:2;6635:18;;;6628:30;6694:34;6674:18;;;6667:62;6765:27;6745:18;;;6738:55;6810:19;;34373:91:0::1;6414:421:1::0;34373:91:0::1;34478:41;34507:4;34513:5;34478:28;:41::i;40157:106::-:0;20133:13;:11;:13::i;:::-;40231:10:::1;:24:::0;40157:106::o;40272:103::-;20133:13;:11;:13::i;:::-;-1:-1:-1;;;;;40345:13:0;;;::::1;;::::0;;;:8:::1;:13;::::0;;;;:22;;-1:-1:-1;;40345:22:0::1;::::0;::::1;;::::0;;;::::1;::::0;;40272:103::o;11923:437::-;12016:4;5165:10;12016:4;12099:25;5165:10;12116:7;12099:9;:25::i;:::-;12072:52;;12163:15;12143:16;:35;;12135:85;;;;-1:-1:-1;;;12135:85:0;;7042:2:1;12135:85:0;;;7024:21:1;7081:2;7061:18;;;7054:30;7120:34;7100:18;;;7093:62;-1:-1:-1;;;7171:18:1;;;7164:35;7216:19;;12135:85:0;6840:401:1;12135:85:0;12256:60;12265:5;12272:7;12300:15;12281:16;:34;12256:8;:60::i;8965:193::-;9044:4;5165:10;9100:28;5165:10;9117:2;9121:6;9100:9;:28::i;38561:151::-;20133:13;:11;:13::i;:::-;38661:1:::1;38649:9;:13;38641:22;;;::::0;::::1;;38674:18;:30:::0;38561:151::o;35802:283::-;20133:13;:11;:13::i;:::-;35917:15:::1;::::0;-1:-1:-1;;;;;35917:15:0;;::::1;35897:35:::0;;::::1;::::0;35889:88:::1;;;::::0;-1:-1:-1;;;35889:88:0;;7448:2:1;35889:88:0::1;::::0;::::1;7430:21:1::0;7487:2;7467:18;;;7460:30;7526:34;7506:18;;;7499:62;-1:-1:-1;;;7577:18:1;;;7570:38;7625:19;;35889:88:0::1;7246:404:1::0;35889:88:0::1;35988:15;:34:::0;;-1:-1:-1;;;;;;35988:34:0::1;-1:-1:-1::0;;;;;35988:34:0;::::1;::::0;;::::1;::::0;;;36038:39:::1;::::0;1437:51:1;;;36038:39:0::1;::::0;1425:2:1;1410:18;36038:39:0::1;;;;;;;35802:283:::0;:::o;9222:151::-;-1:-1:-1;;;;;9338:18:0;;;9311:7;9338:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9222:151::o;39707:191::-;39782:4;39817:7;20321:6;;-1:-1:-1;;;;;20321:6:0;;20248:87;39817:7;-1:-1:-1;;;;;39809:15:0;:4;-1:-1:-1;;;;;39809:15:0;;:32;;;-1:-1:-1;20321:6:0;;-1:-1:-1;;;;;39828:13:0;;;20321:6;;39828:13;39809:32;:57;;;-1:-1:-1;;;;;;39845:21:0;;39861:4;39845:21;39809:57;:80;;;-1:-1:-1;;;;;;39870:19:0;;39884:4;39870:19;39809:80;39801:89;39707:191;-1:-1:-1;;;39707:191:0:o;34891:247::-;20133:13;:11;:13::i;:::-;-1:-1:-1;;;;;34972:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;::::1;;34971:29;34963:78;;;::::0;-1:-1:-1;;;34963:78:0;;7857:2:1;34963:78:0::1;::::0;::::1;7839:21:1::0;7896:2;7876:18;;;7869:30;7935:34;7915:18;;;7908:62;-1:-1:-1;;;7986:18:1;;;7979:34;8030:19;;34963:78:0::1;7655:400:1::0;34963:78:0::1;-1:-1:-1::0;;;;;35052:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;:35;;-1:-1:-1;;35052:35:0::1;35083:4;35052:35;::::0;;35106:24;::::1;::::0;35052:28;35106:24:::1;34891:247:::0;:::o;39907:122::-;20133:13;:11;:13::i;:::-;39980:34:::1;:41:::0;;-1:-1:-1;;39980:41:0::1;40017:4;39980:41;::::0;;39907:122::o;40038:110::-;20133:13;:11;:13::i;:::-;40114:11:::1;:26:::0;40038:110::o;21157:201::-;20133:13;:11;:13::i;:::-;-1:-1:-1;;;;;21246:22:0;::::1;21238:73;;;::::0;-1:-1:-1;;;21238:73:0;;8262:2:1;21238:73:0::1;::::0;::::1;8244:21:1::0;8301:2;8281:18;;;8274:30;8340:34;8320:18;;;8313:62;-1:-1:-1;;;8391:18:1;;;8384:36;8437:19;;21238:73:0::1;8060:402:1::0;21238:73:0::1;21322:28;21341:8;21322:18;:28::i;33686:441::-:0;20133:13;:11;:13::i;:::-;33782:4:::1;-1:-1:-1::0;;;;;33765:22:0;::::1;::::0;33757:67:::1;;;::::0;-1:-1:-1;;;33757:67:0;;8669:2:1;33757:67:0::1;::::0;::::1;8651:21:1::0;;;8688:18;;;8681:30;8747:34;8727:18;;;8720:62;8799:18;;33757:67:0::1;8467:356:1::0;33757:67:0::1;-1:-1:-1::0;;;;;33839:21:0;::::1;33835:126;;33877:51;::::0;33885:10:::1;::::0;33906:21:::1;33877:51:::0;::::1;;;::::0;::::1;::::0;;;33906:21;33885:10;33877:51;::::1;;;;;;;;;;;;;::::0;::::1;;;;33835:126;34033:35;::::0;-1:-1:-1;;;34033:35:0;;34062:4:::1;34033:35;::::0;::::1;1437:51:1::0;33998:5:0;;33971:17:::1;::::0;-1:-1:-1;;;;;34033:20:0;::::1;::::0;::::1;::::0;1410:18:1;;34033:35:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;34079:40;::::0;-1:-1:-1;;;34079:40:0;;34099:10:::1;34079:40;::::0;::::1;9191:51:1::0;9258:18;;;9251:34;;;34015:53:0;;-1:-1:-1;;;;;;34079:19:0;::::1;::::0;::::1;::::0;9164:18:1;;34079:40:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;33746:381;;33686:441:::0;:::o;33524:153::-;20133:13;:11;:13::i;:::-;33581:16:::1;::::0;::::1;;:25;33573:62;;;::::0;-1:-1:-1;;;33573:62:0;;9748:2:1;33573:62:0::1;::::0;::::1;9730:21:1::0;9787:2;9767:18;;;9760:30;9826:26;9806:18;;;9799:54;9870:18;;33573:62:0::1;9546:348:1::0;33573:62:0::1;33646:16;:23:::0;;-1:-1:-1;;33646:23:0::1;33665:4;33646:23;::::0;;33524:153::o;15564:381::-;-1:-1:-1;;;;;15700:19:0;;15692:68;;;;-1:-1:-1;;;15692:68:0;;10101:2:1;15692:68:0;;;10083:21:1;10140:2;10120:18;;;10113:30;10179:34;10159:18;;;10152:62;-1:-1:-1;;;10230:18:1;;;10223:34;10274:19;;15692:68:0;9899:400:1;15692:68:0;-1:-1:-1;;;;;15779:21:0;;15771:68;;;;-1:-1:-1;;;15771:68:0;;10506:2:1;15771:68:0;;;10488:21:1;10545:2;10525:18;;;10518:30;10584:34;10564:18;;;10557:62;-1:-1:-1;;;10635:18:1;;;10628:32;10677:19;;15771:68:0;10304:398:1;15771:68:0;-1:-1:-1;;;;;15853:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15905:32;;1897:25:1;;;15905:32:0;;1870:18:1;15905:32:0;;;;;;;;15564:381;;;:::o;20414:132::-;20321:6;;-1:-1:-1;;;;;20321:6:0;5165:10;20478:23;20470:68;;;;-1:-1:-1;;;20470:68:0;;10909:2:1;20470:68:0;;;10891:21:1;;;10928:18;;;10921:30;10987:34;10967:18;;;10960:62;11039:18;;20470:68:0;10707:356:1;16237:453:0;16372:24;16399:25;16409:5;16416:7;16399:9;:25::i;:::-;16372:52;;-1:-1:-1;;16439:16:0;:37;16435:248;;16521:6;16501:16;:26;;16493:68;;;;-1:-1:-1;;;16493:68:0;;11270:2:1;16493:68:0;;;11252:21:1;11309:2;11289:18;;;11282:30;11348:31;11328:18;;;11321:59;11397:18;;16493:68:0;11068:353:1;16493:68:0;16605:51;16614:5;16621:7;16649:6;16630:16;:25;16605:8;:51::i;36094:1812::-;-1:-1:-1;;;;;36226:18:0;;36218:68;;;;-1:-1:-1;;;36218:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;36305:16:0;;36297:64;;;;-1:-1:-1;;;36297:64:0;;;;;;;:::i;:::-;36380:8;;-1:-1:-1;;;36380:8:0;;;;36375:66;;36405:24;36412:4;36418:2;36422:6;36405;:24::i;:::-;36469:6;;36502:7;;-1:-1:-1;;;;;36528:14:0;;36454:12;36528:14;;;:8;:14;;;;;;;;36527:15;:32;;;;-1:-1:-1;;;;;;36547:12:0;;;;;;:8;:12;;;;;;;;36546:13;36527:32;36523:111;;;36584:16;;;;36576:46;;;;-1:-1:-1;;;36576:46:0;;12438:2:1;36576:46:0;;;12420:21:1;12477:2;12457:18;;;12450:30;-1:-1:-1;;;12496:18:1;;;12489:47;12553:18;;36576:46:0;12236:341:1;36576:46:0;36651:6;36661:1;36651:11;36647:50;;36679:7;;36094:1812;;;:::o;36647:50::-;36726:8;;-1:-1:-1;;;;;36752:25:0;;36710:12;36752:25;;;:19;:25;;;;;;36726:8;-1:-1:-1;;;36726:8:0;;;;;36725:9;;36752:25;;:52;;-1:-1:-1;;;;;;36781:23:0;;;;;;:19;:23;;;;;;;;36752:52;36748:100;;;-1:-1:-1;36831:5:0;36748:100;36896:4;36861:14;8732:18;;;;;;;;;;;36861:41;;36916:12;36941:18;;36931:6;:28;;:42;;;;;36972:1;36963:6;:10;36931:42;:78;;;;-1:-1:-1;;;;;;36978:31:0;;;;;;:25;:31;;;;;;;;36977:32;36931:78;:89;;;;;37013:7;36931:89;36916:104;;37035:7;:33;;;;-1:-1:-1;37060:8:0;;-1:-1:-1;;;37060:8:0;;;;37059:9;37035:33;37031:361;;;37085:8;:15;;-1:-1:-1;;;;37085:15:0;;-1:-1:-1;;;37085:15:0;;;;-1:-1:-1;;;;;37147:13:0;-1:-1:-1;8732:18:0;;;;;;;;;;;37203:16;;37222:3;;37189:30;;8732:18;37189:30;:::i;:::-;:36;;;;:::i;:::-;37180:6;:45;37176:131;;;37288:3;37269:16;;37255:11;:30;;;;:::i;:::-;:36;;;;:::i;:::-;37246:45;;37176:131;37321:28;37342:6;37321:20;:28::i;:::-;-1:-1:-1;37364:8:0;:16;;-1:-1:-1;;;;37364:16:0;;;37031:361;37409:7;:30;;;;-1:-1:-1;37426:13:0;;-1:-1:-1;;;;;37420:19:0;;;37426:13;;37420:19;37409:30;:46;;;;;37454:1;37443:8;:12;37409:46;37405:447;;;37472:12;37509:3;37488:17;37497:8;37488:6;:17;:::i;:::-;37487:25;;;;:::i;:::-;37472:40;-1:-1:-1;37536:13:0;37472:40;37536:6;:13;:::i;:::-;37527:22;;37567:42;37583:4;37597;37604;37567:15;:42::i;:::-;37457:164;37405:447;;;37640:7;:32;;;;-1:-1:-1;37659:13:0;;-1:-1:-1;;;;;37651:21:0;;;37659:13;;37651:21;37640:32;:47;;;;;37686:1;37676:7;:11;37640:47;37636:216;;;37704:12;37740:3;37720:16;37729:7;37720:6;:16;:::i;:::-;37719:24;;;;:::i;:::-;37704:39;-1:-1:-1;37767:13:0;37704:39;37767:6;:13;:::i;:::-;37758:22;;37798:42;37814:4;37828;37835;37798:15;:42::i;:::-;37689:163;37636:216;37865:33;37881:4;37887:2;37891:6;37865:15;:33::i;:::-;36207:1699;;;;;36094:1812;;;:::o;14530:595::-;-1:-1:-1;;;;;14614:21:0;;14606:67;;;;-1:-1:-1;;;14606:67:0;;13309:2:1;14606:67:0;;;13291:21:1;13348:2;13328:18;;;13321:30;13387:34;13367:18;;;13360:62;-1:-1:-1;;;13438:18:1;;;13431:31;13479:19;;14606:67:0;13107:397:1;14606:67:0;-1:-1:-1;;;;;14775:18:0;;14750:22;14775:18;;;;;;;;;;;14812:24;;;;14804:71;;;;-1:-1:-1;;;14804:71:0;;13711:2:1;14804:71:0;;;13693:21:1;13750:2;13730:18;;;13723:30;13789:34;13769:18;;;13762:62;-1:-1:-1;;;13840:18:1;;;13833:32;13882:19;;14804:71:0;13509:398:1;14804:71:0;-1:-1:-1;;;;;14911:18:0;;:9;:18;;;;;;;;;;14932:23;;;14911:44;;14977:12;:22;;14949:6;;14911:9;14977:22;;14949:6;;14977:22;:::i;:::-;;;;-1:-1:-1;;15018:37:0;;1897:25:1;;;15044:1:0;;-1:-1:-1;;;;;15018:37:0;;;;;1885:2:1;1870:18;15018:37:0;1751:177:1;15069:48:0;14595:530;14530:595;;:::o;21519:191::-;21612:6;;;-1:-1:-1;;;;;21629:17:0;;;-1:-1:-1;;;;;;21629:17:0;;;;;;;21662:40;;21612:6;;;21629:17;21612:6;;21662:40;;21593:16;;21662:40;21582:128;21519:191;:::o;34536:309::-;-1:-1:-1;;;;;34627:31:0;;;;;;:25;:31;;;;;;:40;;;:31;;;;:40;;;34619:109;;;;-1:-1:-1;;;34619:109:0;;14114:2:1;34619:109:0;;;14096:21:1;14153:2;14133:18;;;14126:30;14192:34;14172:18;;;14165:62;14263:26;14243:18;;;14236:54;14307:19;;34619:109:0;13912:420:1;34619:109:0;-1:-1:-1;;;;;34739:31:0;;;;;;:25;:31;;;;;;:39;;-1:-1:-1;;34739:39:0;;;;;;;;;;34797:40;;34739:39;;:31;34797:40;;;34536:309;;:::o;38935:363::-;39055:34;;;;39050:241;;39114:28;39133:4;39139:2;39114:18;:28::i;:::-;39113:29;:46;;;;-1:-1:-1;;;;;;39147:12:0;;;;;;:8;:12;;;;;;;;39146:13;39113:46;39109:171;;;39180:29;39198:2;39202:6;39180:17;:29::i;:::-;39231:33;39253:2;39257:6;39231:21;:33::i;37943:609::-;38040:16;;;38054:1;38040:16;;;;;;;;38016:21;;38040:16;;;;;;;;;;-1:-1:-1;38040:16:0;38016:40;;38085:4;38067;38072:1;38067:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;38067:23:0;;;:7;;;;;;;;;;:23;;;;38111:15;;:22;;;-1:-1:-1;;;38111:22:0;;;;:15;;;;;:20;;:22;;;;;38067:7;;38111:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;38101:4;38106:1;38101:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;38101:32:0;;;:7;;;;;;;;;:32;38151:15;;:187;;-1:-1:-1;;;38151:187:0;;:15;;;:66;;:187;;38232:11;;38151:15;;38275:4;;38302;;38322:15;;38151:187;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;38147:222;38451:15;;38403:21;;38435:45;;-1:-1:-1;;;;;38451:15:0;38403:21;38435:7;:45::i;:::-;38499;;;6335:25:1;;;6391:2;6376:18;;6369:34;;;38499:45:0;;6308:18:1;38499:45:0;;;;;;;38002:550;;37943:609;:::o;12831:675::-;-1:-1:-1;;;;;12962:18:0;;12954:68;;;;-1:-1:-1;;;12954:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;13041:16:0;;13033:64;;;;-1:-1:-1;;;13033:64:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;13185:15:0;;13163:19;13185:15;;;;;;;;;;;13219:21;;;;13211:72;;;;-1:-1:-1;;;13211:72:0;;16044:2:1;13211:72:0;;;16026:21:1;16083:2;16063:18;;;16056:30;16122:34;16102:18;;;16095:62;-1:-1:-1;;;16173:18:1;;;16166:36;16219:19;;13211:72:0;15842:402:1;13211:72:0;-1:-1:-1;;;;;13319:15:0;;;:9;:15;;;;;;;;;;;13337:20;;;13319:38;;13379:13;;;;;;;;:23;;13351:6;;13319:9;13379:23;;13351:6;;13379:23;:::i;:::-;;;;;;;;13436:2;-1:-1:-1;;;;;13421:26:0;13430:4;-1:-1:-1;;;;;13421:26:0;;13440:6;13421:26;;;;1897:25:1;;1885:2;1870:18;;1751:177;13421:26:0;;;;;;;;13461:37;14530:595;39307:143;39405:11;;39395:6;:21;;39387:52;;;;-1:-1:-1;;;39387:52:0;;16451:2:1;39387:52:0;;;16433:21:1;16490:2;16470:18;;;16463:30;-1:-1:-1;;;16509:18:1;;;16502:48;16567:18;;39387:52:0;16249:342:1;39459:239:0;39553:13;;-1:-1:-1;;;;;39553:13:0;;;39547:19;;;;39543:58;;39459:239;;:::o;39543:58::-;39648:10;;39638:6;39622:13;39632:2;-1:-1:-1;;;;;8732:18:0;8705:7;8732:18;;;;;;;;;;;;8631:127;39622:13;:22;;;;:::i;:::-;:36;;39614:73;;;;-1:-1:-1;;;39614:73:0;;16798:2:1;39614:73:0;;;16780:21:1;16837:2;16817:18;;;16810:30;16876:26;16856:18;;;16849:54;16920:18;;39614:73:0;16596:348:1;34136:137:0;34219:9;-1:-1:-1;;;;;34219:14:0;34240:4;34254:6;34219:46;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34136:137;;:::o;206:597:1:-;318:4;347:2;376;365:9;358:21;408:6;402:13;451:6;446:2;435:9;431:18;424:34;476:1;486:140;500:6;497:1;494:13;486:140;;;595:14;;;591:23;;585:30;561:17;;;580:2;557:26;550:66;515:10;;486:140;;;644:6;641:1;638:13;635:91;;;714:1;709:2;700:6;689:9;685:22;681:31;674:42;635:91;-1:-1:-1;787:2:1;766:15;-1:-1:-1;;762:29:1;747:45;;;;794:2;743:54;;206:597;-1:-1:-1;;;206:597:1:o;808:131::-;-1:-1:-1;;;;;883:31:1;;873:42;;863:70;;929:1;926;919:12;944:315;1012:6;1020;1073:2;1061:9;1052:7;1048:23;1044:32;1041:52;;;1089:1;1086;1079:12;1041:52;1128:9;1115:23;1147:31;1172:5;1147:31;:::i;:::-;1197:5;1249:2;1234:18;;;;1221:32;;-1:-1:-1;;;944:315:1:o;1499:247::-;1558:6;1611:2;1599:9;1590:7;1586:23;1582:32;1579:52;;;1627:1;1624;1617:12;1579:52;1666:9;1653:23;1685:31;1710:5;1685:31;:::i;1933:180::-;1992:6;2045:2;2033:9;2024:7;2020:23;2016:32;2013:52;;;2061:1;2058;2051:12;2013:52;-1:-1:-1;2084:23:1;;1933:180;-1:-1:-1;1933:180:1:o;2118:456::-;2195:6;2203;2211;2264:2;2252:9;2243:7;2239:23;2235:32;2232:52;;;2280:1;2277;2270:12;2232:52;2319:9;2306:23;2338:31;2363:5;2338:31;:::i;:::-;2388:5;-1:-1:-1;2445:2:1;2430:18;;2417:32;2458:33;2417:32;2458:33;:::i;:::-;2118:456;;2510:7;;-1:-1:-1;;;2564:2:1;2549:18;;;;2536:32;;2118:456::o;2976:248::-;3044:6;3052;3105:2;3093:9;3084:7;3080:23;3076:32;3073:52;;;3121:1;3118;3111:12;3073:52;-1:-1:-1;;3144:23:1;;;3214:2;3199:18;;;3186:32;;-1:-1:-1;2976:248:1:o;3229:118::-;3315:5;3308:13;3301:21;3294:5;3291:32;3281:60;;3337:1;3334;3327:12;3352:382;3417:6;3425;3478:2;3466:9;3457:7;3453:23;3449:32;3446:52;;;3494:1;3491;3484:12;3446:52;3533:9;3520:23;3552:31;3577:5;3552:31;:::i;:::-;3602:5;-1:-1:-1;3659:2:1;3644:18;;3631:32;3672:30;3631:32;3672:30;:::i;:::-;3721:7;3711:17;;;3352:382;;;;;:::o;3739:388::-;3807:6;3815;3868:2;3856:9;3847:7;3843:23;3839:32;3836:52;;;3884:1;3881;3874:12;3836:52;3923:9;3910:23;3942:31;3967:5;3942:31;:::i;:::-;3992:5;-1:-1:-1;4049:2:1;4034:18;;4021:32;4062:33;4021:32;4062:33;:::i;4132:380::-;4211:1;4207:12;;;;4254;;;4275:61;;4329:4;4321:6;4317:17;4307:27;;4275:61;4382:2;4374:6;4371:14;4351:18;4348:38;4345:161;;4428:10;4423:3;4419:20;4416:1;4409:31;4463:4;4460:1;4453:15;4491:4;4488:1;4481:15;4345:161;;4132:380;;;:::o;5541:127::-;5602:10;5597:3;5593:20;5590:1;5583:31;5633:4;5630:1;5623:15;5657:4;5654:1;5647:15;5673:128;5713:3;5744:1;5740:6;5737:1;5734:13;5731:39;;;5750:18;;:::i;:::-;-1:-1:-1;5786:9:1;;5673:128::o;8828:184::-;8898:6;8951:2;8939:9;8930:7;8926:23;8922:32;8919:52;;;8967:1;8964;8957:12;8919:52;-1:-1:-1;8990:16:1;;8828:184;-1:-1:-1;8828:184:1:o;9296:245::-;9363:6;9416:2;9404:9;9395:7;9391:23;9387:32;9384:52;;;9432:1;9429;9422:12;9384:52;9464:9;9458:16;9483:28;9505:5;9483:28;:::i;11426:401::-;11628:2;11610:21;;;11667:2;11647:18;;;11640:30;11706:34;11701:2;11686:18;;11679:62;-1:-1:-1;;;11772:2:1;11757:18;;11750:35;11817:3;11802:19;;11426:401::o;11832:399::-;12034:2;12016:21;;;12073:2;12053:18;;;12046:30;12112:34;12107:2;12092:18;;12085:62;-1:-1:-1;;;12178:2:1;12163:18;;12156:33;12221:3;12206:19;;11832:399::o;12582:168::-;12622:7;12688:1;12684;12680:6;12676:14;12673:1;12670:21;12665:1;12658:9;12651:17;12647:45;12644:71;;;12695:18;;:::i;:::-;-1:-1:-1;12735:9:1;;12582:168::o;12755:217::-;12795:1;12821;12811:132;;12865:10;12860:3;12856:20;12853:1;12846:31;12900:4;12897:1;12890:15;12928:4;12925:1;12918:15;12811:132;-1:-1:-1;12957:9:1;;12755:217::o;12977:125::-;13017:4;13045:1;13042;13039:8;13036:34;;;13050:18;;:::i;:::-;-1:-1:-1;13087:9:1;;12977:125::o;14469:127::-;14530:10;14525:3;14521:20;14518:1;14511:31;14561:4;14558:1;14551:15;14585:4;14582:1;14575:15;14601:251;14671:6;14724:2;14712:9;14703:7;14699:23;14695:32;14692:52;;;14740:1;14737;14730:12;14692:52;14772:9;14766:16;14791:31;14816:5;14791:31;:::i;14857:980::-;15119:4;15167:3;15156:9;15152:19;15198:6;15187:9;15180:25;15224:2;15262:6;15257:2;15246:9;15242:18;15235:34;15305:3;15300:2;15289:9;15285:18;15278:31;15329:6;15364;15358:13;15395:6;15387;15380:22;15433:3;15422:9;15418:19;15411:26;;15472:2;15464:6;15460:15;15446:29;;15493:1;15503:195;15517:6;15514:1;15511:13;15503:195;;;15582:13;;-1:-1:-1;;;;;15578:39:1;15566:52;;15673:15;;;;15638:12;;;;15614:1;15532:9;15503:195;;;-1:-1:-1;;;;;;;15754:32:1;;;;15749:2;15734:18;;15727:60;-1:-1:-1;;;15818:3:1;15803:19;15796:35;15715:3;14857:980;-1:-1:-1;;;14857:980:1:o

Swarm Source

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