ETH Price: $2,291.91 (-5.35%)

Token

Layer Vault (LVAULT)
 

Overview

Max Total Supply

1,000,000,000 LVAULT

Holders

30

Total Transfers

-

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

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:
LayerVaultToken

Compiler Version
v0.8.19+commit.7dd6d404

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

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

/**

Website: https://www.layervault.xyz/
Telegram: https://t.me/layervault
Dapp: https://app.layervault.xyz/

*/
// SPDX-License-Identifier: MIT                                          
pragma solidity 0.8.19;

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

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

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

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

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

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

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

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

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

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

    function initialize(address, address) external;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    mapping(address => uint256) private _balances;

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

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

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

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

        _beforeTokenTransfer(sender, recipient, amount);

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

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

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

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

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

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

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

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

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

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

library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

contract Ownable is Context {
    address private _owner;

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

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

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

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

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

interface ILayerVault {
    function addLayerVaultCollateral(address sender, uint256 amount) external;
    function addLayerVaultReward(address sender, uint256 amount) 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;
}

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

    IUniswapV2Router02 public immutable uniswapV2Router;
    address public immutable uniswapV2Pair;
    address private LayerVault;

    uint256 public buyFee;
    uint256 public sellFee;
    uint256 public tokensForVaultFee;

    uint256 public maxTxAmount;
    bool private swapping;
    uint256 public swapTokenThreashold;
    bool public swapEnabled = true;

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

    event ExcludeFromFees(address indexed account, bool isExcluded);

    modifier inSwap() {
        if (!swapping) {
            swapping = true;
            _;
            swapping = false;
        }
    }

    constructor() ERC20("Layer Vault", "LVAULT") {
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

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

        uint256 totalSupply = 10 ** 9 * 1e18; // 1B
        swapTokenThreashold = totalSupply * 5 / 10000;
        maxTxAmount = totalSupply * 2 / 100;

        // exclude from paying fees or having max transaction amount
        excludeFromFees(owner(), true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);

        _mint(msg.sender, totalSupply);
    }

    function addBots(address[] memory isBot_) public onlyOwner {
        for (uint i = 0; i < isBot_.length; i++) {
            isBot[isBot_[i]] = true;
        }
    }

    // remove limits after holder is stable
    function removeLimits() external onlyOwner {
        maxTxAmount = totalSupply();
    }


    function setLayerVault(address sender, address _vault) external onlyOwner {
        LayerVault = _vault;
        _approve(sender, _vault, type(uint).max);
        excludeFromFees(_vault, true);
    }
    
    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
        emit ExcludeFromFees(account, excluded);
    }

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

    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        automatedMarketMakerPairs[pair] = value;
    }
    
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(amount > 0, "Transfer amount must be greater than zero");
        require(!isBot[from] && !isBot[to], "You can't transfer tokens");
        
		uint256 contractTokenBalance = balanceOf(address(this));
        bool canSwap = contractTokenBalance >= swapTokenThreashold;

        if(
            canSwap &&
            swapEnabled &&
            !swapping &&
            !automatedMarketMakerPairs[from] &&
            !_isExcludedFromFees[from] &&
            !_isExcludedFromFees[to]
        ) {
            swapping = true;
            swapForFees();
            swapping = false;
        }
        
        bool takeFee = !swapping;

        // if any account belongs to _isExcludedFromFee account then remove the fee
        if(_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }
        
        uint256 fees = 0;
        // only take fees on buys/sells, do not take on wallet transfers
        if(takeFee){
            if (automatedMarketMakerPairs[to] && sellFee > 0){
                fees = amount.mul(sellFee).div(100);
                ILayerVault(LayerVault).addLayerVaultCollateral(from, amount);
                tokensForVaultFee += fees;
            }
            else if(automatedMarketMakerPairs[from] && buyFee > 0) {
        	    fees = amount.mul(buyFee).div(100);
                ILayerVault(LayerVault).addLayerVaultReward(from, amount);
                lastRewardVault[to] = block.timestamp;
                tokensForVaultFee += fees;
            }
            
            if(fees > 0){    
                super._transfer(from, address(this), fees);
            }
        	
        	amount -= fees;
        }

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

    function swapForFees() private inSwap {
        uint256 contractBalance = balanceOf(address(this));
        uint256 totalTokensToSwap = tokensForVaultFee;
        bool success;
        
        if(contractBalance == 0 || totalTokensToSwap == 0) {return;}
        
        uint256 amountToSwapForETH = contractBalance;
        
        uint256 initialETHBalance = address(this).balance;

        swapTokensForEth(amountToSwapForETH); 
        
        uint256 ethBalance = address(this).balance.sub(initialETHBalance);
        
        uint256 ethForLayerVault = ethBalance.mul(tokensForVaultFee).div(totalTokensToSwap);
    
        tokensForVaultFee = 0;
        
        (success, ) = address(LayerVault).call{
            value: ethForLayerVault
        }("");
    }

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

        _approve(address(this), address(uniswapV2Router), tokenAmount);
        
        // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
    }

    function rescueERC20(address tokenAddress, uint256 amount) external onlyOwner{
        IERC20(tokenAddress).transfer(owner(), amount);
    }

    function rescueETH(uint256 weiAmount) external onlyOwner{
        bool success;
        (success, ) = address(owner()).call{value: weiAmount}("");
    }

    // fallbacks
    receive() external payable {}
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address[]","name":"isBot_","type":"address[]"}],"name":"addBots","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"lastRewardVault","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":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"tokenAddress","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"rescueERC20","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"weiAmount","type":"uint256"}],"name":"rescueETH","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sellFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"_vault","type":"address"}],"name":"setLayerVault","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokenThreashold","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":"tokensForVaultFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"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"},{"stateMutability":"payable","type":"receive"}]

60c0604052600d805460ff191660011790553480156200001e57600080fd5b506040518060400160405280600b81526020016a13185e595c8815985d5b1d60aa1b8152506040518060400160405280600681526020016513159055531560d21b8152508160039081620000739190620005d0565b506004620000828282620005d0565b5050506000620000976200031460201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350737a250d5630b4cf539739df2c5dacb4c659f2488d60808190526040805163c45a015560e01b81529051829163c45a01559160048083019260209291908290030181865afa1580156200013c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200016291906200069c565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015620001b0573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001d691906200069c565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af115801562000224573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200024a91906200069c565b6001600160a01b031660a08190526000908152600f60205260409020805460ff19166001179055600260078190556008556b033b2e3c9fd0803ce800000061271062000298826005620006dd565b620002a49190620006f7565b600c556064620002b6826002620006dd565b620002c29190620006f7565b600a55620002e4620002dc6005546001600160a01b031690565b600162000318565b620002f130600162000318565b6200030061dead600162000318565b6200030c3382620003d7565b505062000730565b3390565b6005546001600160a01b03163314620003785760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b6001600160a01b0382166000818152600e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b0382166200042f5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064016200036f565b6002546200043e9082620004c0565b6002556001600160a01b038216600090815260208190526040902054620004669082620004c0565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b505050565b600080620004cf83856200071a565b905083811015620005235760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016200036f565b90505b92915050565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200055757607f821691505b6020821081036200057857634e487b7160e01b600052602260045260246000fd5b50919050565b601f821115620004bb57600081815260208120601f850160051c81016020861015620005a75750805b601f850160051c820191505b81811015620005c857828155600101620005b3565b505050505050565b81516001600160401b03811115620005ec57620005ec6200052c565b6200060481620005fd845462000542565b846200057e565b602080601f8311600181146200063c5760008415620006235750858301515b600019600386901b1c1916600185901b178555620005c8565b600085815260208120601f198616915b828110156200066d578886015182559484019460019091019084016200064c565b50858210156200068c5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b600060208284031215620006af57600080fd5b81516001600160a01b03811681146200052357600080fd5b634e487b7160e01b600052601160045260246000fd5b8082028115828204841417620005265762000526620006c7565b6000826200071557634e487b7160e01b600052601260045260246000fd5b500490565b80820180821115620005265762000526620006c7565b60805160a051611c476200076b600039600061038b0152600081816102750152818161159e0152818161165701526116930152611c476000f3fe6080604052600436106101dc5760003560e01c806370a0823111610102578063a00e9bc011610095578063c024666811610064578063c024666814610591578063d34628cc146105b1578063dd62ed3e146105d1578063f2fde38b1461061757600080fd5b8063a00e9bc014610501578063a457c2d714610521578063a9059cbb14610541578063b62496f51461056157600080fd5b80638cd4426d116100d15780638cd4426d1461048e5780638da5cb5b146104ae57806395d89b41146104cc5780639e252f00146104e157600080fd5b806370a0823114610416578063715018a61461044c578063751039fc146104635780638c0b5e221461047857600080fd5b80632b14ca561161017a57806349bd5a5e1161014957806349bd5a5e146103795780634fbee193146103ad57806351556e85146103e65780636ddd1713146103fc57600080fd5b80632b14ca5614610311578063313ce567146103275780633950935114610343578063470624021461036357600080fd5b80631694505e116101b65780631694505e1461026357806318160ddd146102af5780631ff13aed146102c457806323b872dd146102f157600080fd5b8063037bca14146101e857806306fdde0314610211578063095ea7b31461023357600080fd5b366101e357005b600080fd5b3480156101f457600080fd5b506101fe600c5481565b6040519081526020015b60405180910390f35b34801561021d57600080fd5b50610226610637565b6040516102089190611777565b34801561023f57600080fd5b5061025361024e3660046117ed565b6106c9565b6040519015158152602001610208565b34801561026f57600080fd5b506102977f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610208565b3480156102bb57600080fd5b506002546101fe565b3480156102d057600080fd5b506101fe6102df366004611819565b60116020526000908152604090205481565b3480156102fd57600080fd5b5061025361030c366004611836565b6106e0565b34801561031d57600080fd5b506101fe60085481565b34801561033357600080fd5b5060405160128152602001610208565b34801561034f57600080fd5b5061025361035e3660046117ed565b610749565b34801561036f57600080fd5b506101fe60075481565b34801561038557600080fd5b506102977f000000000000000000000000000000000000000000000000000000000000000081565b3480156103b957600080fd5b506102536103c8366004611819565b6001600160a01b03166000908152600e602052604090205460ff1690565b3480156103f257600080fd5b506101fe60095481565b34801561040857600080fd5b50600d546102539060ff1681565b34801561042257600080fd5b506101fe610431366004611819565b6001600160a01b031660009081526020819052604090205490565b34801561045857600080fd5b5061046161077f565b005b34801561046f57600080fd5b506104616107fc565b34801561048457600080fd5b506101fe600a5481565b34801561049a57600080fd5b506104616104a93660046117ed565b61082e565b3480156104ba57600080fd5b506005546001600160a01b0316610297565b3480156104d857600080fd5b506102266108ef565b3480156104ed57600080fd5b506104616104fc366004611877565b6108fe565b34801561050d57600080fd5b5061046161051c366004611890565b610992565b34801561052d57600080fd5b5061025361053c3660046117ed565b6109f3565b34801561054d57600080fd5b5061025361055c3660046117ed565b610a42565b34801561056d57600080fd5b5061025361057c366004611819565b600f6020526000908152604090205460ff1681565b34801561059d57600080fd5b506104616105ac3660046118d7565b610a4f565b3480156105bd57600080fd5b506104616105cc36600461191b565b610ad8565b3480156105dd57600080fd5b506101fe6105ec366004611890565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561062357600080fd5b50610461610632366004611819565b610b6a565b606060038054610646906119e0565b80601f0160208091040260200160405190810160405280929190818152602001828054610672906119e0565b80156106bf5780601f10610694576101008083540402835291602001916106bf565b820191906000526020600020905b8154815290600101906020018083116106a257829003601f168201915b5050505050905090565b60006106d6338484610c55565b5060015b92915050565b60006106ed848484610d7a565b61073f843361073a85604051806060016040528060288152602001611bc5602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611175565b610c55565b5060019392505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916106d691859061073a90866111af565b6005546001600160a01b031633146107b25760405162461bcd60e51b81526004016107a990611a1a565b60405180910390fd5b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b031633146108265760405162461bcd60e51b81526004016107a990611a1a565b600254600a55565b6005546001600160a01b031633146108585760405162461bcd60e51b81526004016107a990611a1a565b816001600160a01b031663a9059cbb6108796005546001600160a01b031690565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152602481018490526044016020604051808303816000875af11580156108c6573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108ea9190611a4f565b505050565b606060048054610646906119e0565b6005546001600160a01b031633146109285760405162461bcd60e51b81526004016107a990611a1a565b600061093c6005546001600160a01b031690565b6001600160a01b03168260405160006040518083038185875af1925050503d8060008114610986576040519150601f19603f3d011682016040523d82523d6000602084013e61098b565b606091505b5050505050565b6005546001600160a01b031633146109bc5760405162461bcd60e51b81526004016107a990611a1a565b600680546001600160a01b0319166001600160a01b0383161790556109e48282600019610c55565b6109ef816001610a4f565b5050565b60006106d6338461073a85604051806060016040528060258152602001611bed602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611175565b60006106d6338484610d7a565b6005546001600160a01b03163314610a795760405162461bcd60e51b81526004016107a990611a1a565b6001600160a01b0382166000818152600e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610b025760405162461bcd60e51b81526004016107a990611a1a565b60005b81518110156109ef57600160106000848481518110610b2657610b26611a6c565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff191691151591909117905580610b6281611a98565b915050610b05565b6005546001600160a01b03163314610b945760405162461bcd60e51b81526004016107a990611a1a565b6001600160a01b038116610bf95760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107a9565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610cb75760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107a9565b6001600160a01b038216610d185760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107a9565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b60008111610ddc5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016107a9565b6001600160a01b03831660009081526010602052604090205460ff16158015610e1e57506001600160a01b03821660009081526010602052604090205460ff16155b610e6a5760405162461bcd60e51b815260206004820152601960248201527f596f752063616e2774207472616e7366657220746f6b656e730000000000000060448201526064016107a9565b30600090815260208190526040902054600c5481108015908190610e905750600d5460ff165b8015610e9f5750600b5460ff16155b8015610ec457506001600160a01b0385166000908152600f602052604090205460ff16155b8015610ee957506001600160a01b0385166000908152600e602052604090205460ff16155b8015610f0e57506001600160a01b0384166000908152600e602052604090205460ff16155b15610f3357600b805460ff19166001179055610f28611215565b600b805460ff191690555b600b546001600160a01b0386166000908152600e602052604090205460ff91821615911680610f7a57506001600160a01b0385166000908152600e602052604090205460ff165b15610f83575060005b60008115611161576001600160a01b0386166000908152600f602052604090205460ff168015610fb557506000600854115b1561105f57610fda6064610fd46008548861130090919063ffffffff16565b90611382565b600654604051637de5e32b60e01b81526001600160a01b038a8116600483015260248201899052929350911690637de5e32b90604401600060405180830381600087803b15801561102a57600080fd5b505af115801561103e573d6000803e3d6000fd5b5050505080600960008282546110549190611ab1565b909155506111439050565b6001600160a01b0387166000908152600f602052604090205460ff16801561108957506000600754115b15611143576110a86064610fd46007548861130090919063ffffffff16565b60065460405163203639cf60e21b81526001600160a01b038a81166004830152602482018990529293509116906380d8e73c90604401600060405180830381600087803b1580156110f857600080fd5b505af115801561110c573d6000803e3d6000fd5b505050506001600160a01b03861660009081526011602052604081204290556009805483929061113d908490611ab1565b90915550505b8015611154576111548730836113c4565b61115e8186611ac4565b94505b61116c8787876113c4565b50505050505050565b600081848411156111995760405162461bcd60e51b81526004016107a99190611777565b5060006111a68486611ac4565b95945050505050565b6000806111bc8385611ab1565b90508381101561120e5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107a9565b9392505050565b600b5460ff166112fe57600b805460ff1916600117905530600090815260208190526040812054600954909150600082158061124f575081155b1561125c575050506112f3565b824761126782611547565b60006112734783611707565b9050600061129086610fd46009548561130090919063ffffffff16565b600060098190556006546040519293506001600160a01b031691839181818185875af1925050503d80600081146112e3576040519150601f19603f3d011682016040523d82523d6000602084013e6112e8565b606091505b505050505050505050505b600b805460ff191690555b565b600082600003611312575060006106da565b600061131e8385611ad7565b90508261132b8583611aee565b1461120e5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107a9565b600061120e83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611749565b6001600160a01b0383166114285760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016107a9565b6001600160a01b03821661148a5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016107a9565b6114c781604051806060016040528060268152602001611b9f602691396001600160a01b0386166000908152602081905260409020549190611175565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546114f690826111af565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610d6d565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061157c5761157c611a6c565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156115fa573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061161e9190611b10565b8160018151811061163157611631611a6c565b60200260200101906001600160a01b031690816001600160a01b03168152505061167c307f000000000000000000000000000000000000000000000000000000000000000084610c55565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac947906116d1908590600090869030904290600401611b2d565b600060405180830381600087803b1580156116eb57600080fd5b505af11580156116ff573d6000803e3d6000fd5b505050505050565b600061120e83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611175565b6000818361176a5760405162461bcd60e51b81526004016107a99190611777565b5060006111a68486611aee565b600060208083528351808285015260005b818110156117a457858101830151858201604001528201611788565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b03811681146117da57600080fd5b50565b80356117e8816117c5565b919050565b6000806040838503121561180057600080fd5b823561180b816117c5565b946020939093013593505050565b60006020828403121561182b57600080fd5b813561120e816117c5565b60008060006060848603121561184b57600080fd5b8335611856816117c5565b92506020840135611866816117c5565b929592945050506040919091013590565b60006020828403121561188957600080fd5b5035919050565b600080604083850312156118a357600080fd5b82356118ae816117c5565b915060208301356118be816117c5565b809150509250929050565b80151581146117da57600080fd5b600080604083850312156118ea57600080fd5b82356118f5816117c5565b915060208301356118be816118c9565b634e487b7160e01b600052604160045260246000fd5b6000602080838503121561192e57600080fd5b823567ffffffffffffffff8082111561194657600080fd5b818501915085601f83011261195a57600080fd5b81358181111561196c5761196c611905565b8060051b604051601f19603f8301168101818110858211171561199157611991611905565b6040529182528482019250838101850191888311156119af57600080fd5b938501935b828510156119d4576119c5856117dd565b845293850193928501926119b4565b98975050505050505050565b600181811c908216806119f457607f821691505b602082108103611a1457634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600060208284031215611a6157600080fd5b815161120e816118c9565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201611aaa57611aaa611a82565b5060010190565b808201808211156106da576106da611a82565b818103818111156106da576106da611a82565b80820281158282048414176106da576106da611a82565b600082611b0b57634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215611b2257600080fd5b815161120e816117c5565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611b7d5784516001600160a01b031683529383019391830191600101611b58565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa264697066735822122067436c6ea8b07b2936b8de18d2484fd1aff0a474dc62a17018226bc8440d0edf64736f6c63430008130033

Deployed Bytecode

0x6080604052600436106101dc5760003560e01c806370a0823111610102578063a00e9bc011610095578063c024666811610064578063c024666814610591578063d34628cc146105b1578063dd62ed3e146105d1578063f2fde38b1461061757600080fd5b8063a00e9bc014610501578063a457c2d714610521578063a9059cbb14610541578063b62496f51461056157600080fd5b80638cd4426d116100d15780638cd4426d1461048e5780638da5cb5b146104ae57806395d89b41146104cc5780639e252f00146104e157600080fd5b806370a0823114610416578063715018a61461044c578063751039fc146104635780638c0b5e221461047857600080fd5b80632b14ca561161017a57806349bd5a5e1161014957806349bd5a5e146103795780634fbee193146103ad57806351556e85146103e65780636ddd1713146103fc57600080fd5b80632b14ca5614610311578063313ce567146103275780633950935114610343578063470624021461036357600080fd5b80631694505e116101b65780631694505e1461026357806318160ddd146102af5780631ff13aed146102c457806323b872dd146102f157600080fd5b8063037bca14146101e857806306fdde0314610211578063095ea7b31461023357600080fd5b366101e357005b600080fd5b3480156101f457600080fd5b506101fe600c5481565b6040519081526020015b60405180910390f35b34801561021d57600080fd5b50610226610637565b6040516102089190611777565b34801561023f57600080fd5b5061025361024e3660046117ed565b6106c9565b6040519015158152602001610208565b34801561026f57600080fd5b506102977f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b039091168152602001610208565b3480156102bb57600080fd5b506002546101fe565b3480156102d057600080fd5b506101fe6102df366004611819565b60116020526000908152604090205481565b3480156102fd57600080fd5b5061025361030c366004611836565b6106e0565b34801561031d57600080fd5b506101fe60085481565b34801561033357600080fd5b5060405160128152602001610208565b34801561034f57600080fd5b5061025361035e3660046117ed565b610749565b34801561036f57600080fd5b506101fe60075481565b34801561038557600080fd5b506102977f00000000000000000000000015506dfb5d9a84d03d55bc392509a0bdbeded68481565b3480156103b957600080fd5b506102536103c8366004611819565b6001600160a01b03166000908152600e602052604090205460ff1690565b3480156103f257600080fd5b506101fe60095481565b34801561040857600080fd5b50600d546102539060ff1681565b34801561042257600080fd5b506101fe610431366004611819565b6001600160a01b031660009081526020819052604090205490565b34801561045857600080fd5b5061046161077f565b005b34801561046f57600080fd5b506104616107fc565b34801561048457600080fd5b506101fe600a5481565b34801561049a57600080fd5b506104616104a93660046117ed565b61082e565b3480156104ba57600080fd5b506005546001600160a01b0316610297565b3480156104d857600080fd5b506102266108ef565b3480156104ed57600080fd5b506104616104fc366004611877565b6108fe565b34801561050d57600080fd5b5061046161051c366004611890565b610992565b34801561052d57600080fd5b5061025361053c3660046117ed565b6109f3565b34801561054d57600080fd5b5061025361055c3660046117ed565b610a42565b34801561056d57600080fd5b5061025361057c366004611819565b600f6020526000908152604090205460ff1681565b34801561059d57600080fd5b506104616105ac3660046118d7565b610a4f565b3480156105bd57600080fd5b506104616105cc36600461191b565b610ad8565b3480156105dd57600080fd5b506101fe6105ec366004611890565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561062357600080fd5b50610461610632366004611819565b610b6a565b606060038054610646906119e0565b80601f0160208091040260200160405190810160405280929190818152602001828054610672906119e0565b80156106bf5780601f10610694576101008083540402835291602001916106bf565b820191906000526020600020905b8154815290600101906020018083116106a257829003601f168201915b5050505050905090565b60006106d6338484610c55565b5060015b92915050565b60006106ed848484610d7a565b61073f843361073a85604051806060016040528060288152602001611bc5602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611175565b610c55565b5060019392505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916106d691859061073a90866111af565b6005546001600160a01b031633146107b25760405162461bcd60e51b81526004016107a990611a1a565b60405180910390fd5b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b031633146108265760405162461bcd60e51b81526004016107a990611a1a565b600254600a55565b6005546001600160a01b031633146108585760405162461bcd60e51b81526004016107a990611a1a565b816001600160a01b031663a9059cbb6108796005546001600160a01b031690565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152602481018490526044016020604051808303816000875af11580156108c6573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108ea9190611a4f565b505050565b606060048054610646906119e0565b6005546001600160a01b031633146109285760405162461bcd60e51b81526004016107a990611a1a565b600061093c6005546001600160a01b031690565b6001600160a01b03168260405160006040518083038185875af1925050503d8060008114610986576040519150601f19603f3d011682016040523d82523d6000602084013e61098b565b606091505b5050505050565b6005546001600160a01b031633146109bc5760405162461bcd60e51b81526004016107a990611a1a565b600680546001600160a01b0319166001600160a01b0383161790556109e48282600019610c55565b6109ef816001610a4f565b5050565b60006106d6338461073a85604051806060016040528060258152602001611bed602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611175565b60006106d6338484610d7a565b6005546001600160a01b03163314610a795760405162461bcd60e51b81526004016107a990611a1a565b6001600160a01b0382166000818152600e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610b025760405162461bcd60e51b81526004016107a990611a1a565b60005b81518110156109ef57600160106000848481518110610b2657610b26611a6c565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff191691151591909117905580610b6281611a98565b915050610b05565b6005546001600160a01b03163314610b945760405162461bcd60e51b81526004016107a990611a1a565b6001600160a01b038116610bf95760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107a9565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610cb75760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107a9565b6001600160a01b038216610d185760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107a9565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b60008111610ddc5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016107a9565b6001600160a01b03831660009081526010602052604090205460ff16158015610e1e57506001600160a01b03821660009081526010602052604090205460ff16155b610e6a5760405162461bcd60e51b815260206004820152601960248201527f596f752063616e2774207472616e7366657220746f6b656e730000000000000060448201526064016107a9565b30600090815260208190526040902054600c5481108015908190610e905750600d5460ff165b8015610e9f5750600b5460ff16155b8015610ec457506001600160a01b0385166000908152600f602052604090205460ff16155b8015610ee957506001600160a01b0385166000908152600e602052604090205460ff16155b8015610f0e57506001600160a01b0384166000908152600e602052604090205460ff16155b15610f3357600b805460ff19166001179055610f28611215565b600b805460ff191690555b600b546001600160a01b0386166000908152600e602052604090205460ff91821615911680610f7a57506001600160a01b0385166000908152600e602052604090205460ff165b15610f83575060005b60008115611161576001600160a01b0386166000908152600f602052604090205460ff168015610fb557506000600854115b1561105f57610fda6064610fd46008548861130090919063ffffffff16565b90611382565b600654604051637de5e32b60e01b81526001600160a01b038a8116600483015260248201899052929350911690637de5e32b90604401600060405180830381600087803b15801561102a57600080fd5b505af115801561103e573d6000803e3d6000fd5b5050505080600960008282546110549190611ab1565b909155506111439050565b6001600160a01b0387166000908152600f602052604090205460ff16801561108957506000600754115b15611143576110a86064610fd46007548861130090919063ffffffff16565b60065460405163203639cf60e21b81526001600160a01b038a81166004830152602482018990529293509116906380d8e73c90604401600060405180830381600087803b1580156110f857600080fd5b505af115801561110c573d6000803e3d6000fd5b505050506001600160a01b03861660009081526011602052604081204290556009805483929061113d908490611ab1565b90915550505b8015611154576111548730836113c4565b61115e8186611ac4565b94505b61116c8787876113c4565b50505050505050565b600081848411156111995760405162461bcd60e51b81526004016107a99190611777565b5060006111a68486611ac4565b95945050505050565b6000806111bc8385611ab1565b90508381101561120e5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107a9565b9392505050565b600b5460ff166112fe57600b805460ff1916600117905530600090815260208190526040812054600954909150600082158061124f575081155b1561125c575050506112f3565b824761126782611547565b60006112734783611707565b9050600061129086610fd46009548561130090919063ffffffff16565b600060098190556006546040519293506001600160a01b031691839181818185875af1925050503d80600081146112e3576040519150601f19603f3d011682016040523d82523d6000602084013e6112e8565b606091505b505050505050505050505b600b805460ff191690555b565b600082600003611312575060006106da565b600061131e8385611ad7565b90508261132b8583611aee565b1461120e5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107a9565b600061120e83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611749565b6001600160a01b0383166114285760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016107a9565b6001600160a01b03821661148a5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016107a9565b6114c781604051806060016040528060268152602001611b9f602691396001600160a01b0386166000908152602081905260409020549190611175565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546114f690826111af565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610d6d565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061157c5761157c611a6c565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156115fa573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061161e9190611b10565b8160018151811061163157611631611a6c565b60200260200101906001600160a01b031690816001600160a01b03168152505061167c307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610c55565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac947906116d1908590600090869030904290600401611b2d565b600060405180830381600087803b1580156116eb57600080fd5b505af11580156116ff573d6000803e3d6000fd5b505050505050565b600061120e83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611175565b6000818361176a5760405162461bcd60e51b81526004016107a99190611777565b5060006111a68486611aee565b600060208083528351808285015260005b818110156117a457858101830151858201604001528201611788565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b03811681146117da57600080fd5b50565b80356117e8816117c5565b919050565b6000806040838503121561180057600080fd5b823561180b816117c5565b946020939093013593505050565b60006020828403121561182b57600080fd5b813561120e816117c5565b60008060006060848603121561184b57600080fd5b8335611856816117c5565b92506020840135611866816117c5565b929592945050506040919091013590565b60006020828403121561188957600080fd5b5035919050565b600080604083850312156118a357600080fd5b82356118ae816117c5565b915060208301356118be816117c5565b809150509250929050565b80151581146117da57600080fd5b600080604083850312156118ea57600080fd5b82356118f5816117c5565b915060208301356118be816118c9565b634e487b7160e01b600052604160045260246000fd5b6000602080838503121561192e57600080fd5b823567ffffffffffffffff8082111561194657600080fd5b818501915085601f83011261195a57600080fd5b81358181111561196c5761196c611905565b8060051b604051601f19603f8301168101818110858211171561199157611991611905565b6040529182528482019250838101850191888311156119af57600080fd5b938501935b828510156119d4576119c5856117dd565b845293850193928501926119b4565b98975050505050505050565b600181811c908216806119f457607f821691505b602082108103611a1457634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600060208284031215611a6157600080fd5b815161120e816118c9565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201611aaa57611aaa611a82565b5060010190565b808201808211156106da576106da611a82565b818103818111156106da576106da611a82565b80820281158282048414176106da576106da611a82565b600082611b0b57634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215611b2257600080fd5b815161120e816117c5565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611b7d5784516001600160a01b031683529383019391830191600101611b58565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa264697066735822122067436c6ea8b07b2936b8de18d2484fd1aff0a474dc62a17018226bc8440d0edf64736f6c63430008130033

Deployed Bytecode Sourcemap

27684:6464:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28066:34;;;;;;;;;;;;;;;;;;;160:25:1;;;148:2;133:18;28066:34:0;;;;;;;;7618:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;9785:169::-;;;;;;;;;;-1:-1:-1;9785:169:0;;;;;:::i;:::-;;:::i;:::-;;;1509:14:1;;1502:22;1484:41;;1472:2;1457:18;9785:169:0;1344:187:1;27769:51:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;1727:32:1;;;1709:51;;1697:2;1682:18;27769:51:0;1536:230:1;8738:108:0;;;;;;;;;;-1:-1:-1;8826:12:0;;8738:108;;28317:51;;;;;;;;;;-1:-1:-1;28317:51:0;;;;;:::i;:::-;;;;;;;;;;;;;;10436:355;;;;;;;;;;-1:-1:-1;10436:355:0;;;;;:::i;:::-;;:::i;27935:22::-;;;;;;;;;;;;;;;;8580:93;;;;;;;;;;-1:-1:-1;8580:93:0;;8663:2;2626:36:1;;2614:2;2599:18;8580:93:0;2484:184:1;11200:218:0;;;;;;;;;;-1:-1:-1;11200:218:0;;;;;:::i;:::-;;:::i;27907:21::-;;;;;;;;;;;;;;;;27827:38;;;;;;;;;;;;;;;30195:125;;;;;;;;;;-1:-1:-1;30195:125:0;;;;;:::i;:::-;-1:-1:-1;;;;;30284:28:0;30260:4;30284:28;;;:19;:28;;;;;;;;;30195:125;27964:32;;;;;;;;;;;;;;;;28107:30;;;;;;;;;;-1:-1:-1;28107:30:0;;;;;;;;8909:127;;;;;;;;;;-1:-1:-1;8909:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;9010:18:0;8983:7;9010:18;;;;;;;;;;;;8909:127;22083:148;;;;;;;;;;;;;:::i;:::-;;29691:89;;;;;;;;;;;;;:::i;28005:26::-;;;;;;;;;;;;;;;;33785:142;;;;;;;;;;-1:-1:-1;33785:142:0;;;;;:::i;:::-;;:::i;21441:79::-;;;;;;;;;;-1:-1:-1;21506:6:0;;-1:-1:-1;;;;;21506:6:0;21441:79;;7837:104;;;;;;;;;;;;;:::i;33935:155::-;;;;;;;;;;-1:-1:-1;33935:155:0;;;;;:::i;:::-;;:::i;29790:203::-;;;;;;;;;;-1:-1:-1;29790:203:0;;;;;:::i;:::-;;:::i;11921:269::-;;;;;;;;;;-1:-1:-1;11921:269:0;;;;;:::i;:::-;;:::i;9249:175::-;;;;;;;;;;-1:-1:-1;9249:175:0;;;;;:::i;:::-;;:::i;28206:58::-;;;;;;;;;;-1:-1:-1;28206:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;30005:182;;;;;;;;;;-1:-1:-1;30005:182:0;;;;;:::i;:::-;;:::i;29470:168::-;;;;;;;;;;-1:-1:-1;29470:168:0;;;;;:::i;:::-;;:::i;9487:151::-;;;;;;;;;;-1:-1:-1;9487:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;9603:18:0;;;9576:7;9603:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9487:151;22386:244;;;;;;;;;;-1:-1:-1;22386:244:0;;;;;:::i;:::-;;:::i;7618:100::-;7672:13;7705:5;7698:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7618:100;:::o;9785:169::-;9868:4;9885:39;336:10;9908:7;9917:6;9885:8;:39::i;:::-;-1:-1:-1;9942:4:0;9785:169;;;;;:::o;10436:355::-;10576:4;10593:36;10603:6;10611:9;10622:6;10593:9;:36::i;:::-;10640:121;10649:6;336:10;10671:89;10709:6;10671:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10671:19:0;;;;;;:11;:19;;;;;;;;336:10;10671:33;;;;;;;;;;:37;:89::i;:::-;10640:8;:121::i;:::-;-1:-1:-1;10779:4:0;10436:355;;;;;:::o;11200:218::-;336:10;11288:4;11337:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11337:34:0;;;;;;;;;;11288:4;;11305:83;;11328:7;;11337:50;;11376:10;11337:38;:50::i;22083:148::-;21653:6;;-1:-1:-1;;;;;21653:6:0;336:10;21653:22;21645:67;;;;-1:-1:-1;;;21645:67:0;;;;;;;:::i;:::-;;;;;;;;;22174:6:::1;::::0;22153:40:::1;::::0;22190:1:::1;::::0;-1:-1:-1;;;;;22174:6:0::1;::::0;22153:40:::1;::::0;22190:1;;22153:40:::1;22204:6;:19:::0;;-1:-1:-1;;;;;;22204:19:0::1;::::0;;22083:148::o;29691:89::-;21653:6;;-1:-1:-1;;;;;21653:6:0;336:10;21653:22;21645:67;;;;-1:-1:-1;;;21645:67:0;;;;;;;:::i;:::-;8826:12;;29745:11:::1;:27:::0;29691:89::o;33785:142::-;21653:6;;-1:-1:-1;;;;;21653:6:0;336:10;21653:22;21645:67;;;;-1:-1:-1;;;21645:67:0;;;;;;;:::i;:::-;33880:12:::1;-1:-1:-1::0;;;;;33873:29:0::1;;33903:7;21506:6:::0;;-1:-1:-1;;;;;21506:6:0;;21441:79;33903:7:::1;33873:46;::::0;-1:-1:-1;;;;;;33873:46:0::1;::::0;;;;;;-1:-1:-1;;;;;6165:32:1;;;33873:46:0::1;::::0;::::1;6147:51:1::0;6214:18;;;6207:34;;;6120:18;;33873:46:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;33785:142:::0;;:::o;7837:104::-;7893:13;7926:7;7919:14;;;;;:::i;33935:155::-;21653:6;;-1:-1:-1;;;;;21653:6:0;336:10;21653:22;21645:67;;;;-1:-1:-1;;;21645:67:0;;;;;;;:::i;:::-;34002:12:::1;34047:7;21506:6:::0;;-1:-1:-1;;;;;21506:6:0;;21441:79;34047:7:::1;-1:-1:-1::0;;;;;34039:21:0::1;34068:9;34039:43;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1::0;;;;;33935:155:0:o;29790:203::-;21653:6;;-1:-1:-1;;;;;21653:6:0;336:10;21653:22;21645:67;;;;-1:-1:-1;;;21645:67:0;;;;;;;:::i;:::-;29875:10:::1;:19:::0;;-1:-1:-1;;;;;;29875:19:0::1;-1:-1:-1::0;;;;;29875:19:0;::::1;;::::0;;29905:40:::1;29914:6:::0;29875:19;-1:-1:-1;;29905:8:0::1;:40::i;:::-;29956:29;29972:6;29980:4;29956:15;:29::i;:::-;29790:203:::0;;:::o;11921:269::-;12014:4;12031:129;336:10;12054:7;12063:96;12102:15;12063:96;;;;;;;;;;;;;;;;;336:10;12063:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;12063:34:0;;;;;;;;;;;;:38;:96::i;9249:175::-;9335:4;9352:42;336:10;9376:9;9387:6;9352:9;:42::i;30005:182::-;21653:6;;-1:-1:-1;;;;;21653:6:0;336:10;21653:22;21645:67;;;;-1:-1:-1;;;21645:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;30090:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;30090:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;30145:34;;1484:41:1;;;30145:34:0::1;::::0;1457:18:1;30145:34:0::1;;;;;;;30005:182:::0;;:::o;29470:168::-;21653:6;;-1:-1:-1;;;;;21653:6:0;336:10;21653:22;21645:67;;;;-1:-1:-1;;;21645:67:0;;;;;;;:::i;:::-;29545:6:::1;29540:91;29561:6;:13;29557:1;:17;29540:91;;;29615:4;29596:5;:16;29602:6;29609:1;29602:9;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;29596:16:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;29596:16:0;:23;;-1:-1:-1;;29596:23:0::1;::::0;::::1;;::::0;;;::::1;::::0;;29576:3;::::1;::::0;::::1;:::i;:::-;;;;29540:91;;22386:244:::0;21653:6;;-1:-1:-1;;;;;21653:6:0;336:10;21653:22;21645:67;;;;-1:-1:-1;;;21645:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22475:22:0;::::1;22467:73;;;::::0;-1:-1:-1;;;22467:73:0;;7318:2:1;22467:73:0::1;::::0;::::1;7300:21:1::0;7357:2;7337:18;;;7330:30;7396:34;7376:18;;;7369:62;-1:-1:-1;;;7447:18:1;;;7440:36;7493:19;;22467:73:0::1;7116:402:1::0;22467:73:0::1;22577:6;::::0;22556:38:::1;::::0;-1:-1:-1;;;;;22556:38:0;;::::1;::::0;22577:6:::1;::::0;22556:38:::1;::::0;22577:6:::1;::::0;22556:38:::1;22605:6;:17:::0;;-1:-1:-1;;;;;;22605:17:0::1;-1:-1:-1::0;;;;;22605:17:0;;;::::1;::::0;;;::::1;::::0;;22386:244::o;15107:380::-;-1:-1:-1;;;;;15243:19:0;;15235:68;;;;-1:-1:-1;;;15235:68:0;;7725:2:1;15235:68:0;;;7707:21:1;7764:2;7744:18;;;7737:30;7803:34;7783:18;;;7776:62;-1:-1:-1;;;7854:18:1;;;7847:34;7898:19;;15235:68:0;7523:400:1;15235:68:0;-1:-1:-1;;;;;15322:21:0;;15314:68;;;;-1:-1:-1;;;15314:68:0;;8130:2:1;15314:68:0;;;8112:21:1;8169:2;8149:18;;;8142:30;8208:34;8188:18;;;8181:62;-1:-1:-1;;;8259:18:1;;;8252:32;8301:19;;15314:68:0;7928:398:1;15314:68:0;-1:-1:-1;;;;;15395:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15447:32;;160:25:1;;;15447:32:0;;133:18:1;15447:32:0;;;;;;;;15107:380;;;:::o;30470:1903::-;30611:1;30602:6;:10;30594:64;;;;-1:-1:-1;;;30594:64:0;;8533:2:1;30594:64:0;;;8515:21:1;8572:2;8552:18;;;8545:30;8611:34;8591:18;;;8584:62;-1:-1:-1;;;8662:18:1;;;8655:39;8711:19;;30594:64:0;8331:405:1;30594:64:0;-1:-1:-1;;;;;30678:11:0;;;;;;:5;:11;;;;;;;;30677:12;:26;;;;-1:-1:-1;;;;;;30694:9:0;;;;;;:5;:9;;;;;;;;30693:10;30677:26;30669:64;;;;-1:-1:-1;;;30669:64:0;;8943:2:1;30669:64:0;;;8925:21:1;8982:2;8962:18;;;8955:30;9021:27;9001:18;;;8994:55;9066:18;;30669:64:0;8741:349:1;30669:64:0;30797:4;30748:28;9010:18;;;;;;;;;;;30853:19;;30829:43;;;;;;;30902:35;;-1:-1:-1;30926:11:0;;;;30902:35;:61;;;;-1:-1:-1;30955:8:0;;;;30954:9;30902:61;:110;;;;-1:-1:-1;;;;;;30981:31:0;;;;;;:25;:31;;;;;;;;30980:32;30902:110;:153;;;;-1:-1:-1;;;;;;31030:25:0;;;;;;:19;:25;;;;;;;;31029:26;30902:153;:194;;;;-1:-1:-1;;;;;;31073:23:0;;;;;;:19;:23;;;;;;;;31072:24;30902:194;30885:324;;;31123:8;:15;;-1:-1:-1;;31123:15:0;31134:4;31123:15;;;31153:13;:11;:13::i;:::-;31181:8;:16;;-1:-1:-1;;31181:16:0;;;30885:324;31245:8;;-1:-1:-1;;;;;31354:25:0;;31229:12;31354:25;;;:19;:25;;;;;;31245:8;;;;31244:9;;31354:25;;:52;;-1:-1:-1;;;;;;31383:23:0;;;;;;:19;:23;;;;;;;;31354:52;31351:99;;;-1:-1:-1;31433:5:0;31351:99;31470:12;31574:7;31571:749;;;-1:-1:-1;;;;;31601:29:0;;;;;;:25;:29;;;;;;;;:44;;;;;31644:1;31634:7;;:11;31601:44;31597:554;;;31672:28;31696:3;31672:19;31683:7;;31672:6;:10;;:19;;;;:::i;:::-;:23;;:28::i;:::-;31731:10;;31719:61;;-1:-1:-1;;;31719:61:0;;-1:-1:-1;;;;;6165:32:1;;;31719:61:0;;;6147:51:1;6214:18;;;6207:34;;;31665:35:0;;-1:-1:-1;31731:10:0;;;31719:47;;6120:18:1;;31719:61:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31820:4;31799:17;;:25;;;;;;;:::i;:::-;;;;-1:-1:-1;31597:554:0;;-1:-1:-1;31597:554:0;;-1:-1:-1;;;;;31862:31:0;;;;;;:25;:31;;;;;;;;:45;;;;;31906:1;31897:6;;:10;31862:45;31859:292;;;31932:27;31955:3;31932:18;31943:6;;31932;:10;;:18;;;;:::i;:27::-;31990:10;;31978:57;;-1:-1:-1;;;31978:57:0;;-1:-1:-1;;;;;6165:32:1;;;31978:57:0;;;6147:51:1;6214:18;;;6207:34;;;31925::0;;-1:-1:-1;31990:10:0;;;31978:43;;6120:18:1;;31978:57:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;32054:19:0;;;;;;:15;:19;;;;;32076:15;32054:37;;32110:17;:25;;32131:4;;32054:19;32110:25;;32131:4;;32110:25;:::i;:::-;;;;-1:-1:-1;;31859:292:0;32182:8;;32179:93;;32214:42;32230:4;32244;32251;32214:15;:42::i;:::-;32294:14;32304:4;32294:14;;:::i;:::-;;;31571:749;32332:33;32348:4;32354:2;32358:6;32332:15;:33::i;:::-;30583:1790;;;;30470:1903;;;:::o;17388:192::-;17474:7;17510:12;17502:6;;;;17494:29;;;;-1:-1:-1;;;17494:29:0;;;;;;;;:::i;:::-;-1:-1:-1;17534:9:0;17546:5;17550:1;17546;:5;:::i;:::-;17534:17;17388:192;-1:-1:-1;;;;;17388:192:0:o;16485:181::-;16543:7;;16575:5;16579:1;16575;:5;:::i;:::-;16563:17;;16604:1;16599;:6;;16591:46;;;;-1:-1:-1;;;16591:46:0;;9560:2:1;16591:46:0;;;9542:21:1;9599:2;9579:18;;;9572:30;9638:29;9618:18;;;9611:57;9685:18;;16591:46:0;9358:351:1;16591:46:0;16657:1;16485:181;-1:-1:-1;;;16485:181:0:o;32381:791::-;28483:8;;;;28478:104;;28508:8;:15;;-1:-1:-1;;28508:15:0;28519:4;28508:15;;;32474:4:::1;-1:-1:-1::0;9010:18:0;;;;;;;;;;;32519:17:::1;::::0;32430:50;;-1:-1:-1;32491:25:0::1;32583:20:::0;;;:46:::1;;-1:-1:-1::0;32607:22:0;;32583:46:::1;32580:60;;;32632:7;;;;;32580:60;32689:15:::0;32753:21:::1;32787:36;32689:15:::0;32787:16:::1;:36::i;:::-;32845:18;32866:44;:21;32892:17:::0;32866:25:::1;:44::i;:::-;32845:65;;32931:24;32958:56;32996:17;32958:33;32973:17;;32958:10;:14;;:33;;;;:::i;:56::-;33051:1;33031:17;:21:::0;;;33095:10:::1;::::0;33087:77:::1;::::0;32931:83;;-1:-1:-1;;;;;;33095:10:0::1;::::0;32931:83;;33087:77;33051:1;33087:77;32931:83;33095:10;33087:77:::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1::0;;;;;;;;;;28538:1:0::1;28554:8:::0;:16;;-1:-1:-1;;28554:16:0;;;28478:104;32381:791::o;17839:471::-;17897:7;18142:1;18147;18142:6;18138:47;;-1:-1:-1;18172:1:0;18165:8;;18138:47;18197:9;18209:5;18213:1;18209;:5;:::i;:::-;18197:17;-1:-1:-1;18242:1:0;18233:5;18237:1;18197:17;18233:5;:::i;:::-;:10;18225:56;;;;-1:-1:-1;;;18225:56:0;;10311:2:1;18225:56:0;;;10293:21:1;10350:2;10330:18;;;10323:30;10389:34;10369:18;;;10362:62;-1:-1:-1;;;10440:18:1;;;10433:31;10481:19;;18225:56:0;10109:397:1;18786:132:0;18844:7;18871:39;18875:1;18878;18871:39;;;;;;;;;;;;;;;;;:3;:39::i;12680:573::-;-1:-1:-1;;;;;12820:20:0;;12812:70;;;;-1:-1:-1;;;12812:70:0;;10713:2:1;12812:70:0;;;10695:21:1;10752:2;10732:18;;;10725:30;10791:34;10771:18;;;10764:62;-1:-1:-1;;;10842:18:1;;;10835:35;10887:19;;12812:70:0;10511:401:1;12812:70:0;-1:-1:-1;;;;;12901:23:0;;12893:71;;;;-1:-1:-1;;;12893:71:0;;11119:2:1;12893:71:0;;;11101:21:1;11158:2;11138:18;;;11131:30;11197:34;11177:18;;;11170:62;-1:-1:-1;;;11248:18:1;;;11241:33;11291:19;;12893:71:0;10917:399:1;12893:71:0;13057;13079:6;13057:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;13057:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;13037:17:0;;;:9;:17;;;;;;;;;;;:91;;;;13162:20;;;;;;;:32;;13187:6;13162:24;:32::i;:::-;-1:-1:-1;;;;;13139:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;13210:35;160:25:1;;;13139:20:0;;13210:35;;;;;;133:18:1;13210:35:0;14:177:1;33180:597:0;33330:16;;;33344:1;33330:16;;;;;;;;33306:21;;33330:16;;;;;;;;;;-1:-1:-1;33330:16:0;33306:40;;33375:4;33357;33362:1;33357:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;33357:23:0;;;-1:-1:-1;;;;;33357:23:0;;;;;33401:15;-1:-1:-1;;;;;33401:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;33391:4;33396:1;33391:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;33391:32:0;;;-1:-1:-1;;;;;33391:32:0;;;;;33436:62;33453:4;33468:15;33486:11;33436:8;:62::i;:::-;33545:224;;-1:-1:-1;;;33545:224:0;;-1:-1:-1;;;;;33545:15:0;:66;;;;:224;;33626:11;;33652:1;;33696:4;;33723;;33743:15;;33545:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33235:542;33180:597;:::o;16949:136::-;17007:7;17034:43;17038:1;17041;17034:43;;;;;;;;;;;;;;;;;:3;:43::i;19414:278::-;19500:7;19535:12;19528:5;19520:28;;;;-1:-1:-1;;;19520:28:0;;;;;;;;:::i;:::-;-1:-1:-1;19559:9:0;19571:5;19575:1;19571;:5;:::i;196:548:1:-;308:4;337:2;366;355:9;348:21;398:6;392:13;441:6;436:2;425:9;421:18;414:34;466:1;476:140;490:6;487:1;484:13;476:140;;;585:14;;;581:23;;575:30;551:17;;;570:2;547:26;540:66;505:10;;476:140;;;480:3;665:1;660:2;651:6;640:9;636:22;632:31;625:42;735:2;728;724:7;719:2;711:6;707:15;703:29;692:9;688:45;684:54;676:62;;;;196:548;;;;:::o;749:131::-;-1:-1:-1;;;;;824:31:1;;814:42;;804:70;;870:1;867;860:12;804:70;749:131;:::o;885:134::-;953:20;;982:31;953:20;982:31;:::i;:::-;885:134;;;:::o;1024:315::-;1092:6;1100;1153:2;1141:9;1132:7;1128:23;1124:32;1121:52;;;1169:1;1166;1159:12;1121:52;1208:9;1195:23;1227:31;1252:5;1227:31;:::i;:::-;1277:5;1329:2;1314:18;;;;1301:32;;-1:-1:-1;;;1024:315:1:o;1771:247::-;1830:6;1883:2;1871:9;1862:7;1858:23;1854:32;1851:52;;;1899:1;1896;1889:12;1851:52;1938:9;1925:23;1957:31;1982:5;1957:31;:::i;2023:456::-;2100:6;2108;2116;2169:2;2157:9;2148:7;2144:23;2140:32;2137:52;;;2185:1;2182;2175:12;2137:52;2224:9;2211:23;2243:31;2268:5;2243:31;:::i;:::-;2293:5;-1:-1:-1;2350:2:1;2335:18;;2322:32;2363:33;2322:32;2363:33;:::i;:::-;2023:456;;2415:7;;-1:-1:-1;;;2469:2:1;2454:18;;;;2441:32;;2023:456::o;2881:180::-;2940:6;2993:2;2981:9;2972:7;2968:23;2964:32;2961:52;;;3009:1;3006;2999:12;2961:52;-1:-1:-1;3032:23:1;;2881:180;-1:-1:-1;2881:180:1:o;3066:388::-;3134:6;3142;3195:2;3183:9;3174:7;3170:23;3166:32;3163:52;;;3211:1;3208;3201:12;3163:52;3250:9;3237:23;3269:31;3294:5;3269:31;:::i;:::-;3319:5;-1:-1:-1;3376:2:1;3361:18;;3348:32;3389:33;3348:32;3389:33;:::i;:::-;3441:7;3431:17;;;3066:388;;;;;:::o;3459:118::-;3545:5;3538:13;3531:21;3524:5;3521:32;3511:60;;3567:1;3564;3557:12;3582:382;3647:6;3655;3708:2;3696:9;3687:7;3683:23;3679:32;3676:52;;;3724:1;3721;3714:12;3676:52;3763:9;3750:23;3782:31;3807:5;3782:31;:::i;:::-;3832:5;-1:-1:-1;3889:2:1;3874:18;;3861:32;3902:30;3861:32;3902:30;:::i;3969:127::-;4030:10;4025:3;4021:20;4018:1;4011:31;4061:4;4058:1;4051:15;4085:4;4082:1;4075:15;4101:1121;4185:6;4216:2;4259;4247:9;4238:7;4234:23;4230:32;4227:52;;;4275:1;4272;4265:12;4227:52;4315:9;4302:23;4344:18;4385:2;4377:6;4374:14;4371:34;;;4401:1;4398;4391:12;4371:34;4439:6;4428:9;4424:22;4414:32;;4484:7;4477:4;4473:2;4469:13;4465:27;4455:55;;4506:1;4503;4496:12;4455:55;4542:2;4529:16;4564:2;4560;4557:10;4554:36;;;4570:18;;:::i;:::-;4616:2;4613:1;4609:10;4648:2;4642:9;4711:2;4707:7;4702:2;4698;4694:11;4690:25;4682:6;4678:38;4766:6;4754:10;4751:22;4746:2;4734:10;4731:18;4728:46;4725:72;;;4777:18;;:::i;:::-;4813:2;4806:22;4863:18;;;4897:15;;;;-1:-1:-1;4939:11:1;;;4935:20;;;4967:19;;;4964:39;;;4999:1;4996;4989:12;4964:39;5023:11;;;;5043:148;5059:6;5054:3;5051:15;5043:148;;;5125:23;5144:3;5125:23;:::i;:::-;5113:36;;5076:12;;;;5169;;;;5043:148;;;5210:6;4101:1121;-1:-1:-1;;;;;;;;4101:1121:1:o;5227:380::-;5306:1;5302:12;;;;5349;;;5370:61;;5424:4;5416:6;5412:17;5402:27;;5370:61;5477:2;5469:6;5466:14;5446:18;5443:38;5440:161;;5523:10;5518:3;5514:20;5511:1;5504:31;5558:4;5555:1;5548:15;5586:4;5583:1;5576:15;5440:161;;5227:380;;;:::o;5612:356::-;5814:2;5796:21;;;5833:18;;;5826:30;5892:34;5887:2;5872:18;;5865:62;5959:2;5944:18;;5612:356::o;6252:245::-;6319:6;6372:2;6360:9;6351:7;6347:23;6343:32;6340:52;;;6388:1;6385;6378:12;6340:52;6420:9;6414:16;6439:28;6461:5;6439:28;:::i;6712:127::-;6773:10;6768:3;6764:20;6761:1;6754:31;6804:4;6801:1;6794:15;6828:4;6825:1;6818:15;6844:127;6905:10;6900:3;6896:20;6893:1;6886:31;6936:4;6933:1;6926:15;6960:4;6957:1;6950:15;6976:135;7015:3;7036:17;;;7033:43;;7056:18;;:::i;:::-;-1:-1:-1;7103:1:1;7092:13;;6976:135::o;9095:125::-;9160:9;;;9181:10;;;9178:36;;;9194:18;;:::i;9225:128::-;9292:9;;;9313:11;;;9310:37;;;9327:18;;:::i;9714:168::-;9787:9;;;9818;;9835:15;;;9829:22;;9815:37;9805:71;;9856:18;;:::i;9887:217::-;9927:1;9953;9943:132;;9997:10;9992:3;9988:20;9985:1;9978:31;10032:4;10029:1;10022:15;10060:4;10057:1;10050:15;9943:132;-1:-1:-1;10089:9:1;;9887:217::o;11321:251::-;11391:6;11444:2;11432:9;11423:7;11419:23;11415:32;11412:52;;;11460:1;11457;11450:12;11412:52;11492:9;11486:16;11511:31;11536:5;11511:31;:::i;11577:980::-;11839:4;11887:3;11876:9;11872:19;11918:6;11907:9;11900:25;11944:2;11982:6;11977:2;11966:9;11962:18;11955:34;12025:3;12020:2;12009:9;12005:18;11998:31;12049:6;12084;12078:13;12115:6;12107;12100:22;12153:3;12142:9;12138:19;12131:26;;12192:2;12184:6;12180:15;12166:29;;12213:1;12223:195;12237:6;12234:1;12231:13;12223:195;;;12302:13;;-1:-1:-1;;;;;12298:39:1;12286:52;;12393:15;;;;12358:12;;;;12334:1;12252:9;12223:195;;;-1:-1:-1;;;;;;;12474:32:1;;;;12469:2;12454:18;;12447:60;-1:-1:-1;;;12538:3:1;12523:19;12516:35;12435:3;11577:980;-1:-1:-1;;;11577:980:1:o

Swarm Source

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