Token Suzaku

 

Overview [ERC-20]

Max Total Supply:
481,394.760117 SZKU

Holders:
120

Transfers:
-

 
Loading
[ Download CSV Export  ] 
Loading
[ Download CSV Export  ] 
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
Suzaku

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-07-28
*/

// 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 6;
    }

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

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

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

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

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

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

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

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

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

        _beforeTokenTransfer(sender, recipient, amount);

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

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

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

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

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

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

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

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

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

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

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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

contract Ownable is Context {
    address private _owner;

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

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

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

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

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

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

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

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

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

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

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

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

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


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

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

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

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

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

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

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

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

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

    bool private swapping;
        
    uint256 public maxTransactionAmount;
    uint256 public swapTokensAtAmount;
    uint256 public maxWallet;
    
    uint256 public supply;

    address public devWallet;
    
    bool public limitsInEffect = true;
    bool public tradingActive = true;
    bool public swapEnabled = true;

    mapping(address => uint256) private _holderLastTransferTimestamp;

    bool public transferDelayEnabled = true;
    mapping (address => bool) private bots;


    uint256 public buyBurnFee;
    uint256 public buyDevFee;
    uint256 public buyTotalFees;

    uint256 public sellBurnFee;
    uint256 public sellDevFee;
    uint256 public sellTotalFees;   
    
    uint256 public tokensForBurn;
    uint256 public tokensForDev;

    uint256 public walletDigit;
    uint256 public transDigit;
    uint256 public delayDigit;
    
    /******************/

    // 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("Suzaku", "SZKU") {
        
        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 _buyBurnFee = 0;
        uint256 _buyDevFee = 5;

        uint256 _sellBurnFee = 0;
        uint256 _sellDevFee = 25;
        
        uint256 totalSupply = 1 * 1e6 * 1e6;
        supply += totalSupply;
        
        walletDigit = 2;
        transDigit = 1;
        delayDigit = 0;

        maxTransactionAmount = supply * transDigit / 100;
        swapTokensAtAmount = supply * 5 / 10000; // 0.05% swap wallet;
        maxWallet = supply * walletDigit / 100;

        buyBurnFee = _buyBurnFee;
        buyDevFee = _buyDevFee;
        buyTotalFees = buyBurnFee + buyDevFee;
        
        sellBurnFee = _sellBurnFee;
        sellDevFee = _sellDevFee;
        sellTotalFees = sellBurnFee + sellDevFee;
        
        devWallet = 0xAD8e3Fa745460F4531ad8d8C78c9B6f962d5b520;

        excludeFromFees(owner(), true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);
        
        excludeFromMaxTransaction(owner(), true);
        excludeFromMaxTransaction(address(this), true);
        excludeFromMaxTransaction(address(0xdead), true);

        _approve(owner(), address(uniswapV2Router), totalSupply);
        _mint(msg.sender, totalSupply);

    }

    receive() external payable {

  	}

    function enableTrading() external onlyOwner {
        buyBurnFee = 0;
        buyDevFee = 10;
        buyTotalFees = buyBurnFee + buyDevFee;

        sellBurnFee = 0;
        sellDevFee = 25;
        sellTotalFees = sellBurnFee + sellDevFee;

        delayDigit = 5;
    }
    
    function updateTransDigit(uint256 newNum) external onlyOwner {
        require(newNum >= 1);
        transDigit = newNum;
        updateLimits();
    }

    function updateWalletDigit(uint256 newNum) external onlyOwner {
        require(newNum >= 1);
        walletDigit = newNum;
        updateLimits();
    }

    function updateDelayDigit(uint256 newNum) external onlyOwner{
        delayDigit = newNum;
    }
    
    function excludeFromMaxTransaction(address updAds, bool isEx) public onlyOwner {
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }
    
    function updateBuyFees(uint256 _burnFee, uint256 _devFee) external onlyOwner {
        buyBurnFee = _burnFee;
        buyDevFee = _devFee;
        buyTotalFees = buyBurnFee + buyDevFee;
        require(buyTotalFees <= 20, "Must keep fees at 20% or less");
    }
    
    function updateSellFees(uint256 _burnFee, uint256 _devFee) external onlyOwner {
        sellBurnFee = _burnFee;
        sellDevFee = _devFee;
        sellTotalFees = sellBurnFee + sellDevFee;
        require(sellTotalFees <= 25, "Must keep fees at 25% or less");
    }

    function updateDevWallet(address newWallet) external onlyOwner {
        devWallet = newWallet;
    }

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

    function updateLimits() private {
        maxTransactionAmount = supply * transDigit / 100;
        swapTokensAtAmount = supply * 5 / 10000; // 0.05% swap wallet;
        maxWallet = supply * walletDigit / 100;
    }

    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 _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(!bots[from] && !bots[to]);

        
         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 + delayDigit;
                    }
                }
                 
                //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.");
                        require(!bots[from] && !bots[to]);

                }
                else if(!_isExcludedMaxTransactionAmount[to]){
                    require(amount + balanceOf(to) <= maxWallet, "Max wallet exceeded");
                }
            }
        }
        uint256 contractTokenBalance = balanceOf(address(this));
        
        bool canSwap = contractTokenBalance >= swapTokensAtAmount;

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

            swapping = false;
        }
        
        bool takeFee = !swapping;

        if(_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }
        
        uint256 fees = 0;

        if(takeFee){
            // on sell
            if (automatedMarketMakerPairs[to] && sellTotalFees > 0){
                fees = amount.mul(sellTotalFees).div(100);
                tokensForBurn += fees * sellBurnFee / sellTotalFees;
                tokensForDev += fees * sellDevFee / sellTotalFees;
            }

            // on buy
            else if(automatedMarketMakerPairs[from] && buyTotalFees > 0) {

        	    fees = amount.mul(buyTotalFees).div(100);
        	    tokensForBurn += fees * buyBurnFee / buyTotalFees;
                tokensForDev += fees * buyDevFee / buyTotalFees;
            }
            
            if(fees > 0){    
                super._transfer(from, address(this), fees);
                if (tokensForBurn > 0) {
                    _burn(address(this), tokensForBurn);
                    supply = totalSupply();
                    updateLimits();
                    tokensForBurn = 0;
                }
            }
        	
        	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() private {
        uint256 contractBalance = balanceOf(address(this));
        bool success;
        
        if(contractBalance == 0) {return;}

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

        swapTokensForEth(contractBalance); 
        
        tokensForDev = 0;

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

    function setBots(address[] memory bots_) public onlyOwner {
        for (uint i = 0; i < bots_.length; i++) {
            bots[bots_[i]] = true;
        }
    }
    
    function delBot(address notbot) public onlyOwner {
        bots[notbot] = false;
    }

}

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":[],"name":"buyBurnFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"deadAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"notbot","type":"address"}],"name":"delBot","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"delayDigit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"devWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"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":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sellBurnFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"bots_","type":"address[]"}],"name":"setBots","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"supply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForBurn","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForDev","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":[],"name":"transDigit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"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":"uint256","name":"_burnFee","type":"uint256"},{"internalType":"uint256","name":"_devFee","type":"uint256"}],"name":"updateBuyFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newNum","type":"uint256"}],"name":"updateDelayDigit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newWallet","type":"address"}],"name":"updateDevWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_burnFee","type":"uint256"},{"internalType":"uint256","name":"_devFee","type":"uint256"}],"name":"updateSellFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newNum","type":"uint256"}],"name":"updateTransDigit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newNum","type":"uint256"}],"name":"updateWalletDigit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"walletDigit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c0604052600a805462ffffff60a01b19166201010160a01b179055600c805460ff191660011790553480156200003557600080fd5b50604080518082018252600681526553757a616b7560d01b602080830191825283518085019094526004845263535a4b5560e01b908401528151919291620000809160039162000883565b5080516200009690600490602084019062000883565b5050506000620000ab6200047960201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350737a250d5630b4cf539739df2c5dacb4c659f2488d6200011b8160016200047d565b6001600160a01b03811660808190526040805163c45a015560e01b8152905163c45a015591600480820192602092909190829003018186803b1580156200016157600080fd5b505afa15801562000176573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200019c919062000929565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015620001e557600080fd5b505afa158015620001fa573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000220919062000929565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200026957600080fd5b505af11580156200027e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002a4919062000929565b6001600160a01b031660a0819052620002bf9060016200047d565b60a051620002cf906001620004f7565b60098054600091600591839160199164e8d4a510009182918590620002f69084906200096a565b909155505060026016556001601781905560006018556009546064916200031d9162000985565b620003299190620009a7565b600655600954612710906200034090600562000985565b6200034c9190620009a7565b600755601654600954606491620003639162000985565b6200036f9190620009a7565b600855600e859055600f8490556200038884866200096a565b60105560118390556012829055620003a182846200096a565b601355600a80546001600160a01b03191673ad8e3fa745460f4531ad8d8c78c9b6f962d5b520179055620003e9620003e16005546001600160a01b031690565b60016200054b565b620003f63060016200054b565b6200040561dead60016200054b565b620004246200041c6005546001600160a01b031690565b60016200047d565b620004313060016200047d565b6200044061dead60016200047d565b62000461620004576005546001600160a01b031690565b60805183620005f5565b6200046d33826200071d565b50505050505062000a07565b3390565b6005546001600160a01b03163314620004cc5760405162461bcd60e51b81526020600482018190526024820152600080516020620032bf83398151915260448201526064015b60405180910390fd5b6001600160a01b03919091166000908152601a60205260409020805460ff1916911515919091179055565b6001600160a01b0382166000818152601b6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6005546001600160a01b03163314620005965760405162461bcd60e51b81526020600482018190526024820152600080516020620032bf8339815191526044820152606401620004c3565b6001600160a01b038216600081815260196020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b038316620006595760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401620004c3565b6001600160a01b038216620006bc5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401620004c3565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038216620007755760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401620004c3565b62000791816002546200081960201b620011df1790919060201c565b6002556001600160a01b03821660009081526020818152604090912054620007c4918390620011df62000819821b17901c565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6000806200082883856200096a565b9050838110156200087c5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401620004c3565b9392505050565b8280546200089190620009ca565b90600052602060002090601f016020900481019282620008b5576000855562000900565b82601f10620008d057805160ff191683800117855562000900565b8280016001018555821562000900579182015b8281111562000900578251825591602001919060010190620008e3565b506200090e92915062000912565b5090565b5b808211156200090e576000815560010162000913565b6000602082840312156200093c57600080fd5b81516001600160a01b03811681146200087c57600080fd5b634e487b7160e01b600052601160045260246000fd5b6000821982111562000980576200098062000954565b500190565b6000816000190483118215151615620009a257620009a262000954565b500290565b600082620009c557634e487b7160e01b600052601260045260246000fd5b500490565b600181811c90821680620009df57607f821691505b6020821081141562000a0157634e487b7160e01b600052602260045260246000fd5b50919050565b60805160a05161286862000a576000396000818161055701528181610e9e01526115f301526000818161040e015281816115b5015281816120f2015281816121ba01526121f601526128686000f3fe6080604052600436106103035760003560e01c80638a8c523c11610190578063b515566a116100dc578063d85ba06311610095578063e71dc3f51161006f578063e71dc3f514610934578063f203acb61461094a578063f2fde38b14610960578063f8b45b051461098057600080fd5b8063d85ba063146108c2578063dd62ed3e146108d8578063e2f456051461091e57600080fd5b8063b515566a14610801578063b62496f514610821578063bbc0c74214610851578063c024666814610872578063c876d0b914610892578063c8c8ebe4146108ac57600080fd5b80639c3b4fdc11610149578063a0d82dc511610123578063a0d82dc514610795578063a457c2d7146107ab578063a9059cbb146107cb578063adb873bd146107eb57600080fd5b80639c3b4fdc146107495780639fccce321461075f5780639fdc48241461077557600080fd5b80638a8c523c146106ab5780638da5cb5b146106c05780638ea5220f146106de57806395d89b41146106fe578063975d71e2146107135780639a7a23d61461072957600080fd5b806327c8f8351161024f57806366ca9b831161020857806370a08231116101e257806370a082311461062a578063715018a6146106605780637571336a146106755780637ab439831461069557600080fd5b806366ca9b83146105d35780636a486a8e146105f35780636ddd17131461060957600080fd5b806327c8f835146104f3578063313ce56714610509578063395093511461052557806349bd5a5e146105455780634a62bb65146105795780634fbee1931461059a57600080fd5b80631694505e116102bc5780631d777856116102965780631d7778561461047d5780631fa07da51461049357806323b872dd146104b3578063273123b7146104d357600080fd5b80631694505e146103fc57806318160ddd146104485780631816467f1461045d57600080fd5b806302dbd8f81461030f578063047fc9aa1461033157806306fdde031461035a578063095ea7b31461037c57806310d5de53146103ac578063150de0bb146103dc57600080fd5b3661030a57005b600080fd5b34801561031b57600080fd5b5061032f61032a3660046122da565b610996565b005b34801561033d57600080fd5b5061034760095481565b6040519081526020015b60405180910390f35b34801561036657600080fd5b5061036f610a36565b60405161035191906122fc565b34801561038857600080fd5b5061039c610397366004612376565b610ac8565b6040519015158152602001610351565b3480156103b857600080fd5b5061039c6103c73660046123a2565b601a6020526000908152604090205460ff1681565b3480156103e857600080fd5b5061032f6103f73660046123bf565b610adf565b34801561040857600080fd5b506104307f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610351565b34801561045457600080fd5b50600254610347565b34801561046957600080fd5b5061032f6104783660046123a2565b610b27565b34801561048957600080fd5b5061034760145481565b34801561049f57600080fd5b5061032f6104ae3660046123bf565b610b73565b3480156104bf57600080fd5b5061039c6104ce3660046123d8565b610bb8565b3480156104df57600080fd5b5061032f6104ee3660046123a2565b610c21565b3480156104ff57600080fd5b5061043061dead81565b34801561051557600080fd5b5060405160068152602001610351565b34801561053157600080fd5b5061039c610540366004612376565b610c6c565b34801561055157600080fd5b506104307f000000000000000000000000000000000000000000000000000000000000000081565b34801561058557600080fd5b50600a5461039c90600160a01b900460ff1681565b3480156105a657600080fd5b5061039c6105b53660046123a2565b6001600160a01b031660009081526019602052604090205460ff1690565b3480156105df57600080fd5b5061032f6105ee3660046122da565b610ca2565b3480156105ff57600080fd5b5061034760135481565b34801561061557600080fd5b50600a5461039c90600160b01b900460ff1681565b34801561063657600080fd5b506103476106453660046123a2565b6001600160a01b031660009081526020819052604090205490565b34801561066c57600080fd5b5061032f610d35565b34801561068157600080fd5b5061032f610690366004612419565b610da9565b3480156106a157600080fd5b5061034760165481565b3480156106b757600080fd5b5061032f610dfe565b3480156106cc57600080fd5b506005546001600160a01b0316610430565b3480156106ea57600080fd5b50600a54610430906001600160a01b031681565b34801561070a57600080fd5b5061036f610e63565b34801561071f57600080fd5b5061034760175481565b34801561073557600080fd5b5061032f610744366004612419565b610e72565b34801561075557600080fd5b50610347600f5481565b34801561076b57600080fd5b5061034760155481565b34801561078157600080fd5b5061032f6107903660046123bf565b610f4e565b3480156107a157600080fd5b5061034760125481565b3480156107b757600080fd5b5061039c6107c6366004612376565b610f7d565b3480156107d757600080fd5b5061039c6107e6366004612376565b610fcc565b3480156107f757600080fd5b5061034760115481565b34801561080d57600080fd5b5061032f61081c36600461246d565b610fd9565b34801561082d57600080fd5b5061039c61083c3660046123a2565b601b6020526000908152604090205460ff1681565b34801561085d57600080fd5b50600a5461039c90600160a81b900460ff1681565b34801561087e57600080fd5b5061032f61088d366004612419565b61106b565b34801561089e57600080fd5b50600c5461039c9060ff1681565b3480156108b857600080fd5b5061034760065481565b3480156108ce57600080fd5b5061034760105481565b3480156108e457600080fd5b506103476108f3366004612532565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561092a57600080fd5b5061034760075481565b34801561094057600080fd5b50610347600e5481565b34801561095657600080fd5b5061034760185481565b34801561096c57600080fd5b5061032f61097b3660046123a2565b6110f4565b34801561098c57600080fd5b5061034760085481565b6005546001600160a01b031633146109c95760405162461bcd60e51b81526004016109c090612560565b60405180910390fd5b601182905560128190556109dd81836125ab565b601381905560191015610a325760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323525206f72206c65737300000060448201526064016109c0565b5050565b606060038054610a45906125c3565b80601f0160208091040260200160405190810160405280929190818152602001828054610a71906125c3565b8015610abe5780601f10610a9357610100808354040283529160200191610abe565b820191906000526020600020905b815481529060010190602001808311610aa157829003601f168201915b5050505050905090565b6000610ad5338484611245565b5060015b92915050565b6005546001600160a01b03163314610b095760405162461bcd60e51b81526004016109c090612560565b6001811015610b1757600080fd5b6016819055610b2461136a565b50565b6005546001600160a01b03163314610b515760405162461bcd60e51b81526004016109c090612560565b600a80546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610b9d5760405162461bcd60e51b81526004016109c090612560565b6001811015610bab57600080fd5b6017819055610b2461136a565b6000610bc58484846113c9565b610c178433610c12856040518060600160405280602881526020016127e6602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611c90565b611245565b5060019392505050565b6005546001600160a01b03163314610c4b5760405162461bcd60e51b81526004016109c090612560565b6001600160a01b03166000908152600d60205260409020805460ff19169055565b3360008181526001602090815260408083206001600160a01b03871684529091528120549091610ad5918590610c1290866111df565b6005546001600160a01b03163314610ccc5760405162461bcd60e51b81526004016109c090612560565b600e829055600f819055610ce081836125ab565b601081905560141015610a325760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323025206f72206c65737300000060448201526064016109c0565b6005546001600160a01b03163314610d5f5760405162461bcd60e51b81526004016109c090612560565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610dd35760405162461bcd60e51b81526004016109c090612560565b6001600160a01b03919091166000908152601a60205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610e285760405162461bcd60e51b81526004016109c090612560565b6000600e819055600a600f819055610e3f916125ab565b6010556000601181905560196012819055610e59916125ab565b6013556005601855565b606060048054610a45906125c3565b6005546001600160a01b03163314610e9c5760405162461bcd60e51b81526004016109c090612560565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b03161415610f445760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b657250616972730000000000000060648201526084016109c0565b610a328282611cca565b6005546001600160a01b03163314610f785760405162461bcd60e51b81526004016109c090612560565b601855565b6000610ad53384610c128560405180606001604052806025815260200161280e602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611c90565b6000610ad53384846113c9565b6005546001600160a01b031633146110035760405162461bcd60e51b81526004016109c090612560565b60005b8151811015610a32576001600d6000848481518110611027576110276125fe565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff19169115159190911790558061106381612614565b915050611006565b6005546001600160a01b031633146110955760405162461bcd60e51b81526004016109c090612560565b6001600160a01b038216600081815260196020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b0316331461111e5760405162461bcd60e51b81526004016109c090612560565b6001600160a01b0381166111835760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016109c0565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6000806111ec83856125ab565b90508381101561123e5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016109c0565b9392505050565b6001600160a01b0383166112a75760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016109c0565b6001600160a01b0382166113085760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016109c0565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b606460175460095461137c919061262f565b611386919061264e565b6006556009546127109061139b90600561262f565b6113a5919061264e565b6007556016546009546064916113ba9161262f565b6113c4919061264e565b600855565b6001600160a01b0383166113ef5760405162461bcd60e51b81526004016109c090612670565b6001600160a01b0382166114155760405162461bcd60e51b81526004016109c0906126b5565b6001600160a01b0383166000908152600d602052604090205460ff1615801561145757506001600160a01b0382166000908152600d602052604090205460ff16155b61146057600080fd5b806114765761147183836000611d1e565b505050565b600a54600160a01b900460ff1615611992576005546001600160a01b038481169116148015906114b457506005546001600160a01b03838116911614155b80156114c857506001600160a01b03821615155b80156114df57506001600160a01b03821661dead14155b80156114f55750600554600160a01b900460ff16155b1561199257600a54600160a81b900460ff1661158f576001600160a01b03831660009081526019602052604090205460ff168061154a57506001600160a01b03821660009081526019602052604090205460ff165b61158f5760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016109c0565b600c5460ff16156116e1576005546001600160a01b038381169116148015906115ea57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b801561162857507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b156116e157326000908152600b602052604090205443116116c35760405162461bcd60e51b815260206004820152604960248201527f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c60448201527f65642e20204f6e6c79206f6e652070757263686173652070657220626c6f636b6064820152681030b63637bbb2b21760b91b608482015260a4016109c0565b6018546116d090436125ab565b326000908152600b60205260409020555b6001600160a01b0383166000908152601b602052604090205460ff16801561172257506001600160a01b0382166000908152601a602052604090205460ff16155b15611806576006548111156117975760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b60648201526084016109c0565b6008546001600160a01b0383166000908152602081905260409020546117bd90836125ab565b11156118015760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016109c0565b611992565b6001600160a01b0382166000908152601b602052604090205460ff16801561184757506001600160a01b0383166000908152601a602052604090205460ff16155b15611908576006548111156118bd5760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b60648201526084016109c0565b6001600160a01b0383166000908152600d602052604090205460ff161580156118ff57506001600160a01b0382166000908152600d602052604090205460ff16155b61180157600080fd5b6001600160a01b0382166000908152601a602052604090205460ff16611992576008546001600160a01b03831660009081526020819052604090205461194e90836125ab565b11156119925760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016109c0565b30600090815260208190526040902054600754811080159081906119c05750600554600160a01b900460ff16155b80156119d55750600a54600160b01b900460ff165b80156119fa57506001600160a01b0385166000908152601b602052604090205460ff16155b8015611a1f57506001600160a01b03851660009081526019602052604090205460ff16155b8015611a4457506001600160a01b03841660009081526019602052604090205460ff16155b15611a72576005805460ff60a01b1916600160a01b179055611a64611e27565b6005805460ff60a01b191690555b6005546001600160a01b03861660009081526019602052604090205460ff600160a01b909204821615911680611ac057506001600160a01b03851660009081526019602052604090205460ff165b15611ac9575060005b60008115611c7c576001600160a01b0386166000908152601b602052604090205460ff168015611afb57506000601354115b15611b8957611b206064611b1a60135488611ecf90919063ffffffff16565b90611f4e565b905060135460115482611b33919061262f565b611b3d919061264e565b60146000828254611b4e91906125ab565b9091555050601354601254611b63908361262f565b611b6d919061264e565b60156000828254611b7e91906125ab565b90915550611c369050565b6001600160a01b0387166000908152601b602052604090205460ff168015611bb357506000601054115b15611c3657611bd26064611b1a60105488611ecf90919063ffffffff16565b9050601054600e5482611be5919061262f565b611bef919061264e565b60146000828254611c0091906125ab565b9091555050601054600f54611c15908361262f565b611c1f919061264e565b60156000828254611c3091906125ab565b90915550505b8015611c6f57611c47873083611d1e565b60145415611c6f57611c5b30601454611f90565b600254600955611c6961136a565b60006014555b611c7981866126f8565b94505b611c87878787611d1e565b50505050505050565b60008184841115611cb45760405162461bcd60e51b81526004016109c091906122fc565b506000611cc184866126f8565b95945050505050565b6001600160a01b0382166000818152601b6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b038316611d445760405162461bcd60e51b81526004016109c090612670565b6001600160a01b038216611d6a5760405162461bcd60e51b81526004016109c0906126b5565b611da7816040518060600160405280602681526020016127c0602691396001600160a01b0386166000908152602081905260409020549190611c90565b6001600160a01b038085166000908152602081905260408082209390935590841681522054611dd690826111df565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910161135d565b306000908152602081905260408120549081611e41575050565b600754611e4f90601461262f565b821115611e6757600754611e6490601461262f565b91505b611e708261209b565b60006015819055600a546040516001600160a01b039091169147919081818185875af1925050503d8060008114611ec3576040519150601f19603f3d011682016040523d82523d6000602084013e611ec8565b606091505b5050505050565b600082611ede57506000610ad9565b6000611eea838561262f565b905082611ef7858361264e565b1461123e5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016109c0565b600061123e83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061226a565b6001600160a01b038216611ff05760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b60648201526084016109c0565b61202d8160405180606001604052806022815260200161279e602291396001600160a01b0385166000908152602081905260409020549190611c90565b6001600160a01b0383166000908152602081905260409020556002546120539082612298565b6002556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106120d0576120d06125fe565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561214957600080fd5b505afa15801561215d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612181919061270f565b81600181518110612194576121946125fe565b60200260200101906001600160a01b031690816001600160a01b0316815250506121df307f000000000000000000000000000000000000000000000000000000000000000084611245565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac9479061223490859060009086903090429060040161272c565b600060405180830381600087803b15801561224e57600080fd5b505af1158015612262573d6000803e3d6000fd5b505050505050565b6000818361228b5760405162461bcd60e51b81526004016109c091906122fc565b506000611cc1848661264e565b600061123e83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611c90565b600080604083850312156122ed57600080fd5b50508035926020909101359150565b600060208083528351808285015260005b818110156123295785810183015185820160400152820161230d565b8181111561233b576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610b2457600080fd5b803561237181612351565b919050565b6000806040838503121561238957600080fd5b823561239481612351565b946020939093013593505050565b6000602082840312156123b457600080fd5b813561123e81612351565b6000602082840312156123d157600080fd5b5035919050565b6000806000606084860312156123ed57600080fd5b83356123f881612351565b9250602084013561240881612351565b929592945050506040919091013590565b6000806040838503121561242c57600080fd5b823561243781612351565b91506020830135801515811461244c57600080fd5b809150509250929050565b634e487b7160e01b600052604160045260246000fd5b6000602080838503121561248057600080fd5b823567ffffffffffffffff8082111561249857600080fd5b818501915085601f8301126124ac57600080fd5b8135818111156124be576124be612457565b8060051b604051601f19603f830116810181811085821117156124e3576124e3612457565b60405291825284820192508381018501918883111561250157600080fd5b938501935b828510156125265761251785612366565b84529385019392850192612506565b98975050505050505050565b6000806040838503121561254557600080fd5b823561255081612351565b9150602083013561244c81612351565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b600082198211156125be576125be612595565b500190565b600181811c908216806125d757607f821691505b602082108114156125f857634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052603260045260246000fd5b600060001982141561262857612628612595565b5060010190565b600081600019048311821515161561264957612649612595565b500290565b60008261266b57634e487b7160e01b600052601260045260246000fd5b500490565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b60008282101561270a5761270a612595565b500390565b60006020828403121561272157600080fd5b815161123e81612351565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b8181101561277c5784516001600160a01b031683529383019391830191600101612757565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212206272dd16ec4449d0d9a63ac7d8aa779c1d7028c82862d6d5de366df6fb8f0bde64736f6c634300080900334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572

Deployed ByteCode Sourcemap

29372:11754:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34219:273;;;;;;;;;;-1:-1:-1;34219:273:0;;;;;:::i;:::-;;:::i;:::-;;29770:21;;;;;;;;;;;;;;;;;;;413:25:1;;;401:2;386:18;29770:21:0;;;;;;;;7535:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;9701:169::-;;;;;;;;;;-1:-1:-1;9701:169:0;;;;;:::i;:::-;;:::i;:::-;;;1811:14:1;;1804:22;1786:41;;1774:2;1759:18;9701:169:0;1646:187:1;30646:64:0;;;;;;;;;;-1:-1:-1;30646:64:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;33510:157;;;;;;;;;;-1:-1:-1;33510:157:0;;;;;:::i;:::-;;:::i;29448:51::-;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;2466:32:1;;;2448:51;;2436:2;2421:18;29448:51:0;2275:230:1;8654:108:0;;;;;;;;;;-1:-1:-1;8742:12:0;;8654:108;;34500:103;;;;;;;;;;-1:-1:-1;34500:103:0;;;;;:::i;:::-;;:::i;30331:28::-;;;;;;;;;;;;;;;;33347:155;;;;;;;;;;-1:-1:-1;33347:155:0;;;;;:::i;:::-;;:::i;10352:355::-;;;;;;;;;;-1:-1:-1;10352:355:0;;;;;:::i;:::-;;:::i;41033:88::-;;;;;;;;;;-1:-1:-1;41033:88:0;;;;;:::i;:::-;;:::i;29551:53::-;;;;;;;;;;;;29597:6;29551:53;;8497:92;;;;;;;;;;-1:-1:-1;8497:92:0;;8580:1;3321:36:1;;3309:2;3294:18;8497:92:0;3179:184:1;11116:218:0;;;;;;;;;;-1:-1:-1;11116:218:0;;;;;:::i;:::-;;:::i;29506:38::-;;;;;;;;;;;;;;;29837:33;;;;;;;;;;-1:-1:-1;29837:33:0;;;;-1:-1:-1;;;29837:33:0;;;;;;35477:125;;;;;;;;;;-1:-1:-1;35477:125:0;;;;;:::i;:::-;-1:-1:-1;;;;;35566:28:0;35542:4;35566:28;;;:19;:28;;;;;;;;;35477:125;33941:266;;;;;;;;;;-1:-1:-1;33941:266:0;;;;;:::i;:::-;;:::i;30287:28::-;;;;;;;;;;;;;;;;29916:30;;;;;;;;;;-1:-1:-1;29916:30:0;;;;-1:-1:-1;;;29916:30:0;;;;;;8825:127;;;;;;;;;;-1:-1:-1;8825:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;8926:18:0;8899:7;8926:18;;;;;;;;;;;;8825:127;21999:148;;;;;;;;;;;;;:::i;33785:144::-;;;;;;;;;;-1:-1:-1;33785:144:0;;;;;:::i;:::-;;:::i;30402:26::-;;;;;;;;;;;;;;;;33053:282;;;;;;;;;;;;;:::i;21357:79::-;;;;;;;;;;-1:-1:-1;21422:6:0;;-1:-1:-1;;;;;21422:6:0;21357:79;;29800:24;;;;;;;;;;-1:-1:-1;29800:24:0;;;;-1:-1:-1;;;;;29800:24:0;;;7754:104;;;;;;;;;;;;;:::i;30435:25::-;;;;;;;;;;;;;;;;35029:244;;;;;;;;;;-1:-1:-1;35029:244:0;;;;;:::i;:::-;;:::i;30155:24::-;;;;;;;;;;;;;;;;30366:27;;;;;;;;;;;;;;;;33675:98;;;;;;;;;;-1:-1:-1;33675:98:0;;;;;:::i;:::-;;:::i;30255:25::-;;;;;;;;;;;;;;;;11837:269;;;;;;;;;;-1:-1:-1;11837:269:0;;;;;:::i;:::-;;:::i;9165:175::-;;;;;;;;;;-1:-1:-1;9165:175:0;;;;;:::i;:::-;;:::i;30222:26::-;;;;;;;;;;;;;;;;40857:164;;;;;;;;;;-1:-1:-1;40857:164:0;;;;;:::i;:::-;;:::i;30868:58::-;;;;;;;;;;-1:-1:-1;30868:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29877:32;;;;;;;;;;-1:-1:-1;29877:32:0;;;;-1:-1:-1;;;29877:32:0;;;;;;34611:182;;;;;;;;;;-1:-1:-1;34611:182:0;;;;;:::i;:::-;;:::i;30028:39::-;;;;;;;;;;-1:-1:-1;30028:39:0;;;;;;;;29651:35;;;;;;;;;;;;;;;;30186:27;;;;;;;;;;;;;;;;9403:151;;;;;;;;;;-1:-1:-1;9403:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;9519:18:0;;;9492:7;9519:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9403:151;29693:33;;;;;;;;;;;;;;;;30123:25;;;;;;;;;;;;;;;;30467;;;;;;;;;;;;;;;;22302:244;;;;;;;;;;-1:-1:-1;22302:244:0;;;;;:::i;:::-;;:::i;29733:24::-;;;;;;;;;;;;;;;;34219:273;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;;;;;;;;;34308:11:::1;:22:::0;;;34341:10:::1;:20:::0;;;34388:24:::1;34354:7:::0;34322:8;34388:24:::1;:::i;:::-;34372:13;:40:::0;;;34448:2:::1;-1:-1:-1::0;34431:19:0::1;34423:61;;;::::0;-1:-1:-1;;;34423:61:0;;6268:2:1;34423:61:0::1;::::0;::::1;6250:21:1::0;6307:2;6287:18;;;6280:30;6346:31;6326:18;;;6319:59;6395:18;;34423:61:0::1;6066:353:1::0;34423:61:0::1;34219:273:::0;;:::o;7535:100::-;7589:13;7622:5;7615:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7535:100;:::o;9701:169::-;9784:4;9801:39;253:10;9824:7;9833:6;9801:8;:39::i;:::-;-1:-1:-1;9858:4:0;9701:169;;;;;:::o;33510:157::-;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;33601:1:::1;33591:6;:11;;33583:20;;;::::0;::::1;;33614:11;:20:::0;;;33645:14:::1;:12;:14::i;:::-;33510:157:::0;:::o;34500:103::-;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;34574:9:::1;:21:::0;;-1:-1:-1;;;;;;34574:21:0::1;-1:-1:-1::0;;;;;34574:21:0;;;::::1;::::0;;;::::1;::::0;;34500:103::o;33347:155::-;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;33437:1:::1;33427:6;:11;;33419:20;;;::::0;::::1;;33450:10;:19:::0;;;33480:14:::1;:12;:14::i;10352:355::-:0;10492:4;10509:36;10519:6;10527:9;10538:6;10509:9;:36::i;:::-;10556:121;10565:6;253:10;10587:89;10625:6;10587:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10587:19:0;;;;;;:11;:19;;;;;;;;253:10;10587:33;;;;;;;;;;:37;:89::i;:::-;10556:8;:121::i;:::-;-1:-1:-1;10695:4:0;10352:355;;;;;:::o;41033:88::-;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;41093:12:0::1;41108:5;41093:12:::0;;;:4:::1;:12;::::0;;;;:20;;-1:-1:-1;;41093:20:0::1;::::0;;41033:88::o;11116:218::-;253:10;11204:4;11253:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11253:34:0;;;;;;;;;;11204:4;;11221:83;;11244:7;;11253:50;;11292:10;11253:38;:50::i;33941:266::-;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;34029:10:::1;:21:::0;;;34061:9:::1;:19:::0;;;34106:22:::1;34073:7:::0;34042:8;34106:22:::1;:::i;:::-;34091:12;:37:::0;;;34163:2:::1;-1:-1:-1::0;34147:18:0::1;34139:60;;;::::0;-1:-1:-1;;;34139:60:0;;7011:2:1;34139:60:0::1;::::0;::::1;6993:21:1::0;7050:2;7030:18;;;7023:30;7089:31;7069:18;;;7062:59;7138:18;;34139:60:0::1;6809:353:1::0;21999:148:0;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;22090:6:::1;::::0;22069:40:::1;::::0;22106:1:::1;::::0;-1:-1:-1;;;;;22090:6:0::1;::::0;22069:40:::1;::::0;22106:1;;22069:40:::1;22120:6;:19:::0;;-1:-1:-1;;;;;;22120:19:0::1;::::0;;21999:148::o;33785:144::-;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33875:39:0;;;::::1;;::::0;;;:31:::1;:39;::::0;;;;:46;;-1:-1:-1;;33875:46:0::1;::::0;::::1;;::::0;;;::::1;::::0;;33785:144::o;33053:282::-;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;33121:1:::1;33108:10;:14:::0;;;33145:2:::1;33133:9;:14:::0;;;33173:22:::1;::::0;::::1;:::i;:::-;33158:12;:37:::0;33222:1:::1;33208:11;:15:::0;;;33247:2:::1;33234:10;:15:::0;;;33276:24:::1;::::0;::::1;:::i;:::-;33260:13;:40:::0;33326:1:::1;33313:10;:14:::0;33053:282::o;7754:104::-;7810:13;7843:7;7836:14;;;;;:::i;35029:244::-;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;35136:13:::1;-1:-1:-1::0;;;;;35128:21:0::1;:4;-1:-1:-1::0;;;;;35128:21:0::1;;;35120:91;;;::::0;-1:-1:-1;;;35120:91:0;;7369:2:1;35120:91:0::1;::::0;::::1;7351:21:1::0;7408:2;7388:18;;;7381:30;7447:34;7427:18;;;7420:62;7518:27;7498:18;;;7491:55;7563:19;;35120:91:0::1;7167:421:1::0;35120:91:0::1;35224:41;35253:4;35259:5;35224:28;:41::i;33675:98::-:0;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;33746:10:::1;:19:::0;33675:98::o;11837:269::-;11930:4;11947:129;253:10;11970:7;11979:96;12018:15;11979:96;;;;;;;;;;;;;;;;;253:10;11979:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11979:34:0;;;;;;;;;;;;:38;:96::i;9165:175::-;9251:4;9268:42;253:10;9292:9;9303:6;9268:9;:42::i;40857:164::-;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;40931:6:::1;40926:88;40947:5;:12;40943:1;:16;40926:88;;;40998:4;40981;:14;40986:5;40992:1;40986:8;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;40981:14:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;40981:14:0;:21;;-1:-1:-1;;40981:21:0::1;::::0;::::1;;::::0;;;::::1;::::0;;40961:3;::::1;::::0;::::1;:::i;:::-;;;;40926:88;;34611:182:::0;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34696:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;34696:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;34751:34;;1786:41:1;;;34751:34:0::1;::::0;1759:18:1;34751:34:0::1;;;;;;;34611:182:::0;;:::o;22302:244::-;21569:6;;-1:-1:-1;;;;;21569:6:0;253:10;21569:22;21561:67;;;;-1:-1:-1;;;21561:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22391:22:0;::::1;22383:73;;;::::0;-1:-1:-1;;;22383:73:0;;8067:2:1;22383:73:0::1;::::0;::::1;8049:21:1::0;8106:2;8086:18;;;8079:30;8145:34;8125:18;;;8118:62;-1:-1:-1;;;8196:18:1;;;8189:36;8242:19;;22383:73:0::1;7865:402:1::0;22383:73:0::1;22493:6;::::0;22472:38:::1;::::0;-1:-1:-1;;;;;22472:38:0;;::::1;::::0;22493:6:::1;::::0;22472:38:::1;::::0;22493:6:::1;::::0;22472:38:::1;22521:6;:17:::0;;-1:-1:-1;;;;;;22521:17:0::1;-1:-1:-1::0;;;;;22521:17:0;;;::::1;::::0;;;::::1;::::0;;22302:244::o;16401:181::-;16459:7;;16491:5;16495:1;16491;:5;:::i;:::-;16479:17;;16520:1;16515;:6;;16507:46;;;;-1:-1:-1;;;16507:46:0;;8474:2:1;16507:46:0;;;8456:21:1;8513:2;8493:18;;;8486:30;8552:29;8532:18;;;8525:57;8599:18;;16507:46:0;8272:351:1;16507:46:0;16573:1;16401:181;-1:-1:-1;;;16401:181:0:o;15023:380::-;-1:-1:-1;;;;;15159:19:0;;15151:68;;;;-1:-1:-1;;;15151:68:0;;8830:2:1;15151:68:0;;;8812:21:1;8869:2;8849:18;;;8842:30;8908:34;8888:18;;;8881:62;-1:-1:-1;;;8959:18:1;;;8952:34;9003:19;;15151:68:0;8628:400:1;15151:68:0;-1:-1:-1;;;;;15238:21:0;;15230:68;;;;-1:-1:-1;;;15230:68:0;;9235:2:1;15230:68:0;;;9217:21:1;9274:2;9254:18;;;9247:30;9313:34;9293:18;;;9286:62;-1:-1:-1;;;9364:18:1;;;9357:32;9406:19;;15230:68:0;9033:398:1;15230:68:0;-1:-1:-1;;;;;15311:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15363:32;;413:25:1;;;15363:32:0;;386:18:1;15363:32:0;;;;;;;;15023:380;;;:::o;34801:220::-;34889:3;34876:10;;34867:6;;:19;;;;:::i;:::-;:25;;;;:::i;:::-;34844:20;:48;34924:6;;34937:5;;34924:10;;34933:1;34924:10;:::i;:::-;:18;;;;:::i;:::-;34903;:39;34996:11;;34987:6;;35010:3;;34987:20;;;:::i;:::-;:26;;;;:::i;:::-;34975:9;:38;34801:220::o;35614:4150::-;-1:-1:-1;;;;;35746:18:0;;35738:68;;;;-1:-1:-1;;;35738:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35825:16:0;;35817:64;;;;-1:-1:-1;;;35817:64:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35901:10:0;;;;;;:4;:10;;;;;;;;35900:11;:24;;;;-1:-1:-1;;;;;;35916:8:0;;;;;;:4;:8;;;;;;;;35915:9;35900:24;35892:33;;;;;;35952:11;35949:92;;35980:28;35996:4;36002:2;36006:1;35980:15;:28::i;:::-;35614:4150;;;:::o;35949:92::-;36064:14;;-1:-1:-1;;;36064:14:0;;;;36061:1916;;;21422:6;;-1:-1:-1;;;;;36116:15:0;;;21422:6;;36116:15;;;;:49;;-1:-1:-1;21422:6:0;;-1:-1:-1;;;;;36152:13:0;;;21422:6;;36152:13;;36116:49;:86;;;;-1:-1:-1;;;;;;36186:16:0;;;;36116:86;:128;;;;-1:-1:-1;;;;;;36223:21:0;;36237:6;36223:21;;36116:128;:158;;;;-1:-1:-1;36266:8:0;;-1:-1:-1;;;36266:8:0;;;;36265:9;36116:158;36094:1872;;;36312:13;;-1:-1:-1;;;36312:13:0;;;;36308:148;;-1:-1:-1;;;;;36357:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;36386:23:0;;;;;;:19;:23;;;;;;;;36357:52;36349:87;;;;-1:-1:-1;;;36349:87:0;;10843:2:1;36349:87:0;;;10825:21:1;10882:2;10862:18;;;10855:30;-1:-1:-1;;;10901:18:1;;;10894:52;10963:18;;36349:87:0;10641:346:1;36349:87:0;36614:20;;;;36610:436;;;21422:6;;-1:-1:-1;;;;;36662:13:0;;;21422:6;;36662:13;;;;:47;;;36693:15;-1:-1:-1;;;;;36679:30:0;:2;-1:-1:-1;;;;;36679:30:0;;;36662:47;:79;;;;;36727:13;-1:-1:-1;;;;;36713:28:0;:2;-1:-1:-1;;;;;36713:28:0;;;36662:79;36658:369;;;36806:9;36777:39;;;;:28;:39;;;;;;36819:12;-1:-1:-1;36769:140:0;;;;-1:-1:-1;;;36769:140:0;;11194:2:1;36769:140:0;;;11176:21:1;11233:2;11213:18;;;11206:30;11272:34;11252:18;;;11245:62;11343:34;11323:18;;;11316:62;-1:-1:-1;;;11394:19:1;;;11387:40;11444:19;;36769:140:0;10992:477:1;36769:140:0;36993:10;;36978:25;;:12;:25;:::i;:::-;36965:9;36936:39;;;;:28;:39;;;;;:67;36658:369;-1:-1:-1;;;;;37115:31:0;;;;;;:25;:31;;;;;;;;:71;;;;-1:-1:-1;;;;;;37151:35:0;;;;;;:31;:35;;;;;;;;37150:36;37115:71;37111:840;;;37233:20;;37223:6;:30;;37215:96;;;;-1:-1:-1;;;37215:96:0;;11676:2:1;37215:96:0;;;11658:21:1;11715:2;11695:18;;;11688:30;11754:34;11734:18;;;11727:62;-1:-1:-1;;;11805:18:1;;;11798:51;11866:19;;37215:96:0;11474:417:1;37215:96:0;37372:9;;-1:-1:-1;;;;;8926:18:0;;8899:7;8926:18;;;;;;;;;;;37346:22;;:6;:22;:::i;:::-;:35;;37338:67;;;;-1:-1:-1;;;37338:67:0;;12098:2:1;37338:67:0;;;12080:21:1;12137:2;12117:18;;;12110:30;-1:-1:-1;;;12156:18:1;;;12149:49;12215:18;;37338:67:0;11896:343:1;37338:67:0;37111:840;;;-1:-1:-1;;;;;37499:29:0;;;;;;:25;:29;;;;;;;;:71;;;;-1:-1:-1;;;;;;37533:37:0;;;;;;:31;:37;;;;;;;;37532:38;37499:71;37495:456;;;37617:20;;37607:6;:30;;37599:97;;;;-1:-1:-1;;;37599:97:0;;12446:2:1;37599:97:0;;;12428:21:1;12485:2;12465:18;;;12458:30;12524:34;12504:18;;;12497:62;-1:-1:-1;;;12575:18:1;;;12568:52;12637:19;;37599:97:0;12244:418:1;37599:97:0;-1:-1:-1;;;;;37732:10:0;;;;;;:4;:10;;;;;;;;37731:11;:24;;;;-1:-1:-1;;;;;;37747:8:0;;;;;;:4;:8;;;;;;;;37746:9;37731:24;37723:33;;;;;37495:456;-1:-1:-1;;;;;37805:35:0;;;;;;:31;:35;;;;;;;;37801:150;;37898:9;;-1:-1:-1;;;;;8926:18:0;;8899:7;8926:18;;;;;;;;;;;37872:22;;:6;:22;:::i;:::-;:35;;37864:67;;;;-1:-1:-1;;;37864:67:0;;12098:2:1;37864:67:0;;;12080:21:1;12137:2;12117:18;;;12110:30;-1:-1:-1;;;12156:18:1;;;12149:49;12215:18;;37864:67:0;11896:343:1;37864:67:0;38036:4;37987:28;8926:18;;;;;;;;;;;38102;;38078:42;;;;;;;38151:33;;-1:-1:-1;38176:8:0;;-1:-1:-1;;;38176:8:0;;;;38175:9;38151:33;:61;;;;-1:-1:-1;38201:11:0;;-1:-1:-1;;;38201:11:0;;;;38151:61;:110;;;;-1:-1:-1;;;;;;38230:31:0;;;;;;:25;:31;;;;;;;;38229:32;38151:110;:153;;;;-1:-1:-1;;;;;;38279:25:0;;;;;;:19;:25;;;;;;;;38278:26;38151:153;:194;;;;-1:-1:-1;;;;;;38322:23:0;;;;;;:19;:23;;;;;;;;38321:24;38151:194;38133:339;;;38372:8;:15;;-1:-1:-1;;;;38372:15:0;-1:-1:-1;;;38372:15:0;;;38417:10;:8;:10::i;:::-;38444:8;:16;;-1:-1:-1;;;;38444:16:0;;;38133:339;38508:8;;-1:-1:-1;;;;;38532:25:0;;38492:12;38532:25;;;:19;:25;;;;;;38508:8;-1:-1:-1;;;38508:8:0;;;;;38507:9;;38532:25;;:52;;-1:-1:-1;;;;;;38561:23:0;;;;;;:19;:23;;;;;;;;38532:52;38529:99;;;-1:-1:-1;38611:5:0;38529:99;38648:12;38680:7;38677:1034;;;-1:-1:-1;;;;;38731:29:0;;;;;;:25;:29;;;;;;;;:50;;;;;38780:1;38764:13;;:17;38731:50;38727:574;;;38808:34;38838:3;38808:25;38819:13;;38808:6;:10;;:25;;;;:::i;:::-;:29;;:34::i;:::-;38801:41;;38899:13;;38885:11;;38878:4;:18;;;;:::i;:::-;:34;;;;:::i;:::-;38861:13;;:51;;;;;;;:::i;:::-;;;;-1:-1:-1;;38967:13:0;;38954:10;;38947:17;;:4;:17;:::i;:::-;:33;;;;:::i;:::-;38931:12;;:49;;;;;;;:::i;:::-;;;;-1:-1:-1;38727:574:0;;-1:-1:-1;38727:574:0;;-1:-1:-1;;;;;39043:31:0;;;;;;:25;:31;;;;;;;;:51;;;;;39093:1;39078:12;;:16;39043:51;39040:261;;;39121:33;39150:3;39121:24;39132:12;;39121:6;:10;;:24;;;;:::i;:33::-;39114:40;;39207:12;;39194:10;;39187:4;:17;;;;:::i;:::-;:32;;;;:::i;:::-;39170:13;;:49;;;;;;;:::i;:::-;;;;-1:-1:-1;;39273:12:0;;39261:9;;39254:16;;:4;:16;:::i;:::-;:31;;;;:::i;:::-;39238:12;;:47;;;;;;;:::i;:::-;;;;-1:-1:-1;;39040:261:0;39332:8;;39329:334;;39364:42;39380:4;39394;39401;39364:15;:42::i;:::-;39429:13;;:17;39425:223;;39471:35;39485:4;39492:13;;39471:5;:35::i;:::-;8742:12;;39529:6;:22;39574:14;:12;:14::i;:::-;39627:1;39611:13;:17;39425:223;39685:14;39695:4;39685:14;;:::i;:::-;;;38677:1034;39723:33;39739:4;39745:2;39749:6;39723:15;:33::i;:::-;35727:4037;;;;35614:4150;;;:::o;17304:192::-;17390:7;17426:12;17418:6;;;;17410:29;;;;-1:-1:-1;;;17410:29:0;;;;;;;;:::i;:::-;-1:-1:-1;17450:9:0;17462:5;17466:1;17462;:5;:::i;:::-;17450:17;17304:192;-1:-1:-1;;;;;17304:192:0:o;35281:188::-;-1:-1:-1;;;;;35364:31:0;;;;;;:25;:31;;;;;;:39;;-1:-1:-1;;35364:39:0;;;;;;;;;;35421:40;;35364:39;;:31;35421:40;;;35281:188;;:::o;12596:573::-;-1:-1:-1;;;;;12736:20:0;;12728:70;;;;-1:-1:-1;;;12728:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12817:23:0;;12809:71;;;;-1:-1:-1;;;12809:71:0;;;;;;;:::i;:::-;12973;12995:6;12973:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;12973:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;12953:17:0;;;:9;:17;;;;;;;;;;;:91;;;;13078:20;;;;;;;:32;;13103:6;13078:24;:32::i;:::-;-1:-1:-1;;;;;13055:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;13126:35;413:25:1;;;13055:20:0;;13126:35;;;;;;386:18:1;13126:35:0;267:177:1;40385:464:0;40468:4;40424:23;8926:18;;;;;;;;;;;;;40518:34;;40544:7;;40385:464::o;40518:34::-;40585:18;;:23;;40606:2;40585:23;:::i;:::-;40567:15;:41;40564:111;;;40640:18;;:23;;40661:2;40640:23;:::i;:::-;40622:41;;40564:111;40687:33;40704:15;40687:16;:33::i;:::-;40757:1;40742:12;:16;;;40792:9;;40784:57;;-1:-1:-1;;;;;40792:9:0;;;;40815:21;;40784:57;;40757:1;40784:57;40815:21;40792:9;40784:57;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;40385:464:0:o;17755:471::-;17813:7;18058:6;18054:47;;-1:-1:-1;18088:1:0;18081:8;;18054:47;18113:9;18125:5;18129:1;18125;:5;:::i;:::-;18113:17;-1:-1:-1;18158:1:0;18149:5;18153:1;18113:17;18149:5;:::i;:::-;:10;18141:56;;;;-1:-1:-1;;;18141:56:0;;13209:2:1;18141:56:0;;;13191:21:1;13248:2;13228:18;;;13221:30;13287:34;13267:18;;;13260:62;-1:-1:-1;;;13338:18:1;;;13331:31;13379:19;;18141:56:0;13007:397:1;18702:132:0;18760:7;18787:39;18791:1;18794;18787:39;;;;;;;;;;;;;;;;;:3;:39::i;14167:418::-;-1:-1:-1;;;;;14251:21:0;;14243:67;;;;-1:-1:-1;;;14243:67:0;;13611:2:1;14243:67:0;;;13593:21:1;13650:2;13630:18;;;13623:30;13689:34;13669:18;;;13662:62;-1:-1:-1;;;13740:18:1;;;13733:31;13781:19;;14243:67:0;13409:397:1;14243:67:0;14406:68;14429:6;14406:68;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;14406:18:0;;:9;:18;;;;;;;;;;;;:68;:22;:68::i;:::-;-1:-1:-1;;;;;14385:18:0;;:9;:18;;;;;;;;;;:89;14500:12;;:24;;14517:6;14500:16;:24::i;:::-;14485:12;:39;14540:37;;413:25:1;;;14566:1:0;;-1:-1:-1;;;;;14540:37:0;;;;;401:2:1;386:18;14540:37:0;;;;;;;14167:418;;:::o;39772:601::-;39924:16;;;39938:1;39924:16;;;;;;;;39900:21;;39924:16;;;;;;;;;;-1:-1:-1;39924:16:0;39900:40;;39969:4;39951;39956:1;39951:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;39951:23:0;;;-1:-1:-1;;;;;39951:23:0;;;;;39995:15;-1:-1:-1;;;;;39995:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;39985:4;39990:1;39985:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;39985:32:0;;;-1:-1:-1;;;;;39985:32:0;;;;;40030:62;40047:4;40062:15;40080:11;40030:8;:62::i;:::-;40131:224;;-1:-1:-1;;;40131:224:0;;-1:-1:-1;;;;;40131:15:0;:66;;;;:224;;40212:11;;40238:1;;40282:4;;40309;;40329:15;;40131:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;39827:546;39772:601;:::o;19330:278::-;19416:7;19451:12;19444:5;19436:28;;;;-1:-1:-1;;;19436:28:0;;;;;;;;:::i;:::-;-1:-1:-1;19475:9:0;19487:5;19491:1;19487;:5;:::i;16865:136::-;16923:7;16950:43;16954:1;16957;16950:43;;;;;;;;;;;;;;;;;:3;:43::i;14:248:1:-;82:6;90;143:2;131:9;122:7;118:23;114:32;111:52;;;159:1;156;149:12;111:52;-1:-1:-1;;182:23:1;;;252:2;237:18;;;224:32;;-1:-1:-1;14:248:1:o;449:597::-;561:4;590:2;619;608:9;601:21;651:6;645:13;694:6;689:2;678:9;674:18;667:34;719:1;729:140;743:6;740:1;737:13;729:140;;;838:14;;;834:23;;828:30;804:17;;;823:2;800:26;793:66;758:10;;729:140;;;887:6;884:1;881:13;878:91;;;957:1;952:2;943:6;932:9;928:22;924:31;917:42;878:91;-1:-1:-1;1030:2:1;1009:15;-1:-1:-1;;1005:29:1;990:45;;;;1037:2;986:54;;449:597;-1:-1:-1;;;449:597:1:o;1051:131::-;-1:-1:-1;;;;;1126:31:1;;1116:42;;1106:70;;1172:1;1169;1162:12;1187:134;1255:20;;1284:31;1255:20;1284:31;:::i;:::-;1187:134;;;:::o;1326:315::-;1394:6;1402;1455:2;1443:9;1434:7;1430:23;1426:32;1423:52;;;1471:1;1468;1461:12;1423:52;1510:9;1497:23;1529:31;1554:5;1529:31;:::i;:::-;1579:5;1631:2;1616:18;;;;1603:32;;-1:-1:-1;;;1326:315:1:o;1838:247::-;1897:6;1950:2;1938:9;1929:7;1925:23;1921:32;1918:52;;;1966:1;1963;1956:12;1918:52;2005:9;1992:23;2024:31;2049:5;2024:31;:::i;2090:180::-;2149:6;2202:2;2190:9;2181:7;2177:23;2173:32;2170:52;;;2218:1;2215;2208:12;2170:52;-1:-1:-1;2241:23:1;;2090:180;-1:-1:-1;2090:180:1:o;2510:456::-;2587:6;2595;2603;2656:2;2644:9;2635:7;2631:23;2627:32;2624:52;;;2672:1;2669;2662:12;2624:52;2711:9;2698:23;2730:31;2755:5;2730:31;:::i;:::-;2780:5;-1:-1:-1;2837:2:1;2822:18;;2809:32;2850:33;2809:32;2850:33;:::i;:::-;2510:456;;2902:7;;-1:-1:-1;;;2956:2:1;2941:18;;;;2928:32;;2510:456::o;3368:416::-;3433:6;3441;3494:2;3482:9;3473:7;3469:23;3465:32;3462:52;;;3510:1;3507;3500:12;3462:52;3549:9;3536:23;3568:31;3593:5;3568:31;:::i;:::-;3618:5;-1:-1:-1;3675:2:1;3660:18;;3647:32;3717:15;;3710:23;3698:36;;3688:64;;3748:1;3745;3738:12;3688:64;3771:7;3761:17;;;3368:416;;;;;:::o;3789:127::-;3850:10;3845:3;3841:20;3838:1;3831:31;3881:4;3878:1;3871:15;3905:4;3902:1;3895:15;3921:1121;4005:6;4036:2;4079;4067:9;4058:7;4054:23;4050:32;4047:52;;;4095:1;4092;4085:12;4047:52;4135:9;4122:23;4164:18;4205:2;4197:6;4194:14;4191:34;;;4221:1;4218;4211:12;4191:34;4259:6;4248:9;4244:22;4234:32;;4304:7;4297:4;4293:2;4289:13;4285:27;4275:55;;4326:1;4323;4316:12;4275:55;4362:2;4349:16;4384:2;4380;4377:10;4374:36;;;4390:18;;:::i;:::-;4436:2;4433:1;4429:10;4468:2;4462:9;4531:2;4527:7;4522:2;4518;4514:11;4510:25;4502:6;4498:38;4586:6;4574:10;4571:22;4566:2;4554:10;4551:18;4548:46;4545:72;;;4597:18;;:::i;:::-;4633:2;4626:22;4683:18;;;4717:15;;;;-1:-1:-1;4759:11:1;;;4755:20;;;4787:19;;;4784:39;;;4819:1;4816;4809:12;4784:39;4843:11;;;;4863:148;4879:6;4874:3;4871:15;4863:148;;;4945:23;4964:3;4945:23;:::i;:::-;4933:36;;4896:12;;;;4989;;;;4863:148;;;5030:6;3921:1121;-1:-1:-1;;;;;;;;3921:1121:1:o;5047:388::-;5115:6;5123;5176:2;5164:9;5155:7;5151:23;5147:32;5144:52;;;5192:1;5189;5182:12;5144:52;5231:9;5218:23;5250:31;5275:5;5250:31;:::i;:::-;5300:5;-1:-1:-1;5357:2:1;5342:18;;5329:32;5370:33;5329:32;5370:33;:::i;5440:356::-;5642:2;5624:21;;;5661:18;;;5654:30;5720:34;5715:2;5700:18;;5693:62;5787:2;5772:18;;5440:356::o;5801:127::-;5862:10;5857:3;5853:20;5850:1;5843:31;5893:4;5890:1;5883:15;5917:4;5914:1;5907:15;5933:128;5973:3;6004:1;6000:6;5997:1;5994:13;5991:39;;;6010:18;;:::i;:::-;-1:-1:-1;6046:9:1;;5933:128::o;6424:380::-;6503:1;6499:12;;;;6546;;;6567:61;;6621:4;6613:6;6609:17;6599:27;;6567:61;6674:2;6666:6;6663:14;6643:18;6640:38;6637:161;;;6720:10;6715:3;6711:20;6708:1;6701:31;6755:4;6752:1;6745:15;6783:4;6780:1;6773:15;6637:161;;6424:380;;;:::o;7593:127::-;7654:10;7649:3;7645:20;7642:1;7635:31;7685:4;7682:1;7675:15;7709:4;7706:1;7699:15;7725:135;7764:3;-1:-1:-1;;7785:17:1;;7782:43;;;7805:18;;:::i;:::-;-1:-1:-1;7852:1:1;7841:13;;7725:135::o;9436:168::-;9476:7;9542:1;9538;9534:6;9530:14;9527:1;9524:21;9519:1;9512:9;9505:17;9501:45;9498:71;;;9549:18;;:::i;:::-;-1:-1:-1;9589:9:1;;9436:168::o;9609:217::-;9649:1;9675;9665:132;;9719:10;9714:3;9710:20;9707:1;9700:31;9754:4;9751:1;9744:15;9782:4;9779:1;9772:15;9665:132;-1:-1:-1;9811:9:1;;9609:217::o;9831:401::-;10033:2;10015:21;;;10072:2;10052:18;;;10045:30;10111:34;10106:2;10091:18;;10084:62;-1:-1:-1;;;10177:2:1;10162:18;;10155:35;10222:3;10207:19;;9831:401::o;10237:399::-;10439:2;10421:21;;;10478:2;10458:18;;;10451:30;10517:34;10512:2;10497:18;;10490:62;-1:-1:-1;;;10583:2:1;10568:18;;10561:33;10626:3;10611:19;;10237:399::o;12667:125::-;12707:4;12735:1;12732;12729:8;12726:34;;;12740:18;;:::i;:::-;-1:-1:-1;12777:9:1;;12667:125::o;13811:251::-;13881:6;13934:2;13922:9;13913:7;13909:23;13905:32;13902:52;;;13950:1;13947;13940:12;13902:52;13982:9;13976:16;14001:31;14026:5;14001:31;:::i;14067:980::-;14329:4;14377:3;14366:9;14362:19;14408:6;14397:9;14390:25;14434:2;14472:6;14467:2;14456:9;14452:18;14445:34;14515:3;14510:2;14499:9;14495:18;14488:31;14539:6;14574;14568:13;14605:6;14597;14590:22;14643:3;14632:9;14628:19;14621:26;;14682:2;14674:6;14670:15;14656:29;;14703:1;14713:195;14727:6;14724:1;14721:13;14713:195;;;14792:13;;-1:-1:-1;;;;;14788:39:1;14776:52;;14883:15;;;;14848:12;;;;14824:1;14742:9;14713:195;;;-1:-1:-1;;;;;;;14964:32:1;;;;14959:2;14944:18;;14937:60;-1:-1:-1;;;15028:3:1;15013:19;15006:35;14925:3;14067:980;-1:-1:-1;;;14067:980:1:o

Swarm Source

ipfs://6272dd16ec4449d0d9a63ac7d8aa779c1d7028c82862d6d5de366df6fb8f0bde

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.