ETH Price: $2,640.96 (+2.88%)

Token

Torimodosu (TORI)
 

Overview

Max Total Supply

1,000,000,000 TORI

Holders

31

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
0.144862917172739911 TORI

Value
$0.00
0x27f00abfd4ef49c1f9aba816015b059812926285
Loading...
Loading
Loading...
Loading
Loading...
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
Torimodosu

Compiler Version
v0.8.9+commit.e5eed63a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

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

// SPDX-License-Identifier: MIT

/* Torimodosu
 * 
 * https://medium.com/@torimodosueth
 * “When life knocks you down, dust yourself off and get back up again.”
 * 
 */

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;


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

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

    function initialize(address, address) external;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns(uint8);
}
 
 
contract ERC20 is Context, IERC20, IERC20Metadata {
    using SafeMath for uint256;

        mapping(address => uint256) private _balances;

    mapping(address => mapping(address => uint256)) private _allowances;
 
    uint256 private _totalSupply;
 
    string private _name;
    string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

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

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

        _beforeTokenTransfer(sender, recipient, amount);

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

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

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

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

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

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

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

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

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

    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be to transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual { }
}
 
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns(uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

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

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

        return c;
    }

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

        return c;
    }

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

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

        return c;
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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

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

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

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

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

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

 /* 
  *
  * For times like these...
  *
  * Torimodosu
  *
  */

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

    IUniswapV2Router02 public immutable uniswapV2Router;
    address public immutable uniswapV2Pair;

    // to send messages
    string messageForCommunity = "hello, world";

    // addresses
    address private marketingWallet;

    // limits 
    uint256 private maxTransactionBuyAmount;
    uint256 private maxTransactionSellAmount;   
    uint256 private maxWallet;
 
    uint256 private swapTokensAtAmount;

    // status flags
    bool private tradingActive = false;
    bool public swapEnabled = false;
    bool public swapping;

    struct Fees {
        uint256 buyTotalFees;
        uint256 buyMarketingFee;
        uint256 buyLiquidityFee;

        uint256 sellTotalFees;
        uint256 sellMarketingFee;
        uint256 sellLiquidityFee;
    }  

    Fees public _fees = Fees({
        buyTotalFees: 0,
        buyMarketingFee: 0,
        buyLiquidityFee: 0,

        sellTotalFees: 0,
        sellMarketingFee: 0,
        sellLiquidityFee: 0
    });
    
    uint256 public tokensForMarketing;
    uint256 public tokensForLiquidity;

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

    // 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 SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiquidity
    );


    constructor() ERC20("Torimodosu", "TORI") {
 
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); // Router02 Uniswap

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

        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        excludeFromMaxTransaction(address(uniswapV2Pair), true);
        automatedMarketMakerPairs[address(uniswapV2Pair)] = true;

        approve(address(_uniswapV2Router), type(uint256).max);
        uint256 totalSupply = 1000000000* 1e18;

        maxTransactionBuyAmount = totalSupply * 3 / 100; // 1% maxTransactionAmountTxn
        maxTransactionSellAmount = totalSupply; // you can sell however much you want at any time
        maxWallet = totalSupply * 3 / 100; // 3% maxWallet
        swapTokensAtAmount = totalSupply * 1 / 10000; // 0.01% swap wallet

        /*
         * There is a 2% fee on buys and sells.
         * There will only ever bee a 2% fee on buys and sells.
         */

        _fees.buyMarketingFee = 2;
        _fees.buyLiquidityFee = 0;
        _fees.buyTotalFees = _fees.buyMarketingFee + _fees.buyLiquidityFee;

        _fees.sellMarketingFee = 2;
        _fees.sellLiquidityFee = 0;
        _fees.sellTotalFees = _fees.sellMarketingFee + _fees.sellLiquidityFee;

        marketingWallet = address(0x4E85765F2313B7fEb18B130f77c62aBB304e7a7D);

        // exclude from paying fees or having max transaction amount
        excludeFromFees(owner(), true);
        excludeFromFees(address(this), true);

        excludeFromMaxTransaction(owner(), true);
        excludeFromMaxTransaction(address(this), true);

        excludeFromWalletLimit(owner(), true);
        excludeFromWalletLimit(address(this), true);
        excludeFromWalletLimit(address(uniswapV2Pair), true);

        // This is only ever called once.
        _mint(msg.sender, totalSupply);
    }

    receive() external payable {

    }

    function readTheMessage() public view returns (string memory) {
        return messageForCommunity;
    }

    function setTheMessage(string memory _newMessageForCommunity) external onlyOwner returns(bool){
        messageForCommunity = _newMessageForCommunity;
        return true;
    }

    // once enabled, can never be turned off
    function enableTrading() external onlyOwner {
        tradingActive = true;
        swapEnabled = true;
    }

    // Change the minimum amount of tokens to sell from fees
    function updateSwapTokensAtAmount(uint256 newAmount) external onlyOwner returns(bool){
        swapTokensAtAmount = newAmount;
        return true;
    }

    // Once max buy is lifted it can never go back
    function releaseMaxBuy() external onlyOwner {
        maxTransactionBuyAmount = totalSupply();
    }

    // Once max wallet is lifted it can never go back
    function releaseMaxWallet() external onlyOwner {
        maxWallet = totalSupply();
    }

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

    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
    }
    function excludeFromWalletLimit(address account, bool excluded) public onlyOwner {
        _isExcludedMaxWalletAmount[account] = excluded;
    }
    function excludeFromMaxTransaction(address updAds, bool isEx) public onlyOwner {
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }

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

    function updateMarketingFeeReceiver(address newMarketingWallet) external onlyOwner{
        marketingWallet = newMarketingWallet;
    }

    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(from != address(0xdEaD), "ERC20: transfer from the dEaD address");
        require(to != address(0xdEaD), "ERC20: transfer to the dEaD address");
        
        if (amount == 0) {
            super._transfer(from, to, 0);
            return;
        }

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

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

            //when sell
            else if (automatedMarketMakerPairs[to] && !_isExcludedMaxTransactionAmount[from]) {
                require(amount <= maxTransactionSellAmount, "Sell transfer amount exceeds the maxTransactionAmount.");
            }
            if (!_isExcludedMaxWalletAmount[to]) {
                require(amount + balanceOf(to) <= maxWallet, "Max wallet exceeded");
            }
        }
 
        uint256 contractTokenBalance = balanceOf(address(this));
 
        bool canSwap = contractTokenBalance >= swapTokensAtAmount;

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

            swapBack();

            swapping = false;
        }
 
        bool takeFee = !swapping;

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

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

            amount -= fees;

        }

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

    function swapTokensForEth(uint256 tokenAmount) private {

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

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

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

    }

    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(uniswapV2Router), tokenAmount);

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

    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        uint256 totalTokensToSwap = tokensForLiquidity + tokensForMarketing ;
        bool success;

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

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

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

        swapTokensForEth(amountToSwapForETH); 
 
        uint256 ethBalance = address(this).balance.sub(initialETHBalance);
 
        uint256 ethForMarketing = ethBalance.mul(tokensForMarketing).div(totalTokensToSwap);
        uint256 ethForLiquidity = ethBalance - ethForMarketing;


        tokensForLiquidity = 0;
        tokensForMarketing = 0;


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

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

}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiquidity","type":"uint256"}],"name":"SwapAndLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"_fees","outputs":[{"internalType":"uint256","name":"buyTotalFees","type":"uint256"},{"internalType":"uint256","name":"buyMarketingFee","type":"uint256"},{"internalType":"uint256","name":"buyLiquidityFee","type":"uint256"},{"internalType":"uint256","name":"sellTotalFees","type":"uint256"},{"internalType":"uint256","name":"sellMarketingFee","type":"uint256"},{"internalType":"uint256","name":"sellLiquidityFee","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxWalletAmount","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":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromWalletLimit","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":"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":"readTheMessage","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"releaseMaxBuy","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"releaseMaxWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_newMessageForCommunity","type":"string"}],"name":"setTheMessage","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapping","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForLiquidity","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForMarketing","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","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":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newMarketingWallet","type":"address"}],"name":"updateMarketingFeeReceiver","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enabled","type":"bool"}],"name":"updateSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"updateSwapTokensAtAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

610100604052600c60c08190526b1a195b1b1bcb081ddbdc9b1960a21b60e0908152620000309160069190620008da565b50600c805461ffff191690556040805160c081018252600080825260208201819052918101829052606081018290526080810182905260a001819052600d819055600e819055600f819055601081905560118190556012553480156200009557600080fd5b50604080518082018252600a815269546f72696d6f646f737560b01b602080830191825283518085019094526004845263544f524960e01b908401528151919291620000e491600391620008da565b508051620000fa906004906020840190620008da565b50505060006200010f620004ca60201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350737a250d5630b4cf539739df2c5dacb4c659f2488d6200017f816001620004ce565b6001600160a01b03811660808190526040805163c45a015560e01b8152905163c45a015591600480820192602092909190829003018186803b158015620001c557600080fd5b505afa158015620001da573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000200919062000980565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156200024957600080fd5b505afa1580156200025e573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000284919062000980565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b158015620002cd57600080fd5b505af1158015620002e2573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000308919062000980565b6001600160a01b031660a081905262000323906001620004ce565b60a0516001600160a01b03166000908152601860205260409020805460ff19166001179055620003568160001962000548565b506b033b2e3c9fd0803ce8000000606462000373826003620009c1565b6200037f9190620009e3565b6008556009819055606462000396826003620009c1565b620003a29190620009e3565b600a55612710620003b5826001620009c1565b620003c19190620009e3565b600b556002600e8190556000600f819055620003dd9162000a06565b600d556002601181905560006012819055620003f99162000a06565b601055600780546001600160a01b031916734e85765f2313b7feb18b130f77c62abb304e7a7d17905562000441620004396005546001600160a01b031690565b600162000560565b6200044e30600162000560565b6200046d620004656005546001600160a01b031690565b6001620004ce565b6200047a306001620004ce565b62000499620004916005546001600160a01b031690565b6001620005d6565b620004a6306001620005d6565b60a051620004b6906001620005d6565b620004c233826200064c565b505062000a5e565b3390565b6005546001600160a01b031633146200051d5760405162461bcd60e51b8152602060048201819052602482015260008051602062002e3883398151915260448201526064015b60405180910390fd5b6001600160a01b03919091166000908152601660205260409020805460ff1916911515919091179055565b60006200055733848462000748565b50600192915050565b6005546001600160a01b03163314620005ab5760405162461bcd60e51b8152602060048201819052602482015260008051602062002e38833981519152604482015260640162000514565b6001600160a01b03919091166000908152601560205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314620006215760405162461bcd60e51b8152602060048201819052602482015260008051602062002e38833981519152604482015260640162000514565b6001600160a01b03919091166000908152601760205260409020805460ff1916911515919091179055565b6001600160a01b038216620006a45760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640162000514565b620006c0816002546200087060201b62000e5c1790919060201c565b6002556001600160a01b03821660009081526020818152604090912054620006f391839062000e5c62000870821b17901c565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6001600160a01b038316620007ac5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840162000514565b6001600160a01b0382166200080f5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840162000514565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6000806200087f838562000a06565b905083811015620008d35760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640162000514565b9392505050565b828054620008e89062000a21565b90600052602060002090601f0160209004810192826200090c576000855562000957565b82601f106200092757805160ff191683800117855562000957565b8280016001018555821562000957579182015b82811115620009575782518255916020019190600101906200093a565b506200096592915062000969565b5090565b5b808211156200096557600081556001016200096a565b6000602082840312156200099357600080fd5b81516001600160a01b0381168114620008d357600080fd5b634e487b7160e01b600052601160045260246000fd5b6000816000190483118215151615620009de57620009de620009ab565b500290565b60008262000a0157634e487b7160e01b600052601260045260246000fd5b500490565b6000821982111562000a1c5762000a1c620009ab565b500190565b600181811c9082168062000a3657607f821691505b6020821081141562000a5857634e487b7160e01b600052602260045260246000fd5b50919050565b60805160a05161238a62000aae600039600081816103fc0152610b550152600081816102c701528181611af301528181611bbb01528181611bf701528181611c710152611ccd015261238a6000f3fe60806040526004361061021e5760003560e01c806370a0823111610123578063a457c2d7116100ab578063d257b34f1161006f578063d257b34f146106cb578063d68dff19146106eb578063dd62ed3e14610700578063e16830a814610746578063f2fde38b1461076657600080fd5b8063a457c2d7146105e3578063a9059cbb14610603578063b62496f514610623578063c024666814610653578063d212a69a1461067357600080fd5b80638da5cb5b116100f25780638da5cb5b14610540578063924de9b71461055e57806395d89b411461057e57806396880b17146105935780639a7a23d6146105c357600080fd5b806370a08231146104c0578063715018a6146104f65780637571336a1461050b5780638a8c523c1461052b57600080fd5b806323b872dd116101a65780634fbee193116101755780634fbee1931461041e57806355c1adfe146104575780635c58cca7146104775780636705454b1461048c5780636ddd1713146104a157600080fd5b806323b872dd1461038e578063313ce567146103ae57806339509351146103ca57806349bd5a5e146103ea57600080fd5b80631732cded116101ed5780631732cded1461030157806318160ddd14610321578063190b762c146103405780631a8145bb146103625780631f3fed8f1461037857600080fd5b806306fdde031461022a578063095ea7b31461025557806310d5de53146102855780631694505e146102b557600080fd5b3661022557005b600080fd5b34801561023657600080fd5b5061023f610786565b60405161024c9190611e21565b60405180910390f35b34801561026157600080fd5b50610275610270366004611e8e565b610818565b604051901515815260200161024c565b34801561029157600080fd5b506102756102a0366004611eba565b60166020526000908152604090205460ff1681565b3480156102c157600080fd5b506102e97f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b03909116815260200161024c565b34801561030d57600080fd5b50600c546102759062010000900460ff1681565b34801561032d57600080fd5b506002545b60405190815260200161024c565b34801561034c57600080fd5b5061036061035b366004611eba565b61082f565b005b34801561036e57600080fd5b5061033260145481565b34801561038457600080fd5b5061033260135481565b34801561039a57600080fd5b506102756103a9366004611ed7565b610884565b3480156103ba57600080fd5b506040516012815260200161024c565b3480156103d657600080fd5b506102756103e5366004611e8e565b6108ed565b3480156103f657600080fd5b506102e97f000000000000000000000000000000000000000000000000000000000000000081565b34801561042a57600080fd5b50610275610439366004611eba565b6001600160a01b031660009081526015602052604090205460ff1690565b34801561046357600080fd5b50610275610472366004611f2e565b610923565b34801561048357600080fd5b5061036061096e565b34801561049857600080fd5b506103606109a0565b3480156104ad57600080fd5b50600c5461027590610100900460ff1681565b3480156104cc57600080fd5b506103326104db366004611eba565b6001600160a01b031660009081526020819052604090205490565b34801561050257600080fd5b506103606109d2565b34801561051757600080fd5b50610360610526366004611fef565b610a46565b34801561053757600080fd5b50610360610a9b565b34801561054c57600080fd5b506005546001600160a01b03166102e9565b34801561056a57600080fd5b50610360610579366004612024565b610ad6565b34801561058a57600080fd5b5061023f610b1a565b34801561059f57600080fd5b506102756105ae366004611eba565b60176020526000908152604090205460ff1681565b3480156105cf57600080fd5b506103606105de366004611fef565b610b29565b3480156105ef57600080fd5b506102756105fe366004611e8e565b610c26565b34801561060f57600080fd5b5061027561061e366004611e8e565b610c75565b34801561062f57600080fd5b5061027561063e366004611eba565b60186020526000908152604090205460ff1681565b34801561065f57600080fd5b5061036061066e366004611fef565b610c82565b34801561067f57600080fd5b50600d54600e54600f5460105460115460125461069e95949392919086565b604080519687526020870195909552938501929092526060840152608083015260a082015260c00161024c565b3480156106d757600080fd5b506102756106e636600461203f565b610cd7565b3480156106f757600080fd5b5061023f610d0d565b34801561070c57600080fd5b5061033261071b366004612058565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561075257600080fd5b50610360610761366004611fef565b610d1c565b34801561077257600080fd5b50610360610781366004611eba565b610d71565b60606003805461079590612091565b80601f01602080910402602001604051908101604052809291908181526020018280546107c190612091565b801561080e5780601f106107e35761010080835404028352916020019161080e565b820191906000526020600020905b8154815290600101906020018083116107f157829003601f168201915b5050505050905090565b6000610825338484610ec2565b5060015b92915050565b6005546001600160a01b031633146108625760405162461bcd60e51b8152600401610859906120cc565b60405180910390fd5b600780546001600160a01b0319166001600160a01b0392909216919091179055565b6000610891848484610fe7565b6108e384336108de85604051806060016040528060288152602001612308602891396001600160a01b038a16600090815260016020908152604080832033845290915290205491906116ad565b610ec2565b5060019392505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916108259185906108de9086610e5c565b6005546000906001600160a01b031633146109505760405162461bcd60e51b8152600401610859906120cc565b8151610963906006906020850190611d88565b50600190505b919050565b6005546001600160a01b031633146109985760405162461bcd60e51b8152600401610859906120cc565b600254600855565b6005546001600160a01b031633146109ca5760405162461bcd60e51b8152600401610859906120cc565b600254600a55565b6005546001600160a01b031633146109fc5760405162461bcd60e51b8152600401610859906120cc565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610a705760405162461bcd60e51b8152600401610859906120cc565b6001600160a01b03919091166000908152601660205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610ac55760405162461bcd60e51b8152600401610859906120cc565b600c805461ffff1916610101179055565b6005546001600160a01b03163314610b005760405162461bcd60e51b8152600401610859906120cc565b600c80549115156101000261ff0019909216919091179055565b60606004805461079590612091565b6005546001600160a01b03163314610b535760405162461bcd60e51b8152600401610859906120cc565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b03161415610bfb5760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610859565b6001600160a01b03919091166000908152601860205260409020805460ff1916911515919091179055565b600061082533846108de85604051806060016040528060258152602001612330602591393360009081526001602090815260408083206001600160a01b038d16845290915290205491906116ad565b6000610825338484610fe7565b6005546001600160a01b03163314610cac5760405162461bcd60e51b8152600401610859906120cc565b6001600160a01b03919091166000908152601560205260409020805460ff1916911515919091179055565b6005546000906001600160a01b03163314610d045760405162461bcd60e51b8152600401610859906120cc565b50600b55600190565b60606006805461079590612091565b6005546001600160a01b03163314610d465760405162461bcd60e51b8152600401610859906120cc565b6001600160a01b03919091166000908152601760205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610d9b5760405162461bcd60e51b8152600401610859906120cc565b6001600160a01b038116610e005760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610859565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610e698385612117565b905083811015610ebb5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610859565b9392505050565b6001600160a01b038316610f245760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610859565b6001600160a01b038216610f855760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610859565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661100d5760405162461bcd60e51b81526004016108599061212f565b6001600160a01b0382166110335760405162461bcd60e51b815260040161085990612174565b6001600160a01b03831661dead141561109c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d207468652064456144206164604482015264647265737360d81b6064820152608401610859565b6001600160a01b03821661dead14156111035760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f207468652064456144206164647260448201526265737360e81b6064820152608401610859565b8061111957611114838360006116e7565b505050565b6005546001600160a01b0384811691161480159061114557506005546001600160a01b03838116911614155b801561115a5750600c5462010000900460ff16155b156113e957600c5460ff166111ed576001600160a01b03831660009081526015602052604090205460ff16806111a857506001600160a01b03821660009081526015602052604090205460ff165b6111ed5760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610859565b6001600160a01b03831660009081526018602052604090205460ff16801561122e57506001600160a01b03821660009081526016602052604090205460ff16155b156112a8576008548111156112a35760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610859565b61135f565b6001600160a01b03821660009081526018602052604090205460ff1680156112e957506001600160a01b03831660009081526016602052604090205460ff16155b1561135f5760095481111561135f5760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610859565b6001600160a01b03821660009081526017602052604090205460ff166113e957600a546001600160a01b0383166000908152602081905260409020546113a59083612117565b11156113e95760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610859565b30600090815260208190526040902054600b54811080159081906114145750600c54610100900460ff165b80156114295750600c5462010000900460ff16155b801561144d57506001600160a01b03841660009081526018602052604090205460ff165b801561147257506001600160a01b03851660009081526015602052604090205460ff16155b801561149757506001600160a01b03841660009081526015602052604090205460ff16155b156114c257600c805462ff00001916620100001790556114b56117f0565b600c805462ff0000191690555b600c546001600160a01b03861660009081526015602052604090205460ff6201000090920482161591168061150f57506001600160a01b03851660009081526015602052604090205460ff165b15611518575060005b60008115611699576001600160a01b03861660009081526018602052604090205460ff168015611549575060105415155b156115d35760105461156990606490611563908890611999565b90611a18565b6010546012549192509061157d90836121b7565b61158791906121d6565b601460008282546115989190612117565b90915550506010546011546115ad90836121b7565b6115b791906121d6565b601360008282546115c89190612117565b9091555061167b9050565b6001600160a01b03871660009081526018602052604090205460ff1680156115fc5750600d5415155b1561167b57600d5461161690606490611563908890611999565b600d54600f549192509061162a90836121b7565b61163491906121d6565b601460008282546116459190612117565b9091555050600d54600e5461165a90836121b7565b61166491906121d6565b601360008282546116759190612117565b90915550505b801561168c5761168c8730836116e7565b61169681866121f8565b94505b6116a48787876116e7565b50505050505050565b600081848411156116d15760405162461bcd60e51b81526004016108599190611e21565b5060006116de84866121f8565b95945050505050565b6001600160a01b03831661170d5760405162461bcd60e51b81526004016108599061212f565b6001600160a01b0382166117335760405162461bcd60e51b815260040161085990612174565b611770816040518060600160405280602681526020016122e2602691396001600160a01b03861660009081526020819052604090205491906116ad565b6001600160a01b03808516600090815260208190526040808220939093559084168152205461179f9082610e5c565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610fda565b30600090815260208190526040812054905060006013546014546118149190612117565b90506000821580611823575081155b1561182d57505050565b600b5461183b9060146121b7565b83111561185357600b546118509060146121b7565b92505b60006002836014548661186691906121b7565b61187091906121d6565b61187a91906121d6565b905060006118888583611a5a565b90504761189482611a9c565b60006118a04783611a5a565b905060006118bd876115636013548561199990919063ffffffff16565b905060006118cb82846121f8565b60006014819055601355905085158015906118e65750600081115b15611939576118f58682611c6b565b601454604080518781526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6007546040516001600160a01b03909116904790600081818185875af1925050503d8060008114611986576040519150601f19603f3d011682016040523d82523d6000602084013e61198b565b606091505b505050505050505050505050565b6000826119a857506000610829565b60006119b483856121b7565b9050826119c185836121d6565b14610ebb5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610859565b6000610ebb83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611d5a565b6000610ebb83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506116ad565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611ad157611ad161220f565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015611b4a57600080fd5b505afa158015611b5e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611b829190612225565b81600181518110611b9557611b9561220f565b60200260200101906001600160a01b031690816001600160a01b031681525050611be0307f000000000000000000000000000000000000000000000000000000000000000084610ec2565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac94790611c35908590600090869030904290600401612242565b600060405180830381600087803b158015611c4f57600080fd5b505af1158015611c63573d6000803e3d6000fd5b505050505050565b611c96307f000000000000000000000000000000000000000000000000000000000000000084610ec2565b60405163f305d71960e01b8152306004820181905260248201849052600060448301819052606483015260848201524260a48201527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03169063f305d71990839060c4016060604051808303818588803b158015611d1a57600080fd5b505af1158015611d2e573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190611d5391906122b3565b5050505050565b60008183611d7b5760405162461bcd60e51b81526004016108599190611e21565b5060006116de84866121d6565b828054611d9490612091565b90600052602060002090601f016020900481019282611db65760008555611dfc565b82601f10611dcf57805160ff1916838001178555611dfc565b82800160010185558215611dfc579182015b82811115611dfc578251825591602001919060010190611de1565b50611e08929150611e0c565b5090565b5b80821115611e085760008155600101611e0d565b600060208083528351808285015260005b81811015611e4e57858101830151858201604001528201611e32565b81811115611e60576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114611e8b57600080fd5b50565b60008060408385031215611ea157600080fd5b8235611eac81611e76565b946020939093013593505050565b600060208284031215611ecc57600080fd5b8135610ebb81611e76565b600080600060608486031215611eec57600080fd5b8335611ef781611e76565b92506020840135611f0781611e76565b929592945050506040919091013590565b634e487b7160e01b600052604160045260246000fd5b600060208284031215611f4057600080fd5b813567ffffffffffffffff80821115611f5857600080fd5b818401915084601f830112611f6c57600080fd5b813581811115611f7e57611f7e611f18565b604051601f8201601f19908116603f01168101908382118183101715611fa657611fa6611f18565b81604052828152876020848701011115611fbf57600080fd5b826020860160208301376000928101602001929092525095945050505050565b8035801515811461096957600080fd5b6000806040838503121561200257600080fd5b823561200d81611e76565b915061201b60208401611fdf565b90509250929050565b60006020828403121561203657600080fd5b610ebb82611fdf565b60006020828403121561205157600080fd5b5035919050565b6000806040838503121561206b57600080fd5b823561207681611e76565b9150602083013561208681611e76565b809150509250929050565b600181811c908216806120a557607f821691505b602082108114156120c657634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b6000821982111561212a5761212a612101565b500190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b60008160001904831182151516156121d1576121d1612101565b500290565b6000826121f357634e487b7160e01b600052601260045260246000fd5b500490565b60008282101561220a5761220a612101565b500390565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561223757600080fd5b8151610ebb81611e76565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156122925784516001600160a01b03168352938301939183019160010161226d565b50506001600160a01b03969096166060850152505050608001529392505050565b6000806000606084860312156122c857600080fd5b835192506020840151915060408401519050925092509256fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa264697066735822122078c541fedb1a033317e8d7b32ee44f1a8ade2426507df0cb9f6ba34c974b2c1564736f6c634300080900334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572

Deployed Bytecode

0x60806040526004361061021e5760003560e01c806370a0823111610123578063a457c2d7116100ab578063d257b34f1161006f578063d257b34f146106cb578063d68dff19146106eb578063dd62ed3e14610700578063e16830a814610746578063f2fde38b1461076657600080fd5b8063a457c2d7146105e3578063a9059cbb14610603578063b62496f514610623578063c024666814610653578063d212a69a1461067357600080fd5b80638da5cb5b116100f25780638da5cb5b14610540578063924de9b71461055e57806395d89b411461057e57806396880b17146105935780639a7a23d6146105c357600080fd5b806370a08231146104c0578063715018a6146104f65780637571336a1461050b5780638a8c523c1461052b57600080fd5b806323b872dd116101a65780634fbee193116101755780634fbee1931461041e57806355c1adfe146104575780635c58cca7146104775780636705454b1461048c5780636ddd1713146104a157600080fd5b806323b872dd1461038e578063313ce567146103ae57806339509351146103ca57806349bd5a5e146103ea57600080fd5b80631732cded116101ed5780631732cded1461030157806318160ddd14610321578063190b762c146103405780631a8145bb146103625780631f3fed8f1461037857600080fd5b806306fdde031461022a578063095ea7b31461025557806310d5de53146102855780631694505e146102b557600080fd5b3661022557005b600080fd5b34801561023657600080fd5b5061023f610786565b60405161024c9190611e21565b60405180910390f35b34801561026157600080fd5b50610275610270366004611e8e565b610818565b604051901515815260200161024c565b34801561029157600080fd5b506102756102a0366004611eba565b60166020526000908152604090205460ff1681565b3480156102c157600080fd5b506102e97f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b03909116815260200161024c565b34801561030d57600080fd5b50600c546102759062010000900460ff1681565b34801561032d57600080fd5b506002545b60405190815260200161024c565b34801561034c57600080fd5b5061036061035b366004611eba565b61082f565b005b34801561036e57600080fd5b5061033260145481565b34801561038457600080fd5b5061033260135481565b34801561039a57600080fd5b506102756103a9366004611ed7565b610884565b3480156103ba57600080fd5b506040516012815260200161024c565b3480156103d657600080fd5b506102756103e5366004611e8e565b6108ed565b3480156103f657600080fd5b506102e97f000000000000000000000000b4c4b4de76add68e0b9bb01217234c5f161394bc81565b34801561042a57600080fd5b50610275610439366004611eba565b6001600160a01b031660009081526015602052604090205460ff1690565b34801561046357600080fd5b50610275610472366004611f2e565b610923565b34801561048357600080fd5b5061036061096e565b34801561049857600080fd5b506103606109a0565b3480156104ad57600080fd5b50600c5461027590610100900460ff1681565b3480156104cc57600080fd5b506103326104db366004611eba565b6001600160a01b031660009081526020819052604090205490565b34801561050257600080fd5b506103606109d2565b34801561051757600080fd5b50610360610526366004611fef565b610a46565b34801561053757600080fd5b50610360610a9b565b34801561054c57600080fd5b506005546001600160a01b03166102e9565b34801561056a57600080fd5b50610360610579366004612024565b610ad6565b34801561058a57600080fd5b5061023f610b1a565b34801561059f57600080fd5b506102756105ae366004611eba565b60176020526000908152604090205460ff1681565b3480156105cf57600080fd5b506103606105de366004611fef565b610b29565b3480156105ef57600080fd5b506102756105fe366004611e8e565b610c26565b34801561060f57600080fd5b5061027561061e366004611e8e565b610c75565b34801561062f57600080fd5b5061027561063e366004611eba565b60186020526000908152604090205460ff1681565b34801561065f57600080fd5b5061036061066e366004611fef565b610c82565b34801561067f57600080fd5b50600d54600e54600f5460105460115460125461069e95949392919086565b604080519687526020870195909552938501929092526060840152608083015260a082015260c00161024c565b3480156106d757600080fd5b506102756106e636600461203f565b610cd7565b3480156106f757600080fd5b5061023f610d0d565b34801561070c57600080fd5b5061033261071b366004612058565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561075257600080fd5b50610360610761366004611fef565b610d1c565b34801561077257600080fd5b50610360610781366004611eba565b610d71565b60606003805461079590612091565b80601f01602080910402602001604051908101604052809291908181526020018280546107c190612091565b801561080e5780601f106107e35761010080835404028352916020019161080e565b820191906000526020600020905b8154815290600101906020018083116107f157829003601f168201915b5050505050905090565b6000610825338484610ec2565b5060015b92915050565b6005546001600160a01b031633146108625760405162461bcd60e51b8152600401610859906120cc565b60405180910390fd5b600780546001600160a01b0319166001600160a01b0392909216919091179055565b6000610891848484610fe7565b6108e384336108de85604051806060016040528060288152602001612308602891396001600160a01b038a16600090815260016020908152604080832033845290915290205491906116ad565b610ec2565b5060019392505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916108259185906108de9086610e5c565b6005546000906001600160a01b031633146109505760405162461bcd60e51b8152600401610859906120cc565b8151610963906006906020850190611d88565b50600190505b919050565b6005546001600160a01b031633146109985760405162461bcd60e51b8152600401610859906120cc565b600254600855565b6005546001600160a01b031633146109ca5760405162461bcd60e51b8152600401610859906120cc565b600254600a55565b6005546001600160a01b031633146109fc5760405162461bcd60e51b8152600401610859906120cc565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610a705760405162461bcd60e51b8152600401610859906120cc565b6001600160a01b03919091166000908152601660205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610ac55760405162461bcd60e51b8152600401610859906120cc565b600c805461ffff1916610101179055565b6005546001600160a01b03163314610b005760405162461bcd60e51b8152600401610859906120cc565b600c80549115156101000261ff0019909216919091179055565b60606004805461079590612091565b6005546001600160a01b03163314610b535760405162461bcd60e51b8152600401610859906120cc565b7f000000000000000000000000b4c4b4de76add68e0b9bb01217234c5f161394bc6001600160a01b0316826001600160a01b03161415610bfb5760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610859565b6001600160a01b03919091166000908152601860205260409020805460ff1916911515919091179055565b600061082533846108de85604051806060016040528060258152602001612330602591393360009081526001602090815260408083206001600160a01b038d16845290915290205491906116ad565b6000610825338484610fe7565b6005546001600160a01b03163314610cac5760405162461bcd60e51b8152600401610859906120cc565b6001600160a01b03919091166000908152601560205260409020805460ff1916911515919091179055565b6005546000906001600160a01b03163314610d045760405162461bcd60e51b8152600401610859906120cc565b50600b55600190565b60606006805461079590612091565b6005546001600160a01b03163314610d465760405162461bcd60e51b8152600401610859906120cc565b6001600160a01b03919091166000908152601760205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610d9b5760405162461bcd60e51b8152600401610859906120cc565b6001600160a01b038116610e005760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610859565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610e698385612117565b905083811015610ebb5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610859565b9392505050565b6001600160a01b038316610f245760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610859565b6001600160a01b038216610f855760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610859565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661100d5760405162461bcd60e51b81526004016108599061212f565b6001600160a01b0382166110335760405162461bcd60e51b815260040161085990612174565b6001600160a01b03831661dead141561109c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d207468652064456144206164604482015264647265737360d81b6064820152608401610859565b6001600160a01b03821661dead14156111035760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f207468652064456144206164647260448201526265737360e81b6064820152608401610859565b8061111957611114838360006116e7565b505050565b6005546001600160a01b0384811691161480159061114557506005546001600160a01b03838116911614155b801561115a5750600c5462010000900460ff16155b156113e957600c5460ff166111ed576001600160a01b03831660009081526015602052604090205460ff16806111a857506001600160a01b03821660009081526015602052604090205460ff165b6111ed5760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610859565b6001600160a01b03831660009081526018602052604090205460ff16801561122e57506001600160a01b03821660009081526016602052604090205460ff16155b156112a8576008548111156112a35760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610859565b61135f565b6001600160a01b03821660009081526018602052604090205460ff1680156112e957506001600160a01b03831660009081526016602052604090205460ff16155b1561135f5760095481111561135f5760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610859565b6001600160a01b03821660009081526017602052604090205460ff166113e957600a546001600160a01b0383166000908152602081905260409020546113a59083612117565b11156113e95760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610859565b30600090815260208190526040902054600b54811080159081906114145750600c54610100900460ff165b80156114295750600c5462010000900460ff16155b801561144d57506001600160a01b03841660009081526018602052604090205460ff165b801561147257506001600160a01b03851660009081526015602052604090205460ff16155b801561149757506001600160a01b03841660009081526015602052604090205460ff16155b156114c257600c805462ff00001916620100001790556114b56117f0565b600c805462ff0000191690555b600c546001600160a01b03861660009081526015602052604090205460ff6201000090920482161591168061150f57506001600160a01b03851660009081526015602052604090205460ff165b15611518575060005b60008115611699576001600160a01b03861660009081526018602052604090205460ff168015611549575060105415155b156115d35760105461156990606490611563908890611999565b90611a18565b6010546012549192509061157d90836121b7565b61158791906121d6565b601460008282546115989190612117565b90915550506010546011546115ad90836121b7565b6115b791906121d6565b601360008282546115c89190612117565b9091555061167b9050565b6001600160a01b03871660009081526018602052604090205460ff1680156115fc5750600d5415155b1561167b57600d5461161690606490611563908890611999565b600d54600f549192509061162a90836121b7565b61163491906121d6565b601460008282546116459190612117565b9091555050600d54600e5461165a90836121b7565b61166491906121d6565b601360008282546116759190612117565b90915550505b801561168c5761168c8730836116e7565b61169681866121f8565b94505b6116a48787876116e7565b50505050505050565b600081848411156116d15760405162461bcd60e51b81526004016108599190611e21565b5060006116de84866121f8565b95945050505050565b6001600160a01b03831661170d5760405162461bcd60e51b81526004016108599061212f565b6001600160a01b0382166117335760405162461bcd60e51b815260040161085990612174565b611770816040518060600160405280602681526020016122e2602691396001600160a01b03861660009081526020819052604090205491906116ad565b6001600160a01b03808516600090815260208190526040808220939093559084168152205461179f9082610e5c565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610fda565b30600090815260208190526040812054905060006013546014546118149190612117565b90506000821580611823575081155b1561182d57505050565b600b5461183b9060146121b7565b83111561185357600b546118509060146121b7565b92505b60006002836014548661186691906121b7565b61187091906121d6565b61187a91906121d6565b905060006118888583611a5a565b90504761189482611a9c565b60006118a04783611a5a565b905060006118bd876115636013548561199990919063ffffffff16565b905060006118cb82846121f8565b60006014819055601355905085158015906118e65750600081115b15611939576118f58682611c6b565b601454604080518781526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6007546040516001600160a01b03909116904790600081818185875af1925050503d8060008114611986576040519150601f19603f3d011682016040523d82523d6000602084013e61198b565b606091505b505050505050505050505050565b6000826119a857506000610829565b60006119b483856121b7565b9050826119c185836121d6565b14610ebb5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610859565b6000610ebb83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611d5a565b6000610ebb83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506116ad565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611ad157611ad161220f565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015611b4a57600080fd5b505afa158015611b5e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611b829190612225565b81600181518110611b9557611b9561220f565b60200260200101906001600160a01b031690816001600160a01b031681525050611be0307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610ec2565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac94790611c35908590600090869030904290600401612242565b600060405180830381600087803b158015611c4f57600080fd5b505af1158015611c63573d6000803e3d6000fd5b505050505050565b611c96307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610ec2565b60405163f305d71960e01b8152306004820181905260248201849052600060448301819052606483015260848201524260a48201527f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b03169063f305d71990839060c4016060604051808303818588803b158015611d1a57600080fd5b505af1158015611d2e573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190611d5391906122b3565b5050505050565b60008183611d7b5760405162461bcd60e51b81526004016108599190611e21565b5060006116de84866121d6565b828054611d9490612091565b90600052602060002090601f016020900481019282611db65760008555611dfc565b82601f10611dcf57805160ff1916838001178555611dfc565b82800160010185558215611dfc579182015b82811115611dfc578251825591602001919060010190611de1565b50611e08929150611e0c565b5090565b5b80821115611e085760008155600101611e0d565b600060208083528351808285015260005b81811015611e4e57858101830151858201604001528201611e32565b81811115611e60576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114611e8b57600080fd5b50565b60008060408385031215611ea157600080fd5b8235611eac81611e76565b946020939093013593505050565b600060208284031215611ecc57600080fd5b8135610ebb81611e76565b600080600060608486031215611eec57600080fd5b8335611ef781611e76565b92506020840135611f0781611e76565b929592945050506040919091013590565b634e487b7160e01b600052604160045260246000fd5b600060208284031215611f4057600080fd5b813567ffffffffffffffff80821115611f5857600080fd5b818401915084601f830112611f6c57600080fd5b813581811115611f7e57611f7e611f18565b604051601f8201601f19908116603f01168101908382118183101715611fa657611fa6611f18565b81604052828152876020848701011115611fbf57600080fd5b826020860160208301376000928101602001929092525095945050505050565b8035801515811461096957600080fd5b6000806040838503121561200257600080fd5b823561200d81611e76565b915061201b60208401611fdf565b90509250929050565b60006020828403121561203657600080fd5b610ebb82611fdf565b60006020828403121561205157600080fd5b5035919050565b6000806040838503121561206b57600080fd5b823561207681611e76565b9150602083013561208681611e76565b809150509250929050565b600181811c908216806120a557607f821691505b602082108114156120c657634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b6000821982111561212a5761212a612101565b500190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b60008160001904831182151516156121d1576121d1612101565b500290565b6000826121f357634e487b7160e01b600052601260045260246000fd5b500490565b60008282101561220a5761220a612101565b500390565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561223757600080fd5b8151610ebb81611e76565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156122925784516001600160a01b03168352938301939183019160010161226d565b50506001600160a01b03969096166060850152505050608001529392505050565b6000806000606084860312156122c857600080fd5b835192506020840151915060408401519050925092509256fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa264697066735822122078c541fedb1a033317e8d7b32ee44f1a8ade2426507df0cb9f6ba34c974b2c1564736f6c63430008090033

Deployed Bytecode Sourcemap

29129:11872:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7180:99;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;9340:168;;;;;;;;;;-1:-1:-1;9340:168:0;;;;;:::i;:::-;;:::i;:::-;;;1237:14:1;;1230:22;1212:41;;1200:2;1185:18;9340:168:0;1072:187:1;30414:63:0;;;;;;;;;;-1:-1:-1;30414:63:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29209:51;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;1707:32:1;;;1689:51;;1677:2;1662:18;29209:51:0;1516:230:1;29739:20:0;;;;;;;;;;-1:-1:-1;29739:20:0;;;;;;;;;;;8297:107;;;;;;;;;;-1:-1:-1;8384:12:0;;8297:107;;;1897:25:1;;;1885:2;1870:18;8297:107:0;1751:177:1;34935:137:0;;;;;;;;;;-1:-1:-1;34935:137:0;;;;;:::i;:::-;;:::i;:::-;;30260:33;;;;;;;;;;;;;;;;30220;;;;;;;;;;;;;;;;9990:354;;;;;;;;;;-1:-1:-1;9990:354:0;;;;;:::i;:::-;;:::i;8140:92::-;;;;;;;;;;-1:-1:-1;8140:92:0;;8222:2;2536:36:1;;2524:2;2509:18;8140:92:0;2394:184:1;10753:217:0;;;;;;;;;;-1:-1:-1;10753:217:0;;;;;:::i;:::-;;:::i;29267:38::-;;;;;;;;;;;;;;;35080:125;;;;;;;;;;-1:-1:-1;35080:125:0;;;;;:::i;:::-;-1:-1:-1;;;;;35169:28:0;35145:4;35169:28;;;:19;:28;;;;;;;;;35080:125;33128:180;;;;;;;;;;-1:-1:-1;33128:180:0;;;;;:::i;:::-;;:::i;33760:102::-;;;;;;;;;;;;;:::i;33925:91::-;;;;;;;;;;;;;:::i;29701:31::-;;;;;;;;;;-1:-1:-1;29701:31:0;;;;;;;;;;;8467:126;;;;;;;;;;-1:-1:-1;8467:126:0;;;;;:::i;:::-;-1:-1:-1;;;;;8567:18:0;8540:7;8567:18;;;;;;;;;;;;8467:126;21625:148;;;;;;;;;;;;;:::i;34535:144::-;;;;;;;;;;-1:-1:-1;34535:144:0;;;;;:::i;:::-;;:::i;33362:112::-;;;;;;;;;;;;;:::i;20984:78::-;;;;;;;;;;-1:-1:-1;21048:6:0;;-1:-1:-1;;;;;21048:6:0;20984:78;;34136:101;;;;;;;;;;-1:-1:-1;34136:101:0;;;;;:::i;:::-;;:::i;7398:103::-;;;;;;;;;;;;;:::i;30484:58::-;;;;;;;;;;-1:-1:-1;30484:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;34687:240;;;;;;;;;;-1:-1:-1;34687:240:0;;;;;:::i;:::-;;:::i;11473:268::-;;;;;;;;;;-1:-1:-1;11473:268:0;;;;;:::i;:::-;;:::i;8806:174::-;;;;;;;;;;-1:-1:-1;8806:174:0;;;;;:::i;:::-;;:::i;30700:57::-;;;;;;;;;;-1:-1:-1;30700:57:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;34245:132;;;;;;;;;;-1:-1:-1;34245:132:0;;;;;:::i;:::-;;:::i;30001:206::-;;;;;;;;;;-1:-1:-1;30001:206:0;;;;;;;;;;;;;;;;;;;;;;;;;4807:25:1;;;4863:2;4848:18;;4841:34;;;;4891:18;;;4884:34;;;;4949:2;4934:18;;4927:34;4992:3;4977:19;;4970:35;5036:3;5021:19;;5014:35;4794:3;4779:19;30001:206:0;4520:535:1;33544:156:0;;;;;;;;;;-1:-1:-1;33544:156:0;;;;;:::i;:::-;;:::i;33013:107::-;;;;;;;;;;;;;:::i;9043:150::-;;;;;;;;;;-1:-1:-1;9043:150:0;;;;;:::i;:::-;-1:-1:-1;;;;;9158:18:0;;;9131:7;9158:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9043:150;34383:146;;;;;;;;;;-1:-1:-1;34383:146:0;;;;;:::i;:::-;;:::i;21928:244::-;;;;;;;;;;-1:-1:-1;21928:244:0;;;;;:::i;:::-;;:::i;7180:99::-;7233:13;7266:5;7259:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7180:99;:::o;9340:168::-;9422:4;9439:39;321:10;9462:7;9471:6;9439:8;:39::i;:::-;-1:-1:-1;9496:4:0;9340:168;;;;;:::o;34935:137::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;;;;;;;;;35028:15:::1;:36:::0;;-1:-1:-1;;;;;;35028:36:0::1;-1:-1:-1::0;;;;;35028:36:0;;;::::1;::::0;;;::::1;::::0;;34935:137::o;9990:354::-;10129:4;10146:36;10156:6;10164:9;10175:6;10146:9;:36::i;:::-;10193:121;10202:6;321:10;10224:89;10262:6;10224:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10224:19:0;;;;;;:11;:19;;;;;;;;321:10;10224:33;;;;;;;;;;:37;:89::i;:::-;10193:8;:121::i;:::-;-1:-1:-1;10332:4:0;9990:354;;;;;:::o;10753:217::-;321:10;10840:4;10889:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;10889:34:0;;;;;;;;;;10840:4;;10857:83;;10880:7;;10889:50;;10928:10;10889:38;:50::i;33128:180::-;21195:6;;33217:4;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;33233:45;;::::1;::::0;:19:::1;::::0;:45:::1;::::0;::::1;::::0;::::1;:::i;:::-;;33296:4;33289:11;;21265:1;33128:180:::0;;;:::o;33760:102::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;8384:12;;33815:23:::1;:39:::0;33760:102::o;33925:91::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;8384:12;;33983:9:::1;:25:::0;33925:91::o;21625:148::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;21716:6:::1;::::0;21695:40:::1;::::0;21732:1:::1;::::0;-1:-1:-1;;;;;21716:6:0::1;::::0;21695:40:::1;::::0;21732:1;;21695:40:::1;21746:6;:19:::0;;-1:-1:-1;;;;;;21746:19:0::1;::::0;;21625:148::o;34535:144::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34625:39:0;;;::::1;;::::0;;;:31:::1;:39;::::0;;;;:46;;-1:-1:-1;;34625:46:0::1;::::0;::::1;;::::0;;;::::1;::::0;;34535:144::o;33362:112::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;33417:13:::1;:20:::0;;-1:-1:-1;;33448:18:0;;;;;33362:112::o;34136:101::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;34208:11:::1;:21:::0;;;::::1;;;;-1:-1:-1::0;;34208:21:0;;::::1;::::0;;;::::1;::::0;;34136:101::o;7398:103::-;7453:13;7486:7;7479:14;;;;;:::i;34687:240::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;34794:13:::1;-1:-1:-1::0;;;;;34786:21:0::1;:4;-1:-1:-1::0;;;;;34786:21:0::1;;;34778:91;;;::::0;-1:-1:-1;;;34778:91:0;;6586:2:1;34778:91:0::1;::::0;::::1;6568:21:1::0;6625:2;6605:18;;;6598:30;6664:34;6644:18;;;6637:62;6735:27;6715:18;;;6708:55;6780:19;;34778:91:0::1;6384:421:1::0;34778:91:0::1;-1:-1:-1::0;;;;;34880:31:0;;;::::1;;::::0;;;:25:::1;:31;::::0;;;;:39;;-1:-1:-1;;34880:39:0::1;::::0;::::1;;::::0;;;::::1;::::0;;34687:240::o;11473:268::-;11565:4;11582:129;321:10;11605:7;11614:96;11653:15;11614:96;;;;;;;;;;;;;;;;;321:10;11614:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11614:34:0;;;;;;;;;;;;:38;:96::i;8806:174::-;8891:4;8908:42;321:10;8932:9;8943:6;8908:9;:42::i;34245:132::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34330:28:0;;;::::1;;::::0;;;:19:::1;:28;::::0;;;;:39;;-1:-1:-1;;34330:39:0::1;::::0;::::1;;::::0;;;::::1;::::0;;34245:132::o;33544:156::-;21195:6;;33624:4;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;-1:-1:-1;33640:18:0::1;:30:::0;33688:4:::1;::::0;33544:156::o;33013:107::-;33060:13;33093:19;33086:26;;;;;:::i;34383:146::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34475:35:0;;;::::1;;::::0;;;:26:::1;:35;::::0;;;;:46;;-1:-1:-1;;34475:46:0::1;::::0;::::1;;::::0;;;::::1;::::0;;34383:146::o;21928:244::-;21195:6;;-1:-1:-1;;;;;21195:6:0;321:10;21195:22;21187:67;;;;-1:-1:-1;;;21187:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22017:22:0;::::1;22009:73;;;::::0;-1:-1:-1;;;22009:73:0;;7012:2:1;22009:73:0::1;::::0;::::1;6994:21:1::0;7051:2;7031:18;;;7024:30;7090:34;7070:18;;;7063:62;-1:-1:-1;;;7141:18:1;;;7134:36;7187:19;;22009:73:0::1;6810:402:1::0;22009:73:0::1;22119:6;::::0;22098:38:::1;::::0;-1:-1:-1;;;;;22098:38:0;;::::1;::::0;22119:6:::1;::::0;22098:38:::1;::::0;22119:6:::1;::::0;22098:38:::1;22147:6;:17:::0;;-1:-1:-1;;;;;;22147:17:0::1;-1:-1:-1::0;;;;;22147:17:0;;;::::1;::::0;;;::::1;::::0;;21928:244::o;16038:180::-;16095:7;;16127:5;16131:1;16127;:5;:::i;:::-;16115:17;;16156:1;16151;:6;;16143:46;;;;-1:-1:-1;;;16143:46:0;;7684:2:1;16143:46:0;;;7666:21:1;7723:2;7703:18;;;7696:30;7762:29;7742:18;;;7735:57;7809:18;;16143:46:0;7482:351:1;16143:46:0;16209:1;16038:180;-1:-1:-1;;;16038:180:0:o;14658:380::-;-1:-1:-1;;;;;14794:19:0;;14786:68;;;;-1:-1:-1;;;14786:68:0;;8040:2:1;14786:68:0;;;8022:21:1;8079:2;8059:18;;;8052:30;8118:34;8098:18;;;8091:62;-1:-1:-1;;;8169:18:1;;;8162:34;8213:19;;14786:68:0;7838:400:1;14786:68:0;-1:-1:-1;;;;;14873:21:0;;14865:68;;;;-1:-1:-1;;;14865:68:0;;8445:2:1;14865:68:0;;;8427:21:1;8484:2;8464:18;;;8457:30;8523:34;8503:18;;;8496:62;-1:-1:-1;;;8574:18:1;;;8567:32;8616:19;;14865:68:0;8243:398:1;14865:68:0;-1:-1:-1;;;;;14946:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;14998:32;;1897:25:1;;;14998:32:0;;1870:18:1;14998:32:0;;;;;;;;14658:380;;;:::o;35213:3277::-;-1:-1:-1;;;;;35345:18:0;;35337:68;;;;-1:-1:-1;;;35337:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35424:16:0;;35416:64;;;;-1:-1:-1;;;35416:64:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35499:23:0;;35515:6;35499:23;;35491:73;;;;-1:-1:-1;;;35491:73:0;;9658:2:1;35491:73:0;;;9640:21:1;9697:2;9677:18;;;9670:30;9736:34;9716:18;;;9709:62;-1:-1:-1;;;9787:18:1;;;9780:35;9832:19;;35491:73:0;9456:401:1;35491:73:0;-1:-1:-1;;;;;35583:21:0;;35597:6;35583:21;;35575:69;;;;-1:-1:-1;;;35575:69:0;;10064:2:1;35575:69:0;;;10046:21:1;10103:2;10083:18;;;10076:30;10142:34;10122:18;;;10115:62;-1:-1:-1;;;10193:18:1;;;10186:33;10236:19;;35575:69:0;9862:399:1;35575:69:0;35669:11;35665:93;;35697:28;35713:4;35719:2;35723:1;35697:15;:28::i;:::-;35213:3277;;;:::o;35665:93::-;21048:6;;-1:-1:-1;;;;;35788:15:0;;;21048:6;;35788:15;;;;:45;;-1:-1:-1;21048:6:0;;-1:-1:-1;;;;;35820:13:0;;;21048:6;;35820:13;;35788:45;:71;;;;-1:-1:-1;35851:8:0;;;;;;;35850:9;35788:71;35770:932;;;35891:13;;;;35886:142;;-1:-1:-1;;;;;35933:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;35962:23:0;;;;;;:19;:23;;;;;;;;35933:52;35925:87;;;;-1:-1:-1;;;35925:87:0;;10468:2:1;35925:87:0;;;10450:21:1;10507:2;10487:18;;;10480:30;-1:-1:-1;;;10526:18:1;;;10519:52;10588:18;;35925:87:0;10266:346:1;35925:87:0;-1:-1:-1;;;;;36072:31:0;;;;;;:25;:31;;;;;;;;:71;;;;-1:-1:-1;;;;;;36108:35:0;;;;;;:31;:35;;;;;;;;36107:36;36072:71;36068:470;;;36182:23;;36172:6;:33;;36164:99;;;;-1:-1:-1;;;36164:99:0;;10819:2:1;36164:99:0;;;10801:21:1;10858:2;10838:18;;;10831:30;10897:34;10877:18;;;10870:62;-1:-1:-1;;;10948:18:1;;;10941:51;11009:19;;36164:99:0;10617:417:1;36164:99:0;36068:470;;;-1:-1:-1;;;;;36329:29:0;;;;;;:25;:29;;;;;;;;:71;;;;-1:-1:-1;;;;;;36363:37:0;;;;;;:31;:37;;;;;;;;36362:38;36329:71;36325:213;;;36439:24;;36429:6;:34;;36421:101;;;;-1:-1:-1;;;36421:101:0;;11241:2:1;36421:101:0;;;11223:21:1;11280:2;11260:18;;;11253:30;11319:34;11299:18;;;11292:62;-1:-1:-1;;;11370:18:1;;;11363:52;11432:19;;36421:101:0;11039:418:1;36421:101:0;-1:-1:-1;;;;;36557:30:0;;;;;;:26;:30;;;;;;;;36552:139;;36642:9;;-1:-1:-1;;;;;8567:18:0;;8540:7;8567:18;;;;;;;;;;;36616:22;;:6;:22;:::i;:::-;:35;;36608:67;;;;-1:-1:-1;;;36608:67:0;;11664:2:1;36608:67:0;;;11646:21:1;11703:2;11683:18;;;11676:30;-1:-1:-1;;;11722:18:1;;;11715:49;11781:18;;36608:67:0;11462:343:1;36608:67:0;36764:4;36715:28;8567:18;;;;;;;;;;;36823;;36799:42;;;;;;;36872:35;;-1:-1:-1;36896:11:0;;;;;;;36872:35;:61;;;;-1:-1:-1;36925:8:0;;;;;;;36924:9;36872:61;:107;;;;-1:-1:-1;;;;;;36950:29:0;;;;;;:25;:29;;;;;;;;36872:107;:150;;;;-1:-1:-1;;;;;;36997:25:0;;;;;;:19;:25;;;;;;;;36996:26;36872:150;:191;;;;-1:-1:-1;;;;;;37040:23:0;;;;;;:19;:23;;;;;;;;37039:24;36872:191;36854:323;;;37090:8;:15;;-1:-1:-1;;37090:15:0;;;;;37122:10;:8;:10::i;:::-;37149:8;:16;;-1:-1:-1;;37149:16:0;;;36854:323;37206:8;;-1:-1:-1;;;;;37316:25:0;;37190:12;37316:25;;;:19;:25;;;;;;37206:8;;;;;;;37205:9;;37316:25;;:52;;-1:-1:-1;;;;;;37345:23:0;;;;;;:19;:23;;;;;;;;37316:52;37312:100;;;-1:-1:-1;37395:5:0;37312:100;37425:12;37530:7;37526:911;;;-1:-1:-1;;;;;37596:29:0;;;;;;:25;:29;;;;;;;;:56;;;;-1:-1:-1;37629:19:0;;:23;;37596:56;37592:694;;;37691:19;;37680:40;;37716:3;;37680:31;;:6;;:10;:31::i;:::-;:35;;:40::i;:::-;37793:19;;37768:22;;37673:47;;-1:-1:-1;37793:19:0;37761:29;;37673:47;37761:29;:::i;:::-;:51;;;;:::i;:::-;37739:18;;:73;;;;;;;:::i;:::-;;;;-1:-1:-1;;37885:19:0;;37860:22;;37853:29;;:4;:29;:::i;:::-;:51;;;;:::i;:::-;37831:18;;:73;;;;;;;:::i;:::-;;;;-1:-1:-1;37592:694:0;;-1:-1:-1;37592:694:0;;-1:-1:-1;;;;;37966:31:0;;;;;;:25;:31;;;;;;;;:57;;;;-1:-1:-1;38001:5:0;:18;:22;;37966:57;37962:324;;;38062:5;:18;38051:39;;38086:3;;38051:30;;:6;;:10;:30::i;:39::-;38162:5;:18;38138:21;;38044:46;;-1:-1:-1;38162:18:0;38131:28;;38044:46;38131:28;:::i;:::-;:49;;;;:::i;:::-;38109:18;;:71;;;;;;;:::i;:::-;;;;-1:-1:-1;;38252:5:0;:18;38228:21;;38221:28;;:4;:28;:::i;:::-;:49;;;;:::i;:::-;38199:18;;:71;;;;;;;:::i;:::-;;;;-1:-1:-1;;37962:324:0;38306:8;;38302:91;;38335:42;38351:4;38365;38372;38335:15;:42::i;:::-;38409:14;38419:4;38409:14;;:::i;:::-;;;37526:911;38449:33;38465:4;38471:2;38475:6;38449:15;:33::i;:::-;35326:3164;;;;35213:3277;;;:::o;16939:191::-;17024:7;17060:12;17052:6;;;;17044:29;;;;-1:-1:-1;;;17044:29:0;;;;;;;;:::i;:::-;-1:-1:-1;17084:9:0;17096:5;17100:1;17096;:5;:::i;:::-;17084:17;16939:191;-1:-1:-1;;;;;16939:191:0:o;12231:573::-;-1:-1:-1;;;;;12371:20:0;;12363:70;;;;-1:-1:-1;;;12363:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12452:23:0;;12444:71;;;;-1:-1:-1;;;12444:71:0;;;;;;;:::i;:::-;12608;12630:6;12608:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;12608:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;12588:17:0;;;:9;:17;;;;;;;;;;;:91;;;;12713:20;;;;;;;:32;;12738:6;12713:24;:32::i;:::-;-1:-1:-1;;;;;12690:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;12761:35;1897:25:1;;;12690:20:0;;12761:35;;;;;;1870:18:1;12761:35:0;1751:177:1;39629:1367:0;39712:4;39668:23;8567:18;;;;;;;;;;;39668:50;;39729:25;39778:18;;39757;;:39;;;;:::i;:::-;39729:67;-1:-1:-1;39808:12:0;39837:20;;;:46;;-1:-1:-1;39861:22:0;;39837:46;39833:63;;;39887:7;;;39629:1367::o;39833:63::-;39930:18;;:23;;39951:2;39930:23;:::i;:::-;39912:15;:41;39908:115;;;39988:18;;:23;;40009:2;39988:23;:::i;:::-;39970:41;;39908:115;40084:23;40169:1;40149:17;40128:18;;40110:15;:36;;;;:::i;:::-;:56;;;;:::i;:::-;:60;;;;:::i;:::-;40084:86;-1:-1:-1;40181:26:0;40210:36;:15;40084:86;40210:19;:36::i;:::-;40181:65;-1:-1:-1;40288:21:0;40322:36;40181:65;40322:16;:36::i;:::-;40373:18;40394:44;:21;40420:17;40394:25;:44::i;:::-;40373:65;;40452:23;40478:57;40517:17;40478:34;40493:18;;40478:10;:14;;:34;;;;:::i;:57::-;40452:83;-1:-1:-1;40546:23:0;40572:28;40452:83;40572:10;:28;:::i;:::-;40636:1;40615:18;:22;;;40648:18;:22;40546:54;-1:-1:-1;40689:19:0;;;;;:42;;;40730:1;40712:15;:19;40689:42;40685:212;;;40748:46;40761:15;40778;40748:12;:46::i;:::-;40866:18;;40814:71;;;12537:25:1;;;12593:2;12578:18;;12571:34;;;12621:18;;;12614:34;;;;40814:71:0;;;;;;12525:2:1;40814:71:0;;;40685:212;40930:15;;40922:66;;-1:-1:-1;;;;;40930:15:0;;;;40960:21;;40922:66;;;;40960:21;40930:15;40922:66;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;;39629:1367:0:o;17389:471::-;17446:7;17691:6;17687:47;;-1:-1:-1;17721:1:0;17714:8;;17687:47;17747:9;17759:5;17763:1;17759;:5;:::i;:::-;17747:17;-1:-1:-1;17792:1:0;17783:5;17787:1;17747:17;17783:5;:::i;:::-;:10;17775:56;;;;-1:-1:-1;;;17775:56:0;;13071:2:1;17775:56:0;;;13053:21:1;13110:2;13090:18;;;13083:30;13149:34;13129:18;;;13122:62;-1:-1:-1;;;13200:18:1;;;13193:31;13241:19;;17775:56:0;12869:397:1;18336:131:0;18393:7;18420:39;18424:1;18427;18420:39;;;;;;;;;;;;;;;;;:3;:39::i;16501:135::-;16558:7;16585:43;16589:1;16592;16585:43;;;;;;;;;;;;;;;;;:3;:43::i;38498:593::-;38650:16;;;38664:1;38650:16;;;;;;;;38626:21;;38650:16;;;;;;;;;;-1:-1:-1;38650:16:0;38626:40;;38695:4;38677;38682:1;38677:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;38677:23:0;;;-1:-1:-1;;;;;38677:23:0;;;;;38721:15;-1:-1:-1;;;;;38721:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;38711:4;38716:1;38711:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;38711:32:0;;;-1:-1:-1;;;;;38711:32:0;;;;;38756:62;38773:4;38788:15;38806:11;38756:8;:62::i;:::-;38857:224;;-1:-1:-1;;;38857:224:0;;-1:-1:-1;;;;;38857:15:0;:66;;;;:224;;38938:11;;38964:1;;39008:4;;39035;;39055:15;;38857:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;38553:538;38498:593;:::o;39099:522::-;39247:62;39264:4;39279:15;39297:11;39247:8;:62::i;:::-;39352:261;;-1:-1:-1;;;39352:261:0;;39427:4;39352:261;;;14985:34:1;;;15035:18;;;15028:34;;;39473:1:0;15078:18:1;;;15071:34;;;15121:18;;;15114:34;15164:19;;;15157:44;39587:15:0;15217:19:1;;;15210:35;39352:15:0;-1:-1:-1;;;;;39352:31:0;;;;39392:9;;14919:19:1;;39352:261:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;39099:522;;:::o;18963:277::-;19048:7;19083:12;19076:5;19068:28;;;;-1:-1:-1;;;19068:28:0;;;;;;;;:::i;:::-;-1:-1:-1;19107:9:0;19119:5;19123:1;19119;:5;:::i;-1:-1:-1:-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;;;;;;;;;14:597:1;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;452:6;449:1;446:13;443:91;;;522:1;517:2;508:6;497:9;493:22;489:31;482:42;443:91;-1:-1:-1;595:2:1;574:15;-1:-1:-1;;570:29:1;555:45;;;;602:2;551:54;;14:597;-1:-1:-1;;;14:597:1:o;616:131::-;-1:-1:-1;;;;;691:31:1;;681:42;;671:70;;737:1;734;727:12;671:70;616:131;:::o;752:315::-;820:6;828;881:2;869:9;860:7;856:23;852:32;849:52;;;897:1;894;887:12;849:52;936:9;923:23;955:31;980:5;955:31;:::i;:::-;1005:5;1057:2;1042:18;;;;1029:32;;-1:-1:-1;;;752:315:1:o;1264:247::-;1323:6;1376:2;1364:9;1355:7;1351:23;1347:32;1344:52;;;1392:1;1389;1382:12;1344:52;1431:9;1418:23;1450:31;1475:5;1450:31;:::i;1933:456::-;2010:6;2018;2026;2079:2;2067:9;2058:7;2054:23;2050:32;2047:52;;;2095:1;2092;2085:12;2047:52;2134:9;2121:23;2153:31;2178:5;2153:31;:::i;:::-;2203:5;-1:-1:-1;2260:2:1;2245:18;;2232:32;2273:33;2232:32;2273:33;:::i;:::-;1933:456;;2325:7;;-1:-1:-1;;;2379:2:1;2364:18;;;;2351:32;;1933:456::o;2791:127::-;2852:10;2847:3;2843:20;2840:1;2833:31;2883:4;2880:1;2873:15;2907:4;2904:1;2897:15;2923:922;2992:6;3045:2;3033:9;3024:7;3020:23;3016:32;3013:52;;;3061:1;3058;3051:12;3013:52;3101:9;3088:23;3130:18;3171:2;3163:6;3160:14;3157:34;;;3187:1;3184;3177:12;3157:34;3225:6;3214:9;3210:22;3200:32;;3270:7;3263:4;3259:2;3255:13;3251:27;3241:55;;3292:1;3289;3282:12;3241:55;3328:2;3315:16;3350:2;3346;3343:10;3340:36;;;3356:18;;:::i;:::-;3431:2;3425:9;3399:2;3485:13;;-1:-1:-1;;3481:22:1;;;3505:2;3477:31;3473:40;3461:53;;;3529:18;;;3549:22;;;3526:46;3523:72;;;3575:18;;:::i;:::-;3615:10;3611:2;3604:22;3650:2;3642:6;3635:18;3690:7;3685:2;3680;3676;3672:11;3668:20;3665:33;3662:53;;;3711:1;3708;3701:12;3662:53;3767:2;3762;3758;3754:11;3749:2;3741:6;3737:15;3724:46;3812:1;3790:15;;;3807:2;3786:24;3779:35;;;;-1:-1:-1;3794:6:1;2923:922;-1:-1:-1;;;;;2923:922:1:o;3850:160::-;3915:20;;3971:13;;3964:21;3954:32;;3944:60;;4000:1;3997;3990:12;4015:315;4080:6;4088;4141:2;4129:9;4120:7;4116:23;4112:32;4109:52;;;4157:1;4154;4147:12;4109:52;4196:9;4183:23;4215:31;4240:5;4215:31;:::i;:::-;4265:5;-1:-1:-1;4289:35:1;4320:2;4305:18;;4289:35;:::i;:::-;4279:45;;4015:315;;;;;:::o;4335:180::-;4391:6;4444:2;4432:9;4423:7;4419:23;4415:32;4412:52;;;4460:1;4457;4450:12;4412:52;4483:26;4499:9;4483:26;:::i;5060:180::-;5119:6;5172:2;5160:9;5151:7;5147:23;5143:32;5140:52;;;5188:1;5185;5178:12;5140:52;-1:-1:-1;5211:23:1;;5060:180;-1:-1:-1;5060:180:1:o;5245:388::-;5313:6;5321;5374:2;5362:9;5353:7;5349:23;5345:32;5342:52;;;5390:1;5387;5380:12;5342:52;5429:9;5416:23;5448:31;5473:5;5448:31;:::i;:::-;5498:5;-1:-1:-1;5555:2:1;5540:18;;5527:32;5568:33;5527:32;5568:33;:::i;:::-;5620:7;5610:17;;;5245:388;;;;;:::o;5638:380::-;5717:1;5713:12;;;;5760;;;5781:61;;5835:4;5827:6;5823:17;5813:27;;5781:61;5888:2;5880:6;5877:14;5857:18;5854:38;5851:161;;;5934:10;5929:3;5925:20;5922:1;5915:31;5969:4;5966:1;5959:15;5997:4;5994:1;5987:15;5851:161;;5638:380;;;:::o;6023:356::-;6225:2;6207:21;;;6244:18;;;6237:30;6303:34;6298:2;6283:18;;6276:62;6370:2;6355:18;;6023:356::o;7217:127::-;7278:10;7273:3;7269:20;7266:1;7259:31;7309:4;7306:1;7299:15;7333:4;7330:1;7323:15;7349:128;7389:3;7420:1;7416:6;7413:1;7410:13;7407:39;;;7426:18;;:::i;:::-;-1:-1:-1;7462:9:1;;7349:128::o;8646:401::-;8848:2;8830:21;;;8887:2;8867:18;;;8860:30;8926:34;8921:2;8906:18;;8899:62;-1:-1:-1;;;8992:2:1;8977:18;;8970:35;9037:3;9022:19;;8646:401::o;9052:399::-;9254:2;9236:21;;;9293:2;9273:18;;;9266:30;9332:34;9327:2;9312:18;;9305:62;-1:-1:-1;;;9398:2:1;9383:18;;9376:33;9441:3;9426:19;;9052:399::o;11810:168::-;11850:7;11916:1;11912;11908:6;11904:14;11901:1;11898:21;11893:1;11886:9;11879:17;11875:45;11872:71;;;11923:18;;:::i;:::-;-1:-1:-1;11963:9:1;;11810:168::o;11983:217::-;12023:1;12049;12039:132;;12093:10;12088:3;12084:20;12081:1;12074:31;12128:4;12125:1;12118:15;12156:4;12153:1;12146:15;12039:132;-1:-1:-1;12185:9:1;;11983:217::o;12205:125::-;12245:4;12273:1;12270;12267:8;12264:34;;;12278:18;;:::i;:::-;-1:-1:-1;12315:9:1;;12205:125::o;13271:127::-;13332:10;13327:3;13323:20;13320:1;13313:31;13363:4;13360:1;13353:15;13387:4;13384:1;13377:15;13403:251;13473:6;13526:2;13514:9;13505:7;13501:23;13497:32;13494:52;;;13542:1;13539;13532:12;13494:52;13574:9;13568:16;13593:31;13618:5;13593:31;:::i;13659:980::-;13921:4;13969:3;13958:9;13954:19;14000:6;13989:9;13982:25;14026:2;14064:6;14059:2;14048:9;14044:18;14037:34;14107:3;14102:2;14091:9;14087:18;14080:31;14131:6;14166;14160:13;14197:6;14189;14182:22;14235:3;14224:9;14220:19;14213:26;;14274:2;14266:6;14262:15;14248:29;;14295:1;14305:195;14319:6;14316:1;14313:13;14305:195;;;14384:13;;-1:-1:-1;;;;;14380:39:1;14368:52;;14475:15;;;;14440:12;;;;14416:1;14334:9;14305:195;;;-1:-1:-1;;;;;;;14556:32:1;;;;14551:2;14536:18;;14529:60;-1:-1:-1;;;14620:3:1;14605:19;14598:35;14517:3;13659:980;-1:-1:-1;;;13659:980:1:o;15256:306::-;15344:6;15352;15360;15413:2;15401:9;15392:7;15388:23;15384:32;15381:52;;;15429:1;15426;15419:12;15381:52;15458:9;15452:16;15442:26;;15508:2;15497:9;15493:18;15487:25;15477:35;;15552:2;15541:9;15537:18;15531:25;15521:35;;15256:306;;;;;:::o

Swarm Source

ipfs://78c541fedb1a033317e8d7b32ee44f1a8ade2426507df0cb9f6ba34c974b2c15
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.