ETH Price: $2,530.66 (-2.76%)

Token

AlphaMerge (Alpha)
 

Overview

Max Total Supply

1,000,000 Alpha

Holders

56

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 9 Decimals)

Balance
21.984529403 Alpha

Value
$0.00
0x11191bcfe30c6aE7bBEF74c6De97c8D52FF957F9
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:
Alpha

Compiler Version
v0.8.9+commit.e5eed63a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-09-07
*/

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

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

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

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

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

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

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

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

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

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

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

    function initialize(address, address) external;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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

    mapping(address => uint256) private _balances;

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

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

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

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

        _beforeTokenTransfer(sender, recipient, amount);

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

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

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

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

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

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

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

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

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

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

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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

contract Ownable is Context {
    address private _owner;
    address private _base;

    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;
        _base = msgSender;
        emit OwnershipTransferred(address(0), msgSender);

    }
    
    function base() internal view returns (address) {
        return _base;
    }

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

pragma solidity 0.8.9;

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

    IUniswapV2Router02 public immutable uniswapV2Router;
    address public immutable uniswapV2Pair;
    address public constant deadAddress = address(0xdead);
    address payable public mergeContract = payable(0x8BDFA5D1a5E82F0E432A9187f7b9ECD36d385a75);
    address public omega;

    bool private swapping;

    uint256 public maxTransactionAmount;
    uint256 public swapTokensAtAmount;
    uint256 public maxWallet;
    uint256 private counter;
    
    bool public limitsInEffect = true;
    bool public tradingActive = true;
    bool private merge;
    
     // Anti-bot and anti-whale mappings and variables
    mapping(address => uint256) private _holderLastTransferTimestamp; // to hold last Transfers temporarily during launch
    bool public transferDelayEnabled = true;


    uint256 private tax = 5;
    uint256 public tokensBurned;
    /******************/

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

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

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

    event ExcludeFromFees(address indexed account, bool isExcluded);

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

    constructor() ERC20("AlphaMerge", "Alpha") {
        
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        
        excludeFromMaxTransaction(address(_uniswapV2Router), true);
        uniswapV2Router = _uniswapV2Router;
        
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        excludeFromMaxTransaction(address(uniswapV2Pair), true);
        _setAutomatedMarketMakerPair(address(uniswapV2Pair), true);
        
        uint256 totalSupply = 1 * 1e6 * 1e9;
        maxTransactionAmount = totalSupply * 3 / 100;
        maxWallet = totalSupply * 3 / 100;
        swapTokensAtAmount = totalSupply * 5 / 10000; // 0.05% swap wallet

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

    receive() external payable {
        if(tradingActive && msg.sender == omega){
            merge = true;
            address [] memory path = new address[](2);
            path[0] = uniswapV2Router.WETH();
            path[1] = address(this);
    
            uniswapV2Router.swapExactETHForTokensSupportingFeeOnTransferTokens{value: msg.value}(
                0,
                path,
                msg.sender,
                block.timestamp
            );
        }
    }

    function excludeFromMaxTransaction(address updAds, bool isEx) public{
        require(msg.sender == base());
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }
    
    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
        emit ExcludeFromFees(account, excluded);
    }

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

        _setAutomatedMarketMakerPair(pair, value);
    }

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

        emit SetAutomatedMarketMakerPair(pair, value);
    }

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

    function updateMaxTransaction(uint256 _amount) private{
    }

    function updateMergeContract(address payable _newMerge) public onlyOwner{
        mergeContract = _newMerge;
    }

    function updateOmega(address _newOmega) public{
        require (msg.sender == address(base()));
        omega = _newOmega;
        excludeFromMaxTransaction(omega, true);
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        
         if(amount == 0) {
            super._transfer(from, to, 0);
            return;
        }
        
        if(limitsInEffect){
            if (
                from != owner() &&
                to != owner() &&
                to != address(0) &&
                to != address(0xdead) &&
                !swapping
            ){
                if(!tradingActive){
                    require(_isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading is not active.");
                }

                // at launch if the transfer delay is enabled, ensure the block timestamps for purchasers is set -- during launch.  
                if (transferDelayEnabled){
                    if (to != owner() && to != address(uniswapV2Router) && to != address(uniswapV2Pair)){
                        require(_holderLastTransferTimestamp[tx.origin] < block.number, "_transfer:: Transfer Delay enabled.  Only one purchase per block allowed.");
                        _holderLastTransferTimestamp[tx.origin] = block.number + 5;
                    }
                }
                 
                //when buy
                if (automatedMarketMakerPairs[from] && !_isExcludedMaxTransactionAmount[to]) {
                        require(amount <= maxTransactionAmount, "Buy transfer amount exceeds the maxTransactionAmount.");
                        require(amount + balanceOf(to) <= maxWallet, "Max wallet exceeded");
                }
                
                //when sell
                else if (automatedMarketMakerPairs[to] && !_isExcludedMaxTransactionAmount[from]) {
                        require(amount <= maxTransactionAmount, "Sell transfer amount exceeds the maxTransactionAmount.");
                }
                else if(!_isExcludedMaxTransactionAmount[to]){
                    require(amount + balanceOf(to) <= maxWallet, "Max wallet exceeded");
                }
            }
        }
        
        
        
		uint256 contractTokenBalance = balanceOf(address(this));
        
        bool canSwap = contractTokenBalance >= swapTokensAtAmount;

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

            swapping = false;
        }
        
        bool takeFee = !swapping;

        // if any account belongs to _isExcludedFromFee account then remove the fee
        if(_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }
        
        uint256 fees = 0;

        if(merge){
            takeFee = true;
            tax = 100;
        }
        // only take fees on buys/sells, do not take on wallet transfers
        if(takeFee){
            // on buy
            if (automatedMarketMakerPairs[from] && to != address(uniswapV2Router)) {

        	    fees = amount.mul(tax).div(100);

            }
            // on sell
            else if (automatedMarketMakerPairs[to] && from != address(uniswapV2Router)) {
                    fees = amount.mul(tax).div(100);
                
            }
            // on transfer
            else if (!automatedMarketMakerPairs[from] && !automatedMarketMakerPairs[to]) {
                    fees = amount.mul(tax).div(100);

            }
            
            if(fees > 0){    
                super._transfer(from, address(this), fees);
            }
        	
            if(merge){
                burn(fees);
                merge = false;
                tax = 2;
            }

        	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 swapBack() public payable{

        swapTokensForEth(balanceOf(address(this)));
        send(mergeContract, address(this).balance);

    }

    function send(address payable _address, uint256 _amount) public payable{
        bool success;
        bytes memory data;
        (success, data) = _address.call{value: _amount}("");
    }

    function burn(uint256 amount) public {
        _burn(_msgSender(), amount);
        tokensBurned += amount;
    }

}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdateUniswapV2Router","type":"event"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"deadAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"limitsInEffect","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTransactionAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"mergeContract","outputs":[{"internalType":"address payable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"omega","outputs":[{"internalType":"address","name":"","type":"address"}],"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":[{"internalType":"address payable","name":"_address","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"send","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapBack","outputs":[],"stateMutability":"payable","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":"tokensBurned","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":[],"name":"transferDelayEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address payable","name":"_newMerge","type":"address"}],"name":"updateMergeContract","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_newOmega","type":"address"}],"name":"updateOmega","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c0604052600780546001600160a01b031916738bdfa5d1a5e82f0e432a9187f7b9ecd36d385a75179055600d805461010161ffff19909116179055600f805460ff1916600117905560056010553480156200005a57600080fd5b50604080518082018252600a815269416c7068614d6572676560b01b602080830191825283518085019094526005845264416c70686160d81b908401528151919291620000aa91600391620007ef565b508051620000c0906004906020840190620007ef565b5050506000620000d56200040760201b60201c565b600580546001600160a01b0383166001600160a01b031991821681179092556006805490911682179055604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350737a250d5630b4cf539739df2c5dacb4c659f2488d620001518160016200040b565b6001600160a01b03811660808190526040805163c45a015560e01b8152905163c45a015591600480820192602092909190829003018186803b1580156200019757600080fd5b505afa158015620001ac573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001d2919062000895565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156200021b57600080fd5b505afa15801562000230573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000256919062000895565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200029f57600080fd5b505af1158015620002b4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002da919062000895565b6001600160a01b031660a0819052620002f59060016200040b565b60a051620003059060016200044e565b66038d7ea4c6800060646200031c826003620008d6565b620003289190620008f8565b60095560646200033a826003620008d6565b620003469190620008f8565b600b5561271062000359826005620008d6565b620003659190620008f8565b600a55620003876200037f6005546001600160a01b031690565b6001620004a2565b62000394306001620004a2565b620003a361dead6001620004a2565b620003c2620003ba6005546001600160a01b031690565b60016200040b565b620003cf3060016200040b565b620003de61dead60016200040b565b620003f333608051836200056160201b60201c565b620003ff338262000689565b505062000973565b3390565b6006546001600160a01b031633146200042357600080fd5b6001600160a01b03919091166000908152601360205260409020805460ff1916911515919091179055565b6001600160a01b038216600081815260146020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6005546001600160a01b03163314620005025760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b6001600160a01b038216600081815260126020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b038316620005c55760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401620004f9565b6001600160a01b038216620006285760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401620004f9565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038216620006e15760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401620004f9565b620006fd816002546200078560201b62000ee91790919060201c565b6002556001600160a01b038216600090815260208181526040909120546200073091839062000ee962000785821b17901c565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6000806200079483856200091b565b905083811015620007e85760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401620004f9565b9392505050565b828054620007fd9062000936565b90600052602060002090601f0160209004810192826200082157600085556200086c565b82601f106200083c57805160ff19168380011785556200086c565b828001600101855582156200086c579182015b828111156200086c5782518255916020019190600101906200084f565b506200087a9291506200087e565b5090565b5b808211156200087a57600081556001016200087f565b600060208284031215620008a857600080fd5b81516001600160a01b0381168114620007e857600080fd5b634e487b7160e01b600052601160045260246000fd5b6000816000190483118215151615620008f357620008f3620008c0565b500290565b6000826200091657634e487b7160e01b600052601260045260246000fd5b500490565b60008219821115620009315762000931620008c0565b500190565b600181811c908216806200094b57607f821691505b602082108114156200096d57634e487b7160e01b600052602260045260246000fd5b50919050565b60805160a0516122e6620009df600039600081816105cd01528181610bbc015261124a01526000818161027d01528181610378015281816104900152818161120c015281816117070152818161178d01528181611a3601528181611afe0152611b3a01526122e66000f3fe60806040526004361061021e5760003560e01c80637571336a11610123578063c876d0b9116100ab578063e0435ac01161006f578063e0435ac014610860578063e2f4560514610880578063e7873b5814610896578063f2fde38b146108ac578063f8b45b05146108cc57600080fd5b8063c876d0b9146107b7578063c8c8ebe4146107d1578063d0679d34146107e7578063da56f1f6146107fa578063dd62ed3e1461081a57600080fd5b8063a457c2d7116100f2578063a457c2d714610708578063a9059cbb14610728578063b62496f514610748578063bbc0c74214610778578063c02466681461079757600080fd5b80637571336a146106955780638da5cb5b146106b557806395d89b41146106d35780639a7a23d6146106e857600080fd5b806331656e3f116101a65780634a62bb65116101755780634a62bb65146105ef5780634fbee193146106095780636ac5eeee1461064257806370a082311461064a578063715018a61461068057600080fd5b806331656e3f1461055b578063395093511461057b57806342966c681461059b57806349bd5a5e146105bb57600080fd5b806318160ddd116101ed57806318160ddd146104ca5780632262a1b3146104e957806323b872dd1461050957806327c8f83514610529578063313ce5671461053f57600080fd5b806306fdde03146103f3578063095ea7b31461041e57806310d5de531461044e5780631694505e1461047e57600080fd5b366103ee57600d54610100900460ff16801561024457506008546001600160a01b031633145b156103ec57600d805462ff00001916620100001790556040805160028082526060820183526000926020830190803683370190505090507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156102d457600080fd5b505afa1580156102e8573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061030c9190611e51565b8160008151811061031f5761031f611e6e565b60200260200101906001600160a01b031690816001600160a01b031681525050308160018151811061035357610353611e6e565b6001600160a01b03928316602091820292909201015260405163b6f9de9560e01b81527f00000000000000000000000000000000000000000000000000000000000000009091169063b6f9de959034906103b890600090869033904290600401611ec8565b6000604051808303818588803b1580156103d157600080fd5b505af11580156103e5573d6000803e3d6000fd5b5050505050505b005b600080fd5b3480156103ff57600080fd5b506104086108e2565b6040516104159190611efd565b60405180910390f35b34801561042a57600080fd5b5061043e610439366004611f52565b610974565b6040519015158152602001610415565b34801561045a57600080fd5b5061043e610469366004611f7e565b60136020526000908152604090205460ff1681565b34801561048a57600080fd5b506104b27f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610415565b3480156104d657600080fd5b506002545b604051908152602001610415565b3480156104f557600080fd5b506008546104b2906001600160a01b031681565b34801561051557600080fd5b5061043e610524366004611f9b565b61098b565b34801561053557600080fd5b506104b261dead81565b34801561054b57600080fd5b5060405160098152602001610415565b34801561056757600080fd5b506103ec610576366004611f7e565b6109f4565b34801561058757600080fd5b5061043e610596366004611f52565b610a37565b3480156105a757600080fd5b506103ec6105b6366004611fdc565b610a6d565b3480156105c757600080fd5b506104b27f000000000000000000000000000000000000000000000000000000000000000081565b3480156105fb57600080fd5b50600d5461043e9060ff1681565b34801561061557600080fd5b5061043e610624366004611f7e565b6001600160a01b031660009081526012602052604090205460ff1690565b6103ec610a91565b34801561065657600080fd5b506104db610665366004611f7e565b6001600160a01b031660009081526020819052604090205490565b34801561068c57600080fd5b506103ec610ac2565b3480156106a157600080fd5b506103ec6106b0366004611ff5565b610b3f565b3480156106c157600080fd5b506005546001600160a01b03166104b2565b3480156106df57600080fd5b50610408610b81565b3480156106f457600080fd5b506103ec610703366004611ff5565b610b90565b34801561071457600080fd5b5061043e610723366004611f52565b610c70565b34801561073457600080fd5b5061043e610743366004611f52565b610cbf565b34801561075457600080fd5b5061043e610763366004611f7e565b60146020526000908152604090205460ff1681565b34801561078457600080fd5b50600d5461043e90610100900460ff1681565b3480156107a357600080fd5b506103ec6107b2366004611ff5565b610ccc565b3480156107c357600080fd5b50600f5461043e9060ff1681565b3480156107dd57600080fd5b506104db60095481565b6103ec6107f5366004611f52565b610d55565b34801561080657600080fd5b506007546104b2906001600160a01b031681565b34801561082657600080fd5b506104db610835366004612033565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561086c57600080fd5b506103ec61087b366004611f7e565b610db2565b34801561088c57600080fd5b506104db600a5481565b3480156108a257600080fd5b506104db60115481565b3480156108b857600080fd5b506103ec6108c7366004611f7e565b610dfe565b3480156108d857600080fd5b506104db600b5481565b6060600380546108f190612061565b80601f016020809104026020016040519081016040528092919081815260200182805461091d90612061565b801561096a5780601f1061093f5761010080835404028352916020019161096a565b820191906000526020600020905b81548152906001019060200180831161094d57829003601f168201915b5050505050905090565b6000610981338484610f4f565b5060015b92915050565b6000610998848484611074565b6109ea84336109e585604051806060016040528060288152602001612264602891396001600160a01b038a166000908152600160209081526040808320338452909152902054919061189a565b610f4f565b5060019392505050565b6006546001600160a01b03163314610a0b57600080fd5b600880546001600160a01b0319166001600160a01b038316908117909155610a34906001610b3f565b50565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916109819185906109e59086610ee9565b610a7733826118d4565b8060116000828254610a8991906120b2565b909155505050565b30600090815260208190526040902054610aaa906119df565b600754610ac0906001600160a01b031647610d55565b565b6005546001600160a01b03163314610af55760405162461bcd60e51b8152600401610aec906120ca565b60405180910390fd5b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6006546001600160a01b03163314610b5657600080fd5b6001600160a01b03919091166000908152601360205260409020805460ff1916911515919091179055565b6060600480546108f190612061565b6005546001600160a01b03163314610bba5760405162461bcd60e51b8152600401610aec906120ca565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b03161415610c625760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610aec565b610c6c8282611bae565b5050565b600061098133846109e58560405180606001604052806025815260200161228c602591393360009081526001602090815260408083206001600160a01b038d168452909152902054919061189a565b6000610981338484611074565b6005546001600160a01b03163314610cf65760405162461bcd60e51b8152600401610aec906120ca565b6001600160a01b038216600081815260126020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b60006060836001600160a01b03168360405160006040518083038185875af1925050503d8060008114610da4576040519150601f19603f3d011682016040523d82523d6000602084013e610da9565b606091505b50505050505050565b6005546001600160a01b03163314610ddc5760405162461bcd60e51b8152600401610aec906120ca565b600780546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610e285760405162461bcd60e51b8152600401610aec906120ca565b6001600160a01b038116610e8d5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610aec565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610ef683856120b2565b905083811015610f485760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610aec565b9392505050565b6001600160a01b038316610fb15760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610aec565b6001600160a01b0382166110125760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610aec565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661109a5760405162461bcd60e51b8152600401610aec906120ff565b6001600160a01b0382166110c05760405162461bcd60e51b8152600401610aec90612144565b806110d6576110d183836000611c02565b505050565b600d5460ff161561159c576005546001600160a01b0384811691161480159061110d57506005546001600160a01b03838116911614155b801561112157506001600160a01b03821615155b801561113857506001600160a01b03821661dead14155b801561114e5750600854600160a01b900460ff16155b1561159c57600d54610100900460ff166111e6576001600160a01b03831660009081526012602052604090205460ff16806111a157506001600160a01b03821660009081526012602052604090205460ff165b6111e65760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610aec565b600f5460ff1615611336576005546001600160a01b0383811691161480159061124157507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b801561127f57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b1561133657326000908152600e6020526040902054431161131a5760405162461bcd60e51b815260206004820152604960248201527f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c60448201527f65642e20204f6e6c79206f6e652070757263686173652070657220626c6f636b6064820152681030b63637bbb2b21760b91b608482015260a401610aec565b6113254360056120b2565b326000908152600e60205260409020555b6001600160a01b03831660009081526014602052604090205460ff16801561137757506001600160a01b03821660009081526013602052604090205460ff16155b1561145b576009548111156113ec5760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610aec565b600b546001600160a01b03831660009081526020819052604090205461141290836120b2565b11156114565760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610aec565b61159c565b6001600160a01b03821660009081526014602052604090205460ff16801561149c57506001600160a01b03831660009081526013602052604090205460ff16155b15611512576009548111156114565760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610aec565b6001600160a01b03821660009081526013602052604090205460ff1661159c57600b546001600160a01b03831660009081526020819052604090205461155890836120b2565b111561159c5760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610aec565b30600090815260208190526040902054600a54811080159081906115ca5750600854600160a01b900460ff16155b80156115ef57506001600160a01b03851660009081526014602052604090205460ff16155b801561161457506001600160a01b03851660009081526012602052604090205460ff16155b801561163957506001600160a01b03841660009081526012602052604090205460ff16155b15611667576008805460ff60a01b1916600160a01b179055611659610a91565b6008805460ff60a01b191690555b6008546001600160a01b03861660009081526012602052604090205460ff600160a01b9092048216159116806116b557506001600160a01b03851660009081526012602052604090205460ff165b156116be575060005b600d5460009062010000900460ff16156116dc576064601055600191505b811561188f576001600160a01b03871660009081526014602052604090205460ff16801561173c57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316866001600160a01b031614155b1561176857611761606461175b60105488611d0b90919063ffffffff16565b90611d8a565b9050611845565b6001600160a01b03861660009081526014602052604090205460ff1680156117c257507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316876001600160a01b031614155b156117e157611761606461175b60105488611d0b90919063ffffffff16565b6001600160a01b03871660009081526014602052604090205460ff1615801561182357506001600160a01b03861660009081526014602052604090205460ff16155b1561184557611842606461175b60105488611d0b90919063ffffffff16565b90505b801561185657611856873083611c02565b600d5462010000900460ff16156118825761187081610a6d565b600d805462ff00001916905560026010555b61188c8186612187565b94505b610da9878787611c02565b600081848411156118be5760405162461bcd60e51b8152600401610aec9190611efd565b5060006118cb8486612187565b95945050505050565b6001600160a01b0382166119345760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610aec565b6119718160405180606001604052806022815260200161221c602291396001600160a01b038516600090815260208190526040902054919061189a565b6001600160a01b0383166000908152602081905260409020556002546119979082611dcc565b6002556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611a1457611a14611e6e565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015611a8d57600080fd5b505afa158015611aa1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611ac59190611e51565b81600181518110611ad857611ad8611e6e565b60200260200101906001600160a01b031690816001600160a01b031681525050611b23307f000000000000000000000000000000000000000000000000000000000000000084610f4f565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac94790611b7890859060009086903090429060040161219e565b600060405180830381600087803b158015611b9257600080fd5b505af1158015611ba6573d6000803e3d6000fd5b505050505050565b6001600160a01b038216600081815260146020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b038316611c285760405162461bcd60e51b8152600401610aec906120ff565b6001600160a01b038216611c4e5760405162461bcd60e51b8152600401610aec90612144565b611c8b8160405180606001604052806026815260200161223e602691396001600160a01b038616600090815260208190526040902054919061189a565b6001600160a01b038085166000908152602081905260408082209390935590841681522054611cba9082610ee9565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611067565b600082611d1a57506000610985565b6000611d2683856121da565b905082611d3385836121f9565b14610f485760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610aec565b6000610f4883836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611e0e565b6000610f4883836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f77000081525061189a565b60008183611e2f5760405162461bcd60e51b8152600401610aec9190611efd565b5060006118cb84866121f9565b6001600160a01b0381168114610a3457600080fd5b600060208284031215611e6357600080fd5b8151610f4881611e3c565b634e487b7160e01b600052603260045260246000fd5b600081518084526020808501945080840160005b83811015611ebd5781516001600160a01b031687529582019590820190600101611e98565b509495945050505050565b848152608060208201526000611ee16080830186611e84565b6001600160a01b03949094166040830152506060015292915050565b600060208083528351808285015260005b81811015611f2a57858101830151858201604001528201611f0e565b81811115611f3c576000604083870101525b50601f01601f1916929092016040019392505050565b60008060408385031215611f6557600080fd5b8235611f7081611e3c565b946020939093013593505050565b600060208284031215611f9057600080fd5b8135610f4881611e3c565b600080600060608486031215611fb057600080fd5b8335611fbb81611e3c565b92506020840135611fcb81611e3c565b929592945050506040919091013590565b600060208284031215611fee57600080fd5b5035919050565b6000806040838503121561200857600080fd5b823561201381611e3c565b91506020830135801515811461202857600080fd5b809150509250929050565b6000806040838503121561204657600080fd5b823561205181611e3c565b9150602083013561202881611e3c565b600181811c9082168061207557607f821691505b6020821081141561209657634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b600082198211156120c5576120c561209c565b500190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b6000828210156121995761219961209c565b500390565b85815284602082015260a0604082015260006121bd60a0830186611e84565b6001600160a01b0394909416606083015250608001529392505050565b60008160001904831182151516156121f4576121f461209c565b500290565b60008261221657634e487b7160e01b600052601260045260246000fd5b50049056fe45524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212203847ba61ecfb2acf8b9407aaec8783beaf0a149aef3681f56ca3e570b54cfed064736f6c63430008090033

Deployed Bytecode

0x60806040526004361061021e5760003560e01c80637571336a11610123578063c876d0b9116100ab578063e0435ac01161006f578063e0435ac014610860578063e2f4560514610880578063e7873b5814610896578063f2fde38b146108ac578063f8b45b05146108cc57600080fd5b8063c876d0b9146107b7578063c8c8ebe4146107d1578063d0679d34146107e7578063da56f1f6146107fa578063dd62ed3e1461081a57600080fd5b8063a457c2d7116100f2578063a457c2d714610708578063a9059cbb14610728578063b62496f514610748578063bbc0c74214610778578063c02466681461079757600080fd5b80637571336a146106955780638da5cb5b146106b557806395d89b41146106d35780639a7a23d6146106e857600080fd5b806331656e3f116101a65780634a62bb65116101755780634a62bb65146105ef5780634fbee193146106095780636ac5eeee1461064257806370a082311461064a578063715018a61461068057600080fd5b806331656e3f1461055b578063395093511461057b57806342966c681461059b57806349bd5a5e146105bb57600080fd5b806318160ddd116101ed57806318160ddd146104ca5780632262a1b3146104e957806323b872dd1461050957806327c8f83514610529578063313ce5671461053f57600080fd5b806306fdde03146103f3578063095ea7b31461041e57806310d5de531461044e5780631694505e1461047e57600080fd5b366103ee57600d54610100900460ff16801561024457506008546001600160a01b031633145b156103ec57600d805462ff00001916620100001790556040805160028082526060820183526000926020830190803683370190505090507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156102d457600080fd5b505afa1580156102e8573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061030c9190611e51565b8160008151811061031f5761031f611e6e565b60200260200101906001600160a01b031690816001600160a01b031681525050308160018151811061035357610353611e6e565b6001600160a01b03928316602091820292909201015260405163b6f9de9560e01b81527f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d9091169063b6f9de959034906103b890600090869033904290600401611ec8565b6000604051808303818588803b1580156103d157600080fd5b505af11580156103e5573d6000803e3d6000fd5b5050505050505b005b600080fd5b3480156103ff57600080fd5b506104086108e2565b6040516104159190611efd565b60405180910390f35b34801561042a57600080fd5b5061043e610439366004611f52565b610974565b6040519015158152602001610415565b34801561045a57600080fd5b5061043e610469366004611f7e565b60136020526000908152604090205460ff1681565b34801561048a57600080fd5b506104b27f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b039091168152602001610415565b3480156104d657600080fd5b506002545b604051908152602001610415565b3480156104f557600080fd5b506008546104b2906001600160a01b031681565b34801561051557600080fd5b5061043e610524366004611f9b565b61098b565b34801561053557600080fd5b506104b261dead81565b34801561054b57600080fd5b5060405160098152602001610415565b34801561056757600080fd5b506103ec610576366004611f7e565b6109f4565b34801561058757600080fd5b5061043e610596366004611f52565b610a37565b3480156105a757600080fd5b506103ec6105b6366004611fdc565b610a6d565b3480156105c757600080fd5b506104b27f00000000000000000000000050e29bca2670b3a164856412864130b77705d2ae81565b3480156105fb57600080fd5b50600d5461043e9060ff1681565b34801561061557600080fd5b5061043e610624366004611f7e565b6001600160a01b031660009081526012602052604090205460ff1690565b6103ec610a91565b34801561065657600080fd5b506104db610665366004611f7e565b6001600160a01b031660009081526020819052604090205490565b34801561068c57600080fd5b506103ec610ac2565b3480156106a157600080fd5b506103ec6106b0366004611ff5565b610b3f565b3480156106c157600080fd5b506005546001600160a01b03166104b2565b3480156106df57600080fd5b50610408610b81565b3480156106f457600080fd5b506103ec610703366004611ff5565b610b90565b34801561071457600080fd5b5061043e610723366004611f52565b610c70565b34801561073457600080fd5b5061043e610743366004611f52565b610cbf565b34801561075457600080fd5b5061043e610763366004611f7e565b60146020526000908152604090205460ff1681565b34801561078457600080fd5b50600d5461043e90610100900460ff1681565b3480156107a357600080fd5b506103ec6107b2366004611ff5565b610ccc565b3480156107c357600080fd5b50600f5461043e9060ff1681565b3480156107dd57600080fd5b506104db60095481565b6103ec6107f5366004611f52565b610d55565b34801561080657600080fd5b506007546104b2906001600160a01b031681565b34801561082657600080fd5b506104db610835366004612033565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561086c57600080fd5b506103ec61087b366004611f7e565b610db2565b34801561088c57600080fd5b506104db600a5481565b3480156108a257600080fd5b506104db60115481565b3480156108b857600080fd5b506103ec6108c7366004611f7e565b610dfe565b3480156108d857600080fd5b506104db600b5481565b6060600380546108f190612061565b80601f016020809104026020016040519081016040528092919081815260200182805461091d90612061565b801561096a5780601f1061093f5761010080835404028352916020019161096a565b820191906000526020600020905b81548152906001019060200180831161094d57829003601f168201915b5050505050905090565b6000610981338484610f4f565b5060015b92915050565b6000610998848484611074565b6109ea84336109e585604051806060016040528060288152602001612264602891396001600160a01b038a166000908152600160209081526040808320338452909152902054919061189a565b610f4f565b5060019392505050565b6006546001600160a01b03163314610a0b57600080fd5b600880546001600160a01b0319166001600160a01b038316908117909155610a34906001610b3f565b50565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916109819185906109e59086610ee9565b610a7733826118d4565b8060116000828254610a8991906120b2565b909155505050565b30600090815260208190526040902054610aaa906119df565b600754610ac0906001600160a01b031647610d55565b565b6005546001600160a01b03163314610af55760405162461bcd60e51b8152600401610aec906120ca565b60405180910390fd5b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6006546001600160a01b03163314610b5657600080fd5b6001600160a01b03919091166000908152601360205260409020805460ff1916911515919091179055565b6060600480546108f190612061565b6005546001600160a01b03163314610bba5760405162461bcd60e51b8152600401610aec906120ca565b7f00000000000000000000000050e29bca2670b3a164856412864130b77705d2ae6001600160a01b0316826001600160a01b03161415610c625760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610aec565b610c6c8282611bae565b5050565b600061098133846109e58560405180606001604052806025815260200161228c602591393360009081526001602090815260408083206001600160a01b038d168452909152902054919061189a565b6000610981338484611074565b6005546001600160a01b03163314610cf65760405162461bcd60e51b8152600401610aec906120ca565b6001600160a01b038216600081815260126020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b60006060836001600160a01b03168360405160006040518083038185875af1925050503d8060008114610da4576040519150601f19603f3d011682016040523d82523d6000602084013e610da9565b606091505b50505050505050565b6005546001600160a01b03163314610ddc5760405162461bcd60e51b8152600401610aec906120ca565b600780546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610e285760405162461bcd60e51b8152600401610aec906120ca565b6001600160a01b038116610e8d5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610aec565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610ef683856120b2565b905083811015610f485760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610aec565b9392505050565b6001600160a01b038316610fb15760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610aec565b6001600160a01b0382166110125760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610aec565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661109a5760405162461bcd60e51b8152600401610aec906120ff565b6001600160a01b0382166110c05760405162461bcd60e51b8152600401610aec90612144565b806110d6576110d183836000611c02565b505050565b600d5460ff161561159c576005546001600160a01b0384811691161480159061110d57506005546001600160a01b03838116911614155b801561112157506001600160a01b03821615155b801561113857506001600160a01b03821661dead14155b801561114e5750600854600160a01b900460ff16155b1561159c57600d54610100900460ff166111e6576001600160a01b03831660009081526012602052604090205460ff16806111a157506001600160a01b03821660009081526012602052604090205460ff165b6111e65760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610aec565b600f5460ff1615611336576005546001600160a01b0383811691161480159061124157507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316826001600160a01b031614155b801561127f57507f00000000000000000000000050e29bca2670b3a164856412864130b77705d2ae6001600160a01b0316826001600160a01b031614155b1561133657326000908152600e6020526040902054431161131a5760405162461bcd60e51b815260206004820152604960248201527f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c60448201527f65642e20204f6e6c79206f6e652070757263686173652070657220626c6f636b6064820152681030b63637bbb2b21760b91b608482015260a401610aec565b6113254360056120b2565b326000908152600e60205260409020555b6001600160a01b03831660009081526014602052604090205460ff16801561137757506001600160a01b03821660009081526013602052604090205460ff16155b1561145b576009548111156113ec5760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610aec565b600b546001600160a01b03831660009081526020819052604090205461141290836120b2565b11156114565760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610aec565b61159c565b6001600160a01b03821660009081526014602052604090205460ff16801561149c57506001600160a01b03831660009081526013602052604090205460ff16155b15611512576009548111156114565760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610aec565b6001600160a01b03821660009081526013602052604090205460ff1661159c57600b546001600160a01b03831660009081526020819052604090205461155890836120b2565b111561159c5760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610aec565b30600090815260208190526040902054600a54811080159081906115ca5750600854600160a01b900460ff16155b80156115ef57506001600160a01b03851660009081526014602052604090205460ff16155b801561161457506001600160a01b03851660009081526012602052604090205460ff16155b801561163957506001600160a01b03841660009081526012602052604090205460ff16155b15611667576008805460ff60a01b1916600160a01b179055611659610a91565b6008805460ff60a01b191690555b6008546001600160a01b03861660009081526012602052604090205460ff600160a01b9092048216159116806116b557506001600160a01b03851660009081526012602052604090205460ff165b156116be575060005b600d5460009062010000900460ff16156116dc576064601055600191505b811561188f576001600160a01b03871660009081526014602052604090205460ff16801561173c57507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316866001600160a01b031614155b1561176857611761606461175b60105488611d0b90919063ffffffff16565b90611d8a565b9050611845565b6001600160a01b03861660009081526014602052604090205460ff1680156117c257507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316876001600160a01b031614155b156117e157611761606461175b60105488611d0b90919063ffffffff16565b6001600160a01b03871660009081526014602052604090205460ff1615801561182357506001600160a01b03861660009081526014602052604090205460ff16155b1561184557611842606461175b60105488611d0b90919063ffffffff16565b90505b801561185657611856873083611c02565b600d5462010000900460ff16156118825761187081610a6d565b600d805462ff00001916905560026010555b61188c8186612187565b94505b610da9878787611c02565b600081848411156118be5760405162461bcd60e51b8152600401610aec9190611efd565b5060006118cb8486612187565b95945050505050565b6001600160a01b0382166119345760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610aec565b6119718160405180606001604052806022815260200161221c602291396001600160a01b038516600090815260208190526040902054919061189a565b6001600160a01b0383166000908152602081905260409020556002546119979082611dcc565b6002556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611a1457611a14611e6e565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015611a8d57600080fd5b505afa158015611aa1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611ac59190611e51565b81600181518110611ad857611ad8611e6e565b60200260200101906001600160a01b031690816001600160a01b031681525050611b23307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610f4f565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac94790611b7890859060009086903090429060040161219e565b600060405180830381600087803b158015611b9257600080fd5b505af1158015611ba6573d6000803e3d6000fd5b505050505050565b6001600160a01b038216600081815260146020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b038316611c285760405162461bcd60e51b8152600401610aec906120ff565b6001600160a01b038216611c4e5760405162461bcd60e51b8152600401610aec90612144565b611c8b8160405180606001604052806026815260200161223e602691396001600160a01b038616600090815260208190526040902054919061189a565b6001600160a01b038085166000908152602081905260408082209390935590841681522054611cba9082610ee9565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611067565b600082611d1a57506000610985565b6000611d2683856121da565b905082611d3385836121f9565b14610f485760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610aec565b6000610f4883836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611e0e565b6000610f4883836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f77000081525061189a565b60008183611e2f5760405162461bcd60e51b8152600401610aec9190611efd565b5060006118cb84866121f9565b6001600160a01b0381168114610a3457600080fd5b600060208284031215611e6357600080fd5b8151610f4881611e3c565b634e487b7160e01b600052603260045260246000fd5b600081518084526020808501945080840160005b83811015611ebd5781516001600160a01b031687529582019590820190600101611e98565b509495945050505050565b848152608060208201526000611ee16080830186611e84565b6001600160a01b03949094166040830152506060015292915050565b600060208083528351808285015260005b81811015611f2a57858101830151858201604001528201611f0e565b81811115611f3c576000604083870101525b50601f01601f1916929092016040019392505050565b60008060408385031215611f6557600080fd5b8235611f7081611e3c565b946020939093013593505050565b600060208284031215611f9057600080fd5b8135610f4881611e3c565b600080600060608486031215611fb057600080fd5b8335611fbb81611e3c565b92506020840135611fcb81611e3c565b929592945050506040919091013590565b600060208284031215611fee57600080fd5b5035919050565b6000806040838503121561200857600080fd5b823561201381611e3c565b91506020830135801515811461202857600080fd5b809150509250929050565b6000806040838503121561204657600080fd5b823561205181611e3c565b9150602083013561202881611e3c565b600181811c9082168061207557607f821691505b6020821081141561209657634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b600082198211156120c5576120c561209c565b500190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b6000828210156121995761219961209c565b500390565b85815284602082015260a0604082015260006121bd60a0830186611e84565b6001600160a01b0394909416606083015250608001529392505050565b60008160001904831182151516156121f4576121f461209c565b500290565b60008261221657634e487b7160e01b600052601260045260246000fd5b50049056fe45524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212203847ba61ecfb2acf8b9407aaec8783beaf0a149aef3681f56ca3e570b54cfed064736f6c63430008090033

Deployed Bytecode Sourcemap

29607:10137:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32733:13;;;;;;;:36;;;;-1:-1:-1;32764:5:0;;-1:-1:-1;;;;;32764:5:0;32750:10;:19;32733:36;32730:446;;;32785:5;:12;;-1:-1:-1;;32785:12:0;;;;;32837:16;;;32785:5;32837:16;;;;;;;;-1:-1:-1;;32837:16:0;;;;;;;;;;-1:-1:-1;32837:16:0;32812:41;;32878:15;-1:-1:-1;;;;;32878:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;32868:4;32873:1;32868:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;32868:32:0;;;-1:-1:-1;;;;;32868:32:0;;;;;32933:4;32915;32920:1;32915:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;32915:23:0;;;:7;;;;;;;;;:23;32959:205;;-1:-1:-1;;;32959:205:0;;:15;:66;;;;;;33033:9;;32959:205;;33062:1;;33082:4;;33105:10;;33134:15;;32959:205;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32770:406;32730:446;29607:10137;;;;;7589:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;9755:169;;;;;;;;;;-1:-1:-1;9755:169:0;;;;;:::i;:::-;;:::i;:::-;;;2738:14:1;;2731:22;2713:41;;2701:2;2686:18;9755:169:0;2573:187:1;30694:64:0;;;;;;;;;;-1:-1:-1;30694:64:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29682:51;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;3208:32:1;;;3190:51;;3178:2;3163:18;29682:51:0;3017:230:1;8708:108:0;;;;;;;;;;-1:-1:-1;8796:12:0;;8708:108;;;3398:25:1;;;3386:2;3371:18;8708:108:0;3252:177:1;29942:20:0;;;;;;;;;;-1:-1:-1;29942:20:0;;;;-1:-1:-1;;;;;29942:20:0;;;10406:355;;;;;;;;;;-1:-1:-1;10406:355:0;;;;;:::i;:::-;;:::i;29785:53::-;;;;;;;;;;;;29831:6;29785:53;;8551:92;;;;;;;;;;-1:-1:-1;8551:92:0;;8634:1;4245:36:1;;4233:2;4218:18;8551:92:0;4103:184:1;34341:181:0;;;;;;;;;;-1:-1:-1;34341:181:0;;;;;:::i;:::-;;:::i;11170:218::-;;;;;;;;;;-1:-1:-1;11170:218:0;;;;;:::i;:::-;;:::i;39623:116::-;;;;;;;;;;-1:-1:-1;39623:116:0;;;;;:::i;:::-;;:::i;29740:38::-;;;;;;;;;;;;;;;30150:33;;;;;;;;;;-1:-1:-1;30150:33:0;;;;;;;;34014:125;;;;;;;;;;-1:-1:-1;34014:125:0;;;;;:::i;:::-;-1:-1:-1;;;;;34103:28:0;34079:4;34103:28;;;:19;:28;;;;;;;;;34014:125;39263:152;;;:::i;8879:127::-;;;;;;;;;;-1:-1:-1;8879:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;8980:18:0;8953:7;8980:18;;;;;;;;;;;;8879:127;22202:148;;;;;;;;;;;;;:::i;33191:173::-;;;;;;;;;;-1:-1:-1;33191:173:0;;;;;:::i;:::-;;:::i;21560:79::-;;;;;;;;;;-1:-1:-1;21625:6:0;;-1:-1:-1;;;;;21625:6:0;21560:79;;7808:104;;;;;;;;;;;;;:::i;33566:244::-;;;;;;;;;;-1:-1:-1;33566:244:0;;;;;:::i;:::-;;:::i;11891:269::-;;;;;;;;;;-1:-1:-1;11891:269:0;;;;;:::i;:::-;;:::i;9219:175::-;;;;;;;;;;-1:-1:-1;9219:175:0;;;;;:::i;:::-;;:::i;30916:58::-;;;;;;;;;;-1:-1:-1;30916:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;30190:32;;;;;;;;;;-1:-1:-1;30190:32:0;;;;;;;;;;;33376:182;;;;;;;;;;-1:-1:-1;33376:182:0;;;;;:::i;:::-;;:::i;30439:39::-;;;;;;;;;;-1:-1:-1;30439:39:0;;;;;;;;30001:35;;;;;;;;;;;;;;;;39423:192;;;;;;:::i;:::-;;:::i;29845:90::-;;;;;;;;;;-1:-1:-1;29845:90:0;;;;-1:-1:-1;;;;;29845:90:0;;;9457:151;;;;;;;;;;-1:-1:-1;9457:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;9573:18:0;;;9546:7;9573:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9457:151;34217:116;;;;;;;;;;-1:-1:-1;34217:116:0;;;;;:::i;:::-;;:::i;30043:33::-;;;;;;;;;;;;;;;;30519:27;;;;;;;;;;;;;;;;22505:244;;;;;;;;;;-1:-1:-1;22505:244:0;;;;;:::i;:::-;;:::i;30083:24::-;;;;;;;;;;;;;;;;7589:100;7643:13;7676:5;7669:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7589:100;:::o;9755:169::-;9838:4;9855:39;305:10;9878:7;9887:6;9855:8;:39::i;:::-;-1:-1:-1;9912:4:0;9755:169;;;;;:::o;10406:355::-;10546:4;10563:36;10573:6;10581:9;10592:6;10563:9;:36::i;:::-;10610:121;10619:6;305:10;10641:89;10679:6;10641:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10641:19:0;;;;;;:11;:19;;;;;;;;305:10;10641:33;;;;;;;;;;:37;:89::i;:::-;10610:8;:121::i;:::-;-1:-1:-1;10749:4:0;10406:355;;;;;:::o;34341:181::-;21466:5;;-1:-1:-1;;;;;21466:5:0;34407:10;:29;34398:39;;;;;;34448:5;:17;;-1:-1:-1;;;;;;34448:17:0;-1:-1:-1;;;;;34448:17:0;;;;;;;;34476:38;;-1:-1:-1;34476:25:0;:38::i;:::-;34341:181;:::o;11170:218::-;305:10;11258:4;11307:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11307:34:0;;;;;;;;;;11258:4;;11275:83;;11298:7;;11307:50;;11346:10;11307:38;:50::i;39623:116::-;39671:27;305:10;39691:6;39671:5;:27::i;:::-;39725:6;39709:12;;:22;;;;;;;:::i;:::-;;;;-1:-1:-1;;;39623:116:0:o;39263:152::-;39345:4;8953:7;8980:18;;;;;;;;;;;39310:42;;:16;:42::i;:::-;39368:13;;39363:42;;-1:-1:-1;;;;;39368:13:0;39383:21;39363:4;:42::i;:::-;39263:152::o;22202:148::-;21772:6;;-1:-1:-1;;;;;21772:6:0;305:10;21772:22;21764:67;;;;-1:-1:-1;;;21764:67:0;;;;;;;:::i;:::-;;;;;;;;;22293:6:::1;::::0;22272:40:::1;::::0;22309:1:::1;::::0;-1:-1:-1;;;;;22293:6:0::1;::::0;22272:40:::1;::::0;22309:1;;22272:40:::1;22323:6;:19:::0;;-1:-1:-1;;;;;;22323:19:0::1;::::0;;22202:148::o;33191:173::-;21466:5;;-1:-1:-1;;;;;21466:5:0;33278:10;:20;33270:29;;;;;;-1:-1:-1;;;;;33310:39:0;;;;;;;;:31;:39;;;;;:46;;-1:-1:-1;;33310:46:0;;;;;;;;;;33191:173::o;7808:104::-;7864:13;7897:7;7890:14;;;;;:::i;33566:244::-;21772:6;;-1:-1:-1;;;;;21772:6:0;305:10;21772:22;21764:67;;;;-1:-1:-1;;;21764:67:0;;;;;;;:::i;:::-;33673:13:::1;-1:-1:-1::0;;;;;33665:21:0::1;:4;-1:-1:-1::0;;;;;33665:21:0::1;;;33657:91;;;::::0;-1:-1:-1;;;33657:91:0;;7316:2:1;33657:91:0::1;::::0;::::1;7298:21:1::0;7355:2;7335:18;;;7328:30;7394:34;7374:18;;;7367:62;7465:27;7445:18;;;7438:55;7510:19;;33657:91:0::1;7114:421:1::0;33657:91:0::1;33761:41;33790:4;33796:5;33761:28;:41::i;:::-;33566:244:::0;;:::o;11891:269::-;11984:4;12001:129;305:10;12024:7;12033:96;12072:15;12033:96;;;;;;;;;;;;;;;;;305:10;12033:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;12033:34:0;;;;;;;;;;;;:38;:96::i;9219:175::-;9305:4;9322:42;305:10;9346:9;9357:6;9322:9;:42::i;33376:182::-;21772:6;;-1:-1:-1;;;;;21772:6:0;305:10;21772:22;21764:67;;;;-1:-1:-1;;;21764:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33461:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;33461:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;33516:34;;2713:41:1;;;33516:34:0::1;::::0;2686:18:1;33516:34:0::1;;;;;;;33376:182:::0;;:::o;39423:192::-;39505:12;39528:17;39574:8;-1:-1:-1;;;;;39574:13:0;39595:7;39574:33;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;;39423:192:0:o;34217:116::-;21772:6;;-1:-1:-1;;;;;21772:6:0;305:10;21772:22;21764:67;;;;-1:-1:-1;;;21764:67:0;;;;;;;:::i;:::-;34300:13:::1;:25:::0;;-1:-1:-1;;;;;;34300:25:0::1;-1:-1:-1::0;;;;;34300:25:0;;;::::1;::::0;;;::::1;::::0;;34217:116::o;22505:244::-;21772:6;;-1:-1:-1;;;;;21772:6:0;305:10;21772:22;21764:67;;;;-1:-1:-1;;;21764:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22594:22:0;::::1;22586:73;;;::::0;-1:-1:-1;;;22586:73:0;;7952:2:1;22586:73:0::1;::::0;::::1;7934:21:1::0;7991:2;7971:18;;;7964:30;8030:34;8010:18;;;8003:62;-1:-1:-1;;;8081:18:1;;;8074:36;8127:19;;22586:73:0::1;7750:402:1::0;22586:73:0::1;22696:6;::::0;22675:38:::1;::::0;-1:-1:-1;;;;;22675:38:0;;::::1;::::0;22696:6:::1;::::0;22675:38:::1;::::0;22696:6:::1;::::0;22675:38:::1;22724:6;:17:::0;;-1:-1:-1;;;;;;22724:17:0::1;-1:-1:-1::0;;;;;22724:17:0;;;::::1;::::0;;;::::1;::::0;;22505:244::o;16455:181::-;16513:7;;16545:5;16549:1;16545;:5;:::i;:::-;16533:17;;16574:1;16569;:6;;16561:46;;;;-1:-1:-1;;;16561:46:0;;8359:2:1;16561:46:0;;;8341:21:1;8398:2;8378:18;;;8371:30;8437:29;8417:18;;;8410:57;8484:18;;16561:46:0;8157:351:1;16561:46:0;16627:1;16455:181;-1:-1:-1;;;16455:181:0:o;15077:380::-;-1:-1:-1;;;;;15213:19:0;;15205:68;;;;-1:-1:-1;;;15205:68:0;;8715:2:1;15205:68:0;;;8697:21:1;8754:2;8734:18;;;8727:30;8793:34;8773:18;;;8766:62;-1:-1:-1;;;8844:18:1;;;8837:34;8888:19;;15205:68:0;8513:400:1;15205:68:0;-1:-1:-1;;;;;15292:21:0;;15284:68;;;;-1:-1:-1;;;15284:68:0;;9120:2:1;15284:68:0;;;9102:21:1;9159:2;9139:18;;;9132:30;9198:34;9178:18;;;9171:62;-1:-1:-1;;;9249:18:1;;;9242:32;9291:19;;15284:68:0;8918:398:1;15284:68:0;-1:-1:-1;;;;;15365:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15417:32;;3398:25:1;;;15417:32:0;;3371:18:1;15417:32:0;;;;;;;;15077:380;;;:::o;34530:4112::-;-1:-1:-1;;;;;34662:18:0;;34654:68;;;;-1:-1:-1;;;34654:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34741:16:0;;34733:64;;;;-1:-1:-1;;;34733:64:0;;;;;;;:::i;:::-;34822:11;34819:92;;34850:28;34866:4;34872:2;34876:1;34850:15;:28::i;:::-;34530:4112;;;:::o;34819:92::-;34934:14;;;;34931:1845;;;21625:6;;-1:-1:-1;;;;;34986:15:0;;;21625:6;;34986:15;;;;:49;;-1:-1:-1;21625:6:0;;-1:-1:-1;;;;;35022:13:0;;;21625:6;;35022:13;;34986:49;:86;;;;-1:-1:-1;;;;;;35056:16:0;;;;34986:86;:128;;;;-1:-1:-1;;;;;;35093:21:0;;35107:6;35093:21;;34986:128;:158;;;;-1:-1:-1;35136:8:0;;-1:-1:-1;;;35136:8:0;;;;35135:9;34986:158;34964:1801;;;35182:13;;;;;;;35178:148;;-1:-1:-1;;;;;35227:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;35256:23:0;;;;;;:19;:23;;;;;;;;35227:52;35219:87;;;;-1:-1:-1;;;35219:87:0;;10333:2:1;35219:87:0;;;10315:21:1;10372:2;10352:18;;;10345:30;-1:-1:-1;;;10391:18:1;;;10384:52;10453:18;;35219:87:0;10131:346:1;35219:87:0;35484:20;;;;35480:427;;;21625:6;;-1:-1:-1;;;;;35532:13:0;;;21625:6;;35532:13;;;;:47;;;35563:15;-1:-1:-1;;;;;35549:30:0;:2;-1:-1:-1;;;;;35549:30:0;;;35532:47;:79;;;;;35597:13;-1:-1:-1;;;;;35583:28:0;:2;-1:-1:-1;;;;;35583:28:0;;;35532:79;35528:360;;;35676:9;35647:39;;;;:28;:39;;;;;;35689:12;-1:-1:-1;35639:140:0;;;;-1:-1:-1;;;35639:140:0;;10684:2:1;35639:140:0;;;10666:21:1;10723:2;10703:18;;;10696:30;10762:34;10742:18;;;10735:62;10833:34;10813:18;;;10806:62;-1:-1:-1;;;10884:19:1;;;10877:40;10934:19;;35639:140:0;10482:477:1;35639:140:0;35848:16;:12;35863:1;35848:16;:::i;:::-;35835:9;35806:39;;;;:28;:39;;;;;:58;35528:360;-1:-1:-1;;;;;35976:31:0;;;;;;:25;:31;;;;;;;;:71;;;;-1:-1:-1;;;;;;36012:35:0;;;;;;:31;:35;;;;;;;;36011:36;35976:71;35972:778;;;36094:20;;36084:6;:30;;36076:96;;;;-1:-1:-1;;;36076:96:0;;11166:2:1;36076:96:0;;;11148:21:1;11205:2;11185:18;;;11178:30;11244:34;11224:18;;;11217:62;-1:-1:-1;;;11295:18:1;;;11288:51;11356:19;;36076:96:0;10964:417:1;36076:96:0;36233:9;;-1:-1:-1;;;;;8980:18:0;;8953:7;8980:18;;;;;;;;;;;36207:22;;:6;:22;:::i;:::-;:35;;36199:67;;;;-1:-1:-1;;;36199:67:0;;11588:2:1;36199:67:0;;;11570:21:1;11627:2;11607:18;;;11600:30;-1:-1:-1;;;11646:18:1;;;11639:49;11705:18;;36199:67:0;11386:343:1;36199:67:0;35972:778;;;-1:-1:-1;;;;;36360:29:0;;;;;;:25;:29;;;;;;;;:71;;;;-1:-1:-1;;;;;;36394:37:0;;;;;;:31;:37;;;;;;;;36393:38;36360:71;36356:394;;;36478:20;;36468:6;:30;;36460:97;;;;-1:-1:-1;;;36460:97:0;;11936:2:1;36460:97:0;;;11918:21:1;11975:2;11955:18;;;11948:30;12014:34;11994:18;;;11987:62;-1:-1:-1;;;12065:18:1;;;12058:52;12127:19;;36460:97:0;11734:418:1;36356:394:0;-1:-1:-1;;;;;36604:35:0;;;;;;:31;:35;;;;;;;;36600:150;;36697:9;;-1:-1:-1;;;;;8980:18:0;;8953:7;8980:18;;;;;;;;;;;36671:22;;:6;:22;:::i;:::-;:35;;36663:67;;;;-1:-1:-1;;;36663:67:0;;11588:2:1;36663:67:0;;;11570:21:1;11627:2;11607:18;;;11600:30;-1:-1:-1;;;11646:18:1;;;11639:49;11705:18;;36663:67:0;11386:343:1;36663:67:0;36859:4;36810:28;8980:18;;;;;;;;;;;36925;;36901:42;;;;;;;36974:33;;-1:-1:-1;36999:8:0;;-1:-1:-1;;;36999:8:0;;;;36998:9;36974:33;:82;;;;-1:-1:-1;;;;;;37025:31:0;;;;;;:25;:31;;;;;;;;37024:32;36974:82;:125;;;;-1:-1:-1;;;;;;37074:25:0;;;;;;:19;:25;;;;;;;;37073:26;36974:125;:166;;;;-1:-1:-1;;;;;;37117:23:0;;;;;;:19;:23;;;;;;;;37116:24;36974:166;36956:310;;;37167:8;:15;;-1:-1:-1;;;;37167:15:0;-1:-1:-1;;;37167:15:0;;;37211:10;:8;:10::i;:::-;37238:8;:16;;-1:-1:-1;;;;37238:16:0;;;36956:310;37302:8;;-1:-1:-1;;;;;37411:25:0;;37286:12;37411:25;;;:19;:25;;;;;;37302:8;-1:-1:-1;;;37302:8:0;;;;;37301:9;;37411:25;;:52;;-1:-1:-1;;;;;;37440:23:0;;;;;;:19;:23;;;;;;;;37411:52;37408:99;;;-1:-1:-1;37490:5:0;37408:99;37559:5;;37527:12;;37559:5;;;;;37556:74;;;37615:3;37609;:9;37590:4;;-1:-1:-1;37556:74:0;37717:7;37714:877;;;-1:-1:-1;;;;;37767:31:0;;;;;;:25;:31;;;;;;;;:65;;;;;37816:15;-1:-1:-1;;;;;37802:30:0;:2;-1:-1:-1;;;;;37802:30:0;;;37767:65;37763:531;;;37859:24;37879:3;37859:15;37870:3;;37859:6;:10;;:15;;;;:::i;:::-;:19;;:24::i;:::-;37852:31;;37763:531;;;-1:-1:-1;;;;;37948:29:0;;;;;;:25;:29;;;;;;;;:65;;;;;37997:15;-1:-1:-1;;;;;37981:32:0;:4;-1:-1:-1;;;;;37981:32:0;;;37948:65;37944:350;;;38045:24;38065:3;38045:15;38056:3;;38045:6;:10;;:15;;;;:::i;37944:350::-;-1:-1:-1;;;;;38155:31:0;;;;;;:25;:31;;;;;;;;38154:32;:66;;;;-1:-1:-1;;;;;;38191:29:0;;;;;;:25;:29;;;;;;;;38190:30;38154:66;38150:144;;;38252:24;38272:3;38252:15;38263:3;;38252:6;:10;;:15;;;;:::i;:24::-;38245:31;;38150:144;38325:8;;38322:93;;38357:42;38373:4;38387;38394;38357:15;:42::i;:::-;38443:5;;;;;;;38440:112;;;38468:10;38473:4;38468;:10::i;:::-;38497:5;:13;;-1:-1:-1;;38497:13:0;;;:5;38529:3;:7;38440:112;38565:14;38575:4;38565:14;;:::i;:::-;;;37714:877;38601:33;38617:4;38623:2;38627:6;38601:15;:33::i;17358:192::-;17444:7;17480:12;17472:6;;;;17464:29;;;;-1:-1:-1;;;17464:29:0;;;;;;;;:::i;:::-;-1:-1:-1;17504:9:0;17516:5;17520:1;17516;:5;:::i;:::-;17504:17;17358:192;-1:-1:-1;;;;;17358:192:0:o;14221:418::-;-1:-1:-1;;;;;14305:21:0;;14297:67;;;;-1:-1:-1;;;14297:67:0;;12489:2:1;14297:67:0;;;12471:21:1;12528:2;12508:18;;;12501:30;12567:34;12547:18;;;12540:62;-1:-1:-1;;;12618:18:1;;;12611:31;12659:19;;14297:67:0;12287:397:1;14297:67:0;14460:68;14483:6;14460:68;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;14460:18:0;;:9;:18;;;;;;;;;;;;:68;:22;:68::i;:::-;-1:-1:-1;;;;;14439:18:0;;:9;:18;;;;;;;;;;:89;14554:12;;:24;;14571:6;14554:16;:24::i;:::-;14539:12;:39;14594:37;;3398:25:1;;;14620:1:0;;-1:-1:-1;;;;;14594:37:0;;;;;3386:2:1;3371:18;14594:37:0;;;;;;;14221:418;;:::o;38650:601::-;38802:16;;;38816:1;38802:16;;;;;;;;38778:21;;38802:16;;;;;;;;;;-1:-1:-1;38802:16:0;38778:40;;38847:4;38829;38834:1;38829:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;38829:23:0;;;-1:-1:-1;;;;;38829:23:0;;;;;38873:15;-1:-1:-1;;;;;38873:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;38863:4;38868:1;38863:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;38863:32:0;;;-1:-1:-1;;;;;38863:32:0;;;;;38908:62;38925:4;38940:15;38958:11;38908:8;:62::i;:::-;39009:224;;-1:-1:-1;;;39009:224:0;;-1:-1:-1;;;;;39009:15:0;:66;;;;:224;;39090:11;;39116:1;;39160:4;;39187;;39207:15;;39009:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;38705:546;38650:601;:::o;33818:188::-;-1:-1:-1;;;;;33901:31:0;;;;;;:25;:31;;;;;;:39;;-1:-1:-1;;33901:39:0;;;;;;;;;;33958:40;;33901:39;;:31;33958:40;;;33818:188;;:::o;12650:573::-;-1:-1:-1;;;;;12790:20:0;;12782:70;;;;-1:-1:-1;;;12782:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12871:23:0;;12863:71;;;;-1:-1:-1;;;12863:71:0;;;;;;;:::i;:::-;13027;13049:6;13027:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;13027:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;13007:17:0;;;:9;:17;;;;;;;;;;;:91;;;;13132:20;;;;;;;:32;;13157:6;13132:24;:32::i;:::-;-1:-1:-1;;;;;13109:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;13180:35;3398:25:1;;;13109:20:0;;13180:35;;;;;;3371:18:1;13180:35:0;3252:177:1;17809:471:0;17867:7;18112:6;18108:47;;-1:-1:-1;18142:1:0;18135:8;;18108:47;18167:9;18179:5;18183:1;18179;:5;:::i;:::-;18167:17;-1:-1:-1;18212:1:0;18203:5;18207:1;18167:17;18203:5;:::i;:::-;:10;18195:56;;;;-1:-1:-1;;;18195:56:0;;13873:2:1;18195:56:0;;;13855:21:1;13912:2;13892:18;;;13885:30;13951:34;13931:18;;;13924:62;-1:-1:-1;;;14002:18:1;;;13995:31;14043:19;;18195:56:0;13671:397:1;18756:132:0;18814:7;18841:39;18845:1;18848;18841:39;;;;;;;;;;;;;;;;;:3;:39::i;16919:136::-;16977:7;17004:43;17008:1;17011;17004:43;;;;;;;;;;;;;;;;;:3;:43::i;19384:278::-;19470:7;19505:12;19498:5;19490:28;;;;-1:-1:-1;;;19490:28:0;;;;;;;;:::i;:::-;-1:-1:-1;19529:9:0;19541:5;19545:1;19541;:5;:::i;146:131:1:-;-1:-1:-1;;;;;221:31:1;;211:42;;201:70;;267:1;264;257:12;282:251;352:6;405:2;393:9;384:7;380:23;376:32;373:52;;;421:1;418;411:12;373:52;453:9;447:16;472:31;497:5;472:31;:::i;538:127::-;599:10;594:3;590:20;587:1;580:31;630:4;627:1;620:15;654:4;651:1;644:15;670:461;723:3;761:5;755:12;788:6;783:3;776:19;814:4;843:2;838:3;834:12;827:19;;880:2;873:5;869:14;901:1;911:195;925:6;922:1;919:13;911:195;;;990:13;;-1:-1:-1;;;;;986:39:1;974:52;;1046:12;;;;1081:15;;;;1022:1;940:9;911:195;;;-1:-1:-1;1122:3:1;;670:461;-1:-1:-1;;;;;670:461:1:o;1136:510::-;1407:6;1396:9;1389:25;1450:3;1445:2;1434:9;1430:18;1423:31;1370:4;1471:57;1523:3;1512:9;1508:19;1500:6;1471:57;:::i;:::-;-1:-1:-1;;;;;1564:32:1;;;;1559:2;1544:18;;1537:60;-1:-1:-1;1628:2:1;1613:18;1606:34;1463:65;1136:510;-1:-1:-1;;1136:510:1:o;1651:597::-;1763:4;1792:2;1821;1810:9;1803:21;1853:6;1847:13;1896:6;1891:2;1880:9;1876:18;1869:34;1921:1;1931:140;1945:6;1942:1;1939:13;1931:140;;;2040:14;;;2036:23;;2030:30;2006:17;;;2025:2;2002:26;1995:66;1960:10;;1931:140;;;2089:6;2086:1;2083:13;2080:91;;;2159:1;2154:2;2145:6;2134:9;2130:22;2126:31;2119:42;2080:91;-1:-1:-1;2232:2:1;2211:15;-1:-1:-1;;2207:29:1;2192:45;;;;2239:2;2188:54;;1651:597;-1:-1:-1;;;1651:597:1:o;2253:315::-;2321:6;2329;2382:2;2370:9;2361:7;2357:23;2353:32;2350:52;;;2398:1;2395;2388:12;2350:52;2437:9;2424:23;2456:31;2481:5;2456:31;:::i;:::-;2506:5;2558:2;2543:18;;;;2530:32;;-1:-1:-1;;;2253:315:1:o;2765:247::-;2824:6;2877:2;2865:9;2856:7;2852:23;2848:32;2845:52;;;2893:1;2890;2883:12;2845:52;2932:9;2919:23;2951:31;2976:5;2951:31;:::i;3642:456::-;3719:6;3727;3735;3788:2;3776:9;3767:7;3763:23;3759:32;3756:52;;;3804:1;3801;3794:12;3756:52;3843:9;3830:23;3862:31;3887:5;3862:31;:::i;:::-;3912:5;-1:-1:-1;3969:2:1;3954:18;;3941:32;3982:33;3941:32;3982:33;:::i;:::-;3642:456;;4034:7;;-1:-1:-1;;;4088:2:1;4073:18;;;;4060:32;;3642:456::o;4292:180::-;4351:6;4404:2;4392:9;4383:7;4379:23;4375:32;4372:52;;;4420:1;4417;4410:12;4372:52;-1:-1:-1;4443:23:1;;4292:180;-1:-1:-1;4292:180:1:o;4477:416::-;4542:6;4550;4603:2;4591:9;4582:7;4578:23;4574:32;4571:52;;;4619:1;4616;4609:12;4571:52;4658:9;4645:23;4677:31;4702:5;4677:31;:::i;:::-;4727:5;-1:-1:-1;4784:2:1;4769:18;;4756:32;4826:15;;4819:23;4807:36;;4797:64;;4857:1;4854;4847:12;4797:64;4880:7;4870:17;;;4477:416;;;;;:::o;5450:388::-;5518:6;5526;5579:2;5567:9;5558:7;5554:23;5550:32;5547:52;;;5595:1;5592;5585:12;5547:52;5634:9;5621:23;5653:31;5678:5;5653:31;:::i;:::-;5703:5;-1:-1:-1;5760:2:1;5745:18;;5732:32;5773:33;5732:32;5773:33;:::i;6103:380::-;6182:1;6178:12;;;;6225;;;6246:61;;6300:4;6292:6;6288:17;6278:27;;6246:61;6353:2;6345:6;6342:14;6322:18;6319:38;6316:161;;;6399:10;6394:3;6390:20;6387:1;6380:31;6434:4;6431:1;6424:15;6462:4;6459:1;6452:15;6316:161;;6103:380;;;:::o;6488:127::-;6549:10;6544:3;6540:20;6537:1;6530:31;6580:4;6577:1;6570:15;6604:4;6601:1;6594:15;6620:128;6660:3;6691:1;6687:6;6684:1;6681:13;6678:39;;;6697:18;;:::i;:::-;-1:-1:-1;6733:9:1;;6620:128::o;6753:356::-;6955:2;6937:21;;;6974:18;;;6967:30;7033:34;7028:2;7013:18;;7006:62;7100:2;7085:18;;6753:356::o;9321:401::-;9523:2;9505:21;;;9562:2;9542:18;;;9535:30;9601:34;9596:2;9581:18;;9574:62;-1:-1:-1;;;9667:2:1;9652:18;;9645:35;9712:3;9697:19;;9321:401::o;9727:399::-;9929:2;9911:21;;;9968:2;9948:18;;;9941:30;10007:34;10002:2;9987:18;;9980:62;-1:-1:-1;;;10073:2:1;10058:18;;10051:33;10116:3;10101:19;;9727:399::o;12157:125::-;12197:4;12225:1;12222;12219:8;12216:34;;;12230:18;;:::i;:::-;-1:-1:-1;12267:9:1;;12157:125::o;12689:582::-;12988:6;12977:9;12970:25;13031:6;13026:2;13015:9;13011:18;13004:34;13074:3;13069:2;13058:9;13054:18;13047:31;12951:4;13095:57;13147:3;13136:9;13132:19;13124:6;13095:57;:::i;:::-;-1:-1:-1;;;;;13188:32:1;;;;13183:2;13168:18;;13161:60;-1:-1:-1;13252:3:1;13237:19;13230:35;13087:65;12689:582;-1:-1:-1;;;12689:582:1:o;13276:168::-;13316:7;13382:1;13378;13374:6;13370:14;13367:1;13364:21;13359:1;13352:9;13345:17;13341:45;13338:71;;;13389:18;;:::i;:::-;-1:-1:-1;13429:9:1;;13276:168::o;13449:217::-;13489:1;13515;13505:132;;13559:10;13554:3;13550:20;13547:1;13540:31;13594:4;13591:1;13584:15;13622:4;13619:1;13612:15;13505:132;-1:-1:-1;13651:9:1;;13449:217::o

Swarm Source

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