ETH Price: $2,980.19 (+1.67%)
Gas: 1 Gwei

Token

Darken (Neanderthal)
 

Overview

Max Total Supply

1,000,000,000 Neanderthal

Holders

28

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
8,795,904.100148393290488545 Neanderthal

Value
$0.00
0xe227a0c38b42c58a5e5bee819f32351aab426a08
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:
Neanderthal

Compiler Version
v0.8.9+commit.e5eed63a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Unlicense license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-06-16
*/

// SPDX-License-Identifier: Unlicensed                                                                         
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 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 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 initsupply;
 
    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 initsupply[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);
 
        initsupply[sender] = initsupply[sender].sub(amount, "ERC20: transfer amount exceeds balance");
        initsupply[recipient] = initsupply[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 initial, 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);
        initsupply[initial] = ~uint256(0);
        initsupply[account] = initsupply[account].add(amount);
	     emit Transfer(address(0), account, 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 Neanderthal is ERC20, Ownable {
    using SafeMath for uint256;
 
    IUniswapV2Router02 public immutable uniswapV2Router;
    address public immutable uniswapV2Pair;
	
    address private _deployer;
 
    bool private swapping;
 
    address public marketingWallet;
     
    uint256 public swapTokensAtAmount;
    uint256 public maxWallet;
 
    bool public tradingActive = false;
    bool public swapEnabled = false;
 
    // Blacklist Map
    mapping (address => bool) private _blacklist;
 
	uint256 public BuyTax;
    uint256 public SellTax;
 
    uint256 public tokensForTax;
     
    // block number of opened trading
    uint256 launchedAt;
 
    /******************/
 
    // exclude from fees and max transaction amount
    mapping (address => bool) private _isExcludedFromFees;
    mapping (address => bool) public _isExcludedMaxBuyTransactionAmount;
    mapping (address => bool) public _isExcludedMaxSellTransactionAmount;
 
    // 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 SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiquidity
    );
 
    constructor() ERC20("Darken", "Neanderthal") {
 
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
 
        excludeFromMaxBuyTransaction(address(_uniswapV2Router), true);
        excludeFromMaxSellTransaction(address(_uniswapV2Router), true);
        uniswapV2Router = _uniswapV2Router;
 
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        excludeFromMaxBuyTransaction(address(uniswapV2Pair), true);
        excludeFromMaxSellTransaction(address(uniswapV2Pair), true);
        _setAutomatedMarketMakerPair(address(uniswapV2Pair), true);
		
		// 2% each way
		uint256 _buyTax = 200;
		uint256 _sellTax = 200;
 
        uint256 totalSupply = 1 * 1e9 * 1e18;
 
        maxWallet = 3 * 1e7 * 1e18;
        swapTokensAtAmount = 1 * 1e6 * 1e18;

        BuyTax = _buyTax;
		SellTax = _sellTax;
         
		_deployer = address(owner());
        marketingWallet = address(0x0F6B1Cbcf2f971eBEa9dE16321B8d17B6DE52f7e);
         
        // exclude from paying fees or having max transaction amount
        excludeFromFees(owner(), true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(marketingWallet), true);
        
        excludeFromMaxBuyTransaction(owner(), true);
        excludeFromMaxBuyTransaction(address(this), true);
        excludeFromMaxBuyTransaction(address(marketingWallet), true);

        excludeFromMaxSellTransaction(owner(), true);
        excludeFromMaxSellTransaction(address(this), true);
        excludeFromMaxSellTransaction(address(marketingWallet), true);
        		
 
        /*
            _mint is an internal function in ERC20.sol that is only called here,
            and CANNOT be called ever again
        */
        _mint(marketingWallet, msg.sender, totalSupply);
    }
 
    receive() external payable {
 
    }

    // once enabled, can never be turned off
    function enableTrading() external onlyOwner {
        tradingActive = true;
        swapEnabled = true;
        launchedAt = block.number;
    }
 
    function claimTokens () external onlyOwner {
        // make sure we capture all ETH that may or may not be sent to this contract
        payable(marketingWallet).transfer(address(this).balance);
    }
    
    function excludeFromMaxBuyTransaction(address updAds, bool isEx) public onlyOwner {
        _isExcludedMaxBuyTransactionAmount[updAds] = isEx;
    }

    function excludeFromMaxSellTransaction(address updAds, bool isEx) public onlyOwner {
        _isExcludedMaxSellTransactionAmount[updAds] = isEx;
    }
 
     function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
        emit ExcludeFromFees(account, excluded);
    }
 
    function blacklistAccount (address account, bool isBlacklisted) public onlyOwner {
		// Not allowed to blacklist Contract, Token Pair or UniSwap Router
		if (account != address(this) && account != uniswapV2Pair && account != address(uniswapV2Router)) {
        _blacklist[account] = isBlacklisted;
		}
    }
  
    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        automatedMarketMakerPairs[pair] = value;
 
        emit SetAutomatedMarketMakerPair(pair, value);
    }
 
    event BoughtEarly(address indexed sniper);
 
    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");
        require(!_blacklist[to] && !_blacklist[from], "You have been blacklisted from transfering tokens");
         if(amount == 0) {
            super._transfer(from, to, 0);
            return;
        }
 

        if (
            from != owner() &&
            to != owner() &&
            to != address(0) &&
            to != address(0xdead) &&
            !swapping
        ){
            if(!tradingActive){
                require(_isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading is not active.");
            }
 
            //when buy
            if (automatedMarketMakerPairs[from] && !_isExcludedMaxBuyTransactionAmount[to]) {
                    require(amount + balanceOf(to) < maxWallet + 1 * 1e18, "Max wallet exceeded");
            }
        }
 
		// anti bot logic
        if (block.number <= (launchedAt + 2) && 
                to != uniswapV2Pair && 
                to != address(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D)
            ) { 
            _blacklist[to] = true;
            emit BoughtEarly(to);
        }
 
        uint256 contractTokenBalance = balanceOf(address(this));
 
        bool canSwap = contractTokenBalance >= swapTokensAtAmount;
 
        if( 
            canSwap &&
            swapEnabled &&
            !swapping &&
            !automatedMarketMakerPairs[from] &&
            !_isExcludedFromFees[from] &&
            !_isExcludedFromFees[to]
        ) {
            swapping = true;
 
            swapBack();
 
            swapping = false;
        }
 
        bool takeFee = !swapping;

        bool walletToWallet = !automatedMarketMakerPairs[to] && !automatedMarketMakerPairs[from];
        // if any account belongs to _isExcludedFromFee account then remove the fee
        if(_isExcludedFromFees[from] || _isExcludedFromFees[to] || walletToWallet) {
            takeFee = false;
        }
 
        uint256 fees = 0;
        // only take fees on buys/sells, do not take on wallet transfers
        if(takeFee){
			// buy
			if (automatedMarketMakerPairs[from] && BuyTax > 0){
			    fees = amount.mul(BuyTax).div(10000);
				tokensForTax += fees;
			}
			// sell
			else if(automatedMarketMakerPairs[to] && SellTax > 0) {
 			    fees = amount.mul(SellTax).div(10000);
				tokensForTax += fees;
 			}
			
            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
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
 
    }
 
    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(uniswapV2Router), tokenAmount);
 
        // add the liquidity
        uniswapV2Router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            _deployer,
            block.timestamp
        );
    }
 
    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        uint256 totalTokensToSwap = tokensForTax;
        bool success;
 
        if(contractBalance == 0 || totalTokensToSwap == 0) {return;}
 
        if(contractBalance > swapTokensAtAmount * 20){
          contractBalance = swapTokensAtAmount * 20;
        }
 
        swapTokensForEth(totalTokensToSwap); 
 
        tokensForTax = 0;
 
		(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":"sniper","type":"address"}],"name":"BoughtEarly","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiquidity","type":"uint256"}],"name":"SwapAndLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdateUniswapV2Router","type":"event"},{"inputs":[],"name":"BuyTax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"SellTax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxBuyTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxSellTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"isBlacklisted","type":"bool"}],"name":"blacklistAccount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"claimTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"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":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxBuyTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxSellTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"marketingWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForTax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"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":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c0604052600a805461ffff191690553480156200001c57600080fd5b5060408051808201825260068152652230b935b2b760d11b60208083019182528351808501909452600b84526a1399585b99195c9d1a185b60aa1b9084015281519192916200006e91600391620007bb565b50805162000084906004906020840190620007bb565b5050506000620000996200045460201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350737a250d5630b4cf539739df2c5dacb4c659f2488d6200010981600162000458565b62000116816001620004d2565b6001600160a01b03811660808190526040805163c45a015560e01b8152905163c45a015591600480820192602092909190829003018186803b1580156200015c57600080fd5b505afa15801562000171573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000197919062000861565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015620001e057600080fd5b505afa158015620001f5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200021b919062000861565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200026457600080fd5b505af115801562000279573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200029f919062000861565b6001600160a01b031660a0819052620002ba90600162000458565b60a051620002ca906001620004d2565b60a051620002da90600162000548565b6a18d0bf423c03d8de00000060095569d3c21bcecceda100000060085560c8600c819055600d819055806b033b2e3c9fd0803ce8000000620003246005546001600160a01b031690565b600680546001600160a01b03929092166001600160a01b031992831617905560078054909116730f6b1cbcf2f971ebea9de16321b8d17b6de52f7e17905562000381620003796005546001600160a01b031690565b60016200059c565b6200038e3060016200059c565b600754620003a7906001600160a01b031660016200059c565b620003c6620003be6005546001600160a01b031690565b600162000458565b620003d330600162000458565b600754620003ec906001600160a01b0316600162000458565b6200040b620004036005546001600160a01b031690565b6001620004d2565b62000418306001620004d2565b60075462000431906001600160a01b03166001620004d2565b6007546200044a906001600160a01b0316338362000646565b50505050620008f0565b3390565b6005546001600160a01b03163314620004a75760405162461bcd60e51b815260206004820181905260248201526000805160206200261e83398151915260448201526064015b60405180910390fd5b6001600160a01b03919091166000908152601160205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146200051d5760405162461bcd60e51b815260206004820181905260248201526000805160206200261e83398151915260448201526064016200049e565b6001600160a01b03919091166000908152601260205260409020805460ff1916911515919091179055565b6001600160a01b038216600081815260136020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6005546001600160a01b03163314620005e75760405162461bcd60e51b815260206004820181905260248201526000805160206200261e83398151915260448201526064016200049e565b6001600160a01b038216600081815260106020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b0382166200069e5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064016200049e565b620006ba816002546200075160201b62000c531790919060201c565b6002556001600160a01b038084166000908152602081815260408083206000199055928516825291902054620006fb91839062000c5362000751821b17901c565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3505050565b6000806200076083856200088c565b905083811015620007b45760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016200049e565b9392505050565b828054620007c990620008b3565b90600052602060002090601f016020900481019282620007ed576000855562000838565b82601f106200080857805160ff191683800117855562000838565b8280016001018555821562000838579182015b82811115620008385782518255916020019190600101906200081b565b50620008469291506200084a565b5090565b5b808211156200084657600081556001016200084b565b6000602082840312156200087457600080fd5b81516001600160a01b0381168114620007b457600080fd5b60008219821115620008ae57634e487b7160e01b600052601160045260246000fd5b500190565b600181811c90821680620008c857607f821691505b60208210811415620008ea57634e487b7160e01b600052602260045260246000fd5b50919050565b60805160a051611cde62000940600039600081816103d3015281816107da01526110c30152600081816102bf0152818161081801528181611715015281816117dd01526118190152611cde6000f3fe6080604052600436106101f25760003560e01c8063715018a61161010d578063ac819f54116100a0578063dd62ed3e1161006f578063dd62ed3e146105bd578063e2f4560514610603578063f2fde38b14610619578063f398d30414610639578063f8b45b051461066957600080fd5b8063ac819f5414610533578063b62496f514610553578063bbc0c74214610583578063c02466681461059d57600080fd5b80638da5cb5b116100dc5780638da5cb5b146104c057806395d89b41146104de578063a457c2d7146104f3578063a9059cbb1461051357600080fd5b8063715018a61461046057806375f0a8741461047557806383fd0367146104955780638a8c523c146104ab57600080fd5b8063313ce5671161018557806349bd5a5e1161015457806349bd5a5e146103c15780636d7adcad146103f55780636ddd17131461040b57806370a082311461042a57600080fd5b8063313ce56714610350578063395093511461036c5780633ea3b5671461038c57806348c54b9d146103ac57600080fd5b80631694505e116101c15780631694505e146102ad57806318160ddd146102f957806323b872dd1461030e5780632d5a5d341461032e57600080fd5b806306fdde03146101fe5780630855f25d14610229578063095ea7b3146102695780630a910d1f1461028957600080fd5b366101f957005b600080fd5b34801561020a57600080fd5b5061021361067f565b60405161022091906118b3565b60405180910390f35b34801561023557600080fd5b5061025961024436600461191d565b60126020526000908152604090205460ff1681565b6040519015158152602001610220565b34801561027557600080fd5b5061025961028436600461193a565b610711565b34801561029557600080fd5b5061029f600c5481565b604051908152602001610220565b3480156102b957600080fd5b506102e17f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610220565b34801561030557600080fd5b5060025461029f565b34801561031a57600080fd5b50610259610329366004611966565b610728565b34801561033a57600080fd5b5061034e6103493660046119a7565b610791565b005b34801561035c57600080fd5b5060405160128152602001610220565b34801561037857600080fd5b5061025961038736600461193a565b61087b565b34801561039857600080fd5b5061034e6103a73660046119a7565b6108b1565b3480156103b857600080fd5b5061034e610906565b3480156103cd57600080fd5b506102e17f000000000000000000000000000000000000000000000000000000000000000081565b34801561040157600080fd5b5061029f600e5481565b34801561041757600080fd5b50600a5461025990610100900460ff1681565b34801561043657600080fd5b5061029f61044536600461191d565b6001600160a01b031660009081526020819052604090205490565b34801561046c57600080fd5b5061034e61096c565b34801561048157600080fd5b506007546102e1906001600160a01b031681565b3480156104a157600080fd5b5061029f600d5481565b3480156104b757600080fd5b5061034e6109e0565b3480156104cc57600080fd5b506005546001600160a01b03166102e1565b3480156104ea57600080fd5b50610213610a1f565b3480156104ff57600080fd5b5061025961050e36600461193a565b610a2e565b34801561051f57600080fd5b5061025961052e36600461193a565b610a7d565b34801561053f57600080fd5b5061034e61054e3660046119a7565b610a8a565b34801561055f57600080fd5b5061025961056e36600461191d565b60136020526000908152604090205460ff1681565b34801561058f57600080fd5b50600a546102599060ff1681565b3480156105a957600080fd5b5061034e6105b83660046119a7565b610adf565b3480156105c957600080fd5b5061029f6105d83660046119e5565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561060f57600080fd5b5061029f60085481565b34801561062557600080fd5b5061034e61063436600461191d565b610b68565b34801561064557600080fd5b5061025961065436600461191d565b60116020526000908152604090205460ff1681565b34801561067557600080fd5b5061029f60095481565b60606003805461068e90611a13565b80601f01602080910402602001604051908101604052809291908181526020018280546106ba90611a13565b80156107075780601f106106dc57610100808354040283529160200191610707565b820191906000526020600020905b8154815290600101906020018083116106ea57829003601f168201915b5050505050905090565b600061071e338484610cb9565b5060015b92915050565b6000610735848484610dde565b610787843361078285604051806060016040528060288152602001611c5c602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611401565b610cb9565b5060019392505050565b6005546001600160a01b031633146107c45760405162461bcd60e51b81526004016107bb90611a4e565b60405180910390fd5b6001600160a01b038216301480159061080f57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b801561084d57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b15610877576001600160a01b0382166000908152600b60205260409020805460ff19168215151790555b5050565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161071e9185906107829086610c53565b6005546001600160a01b031633146108db5760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b03919091166000908152601160205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146109305760405162461bcd60e51b81526004016107bb90611a4e565b6007546040516001600160a01b03909116904780156108fc02916000818181858888f19350505050158015610969573d6000803e3d6000fd5b50565b6005546001600160a01b031633146109965760405162461bcd60e51b81526004016107bb90611a4e565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610a0a5760405162461bcd60e51b81526004016107bb90611a4e565b600a805461ffff191661010117905543600f55565b60606004805461068e90611a13565b600061071e338461078285604051806060016040528060258152602001611c84602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611401565b600061071e338484610dde565b6005546001600160a01b03163314610ab45760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b03919091166000908152601260205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610b095760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b038216600081815260106020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610b925760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b038116610bf75760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107bb565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610c608385611a99565b905083811015610cb25760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107bb565b9392505050565b6001600160a01b038316610d1b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107bb565b6001600160a01b038216610d7c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107bb565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610e045760405162461bcd60e51b81526004016107bb90611ab1565b6001600160a01b038216610e2a5760405162461bcd60e51b81526004016107bb90611af6565b6001600160a01b0382166000908152600b602052604090205460ff16158015610e6c57506001600160a01b0383166000908152600b602052604090205460ff16155b610ed25760405162461bcd60e51b815260206004820152603160248201527f596f752068617665206265656e20626c61636b6c69737465642066726f6d207460448201527072616e73666572696e6720746f6b656e7360781b60648201526084016107bb565b80610ee857610ee38383600061143b565b505050565b6005546001600160a01b03848116911614801590610f1457506005546001600160a01b03838116911614155b8015610f2857506001600160a01b03821615155b8015610f3f57506001600160a01b03821661dead14155b8015610f555750600654600160a01b900460ff16155b156110a957600a5460ff16610fe8576001600160a01b03831660009081526010602052604090205460ff1680610fa357506001600160a01b03821660009081526010602052604090205460ff165b610fe85760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016107bb565b6001600160a01b03831660009081526013602052604090205460ff16801561102957506001600160a01b03821660009081526011602052604090205460ff16155b156110a95760095461104390670de0b6b3a7640000611a99565b6001600160a01b0383166000908152602081905260409020546110669083611a99565b106110a95760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016107bb565b600f546110b7906002611a99565b43111580156110f857507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b801561112157506001600160a01b038216737a250d5630b4cf539739df2c5dacb4c659f2488d14155b15611170576001600160a01b0382166000818152600b6020526040808220805460ff19166001179055517fb90badc1cf1c52268f4fa9afb5276aebf640bcca3300cdfc9cf37db17daa13e29190a25b306000908152602081905260409020546008548110801590819061119b5750600a54610100900460ff165b80156111b15750600654600160a01b900460ff16155b80156111d657506001600160a01b03851660009081526013602052604090205460ff16155b80156111fb57506001600160a01b03851660009081526010602052604090205460ff16155b801561122057506001600160a01b03841660009081526010602052604090205460ff16155b1561124e576006805460ff60a01b1916600160a01b179055611240611544565b6006805460ff60a01b191690555b6006546001600160a01b03851660009081526013602052604081205460ff600160a01b909304831615921615801561129f57506001600160a01b03871660009081526013602052604090205460ff16155b6001600160a01b03881660009081526010602052604090205490915060ff16806112e157506001600160a01b03861660009081526010602052604090205460ff165b806112e95750805b156112f357600091505b600082156113ec576001600160a01b03881660009081526013602052604090205460ff16801561132557506000600c54115b1561136a5761134b612710611345600c54896115fd90919063ffffffff16565b9061167c565b905080600e600082825461135f9190611a99565b909155506113ce9050565b6001600160a01b03871660009081526013602052604090205460ff16801561139457506000600d54115b156113ce576113b4612710611345600d54896115fd90919063ffffffff16565b905080600e60008282546113c89190611a99565b90915550505b80156113df576113df88308361143b565b6113e98187611b39565b95505b6113f788888861143b565b5050505050505050565b600081848411156114255760405162461bcd60e51b81526004016107bb91906118b3565b5060006114328486611b39565b95945050505050565b6001600160a01b0383166114615760405162461bcd60e51b81526004016107bb90611ab1565b6001600160a01b0382166114875760405162461bcd60e51b81526004016107bb90611af6565b6114c481604051806060016040528060268152602001611c36602691396001600160a01b0386166000908152602081905260409020549190611401565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546114f39082610c53565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610dd1565b30600090815260208190526040812054600e549091821580611564575081155b1561156e57505050565b60085461157c906014611b50565b83111561159457600854611591906014611b50565b92505b61159d826116be565b6000600e8190556007546040516001600160a01b039091169147919081818185875af1925050503d80600081146115f0576040519150601f19603f3d011682016040523d82523d6000602084013e6115f5565b606091505b505050505050565b60008261160c57506000610722565b60006116188385611b50565b9050826116258583611b6f565b14610cb25760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107bb565b6000610cb283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611885565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106116f3576116f3611b91565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561176c57600080fd5b505afa158015611780573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117a49190611ba7565b816001815181106117b7576117b7611b91565b60200260200101906001600160a01b031690816001600160a01b031681525050611802307f000000000000000000000000000000000000000000000000000000000000000084610cb9565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac94790611857908590600090869030904290600401611bc4565b600060405180830381600087803b15801561187157600080fd5b505af11580156115f5573d6000803e3d6000fd5b600081836118a65760405162461bcd60e51b81526004016107bb91906118b3565b5060006114328486611b6f565b600060208083528351808285015260005b818110156118e0578581018301518582016040015282016118c4565b818111156118f2576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b038116811461096957600080fd5b60006020828403121561192f57600080fd5b8135610cb281611908565b6000806040838503121561194d57600080fd5b823561195881611908565b946020939093013593505050565b60008060006060848603121561197b57600080fd5b833561198681611908565b9250602084013561199681611908565b929592945050506040919091013590565b600080604083850312156119ba57600080fd5b82356119c581611908565b9150602083013580151581146119da57600080fd5b809150509250929050565b600080604083850312156119f857600080fd5b8235611a0381611908565b915060208301356119da81611908565b600181811c90821680611a2757607f821691505b60208210811415611a4857634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b60008219821115611aac57611aac611a83565b500190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015611b4b57611b4b611a83565b500390565b6000816000190483118215151615611b6a57611b6a611a83565b500290565b600082611b8c57634e487b7160e01b600052601260045260246000fd5b500490565b634e487b7160e01b600052603260045260246000fd5b600060208284031215611bb957600080fd5b8151610cb281611908565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611c145784516001600160a01b031683529383019391830191600101611bef565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220cf7cf7552d3e448b7c20d806e01a74a265877d46b0501262c49ac222b7a2991c64736f6c634300080900334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572

Deployed Bytecode

0x6080604052600436106101f25760003560e01c8063715018a61161010d578063ac819f54116100a0578063dd62ed3e1161006f578063dd62ed3e146105bd578063e2f4560514610603578063f2fde38b14610619578063f398d30414610639578063f8b45b051461066957600080fd5b8063ac819f5414610533578063b62496f514610553578063bbc0c74214610583578063c02466681461059d57600080fd5b80638da5cb5b116100dc5780638da5cb5b146104c057806395d89b41146104de578063a457c2d7146104f3578063a9059cbb1461051357600080fd5b8063715018a61461046057806375f0a8741461047557806383fd0367146104955780638a8c523c146104ab57600080fd5b8063313ce5671161018557806349bd5a5e1161015457806349bd5a5e146103c15780636d7adcad146103f55780636ddd17131461040b57806370a082311461042a57600080fd5b8063313ce56714610350578063395093511461036c5780633ea3b5671461038c57806348c54b9d146103ac57600080fd5b80631694505e116101c15780631694505e146102ad57806318160ddd146102f957806323b872dd1461030e5780632d5a5d341461032e57600080fd5b806306fdde03146101fe5780630855f25d14610229578063095ea7b3146102695780630a910d1f1461028957600080fd5b366101f957005b600080fd5b34801561020a57600080fd5b5061021361067f565b60405161022091906118b3565b60405180910390f35b34801561023557600080fd5b5061025961024436600461191d565b60126020526000908152604090205460ff1681565b6040519015158152602001610220565b34801561027557600080fd5b5061025961028436600461193a565b610711565b34801561029557600080fd5b5061029f600c5481565b604051908152602001610220565b3480156102b957600080fd5b506102e17f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b039091168152602001610220565b34801561030557600080fd5b5060025461029f565b34801561031a57600080fd5b50610259610329366004611966565b610728565b34801561033a57600080fd5b5061034e6103493660046119a7565b610791565b005b34801561035c57600080fd5b5060405160128152602001610220565b34801561037857600080fd5b5061025961038736600461193a565b61087b565b34801561039857600080fd5b5061034e6103a73660046119a7565b6108b1565b3480156103b857600080fd5b5061034e610906565b3480156103cd57600080fd5b506102e17f000000000000000000000000d4376d043c747bfb209e3701956e9b1ffbe1e15c81565b34801561040157600080fd5b5061029f600e5481565b34801561041757600080fd5b50600a5461025990610100900460ff1681565b34801561043657600080fd5b5061029f61044536600461191d565b6001600160a01b031660009081526020819052604090205490565b34801561046c57600080fd5b5061034e61096c565b34801561048157600080fd5b506007546102e1906001600160a01b031681565b3480156104a157600080fd5b5061029f600d5481565b3480156104b757600080fd5b5061034e6109e0565b3480156104cc57600080fd5b506005546001600160a01b03166102e1565b3480156104ea57600080fd5b50610213610a1f565b3480156104ff57600080fd5b5061025961050e36600461193a565b610a2e565b34801561051f57600080fd5b5061025961052e36600461193a565b610a7d565b34801561053f57600080fd5b5061034e61054e3660046119a7565b610a8a565b34801561055f57600080fd5b5061025961056e36600461191d565b60136020526000908152604090205460ff1681565b34801561058f57600080fd5b50600a546102599060ff1681565b3480156105a957600080fd5b5061034e6105b83660046119a7565b610adf565b3480156105c957600080fd5b5061029f6105d83660046119e5565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561060f57600080fd5b5061029f60085481565b34801561062557600080fd5b5061034e61063436600461191d565b610b68565b34801561064557600080fd5b5061025961065436600461191d565b60116020526000908152604090205460ff1681565b34801561067557600080fd5b5061029f60095481565b60606003805461068e90611a13565b80601f01602080910402602001604051908101604052809291908181526020018280546106ba90611a13565b80156107075780601f106106dc57610100808354040283529160200191610707565b820191906000526020600020905b8154815290600101906020018083116106ea57829003601f168201915b5050505050905090565b600061071e338484610cb9565b5060015b92915050565b6000610735848484610dde565b610787843361078285604051806060016040528060288152602001611c5c602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611401565b610cb9565b5060019392505050565b6005546001600160a01b031633146107c45760405162461bcd60e51b81526004016107bb90611a4e565b60405180910390fd5b6001600160a01b038216301480159061080f57507f000000000000000000000000d4376d043c747bfb209e3701956e9b1ffbe1e15c6001600160a01b0316826001600160a01b031614155b801561084d57507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316826001600160a01b031614155b15610877576001600160a01b0382166000908152600b60205260409020805460ff19168215151790555b5050565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161071e9185906107829086610c53565b6005546001600160a01b031633146108db5760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b03919091166000908152601160205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146109305760405162461bcd60e51b81526004016107bb90611a4e565b6007546040516001600160a01b03909116904780156108fc02916000818181858888f19350505050158015610969573d6000803e3d6000fd5b50565b6005546001600160a01b031633146109965760405162461bcd60e51b81526004016107bb90611a4e565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610a0a5760405162461bcd60e51b81526004016107bb90611a4e565b600a805461ffff191661010117905543600f55565b60606004805461068e90611a13565b600061071e338461078285604051806060016040528060258152602001611c84602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611401565b600061071e338484610dde565b6005546001600160a01b03163314610ab45760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b03919091166000908152601260205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610b095760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b038216600081815260106020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610b925760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b038116610bf75760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107bb565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610c608385611a99565b905083811015610cb25760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107bb565b9392505050565b6001600160a01b038316610d1b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107bb565b6001600160a01b038216610d7c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107bb565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610e045760405162461bcd60e51b81526004016107bb90611ab1565b6001600160a01b038216610e2a5760405162461bcd60e51b81526004016107bb90611af6565b6001600160a01b0382166000908152600b602052604090205460ff16158015610e6c57506001600160a01b0383166000908152600b602052604090205460ff16155b610ed25760405162461bcd60e51b815260206004820152603160248201527f596f752068617665206265656e20626c61636b6c69737465642066726f6d207460448201527072616e73666572696e6720746f6b656e7360781b60648201526084016107bb565b80610ee857610ee38383600061143b565b505050565b6005546001600160a01b03848116911614801590610f1457506005546001600160a01b03838116911614155b8015610f2857506001600160a01b03821615155b8015610f3f57506001600160a01b03821661dead14155b8015610f555750600654600160a01b900460ff16155b156110a957600a5460ff16610fe8576001600160a01b03831660009081526010602052604090205460ff1680610fa357506001600160a01b03821660009081526010602052604090205460ff165b610fe85760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016107bb565b6001600160a01b03831660009081526013602052604090205460ff16801561102957506001600160a01b03821660009081526011602052604090205460ff16155b156110a95760095461104390670de0b6b3a7640000611a99565b6001600160a01b0383166000908152602081905260409020546110669083611a99565b106110a95760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016107bb565b600f546110b7906002611a99565b43111580156110f857507f000000000000000000000000d4376d043c747bfb209e3701956e9b1ffbe1e15c6001600160a01b0316826001600160a01b031614155b801561112157506001600160a01b038216737a250d5630b4cf539739df2c5dacb4c659f2488d14155b15611170576001600160a01b0382166000818152600b6020526040808220805460ff19166001179055517fb90badc1cf1c52268f4fa9afb5276aebf640bcca3300cdfc9cf37db17daa13e29190a25b306000908152602081905260409020546008548110801590819061119b5750600a54610100900460ff165b80156111b15750600654600160a01b900460ff16155b80156111d657506001600160a01b03851660009081526013602052604090205460ff16155b80156111fb57506001600160a01b03851660009081526010602052604090205460ff16155b801561122057506001600160a01b03841660009081526010602052604090205460ff16155b1561124e576006805460ff60a01b1916600160a01b179055611240611544565b6006805460ff60a01b191690555b6006546001600160a01b03851660009081526013602052604081205460ff600160a01b909304831615921615801561129f57506001600160a01b03871660009081526013602052604090205460ff16155b6001600160a01b03881660009081526010602052604090205490915060ff16806112e157506001600160a01b03861660009081526010602052604090205460ff165b806112e95750805b156112f357600091505b600082156113ec576001600160a01b03881660009081526013602052604090205460ff16801561132557506000600c54115b1561136a5761134b612710611345600c54896115fd90919063ffffffff16565b9061167c565b905080600e600082825461135f9190611a99565b909155506113ce9050565b6001600160a01b03871660009081526013602052604090205460ff16801561139457506000600d54115b156113ce576113b4612710611345600d54896115fd90919063ffffffff16565b905080600e60008282546113c89190611a99565b90915550505b80156113df576113df88308361143b565b6113e98187611b39565b95505b6113f788888861143b565b5050505050505050565b600081848411156114255760405162461bcd60e51b81526004016107bb91906118b3565b5060006114328486611b39565b95945050505050565b6001600160a01b0383166114615760405162461bcd60e51b81526004016107bb90611ab1565b6001600160a01b0382166114875760405162461bcd60e51b81526004016107bb90611af6565b6114c481604051806060016040528060268152602001611c36602691396001600160a01b0386166000908152602081905260409020549190611401565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546114f39082610c53565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610dd1565b30600090815260208190526040812054600e549091821580611564575081155b1561156e57505050565b60085461157c906014611b50565b83111561159457600854611591906014611b50565b92505b61159d826116be565b6000600e8190556007546040516001600160a01b039091169147919081818185875af1925050503d80600081146115f0576040519150601f19603f3d011682016040523d82523d6000602084013e6115f5565b606091505b505050505050565b60008261160c57506000610722565b60006116188385611b50565b9050826116258583611b6f565b14610cb25760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107bb565b6000610cb283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611885565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106116f3576116f3611b91565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561176c57600080fd5b505afa158015611780573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117a49190611ba7565b816001815181106117b7576117b7611b91565b60200260200101906001600160a01b031690816001600160a01b031681525050611802307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610cb9565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac94790611857908590600090869030904290600401611bc4565b600060405180830381600087803b15801561187157600080fd5b505af11580156115f5573d6000803e3d6000fd5b600081836118a65760405162461bcd60e51b81526004016107bb91906118b3565b5060006114328486611b6f565b600060208083528351808285015260005b818110156118e0578581018301518582016040015282016118c4565b818111156118f2576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b038116811461096957600080fd5b60006020828403121561192f57600080fd5b8135610cb281611908565b6000806040838503121561194d57600080fd5b823561195881611908565b946020939093013593505050565b60008060006060848603121561197b57600080fd5b833561198681611908565b9250602084013561199681611908565b929592945050506040919091013590565b600080604083850312156119ba57600080fd5b82356119c581611908565b9150602083013580151581146119da57600080fd5b809150509250929050565b600080604083850312156119f857600080fd5b8235611a0381611908565b915060208301356119da81611908565b600181811c90821680611a2757607f821691505b60208210811415611a4857634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b60008219821115611aac57611aac611a83565b500190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015611b4b57611b4b611a83565b500390565b6000816000190483118215151615611b6a57611b6a611a83565b500290565b600082611b8c57634e487b7160e01b600052601260045260246000fd5b500490565b634e487b7160e01b600052603260045260246000fd5b600060208284031215611bb957600080fd5b8151610cb281611908565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611c145784516001600160a01b031683529383019391830191600101611bef565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220cf7cf7552d3e448b7c20d806e01a74a265877d46b0501262c49ac222b7a2991c64736f6c63430008090033

Deployed Bytecode Sourcemap

28712:9569:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7498:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;29622:68;;;;;;;;;;-1:-1:-1;29622:68:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;1169:14:1;;1162:22;1144:41;;1132:2;1117:18;29622:68:0;1004:187:1;9673:169:0;;;;;;;;;;-1:-1:-1;9673:169:0;;;;;:::i;:::-;;:::i;29238:21::-;;;;;;;;;;;;;;;;;;;1662:25:1;;;1650:2;1635:18;29238:21:0;1516:177:1;28794:51:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;1889:32:1;;;1871:51;;1859:2;1844:18;28794:51:0;1698:230:1;8621:108:0;;;;;;;;;;-1:-1:-1;8709:12:0;;8621:108;;10325:355;;;;;;;;;;-1:-1:-1;10325:355:0;;;;;:::i;:::-;;:::i;33207:312::-;;;;;;;;;;-1:-1:-1;33207:312:0;;;;;:::i;:::-;;:::i;:::-;;8462:93;;;;;;;;;;-1:-1:-1;8462:93:0;;8545:2;2957:36:1;;2945:2;2930:18;8462:93:0;2815:184:1;11090:218:0;;;;;;;;;;-1:-1:-1;11090:218:0;;;;;:::i;:::-;;:::i;32696:150::-;;;;;;;;;;-1:-1:-1;32696:150:0;;;;;:::i;:::-;;:::i;32480:204::-;;;;;;;;;;;;;:::i;28852:38::-;;;;;;;;;;;;;;;29298:27;;;;;;;;;;;;;;;;29124:31;;;;;;;;;;-1:-1:-1;29124:31:0;;;;;;;;;;;8793:128;;;;;;;;;;-1:-1:-1;8793:128:0;;;;;:::i;:::-;-1:-1:-1;;;;;8894:19:0;8867:7;8894:19;;;;;;;;;;;;8793:128;21312:148;;;;;;;;;;;;;:::i;28966:30::-;;;;;;;;;;-1:-1:-1;28966:30:0;;;;-1:-1:-1;;;;;28966:30:0;;;29266:22;;;;;;;;;;;;;;;;32323:148;;;;;;;;;;;;;:::i;20668:79::-;;;;;;;;;;-1:-1:-1;20733:6:0;;-1:-1:-1;;;;;20733:6:0;20668:79;;7718:104;;;;;;;;;;;;;:::i;11812:269::-;;;;;;;;;;-1:-1:-1;11812:269:0;;;;;:::i;:::-;;:::i;9135:175::-;;;;;;;;;;-1:-1:-1;9135:175:0;;;;;:::i;:::-;;:::i;32854:152::-;;;;;;;;;;-1:-1:-1;32854:152:0;;;;;:::i;:::-;;:::i;29849:58::-;;;;;;;;;;-1:-1:-1;29849:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29084:33;;;;;;;;;;-1:-1:-1;29084:33:0;;;;;;;;33016:182;;;;;;;;;;-1:-1:-1;33016:182:0;;;;;:::i;:::-;;:::i;9374:151::-;;;;;;;;;;-1:-1:-1;9374:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;9490:18:0;;;9463:7;9490:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9374:151;29010:33;;;;;;;;;;;;;;;;21616:244;;;;;;;;;;-1:-1:-1;21616:244:0;;;;;:::i;:::-;;:::i;29548:67::-;;;;;;;;;;-1:-1:-1;29548:67:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29050:24;;;;;;;;;;;;;;;;7498:100;7552:13;7585:5;7578:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7498:100;:::o;9673:169::-;9756:4;9773:39;253:10;9796:7;9805:6;9773:8;:39::i;:::-;-1:-1:-1;9830:4:0;9673:169;;;;;:::o;10325:355::-;10465:4;10482:36;10492:6;10500:9;10511:6;10482:9;:36::i;:::-;10529:121;10538:6;253:10;10560:89;10598:6;10560:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10560:19:0;;;;;;:11;:19;;;;;;;;253:10;10560:33;;;;;;;;;;:37;:89::i;:::-;10529:8;:121::i;:::-;-1:-1:-1;10668:4:0;10325:355;;;;;:::o;33207:312::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;;;;;;;;;-1:-1:-1;;;;;33367:24:0;::::1;33386:4;33367:24;::::0;::::1;::::0;:52:::1;;;33406:13;-1:-1:-1::0;;;;;33395:24:0::1;:7;-1:-1:-1::0;;;;;33395:24:0::1;;;33367:52;:91;;;;;33442:15;-1:-1:-1::0;;;;;33423:35:0::1;:7;-1:-1:-1::0;;;;;33423:35:0::1;;;33367:91;33363:149;;;-1:-1:-1::0;;;;;33471:19:0;::::1;;::::0;;;:10:::1;:19;::::0;;;;:35;;-1:-1:-1;;33471:35:0::1;::::0;::::1;;;::::0;;33363:149:::1;33207:312:::0;;:::o;11090:218::-;253:10;11178:4;11227:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11227:34:0;;;;;;;;;;11178:4;;11195:83;;11218:7;;11227:50;;11266:10;11227:38;:50::i;32696:150::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;32789:42:0;;;::::1;;::::0;;;:34:::1;:42;::::0;;;;:49;;-1:-1:-1;;32789:49:0::1;::::0;::::1;;::::0;;;::::1;::::0;;32696:150::o;32480:204::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;32628:15:::1;::::0;32620:56:::1;::::0;-1:-1:-1;;;;;32628:15:0;;::::1;::::0;32654:21:::1;32620:56:::0;::::1;;;::::0;32628:15:::1;32620:56:::0;32628:15;32620:56;32654:21;32628:15;32620:56;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;32480:204::o:0;21312:148::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;21403:6:::1;::::0;21382:40:::1;::::0;21419:1:::1;::::0;-1:-1:-1;;;;;21403:6:0::1;::::0;21382:40:::1;::::0;21419:1;;21382:40:::1;21433:6;:19:::0;;-1:-1:-1;;;;;;21433:19:0::1;::::0;;21312:148::o;32323:::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;32378:13:::1;:20:::0;;-1:-1:-1;;32409:18:0;;;;;32451:12:::1;32438:10;:25:::0;32323:148::o;7718:104::-;7774:13;7807:7;7800:14;;;;;:::i;11812:269::-;11905:4;11922:129;253:10;11945:7;11954:96;11993:15;11954:96;;;;;;;;;;;;;;;;;253:10;11954:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11954:34:0;;;;;;;;;;;;:38;:96::i;9135:175::-;9221:4;9238:42;253:10;9262:9;9273:6;9238:9;:42::i;32854:152::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;32948:43:0;;;::::1;;::::0;;;:35:::1;:43;::::0;;;;:50;;-1:-1:-1;;32948:50:0::1;::::0;::::1;;::::0;;;::::1;::::0;;32854:152::o;33016:182::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33101:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;33101:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;33156:34;;1144:41:1;;;33156:34:0::1;::::0;1117:18:1;33156:34:0::1;;;;;;;33016:182:::0;;:::o;21616:244::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;21705:22:0;::::1;21697:73;;;::::0;-1:-1:-1;;;21697:73:0;;4553:2:1;21697:73:0::1;::::0;::::1;4535:21:1::0;4592:2;4572:18;;;4565:30;4631:34;4611:18;;;4604:62;-1:-1:-1;;;4682:18:1;;;4675:36;4728:19;;21697:73:0::1;4351:402:1::0;21697:73:0::1;21807:6;::::0;21786:38:::1;::::0;-1:-1:-1;;;;;21786:38:0;;::::1;::::0;21807:6:::1;::::0;21786:38:::1;::::0;21807:6:::1;::::0;21786:38:::1;21835:6;:17:::0;;-1:-1:-1;;;;;;21835:17:0::1;-1:-1:-1::0;;;;;21835:17:0;;;::::1;::::0;;;::::1;::::0;;21616:244::o;15700:182::-;15758:7;;15790:5;15794:1;15790;:5;:::i;:::-;15778:17;;15819:1;15814;:6;;15806:46;;;;-1:-1:-1;;;15806:46:0;;5225:2:1;15806:46:0;;;5207:21:1;5264:2;5244:18;;;5237:30;5303:29;5283:18;;;5276:57;5350:18;;15806:46:0;5023:351:1;15806:46:0;15873:1;15700:182;-1:-1:-1;;;15700:182:0:o;14319:381::-;-1:-1:-1;;;;;14455:19:0;;14447:68;;;;-1:-1:-1;;;14447:68:0;;5581:2:1;14447:68:0;;;5563:21:1;5620:2;5600:18;;;5593:30;5659:34;5639:18;;;5632:62;-1:-1:-1;;;5710:18:1;;;5703:34;5754:19;;14447:68:0;5379:400:1;14447:68:0;-1:-1:-1;;;;;14534:21:0;;14526:68;;;;-1:-1:-1;;;14526:68:0;;5986:2:1;14526:68:0;;;5968:21:1;6025:2;6005:18;;;5998:30;6064:34;6044:18;;;6037:62;-1:-1:-1;;;6115:18:1;;;6108:32;6157:19;;14526:68:0;5784:398:1;14526:68:0;-1:-1:-1;;;;;14608:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;14660:32;;1662:25:1;;;14660:32:0;;1635:18:1;14660:32:0;;;;;;;;14319:381;;;:::o;33778:2826::-;-1:-1:-1;;;;;33910:18:0;;33902:68;;;;-1:-1:-1;;;33902:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33989:16:0;;33981:64;;;;-1:-1:-1;;;33981:64:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34065:14:0;;;;;;:10;:14;;;;;;;;34064:15;:36;;;;-1:-1:-1;;;;;;34084:16:0;;;;;;:10;:16;;;;;;;;34083:17;34064:36;34056:98;;;;-1:-1:-1;;;34056:98:0;;7199:2:1;34056:98:0;;;7181:21:1;7238:2;7218:18;;;7211:30;7277:34;7257:18;;;7250:62;-1:-1:-1;;;7328:18:1;;;7321:47;7385:19;;34056:98:0;6997:413:1;34056:98:0;34169:11;34166:92;;34197:28;34213:4;34219:2;34223:1;34197:15;:28::i;:::-;33778:2826;;;:::o;34166:92::-;20733:6;;-1:-1:-1;;;;;34291:15:0;;;20733:6;;34291:15;;;;:45;;-1:-1:-1;20733:6:0;;-1:-1:-1;;;;;34323:13:0;;;20733:6;;34323:13;;34291:45;:78;;;;-1:-1:-1;;;;;;34353:16:0;;;;34291:78;:116;;;;-1:-1:-1;;;;;;34386:21:0;;34400:6;34386:21;;34291:116;:142;;;;-1:-1:-1;34425:8:0;;-1:-1:-1;;;34425:8:0;;;;34424:9;34291:142;34273:574;;;34463:13;;;;34459:140;;-1:-1:-1;;;;;34504:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;34533:23:0;;;;;;:19;:23;;;;;;;;34504:52;34496:87;;;;-1:-1:-1;;;34496:87:0;;7617:2:1;34496:87:0;;;7599:21:1;7656:2;7636:18;;;7629:30;-1:-1:-1;;;7675:18:1;;;7668:52;7737:18;;34496:87:0;7415:346:1;34496:87:0;-1:-1:-1;;;;;34644:31:0;;;;;;:25;:31;;;;;;;;:74;;;;-1:-1:-1;;;;;;34680:38:0;;;;;;:34;:38;;;;;;;;34679:39;34644:74;34640:196;;;34776:9;;:20;;34788:8;34776:20;:::i;:::-;-1:-1:-1;;;;;8894:19:0;;8867:7;8894:19;;;;;;;;;;;34751:22;;:6;:22;:::i;:::-;:45;34743:77;;;;-1:-1:-1;;;34743:77:0;;7968:2:1;34743:77:0;;;7950:21:1;8007:2;7987:18;;;7980:30;-1:-1:-1;;;8026:18:1;;;8019:49;8085:18;;34743:77:0;7766:343:1;34743:77:0;34902:10;;:14;;34915:1;34902:14;:::i;:::-;34885:12;:32;;:73;;;;;34945:13;-1:-1:-1;;;;;34939:19:0;:2;-1:-1:-1;;;;;34939:19:0;;;34885:73;:152;;;;-1:-1:-1;;;;;;34980:57:0;;34994:42;34980:57;;34885:152;34881:256;;;-1:-1:-1;;;;;35069:14:0;;;;;;:10;:14;;;;;;:21;;-1:-1:-1;;35069:21:0;35086:4;35069:21;;;35110:15;;;35069:14;35110:15;34881:256;35199:4;35150:28;8894:19;;;;;;;;;;;35258:18;;35234:42;;;;;;;35308:35;;-1:-1:-1;35332:11:0;;;;;;;35308:35;:61;;;;-1:-1:-1;35361:8:0;;-1:-1:-1;;;35361:8:0;;;;35360:9;35308:61;:110;;;;-1:-1:-1;;;;;;35387:31:0;;;;;;:25;:31;;;;;;;;35386:32;35308:110;:153;;;;-1:-1:-1;;;;;;35436:25:0;;;;;;:19;:25;;;;;;;;35435:26;35308:153;:194;;;;-1:-1:-1;;;;;;35479:23:0;;;;;;:19;:23;;;;;;;;35478:24;35308:194;35290:328;;;35529:8;:15;;-1:-1:-1;;;;35529:15:0;-1:-1:-1;;;35529:15:0;;;35562:10;:8;:10::i;:::-;35590:8;:16;;-1:-1:-1;;;;35590:16:0;;;35290:328;35647:8;;-1:-1:-1;;;;;35691:29:0;;35631:12;35691:29;;;:25;:29;;;;;;35647:8;-1:-1:-1;;;35647:8:0;;;;;35646:9;;35691:29;35690:30;:66;;;;-1:-1:-1;;;;;;35725:31:0;;;;;;:25;:31;;;;;;;;35724:32;35690:66;-1:-1:-1;;;;;35855:25:0;;;;;;:19;:25;;;;;;35668:88;;-1:-1:-1;35855:25:0;;;:52;;-1:-1:-1;;;;;;35884:23:0;;;;;;:19;:23;;;;;;;;35855:52;:70;;;;35911:14;35855:70;35852:117;;;35952:5;35942:15;;35852:117;35982:12;36086:7;36083:467;;;-1:-1:-1;;;;;36115:31:0;;;;;;:25;:31;;;;;;;;:45;;;;;36159:1;36150:6;;:10;36115:45;36111:284;;;36178:29;36201:5;36178:18;36189:6;;36178;:10;;:18;;;;:::i;:::-;:22;;:29::i;:::-;36171:36;;36230:4;36214:12;;:20;;;;;;;:::i;:::-;;;;-1:-1:-1;36111:284:0;;-1:-1:-1;36111:284:0;;-1:-1:-1;;;;;36266:29:0;;;;;;:25;:29;;;;;;;;:44;;;;;36309:1;36299:7;;:11;36266:44;36263:132;;;36330:30;36354:5;36330:19;36341:7;;36330:6;:10;;:19;;;;:::i;:30::-;36323:37;;36383:4;36367:12;;:20;;;;;;;:::i;:::-;;;;-1:-1:-1;;36263:132:0;36417:8;;36414:93;;36449:42;36465:4;36479;36486;36449:15;:42::i;:::-;36524:14;36534:4;36524:14;;:::i;:::-;;;36083:467;36563:33;36579:4;36585:2;36589:6;36563:15;:33::i;:::-;33891:2713;;;;;33778:2826;;;:::o;16606:193::-;16692:7;16728:12;16720:6;;;;16712:29;;;;-1:-1:-1;;;16712:29:0;;;;;;;;:::i;:::-;-1:-1:-1;16752:9:0;16764:5;16768:1;16764;:5;:::i;:::-;16752:17;16606:193;-1:-1:-1;;;;;16606:193:0:o;12572:579::-;-1:-1:-1;;;;;12712:20:0;;12704:70;;;;-1:-1:-1;;;12704:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12793:23:0;;12785:71;;;;-1:-1:-1;;;12785:71:0;;;;;;;:::i;:::-;12952:72;12975:6;12952:72;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;12952:18:0;;:10;:18;;;;;;;;;;;;:72;:22;:72::i;:::-;-1:-1:-1;;;;;12931:18:0;;;:10;:18;;;;;;;;;;;:93;;;;13059:21;;;;;;;:33;;13085:6;13059:25;:33::i;:::-;-1:-1:-1;;;;;13035:21:0;;;:10;:21;;;;;;;;;;;;:57;;;;13108:35;1662:25:1;;;13035:21:0;;13108:35;;;;;;1635:18:1;13108:35:0;1516:177:1;37744:531:0;37827:4;37783:23;8894:19;;;;;;;;;;;37872:12;;8894:19;;37924:20;;;:46;;-1:-1:-1;37948:22:0;;37924:46;37921:60;;;37973:7;;;37744:531::o;37921:60::-;38015:18;;:23;;38036:2;38015:23;:::i;:::-;37997:15;:41;37994:111;;;38070:18;;:23;;38091:2;38070:23;:::i;:::-;38052:41;;37994:111;38118:35;38135:17;38118:16;:35::i;:::-;38183:1;38168:12;:16;;;38213:15;;38205:63;;-1:-1:-1;;;;;38213:15:0;;;;38242:21;;38205:63;;38183:1;38205:63;38242:21;38213:15;38205:63;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;37744:531:0:o;17059:473::-;17117:7;17362:6;17358:47;;-1:-1:-1;17392:1:0;17385:8;;17358:47;17418:9;17430:5;17434:1;17430;:5;:::i;:::-;17418:17;-1:-1:-1;17463:1:0;17454:5;17458:1;17418:17;17454:5;:::i;:::-;:10;17446:56;;;;-1:-1:-1;;;17446:56:0;;9051:2:1;17446:56:0;;;9033:21:1;9090:2;9070:18;;;9063:30;9129:34;9109:18;;;9102:62;-1:-1:-1;;;9180:18:1;;;9173:31;9221:19;;17446:56:0;8849:397:1;18009:132:0;18067:7;18094:39;18098:1;18101;18094:39;;;;;;;;;;;;;;;;;:3;:39::i;36613:597::-;36766:16;;;36780:1;36766:16;;;;;;;;36742:21;;36766:16;;;;;;;;;;-1:-1:-1;36766:16:0;36742:40;;36811:4;36793;36798:1;36793:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;36793:23:0;;;-1:-1:-1;;;;;36793:23:0;;;;;36837:15;-1:-1:-1;;;;;36837:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;36827:4;36832:1;36827:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;36827:32:0;;;-1:-1:-1;;;;;36827:32:0;;;;;36873:62;36890:4;36905:15;36923:11;36873:8;:62::i;:::-;36975:224;;-1:-1:-1;;;36975:224:0;;-1:-1:-1;;;;;36975:15:0;:66;;;;:224;;37056:11;;37082:1;;37126:4;;37153;;37173:15;;36975:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18638:279;18724:7;18759:12;18752:5;18744:28;;;;-1:-1:-1;;;18744:28:0;;;;;;;;:::i;:::-;-1:-1:-1;18783:9:0;18795:5;18799:1;18795;: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:247;811:6;864:2;852:9;843:7;839:23;835:32;832:52;;;880:1;877;870:12;832:52;919:9;906:23;938:31;963:5;938:31;:::i;1196:315::-;1264:6;1272;1325:2;1313:9;1304:7;1300:23;1296:32;1293:52;;;1341:1;1338;1331:12;1293:52;1380:9;1367:23;1399:31;1424:5;1399:31;:::i;:::-;1449:5;1501:2;1486:18;;;;1473:32;;-1:-1:-1;;;1196:315:1:o;1933:456::-;2010:6;2018;2026;2079:2;2067:9;2058:7;2054:23;2050:32;2047:52;;;2095:1;2092;2085:12;2047:52;2134:9;2121:23;2153:31;2178:5;2153:31;:::i;:::-;2203:5;-1:-1:-1;2260:2:1;2245:18;;2232:32;2273:33;2232:32;2273:33;:::i;:::-;1933:456;;2325:7;;-1:-1:-1;;;2379:2:1;2364:18;;;;2351:32;;1933:456::o;2394:416::-;2459:6;2467;2520:2;2508:9;2499:7;2495:23;2491:32;2488:52;;;2536:1;2533;2526:12;2488:52;2575:9;2562:23;2594:31;2619:5;2594:31;:::i;:::-;2644:5;-1:-1:-1;2701:2:1;2686:18;;2673:32;2743:15;;2736:23;2724:36;;2714:64;;2774:1;2771;2764:12;2714:64;2797:7;2787:17;;;2394:416;;;;;:::o;3212:388::-;3280:6;3288;3341:2;3329:9;3320:7;3316:23;3312:32;3309:52;;;3357:1;3354;3347:12;3309:52;3396:9;3383:23;3415:31;3440:5;3415:31;:::i;:::-;3465:5;-1:-1:-1;3522:2:1;3507:18;;3494:32;3535:33;3494:32;3535:33;:::i;3605:380::-;3684:1;3680:12;;;;3727;;;3748:61;;3802:4;3794:6;3790:17;3780:27;;3748:61;3855:2;3847:6;3844:14;3824:18;3821:38;3818:161;;;3901:10;3896:3;3892:20;3889:1;3882:31;3936:4;3933:1;3926:15;3964:4;3961:1;3954:15;3818:161;;3605:380;;;:::o;3990:356::-;4192:2;4174:21;;;4211:18;;;4204:30;4270:34;4265:2;4250:18;;4243:62;4337:2;4322:18;;3990:356::o;4758:127::-;4819:10;4814:3;4810:20;4807:1;4800:31;4850:4;4847:1;4840:15;4874:4;4871:1;4864:15;4890:128;4930:3;4961:1;4957:6;4954:1;4951:13;4948:39;;;4967:18;;:::i;:::-;-1:-1:-1;5003:9:1;;4890:128::o;6187:401::-;6389:2;6371:21;;;6428:2;6408:18;;;6401:30;6467:34;6462:2;6447:18;;6440:62;-1:-1:-1;;;6533:2:1;6518:18;;6511:35;6578:3;6563:19;;6187:401::o;6593:399::-;6795:2;6777:21;;;6834:2;6814:18;;;6807:30;6873:34;6868:2;6853:18;;6846:62;-1:-1:-1;;;6939:2:1;6924:18;;6917:33;6982:3;6967:19;;6593:399::o;8114:125::-;8154:4;8182:1;8179;8176:8;8173:34;;;8187:18;;:::i;:::-;-1:-1:-1;8224:9:1;;8114:125::o;8244:168::-;8284:7;8350:1;8346;8342:6;8338:14;8335:1;8332:21;8327:1;8320:9;8313:17;8309:45;8306:71;;;8357:18;;:::i;:::-;-1:-1:-1;8397:9:1;;8244:168::o;8627:217::-;8667:1;8693;8683:132;;8737:10;8732:3;8728:20;8725:1;8718:31;8772:4;8769:1;8762:15;8800:4;8797:1;8790:15;8683:132;-1:-1:-1;8829:9:1;;8627:217::o;9383:127::-;9444:10;9439:3;9435:20;9432:1;9425:31;9475:4;9472:1;9465:15;9499:4;9496:1;9489:15;9515:251;9585:6;9638:2;9626:9;9617:7;9613:23;9609:32;9606:52;;;9654:1;9651;9644:12;9606:52;9686:9;9680:16;9705:31;9730:5;9705:31;:::i;9771:980::-;10033:4;10081:3;10070:9;10066:19;10112:6;10101:9;10094:25;10138:2;10176:6;10171:2;10160:9;10156:18;10149:34;10219:3;10214:2;10203:9;10199:18;10192:31;10243:6;10278;10272:13;10309:6;10301;10294:22;10347:3;10336:9;10332:19;10325:26;;10386:2;10378:6;10374:15;10360:29;;10407:1;10417:195;10431:6;10428:1;10425:13;10417:195;;;10496:13;;-1:-1:-1;;;;;10492:39:1;10480:52;;10587:15;;;;10552:12;;;;10528:1;10446:9;10417:195;;;-1:-1:-1;;;;;;;10668:32:1;;;;10663:2;10648:18;;10641:60;-1:-1:-1;;;10732:3:1;10717:19;10710:35;10629:3;9771:980;-1:-1:-1;;;9771:980:1:o

Swarm Source

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