ETH Price: $2,708.06 (+5.22%)
 

Overview

Max Total Supply

1,000,000,000,000 FELIX

Holders

95

Total Transfers

-

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
FELIX

Compiler Version
v0.8.9+commit.e5eed63a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-12-14
*/

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

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

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

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

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

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

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

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

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

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

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

    function initialize(address, address) external;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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

    mapping(address => uint256) private _balances;

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

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

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

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

        _beforeTokenTransfer(sender, recipient, amount);

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

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

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

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

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

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

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

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

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

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

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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

contract Ownable is Context {
    address private _owner;

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

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

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

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

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



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

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

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

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

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

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

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

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


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

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


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

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

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

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

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

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

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

    bool private swapping;

    address public marketingWallet;
    
    uint8 private _decimals;

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

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

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

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

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

    event ExcludeFromFees(address indexed account, bool isExcluded);

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

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

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

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

    constructor() ERC20("Felix 2.0 ETH", "FELIX") {

        address __owner = msg.sender;

        _decimals = 18;

        uint256 _totalSupply = 1000000000000 * (10**_decimals);
        
        buyTotalFees = 0;
        
        sellTotalFees = 0;

        transferTotalFees = 0;

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


        address currentRouter;

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

        //End of Router Variables.

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(currentRouter);

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

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

    receive() external payable {

  	}

    // once enabled, can never be turned off
    function enableTrading() external onlyOwner {
        tradingActive = true;
        swapEnabled = true;
    }
    
    function decimals() public view override returns (uint8) {
        return _decimals;
    }
    
    // only use to disable contract sales if absolutely necessary (emergency use only)
    function updateSwapEnabled(bool enabled) external onlyOwner(){
        swapEnabled = enabled;
    }

    function updateBuyFees(uint256 _marketingFee) external onlyOwner {
        
        buyTotalFees = _marketingFee;
        require(buyTotalFees <= 10, "Must keep fees at 10% or less");
    }
    
    function updateSellFees(uint256 _marketingFee) external onlyOwner {
        sellTotalFees = _marketingFee;
        require(sellTotalFees <= 10, "Must keep fees at 10% or less");
    }

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

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

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

        _setAutomatedMarketMakerPair(pair, value);
    }
    
    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        require (pair != 0x0000000000000000000000000000000000000000, "The pair cannot be zero address");
        automatedMarketMakerPairs[pair] = value;

        emit SetAutomatedMarketMakerPair(pair, value);
    }

    function updateMarketingWallet(address newMarketingWallet) external onlyOwner {
        emit marketingWalletUpdated(newMarketingWallet, marketingWallet);
        marketingWallet = newMarketingWallet;
    }
    
    function isExcludedFromFees(address account) external view returns(bool) {
        return _isExcludedFromFees[account];
    }
    
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        if(!tradingActive){
            require(_isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading is not active.");
        }
         if(amount == 0) {
            super._transfer(from, to, 0);
            return;
        }
                
		uint256 contractTokenBalance = balanceOf(address(this));
        
        bool canSwap = contractTokenBalance > 0;

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

            swapping = false;
        }
        
        bool takeFee = !swapping;

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

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

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

    function swapTokensForEth(uint256 tokenAmount) private {

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

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

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


    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));

        bool success;
        
        if(contractBalance == 0) {return;}
        
        swapTokensForEth(contractBalance); 
        
        (success,) = address(marketingWallet).call{value: address(this).balance}("");
        
    }
}

Contract Security Audit

Contract ABI

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

60c06040526006805461ffff60a81b191690553480156200001f57600080fd5b50604080518082018252600d81526c08ccad8d2f040645c60408aa89609b1b60208083019182528351808501909452600584526408c8a9892b60db1b908401528151919291620000729160039162000838565b5080516200008890600490602084019062000838565b50505060006200009d6200047560201b60201c565b600580546001600160a01b0319166001600160a01b03831690811790915560405191925090600090600080516020620026b3833981519152908290a3506006805460ff60a01b1916600960a11b179081905533906000906200010c9060ff600160a01b90910416600a620009f1565b6200011d9064e8d4a5100062000a09565b6000600781905560088190556009819055600680546001600160a01b03191673d3db83dedfe62065d971c8633ac955ad59f80e5a17905590915060384614156200017d57507310ed43c718714eb63d5aa57b78b54704e256024e62000285565b4660611415620001a3575073d99d1c33f9fc3444f8101754abc46c52416550d162000285565b4661a86a1415620001ca57507360ae616a2155ee3d9a68541ba4544862310933d462000285565b4660891415620001f0575073a5e0829caced8ffdd4de3c43696c57f7d7a678ff62000285565b4660fa141562000216575073f491e7b69e4244ad4002bc14e878a34207e38c2962000285565b46600314156200023c5750737a250d5630b4cf539739df2c5dacb4c659f2488d62000285565b46600114806200024c5750466004145b156200026e5750737a250d5630b4cf539739df2c5dacb4c659f2488d62000285565b50737a250d5630b4cf539739df2c5dacb4c659f2488d5b6001600160a01b03811660808190526040805163c45a015560e01b8152905183929163c45a0155916004808301926020929190829003018186803b158015620002cd57600080fd5b505afa158015620002e2573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000308919062000a2b565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156200035157600080fd5b505afa15801562000366573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200038c919062000a2b565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b158015620003d557600080fd5b505af1158015620003ea573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000410919062000a2b565b6001600160a01b031660a08190526200042b90600162000479565b6200043884600162000529565b6200044530600162000529565b6200045461dead600162000529565b620004608484620005d3565b6200046b84620006cf565b5050505062000aae565b3390565b6001600160a01b038216620004d55760405162461bcd60e51b815260206004820152601f60248201527f54686520706169722063616e6e6f74206265207a65726f20616464726573730060448201526064015b60405180910390fd5b6001600160a01b0382166000818152600b6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6005546001600160a01b03163314620005745760405162461bcd60e51b81526020600482018190526024820152600080516020620026938339815191526044820152606401620004cc565b6001600160a01b0382166000818152600a6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b0382166200062b5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401620004cc565b6200064781600254620007cc60201b62000d291790919060201c565b6002556001600160a01b038216600090815260208181526040909120546200067a91839062000d29620007cc821b17901c565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6005546001600160a01b031633146200071a5760405162461bcd60e51b81526020600482018190526024820152600080516020620026938339815191526044820152606401620004cc565b6001600160a01b038116620007815760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401620004cc565b6005546040516001600160a01b03808416921690600080516020620026b383398151915290600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080620007db838562000a56565b9050838110156200082f5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401620004cc565b90505b92915050565b828054620008469062000a71565b90600052602060002090601f0160209004810192826200086a5760008555620008b5565b82601f106200088557805160ff1916838001178555620008b5565b82800160010185558215620008b5579182015b82811115620008b557825182559160200191906001019062000898565b50620008c3929150620008c7565b5090565b5b80821115620008c35760008155600101620008c8565b634e487b7160e01b600052601160045260246000fd5b600181815b8085111562000935578160001904821115620009195762000919620008de565b808516156200092757918102915b93841c9390800290620008f9565b509250929050565b6000826200094e5750600162000832565b816200095d5750600062000832565b81600181146200097657600281146200098157620009a1565b600191505062000832565b60ff841115620009955762000995620008de565b50506001821b62000832565b5060208310610133831016604e8410600b8410161715620009c6575081810a62000832565b620009d28383620008f4565b8060001904821115620009e957620009e9620008de565b029392505050565b600062000a0260ff8416836200093d565b9392505050565b600081600019048311821515161562000a265762000a26620008de565b500290565b60006020828403121562000a3e57600080fd5b81516001600160a01b03811681146200082f57600080fd5b6000821982111562000a6c5762000a6c620008de565b500190565b600181811c9082168062000a8657607f821691505b6020821081141562000aa857634e487b7160e01b600052602260045260246000fd5b50919050565b60805160a051611ba362000af060003960008181610358015261097e01526000818161026b015281816115530152818161161b01526116570152611ba36000f3fe6080604052600436106101f25760003560e01c80638a8c523c1161010d578063b4443f5b116100a0578063d85ba0631161006f578063d85ba063146105f0578063dd62ed3e14610606578063e3c4818d1461064c578063eba4c33314610662578063f2fde38b1461068257600080fd5b8063b4443f5b1461055f578063b62496f51461057f578063bbc0c742146105af578063c0246668146105d057600080fd5b80639a7a23d6116100dc5780639a7a23d6146104df578063a457c2d7146104ff578063a9059cbb1461051f578063aacebbe31461053f57600080fd5b80638a8c523c146104775780638da5cb5b1461048c578063924de9b7146104aa57806395d89b41146104ca57600080fd5b806349bd5a5e1161018557806370a082311161015457806370a08231146103ea578063715018a61461042057806371fc46881461043757806375f0a8741461045757600080fd5b806349bd5a5e146103465780634fbee1931461037a5780636a486a8e146103b35780636ddd1713146103c957600080fd5b806323b872dd116101c157806323b872dd146102c457806327c8f835146102e4578063313ce567146102fa578063395093511461032657600080fd5b806306fdde03146101fe578063095ea7b3146102295780631694505e1461025957806318160ddd146102a557600080fd5b366101f957005b600080fd5b34801561020a57600080fd5b506102136106a2565b60405161022091906116f6565b60405180910390f35b34801561023557600080fd5b50610249610244366004611760565b610734565b6040519015158152602001610220565b34801561026557600080fd5b5061028d7f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610220565b3480156102b157600080fd5b506002545b604051908152602001610220565b3480156102d057600080fd5b506102496102df36600461178c565b61074b565b3480156102f057600080fd5b5061028d61dead81565b34801561030657600080fd5b50600654600160a01b900460ff1660405160ff9091168152602001610220565b34801561033257600080fd5b50610249610341366004611760565b6107b4565b34801561035257600080fd5b5061028d7f000000000000000000000000000000000000000000000000000000000000000081565b34801561038657600080fd5b506102496103953660046117cd565b6001600160a01b03166000908152600a602052604090205460ff1690565b3480156103bf57600080fd5b506102b660085481565b3480156103d557600080fd5b5060065461024990600160b01b900460ff1681565b3480156103f657600080fd5b506102b66104053660046117cd565b6001600160a01b031660009081526020819052604090205490565b34801561042c57600080fd5b506104356107ea565b005b34801561044357600080fd5b506104356104523660046117ea565b610867565b34801561046357600080fd5b5060065461028d906001600160a01b031681565b34801561048357600080fd5b506104356108ba565b34801561049857600080fd5b506005546001600160a01b031661028d565b3480156104b657600080fd5b506104356104c5366004611818565b6108fb565b3480156104d657600080fd5b50610213610943565b3480156104eb57600080fd5b506104356104fa366004611833565b610952565b34801561050b57600080fd5b5061024961051a366004611760565b610a32565b34801561052b57600080fd5b5061024961053a366004611760565b610a81565b34801561054b57600080fd5b5061043561055a3660046117cd565b610a8e565b34801561056b57600080fd5b5061043561057a3660046117ea565b610b15565b34801561058b57600080fd5b5061024961059a3660046117cd565b600b6020526000908152604090205460ff1681565b3480156105bb57600080fd5b5060065461024990600160a81b900460ff1681565b3480156105dc57600080fd5b506104356105eb366004611833565b610b65565b3480156105fc57600080fd5b506102b660075481565b34801561061257600080fd5b506102b6610621366004611868565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561065857600080fd5b506102b660095481565b34801561066e57600080fd5b5061043561067d3660046117ea565b610bee565b34801561068e57600080fd5b5061043561069d3660046117cd565b610c3e565b6060600380546106b1906118a1565b80601f01602080910402602001604051908101604052809291908181526020018280546106dd906118a1565b801561072a5780601f106106ff5761010080835404028352916020019161072a565b820191906000526020600020905b81548152906001019060200180831161070d57829003601f168201915b5050505050905090565b6000610741338484610d8f565b5060015b92915050565b6000610758848484610eb4565b6107aa84336107a585604051806060016040528060288152602001611b21602891396001600160a01b038a16600090815260016020908152604080832033845290915290205491906111d2565b610d8f565b5060019392505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916107419185906107a59086610d29565b6005546001600160a01b0316331461081d5760405162461bcd60e51b8152600401610814906118dc565b60405180910390fd5b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b031633146108915760405162461bcd60e51b8152600401610814906118dc565b6007819055600a8111156108b75760405162461bcd60e51b815260040161081490611911565b50565b6005546001600160a01b031633146108e45760405162461bcd60e51b8152600401610814906118dc565b6006805461ffff60a81b191661010160a81b179055565b6005546001600160a01b031633146109255760405162461bcd60e51b8152600401610814906118dc565b60068054911515600160b01b0260ff60b01b19909216919091179055565b6060600480546106b1906118a1565b6005546001600160a01b0316331461097c5760405162461bcd60e51b8152600401610814906118dc565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b03161415610a245760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610814565b610a2e828261120c565b5050565b600061074133846107a585604051806060016040528060258152602001611b49602591393360009081526001602090815260408083206001600160a01b038d16845290915290205491906111d2565b6000610741338484610eb4565b6005546001600160a01b03163314610ab85760405162461bcd60e51b8152600401610814906118dc565b6006546040516001600160a01b03918216918316907fa751787977eeb3902e30e1d19ca00c6ad274a1f622c31a206e32366700b0567490600090a3600680546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610b3f5760405162461bcd60e51b8152600401610814906118dc565b6009819055600a8111156108b75760405162461bcd60e51b815260040161081490611911565b6005546001600160a01b03163314610b8f5760405162461bcd60e51b8152600401610814906118dc565b6001600160a01b0382166000818152600a6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610c185760405162461bcd60e51b8152600401610814906118dc565b6008819055600a8111156108b75760405162461bcd60e51b815260040161081490611911565b6005546001600160a01b03163314610c685760405162461bcd60e51b8152600401610814906118dc565b6001600160a01b038116610ccd5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610814565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610d36838561195e565b905083811015610d885760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610814565b9392505050565b6001600160a01b038316610df15760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610814565b6001600160a01b038216610e525760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610814565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610eda5760405162461bcd60e51b815260040161081490611976565b6001600160a01b038216610f005760405162461bcd60e51b8152600401610814906119bb565b600654600160a81b900460ff16610f95576001600160a01b0383166000908152600a602052604090205460ff1680610f5057506001600160a01b0382166000908152600a602052604090205460ff165b610f955760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610814565b80610fab57610fa6838360006112b6565b505050565b3060009081526020819052604090205480158015908190610fd55750600654600160b01b900460ff165b8015610feb5750600554600160a01b900460ff16155b801561101057506001600160a01b0385166000908152600b602052604090205460ff16155b801561103557506001600160a01b0385166000908152600a602052604090205460ff16155b801561105a57506001600160a01b0384166000908152600a602052604090205460ff16155b15611088576005805460ff60a01b1916600160a01b17905561107a6113bf565b6005805460ff60a01b191690555b6005546001600160a01b0386166000908152600a602052604090205460ff600160a01b9092048216159116806110d657506001600160a01b0385166000908152600a602052604090205460ff165b156110df575060005b600081156111be576001600160a01b0386166000908152600b602052604090205460ff1615611138576008541561113357611130606461112a6008548861143b90919063ffffffff16565b906114ba565b90505b6111a0565b6001600160a01b0387166000908152600b602052604090205460ff161561117b576007541561113357611130606461112a6007548861143b90919063ffffffff16565b600954156111a05761119d606461112a6009548861143b90919063ffffffff16565b90505b80156111b1576111b18730836112b6565b6111bb81866119fe565b94505b6111c98787876112b6565b50505050505050565b600081848411156111f65760405162461bcd60e51b815260040161081491906116f6565b50600061120384866119fe565b95945050505050565b6001600160a01b0382166112625760405162461bcd60e51b815260206004820152601f60248201527f54686520706169722063616e6e6f74206265207a65726f2061646472657373006044820152606401610814565b6001600160a01b0382166000818152600b6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b0383166112dc5760405162461bcd60e51b815260040161081490611976565b6001600160a01b0382166113025760405162461bcd60e51b8152600401610814906119bb565b61133f81604051806060016040528060268152602001611afb602691396001600160a01b03861660009081526020819052604090205491906111d2565b6001600160a01b03808516600090815260208190526040808220939093559084168152205461136e9082610d29565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610ea7565b3060009081526020819052604081205490816113d9575050565b6113e2826114fc565b6006546040516001600160a01b03909116904790600081818185875af1925050503d806000811461142f576040519150601f19603f3d011682016040523d82523d6000602084013e611434565b606091505b5050505050565b60008261144a57506000610745565b60006114568385611a15565b9050826114638583611a34565b14610d885760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610814565b6000610d8883836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506116c8565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061153157611531611a56565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156115aa57600080fd5b505afa1580156115be573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115e29190611a6c565b816001815181106115f5576115f5611a56565b60200260200101906001600160a01b031690816001600160a01b031681525050611640307f000000000000000000000000000000000000000000000000000000000000000084610d8f565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac94790611695908590600090869030904290600401611a89565b600060405180830381600087803b1580156116af57600080fd5b505af19250505080156116c0575060015b610a2e575050565b600081836116e95760405162461bcd60e51b815260040161081491906116f6565b5060006112038486611a34565b600060208083528351808285015260005b8181101561172357858101830151858201604001528201611707565b81811115611735576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b03811681146108b757600080fd5b6000806040838503121561177357600080fd5b823561177e8161174b565b946020939093013593505050565b6000806000606084860312156117a157600080fd5b83356117ac8161174b565b925060208401356117bc8161174b565b929592945050506040919091013590565b6000602082840312156117df57600080fd5b8135610d888161174b565b6000602082840312156117fc57600080fd5b5035919050565b8035801515811461181357600080fd5b919050565b60006020828403121561182a57600080fd5b610d8882611803565b6000806040838503121561184657600080fd5b82356118518161174b565b915061185f60208401611803565b90509250929050565b6000806040838503121561187b57600080fd5b82356118868161174b565b915060208301356118968161174b565b809150509250929050565b600181811c908216806118b557607f821691505b602082108114156118d657634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b6020808252601d908201527f4d757374206b656570206665657320617420313025206f72206c657373000000604082015260600190565b634e487b7160e01b600052601160045260246000fd5b6000821982111561197157611971611948565b500190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015611a1057611a10611948565b500390565b6000816000190483118215151615611a2f57611a2f611948565b500290565b600082611a5157634e487b7160e01b600052601260045260246000fd5b500490565b634e487b7160e01b600052603260045260246000fd5b600060208284031215611a7e57600080fd5b8151610d888161174b565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611ad95784516001600160a01b031683529383019391830191600101611ab4565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220565579816d7d6f54318759ba7030801cf88506e8b93f6bd1fdadc3264a828eb564736f6c634300080900334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65728be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0

Deployed Bytecode

0x6080604052600436106101f25760003560e01c80638a8c523c1161010d578063b4443f5b116100a0578063d85ba0631161006f578063d85ba063146105f0578063dd62ed3e14610606578063e3c4818d1461064c578063eba4c33314610662578063f2fde38b1461068257600080fd5b8063b4443f5b1461055f578063b62496f51461057f578063bbc0c742146105af578063c0246668146105d057600080fd5b80639a7a23d6116100dc5780639a7a23d6146104df578063a457c2d7146104ff578063a9059cbb1461051f578063aacebbe31461053f57600080fd5b80638a8c523c146104775780638da5cb5b1461048c578063924de9b7146104aa57806395d89b41146104ca57600080fd5b806349bd5a5e1161018557806370a082311161015457806370a08231146103ea578063715018a61461042057806371fc46881461043757806375f0a8741461045757600080fd5b806349bd5a5e146103465780634fbee1931461037a5780636a486a8e146103b35780636ddd1713146103c957600080fd5b806323b872dd116101c157806323b872dd146102c457806327c8f835146102e4578063313ce567146102fa578063395093511461032657600080fd5b806306fdde03146101fe578063095ea7b3146102295780631694505e1461025957806318160ddd146102a557600080fd5b366101f957005b600080fd5b34801561020a57600080fd5b506102136106a2565b60405161022091906116f6565b60405180910390f35b34801561023557600080fd5b50610249610244366004611760565b610734565b6040519015158152602001610220565b34801561026557600080fd5b5061028d7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b039091168152602001610220565b3480156102b157600080fd5b506002545b604051908152602001610220565b3480156102d057600080fd5b506102496102df36600461178c565b61074b565b3480156102f057600080fd5b5061028d61dead81565b34801561030657600080fd5b50600654600160a01b900460ff1660405160ff9091168152602001610220565b34801561033257600080fd5b50610249610341366004611760565b6107b4565b34801561035257600080fd5b5061028d7f000000000000000000000000fd11a387afe2044c6542bf9dcc385381f54a845981565b34801561038657600080fd5b506102496103953660046117cd565b6001600160a01b03166000908152600a602052604090205460ff1690565b3480156103bf57600080fd5b506102b660085481565b3480156103d557600080fd5b5060065461024990600160b01b900460ff1681565b3480156103f657600080fd5b506102b66104053660046117cd565b6001600160a01b031660009081526020819052604090205490565b34801561042c57600080fd5b506104356107ea565b005b34801561044357600080fd5b506104356104523660046117ea565b610867565b34801561046357600080fd5b5060065461028d906001600160a01b031681565b34801561048357600080fd5b506104356108ba565b34801561049857600080fd5b506005546001600160a01b031661028d565b3480156104b657600080fd5b506104356104c5366004611818565b6108fb565b3480156104d657600080fd5b50610213610943565b3480156104eb57600080fd5b506104356104fa366004611833565b610952565b34801561050b57600080fd5b5061024961051a366004611760565b610a32565b34801561052b57600080fd5b5061024961053a366004611760565b610a81565b34801561054b57600080fd5b5061043561055a3660046117cd565b610a8e565b34801561056b57600080fd5b5061043561057a3660046117ea565b610b15565b34801561058b57600080fd5b5061024961059a3660046117cd565b600b6020526000908152604090205460ff1681565b3480156105bb57600080fd5b5060065461024990600160a81b900460ff1681565b3480156105dc57600080fd5b506104356105eb366004611833565b610b65565b3480156105fc57600080fd5b506102b660075481565b34801561061257600080fd5b506102b6610621366004611868565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561065857600080fd5b506102b660095481565b34801561066e57600080fd5b5061043561067d3660046117ea565b610bee565b34801561068e57600080fd5b5061043561069d3660046117cd565b610c3e565b6060600380546106b1906118a1565b80601f01602080910402602001604051908101604052809291908181526020018280546106dd906118a1565b801561072a5780601f106106ff5761010080835404028352916020019161072a565b820191906000526020600020905b81548152906001019060200180831161070d57829003601f168201915b5050505050905090565b6000610741338484610d8f565b5060015b92915050565b6000610758848484610eb4565b6107aa84336107a585604051806060016040528060288152602001611b21602891396001600160a01b038a16600090815260016020908152604080832033845290915290205491906111d2565b610d8f565b5060019392505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916107419185906107a59086610d29565b6005546001600160a01b0316331461081d5760405162461bcd60e51b8152600401610814906118dc565b60405180910390fd5b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b031633146108915760405162461bcd60e51b8152600401610814906118dc565b6007819055600a8111156108b75760405162461bcd60e51b815260040161081490611911565b50565b6005546001600160a01b031633146108e45760405162461bcd60e51b8152600401610814906118dc565b6006805461ffff60a81b191661010160a81b179055565b6005546001600160a01b031633146109255760405162461bcd60e51b8152600401610814906118dc565b60068054911515600160b01b0260ff60b01b19909216919091179055565b6060600480546106b1906118a1565b6005546001600160a01b0316331461097c5760405162461bcd60e51b8152600401610814906118dc565b7f000000000000000000000000fd11a387afe2044c6542bf9dcc385381f54a84596001600160a01b0316826001600160a01b03161415610a245760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610814565b610a2e828261120c565b5050565b600061074133846107a585604051806060016040528060258152602001611b49602591393360009081526001602090815260408083206001600160a01b038d16845290915290205491906111d2565b6000610741338484610eb4565b6005546001600160a01b03163314610ab85760405162461bcd60e51b8152600401610814906118dc565b6006546040516001600160a01b03918216918316907fa751787977eeb3902e30e1d19ca00c6ad274a1f622c31a206e32366700b0567490600090a3600680546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610b3f5760405162461bcd60e51b8152600401610814906118dc565b6009819055600a8111156108b75760405162461bcd60e51b815260040161081490611911565b6005546001600160a01b03163314610b8f5760405162461bcd60e51b8152600401610814906118dc565b6001600160a01b0382166000818152600a6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610c185760405162461bcd60e51b8152600401610814906118dc565b6008819055600a8111156108b75760405162461bcd60e51b815260040161081490611911565b6005546001600160a01b03163314610c685760405162461bcd60e51b8152600401610814906118dc565b6001600160a01b038116610ccd5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610814565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610d36838561195e565b905083811015610d885760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610814565b9392505050565b6001600160a01b038316610df15760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610814565b6001600160a01b038216610e525760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610814565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610eda5760405162461bcd60e51b815260040161081490611976565b6001600160a01b038216610f005760405162461bcd60e51b8152600401610814906119bb565b600654600160a81b900460ff16610f95576001600160a01b0383166000908152600a602052604090205460ff1680610f5057506001600160a01b0382166000908152600a602052604090205460ff165b610f955760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610814565b80610fab57610fa6838360006112b6565b505050565b3060009081526020819052604090205480158015908190610fd55750600654600160b01b900460ff165b8015610feb5750600554600160a01b900460ff16155b801561101057506001600160a01b0385166000908152600b602052604090205460ff16155b801561103557506001600160a01b0385166000908152600a602052604090205460ff16155b801561105a57506001600160a01b0384166000908152600a602052604090205460ff16155b15611088576005805460ff60a01b1916600160a01b17905561107a6113bf565b6005805460ff60a01b191690555b6005546001600160a01b0386166000908152600a602052604090205460ff600160a01b9092048216159116806110d657506001600160a01b0385166000908152600a602052604090205460ff165b156110df575060005b600081156111be576001600160a01b0386166000908152600b602052604090205460ff1615611138576008541561113357611130606461112a6008548861143b90919063ffffffff16565b906114ba565b90505b6111a0565b6001600160a01b0387166000908152600b602052604090205460ff161561117b576007541561113357611130606461112a6007548861143b90919063ffffffff16565b600954156111a05761119d606461112a6009548861143b90919063ffffffff16565b90505b80156111b1576111b18730836112b6565b6111bb81866119fe565b94505b6111c98787876112b6565b50505050505050565b600081848411156111f65760405162461bcd60e51b815260040161081491906116f6565b50600061120384866119fe565b95945050505050565b6001600160a01b0382166112625760405162461bcd60e51b815260206004820152601f60248201527f54686520706169722063616e6e6f74206265207a65726f2061646472657373006044820152606401610814565b6001600160a01b0382166000818152600b6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b0383166112dc5760405162461bcd60e51b815260040161081490611976565b6001600160a01b0382166113025760405162461bcd60e51b8152600401610814906119bb565b61133f81604051806060016040528060268152602001611afb602691396001600160a01b03861660009081526020819052604090205491906111d2565b6001600160a01b03808516600090815260208190526040808220939093559084168152205461136e9082610d29565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610ea7565b3060009081526020819052604081205490816113d9575050565b6113e2826114fc565b6006546040516001600160a01b03909116904790600081818185875af1925050503d806000811461142f576040519150601f19603f3d011682016040523d82523d6000602084013e611434565b606091505b5050505050565b60008261144a57506000610745565b60006114568385611a15565b9050826114638583611a34565b14610d885760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610814565b6000610d8883836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506116c8565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061153157611531611a56565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156115aa57600080fd5b505afa1580156115be573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115e29190611a6c565b816001815181106115f5576115f5611a56565b60200260200101906001600160a01b031690816001600160a01b031681525050611640307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610d8f565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac94790611695908590600090869030904290600401611a89565b600060405180830381600087803b1580156116af57600080fd5b505af19250505080156116c0575060015b610a2e575050565b600081836116e95760405162461bcd60e51b815260040161081491906116f6565b5060006112038486611a34565b600060208083528351808285015260005b8181101561172357858101830151858201604001528201611707565b81811115611735576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b03811681146108b757600080fd5b6000806040838503121561177357600080fd5b823561177e8161174b565b946020939093013593505050565b6000806000606084860312156117a157600080fd5b83356117ac8161174b565b925060208401356117bc8161174b565b929592945050506040919091013590565b6000602082840312156117df57600080fd5b8135610d888161174b565b6000602082840312156117fc57600080fd5b5035919050565b8035801515811461181357600080fd5b919050565b60006020828403121561182a57600080fd5b610d8882611803565b6000806040838503121561184657600080fd5b82356118518161174b565b915061185f60208401611803565b90509250929050565b6000806040838503121561187b57600080fd5b82356118868161174b565b915060208301356118968161174b565b809150509250929050565b600181811c908216806118b557607f821691505b602082108114156118d657634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b6020808252601d908201527f4d757374206b656570206665657320617420313025206f72206c657373000000604082015260600190565b634e487b7160e01b600052601160045260246000fd5b6000821982111561197157611971611948565b500190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015611a1057611a10611948565b500390565b6000816000190483118215151615611a2f57611a2f611948565b500290565b600082611a5157634e487b7160e01b600052601260045260246000fd5b500490565b634e487b7160e01b600052603260045260246000fd5b600060208284031215611a7e57600080fd5b8151610d888161174b565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611ad95784516001600160a01b031683529383019391830191600101611ab4565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220565579816d7d6f54318759ba7030801cf88506e8b93f6bd1fdadc3264a828eb564736f6c63430008090033

Deployed Bytecode Sourcemap

29433:9315:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7589:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;9756:169;;;;;;;;;;-1:-1:-1;9756:169:0;;;;;:::i;:::-;;:::i;:::-;;;1237:14:1;;1230:22;1212:41;;1200:2;1185:18;9756:169:0;1072:187:1;29508:51:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;1455:32:1;;;1437:51;;1425:2;1410:18;29508:51:0;1264:230:1;8709:108:0;;;;;;;;;;-1:-1:-1;8797:12:0;;8709:108;;;1645:25:1;;;1633:2;1618:18;8709:108:0;1499:177:1;10407:355:0;;;;;;;;;;-1:-1:-1;10407:355:0;;;;;:::i;:::-;;:::i;29611:53::-;;;;;;;;;;;;29657:6;29611:53;;33596:92;;;;;;;;;;-1:-1:-1;33671:9:0;;-1:-1:-1;;;33671:9:0;;;;33596:92;;2522:4:1;2510:17;;;2492:36;;2480:2;2465:18;33596:92:0;2350:184:1;11171:218:0;;;;;;;;;;-1:-1:-1;11171:218:0;;;;;:::i;:::-;;:::i;29566:38::-;;;;;;;;;;;;;;;35473:127;;;;;;;;;;-1:-1:-1;35473:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;35564:28:0;35540:4;35564:28;;;:19;:28;;;;;;;;;35473:127;29910:28;;;;;;;;;;;;;;;;29818:31;;;;;;;;;;-1:-1:-1;29818:31:0;;;;-1:-1:-1;;;29818:31:0;;;;;;8880:127;;;;;;;;;;-1:-1:-1;8880:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;8981:18:0;8954:7;8981:18;;;;;;;;;;;;8880:127;22054:148;;;;;;;;;;;;;:::i;:::-;;33897:193;;;;;;;;;;-1:-1:-1;33897:193:0;;;;;:::i;:::-;;:::i;29703:30::-;;;;;;;;;;-1:-1:-1;29703:30:0;;;;-1:-1:-1;;;;;29703:30:0;;;33472:112;;;;;;;;;;;;;:::i;21412:79::-;;;;;;;;;;-1:-1:-1;21477:6:0;;-1:-1:-1;;;;;21477:6:0;21412:79;;33788:101;;;;;;;;;;-1:-1:-1;33788:101:0;;;;;:::i;:::-;;:::i;7808:104::-;;;;;;;;;;;;;:::i;34693:246::-;;;;;;;;;;-1:-1:-1;34693:246:0;;;;;:::i;:::-;;:::i;11892:269::-;;;;;;;;;;-1:-1:-1;11892:269:0;;;;;:::i;:::-;;:::i;9220:175::-;;;;;;;;;;-1:-1:-1;9220:175:0;;;;;:::i;:::-;;:::i;35253:208::-;;;;;;;;;;-1:-1:-1;35253:208:0;;;;;:::i;:::-;;:::i;34296:199::-;;;;;;;;;;-1:-1:-1;34296:199:0;;;;;:::i;:::-;;:::i;30288:58::-;;;;;;;;;;-1:-1:-1;30288:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29778:33;;;;;;;;;;-1:-1:-1;29778:33:0;;;;-1:-1:-1;;;29778:33:0;;;;;;34503:182;;;;;;;;;;-1:-1:-1;34503:182:0;;;;;:::i;:::-;;:::i;29870:27::-;;;;;;;;;;;;;;;;9458:151;;;;;;;;;;-1:-1:-1;9458:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;9574:18:0;;;9547:7;9574:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9458:151;29947:32;;;;;;;;;;;;;;;;34102:186;;;;;;;;;;-1:-1:-1;34102:186:0;;;;;:::i;:::-;;:::i;22357:244::-;;;;;;;;;;-1:-1:-1;22357:244:0;;;;;:::i;:::-;;:::i;7589:100::-;7643:13;7676:5;7669:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7589:100;:::o;9756:169::-;9839:4;9856:39;305:10;9879:7;9888:6;9856:8;:39::i;:::-;-1:-1:-1;9913:4:0;9756:169;;;;;:::o;10407:355::-;10547:4;10564:36;10574:6;10582:9;10593:6;10564:9;:36::i;:::-;10611:121;10620:6;305:10;10642:89;10680:6;10642:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10642:19:0;;;;;;:11;:19;;;;;;;;305:10;10642:33;;;;;;;;;;:37;:89::i;:::-;10611:8;:121::i;:::-;-1:-1:-1;10750:4:0;10407:355;;;;;:::o;11171:218::-;305:10;11259:4;11308:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11308:34:0;;;;;;;;;;11259:4;;11276:83;;11299:7;;11308:50;;11347:10;11308:38;:50::i;22054:148::-;21624:6;;-1:-1:-1;;;;;21624:6:0;305:10;21624:22;21616:67;;;;-1:-1:-1;;;21616:67:0;;;;;;;:::i;:::-;;;;;;;;;22145:6:::1;::::0;22124:40:::1;::::0;22161:1:::1;::::0;-1:-1:-1;;;;;22145:6:0::1;::::0;22124:40:::1;::::0;22161:1;;22124:40:::1;22175:6;:19:::0;;-1:-1:-1;;;;;;22175:19:0::1;::::0;;22054:148::o;33897:193::-;21624:6;;-1:-1:-1;;;;;21624:6:0;305:10;21624:22;21616:67;;;;-1:-1:-1;;;21616:67:0;;;;;;;:::i;:::-;33983:12:::1;:28:::0;;;34046:2:::1;34030:18:::0;::::1;;34022:60;;;;-1:-1:-1::0;;;34022:60:0::1;;;;;;;:::i;:::-;33897:193:::0;:::o;33472:112::-;21624:6;;-1:-1:-1;;;;;21624:6:0;305:10;21624:22;21616:67;;;;-1:-1:-1;;;21616:67:0;;;;;;;:::i;:::-;33527:13:::1;:20:::0;;-1:-1:-1;;;;33558:18:0;-1:-1:-1;;;33558:18:0;;;33472:112::o;33788:101::-;21624:6;;-1:-1:-1;;;;;21624:6:0;305:10;21624:22;21616:67;;;;-1:-1:-1;;;21616:67:0;;;;;;;:::i;:::-;33860:11:::1;:21:::0;;;::::1;;-1:-1:-1::0;;;33860:21:0::1;-1:-1:-1::0;;;;33860:21:0;;::::1;::::0;;;::::1;::::0;;33788:101::o;7808:104::-;7864:13;7897:7;7890:14;;;;;:::i;34693:246::-;21624:6;;-1:-1:-1;;;;;21624:6:0;305:10;21624:22;21616:67;;;;-1:-1:-1;;;21616:67:0;;;;;;;:::i;:::-;34802:13:::1;-1:-1:-1::0;;;;;34794:21:0::1;:4;-1:-1:-1::0;;;;;34794:21:0::1;;;34786:91;;;::::0;-1:-1:-1;;;34786:91:0;;5345:2:1;34786:91:0::1;::::0;::::1;5327:21:1::0;5384:2;5364:18;;;5357:30;5423:34;5403:18;;;5396:62;5494:27;5474:18;;;5467:55;5539:19;;34786:91:0::1;5143:421:1::0;34786:91:0::1;34890:41;34919:4;34925:5;34890:28;:41::i;:::-;34693:246:::0;;:::o;11892:269::-;11985:4;12002:129;305:10;12025:7;12034:96;12073:15;12034:96;;;;;;;;;;;;;;;;;305:10;12034:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;12034:34:0;;;;;;;;;;;;:38;:96::i;9220:175::-;9306:4;9323:42;305:10;9347:9;9358:6;9323:9;:42::i;35253:208::-;21624:6;;-1:-1:-1;;;;;21624:6:0;305:10;21624:22;21616:67;;;;-1:-1:-1;;;21616:67:0;;;;;;;:::i;:::-;35390:15:::1;::::0;35347:59:::1;::::0;-1:-1:-1;;;;;35390:15:0;;::::1;::::0;35347:59;::::1;::::0;::::1;::::0;35390:15:::1;::::0;35347:59:::1;35417:15;:36:::0;;-1:-1:-1;;;;;;35417:36:0::1;-1:-1:-1::0;;;;;35417:36:0;;;::::1;::::0;;;::::1;::::0;;35253:208::o;34296:199::-;21624:6;;-1:-1:-1;;;;;21624:6:0;305:10;21624:22;21616:67;;;;-1:-1:-1;;;21616:67:0;;;;;;;:::i;:::-;34377:17:::1;:33:::0;;;34451:2:::1;34430:23:::0;::::1;;34422:65;;;;-1:-1:-1::0;;;34422:65:0::1;;;;;;;:::i;34503:182::-:0;21624:6;;-1:-1:-1;;;;;21624:6:0;305:10;21624:22;21616:67;;;;-1:-1:-1;;;21616:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34588:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;34588:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;34643:34;;1212:41:1;;;34643:34:0::1;::::0;1185:18:1;34643:34:0::1;;;;;;;34503:182:::0;;:::o;34102:186::-;21624:6;;-1:-1:-1;;;;;21624:6:0;305:10;21624:22;21616:67;;;;-1:-1:-1;;;21616:67:0;;;;;;;:::i;:::-;34179:13:::1;:29:::0;;;34244:2:::1;34227:19:::0;::::1;;34219:61;;;;-1:-1:-1::0;;;34219:61:0::1;;;;;;;:::i;22357:244::-:0;21624:6;;-1:-1:-1;;;;;21624:6:0;305:10;21624:22;21616:67;;;;-1:-1:-1;;;21616:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22446:22:0;::::1;22438:73;;;::::0;-1:-1:-1;;;22438:73:0;;5771:2:1;22438:73:0::1;::::0;::::1;5753:21:1::0;5810:2;5790:18;;;5783:30;5849:34;5829:18;;;5822:62;-1:-1:-1;;;5900:18:1;;;5893:36;5946:19;;22438:73:0::1;5569:402:1::0;22438:73:0::1;22548:6;::::0;22527:38:::1;::::0;-1:-1:-1;;;;;22527:38:0;;::::1;::::0;22548:6:::1;::::0;22527:38:::1;::::0;22548:6:::1;::::0;22527:38:::1;22576:6;:17:::0;;-1:-1:-1;;;;;;22576:17:0::1;-1:-1:-1::0;;;;;22576:17:0;;;::::1;::::0;;;::::1;::::0;;22357:244::o;16456:181::-;16514:7;;16546:5;16550:1;16546;:5;:::i;:::-;16534:17;;16575:1;16570;:6;;16562:46;;;;-1:-1:-1;;;16562:46:0;;6443:2:1;16562:46:0;;;6425:21:1;6482:2;6462:18;;;6455:30;6521:29;6501:18;;;6494:57;6568:18;;16562:46:0;6241:351:1;16562:46:0;16628:1;16456:181;-1:-1:-1;;;16456:181:0:o;15078:380::-;-1:-1:-1;;;;;15214:19:0;;15206:68;;;;-1:-1:-1;;;15206:68:0;;6799:2:1;15206:68:0;;;6781:21:1;6838:2;6818:18;;;6811:30;6877:34;6857:18;;;6850:62;-1:-1:-1;;;6928:18:1;;;6921:34;6972:19;;15206:68:0;6597:400:1;15206:68:0;-1:-1:-1;;;;;15293:21:0;;15285:68;;;;-1:-1:-1;;;15285:68:0;;7204:2:1;15285:68:0;;;7186:21:1;7243:2;7223:18;;;7216:30;7282:34;7262:18;;;7255:62;-1:-1:-1;;;7333:18:1;;;7326:32;7375:19;;15285:68:0;7002:398:1;15285:68:0;-1:-1:-1;;;;;15366:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15418:32;;1645:25:1;;;15418:32:0;;1618:18:1;15418:32:0;;;;;;;;15078:380;;;:::o;35612:2171::-;-1:-1:-1;;;;;35744:18:0;;35736:68;;;;-1:-1:-1;;;35736:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35823:16:0;;35815:64;;;;-1:-1:-1;;;35815:64:0;;;;;;;:::i;:::-;35894:13;;-1:-1:-1;;;35894:13:0;;;;35890:132;;-1:-1:-1;;;;;35931:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;35960:23:0;;;;;;:19;:23;;;;;;;;35931:52;35923:87;;;;-1:-1:-1;;;35923:87:0;;8417:2:1;35923:87:0;;;8399:21:1;8456:2;8436:18;;;8429:30;-1:-1:-1;;;8475:18:1;;;8468:52;8537:18;;35923:87:0;8215:346:1;35923:87:0;36036:11;36033:92;;36064:28;36080:4;36086:2;36090:1;36064:15;:28::i;:::-;35612:2171;;;:::o;36033:92::-;36196:4;36147:28;8981:18;;;;;;;;;;;36238:24;;;;;;;36293:35;;-1:-1:-1;36317:11:0;;-1:-1:-1;;;36317:11:0;;;;36293:35;:61;;;;-1:-1:-1;36346:8:0;;-1:-1:-1;;;36346:8:0;;;;36345:9;36293:61;:110;;;;-1:-1:-1;;;;;;36372:31:0;;;;;;:25;:31;;;;;;;;36371:32;36293:110;:153;;;;-1:-1:-1;;;;;;36421:25:0;;;;;;:19;:25;;;;;;;;36420:26;36293:153;:194;;;;-1:-1:-1;;;;;;36464:23:0;;;;;;:19;:23;;;;;;;;36463:24;36293:194;36275:338;;;36514:8;:15;;-1:-1:-1;;;;36514:15:0;-1:-1:-1;;;36514:15:0;;;36558:10;:8;:10::i;:::-;36585:8;:16;;-1:-1:-1;;;;36585:16:0;;;36275:338;36649:8;;-1:-1:-1;;;;;36758:25:0;;36633:12;36758:25;;;:19;:25;;;;;;36649:8;-1:-1:-1;;;36649:8:0;;;;;36648:9;;36758:25;;:52;;-1:-1:-1;;;;;;36787:23:0;;;;;;:19;:23;;;;;;;;36758:52;36755:99;;;-1:-1:-1;36837:5:0;36755:99;36874:12;36978:7;36975:755;;;-1:-1:-1;;;;;37019:29:0;;;;;;:25;:29;;;;;;;;37015:546;;;37072:13;;:17;37068:106;;37120:34;37150:3;37120:25;37131:13;;37120:6;:10;;:25;;;;:::i;:::-;:29;;:34::i;:::-;37113:41;;37068:106;37015:546;;;-1:-1:-1;;;;;37234:31:0;;;;;;:25;:31;;;;;;;;37231:330;;;37290:12;;:16;37286:104;;37337:33;37366:3;37337:24;37348:12;;37337:6;:10;;:24;;;;:::i;37231:330::-;37436:17;;:21;37432:114;;37488:38;37522:3;37488:29;37499:17;;37488:6;:10;;:29;;;;:::i;:38::-;37481:45;;37432:114;37592:8;;37589:93;;37624:42;37640:4;37654;37661;37624:15;:42::i;:::-;37704:14;37714:4;37704:14;;:::i;:::-;;;36975:755;37742:33;37758:4;37764:2;37768:6;37742:15;:33::i;:::-;35725:2058;;;;35612:2171;;;:::o;17359:192::-;17445:7;17481:12;17473:6;;;;17465:29;;;;-1:-1:-1;;;17465:29:0;;;;;;;;:::i;:::-;-1:-1:-1;17505:9:0;17517:5;17521:1;17517;:5;:::i;:::-;17505:17;17359:192;-1:-1:-1;;;;;17359:192:0:o;34951:294::-;-1:-1:-1;;;;;35043:50:0;;35034:95;;;;-1:-1:-1;;;35034:95:0;;8898:2:1;35034:95:0;;;8880:21:1;8937:2;8917:18;;;8910:30;8976:33;8956:18;;;8949:61;9027:18;;35034:95:0;8696:355:1;35034:95:0;-1:-1:-1;;;;;35140:31:0;;;;;;:25;:31;;;;;;:39;;-1:-1:-1;;35140:39:0;;;;;;;;;;35197:40;;35140:39;;:31;35197:40;;;34951:294;;:::o;12651:573::-;-1:-1:-1;;;;;12791:20:0;;12783:70;;;;-1:-1:-1;;;12783:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12872:23:0;;12864:71;;;;-1:-1:-1;;;12864:71:0;;;;;;;:::i;:::-;13028;13050:6;13028:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;13028:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;13008:17:0;;;:9;:17;;;;;;;;;;;:91;;;;13133:20;;;;;;;:32;;13158:6;13133:24;:32::i;:::-;-1:-1:-1;;;;;13110:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;13181:35;1645:25:1;;;13110:20:0;;13181:35;;;;;;1618:18:1;13181:35:0;1499:177:1;38407:338:0;38490:4;38446:23;8981:18;;;;;;;;;;;;;38542:34;;38568:7;;38407:338::o;38542:34::-;38596:33;38613:15;38596:16;:33::i;:::-;38672:15;;38664:63;;-1:-1:-1;;;;;38672:15:0;;;;38701:21;;38664:63;;;;38701:21;38672:15;38664:63;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;38407:338:0:o;17810:471::-;17868:7;18113:6;18109:47;;-1:-1:-1;18143:1:0;18136:8;;18109:47;18168:9;18180:5;18184:1;18180;:5;:::i;:::-;18168:17;-1:-1:-1;18213:1:0;18204:5;18208:1;18168:17;18204:5;:::i;:::-;:10;18196:56;;;;-1:-1:-1;;;18196:56:0;;9863:2:1;18196:56:0;;;9845:21:1;9902:2;9882:18;;;9875:30;9941:34;9921:18;;;9914:62;-1:-1:-1;;;9992:18:1;;;9985:31;10033:19;;18196:56:0;9661:397:1;18757:132:0;18815:7;18842:39;18846:1;18849;18842:39;;;;;;;;;;;;;;;;;:3;:39::i;37791:606::-;37943:16;;;37957:1;37943:16;;;;;;;;37919:21;;37943:16;;;;;;;;;;-1:-1:-1;37943:16:0;37919:40;;37988:4;37970;37975:1;37970:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;37970:23:0;;;-1:-1:-1;;;;;37970:23:0;;;;;38014:15;-1:-1:-1;;;;;38014:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;38004:4;38009:1;38004:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;38004:32:0;;;-1:-1:-1;;;;;38004:32:0;;;;;38049:62;38066:4;38081:15;38099:11;38049:8;:62::i;:::-;38154:224;;-1:-1:-1;;;38154:224:0;;-1:-1:-1;;;;;38154:15:0;:66;;;;:224;;38235:11;;38261:1;;38305:4;;38332;;38352:15;;38154:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;38150:240;;34693:246;;:::o;19385:278::-;19471:7;19506:12;19499:5;19491:28;;;;-1:-1:-1;;;19491:28:0;;;;;;;;:::i;:::-;-1:-1:-1;19530:9:0;19542:5;19546:1;19542;:5;:::i;14:597:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;452:6;449:1;446:13;443:91;;;522:1;517:2;508:6;497:9;493:22;489:31;482:42;443:91;-1:-1:-1;595:2:1;574:15;-1:-1:-1;;570:29:1;555:45;;;;602:2;551:54;;14:597;-1:-1:-1;;;14:597:1:o;616:131::-;-1:-1:-1;;;;;691:31:1;;681:42;;671:70;;737:1;734;727:12;752:315;820:6;828;881:2;869:9;860:7;856:23;852:32;849:52;;;897:1;894;887:12;849:52;936:9;923:23;955:31;980:5;955:31;:::i;:::-;1005:5;1057:2;1042:18;;;;1029:32;;-1:-1:-1;;;752:315:1:o;1681:456::-;1758:6;1766;1774;1827:2;1815:9;1806:7;1802:23;1798:32;1795:52;;;1843:1;1840;1833:12;1795:52;1882:9;1869:23;1901:31;1926:5;1901:31;:::i;:::-;1951:5;-1:-1:-1;2008:2:1;1993:18;;1980:32;2021:33;1980:32;2021:33;:::i;:::-;1681:456;;2073:7;;-1:-1:-1;;;2127:2:1;2112:18;;;;2099:32;;1681:456::o;2539:247::-;2598:6;2651:2;2639:9;2630:7;2626:23;2622:32;2619:52;;;2667:1;2664;2657:12;2619:52;2706:9;2693:23;2725:31;2750:5;2725:31;:::i;2791:180::-;2850:6;2903:2;2891:9;2882:7;2878:23;2874:32;2871:52;;;2919:1;2916;2909:12;2871:52;-1:-1:-1;2942:23:1;;2791:180;-1:-1:-1;2791:180:1:o;2976:160::-;3041:20;;3097:13;;3090:21;3080:32;;3070:60;;3126:1;3123;3116:12;3070:60;2976:160;;;:::o;3141:180::-;3197:6;3250:2;3238:9;3229:7;3225:23;3221:32;3218:52;;;3266:1;3263;3256:12;3218:52;3289:26;3305:9;3289:26;:::i;3326:315::-;3391:6;3399;3452:2;3440:9;3431:7;3427:23;3423:32;3420:52;;;3468:1;3465;3458:12;3420:52;3507:9;3494:23;3526:31;3551:5;3526:31;:::i;:::-;3576:5;-1:-1:-1;3600:35:1;3631:2;3616:18;;3600:35;:::i;:::-;3590:45;;3326:315;;;;;:::o;3646:388::-;3714:6;3722;3775:2;3763:9;3754:7;3750:23;3746:32;3743:52;;;3791:1;3788;3781:12;3743:52;3830:9;3817:23;3849:31;3874:5;3849:31;:::i;:::-;3899:5;-1:-1:-1;3956:2:1;3941:18;;3928:32;3969:33;3928:32;3969:33;:::i;:::-;4021:7;4011:17;;;3646:388;;;;;:::o;4039:380::-;4118:1;4114:12;;;;4161;;;4182:61;;4236:4;4228:6;4224:17;4214:27;;4182:61;4289:2;4281:6;4278:14;4258:18;4255:38;4252:161;;;4335:10;4330:3;4326:20;4323:1;4316:31;4370:4;4367:1;4360:15;4398:4;4395:1;4388:15;4252:161;;4039:380;;;:::o;4424:356::-;4626:2;4608:21;;;4645:18;;;4638:30;4704:34;4699:2;4684:18;;4677:62;4771:2;4756:18;;4424:356::o;4785:353::-;4987:2;4969:21;;;5026:2;5006:18;;;4999:30;5065:31;5060:2;5045:18;;5038:59;5129:2;5114:18;;4785:353::o;5976:127::-;6037:10;6032:3;6028:20;6025:1;6018:31;6068:4;6065:1;6058:15;6092:4;6089:1;6082:15;6108:128;6148:3;6179:1;6175:6;6172:1;6169:13;6166:39;;;6185:18;;:::i;:::-;-1:-1:-1;6221:9:1;;6108:128::o;7405:401::-;7607:2;7589:21;;;7646:2;7626:18;;;7619:30;7685:34;7680:2;7665:18;;7658:62;-1:-1:-1;;;7751:2:1;7736:18;;7729:35;7796:3;7781:19;;7405:401::o;7811:399::-;8013:2;7995:21;;;8052:2;8032:18;;;8025:30;8091:34;8086:2;8071:18;;8064:62;-1:-1:-1;;;8157:2:1;8142:18;;8135:33;8200:3;8185:19;;7811:399::o;8566:125::-;8606:4;8634:1;8631;8628:8;8625:34;;;8639:18;;:::i;:::-;-1:-1:-1;8676:9:1;;8566:125::o;9266:168::-;9306:7;9372:1;9368;9364:6;9360:14;9357:1;9354:21;9349:1;9342:9;9335:17;9331:45;9328:71;;;9379:18;;:::i;:::-;-1:-1:-1;9419:9:1;;9266:168::o;9439:217::-;9479:1;9505;9495:132;;9549:10;9544:3;9540:20;9537:1;9530:31;9584:4;9581:1;9574:15;9612:4;9609:1;9602:15;9495:132;-1:-1:-1;9641:9:1;;9439:217::o;10195:127::-;10256:10;10251:3;10247:20;10244:1;10237:31;10287:4;10284:1;10277:15;10311:4;10308:1;10301:15;10327:251;10397:6;10450:2;10438:9;10429:7;10425:23;10421:32;10418:52;;;10466:1;10463;10456:12;10418:52;10498:9;10492:16;10517:31;10542:5;10517:31;:::i;10583:980::-;10845:4;10893:3;10882:9;10878:19;10924:6;10913:9;10906:25;10950:2;10988:6;10983:2;10972:9;10968:18;10961:34;11031:3;11026:2;11015:9;11011:18;11004:31;11055:6;11090;11084:13;11121:6;11113;11106:22;11159:3;11148:9;11144:19;11137:26;;11198:2;11190:6;11186:15;11172:29;;11219:1;11229:195;11243:6;11240:1;11237:13;11229:195;;;11308:13;;-1:-1:-1;;;;;11304:39:1;11292:52;;11399:15;;;;11364:12;;;;11340:1;11258:9;11229:195;;;-1:-1:-1;;;;;;;11480:32:1;;;;11475:2;11460:18;;11453:60;-1:-1:-1;;;11544:3:1;11529:19;11522:35;11441:3;10583:980;-1:-1:-1;;;10583:980:1:o

Swarm Source

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