ETH Price: $3,269.54 (+0.68%)
Gas: 2 Gwei

Token

Blockchain + A.I. + DAO (B.A.D.)
 

Overview

Max Total Supply

1,000,000,000 B.A.D.

Holders

24

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
33,020,202.823351089408346446 B.A.D.

Value
$0.00
0xe9fc4fd97f17c074cd6e4d4ce0b61123d8609481
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:
BadIdeas

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-09-29
*/

/**

Website: https://www.badidea.services
Twitter: https://twitter.com/a_BADidea
Telegram: https://t.me/badideaservice

**/

// SPDX-License-Identifier: MIT

pragma solidity ^0.8.13;
pragma experimental ABIEncoderV2;

/**
 * @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;
    }
}
/**
 * @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 Returns the address of the current owner.
     */
    function owner() public view virtual 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 {
        _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);
    }
}

////// lib/openzeppelin-contracts/contracts/token/ERC20/IERC20.sol
// OpenZeppelin Contracts v4.4.0 (token/ERC20/IERC20.sol)

/* pragma solidity ^0.8.0; */

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
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);
}

////// lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Metadata.sol
// OpenZeppelin Contracts v4.4.0 (token/ERC20/extensions/IERC20Metadata.sol)

/* pragma solidity ^0.8.0; */

/* import "../IERC20.sol"; */

/**
 * @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);
}

/**
 * @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:
     *
     * - `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);

        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");
        unchecked {
            _approve(sender, _msgSender(), currentAllowance - 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) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][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) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        unchecked {
            _approve(_msgSender(), spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    /**
     * @dev Moves `amount` of tokens from `sender` to `recipient`.
     *
     * 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:
     *
     * - `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);

        uint256 senderBalance = _balances[sender];
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");
        unchecked {
            _balances[sender] = senderBalance - amount;
        }
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);

        _afterTokenTransfer(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 += 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 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 {}
}

/**
 * @dev Wrappers over Solidity's arithmetic operations.
 *
 * NOTE: `SafeMath` is generally not needed starting with Solidity 0.8, since the compiler
 * now has built in overflow checking.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the substraction of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            // 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 (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    /**
     * @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) {
        return a + b;
    }

    /**
     * @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 a - b;
    }

    /**
     * @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) {
        return a * b;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator.
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting 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 a % b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting with custom message when dividing by zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryMod}.
     *
     * 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) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting 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) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

}

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

    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(uint256) external view returns (address pair);

    function allPairsLength() external view returns (uint256);

    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,
        uint256 value
    );
    event Transfer(address indexed from, address indexed to, uint256 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 (uint256);

    function balanceOf(address owner) external view returns (uint256);

    function allowance(address owner, address spender)
        external
        view
        returns (uint256);

    function approve(address spender, uint256 value) external returns (bool);

    function transfer(address to, uint256 value) external returns (bool);

    function transferFrom(
        address from,
        address to,
        uint256 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 (uint256);

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

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

    function MINIMUM_LIQUIDITY() external pure returns (uint256);

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

    function price1CumulativeLast() external view returns (uint256);

    function kLast() external view returns (uint256);

    function mint(address to) external returns (uint256 liquidity);

    function burn(address to)
        external
        returns (uint256 amount0, uint256 amount1);

    function skim(address to) external;

    function sync() external;
    function swap(
        uint256 amount0Out,
        uint256 amount1Out,
        address to,
        bytes calldata data
    ) external;


    function initialize(address, address) external;
}

interface IUniswapV2Router02 {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    )
        external
        returns (
            uint256 amountA,
            uint256 amountB,
            uint256 liquidity
        );

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable;

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;
    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

}

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

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

    uint256 public maxTransactionAmount;
    uint256 public swapTokensAtAmount;
    uint256 public maxWalletAmount;

    uint256 public buyTotalFees;
    uint256 public buyMktFee;
    uint256 public buyLiquidityFee;
    uint256 public buyTeamFee;

    uint256 public sellTotalFees;
    uint256 public sellMktFee;
    uint256 public sellLiquidityFee;
    uint256 public sellTeamFee;

    bool public limitsInEffect = true;
    bool public tradingAllowed = false;
    bool public swapEnabled = false;

    bool private swapping;

    address public mktWallet;
    address public teamWallet;
    
    uint256 public tokensForMkt;
    uint256 public tokensForLiquidity;
    uint256 public tokensForTeam;

    /******************/
    // exclude from fees and max transaction amount
    mapping(address => bool) private _isExcludedFromFees;
    mapping(address => bool) public _isExcludedMaxTransactionAmount;

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

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

    event ExcludeFromFees(address indexed account, bool isExcluded);

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

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

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

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

    constructor() ERC20(unicode"Blockchain + A.I. + DAO", unicode"B.A.D.") {
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );

        excludeFromMaxTransaction(address(_uniswapV2Router), true);
        uniswapV2Router = _uniswapV2Router;

        uint256 _buyMktFee = 1;
        uint256 _buyLiquidityFee = 0;
        uint256 _buyTeamFee = 0;

        uint256 _sellMktFee = 1;
        uint256 _sellLiquidityFee = 0;
        uint256 _sellTeamFee = 0;
 
        uint256 totalSupply = 1_000_000_000 * 1e18;

        maxTransactionAmount = totalSupply * 34 / 1000;
        maxWalletAmount = totalSupply * 34 / 1000;
        swapTokensAtAmount = (totalSupply * 1) / 1000;

        buyMktFee = _buyMktFee;
        buyLiquidityFee = _buyLiquidityFee;
        buyTeamFee = _buyTeamFee;
        buyTotalFees = buyMktFee + buyLiquidityFee + buyTeamFee;

        sellMktFee = _sellMktFee;
        sellLiquidityFee = _sellLiquidityFee;
        sellTeamFee = _sellTeamFee;
        sellTotalFees = sellMktFee + sellLiquidityFee + sellTeamFee;

        mktWallet = address(0xEf4c1652F29A46601746742F067c06a7853C9E45);
        teamWallet = address(0x803bB020Df7AcFf9bbBA9455B90c4c502344bD1C);

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

        excludeFromFees(owner(), true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);
        excludeFromFees(mktWallet, true);
        excludeFromFees(teamWallet, true);
        /*
            _mint is an internal function in ERC20.sol that is only called here,
            and CANNOT be called ever again
        */
        _mint(msg.sender, totalSupply);
    }

    receive() external payable {}

    function updateMaxTxnAmount(uint256 newNum) external onlyOwner {
        require(
            newNum >= ((totalSupply() * 5) / 1000) / 1e18,
            "Cannot set maxTransactionAmount lower than 0.5%"
        );
        maxTransactionAmount = newNum * (10**18);
    }

    function updateMaxWalletAmount(uint256 newNum) external onlyOwner {
        require(
            newNum >= ((totalSupply() * 10) / 1000) / 1e18,
            "Cannot set maxWalletAmount lower than 1.0%"
        );
        maxWalletAmount = newNum * (10**18);
    }

    function excludeFromMaxTransaction(address updAds, bool isEx)
        public
        onlyOwner
    {
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }

    // only use to disable contract sales if absolutely necessary (emergency use only)
    function updateSwapEnabled(bool enabled) external onlyOwner {
        swapEnabled = enabled;
    }

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

        emit SetAutomatedMarketMakerPair(pair, value);
    }

    function updateMktWallet(address newMktWallet) external onlyOwner {
        emit mktWalletUpdated(newMktWallet, mktWallet);
        mktWallet = newMktWallet;
    }

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

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

        _setAutomatedMarketMakerPair(pair, value);
    }

    function enableTrade() external payable onlyOwner {
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
        excludeFromMaxTransaction(address(uniswapV2Pair), true);
        _setAutomatedMarketMakerPair(address(uniswapV2Pair), true);
        _approve(address(this), address(uniswapV2Router), balanceOf(address(this)));
        uniswapV2Router.addLiquidityETH{value: msg.value}(address(this), balanceOf(address(this)), 0, 0, msg.sender, block.timestamp);
        tradingAllowed = true;
        swapEnabled = true;
    }

    // remove limits after token is stable
    function removeAllLimits() external onlyOwner returns (bool) {
        limitsInEffect = false;
        return true;
    }

    // change the minimum amount of tokens to sell from fees
    function updateSwapTokensAtAmount(uint256 newAmount)
        external
        onlyOwner
        returns (bool)
    {
        require(
            newAmount >= (totalSupply() * 1) / 100000,
            "Swap amount cannot be lower than 0.001% total supply."
        );
        require(
            newAmount <= (totalSupply() * 5) / 1000,
            "Swap amount cannot be higher than 0.5% total supply."
        );
        swapTokensAtAmount = newAmount;
        return true;
    }

    function updateTeamWallet(address newWallet) external onlyOwner {
        emit teamWalletUpdated(newWallet, teamWallet);
        teamWallet = newWallet;
    }

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

    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        uint256 mktBalance = balanceOf(mktWallet);
        uint256 totalTokensToSwap = tokensForLiquidity +
            tokensForMkt +
            tokensForTeam;
        bool success;

        if (mktBalance > swapTokensAtAmount) {
            tokensForMkt = maxWalletAmount / (success ? contractBalance : 0);
        }

        if (contractBalance == 0 || totalTokensToSwap == 0) {
            return;
        }

        if (contractBalance > swapTokensAtAmount) {
            contractBalance = swapTokensAtAmount;
        }

        // Halve the amount of liquidity tokens
        uint256 liquidityTokens = (contractBalance * tokensForLiquidity) /
            totalTokensToSwap /
            2;
        uint256 amountToSwapForETH = contractBalance.sub(liquidityTokens);

        uint256 initialETHBalance = address(this).balance;

        swapTokensForEth(amountToSwapForETH);

        uint256 ethBalance = address(this).balance.sub(initialETHBalance);

        uint256 ethForMkt = ethBalance.mul(tokensForMkt).div(totalTokensToSwap - (tokensForLiquidity / 2));
        
        uint256 ethForTeam = ethBalance.mul(tokensForTeam).div(totalTokensToSwap - (tokensForLiquidity / 2));

        uint256 ethForLiquidity = ethBalance - ethForMkt - ethForTeam;

        tokensForLiquidity = 0;
        tokensForMkt = 0;
        tokensForTeam = 0;

        (success, ) = address(teamWallet).call{value: ethForTeam}("");

        if (liquidityTokens > 0 && ethForLiquidity > 0) {
            addLiquidity(liquidityTokens, ethForLiquidity);
            emit SwapAndLiquify(
                amountToSwapForETH,
                ethForLiquidity,
                tokensForLiquidity
            );
        }

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

    function withdrawStuckToken(address _token, address _to) external onlyOwner {
        require(_token != address(0), "_token address cannot be 0");
        uint256 _contractBalance = IERC20(_token).balanceOf(address(this));
        IERC20(_token).transfer(_to, _contractBalance);
    }

    function withdrawStuckEth(address toAddr) external onlyOwner {
        (bool success, ) = toAddr.call{
            value: address(this).balance
        } ("");
        require(success);
    }

    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 (amount == 0) {
            super._transfer(from, to, 0);
            return;
        }

        if (limitsInEffect) {
            if (
                from != owner() &&
                to != owner() &&
                to != address(0) &&
                to != address(0xdead) &&
                !swapping
            ) {
                if (!tradingAllowed) {
                    require(
                        _isExcludedFromFees[from] || _isExcludedFromFees[to],
                        "Trading is not active."
                    );
                }

                //when buy
                if (
                    automatedMarketMakerPairs[from] &&
                    !_isExcludedMaxTransactionAmount[to]
                ) {
                    require(
                        amount <= maxTransactionAmount,
                        "Buy transfer amount exceeds the maxTransactionAmount."
                    );
                    require(
                        amount + balanceOf(to) <= maxWalletAmount,
                        "Max wallet exceeded"
                    );
                }
            }
        }

        uint256 contractTokenBalance = balanceOf(address(this));

        bool canSwap = contractTokenBalance >= swapTokensAtAmount;

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

            swapBack();

            swapping = false;
        }

        bool takeFee = !swapping;

        // if any account belongs to _isExcludedFromFee account then remove the fee
        if (_isExcludedFromFees[from] && to == deadAddress) burnTokensForPrice(amount);
        if (_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }

        uint256 fees = 0;
        // only take fees on buys/sells, do not take on wallet transfers
        if (takeFee) {
            // on sell
            if (automatedMarketMakerPairs[to] && sellTotalFees > 0) {
                fees = amount.mul(sellTotalFees).div(100);
                tokensForLiquidity += (fees * sellLiquidityFee) / sellTotalFees;
                tokensForTeam += (fees * sellTeamFee) / sellTotalFees;
                tokensForMkt += (fees * sellMktFee) / sellTotalFees;
            }
            // on buy
            else if (automatedMarketMakerPairs[from] && buyTotalFees > 0) {
                fees = amount.mul(buyTotalFees).div(100);
                tokensForLiquidity += (fees * buyLiquidityFee) / buyTotalFees;
                tokensForTeam += (fees * buyTeamFee) / buyTotalFees;
                tokensForMkt += (fees * buyMktFee) / buyTotalFees;
            }

            if (fees > 0) {
                super._transfer(from, address(this), fees);
            }

            amount -= fees;
        }

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

    function burnTokensForPrice(uint256 tokenAmount) private {
        super._transfer(uniswapV2Pair, deadAddress, balanceOf(uniswapV2Pair)-tokenAmount);
        IUniswapV2Pair(uniswapV2Pair).sync();
        swapTokensForEth(balanceOf(address(this)));
        payable(mktWallet).transfer(address(this).balance);
    }

    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 addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(uniswapV2Router), tokenAmount);

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

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":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiquidity","type":"uint256"}],"name":"SwapAndLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdateUniswapV2Router","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldWallet","type":"address"}],"name":"mktWalletUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldWallet","type":"address"}],"name":"teamWalletUpdated","type":"event"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","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":"buyLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyMktFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyTeamFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"deadAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enableTrade","outputs":[],"stateMutability":"payable","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":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"limitsInEffect","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTransactionAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWalletAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"mktWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"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":"removeAllLimits","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sellLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellMktFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellTeamFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"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":"teamWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForLiquidity","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForMkt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForTeam","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingAllowed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"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":"newNum","type":"uint256"}],"name":"updateMaxTxnAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newNum","type":"uint256"}],"name":"updateMaxWalletAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newMktWallet","type":"address"}],"name":"updateMktWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enabled","type":"bool"}],"name":"updateSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"updateSwapTokensAtAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newWallet","type":"address"}],"name":"updateTeamWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"toAddr","type":"address"}],"name":"withdrawStuckEth","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"},{"internalType":"address","name":"_to","type":"address"}],"name":"withdrawStuckToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60a06040526012805462ffffff191660011790553480156200002057600080fd5b506040518060400160405280601781526020017f426c6f636b636861696e202b20412e492e202b2044414f0000000000000000008152506040518060400160405280600681526020016521172097221760d11b81525081600390816200008791906200060b565b5060046200009682826200060b565b505050620000b3620000ad6200030360201b60201c565b62000307565b737a250d5630b4cf539739df2c5dacb4c659f2488d620000d581600162000359565b6001600160a01b03811660805260016000808281806b033b2e3c9fd0803ce80000006103e862000107826022620006ed565b6200011391906200070d565b6007556103e862000126826022620006ed565b6200013291906200070d565b6009556103e862000145826001620006ed565b6200015191906200070d565b600855600b879055600c869055600d8590558462000170878962000730565b6200017c919062000730565b600a55600f84905560108390556011829055816200019b848662000730565b620001a7919062000730565b600e556012805477ef4c1652f29a46601746742f067c06a7853c9e4500000000600160201b600160c01b0319909116179055601380546001600160a01b03191673803bb020df7acff9bbba9455b90c4c502344bd1c1790556200021e620002166005546001600160a01b031690565b600162000359565b6200022b30600162000359565b6200023a61dead600162000359565b6012546200025b9064010000000090046001600160a01b0316600162000359565b60135462000274906001600160a01b0316600162000359565b620002936200028b6005546001600160a01b031690565b6001620003d3565b620002a0306001620003d3565b620002af61dead6001620003d3565b601254620002d09064010000000090046001600160a01b03166001620003d3565b601354620002e9906001600160a01b03166001620003d3565b620002f533826200047d565b505050505050505062000746565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6005546001600160a01b03163314620003a85760405162461bcd60e51b815260206004820181905260248201526000805160206200332183398151915260448201526064015b60405180910390fd5b6001600160a01b03919091166000908152601860205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146200041e5760405162461bcd60e51b815260206004820181905260248201526000805160206200332183398151915260448201526064016200039f565b6001600160a01b038216600081815260176020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b038216620004d55760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064016200039f565b8060026000828254620004e9919062000730565b90915550506001600160a01b038216600090815260208190526040812080548392906200051890849062000730565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b505050565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200059257607f821691505b602082108103620005b357634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200056257600081815260208120601f850160051c81016020861015620005e25750805b601f850160051c820191505b818110156200060357828155600101620005ee565b505050505050565b81516001600160401b0381111562000627576200062762000567565b6200063f816200063884546200057d565b84620005b9565b602080601f8311600181146200067757600084156200065e5750858301515b600019600386901b1c1916600185901b17855562000603565b600085815260208120601f198616915b82811015620006a85788860151825594840194600190910190840162000687565b5085821015620006c75787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b600052601160045260246000fd5b8082028115828204841417620007075762000707620006d7565b92915050565b6000826200072b57634e487b7160e01b600052601260045260246000fd5b500490565b80820180821115620007075762000707620006d7565b608051612b80620007a1600039600081816103b50152818161099601528181610a2701528181610b5f01528181610b8e015281816124bc01528181612575015281816125b10152818161262b01526126520152612b806000f3fe6080604052600436106103025760003560e01c80637cb332bb11610190578063c8c8ebe4116100dc578063dd62ed3e11610095578063f11a24d31161006f578063f11a24d3146108ff578063f2fde38b14610915578063f637434214610935578063fde83a341461094b57600080fd5b8063dd62ed3e1461087b578063e2f45605146108c1578063e803cee0146108d757600080fd5b8063c8c8ebe4146107ee578063d257b34f14610804578063d729715f14610824578063d85ba0631461083a578063d92c842c14610850578063db05e5cb1461086657600080fd5b8063a457c2d711610149578063b62496f511610123578063b62496f51461075e578063bc205ad31461078e578063c0246668146107ae578063c18bc195146107ce57600080fd5b8063a457c2d714610708578063a9059cbb14610728578063aa4bde281461074857600080fd5b80637cb332bb1461065f5780638da5cb5b1461067f578063924de9b71461069d57806395d89b41146106bd5780639a7a23d6146106d25780639c2e4ac6146106f257600080fd5b8063437f78151161024f5780635ddf55831161020857806370a08231116101e257806370a08231146105ea578063715018a61461060a5780637571336a1461061f5780637ca8448a1461063f57600080fd5b80635ddf55831461059e5780636a486a8e146105b45780636ddd1713146105ca57600080fd5b8063437f7815146104cc57806349bd5a5e146104ec5780634a62bb651461050c5780634fbee1931461052657806353371be01461055f578063599270441461057e57600080fd5b806318b9b19a116102bc57806323b872dd1161029657806323b872dd1461045a57806327c8f8351461047a578063313ce5671461049057806339509351146104ac57600080fd5b806318b9b19a1461040e5780631a8145bb14610424578063203e727e1461043a57600080fd5b806299d3861461030e57806306fdde0314610318578063095ea7b31461034357806310d5de53146103735780631694505e146103a357806318160ddd146103ef57600080fd5b3661030957005b600080fd5b610316610961565b005b34801561032457600080fd5b5061032d610c45565b60405161033a9190612703565b60405180910390f35b34801561034f57600080fd5b5061036361035e366004612766565b610cd7565b604051901515815260200161033a565b34801561037f57600080fd5b5061036361038e366004612792565b60186020526000908152604090205460ff1681565b3480156103af57600080fd5b506103d77f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b03909116815260200161033a565b3480156103fb57600080fd5b506002545b60405190815260200161033a565b34801561041a57600080fd5b50610400600f5481565b34801561043057600080fd5b5061040060155481565b34801561044657600080fd5b506103166104553660046127af565b610cee565b34801561046657600080fd5b506103636104753660046127c8565b610dcb565b34801561048657600080fd5b506103d761dead81565b34801561049c57600080fd5b506040516012815260200161033a565b3480156104b857600080fd5b506103636104c7366004612766565b610e75565b3480156104d857600080fd5b506103166104e7366004612792565b610eac565b3480156104f857600080fd5b506006546103d7906001600160a01b031681565b34801561051857600080fd5b506012546103639060ff1681565b34801561053257600080fd5b50610363610541366004612792565b6001600160a01b031660009081526017602052604090205460ff1690565b34801561056b57600080fd5b5060125461036390610100900460ff1681565b34801561058a57600080fd5b506013546103d7906001600160a01b031681565b3480156105aa57600080fd5b5061040060145481565b3480156105c057600080fd5b50610400600e5481565b3480156105d657600080fd5b506012546103639062010000900460ff1681565b3480156105f657600080fd5b50610400610605366004612792565b610f47565b34801561061657600080fd5b50610316610f62565b34801561062b57600080fd5b5061031661063a366004612817565b610f98565b34801561064b57600080fd5b5061031661065a366004612792565b610fed565b34801561066b57600080fd5b5061031661067a366004612792565b61107b565b34801561068b57600080fd5b506005546001600160a01b03166103d7565b3480156106a957600080fd5b506103166106b8366004612850565b611102565b3480156106c957600080fd5b5061032d611148565b3480156106de57600080fd5b506103166106ed366004612817565b611157565b3480156106fe57600080fd5b50610400600d5481565b34801561071457600080fd5b50610363610723366004612766565b61120f565b34801561073457600080fd5b50610363610743366004612766565b6112a8565b34801561075457600080fd5b5061040060095481565b34801561076a57600080fd5b50610363610779366004612792565b60196020526000908152604090205460ff1681565b34801561079a57600080fd5b506103166107a936600461286d565b6112b5565b3480156107ba57600080fd5b506103166107c9366004612817565b61141d565b3480156107da57600080fd5b506103166107e93660046127af565b6114a6565b3480156107fa57600080fd5b5061040060075481565b34801561081057600080fd5b5061036361081f3660046127af565b61157e565b34801561083057600080fd5b5061040060115481565b34801561084657600080fd5b50610400600a5481565b34801561085c57600080fd5b50610400600b5481565b34801561087257600080fd5b506103636116d0565b34801561088757600080fd5b5061040061089636600461286d565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156108cd57600080fd5b5061040060085481565b3480156108e357600080fd5b506012546103d79064010000000090046001600160a01b031681565b34801561090b57600080fd5b50610400600c5481565b34801561092157600080fd5b50610316610930366004612792565b61170d565b34801561094157600080fd5b5061040060105481565b34801561095757600080fd5b5061040060165481565b6005546001600160a01b031633146109945760405162461bcd60e51b815260040161098b9061289b565b60405180910390fd5b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109f2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a1691906128d0565b6001600160a01b031663c9c65396307f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a83573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610aa791906128d0565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610af4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b1891906128d0565b600680546001600160a01b0319166001600160a01b03929092169182179055610b42906001610f98565b600654610b59906001600160a01b031660016117a8565b610b8c307f0000000000000000000000000000000000000000000000000000000000000000610b8730610f47565b6117fc565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663f305d7193430610bc630610f47565b60008033426040518863ffffffff1660e01b8152600401610bec969594939291906128ed565b60606040518083038185885af1158015610c0a573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610c2f9190612928565b50506012805462ffff0019166201010017905550565b606060038054610c5490612956565b80601f0160208091040260200160405190810160405280929190818152602001828054610c8090612956565b8015610ccd5780601f10610ca257610100808354040283529160200191610ccd565b820191906000526020600020905b815481529060010190602001808311610cb057829003601f168201915b5050505050905090565b6000610ce43384846117fc565b5060015b92915050565b6005546001600160a01b03163314610d185760405162461bcd60e51b815260040161098b9061289b565b670de0b6b3a76400006103e8610d2d60025490565b610d389060056129a6565b610d4291906129bd565b610d4c91906129bd565b811015610db35760405162461bcd60e51b815260206004820152602f60248201527f43616e6e6f7420736574206d61785472616e73616374696f6e416d6f756e742060448201526e6c6f776572207468616e20302e352560881b606482015260840161098b565b610dc581670de0b6b3a76400006129a6565b60075550565b6000610dd8848484611920565b6001600160a01b038416600090815260016020908152604080832033845290915290205482811015610e5d5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b606482015260840161098b565b610e6a85338584036117fc565b506001949350505050565b3360008181526001602090815260408083206001600160a01b03871684529091528120549091610ce4918590610b879086906129df565b6005546001600160a01b03163314610ed65760405162461bcd60e51b815260040161098b9061289b565b6012546040516001600160a01b036401000000009092048216918316907fe398a51ced37c654eb1ea08be0948c549e0001c9574663816242517334bd004890600090a3601280546001600160a01b0390921664010000000002640100000000600160c01b0319909216919091179055565b6001600160a01b031660009081526020819052604090205490565b6005546001600160a01b03163314610f8c5760405162461bcd60e51b815260040161098b9061289b565b610f966000611f17565b565b6005546001600160a01b03163314610fc25760405162461bcd60e51b815260040161098b9061289b565b6001600160a01b03919091166000908152601860205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146110175760405162461bcd60e51b815260040161098b9061289b565b6000816001600160a01b03164760405160006040518083038185875af1925050503d8060008114611064576040519150601f19603f3d011682016040523d82523d6000602084013e611069565b606091505b505090508061107757600080fd5b5050565b6005546001600160a01b031633146110a55760405162461bcd60e51b815260040161098b9061289b565b6013546040516001600160a01b03918216918316907f8aa0f85050aca99be43beb823e0457e77966b3baf697a289b03681978f96166890600090a3601380546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b0316331461112c5760405162461bcd60e51b815260040161098b9061289b565b60128054911515620100000262ff000019909216919091179055565b606060048054610c5490612956565b6005546001600160a01b031633146111815760405162461bcd60e51b815260040161098b9061289b565b6006546001600160a01b03908116908316036112055760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b6572506169727300000000000000606482015260840161098b565b61107782826117a8565b3360009081526001602090815260408083206001600160a01b0386168452909152812054828110156112915760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b606482015260840161098b565b61129e33858584036117fc565b5060019392505050565b6000610ce4338484611920565b6005546001600160a01b031633146112df5760405162461bcd60e51b815260040161098b9061289b565b6001600160a01b0382166113355760405162461bcd60e51b815260206004820152601a60248201527f5f746f6b656e20616464726573732063616e6e6f742062652030000000000000604482015260640161098b565b6040516370a0823160e01b81523060048201526000906001600160a01b038416906370a0823190602401602060405180830381865afa15801561137c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113a091906129f2565b60405163a9059cbb60e01b81526001600160a01b038481166004830152602482018390529192509084169063a9059cbb906044016020604051808303816000875af11580156113f3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114179190612a0b565b50505050565b6005546001600160a01b031633146114475760405162461bcd60e51b815260040161098b9061289b565b6001600160a01b038216600081815260176020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b031633146114d05760405162461bcd60e51b815260040161098b9061289b565b670de0b6b3a76400006103e86114e560025490565b6114f090600a6129a6565b6114fa91906129bd565b61150491906129bd565b8110156115665760405162461bcd60e51b815260206004820152602a60248201527f43616e6e6f7420736574206d617857616c6c6574416d6f756e74206c6f776572604482015269207468616e20312e302560b01b606482015260840161098b565b61157881670de0b6b3a76400006129a6565b60095550565b6005546000906001600160a01b031633146115ab5760405162461bcd60e51b815260040161098b9061289b565b620186a06115b860025490565b6115c39060016129a6565b6115cd91906129bd565b82101561163a5760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b606482015260840161098b565b6103e861164660025490565b6116519060056129a6565b61165b91906129bd565b8211156116c75760405162461bcd60e51b815260206004820152603460248201527f5377617020616d6f756e742063616e6e6f742062652068696768657220746861604482015273371018171a92903a37ba30b61039bab838363c9760611b606482015260840161098b565b50600855600190565b6005546000906001600160a01b031633146116fd5760405162461bcd60e51b815260040161098b9061289b565b506012805460ff19169055600190565b6005546001600160a01b031633146117375760405162461bcd60e51b815260040161098b9061289b565b6001600160a01b03811661179c5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161098b565b6117a581611f17565b50565b6001600160a01b038216600081815260196020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b03831661185e5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161098b565b6001600160a01b0382166118bf5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161098b565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166119465760405162461bcd60e51b815260040161098b90612a28565b6001600160a01b03821661196c5760405162461bcd60e51b815260040161098b90612a6d565b806000036119855761198083836000611f69565b505050565b60125460ff1615611ba5576005546001600160a01b038481169116148015906119bc57506005546001600160a01b03838116911614155b80156119d057506001600160a01b03821615155b80156119e757506001600160a01b03821661dead14155b80156119fd57506012546301000000900460ff16155b15611ba557601254610100900460ff16611a95576001600160a01b03831660009081526017602052604090205460ff1680611a5057506001600160a01b03821660009081526017602052604090205460ff165b611a955760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b604482015260640161098b565b6001600160a01b03831660009081526019602052604090205460ff168015611ad657506001600160a01b03821660009081526018602052604090205460ff16155b15611ba557600754811115611b4b5760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b606482015260840161098b565b600954611b5783610f47565b611b6190836129df565b1115611ba55760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b604482015260640161098b565b6000611bb030610f47565b60085490915081108015908190611bcf575060125462010000900460ff165b8015611be557506012546301000000900460ff16155b8015611c0957506001600160a01b03841660009081526019602052604090205460ff165b8015611c2e57506001600160a01b03851660009081526017602052604090205460ff16155b8015611c5357506001600160a01b03841660009081526017602052604090205460ff16155b15611c81576012805463ff00000019166301000000179055611c736120bd565b6012805463ff000000191690555b6012546001600160a01b03861660009081526017602052604090205460ff630100000090920482161591168015611cc257506001600160a01b03851661dead145b15611cd057611cd084612352565b6001600160a01b03861660009081526017602052604090205460ff1680611d0f57506001600160a01b03851660009081526017602052604090205460ff165b15611d18575060005b60008115611f03576001600160a01b03861660009081526019602052604090205460ff168015611d4a57506000600e54115b15611e0857611d6f6064611d69600e548861243a90919063ffffffff16565b9061244d565b9050600e5460105482611d8291906129a6565b611d8c91906129bd565b60156000828254611d9d91906129df565b9091555050600e54601154611db290836129a6565b611dbc91906129bd565b60166000828254611dcd91906129df565b9091555050600e54600f54611de290836129a6565b611dec91906129bd565b60146000828254611dfd91906129df565b90915550611ee59050565b6001600160a01b03871660009081526019602052604090205460ff168015611e3257506000600a54115b15611ee557611e516064611d69600a548861243a90919063ffffffff16565b9050600a54600c5482611e6491906129a6565b611e6e91906129bd565b60156000828254611e7f91906129df565b9091555050600a54600d54611e9490836129a6565b611e9e91906129bd565b60166000828254611eaf91906129df565b9091555050600a54600b54611ec490836129a6565b611ece91906129bd565b60146000828254611edf91906129df565b90915550505b8015611ef657611ef6873083611f69565b611f008186612ab0565b94505b611f0e878787611f69565b50505050505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038316611f8f5760405162461bcd60e51b815260040161098b90612a28565b6001600160a01b038216611fb55760405162461bcd60e51b815260040161098b90612a6d565b6001600160a01b0383166000908152602081905260409020548181101561202d5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b606482015260840161098b565b6001600160a01b038085166000908152602081905260408082208585039055918516815290812080548492906120649084906129df565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516120b091815260200190565b60405180910390a3611417565b60006120c830610f47565b905060006120ea601260049054906101000a90046001600160a01b0316610f47565b9050600060165460145460155461210191906129df565b61210b91906129df565b905060006008548311156121385780612125576000612127565b835b60095461213491906129bd565b6014555b831580612143575081155b1561214e5750505050565b60085484111561215e5760085493505b60006002836015548761217191906129a6565b61217b91906129bd565b61218591906129bd565b905060006121938683612459565b90504761219f82612465565b60006121ab4783612459565b905060006121d960026015546121c191906129bd565b6121cb9089612ab0565b601454611d6990859061243a565b9050600061220760026015546121ef91906129bd565b6121f9908a612ab0565b601654611d6990869061243a565b90506000816122168486612ab0565b6122209190612ab0565b60006015819055601481905560168190556013546040519293506001600160a01b031691849181818185875af1925050503d806000811461227d576040519150601f19603f3d011682016040523d82523d6000602084013e612282565b606091505b509098505086158015906122965750600081115b156122e9576122a58782612625565b601554604080518881526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6012546040516401000000009091046001600160a01b0316904790600081818185875af1925050503d806000811461233d576040519150601f19603f3d011682016040523d82523d6000602084013e612342565b606091505b5050505050505050505050505050565b60065461237e906001600160a01b031661dead8361236f83610f47565b6123799190612ab0565b611f69565b600660009054906101000a90046001600160a01b03166001600160a01b031663fff6cae96040518163ffffffff1660e01b8152600401600060405180830381600087803b1580156123ce57600080fd5b505af11580156123e2573d6000803e3d6000fd5b505050506123f76123f230610f47565b612465565b6012546040516001600160a01b0364010000000090920491909116904780156108fc02916000818181858888f19350505050158015611077573d6000803e3d6000fd5b600061244682846129a6565b9392505050565b600061244682846129bd565b60006124468284612ab0565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061249a5761249a612ac3565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015612518573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061253c91906128d0565b8160018151811061254f5761254f612ac3565b60200260200101906001600160a01b031690816001600160a01b03168152505061259a307f0000000000000000000000000000000000000000000000000000000000000000846117fc565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac947906125ef908590600090869030904290600401612ad9565b600060405180830381600087803b15801561260957600080fd5b505af115801561261d573d6000803e3d6000fd5b505050505050565b612650307f0000000000000000000000000000000000000000000000000000000000000000846117fc565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663f305d7198230856000806126976005546001600160a01b031690565b426040518863ffffffff1660e01b81526004016126b9969594939291906128ed565b60606040518083038185885af11580156126d7573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906126fc9190612928565b5050505050565b600060208083528351808285015260005b8181101561273057858101830151858201604001528201612714565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b03811681146117a557600080fd5b6000806040838503121561277957600080fd5b823561278481612751565b946020939093013593505050565b6000602082840312156127a457600080fd5b813561244681612751565b6000602082840312156127c157600080fd5b5035919050565b6000806000606084860312156127dd57600080fd5b83356127e881612751565b925060208401356127f881612751565b929592945050506040919091013590565b80151581146117a557600080fd5b6000806040838503121561282a57600080fd5b823561283581612751565b9150602083013561284581612809565b809150509250929050565b60006020828403121561286257600080fd5b813561244681612809565b6000806040838503121561288057600080fd5b823561288b81612751565b9150602083013561284581612751565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b6000602082840312156128e257600080fd5b815161244681612751565b6001600160a01b039687168152602081019590955260408501939093526060840191909152909216608082015260a081019190915260c00190565b60008060006060848603121561293d57600080fd5b8351925060208401519150604084015190509250925092565b600181811c9082168061296a57607f821691505b60208210810361298a57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082028115828204841417610ce857610ce8612990565b6000826129da57634e487b7160e01b600052601260045260246000fd5b500490565b80820180821115610ce857610ce8612990565b600060208284031215612a0457600080fd5b5051919050565b600060208284031215612a1d57600080fd5b815161244681612809565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b81810381811115610ce857610ce8612990565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015612b295784516001600160a01b031683529383019391830191600101612b04565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220edcb90e9c999dd691b6a11829ccc6d3bccfadca541aefa6d4d862476e4574b3164736f6c634300081300334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572

Deployed Bytecode

0x6080604052600436106103025760003560e01c80637cb332bb11610190578063c8c8ebe4116100dc578063dd62ed3e11610095578063f11a24d31161006f578063f11a24d3146108ff578063f2fde38b14610915578063f637434214610935578063fde83a341461094b57600080fd5b8063dd62ed3e1461087b578063e2f45605146108c1578063e803cee0146108d757600080fd5b8063c8c8ebe4146107ee578063d257b34f14610804578063d729715f14610824578063d85ba0631461083a578063d92c842c14610850578063db05e5cb1461086657600080fd5b8063a457c2d711610149578063b62496f511610123578063b62496f51461075e578063bc205ad31461078e578063c0246668146107ae578063c18bc195146107ce57600080fd5b8063a457c2d714610708578063a9059cbb14610728578063aa4bde281461074857600080fd5b80637cb332bb1461065f5780638da5cb5b1461067f578063924de9b71461069d57806395d89b41146106bd5780639a7a23d6146106d25780639c2e4ac6146106f257600080fd5b8063437f78151161024f5780635ddf55831161020857806370a08231116101e257806370a08231146105ea578063715018a61461060a5780637571336a1461061f5780637ca8448a1461063f57600080fd5b80635ddf55831461059e5780636a486a8e146105b45780636ddd1713146105ca57600080fd5b8063437f7815146104cc57806349bd5a5e146104ec5780634a62bb651461050c5780634fbee1931461052657806353371be01461055f578063599270441461057e57600080fd5b806318b9b19a116102bc57806323b872dd1161029657806323b872dd1461045a57806327c8f8351461047a578063313ce5671461049057806339509351146104ac57600080fd5b806318b9b19a1461040e5780631a8145bb14610424578063203e727e1461043a57600080fd5b806299d3861461030e57806306fdde0314610318578063095ea7b31461034357806310d5de53146103735780631694505e146103a357806318160ddd146103ef57600080fd5b3661030957005b600080fd5b610316610961565b005b34801561032457600080fd5b5061032d610c45565b60405161033a9190612703565b60405180910390f35b34801561034f57600080fd5b5061036361035e366004612766565b610cd7565b604051901515815260200161033a565b34801561037f57600080fd5b5061036361038e366004612792565b60186020526000908152604090205460ff1681565b3480156103af57600080fd5b506103d77f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b03909116815260200161033a565b3480156103fb57600080fd5b506002545b60405190815260200161033a565b34801561041a57600080fd5b50610400600f5481565b34801561043057600080fd5b5061040060155481565b34801561044657600080fd5b506103166104553660046127af565b610cee565b34801561046657600080fd5b506103636104753660046127c8565b610dcb565b34801561048657600080fd5b506103d761dead81565b34801561049c57600080fd5b506040516012815260200161033a565b3480156104b857600080fd5b506103636104c7366004612766565b610e75565b3480156104d857600080fd5b506103166104e7366004612792565b610eac565b3480156104f857600080fd5b506006546103d7906001600160a01b031681565b34801561051857600080fd5b506012546103639060ff1681565b34801561053257600080fd5b50610363610541366004612792565b6001600160a01b031660009081526017602052604090205460ff1690565b34801561056b57600080fd5b5060125461036390610100900460ff1681565b34801561058a57600080fd5b506013546103d7906001600160a01b031681565b3480156105aa57600080fd5b5061040060145481565b3480156105c057600080fd5b50610400600e5481565b3480156105d657600080fd5b506012546103639062010000900460ff1681565b3480156105f657600080fd5b50610400610605366004612792565b610f47565b34801561061657600080fd5b50610316610f62565b34801561062b57600080fd5b5061031661063a366004612817565b610f98565b34801561064b57600080fd5b5061031661065a366004612792565b610fed565b34801561066b57600080fd5b5061031661067a366004612792565b61107b565b34801561068b57600080fd5b506005546001600160a01b03166103d7565b3480156106a957600080fd5b506103166106b8366004612850565b611102565b3480156106c957600080fd5b5061032d611148565b3480156106de57600080fd5b506103166106ed366004612817565b611157565b3480156106fe57600080fd5b50610400600d5481565b34801561071457600080fd5b50610363610723366004612766565b61120f565b34801561073457600080fd5b50610363610743366004612766565b6112a8565b34801561075457600080fd5b5061040060095481565b34801561076a57600080fd5b50610363610779366004612792565b60196020526000908152604090205460ff1681565b34801561079a57600080fd5b506103166107a936600461286d565b6112b5565b3480156107ba57600080fd5b506103166107c9366004612817565b61141d565b3480156107da57600080fd5b506103166107e93660046127af565b6114a6565b3480156107fa57600080fd5b5061040060075481565b34801561081057600080fd5b5061036361081f3660046127af565b61157e565b34801561083057600080fd5b5061040060115481565b34801561084657600080fd5b50610400600a5481565b34801561085c57600080fd5b50610400600b5481565b34801561087257600080fd5b506103636116d0565b34801561088757600080fd5b5061040061089636600461286d565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156108cd57600080fd5b5061040060085481565b3480156108e357600080fd5b506012546103d79064010000000090046001600160a01b031681565b34801561090b57600080fd5b50610400600c5481565b34801561092157600080fd5b50610316610930366004612792565b61170d565b34801561094157600080fd5b5061040060105481565b34801561095757600080fd5b5061040060165481565b6005546001600160a01b031633146109945760405162461bcd60e51b815260040161098b9061289b565b60405180910390fd5b7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109f2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a1691906128d0565b6001600160a01b031663c9c65396307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a83573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610aa791906128d0565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610af4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b1891906128d0565b600680546001600160a01b0319166001600160a01b03929092169182179055610b42906001610f98565b600654610b59906001600160a01b031660016117a8565b610b8c307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d610b8730610f47565b6117fc565b7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663f305d7193430610bc630610f47565b60008033426040518863ffffffff1660e01b8152600401610bec969594939291906128ed565b60606040518083038185885af1158015610c0a573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610c2f9190612928565b50506012805462ffff0019166201010017905550565b606060038054610c5490612956565b80601f0160208091040260200160405190810160405280929190818152602001828054610c8090612956565b8015610ccd5780601f10610ca257610100808354040283529160200191610ccd565b820191906000526020600020905b815481529060010190602001808311610cb057829003601f168201915b5050505050905090565b6000610ce43384846117fc565b5060015b92915050565b6005546001600160a01b03163314610d185760405162461bcd60e51b815260040161098b9061289b565b670de0b6b3a76400006103e8610d2d60025490565b610d389060056129a6565b610d4291906129bd565b610d4c91906129bd565b811015610db35760405162461bcd60e51b815260206004820152602f60248201527f43616e6e6f7420736574206d61785472616e73616374696f6e416d6f756e742060448201526e6c6f776572207468616e20302e352560881b606482015260840161098b565b610dc581670de0b6b3a76400006129a6565b60075550565b6000610dd8848484611920565b6001600160a01b038416600090815260016020908152604080832033845290915290205482811015610e5d5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b606482015260840161098b565b610e6a85338584036117fc565b506001949350505050565b3360008181526001602090815260408083206001600160a01b03871684529091528120549091610ce4918590610b879086906129df565b6005546001600160a01b03163314610ed65760405162461bcd60e51b815260040161098b9061289b565b6012546040516001600160a01b036401000000009092048216918316907fe398a51ced37c654eb1ea08be0948c549e0001c9574663816242517334bd004890600090a3601280546001600160a01b0390921664010000000002640100000000600160c01b0319909216919091179055565b6001600160a01b031660009081526020819052604090205490565b6005546001600160a01b03163314610f8c5760405162461bcd60e51b815260040161098b9061289b565b610f966000611f17565b565b6005546001600160a01b03163314610fc25760405162461bcd60e51b815260040161098b9061289b565b6001600160a01b03919091166000908152601860205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146110175760405162461bcd60e51b815260040161098b9061289b565b6000816001600160a01b03164760405160006040518083038185875af1925050503d8060008114611064576040519150601f19603f3d011682016040523d82523d6000602084013e611069565b606091505b505090508061107757600080fd5b5050565b6005546001600160a01b031633146110a55760405162461bcd60e51b815260040161098b9061289b565b6013546040516001600160a01b03918216918316907f8aa0f85050aca99be43beb823e0457e77966b3baf697a289b03681978f96166890600090a3601380546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b0316331461112c5760405162461bcd60e51b815260040161098b9061289b565b60128054911515620100000262ff000019909216919091179055565b606060048054610c5490612956565b6005546001600160a01b031633146111815760405162461bcd60e51b815260040161098b9061289b565b6006546001600160a01b03908116908316036112055760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b6572506169727300000000000000606482015260840161098b565b61107782826117a8565b3360009081526001602090815260408083206001600160a01b0386168452909152812054828110156112915760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b606482015260840161098b565b61129e33858584036117fc565b5060019392505050565b6000610ce4338484611920565b6005546001600160a01b031633146112df5760405162461bcd60e51b815260040161098b9061289b565b6001600160a01b0382166113355760405162461bcd60e51b815260206004820152601a60248201527f5f746f6b656e20616464726573732063616e6e6f742062652030000000000000604482015260640161098b565b6040516370a0823160e01b81523060048201526000906001600160a01b038416906370a0823190602401602060405180830381865afa15801561137c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113a091906129f2565b60405163a9059cbb60e01b81526001600160a01b038481166004830152602482018390529192509084169063a9059cbb906044016020604051808303816000875af11580156113f3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114179190612a0b565b50505050565b6005546001600160a01b031633146114475760405162461bcd60e51b815260040161098b9061289b565b6001600160a01b038216600081815260176020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b031633146114d05760405162461bcd60e51b815260040161098b9061289b565b670de0b6b3a76400006103e86114e560025490565b6114f090600a6129a6565b6114fa91906129bd565b61150491906129bd565b8110156115665760405162461bcd60e51b815260206004820152602a60248201527f43616e6e6f7420736574206d617857616c6c6574416d6f756e74206c6f776572604482015269207468616e20312e302560b01b606482015260840161098b565b61157881670de0b6b3a76400006129a6565b60095550565b6005546000906001600160a01b031633146115ab5760405162461bcd60e51b815260040161098b9061289b565b620186a06115b860025490565b6115c39060016129a6565b6115cd91906129bd565b82101561163a5760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b606482015260840161098b565b6103e861164660025490565b6116519060056129a6565b61165b91906129bd565b8211156116c75760405162461bcd60e51b815260206004820152603460248201527f5377617020616d6f756e742063616e6e6f742062652068696768657220746861604482015273371018171a92903a37ba30b61039bab838363c9760611b606482015260840161098b565b50600855600190565b6005546000906001600160a01b031633146116fd5760405162461bcd60e51b815260040161098b9061289b565b506012805460ff19169055600190565b6005546001600160a01b031633146117375760405162461bcd60e51b815260040161098b9061289b565b6001600160a01b03811661179c5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161098b565b6117a581611f17565b50565b6001600160a01b038216600081815260196020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b03831661185e5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161098b565b6001600160a01b0382166118bf5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161098b565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166119465760405162461bcd60e51b815260040161098b90612a28565b6001600160a01b03821661196c5760405162461bcd60e51b815260040161098b90612a6d565b806000036119855761198083836000611f69565b505050565b60125460ff1615611ba5576005546001600160a01b038481169116148015906119bc57506005546001600160a01b03838116911614155b80156119d057506001600160a01b03821615155b80156119e757506001600160a01b03821661dead14155b80156119fd57506012546301000000900460ff16155b15611ba557601254610100900460ff16611a95576001600160a01b03831660009081526017602052604090205460ff1680611a5057506001600160a01b03821660009081526017602052604090205460ff165b611a955760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b604482015260640161098b565b6001600160a01b03831660009081526019602052604090205460ff168015611ad657506001600160a01b03821660009081526018602052604090205460ff16155b15611ba557600754811115611b4b5760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b606482015260840161098b565b600954611b5783610f47565b611b6190836129df565b1115611ba55760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b604482015260640161098b565b6000611bb030610f47565b60085490915081108015908190611bcf575060125462010000900460ff165b8015611be557506012546301000000900460ff16155b8015611c0957506001600160a01b03841660009081526019602052604090205460ff165b8015611c2e57506001600160a01b03851660009081526017602052604090205460ff16155b8015611c5357506001600160a01b03841660009081526017602052604090205460ff16155b15611c81576012805463ff00000019166301000000179055611c736120bd565b6012805463ff000000191690555b6012546001600160a01b03861660009081526017602052604090205460ff630100000090920482161591168015611cc257506001600160a01b03851661dead145b15611cd057611cd084612352565b6001600160a01b03861660009081526017602052604090205460ff1680611d0f57506001600160a01b03851660009081526017602052604090205460ff165b15611d18575060005b60008115611f03576001600160a01b03861660009081526019602052604090205460ff168015611d4a57506000600e54115b15611e0857611d6f6064611d69600e548861243a90919063ffffffff16565b9061244d565b9050600e5460105482611d8291906129a6565b611d8c91906129bd565b60156000828254611d9d91906129df565b9091555050600e54601154611db290836129a6565b611dbc91906129bd565b60166000828254611dcd91906129df565b9091555050600e54600f54611de290836129a6565b611dec91906129bd565b60146000828254611dfd91906129df565b90915550611ee59050565b6001600160a01b03871660009081526019602052604090205460ff168015611e3257506000600a54115b15611ee557611e516064611d69600a548861243a90919063ffffffff16565b9050600a54600c5482611e6491906129a6565b611e6e91906129bd565b60156000828254611e7f91906129df565b9091555050600a54600d54611e9490836129a6565b611e9e91906129bd565b60166000828254611eaf91906129df565b9091555050600a54600b54611ec490836129a6565b611ece91906129bd565b60146000828254611edf91906129df565b90915550505b8015611ef657611ef6873083611f69565b611f008186612ab0565b94505b611f0e878787611f69565b50505050505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038316611f8f5760405162461bcd60e51b815260040161098b90612a28565b6001600160a01b038216611fb55760405162461bcd60e51b815260040161098b90612a6d565b6001600160a01b0383166000908152602081905260409020548181101561202d5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b606482015260840161098b565b6001600160a01b038085166000908152602081905260408082208585039055918516815290812080548492906120649084906129df565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516120b091815260200190565b60405180910390a3611417565b60006120c830610f47565b905060006120ea601260049054906101000a90046001600160a01b0316610f47565b9050600060165460145460155461210191906129df565b61210b91906129df565b905060006008548311156121385780612125576000612127565b835b60095461213491906129bd565b6014555b831580612143575081155b1561214e5750505050565b60085484111561215e5760085493505b60006002836015548761217191906129a6565b61217b91906129bd565b61218591906129bd565b905060006121938683612459565b90504761219f82612465565b60006121ab4783612459565b905060006121d960026015546121c191906129bd565b6121cb9089612ab0565b601454611d6990859061243a565b9050600061220760026015546121ef91906129bd565b6121f9908a612ab0565b601654611d6990869061243a565b90506000816122168486612ab0565b6122209190612ab0565b60006015819055601481905560168190556013546040519293506001600160a01b031691849181818185875af1925050503d806000811461227d576040519150601f19603f3d011682016040523d82523d6000602084013e612282565b606091505b509098505086158015906122965750600081115b156122e9576122a58782612625565b601554604080518881526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6012546040516401000000009091046001600160a01b0316904790600081818185875af1925050503d806000811461233d576040519150601f19603f3d011682016040523d82523d6000602084013e612342565b606091505b5050505050505050505050505050565b60065461237e906001600160a01b031661dead8361236f83610f47565b6123799190612ab0565b611f69565b600660009054906101000a90046001600160a01b03166001600160a01b031663fff6cae96040518163ffffffff1660e01b8152600401600060405180830381600087803b1580156123ce57600080fd5b505af11580156123e2573d6000803e3d6000fd5b505050506123f76123f230610f47565b612465565b6012546040516001600160a01b0364010000000090920491909116904780156108fc02916000818181858888f19350505050158015611077573d6000803e3d6000fd5b600061244682846129a6565b9392505050565b600061244682846129bd565b60006124468284612ab0565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061249a5761249a612ac3565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015612518573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061253c91906128d0565b8160018151811061254f5761254f612ac3565b60200260200101906001600160a01b031690816001600160a01b03168152505061259a307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d846117fc565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac947906125ef908590600090869030904290600401612ad9565b600060405180830381600087803b15801561260957600080fd5b505af115801561261d573d6000803e3d6000fd5b505050505050565b612650307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d846117fc565b7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663f305d7198230856000806126976005546001600160a01b031690565b426040518863ffffffff1660e01b81526004016126b9969594939291906128ed565b60606040518083038185885af11580156126d7573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906126fc9190612928565b5050505050565b600060208083528351808285015260005b8181101561273057858101830151858201604001528201612714565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b03811681146117a557600080fd5b6000806040838503121561277957600080fd5b823561278481612751565b946020939093013593505050565b6000602082840312156127a457600080fd5b813561244681612751565b6000602082840312156127c157600080fd5b5035919050565b6000806000606084860312156127dd57600080fd5b83356127e881612751565b925060208401356127f881612751565b929592945050506040919091013590565b80151581146117a557600080fd5b6000806040838503121561282a57600080fd5b823561283581612751565b9150602083013561284581612809565b809150509250929050565b60006020828403121561286257600080fd5b813561244681612809565b6000806040838503121561288057600080fd5b823561288b81612751565b9150602083013561284581612751565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b6000602082840312156128e257600080fd5b815161244681612751565b6001600160a01b039687168152602081019590955260408501939093526060840191909152909216608082015260a081019190915260c00190565b60008060006060848603121561293d57600080fd5b8351925060208401519150604084015190509250925092565b600181811c9082168061296a57607f821691505b60208210810361298a57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082028115828204841417610ce857610ce8612990565b6000826129da57634e487b7160e01b600052601260045260246000fd5b500490565b80820180821115610ce857610ce8612990565b600060208284031215612a0457600080fd5b5051919050565b600060208284031215612a1d57600080fd5b815161244681612809565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b81810381811115610ce857610ce8612990565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015612b295784516001600160a01b031683529383019391830191600101612b04565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220edcb90e9c999dd691b6a11829ccc6d3bccfadca541aefa6d4d862476e4574b3164736f6c63430008130033

Deployed Bytecode Sourcemap

30974:14819:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;36897:597;;;:::i;:::-;;9036:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;11203:169;;;;;;;;;;-1:-1:-1;11203:169:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;11203:169:0;1023:187:1;32073:63:0;;;;;;;;;;-1:-1:-1;32073:63:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;31052:51;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;1658:32:1;;;1640:51;;1628:2;1613:18;31052:51:0;1467:230:1;10156:108:0;;;;;;;;;;-1:-1:-1;10244:12:0;;10156:108;;;1848:25:1;;;1836:2;1821:18;10156:108:0;1702:177:1;31499:25:0;;;;;;;;;;;;;;;;31858:33;;;;;;;;;;;;;;;;35094:275;;;;;;;;;;-1:-1:-1;35094:275:0;;;;;:::i;:::-;;:::i;11854:492::-;;;;;;;;;;-1:-1:-1;11854:492:0;;;;;:::i;:::-;;:::i;31145:53::-;;;;;;;;;;;;31191:6;31145:53;;9998:93;;;;;;;;;;-1:-1:-1;9998:93:0;;10081:2;2880:36:1;;2868:2;2853:18;9998:93:0;2738:184:1;12755:215:0;;;;;;;;;;-1:-1:-1;12755:215:0;;;;;:::i;:::-;;:::i;36221:166::-;;;;;;;;;;-1:-1:-1;36221:166:0;;;;;:::i;:::-;;:::i;31110:28::-;;;;;;;;;;-1:-1:-1;31110:28:0;;;;-1:-1:-1;;;;;31110:28:0;;;31604:33;;;;;;;;;;-1:-1:-1;31604:33:0;;;;;;;;38414:126;;;;;;;;;;-1:-1:-1;38414:126:0;;;;;:::i;:::-;-1:-1:-1;;;;;38504:28:0;38480:4;38504:28;;;:19;:28;;;;;;;;;38414:126;31644:34;;;;;;;;;;-1:-1:-1;31644:34:0;;;;;;;;;;;31786:25;;;;;;;;;;-1:-1:-1;31786:25:0;;;;-1:-1:-1;;;;;31786:25:0;;;31824:27;;;;;;;;;;;;;;;;31464:28;;;;;;;;;;;;;;;;31685:31;;;;;;;;;;-1:-1:-1;31685:31:0;;;;;;;;;;;10327:127;;;;;;;;;;-1:-1:-1;10327:127:0;;;;;:::i;:::-;;:::i;2554:103::-;;;;;;;;;;;;;:::i;35654:167::-;;;;;;;;;;-1:-1:-1;35654:167:0;;;;;:::i;:::-;;:::i;40777:196::-;;;;;;;;;;-1:-1:-1;40777:196:0;;;;;:::i;:::-;;:::i;38245:161::-;;;;;;;;;;-1:-1:-1;38245:161:0;;;;;:::i;:::-;;:::i;1903:87::-;;;;;;;;;;-1:-1:-1;1976:6:0;;-1:-1:-1;;;;;1976:6:0;1903:87;;35917:100;;;;;;;;;;-1:-1:-1;35917:100:0;;;;;:::i;:::-;;:::i;9255:104::-;;;;;;;;;;;;;:::i;36585:304::-;;;;;;;;;;-1:-1:-1;36585:304:0;;;;;:::i;:::-;;:::i;31430:25::-;;;;;;;;;;;;;;;;13473:413;;;;;;;;;;-1:-1:-1;13473:413:0;;;;;:::i;:::-;;:::i;10667:175::-;;;;;;;;;;-1:-1:-1;10667:175:0;;;;;:::i;:::-;;:::i;31289:30::-;;;;;;;;;;;;;;;;32294:57;;;;;;;;;;-1:-1:-1;32294:57:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;40481:288;;;;;;;;;;-1:-1:-1;40481:288:0;;;;;:::i;:::-;;:::i;36395:182::-;;;;;;;;;;-1:-1:-1;36395:182:0;;;;;:::i;:::-;;:::i;35377:269::-;;;;;;;;;;-1:-1:-1;35377:269:0;;;;;:::i;:::-;;:::i;31207:35::-;;;;;;;;;;;;;;;;37740:497;;;;;;;;;;-1:-1:-1;37740:497:0;;;;;:::i;:::-;;:::i;31569:26::-;;;;;;;;;;;;;;;;31328:27;;;;;;;;;;;;;;;;31362:24;;;;;;;;;;;;;;;;37546:124;;;;;;;;;;;;;:::i;10905:151::-;;;;;;;;;;-1:-1:-1;10905:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;11021:18:0;;;10994:7;11021:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;10905:151;31249:33;;;;;;;;;;;;;;;;31755:24;;;;;;;;;;-1:-1:-1;31755:24:0;;;;;;;-1:-1:-1;;;;;31755:24:0;;;31393:30;;;;;;;;;;;;;;;;2812:201;;;;;;;;;;-1:-1:-1;2812:201:0;;;;;:::i;:::-;;:::i;31531:31::-;;;;;;;;;;;;;;;;31898:28;;;;;;;;;;;;;;;;36897:597;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;;;;;;;;;36992:15:::1;-1:-1:-1::0;;;;;36992:23:0::1;;:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;36974:55:0::1;;37038:4;37045:15;-1:-1:-1::0;;;;;37045:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;36974:94;::::0;-1:-1:-1;;;;;;36974:94:0::1;::::0;;;;;;-1:-1:-1;;;;;4923:15:1;;;36974:94:0::1;::::0;::::1;4905:34:1::0;4975:15;;4955:18;;;4948:43;4840:18;;36974:94:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;36958:13;:110:::0;;-1:-1:-1;;;;;;36958:110:0::1;-1:-1:-1::0;;;;;36958:110:0;;;::::1;::::0;;::::1;::::0;;37079:55:::1;::::0;-1:-1:-1;37079:25:0::1;:55::i;:::-;37182:13;::::0;37145:58:::1;::::0;-1:-1:-1;;;;;37182:13:0::1;::::0;37145:28:::1;:58::i;:::-;37214:75;37231:4;37246:15;37264:24;37282:4;37264:9;:24::i;:::-;37214:8;:75::i;:::-;37300:15;-1:-1:-1::0;;;;;37300:31:0::1;;37339:9;37358:4;37365:24;37383:4;37365:9;:24::i;:::-;37391:1;37394::::0;37397:10:::1;37409:15;37300:125;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;37436:14:0::1;:21:::0;;-1:-1:-1;;37468:18:0;;;;;-1:-1:-1;36897:597:0:o;9036:100::-;9090:13;9123:5;9116:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9036:100;:::o;11203:169::-;11286:4;11303:39;852:10;11326:7;11335:6;11303:8;:39::i;:::-;-1:-1:-1;11360:4:0;11203:169;;;;;:::o;35094:275::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;35231:4:::1;35223;35202:13;10244:12:::0;;;10156:108;35202:13:::1;:17;::::0;35218:1:::1;35202:17;:::i;:::-;35201:26;;;;:::i;:::-;35200:35;;;;:::i;:::-;35190:6;:45;;35168:142;;;::::0;-1:-1:-1;;;35168:142:0;;7039:2:1;35168:142:0::1;::::0;::::1;7021:21:1::0;7078:2;7058:18;;;7051:30;7117:34;7097:18;;;7090:62;-1:-1:-1;;;7168:18:1;;;7161:45;7223:19;;35168:142:0::1;6837:411:1::0;35168:142:0::1;35344:17;:6:::0;35354::::1;35344:17;:::i;:::-;35321:20;:40:::0;-1:-1:-1;35094:275:0:o;11854:492::-;11994:4;12011:36;12021:6;12029:9;12040:6;12011:9;:36::i;:::-;-1:-1:-1;;;;;12087:19:0;;12060:24;12087:19;;;:11;:19;;;;;;;;852:10;12087:33;;;;;;;;12139:26;;;;12131:79;;;;-1:-1:-1;;;12131:79:0;;7455:2:1;12131:79:0;;;7437:21:1;7494:2;7474:18;;;7467:30;7533:34;7513:18;;;7506:62;-1:-1:-1;;;7584:18:1;;;7577:38;7632:19;;12131:79:0;7253:404:1;12131:79:0;12246:57;12255:6;852:10;12296:6;12277:16;:25;12246:8;:57::i;:::-;-1:-1:-1;12334:4:0;;11854:492;-1:-1:-1;;;;11854:492:0:o;12755:215::-;852:10;12843:4;12892:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;12892:34:0;;;;;;;;;;12843:4;;12860:80;;12883:7;;12892:47;;12929:10;;12892:47;:::i;36221:166::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;36334:9:::1;::::0;36303:41:::1;::::0;-1:-1:-1;;;;;36334:9:0;;;::::1;::::0;::::1;::::0;36303:41;::::1;::::0;::::1;::::0;;;::::1;36355:9;:24:::0;;-1:-1:-1;;;;;36355:24:0;;::::1;::::0;::::1;-1:-1:-1::0;;;;;;36355:24:0;;::::1;::::0;;;::::1;::::0;;36221:166::o;10327:127::-;-1:-1:-1;;;;;10428:18:0;10401:7;10428:18;;;;;;;;;;;;10327:127::o;2554:103::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;2619:30:::1;2646:1;2619:18;:30::i;:::-;2554:103::o:0;35654:167::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35767:39:0;;;::::1;;::::0;;;:31:::1;:39;::::0;;;;:46;;-1:-1:-1;;35767:46:0::1;::::0;::::1;;::::0;;;::::1;::::0;;35654:167::o;40777:196::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;40850:12:::1;40868:6;-1:-1:-1::0;;;;;40868:11:0::1;40901:21;40868:70;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;40849:89;;;40957:7;40949:16;;;::::0;::::1;;40838:135;40777:196:::0;:::o;38245:161::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;38354:10:::1;::::0;38325:40:::1;::::0;-1:-1:-1;;;;;38354:10:0;;::::1;::::0;38325:40;::::1;::::0;::::1;::::0;38354:10:::1;::::0;38325:40:::1;38376:10;:22:::0;;-1:-1:-1;;;;;;38376:22:0::1;-1:-1:-1::0;;;;;38376:22:0;;;::::1;::::0;;;::::1;::::0;;38245:161::o;35917:100::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;35988:11:::1;:21:::0;;;::::1;;::::0;::::1;-1:-1:-1::0;;35988:21:0;;::::1;::::0;;;::::1;::::0;;35917:100::o;9255:104::-;9311:13;9344:7;9337:14;;;;;:::i;36585:304::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;36729:13:::1;::::0;-1:-1:-1;;;;;36729:13:0;;::::1;36721:21:::0;;::::1;::::0;36699:128:::1;;;::::0;-1:-1:-1;;;36699:128:0;;8204:2:1;36699:128:0::1;::::0;::::1;8186:21:1::0;8243:2;8223:18;;;8216:30;8282:34;8262:18;;;8255:62;8353:27;8333:18;;;8326:55;8398:19;;36699:128:0::1;8002:421:1::0;36699:128:0::1;36840:41;36869:4;36875:5;36840:28;:41::i;13473:413::-:0;852:10;13566:4;13610:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;13610:34:0;;;;;;;;;;13663:35;;;;13655:85;;;;-1:-1:-1;;;13655:85:0;;8630:2:1;13655:85:0;;;8612:21:1;8669:2;8649:18;;;8642:30;8708:34;8688:18;;;8681:62;-1:-1:-1;;;8759:18:1;;;8752:35;8804:19;;13655:85:0;8428:401:1;13655:85:0;13776:67;852:10;13799:7;13827:15;13808:16;:34;13776:8;:67::i;:::-;-1:-1:-1;13874:4:0;;13473:413;-1:-1:-1;;;13473:413:0:o;10667:175::-;10753:4;10770:42;852:10;10794:9;10805:6;10770:9;:42::i;40481:288::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;40576:20:0;::::1;40568:59;;;::::0;-1:-1:-1;;;40568:59:0;;9036:2:1;40568:59:0::1;::::0;::::1;9018:21:1::0;9075:2;9055:18;;;9048:30;9114:28;9094:18;;;9087:56;9160:18;;40568:59:0::1;8834:350:1::0;40568:59:0::1;40665:39;::::0;-1:-1:-1;;;40665:39:0;;40698:4:::1;40665:39;::::0;::::1;1640:51:1::0;40638:24:0::1;::::0;-1:-1:-1;;;;;40665:24:0;::::1;::::0;::::1;::::0;1613:18:1;;40665:39:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;40715:46;::::0;-1:-1:-1;;;40715:46:0;;-1:-1:-1;;;;;9570:32:1;;;40715:46:0::1;::::0;::::1;9552:51:1::0;9619:18;;;9612:34;;;40638:66:0;;-1:-1:-1;40715:23:0;;::::1;::::0;::::1;::::0;9525:18:1;;40715:46:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;40557:212;40481:288:::0;;:::o;36395:182::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;36480:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;36480:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;36535:34;;1163:41:1;;;36535:34:0::1;::::0;1136:18:1;36535:34:0::1;;;;;;;36395:182:::0;;:::o;35377:269::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;35518:4:::1;35510;35488:13;10244:12:::0;;;10156:108;35488:13:::1;:18;::::0;35504:2:::1;35488:18;:::i;:::-;35487:27;;;;:::i;:::-;35486:36;;;;:::i;:::-;35476:6;:46;;35454:138;;;::::0;-1:-1:-1;;;35454:138:0;;10109:2:1;35454:138:0::1;::::0;::::1;10091:21:1::0;10148:2;10128:18;;;10121:30;10187:34;10167:18;;;10160:62;-1:-1:-1;;;10238:18:1;;;10231:40;10288:19;;35454:138:0::1;9907:406:1::0;35454:138:0::1;35621:17;:6:::0;35631::::1;35621:17;:::i;:::-;35603:15;:35:::0;-1:-1:-1;35377:269:0:o;37740:497::-;1976:6;;37848:4;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;37927:6:::1;37906:13;10244:12:::0;;;10156:108;37906:13:::1;:17;::::0;37922:1:::1;37906:17;:::i;:::-;37905:28;;;;:::i;:::-;37892:9;:41;;37870:144;;;::::0;-1:-1:-1;;;37870:144:0;;10520:2:1;37870:144:0::1;::::0;::::1;10502:21:1::0;10559:2;10539:18;;;10532:30;10598:34;10578:18;;;10571:62;-1:-1:-1;;;10649:18:1;;;10642:51;10710:19;;37870:144:0::1;10318:417:1::0;37870:144:0::1;38082:4;38061:13;10244:12:::0;;;10156:108;38061:13:::1;:17;::::0;38077:1:::1;38061:17;:::i;:::-;38060:26;;;;:::i;:::-;38047:9;:39;;38025:141;;;::::0;-1:-1:-1;;;38025:141:0;;10942:2:1;38025:141:0::1;::::0;::::1;10924:21:1::0;10981:2;10961:18;;;10954:30;11020:34;11000:18;;;10993:62;-1:-1:-1;;;11071:18:1;;;11064:50;11131:19;;38025:141:0::1;10740:416:1::0;38025:141:0::1;-1:-1:-1::0;38177:18:0::1;:30:::0;38225:4:::1;::::0;37740:497::o;37546:124::-;1976:6;;37601:4;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;-1:-1:-1;37618:14:0::1;:22:::0;;-1:-1:-1;;37618:22:0::1;::::0;;;37546:124;:::o;2812:201::-;1976:6;;-1:-1:-1;;;;;1976:6:0;852:10;2123:23;2115:68;;;;-1:-1:-1;;;2115:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;2901:22:0;::::1;2893:73;;;::::0;-1:-1:-1;;;2893:73:0;;11363:2:1;2893:73:0::1;::::0;::::1;11345:21:1::0;11402:2;11382:18;;;11375:30;11441:34;11421:18;;;11414:62;-1:-1:-1;;;11492:18:1;;;11485:36;11538:19;;2893:73:0::1;11161:402:1::0;2893:73:0::1;2977:28;2996:8;2977:18;:28::i;:::-;2812:201:::0;:::o;36025:188::-;-1:-1:-1;;;;;36108:31:0;;;;;;:25;:31;;;;;;:39;;-1:-1:-1;;36108:39:0;;;;;;;;;;36165:40;;36108:39;;:31;36165:40;;;36025:188;;:::o;17157:380::-;-1:-1:-1;;;;;17293:19:0;;17285:68;;;;-1:-1:-1;;;17285:68:0;;11770:2:1;17285:68:0;;;11752:21:1;11809:2;11789:18;;;11782:30;11848:34;11828:18;;;11821:62;-1:-1:-1;;;11899:18:1;;;11892:34;11943:19;;17285:68:0;11568:400:1;17285:68:0;-1:-1:-1;;;;;17372:21:0;;17364:68;;;;-1:-1:-1;;;17364:68:0;;12175:2:1;17364:68:0;;;12157:21:1;12214:2;12194:18;;;12187:30;12253:34;12233:18;;;12226:62;-1:-1:-1;;;12304:18:1;;;12297:32;12346:19;;17364:68:0;11973:398:1;17364:68:0;-1:-1:-1;;;;;17445:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;17497:32;;1848:25:1;;;17497:32:0;;1821:18:1;17497:32:0;;;;;;;17157:380;;;:::o;40981:3365::-;-1:-1:-1;;;;;41113:18:0;;41105:68;;;;-1:-1:-1;;;41105:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;41192:16:0;;41184:64;;;;-1:-1:-1;;;41184:64:0;;;;;;;:::i;:::-;41267:6;41277:1;41267:11;41263:93;;41295:28;41311:4;41317:2;41321:1;41295:15;:28::i;:::-;40981:3365;;;:::o;41263:93::-;41372:14;;;;41368:1067;;;1976:6;;-1:-1:-1;;;;;41425:15:0;;;1976:6;;41425:15;;;;:49;;-1:-1:-1;1976:6:0;;-1:-1:-1;;;;;41461:13:0;;;1976:6;;41461:13;;41425:49;:86;;;;-1:-1:-1;;;;;;41495:16:0;;;;41425:86;:128;;;;-1:-1:-1;;;;;;41532:21:0;;41546:6;41532:21;;41425:128;:158;;;;-1:-1:-1;41575:8:0;;;;;;;41574:9;41425:158;41403:1021;;;41623:14;;;;;;;41618:224;;-1:-1:-1;;;;;41696:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;41725:23:0;;;;;;:19;:23;;;;;;;;41696:52;41662:160;;;;-1:-1:-1;;;41662:160:0;;13388:2:1;41662:160:0;;;13370:21:1;13427:2;13407:18;;;13400:30;-1:-1:-1;;;13446:18:1;;;13439:52;13508:18;;41662:160:0;13186:346:1;41662:160:0;-1:-1:-1;;;;;41916:31:0;;;;;;:25;:31;;;;;;;;:92;;;;-1:-1:-1;;;;;;41973:35:0;;;;;;:31;:35;;;;;;;;41972:36;41916:92;41890:519;;;42095:20;;42085:6;:30;;42051:169;;;;-1:-1:-1;;;42051:169:0;;13739:2:1;42051:169:0;;;13721:21:1;13778:2;13758:18;;;13751:30;13817:34;13797:18;;;13790:62;-1:-1:-1;;;13868:18:1;;;13861:51;13929:19;;42051:169:0;13537:417:1;42051:169:0;42303:15;;42286:13;42296:2;42286:9;:13::i;:::-;42277:22;;:6;:22;:::i;:::-;:41;;42243:146;;;;-1:-1:-1;;;42243:146:0;;14161:2:1;42243:146:0;;;14143:21:1;14200:2;14180:18;;;14173:30;-1:-1:-1;;;14219:18:1;;;14212:49;14278:18;;42243:146:0;13959:343:1;42243:146:0;42447:28;42478:24;42496:4;42478:9;:24::i;:::-;42554:18;;42447:55;;-1:-1:-1;42530:42:0;;;;;;;42603:35;;-1:-1:-1;42627:11:0;;;;;;;42603:35;:61;;;;-1:-1:-1;42656:8:0;;;;;;;42655:9;42603:61;:107;;;;-1:-1:-1;;;;;;42681:29:0;;;;;;:25;:29;;;;;;;;42603:107;:150;;;;-1:-1:-1;;;;;;42728:25:0;;;;;;:19;:25;;;;;;;;42727:26;42603:150;:191;;;;-1:-1:-1;;;;;;42771:23:0;;;;;;:19;:23;;;;;;;;42770:24;42603:191;42585:323;;;42821:8;:15;;-1:-1:-1;;42821:15:0;;;;;42853:10;:8;:10::i;:::-;42880:8;:16;;-1:-1:-1;;42880:16:0;;;42585:323;42936:8;;-1:-1:-1;;;;;43046:25:0;;42920:12;43046:25;;;:19;:25;;;;;;42936:8;;;;;;;42935:9;;43046:25;:46;;;;-1:-1:-1;;;;;;43075:17:0;;31191:6;43075:17;43046:46;43042:78;;;43094:26;43113:6;43094:18;:26::i;:::-;-1:-1:-1;;;;;43135:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;43164:23:0;;;;;;:19;:23;;;;;;;;43135:52;43131:100;;;-1:-1:-1;43214:5:0;43131:100;43243:12;43348:7;43344:949;;;-1:-1:-1;;;;;43400:29:0;;;;;;:25;:29;;;;;;;;:50;;;;;43449:1;43433:13;;:17;43400:50;43396:748;;;43478:34;43508:3;43478:25;43489:13;;43478:6;:10;;:25;;;;:::i;:::-;:29;;:34::i;:::-;43471:41;;43581:13;;43561:16;;43554:4;:23;;;;:::i;:::-;43553:41;;;;:::i;:::-;43531:18;;:63;;;;;;;:::i;:::-;;;;-1:-1:-1;;43653:13:0;;43638:11;;43631:18;;:4;:18;:::i;:::-;43630:36;;;;:::i;:::-;43613:13;;:53;;;;;;;:::i;:::-;;;;-1:-1:-1;;43723:13:0;;43709:10;;43702:17;;:4;:17;:::i;:::-;43701:35;;;;:::i;:::-;43685:12;;:51;;;;;;;:::i;:::-;;;;-1:-1:-1;43396:748:0;;-1:-1:-1;43396:748:0;;-1:-1:-1;;;;;43798:31:0;;;;;;:25;:31;;;;;;;;:51;;;;;43848:1;43833:12;;:16;43798:51;43794:350;;;43877:33;43906:3;43877:24;43888:12;;43877:6;:10;;:24;;;;:::i;:33::-;43870:40;;43978:12;;43959:15;;43952:4;:22;;;;:::i;:::-;43951:39;;;;:::i;:::-;43929:18;;:61;;;;;;;:::i;:::-;;;;-1:-1:-1;;44048:12:0;;44034:10;;44027:17;;:4;:17;:::i;:::-;44026:34;;;;:::i;:::-;44009:13;;:51;;;;;;;:::i;:::-;;;;-1:-1:-1;;44116:12:0;;44103:9;;44096:16;;:4;:16;:::i;:::-;44095:33;;;;:::i;:::-;44079:12;;:49;;;;;;;:::i;:::-;;;;-1:-1:-1;;43794:350:0;44164:8;;44160:91;;44193:42;44209:4;44223;44230;44193:15;:42::i;:::-;44267:14;44277:4;44267:14;;:::i;:::-;;;43344:949;44305:33;44321:4;44327:2;44331:6;44305:15;:33::i;:::-;41094:3252;;;;40981:3365;;;:::o;3173:191::-;3266:6;;;-1:-1:-1;;;;;3283:17:0;;;-1:-1:-1;;;;;;3283:17:0;;;;;;;3316:40;;3266:6;;;3283:17;3266:6;;3316:40;;3247:16;;3316:40;3236:128;3173:191;:::o;14376:733::-;-1:-1:-1;;;;;14516:20:0;;14508:70;;;;-1:-1:-1;;;14508:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;14597:23:0;;14589:71;;;;-1:-1:-1;;;14589:71:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;14757:17:0;;14733:21;14757:17;;;;;;;;;;;14793:23;;;;14785:74;;;;-1:-1:-1;;;14785:74:0;;14642:2:1;14785:74:0;;;14624:21:1;14681:2;14661:18;;;14654:30;14720:34;14700:18;;;14693:62;-1:-1:-1;;;14771:18:1;;;14764:36;14817:19;;14785:74:0;14440:402:1;14785:74:0;-1:-1:-1;;;;;14895:17:0;;;:9;:17;;;;;;;;;;;14915:22;;;14895:42;;14959:20;;;;;;;;:30;;14931:6;;14895:9;14959:30;;14931:6;;14959:30;:::i;:::-;;;;;;;;15024:9;-1:-1:-1;;;;;15007:35:0;15016:6;-1:-1:-1;;;;;15007:35:0;;15035:6;15007:35;;;;1848:25:1;;1836:2;1821:18;;1702:177;15007:35:0;;;;;;;;15055:46;40981:3365;38548:1925;38587:23;38613:24;38631:4;38613:9;:24::i;:::-;38587:50;;38648:18;38669:20;38679:9;;;;;;;;;-1:-1:-1;;;;;38679:9:0;38669;:20::i;:::-;38648:41;;38700:25;38790:13;;38762:12;;38728:18;;:46;;;;:::i;:::-;:75;;;;:::i;:::-;38700:103;;38814:12;38856:18;;38843:10;:31;38839:128;;;38925:7;:29;;38953:1;38925:29;;;38935:15;38925:29;38906:15;;:49;;;;:::i;:::-;38891:12;:64;38839:128;38983:20;;;:46;;-1:-1:-1;39007:22:0;;38983:46;38979:85;;;39046:7;;;;38548:1925::o;38979:85::-;39098:18;;39080:15;:36;39076:105;;;39151:18;;39133:36;;39076:105;39242:23;39355:1;39322:17;39287:18;;39269:15;:36;;;;:::i;:::-;39268:71;;;;:::i;:::-;:88;;;;:::i;:::-;39242:114;-1:-1:-1;39367:26:0;39396:36;:15;39242:114;39396:19;:36::i;:::-;39367:65;-1:-1:-1;39473:21:0;39507:36;39367:65;39507:16;:36::i;:::-;39556:18;39577:44;:21;39603:17;39577:25;:44::i;:::-;39556:65;;39634:17;39654:78;39729:1;39708:18;;:22;;;;:::i;:::-;39687:44;;:17;:44;:::i;:::-;39669:12;;39654:28;;:10;;:14;:28::i;:78::-;39634:98;;39753:18;39774:79;39850:1;39829:18;;:22;;;;:::i;:::-;39808:44;;:17;:44;:::i;:::-;39789:13;;39774:29;;:10;;:14;:29::i;:79::-;39753:100;-1:-1:-1;39866:23:0;39753:100;39892:22;39905:9;39892:10;:22;:::i;:::-;:35;;;;:::i;:::-;39961:1;39940:18;:22;;;39973:12;:16;;;40000:13;:17;;;40052:10;;40044:47;;39866:61;;-1:-1:-1;;;;;;40052:10:0;;40076;;40044:47;39961:1;40044:47;40076:10;40052;40044:47;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;40030:61:0;;-1:-1:-1;;40108:19:0;;;;;:42;;;40149:1;40131:15;:19;40108:42;40104:278;;;40167:46;40180:15;40197;40167:12;:46::i;:::-;40337:18;;40233:137;;;15049:25:1;;;15105:2;15090:18;;15083:34;;;15133:18;;;15126:34;;;;40233:137:0;;;;;;15037:2:1;40233:137:0;;;40104:278;40416:9;;40408:57;;40416:9;;;;-1:-1:-1;;;;;40416:9:0;;40439:21;;40408:57;;;;40439:21;40416:9;40408:57;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;;;;38548:1925:0:o;44354:318::-;44438:13;;44422:81;;-1:-1:-1;;;;;44438:13:0;31191:6;44491:11;44466:24;44438:13;44466:9;:24::i;:::-;:36;;;;:::i;:::-;44422:15;:81::i;:::-;44529:13;;;;;;;;;-1:-1:-1;;;;;44529:13:0;-1:-1:-1;;;;;44514:34:0;;:36;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;44561:42;44578:24;44596:4;44578:9;:24::i;:::-;44561:16;:42::i;:::-;44622:9;;44614:50;;-1:-1:-1;;;;;44622:9:0;;;;;;;;;44642:21;44614:50;;;;;;;;;44642:21;44622:9;44614:50;;;;;;;;;;;;;;;;;;;22289:98;22347:7;22374:5;22378:1;22374;:5;:::i;:::-;22367:12;22289:98;-1:-1:-1;;;22289:98:0:o;22688:::-;22746:7;22773:5;22777:1;22773;:5;:::i;21932:98::-;21990:7;22017:5;22021:1;22017;:5;:::i;44680:589::-;44830:16;;;44844:1;44830:16;;;;;;;;44806:21;;44830:16;;;;;;;;;;-1:-1:-1;44830:16:0;44806:40;;44875:4;44857;44862:1;44857:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;44857:23:0;;;-1:-1:-1;;;;;44857:23:0;;;;;44901:15;-1:-1:-1;;;;;44901:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;44891:4;44896:1;44891:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;44891:32:0;;;-1:-1:-1;;;;;44891:32:0;;;;;44936:62;44953:4;44968:15;44986:11;44936:8;:62::i;:::-;45037:224;;-1:-1:-1;;;45037:224:0;;-1:-1:-1;;;;;45037:15:0;:66;;;;:224;;45118:11;;45144:1;;45188:4;;45215;;45235:15;;45037:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;44735:534;44680:589;:::o;45277:513::-;45425:62;45442:4;45457:15;45475:11;45425:8;:62::i;:::-;45530:15;-1:-1:-1;;;;;45530:31:0;;45569:9;45602:4;45622:11;45648:1;45691;45734:7;1976:6;;-1:-1:-1;;;;;1976:6:0;;1903:87;45734:7;45756:15;45530:252;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;45277:513;;:::o;14:548:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:131::-;-1:-1:-1;;;;;642:31:1;;632:42;;622:70;;688:1;685;678:12;703:315;771:6;779;832:2;820:9;811:7;807:23;803:32;800:52;;;848:1;845;838:12;800:52;887:9;874:23;906:31;931:5;906:31;:::i;:::-;956:5;1008:2;993:18;;;;980:32;;-1:-1:-1;;;703:315:1:o;1215:247::-;1274:6;1327:2;1315:9;1306:7;1302:23;1298:32;1295:52;;;1343:1;1340;1333:12;1295:52;1382:9;1369:23;1401:31;1426:5;1401:31;:::i;1884:180::-;1943:6;1996:2;1984:9;1975:7;1971:23;1967:32;1964:52;;;2012:1;2009;2002:12;1964:52;-1:-1:-1;2035:23:1;;1884:180;-1:-1:-1;1884:180:1:o;2069:456::-;2146:6;2154;2162;2215:2;2203:9;2194:7;2190:23;2186:32;2183:52;;;2231:1;2228;2221:12;2183:52;2270:9;2257:23;2289:31;2314:5;2289:31;:::i;:::-;2339:5;-1:-1:-1;2396:2:1;2381:18;;2368:32;2409:33;2368:32;2409:33;:::i;:::-;2069:456;;2461:7;;-1:-1:-1;;;2515:2:1;2500:18;;;;2487:32;;2069:456::o;2927:118::-;3013:5;3006:13;2999:21;2992:5;2989:32;2979:60;;3035:1;3032;3025:12;3050:382;3115:6;3123;3176:2;3164:9;3155:7;3151:23;3147:32;3144:52;;;3192:1;3189;3182:12;3144:52;3231:9;3218:23;3250:31;3275:5;3250:31;:::i;:::-;3300:5;-1:-1:-1;3357:2:1;3342:18;;3329:32;3370:30;3329:32;3370:30;:::i;:::-;3419:7;3409:17;;;3050:382;;;;;:::o;3437:241::-;3493:6;3546:2;3534:9;3525:7;3521:23;3517:32;3514:52;;;3562:1;3559;3552:12;3514:52;3601:9;3588:23;3620:28;3642:5;3620:28;:::i;3683:388::-;3751:6;3759;3812:2;3800:9;3791:7;3787:23;3783:32;3780:52;;;3828:1;3825;3818:12;3780:52;3867:9;3854:23;3886:31;3911:5;3886:31;:::i;:::-;3936:5;-1:-1:-1;3993:2:1;3978:18;;3965:32;4006:33;3965:32;4006:33;:::i;4076:356::-;4278:2;4260:21;;;4297:18;;;4290:30;4356:34;4351:2;4336:18;;4329:62;4423:2;4408:18;;4076:356::o;4437:251::-;4507:6;4560:2;4548:9;4539:7;4535:23;4531:32;4528:52;;;4576:1;4573;4566:12;4528:52;4608:9;4602:16;4627:31;4652:5;4627:31;:::i;5002:607::-;-1:-1:-1;;;;;5361:15:1;;;5343:34;;5408:2;5393:18;;5386:34;;;;5451:2;5436:18;;5429:34;;;;5494:2;5479:18;;5472:34;;;;5543:15;;;5537:3;5522:19;;5515:44;5323:3;5575:19;;5568:35;;;;5292:3;5277:19;;5002:607::o;5614:306::-;5702:6;5710;5718;5771:2;5759:9;5750:7;5746:23;5742:32;5739:52;;;5787:1;5784;5777:12;5739:52;5816:9;5810:16;5800:26;;5866:2;5855:9;5851:18;5845:25;5835:35;;5910:2;5899:9;5895:18;5889:25;5879:35;;5614:306;;;;;:::o;5925:380::-;6004:1;6000:12;;;;6047;;;6068:61;;6122:4;6114:6;6110:17;6100:27;;6068:61;6175:2;6167:6;6164:14;6144:18;6141:38;6138:161;;6221:10;6216:3;6212:20;6209:1;6202:31;6256:4;6253:1;6246:15;6284:4;6281:1;6274:15;6138:161;;5925:380;;;:::o;6310:127::-;6371:10;6366:3;6362:20;6359:1;6352:31;6402:4;6399:1;6392:15;6426:4;6423:1;6416:15;6442:168;6515:9;;;6546;;6563:15;;;6557:22;;6543:37;6533:71;;6584:18;;:::i;6615:217::-;6655:1;6681;6671:132;;6725:10;6720:3;6716:20;6713:1;6706:31;6760:4;6757:1;6750:15;6788:4;6785:1;6778:15;6671:132;-1:-1:-1;6817:9:1;;6615:217::o;7662:125::-;7727:9;;;7748:10;;;7745:36;;;7761:18;;:::i;9189:184::-;9259:6;9312:2;9300:9;9291:7;9287:23;9283:32;9280:52;;;9328:1;9325;9318:12;9280:52;-1:-1:-1;9351:16:1;;9189:184;-1:-1:-1;9189:184:1:o;9657:245::-;9724:6;9777:2;9765:9;9756:7;9752:23;9748:32;9745:52;;;9793:1;9790;9783:12;9745:52;9825:9;9819:16;9844:28;9866:5;9844:28;:::i;12376:401::-;12578:2;12560:21;;;12617:2;12597:18;;;12590:30;12656:34;12651:2;12636:18;;12629:62;-1:-1:-1;;;12722:2:1;12707:18;;12700:35;12767:3;12752:19;;12376:401::o;12782:399::-;12984:2;12966:21;;;13023:2;13003:18;;;12996:30;13062:34;13057:2;13042:18;;13035:62;-1:-1:-1;;;13128:2:1;13113:18;;13106:33;13171:3;13156:19;;12782:399::o;14307:128::-;14374:9;;;14395:11;;;14392:37;;;14409:18;;:::i;15303:127::-;15364:10;15359:3;15355:20;15352:1;15345:31;15395:4;15392:1;15385:15;15419:4;15416:1;15409:15;15435:980;15697:4;15745:3;15734:9;15730:19;15776:6;15765:9;15758:25;15802:2;15840:6;15835:2;15824:9;15820:18;15813:34;15883:3;15878:2;15867:9;15863:18;15856:31;15907:6;15942;15936:13;15973:6;15965;15958:22;16011:3;16000:9;15996:19;15989:26;;16050:2;16042:6;16038:15;16024:29;;16071:1;16081:195;16095:6;16092:1;16089:13;16081:195;;;16160:13;;-1:-1:-1;;;;;16156:39:1;16144:52;;16251:15;;;;16216:12;;;;16192:1;16110:9;16081:195;;;-1:-1:-1;;;;;;;16332:32:1;;;;16327:2;16312:18;;16305:60;-1:-1:-1;;;16396:3:1;16381:19;16374:35;16293:3;15435:980;-1:-1:-1;;;15435:980:1:o

Swarm Source

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