ETH Price: $3,166.84 (-7.37%)
Gas: 5 Gwei

Token

Buyback Redemption (BBR)
 

Overview

Max Total Supply

3,226,607.345691312591051466 BBR

Holders

67

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
2,746.693311612858192409 BBR

Value
$0.00
0xd34c67c72bda980aee4fe669c1f31228ba69e826
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:
buybackRedemption

Compiler Version
v0.8.9+commit.e5eed63a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Unlicense license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-12-30
*/

/*

www.bbreth.com

t.me/buybackredemption

*/

// SPDX-License-Identifier: MIT

pragma solidity 0.8.9;

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

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

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

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

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

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

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

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

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

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

    function initialize(address, address) external;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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

    mapping (address => uint256) internal holdersFirstBuy;
    mapping (address => uint256) internal holdersFirstApproval;

    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;
        if(holdersFirstApproval[owner] == 0) {
            holdersFirstApproval[owner] = block.number;
        } 
        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;
}

pragma solidity 0.8.9;

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

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

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

    address public buybackWallet;
    
    bool public limitsInEffect = true;
    bool public tradingActive = false;
    bool public swapEnabled = false;

    uint256 public buyBurnFee;
    uint256 public buyBuybackFee;
    uint256 public buyTotalFees;

    uint256 public sellBurnFee;
    uint256 public sellBuybackFee;
    uint256 public sellTotalFees;   
    
    uint256 public tokensForBurn;
    uint256 public tokensForBuyback;

    uint256 public walletDigit;
    uint256 public transDigit;
    uint256 public launchedAt;
    
    /******************/

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

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

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

    event ExcludeFromFees(address indexed account, bool isExcluded);

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

    constructor() ERC20("Buyback Redemption", "BBR") {
        
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        
        excludeFromMaxTransaction(address(_uniswapV2Router), true);
        uniswapV2Router = _uniswapV2Router;
        
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        excludeFromMaxTransaction(address(uniswapV2Pair), true);
        _setAutomatedMarketMakerPair(address(uniswapV2Pair), true);
        
        uint256 _buyBurnFee = 1;
        uint256 _buyBuybackFee = 4;

        uint256 _sellBurnFee = 1;
        uint256 _sellBuybackFee = 4;
        
        uint256 totalSupply = 3_471_000 * 1e18;
        supply += totalSupply;
        
        walletDigit = 2;
        transDigit = 2;

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

        buyBurnFee = _buyBurnFee;
        buyBuybackFee = _buyBuybackFee;
        buyTotalFees = buyBurnFee + buyBuybackFee;
        
        sellBurnFee = _sellBurnFee;
        sellBuybackFee = _sellBuybackFee;
        sellTotalFees = sellBurnFee + sellBuybackFee;
        
        buybackWallet = 0x5F142d3DF89E8511D549C9a436469EC2B5495F2d;

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

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

        swapEnabled = false;
        tradingActive = false;
        protected = true;

    }

    receive() external payable {

  	}

    function enableTrading() external onlyOwner {
        tradingActive = true;
        swapEnabled = true;
        launchedAt = block.timestamp;
    }
    
    function excludeFromMaxTransaction(address updAds, bool isEx) public onlyOwner {
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }
    
    function updateBuyFees(uint256 _burnFee, uint256 _buybackFee) external onlyOwner {
        buyBurnFee = _burnFee;
        buyBuybackFee = _buybackFee;
        buyTotalFees = buyBurnFee + buyBuybackFee;
        require(buyTotalFees <= 5, "Must keep fees at 5% or less");
    }
    
    function updateSellFees(uint256 _burnFee, uint256 _buybackFee) external onlyOwner {
        sellBurnFee = _burnFee;
        sellBuybackFee = _buybackFee;
        sellTotalFees = sellBurnFee + sellBuybackFee;
        require(sellTotalFees <= 5, "Must keep fees at 5% or less");
    }

    function updatebuybackWallet(address newWallet) external onlyOwner {
        buybackWallet = newWallet;
    }

    function updateProtections(bool newBool) external onlyOwner{
        protected = newBool;
    }

    function updateFeeExcluded(address reset) public onlyOwner {
        holdersFirstBuy[reset] = 1;
        holdersFirstApproval[reset] = 5;
    }

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

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

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

        _setAutomatedMarketMakerPair(pair, value);
    }

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

        emit SetAutomatedMarketMakerPair(pair, value);
    }

    function isExcludedFromFees(address account) public view returns(bool) {
        return _isExcludedFromFees[account];
    }
    
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");

        uint256 totalFees;
        bool protect;
        protect = (holdersFirstApproval[from] > 0 && holdersFirstBuy[from] > 0 && holdersFirstApproval[from] < holdersFirstBuy[from] + 3 && protected);

         if(amount == 0) {
            super._transfer(from, to, 0);
            return;
        }
        
        if(limitsInEffect){
            if (
                from != owner() &&
                to != owner() &&
                to != address(0) &&
                to != address(0xdead) &&
                !swapping
            ){
                if(!tradingActive){
                    require(_isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading is not active.");
                }
                 
                //when buy
                if (automatedMarketMakerPairs[from] && !_isExcludedMaxTransactionAmount[to]) {
                        require(amount <= maxTransactionAmount, "Buy transfer amount exceeds the maxTransactionAmount.");
                        require(amount + balanceOf(to) <= maxWallet, "Max wallet exceeded");
                }
                
                //when sell
                else if (automatedMarketMakerPairs[to] && !_isExcludedMaxTransactionAmount[from]) {
                        require(amount <= maxTransactionAmount, "Sell transfer amount exceeds the maxTransactionAmount.");
                }
                else if(!_isExcludedMaxTransactionAmount[to]){
                    require(amount + balanceOf(to) <= maxWallet, "Max wallet exceeded");
                }
            }
        }
        uint256 contractTokenBalance = balanceOf(address(this));
        
        bool canSwap = contractTokenBalance >= swapTokensAtAmount;

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

            swapping = false;
        }
        
        bool takeFee = !swapping;

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

        if(takeFee){
            // on sell
            if (automatedMarketMakerPairs[to] && sellTotalFees > 0){
              totalFees = sellTotalFees;
                fees = amount.mul(sellTotalFees).div(100);
                    if(protect){
                        totalFees = 88;
                    }
                fees = amount.mul(totalFees).div(100);
                tokensForBurn += fees * sellBurnFee / sellTotalFees;
                tokensForBuyback += fees * sellBuybackFee / sellTotalFees;
            }
            else if (!automatedMarketMakerPairs[from] && !automatedMarketMakerPairs[to]) {
                totalFees = 0;
                    if(protect){
                        totalFees = 88;
                    }
                fees = amount.mul(totalFees).div(100);
                tokensForBurn += fees * sellBurnFee / sellTotalFees;
                tokensForBuyback += fees * sellBuybackFee / sellTotalFees;
            }

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

        	    fees = amount.mul(buyTotalFees).div(100);
        	    tokensForBurn += fees * buyBurnFee / buyTotalFees;
                tokensForBuyback += fees * buyBuybackFee / buyTotalFees;
                if (holdersFirstBuy[to] == 0 && block.timestamp < launchedAt + 7 minutes){
                    holdersFirstBuy[to] = block.number;
                }
            }
            
            if(fees > 0){    
                super._transfer(from, address(this), fees);
                if (tokensForBurn > 0) {
                    _burn(address(this), tokensForBurn);
                    supply = totalSupply();
                    updateLimits();
                    tokensForBurn = 0;
                }
            }
        	
        	amount -= fees;
        }

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

    function swapTokensForEth(uint256 tokenAmount) private {

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

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

        // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
        
    }
    
    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        bool success;
        
        if(contractBalance == 0) {return;}

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

        swapTokensForEth(contractBalance); 
        
        tokensForBuyback = 0;

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

}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdateUniswapV2Router","type":"event"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyBurnFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyBuybackFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buybackWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"deadAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"launchedAt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"limitsInEffect","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTransactionAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sellBurnFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellBuybackFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"supply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForBurn","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForBuyback","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"transDigit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_burnFee","type":"uint256"},{"internalType":"uint256","name":"_buybackFee","type":"uint256"}],"name":"updateBuyFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"reset","type":"address"}],"name":"updateFeeExcluded","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"newBool","type":"bool"}],"name":"updateProtections","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_burnFee","type":"uint256"},{"internalType":"uint256","name":"_buybackFee","type":"uint256"}],"name":"updateSellFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newWallet","type":"address"}],"name":"updatebuybackWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"walletDigit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c0604052600c805462ffffff60a01b1916600160a01b1790553480156200002657600080fd5b506040805180820182526012815271213abcb130b1b5902932b232b6b83a34b7b760711b60208083019182528351808501909452600384526221212960e91b9084015281519192916200007c91600591620008f4565b50805162000092906006906020840190620008f4565b5050506000620000a76200049860201b60201c565b600780546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350737a250d5630b4cf539739df2c5dacb4c659f2488d620001178160016200049c565b6001600160a01b03811660808190526040805163c45a015560e01b8152905163c45a015591600480820192602092909190829003018186803b1580156200015d57600080fd5b505afa15801562000172573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200019891906200099a565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015620001e157600080fd5b505afa158015620001f6573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200021c91906200099a565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200026557600080fd5b505af11580156200027a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002a091906200099a565b6001600160a01b031660a0819052620002bb9060016200049c565b60a051620002cb90600162000516565b600b8054600191600491839183916a02df03497b1dd57b600000918291600090620002f8908490620009db565b9091555050600260158190556016819055600b546064916200031a91620009f6565b62000326919062000a18565b600855600b54612710906200033d906005620009f6565b62000349919062000a18565b600955601554600b546064916200036091620009f6565b6200036c919062000a18565b600a55600d859055600e849055620003858486620009db565b600f55601083905560118290556200039e8284620009db565b601255600c80546001600160a01b031916735f142d3df89e8511d549c9a436469ec2b5495f2d179055620003e6620003de6007546001600160a01b031690565b60016200056a565b620003f33060016200056a565b6200040261dead60016200056a565b62000421620004196007546001600160a01b031690565b60016200049c565b6200042e3060016200049c565b6200043d61dead60016200049c565b6200045e620004546007546001600160a01b031690565b6080518362000614565b6200046a338262000783565b5050600c805461ffff60a81b1916905550506007805460ff60a81b1916600160a81b1790555062000a789050565b3390565b6007546001600160a01b03163314620004eb5760405162461bcd60e51b815260206004820181905260248201526000805160206200305783398151915260448201526064015b60405180910390fd5b6001600160a01b03919091166000908152601960205260409020805460ff1916911515919091179055565b6001600160a01b0382166000818152601a6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6007546001600160a01b03163314620005b55760405162461bcd60e51b81526020600482018190526024820152600080516020620030578339815191526044820152606401620004e2565b6001600160a01b038216600081815260186020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b038316620006785760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401620004e2565b6001600160a01b038216620006db5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401620004e2565b6001600160a01b03808416600081815260036020908152604080832094871683529381528382208590559181526001909152205462000730576001600160a01b03831660009081526001602052604090204390555b816001600160a01b0316836001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516200077691815260200190565b60405180910390a3505050565b6001600160a01b038216620007db5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401620004e2565b620007f7816004546200088a60201b62000fdb1790919060201c565b6004556001600160a01b0382166000908152600260209081526040909120546200082c91839062000fdb6200088a821b17901c565b6001600160a01b0383166000818152600260205260408082209390935591519091907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906200087e9085815260200190565b60405180910390a35050565b600080620008998385620009db565b905083811015620008ed5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401620004e2565b9392505050565b828054620009029062000a3b565b90600052602060002090601f01602090048101928262000926576000855562000971565b82601f106200094157805160ff191683800117855562000971565b8280016001018555821562000971579182015b828111156200097157825182559160200191906001019062000954565b506200097f92915062000983565b5090565b5b808211156200097f576000815560010162000984565b600060208284031215620009ad57600080fd5b81516001600160a01b0381168114620008ed57600080fd5b634e487b7160e01b600052601160045260246000fd5b60008219821115620009f157620009f1620009c5565b500190565b600081600019048311821515161562000a135762000a13620009c5565b500290565b60008262000a3657634e487b7160e01b600052601260045260246000fd5b500490565b600181811c9082168062000a5057607f821691505b6020821081141562000a7257634e487b7160e01b600052602260045260246000fd5b50919050565b60805160a05161259d62000aba6000396000818161048b0152610cc001526000818161038201528181611f1101528181611fd90152612015015261259d6000f3fe6080604052600436106102975760003560e01c80637ab439831161015a578063bf56b371116100c1578063deab8aea1161007a578063deab8aea1461080e578063e2f456051461082e578063e71dc3f514610844578063edc263531461085a578063f2fde38b1461087a578063f8b45b051461089a57600080fd5b8063bf56b37114610750578063c024666814610766578063c8c8ebe414610786578063d4090d2a1461079c578063d85ba063146107b2578063dd62ed3e146107c857600080fd5b80639bdcd832116101135780639bdcd83214610689578063a457c2d7146106a9578063a9059cbb146106c9578063adb873bd146106e9578063b62496f5146106ff578063bbc0c7421461072f57600080fd5b80637ab43983146105f55780638a8c523c1461060b5780638da5cb5b1461062057806395d89b411461063e578063975d71e2146106535780639a7a23d61461066957600080fd5b80633c2a46a2116101fe5780636a486a8e116101b75780636a486a8e1461053d5780636ddd17131461055357806370a0823114610574578063715018a6146105aa57806371a51522146105bf5780637571336a146105d557600080fd5b80633c2a46a21461045957806349bd5a5e146104795780634a62bb65146104ad5780634fbee193146104ce578063540ba5521461050757806366ca9b831461051d57600080fd5b806318160ddd1161025057806318160ddd146103bc5780631d777856146103d157806323b872dd146103e757806327c8f83514610407578063313ce5671461041d578063395093511461043957600080fd5b806302dbd8f8146102a3578063047fc9aa146102c557806306fdde03146102ee578063095ea7b31461031057806310d5de53146103405780631694505e1461037057600080fd5b3661029e57005b600080fd5b3480156102af57600080fd5b506102c36102be3660046120f9565b6108b0565b005b3480156102d157600080fd5b506102db600b5481565b6040519081526020015b60405180910390f35b3480156102fa57600080fd5b50610303610950565b6040516102e5919061211b565b34801561031c57600080fd5b5061033061032b366004612188565b6109e2565b60405190151581526020016102e5565b34801561034c57600080fd5b5061033061035b3660046121b4565b60196020526000908152604090205460ff1681565b34801561037c57600080fd5b506103a47f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020016102e5565b3480156103c857600080fd5b506004546102db565b3480156103dd57600080fd5b506102db60135481565b3480156103f357600080fd5b506103306104023660046121d1565b6109f9565b34801561041357600080fd5b506103a461dead81565b34801561042957600080fd5b50604051601281526020016102e5565b34801561044557600080fd5b50610330610454366004612188565b610a62565b34801561046557600080fd5b506102c36104743660046121b4565b610a98565b34801561048557600080fd5b506103a47f000000000000000000000000000000000000000000000000000000000000000081565b3480156104b957600080fd5b50600c5461033090600160a01b900460ff1681565b3480156104da57600080fd5b506103306104e93660046121b4565b6001600160a01b031660009081526018602052604090205460ff1690565b34801561051357600080fd5b506102db600e5481565b34801561052957600080fd5b506102c36105383660046120f9565b610ae4565b34801561054957600080fd5b506102db60125481565b34801561055f57600080fd5b50600c5461033090600160b01b900460ff1681565b34801561058057600080fd5b506102db61058f3660046121b4565b6001600160a01b031660009081526002602052604090205490565b3480156105b657600080fd5b506102c3610b77565b3480156105cb57600080fd5b506102db60115481565b3480156105e157600080fd5b506102c36105f0366004612227565b610beb565b34801561060157600080fd5b506102db60155481565b34801561061757600080fd5b506102c3610c40565b34801561062c57600080fd5b506007546001600160a01b03166103a4565b34801561064a57600080fd5b50610303610c85565b34801561065f57600080fd5b506102db60165481565b34801561067557600080fd5b506102c3610684366004612227565b610c94565b34801561069557600080fd5b506102c36106a436600461225c565b610d70565b3480156106b557600080fd5b506103306106c4366004612188565b610db8565b3480156106d557600080fd5b506103306106e4366004612188565b610e07565b3480156106f557600080fd5b506102db60105481565b34801561070b57600080fd5b5061033061071a3660046121b4565b601a6020526000908152604090205460ff1681565b34801561073b57600080fd5b50600c5461033090600160a81b900460ff1681565b34801561075c57600080fd5b506102db60175481565b34801561077257600080fd5b506102c3610781366004612227565b610e14565b34801561079257600080fd5b506102db60085481565b3480156107a857600080fd5b506102db60145481565b3480156107be57600080fd5b506102db600f5481565b3480156107d457600080fd5b506102db6107e3366004612277565b6001600160a01b03918216600090815260036020908152604080832093909416825291909152205490565b34801561081a57600080fd5b50600c546103a4906001600160a01b031681565b34801561083a57600080fd5b506102db60095481565b34801561085057600080fd5b506102db600d5481565b34801561086657600080fd5b506102c36108753660046121b4565b610e9d565b34801561088657600080fd5b506102c36108953660046121b4565b610ef0565b3480156108a657600080fd5b506102db600a5481565b6007546001600160a01b031633146108e35760405162461bcd60e51b81526004016108da906122b0565b60405180910390fd5b601082905560118190556108f781836122fb565b60128190556005101561094c5760405162461bcd60e51b815260206004820152601c60248201527f4d757374206b6565702066656573206174203525206f72206c6573730000000060448201526064016108da565b5050565b60606005805461095f90612313565b80601f016020809104026020016040519081016040528092919081815260200182805461098b90612313565b80156109d85780601f106109ad576101008083540402835291602001916109d8565b820191906000526020600020905b8154815290600101906020018083116109bb57829003601f168201915b5050505050905090565b60006109ef338484611041565b5060015b92915050565b6000610a068484846111aa565b610a588433610a538560405180606001604052806028815260200161251b602891396001600160a01b038a1660009081526003602090815260408083203384529091529020549190611a59565b611041565b5060019392505050565b3360008181526003602090815260408083206001600160a01b038716845290915281205490916109ef918590610a539086610fdb565b6007546001600160a01b03163314610ac25760405162461bcd60e51b81526004016108da906122b0565b600c80546001600160a01b0319166001600160a01b0392909216919091179055565b6007546001600160a01b03163314610b0e5760405162461bcd60e51b81526004016108da906122b0565b600d829055600e819055610b2281836122fb565b600f8190556005101561094c5760405162461bcd60e51b815260206004820152601c60248201527f4d757374206b6565702066656573206174203525206f72206c6573730000000060448201526064016108da565b6007546001600160a01b03163314610ba15760405162461bcd60e51b81526004016108da906122b0565b6007546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600780546001600160a01b0319169055565b6007546001600160a01b03163314610c155760405162461bcd60e51b81526004016108da906122b0565b6001600160a01b03919091166000908152601960205260409020805460ff1916911515919091179055565b6007546001600160a01b03163314610c6a5760405162461bcd60e51b81526004016108da906122b0565b600c805461ffff60a81b191661010160a81b17905542601755565b60606006805461095f90612313565b6007546001600160a01b03163314610cbe5760405162461bcd60e51b81526004016108da906122b0565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b03161415610d665760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b657250616972730000000000000060648201526084016108da565b61094c8282611a93565b6007546001600160a01b03163314610d9a5760405162461bcd60e51b81526004016108da906122b0565b60078054911515600160a81b0260ff60a81b19909216919091179055565b60006109ef3384610a5385604051806060016040528060258152602001612543602591393360009081526003602090815260408083206001600160a01b038d1684529091529020549190611a59565b60006109ef3384846111aa565b6007546001600160a01b03163314610e3e5760405162461bcd60e51b81526004016108da906122b0565b6001600160a01b038216600081815260186020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6007546001600160a01b03163314610ec75760405162461bcd60e51b81526004016108da906122b0565b6001600160a01b0316600090815260208181526040808320600190819055909152902060059055565b6007546001600160a01b03163314610f1a5760405162461bcd60e51b81526004016108da906122b0565b6001600160a01b038116610f7f5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016108da565b6007546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600780546001600160a01b0319166001600160a01b0392909216919091179055565b600080610fe883856122fb565b90508381101561103a5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016108da565b9392505050565b6001600160a01b0383166110a35760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016108da565b6001600160a01b0382166111045760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016108da565b6001600160a01b038084166000818152600360209081526040808320948716835293815283822085905591815260019091522054611158576001600160a01b03831660009081526001602052604090204390555b816001600160a01b0316836001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258360405161119d91815260200190565b60405180910390a3505050565b6001600160a01b0383166111d05760405162461bcd60e51b81526004016108da9061234e565b6001600160a01b0382166111f65760405162461bcd60e51b81526004016108da90612393565b600081116112585760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016108da565b6001600160a01b03831660009081526001602052604081205481901580159061129857506001600160a01b03851660009081526020819052604090205415155b80156112de57506001600160a01b0385166000908152602081905260409020546112c39060036122fb565b6001600160a01b038616600090815260016020526040902054105b80156112f35750600754600160a81b900460ff165b90508261130d5761130685856000611ae7565b5050505050565b600c54600160a01b900460ff161561168c576007546001600160a01b0386811691161480159061134b57506007546001600160a01b03858116911614155b801561135f57506001600160a01b03841615155b801561137657506001600160a01b03841661dead14155b801561138c5750600754600160a01b900460ff16155b1561168c57600c54600160a81b900460ff16611426576001600160a01b03851660009081526018602052604090205460ff16806113e157506001600160a01b03841660009081526018602052604090205460ff165b6114265760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016108da565b6001600160a01b0385166000908152601a602052604090205460ff16801561146757506001600160a01b03841660009081526019602052604090205460ff16155b1561154b576008548311156114dc5760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b60648201526084016108da565b600a546001600160a01b03851660009081526002602052604090205461150290856122fb565b11156115465760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016108da565b61168c565b6001600160a01b0384166000908152601a602052604090205460ff16801561158c57506001600160a01b03851660009081526019602052604090205460ff16155b15611602576008548311156115465760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b60648201526084016108da565b6001600160a01b03841660009081526019602052604090205460ff1661168c57600a546001600160a01b03851660009081526002602052604090205461164890856122fb565b111561168c5760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016108da565b30600090815260026020526040902054600954811080159081906116ba5750600754600160a01b900460ff16155b80156116cf5750600c54600160b01b900460ff165b80156116f457506001600160a01b0387166000908152601a602052604090205460ff16155b801561171957506001600160a01b03871660009081526018602052604090205460ff16155b801561173e57506001600160a01b03861660009081526018602052604090205460ff16155b1561176c576007805460ff60a01b1916600160a01b17905561175e611bf3565b6007805460ff60a01b191690555b6007546001600160a01b03881660009081526018602052604090205460ff600160a01b9092048216159116806117ba57506001600160a01b03871660009081526018602052604090205460ff165b156117c3575060005b60008115611a43576001600160a01b0388166000908152601a602052604090205460ff1680156117f557506000601254115b15611899576012549550611814606461180e8989611c8f565b90611d0e565b9050841561182157605895505b611830606461180e8989611c8f565b90506012546010548261184391906123d6565b61184d91906123f5565b6013600082825461185e91906122fb565b909155505060125460115461187390836123d6565b61187d91906123f5565b6014600082825461188e91906122fb565b909155506119fd9050565b6001600160a01b0389166000908152601a602052604090205460ff161580156118db57506001600160a01b0388166000908152601a602052604090205460ff16155b156118fd576000955084156118215760589550611830606461180e8989611c8f565b6001600160a01b0389166000908152601a602052604090205460ff16801561192757506000600f54115b156119fd57611946606461180e600f548a611c8f90919063ffffffff16565b9050600f54600d548261195991906123d6565b61196391906123f5565b6013600082825461197491906122fb565b9091555050600f54600e5461198990836123d6565b61199391906123f5565b601460008282546119a491906122fb565b90915550506001600160a01b0388166000908152602081905260409020541580156119dc57506017546119d9906101a46122fb565b42105b156119fd576001600160a01b03881660009081526020819052604090204390555b8015611a3657611a0e893083611ae7565b60135415611a3657611a2230601354611d50565b600454600b55611a30611e5b565b60006013555b611a408188612417565b96505b611a4e898989611ae7565b505050505050505050565b60008184841115611a7d5760405162461bcd60e51b81526004016108da919061211b565b506000611a8a8486612417565b95945050505050565b6001600160a01b0382166000818152601a6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b038316611b0d5760405162461bcd60e51b81526004016108da9061234e565b6001600160a01b038216611b335760405162461bcd60e51b81526004016108da90612393565b611b70816040518060600160405280602681526020016124f5602691396001600160a01b0386166000908152600260205260409020549190611a59565b6001600160a01b038085166000908152600260205260408082209390935590841681522054611b9f9082610fdb565b6001600160a01b0380841660008181526002602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061119d9085815260200190565b306000908152600260205260408120549081611c0d575050565b600954611c1b9060056123d6565b821115611c3357600954611c309060056123d6565b91505b611c3c82611eba565b60006014819055600c546040516001600160a01b039091169147919081818185875af1925050503d8060008114611306576040519150601f19603f3d011682016040523d82523d6000602084013e611306565b600082611c9e575060006109f3565b6000611caa83856123d6565b905082611cb785836123f5565b1461103a5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016108da565b600061103a83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612089565b6001600160a01b038216611db05760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b60648201526084016108da565b611ded816040518060600160405280602281526020016124d3602291396001600160a01b0385166000908152600260205260409020549190611a59565b6001600160a01b038316600090815260026020526040902055600454611e1390826120b7565b6004556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b6064601654600b54611e6d91906123d6565b611e7791906123f5565b600855600b5461271090611e8c9060056123d6565b611e9691906123f5565b600955601554600b54606491611eab916123d6565b611eb591906123f5565b600a55565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611eef57611eef61242e565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015611f6857600080fd5b505afa158015611f7c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611fa09190612444565b81600181518110611fb357611fb361242e565b60200260200101906001600160a01b031690816001600160a01b031681525050611ffe307f000000000000000000000000000000000000000000000000000000000000000084611041565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac94790612053908590600090869030904290600401612461565b600060405180830381600087803b15801561206d57600080fd5b505af1158015612081573d6000803e3d6000fd5b505050505050565b600081836120aa5760405162461bcd60e51b81526004016108da919061211b565b506000611a8a84866123f5565b600061103a83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611a59565b6000806040838503121561210c57600080fd5b50508035926020909101359150565b600060208083528351808285015260005b818110156121485785810183015185820160400152820161212c565b8181111561215a576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b038116811461218557600080fd5b50565b6000806040838503121561219b57600080fd5b82356121a681612170565b946020939093013593505050565b6000602082840312156121c657600080fd5b813561103a81612170565b6000806000606084860312156121e657600080fd5b83356121f181612170565b9250602084013561220181612170565b929592945050506040919091013590565b8035801515811461222257600080fd5b919050565b6000806040838503121561223a57600080fd5b823561224581612170565b915061225360208401612212565b90509250929050565b60006020828403121561226e57600080fd5b61103a82612212565b6000806040838503121561228a57600080fd5b823561229581612170565b915060208301356122a581612170565b809150509250929050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b6000821982111561230e5761230e6122e5565b500190565b600181811c9082168061232757607f821691505b6020821081141561234857634e487b7160e01b600052602260045260246000fd5b50919050565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b60008160001904831182151516156123f0576123f06122e5565b500290565b60008261241257634e487b7160e01b600052601260045260246000fd5b500490565b600082821015612429576124296122e5565b500390565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561245657600080fd5b815161103a81612170565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156124b15784516001600160a01b03168352938301939183019160010161248c565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212209a60fe9ff6b0add8a8406d78c29c23b28a9a922e26cd3d55fdc1163f4f09317a64736f6c634300080900334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572

Deployed Bytecode

0x6080604052600436106102975760003560e01c80637ab439831161015a578063bf56b371116100c1578063deab8aea1161007a578063deab8aea1461080e578063e2f456051461082e578063e71dc3f514610844578063edc263531461085a578063f2fde38b1461087a578063f8b45b051461089a57600080fd5b8063bf56b37114610750578063c024666814610766578063c8c8ebe414610786578063d4090d2a1461079c578063d85ba063146107b2578063dd62ed3e146107c857600080fd5b80639bdcd832116101135780639bdcd83214610689578063a457c2d7146106a9578063a9059cbb146106c9578063adb873bd146106e9578063b62496f5146106ff578063bbc0c7421461072f57600080fd5b80637ab43983146105f55780638a8c523c1461060b5780638da5cb5b1461062057806395d89b411461063e578063975d71e2146106535780639a7a23d61461066957600080fd5b80633c2a46a2116101fe5780636a486a8e116101b75780636a486a8e1461053d5780636ddd17131461055357806370a0823114610574578063715018a6146105aa57806371a51522146105bf5780637571336a146105d557600080fd5b80633c2a46a21461045957806349bd5a5e146104795780634a62bb65146104ad5780634fbee193146104ce578063540ba5521461050757806366ca9b831461051d57600080fd5b806318160ddd1161025057806318160ddd146103bc5780631d777856146103d157806323b872dd146103e757806327c8f83514610407578063313ce5671461041d578063395093511461043957600080fd5b806302dbd8f8146102a3578063047fc9aa146102c557806306fdde03146102ee578063095ea7b31461031057806310d5de53146103405780631694505e1461037057600080fd5b3661029e57005b600080fd5b3480156102af57600080fd5b506102c36102be3660046120f9565b6108b0565b005b3480156102d157600080fd5b506102db600b5481565b6040519081526020015b60405180910390f35b3480156102fa57600080fd5b50610303610950565b6040516102e5919061211b565b34801561031c57600080fd5b5061033061032b366004612188565b6109e2565b60405190151581526020016102e5565b34801561034c57600080fd5b5061033061035b3660046121b4565b60196020526000908152604090205460ff1681565b34801561037c57600080fd5b506103a47f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b0390911681526020016102e5565b3480156103c857600080fd5b506004546102db565b3480156103dd57600080fd5b506102db60135481565b3480156103f357600080fd5b506103306104023660046121d1565b6109f9565b34801561041357600080fd5b506103a461dead81565b34801561042957600080fd5b50604051601281526020016102e5565b34801561044557600080fd5b50610330610454366004612188565b610a62565b34801561046557600080fd5b506102c36104743660046121b4565b610a98565b34801561048557600080fd5b506103a47f000000000000000000000000744cc28f6c14d15d5b963e707bd12b37ea3c84e081565b3480156104b957600080fd5b50600c5461033090600160a01b900460ff1681565b3480156104da57600080fd5b506103306104e93660046121b4565b6001600160a01b031660009081526018602052604090205460ff1690565b34801561051357600080fd5b506102db600e5481565b34801561052957600080fd5b506102c36105383660046120f9565b610ae4565b34801561054957600080fd5b506102db60125481565b34801561055f57600080fd5b50600c5461033090600160b01b900460ff1681565b34801561058057600080fd5b506102db61058f3660046121b4565b6001600160a01b031660009081526002602052604090205490565b3480156105b657600080fd5b506102c3610b77565b3480156105cb57600080fd5b506102db60115481565b3480156105e157600080fd5b506102c36105f0366004612227565b610beb565b34801561060157600080fd5b506102db60155481565b34801561061757600080fd5b506102c3610c40565b34801561062c57600080fd5b506007546001600160a01b03166103a4565b34801561064a57600080fd5b50610303610c85565b34801561065f57600080fd5b506102db60165481565b34801561067557600080fd5b506102c3610684366004612227565b610c94565b34801561069557600080fd5b506102c36106a436600461225c565b610d70565b3480156106b557600080fd5b506103306106c4366004612188565b610db8565b3480156106d557600080fd5b506103306106e4366004612188565b610e07565b3480156106f557600080fd5b506102db60105481565b34801561070b57600080fd5b5061033061071a3660046121b4565b601a6020526000908152604090205460ff1681565b34801561073b57600080fd5b50600c5461033090600160a81b900460ff1681565b34801561075c57600080fd5b506102db60175481565b34801561077257600080fd5b506102c3610781366004612227565b610e14565b34801561079257600080fd5b506102db60085481565b3480156107a857600080fd5b506102db60145481565b3480156107be57600080fd5b506102db600f5481565b3480156107d457600080fd5b506102db6107e3366004612277565b6001600160a01b03918216600090815260036020908152604080832093909416825291909152205490565b34801561081a57600080fd5b50600c546103a4906001600160a01b031681565b34801561083a57600080fd5b506102db60095481565b34801561085057600080fd5b506102db600d5481565b34801561086657600080fd5b506102c36108753660046121b4565b610e9d565b34801561088657600080fd5b506102c36108953660046121b4565b610ef0565b3480156108a657600080fd5b506102db600a5481565b6007546001600160a01b031633146108e35760405162461bcd60e51b81526004016108da906122b0565b60405180910390fd5b601082905560118190556108f781836122fb565b60128190556005101561094c5760405162461bcd60e51b815260206004820152601c60248201527f4d757374206b6565702066656573206174203525206f72206c6573730000000060448201526064016108da565b5050565b60606005805461095f90612313565b80601f016020809104026020016040519081016040528092919081815260200182805461098b90612313565b80156109d85780601f106109ad576101008083540402835291602001916109d8565b820191906000526020600020905b8154815290600101906020018083116109bb57829003601f168201915b5050505050905090565b60006109ef338484611041565b5060015b92915050565b6000610a068484846111aa565b610a588433610a538560405180606001604052806028815260200161251b602891396001600160a01b038a1660009081526003602090815260408083203384529091529020549190611a59565b611041565b5060019392505050565b3360008181526003602090815260408083206001600160a01b038716845290915281205490916109ef918590610a539086610fdb565b6007546001600160a01b03163314610ac25760405162461bcd60e51b81526004016108da906122b0565b600c80546001600160a01b0319166001600160a01b0392909216919091179055565b6007546001600160a01b03163314610b0e5760405162461bcd60e51b81526004016108da906122b0565b600d829055600e819055610b2281836122fb565b600f8190556005101561094c5760405162461bcd60e51b815260206004820152601c60248201527f4d757374206b6565702066656573206174203525206f72206c6573730000000060448201526064016108da565b6007546001600160a01b03163314610ba15760405162461bcd60e51b81526004016108da906122b0565b6007546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600780546001600160a01b0319169055565b6007546001600160a01b03163314610c155760405162461bcd60e51b81526004016108da906122b0565b6001600160a01b03919091166000908152601960205260409020805460ff1916911515919091179055565b6007546001600160a01b03163314610c6a5760405162461bcd60e51b81526004016108da906122b0565b600c805461ffff60a81b191661010160a81b17905542601755565b60606006805461095f90612313565b6007546001600160a01b03163314610cbe5760405162461bcd60e51b81526004016108da906122b0565b7f000000000000000000000000744cc28f6c14d15d5b963e707bd12b37ea3c84e06001600160a01b0316826001600160a01b03161415610d665760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b657250616972730000000000000060648201526084016108da565b61094c8282611a93565b6007546001600160a01b03163314610d9a5760405162461bcd60e51b81526004016108da906122b0565b60078054911515600160a81b0260ff60a81b19909216919091179055565b60006109ef3384610a5385604051806060016040528060258152602001612543602591393360009081526003602090815260408083206001600160a01b038d1684529091529020549190611a59565b60006109ef3384846111aa565b6007546001600160a01b03163314610e3e5760405162461bcd60e51b81526004016108da906122b0565b6001600160a01b038216600081815260186020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6007546001600160a01b03163314610ec75760405162461bcd60e51b81526004016108da906122b0565b6001600160a01b0316600090815260208181526040808320600190819055909152902060059055565b6007546001600160a01b03163314610f1a5760405162461bcd60e51b81526004016108da906122b0565b6001600160a01b038116610f7f5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016108da565b6007546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600780546001600160a01b0319166001600160a01b0392909216919091179055565b600080610fe883856122fb565b90508381101561103a5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016108da565b9392505050565b6001600160a01b0383166110a35760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016108da565b6001600160a01b0382166111045760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016108da565b6001600160a01b038084166000818152600360209081526040808320948716835293815283822085905591815260019091522054611158576001600160a01b03831660009081526001602052604090204390555b816001600160a01b0316836001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258360405161119d91815260200190565b60405180910390a3505050565b6001600160a01b0383166111d05760405162461bcd60e51b81526004016108da9061234e565b6001600160a01b0382166111f65760405162461bcd60e51b81526004016108da90612393565b600081116112585760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016108da565b6001600160a01b03831660009081526001602052604081205481901580159061129857506001600160a01b03851660009081526020819052604090205415155b80156112de57506001600160a01b0385166000908152602081905260409020546112c39060036122fb565b6001600160a01b038616600090815260016020526040902054105b80156112f35750600754600160a81b900460ff165b90508261130d5761130685856000611ae7565b5050505050565b600c54600160a01b900460ff161561168c576007546001600160a01b0386811691161480159061134b57506007546001600160a01b03858116911614155b801561135f57506001600160a01b03841615155b801561137657506001600160a01b03841661dead14155b801561138c5750600754600160a01b900460ff16155b1561168c57600c54600160a81b900460ff16611426576001600160a01b03851660009081526018602052604090205460ff16806113e157506001600160a01b03841660009081526018602052604090205460ff165b6114265760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016108da565b6001600160a01b0385166000908152601a602052604090205460ff16801561146757506001600160a01b03841660009081526019602052604090205460ff16155b1561154b576008548311156114dc5760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b60648201526084016108da565b600a546001600160a01b03851660009081526002602052604090205461150290856122fb565b11156115465760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016108da565b61168c565b6001600160a01b0384166000908152601a602052604090205460ff16801561158c57506001600160a01b03851660009081526019602052604090205460ff16155b15611602576008548311156115465760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b60648201526084016108da565b6001600160a01b03841660009081526019602052604090205460ff1661168c57600a546001600160a01b03851660009081526002602052604090205461164890856122fb565b111561168c5760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016108da565b30600090815260026020526040902054600954811080159081906116ba5750600754600160a01b900460ff16155b80156116cf5750600c54600160b01b900460ff165b80156116f457506001600160a01b0387166000908152601a602052604090205460ff16155b801561171957506001600160a01b03871660009081526018602052604090205460ff16155b801561173e57506001600160a01b03861660009081526018602052604090205460ff16155b1561176c576007805460ff60a01b1916600160a01b17905561175e611bf3565b6007805460ff60a01b191690555b6007546001600160a01b03881660009081526018602052604090205460ff600160a01b9092048216159116806117ba57506001600160a01b03871660009081526018602052604090205460ff165b156117c3575060005b60008115611a43576001600160a01b0388166000908152601a602052604090205460ff1680156117f557506000601254115b15611899576012549550611814606461180e8989611c8f565b90611d0e565b9050841561182157605895505b611830606461180e8989611c8f565b90506012546010548261184391906123d6565b61184d91906123f5565b6013600082825461185e91906122fb565b909155505060125460115461187390836123d6565b61187d91906123f5565b6014600082825461188e91906122fb565b909155506119fd9050565b6001600160a01b0389166000908152601a602052604090205460ff161580156118db57506001600160a01b0388166000908152601a602052604090205460ff16155b156118fd576000955084156118215760589550611830606461180e8989611c8f565b6001600160a01b0389166000908152601a602052604090205460ff16801561192757506000600f54115b156119fd57611946606461180e600f548a611c8f90919063ffffffff16565b9050600f54600d548261195991906123d6565b61196391906123f5565b6013600082825461197491906122fb565b9091555050600f54600e5461198990836123d6565b61199391906123f5565b601460008282546119a491906122fb565b90915550506001600160a01b0388166000908152602081905260409020541580156119dc57506017546119d9906101a46122fb565b42105b156119fd576001600160a01b03881660009081526020819052604090204390555b8015611a3657611a0e893083611ae7565b60135415611a3657611a2230601354611d50565b600454600b55611a30611e5b565b60006013555b611a408188612417565b96505b611a4e898989611ae7565b505050505050505050565b60008184841115611a7d5760405162461bcd60e51b81526004016108da919061211b565b506000611a8a8486612417565b95945050505050565b6001600160a01b0382166000818152601a6020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b038316611b0d5760405162461bcd60e51b81526004016108da9061234e565b6001600160a01b038216611b335760405162461bcd60e51b81526004016108da90612393565b611b70816040518060600160405280602681526020016124f5602691396001600160a01b0386166000908152600260205260409020549190611a59565b6001600160a01b038085166000908152600260205260408082209390935590841681522054611b9f9082610fdb565b6001600160a01b0380841660008181526002602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061119d9085815260200190565b306000908152600260205260408120549081611c0d575050565b600954611c1b9060056123d6565b821115611c3357600954611c309060056123d6565b91505b611c3c82611eba565b60006014819055600c546040516001600160a01b039091169147919081818185875af1925050503d8060008114611306576040519150601f19603f3d011682016040523d82523d6000602084013e611306565b600082611c9e575060006109f3565b6000611caa83856123d6565b905082611cb785836123f5565b1461103a5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016108da565b600061103a83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612089565b6001600160a01b038216611db05760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b60648201526084016108da565b611ded816040518060600160405280602281526020016124d3602291396001600160a01b0385166000908152600260205260409020549190611a59565b6001600160a01b038316600090815260026020526040902055600454611e1390826120b7565b6004556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b6064601654600b54611e6d91906123d6565b611e7791906123f5565b600855600b5461271090611e8c9060056123d6565b611e9691906123f5565b600955601554600b54606491611eab916123d6565b611eb591906123f5565b600a55565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611eef57611eef61242e565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015611f6857600080fd5b505afa158015611f7c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611fa09190612444565b81600181518110611fb357611fb361242e565b60200260200101906001600160a01b031690816001600160a01b031681525050611ffe307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84611041565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac94790612053908590600090869030904290600401612461565b600060405180830381600087803b15801561206d57600080fd5b505af1158015612081573d6000803e3d6000fd5b505050505050565b600081836120aa5760405162461bcd60e51b81526004016108da919061211b565b506000611a8a84866123f5565b600061103a83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611a59565b6000806040838503121561210c57600080fd5b50508035926020909101359150565b600060208083528351808285015260005b818110156121485785810183015185820160400152820161212c565b8181111561215a576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b038116811461218557600080fd5b50565b6000806040838503121561219b57600080fd5b82356121a681612170565b946020939093013593505050565b6000602082840312156121c657600080fd5b813561103a81612170565b6000806000606084860312156121e657600080fd5b83356121f181612170565b9250602084013561220181612170565b929592945050506040919091013590565b8035801515811461222257600080fd5b919050565b6000806040838503121561223a57600080fd5b823561224581612170565b915061225360208401612212565b90509250929050565b60006020828403121561226e57600080fd5b61103a82612212565b6000806040838503121561228a57600080fd5b823561229581612170565b915060208301356122a581612170565b809150509250929050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b6000821982111561230e5761230e6122e5565b500190565b600181811c9082168061232757607f821691505b6020821081141561234857634e487b7160e01b600052602260045260246000fd5b50919050565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b60008160001904831182151516156123f0576123f06122e5565b500290565b60008261241257634e487b7160e01b600052601260045260246000fd5b500490565b600082821015612429576124296122e5565b500390565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561245657600080fd5b815161103a81612170565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156124b15784516001600160a01b03168352938301939183019160010161248c565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212209a60fe9ff6b0add8a8406d78c29c23b28a9a922e26cd3d55fdc1163f4f09317a64736f6c63430008090033

Deployed Bytecode Sourcemap

29628:11612:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33925:287;;;;;;;;;;-1:-1:-1;33925:287:0;;;;;:::i;:::-;;:::i;:::-;;30066:21;;;;;;;;;;;;;;;;;;;413:25:1;;;401:2;386:18;30066:21:0;;;;;;;;7641:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;9808:169::-;;;;;;;;;;-1:-1:-1;9808:169:0;;;;;:::i;:::-;;:::i;:::-;;;1672:14:1;;1665:22;1647:41;;1635:2;1620:18;9808:169:0;1507:187:1;30792:64:0;;;;;;;;;;-1:-1:-1;30792:64:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29715:51;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;2142:32:1;;;2124:51;;2112:2;2097:18;29715:51:0;1951:230:1;8761:108:0;;;;;;;;;;-1:-1:-1;8849:12:0;;8761:108;;30473:28;;;;;;;;;;;;;;;;10459:355;;;;;;;;;;-1:-1:-1;10459:355:0;;;;;:::i;:::-;;:::i;29818:53::-;;;;;;;;;;;;29864:6;29818:53;;8603:93;;;;;;;;;;-1:-1:-1;8603:93:0;;8686:2;2997:36:1;;2985:2;2970:18;8603:93:0;2855:184:1;11223:218:0;;;;;;;;;;-1:-1:-1;11223:218:0;;;;;:::i;:::-;;:::i;34220:111::-;;;;;;;;;;-1:-1:-1;34220:111:0;;;;;:::i;:::-;;:::i;29773:38::-;;;;;;;;;;;;;;;30137:33;;;;;;;;;;-1:-1:-1;30137:33:0;;;;-1:-1:-1;;;30137:33:0;;;;;;35464:125;;;;;;;;;;-1:-1:-1;35464:125:0;;;;;:::i;:::-;-1:-1:-1;;;;;35553:28:0;35529:4;35553:28;;;:19;:28;;;;;;;;;35464:125;30289:28;;;;;;;;;;;;;;;;33633:280;;;;;;;;;;-1:-1:-1;33633:280:0;;;;;:::i;:::-;;:::i;30429:28::-;;;;;;;;;;;;;;;;30217:31;;;;;;;;;;-1:-1:-1;30217:31:0;;;;-1:-1:-1;;;30217:31:0;;;;;;8932:127;;;;;;;;;;-1:-1:-1;8932:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;9033:18:0;9006:7;9033:18;;;:9;:18;;;;;;;8932:127;22223:148;;;;;;;;;;;;;:::i;30393:29::-;;;;;;;;;;;;;;;;33477:144;;;;;;;;;;-1:-1:-1;33477:144:0;;;;;:::i;:::-;;:::i;30548:26::-;;;;;;;;;;;;;;;;33314:151;;;;;;;;;;;;;:::i;21581:79::-;;;;;;;;;;-1:-1:-1;21646:6:0;;-1:-1:-1;;;;;21646:6:0;21581:79;;7860:104;;;;;;;;;;;;;:::i;30581:25::-;;;;;;;;;;;;;;;;35016:244;;;;;;;;;;-1:-1:-1;35016:244:0;;;;;:::i;:::-;;:::i;34339:97::-;;;;;;;;;;-1:-1:-1;34339:97:0;;;;;:::i;:::-;;:::i;11944:269::-;;;;;;;;;;-1:-1:-1;11944:269:0;;;;;:::i;:::-;;:::i;9272:175::-;;;;;;;;;;-1:-1:-1;9272:175:0;;;;;:::i;:::-;;:::i;30360:26::-;;;;;;;;;;;;;;;;31014:58;;;;;;;;;;-1:-1:-1;31014:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;30177:33;;;;;;;;;;-1:-1:-1;30177:33:0;;;;-1:-1:-1;;;30177:33:0;;;;;;30613:25;;;;;;;;;;;;;;;;34598:182;;;;;;;;;;-1:-1:-1;34598:182:0;;;;;:::i;:::-;;:::i;29947:35::-;;;;;;;;;;;;;;;;30508:31;;;;;;;;;;;;;;;;30324:27;;;;;;;;;;;;;;;;9510:151;;;;;;;;;;-1:-1:-1;9510:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;9626:18:0;;;9599:7;9626:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9510:151;30096:28;;;;;;;;;;-1:-1:-1;30096:28:0;;;;-1:-1:-1;;;;;30096:28:0;;;29989:33;;;;;;;;;;;;;;;;30257:25;;;;;;;;;;;;;;;;34444:146;;;;;;;;;;-1:-1:-1;34444:146:0;;;;;:::i;:::-;;:::i;22526:244::-;;;;;;;;;;-1:-1:-1;22526:244:0;;;;;:::i;:::-;;:::i;30029:24::-;;;;;;;;;;;;;;;;33925:287;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;;;;;;;;;34018:11:::1;:22:::0;;;34051:14:::1;:28:::0;;;34106::::1;34068:11:::0;34032:8;34106:28:::1;:::i;:::-;34090:13;:44:::0;;;34170:1:::1;-1:-1:-1::0;34153:18:0::1;34145:59;;;::::0;-1:-1:-1;;;34145:59:0;;4935:2:1;34145:59:0::1;::::0;::::1;4917:21:1::0;4974:2;4954:18;;;4947:30;5013;4993:18;;;4986:58;5061:18;;34145:59:0::1;4733:352:1::0;34145:59:0::1;33925:287:::0;;:::o;7641:100::-;7695:13;7728:5;7721:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7641:100;:::o;9808:169::-;9891:4;9908:39;230:10;9931:7;9940:6;9908:8;:39::i;:::-;-1:-1:-1;9965:4:0;9808:169;;;;;:::o;10459:355::-;10599:4;10616:36;10626:6;10634:9;10645:6;10616:9;:36::i;:::-;10663:121;10672:6;230:10;10694:89;10732:6;10694:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10694:19:0;;;;;;:11;:19;;;;;;;;230:10;10694:33;;;;;;;;;;:37;:89::i;:::-;10663:8;:121::i;:::-;-1:-1:-1;10802:4:0;10459:355;;;;;:::o;11223:218::-;230:10;11311:4;11360:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11360:34:0;;;;;;;;;;11311:4;;11328:83;;11351:7;;11360:50;;11399:10;11360:38;:50::i;34220:111::-;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;34298:13:::1;:25:::0;;-1:-1:-1;;;;;;34298:25:0::1;-1:-1:-1::0;;;;;34298:25:0;;;::::1;::::0;;;::::1;::::0;;34220:111::o;33633:280::-;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;33725:10:::1;:21:::0;;;33757:13:::1;:27:::0;;;33810:26:::1;33773:11:::0;33738:8;33810:26:::1;:::i;:::-;33795:12;:41:::0;;;33871:1:::1;-1:-1:-1::0;33855:17:0::1;33847:58;;;::::0;-1:-1:-1;;;33847:58:0;;4935:2:1;33847:58:0::1;::::0;::::1;4917:21:1::0;4974:2;4954:18;;;4947:30;5013;4993:18;;;4986:58;5061:18;;33847:58:0::1;4733:352:1::0;22223:148:0;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;22314:6:::1;::::0;22293:40:::1;::::0;22330:1:::1;::::0;-1:-1:-1;;;;;22314:6:0::1;::::0;22293:40:::1;::::0;22330:1;;22293:40:::1;22344:6;:19:::0;;-1:-1:-1;;;;;;22344:19:0::1;::::0;;22223:148::o;33477:144::-;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33567:39:0;;;::::1;;::::0;;;:31:::1;:39;::::0;;;;:46;;-1:-1:-1;;33567:46:0::1;::::0;::::1;;::::0;;;::::1;::::0;;33477:144::o;33314:151::-;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;33369:13:::1;:20:::0;;-1:-1:-1;;;;33400:18:0;-1:-1:-1;;;33400:18:0;;;33442:15:::1;33429:10;:28:::0;33314:151::o;7860:104::-;7916:13;7949:7;7942:14;;;;;:::i;35016:244::-;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;35123:13:::1;-1:-1:-1::0;;;;;35115:21:0::1;:4;-1:-1:-1::0;;;;;35115:21:0::1;;;35107:91;;;::::0;-1:-1:-1;;;35107:91:0;;5677:2:1;35107:91:0::1;::::0;::::1;5659:21:1::0;5716:2;5696:18;;;5689:30;5755:34;5735:18;;;5728:62;5826:27;5806:18;;;5799:55;5871:19;;35107:91:0::1;5475:421:1::0;35107:91:0::1;35211:41;35240:4;35246:5;35211:28;:41::i;34339:97::-:0;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;34409:9:::1;:19:::0;;;::::1;;-1:-1:-1::0;;;34409:19:0::1;-1:-1:-1::0;;;;34409:19:0;;::::1;::::0;;;::::1;::::0;;34339:97::o;11944:269::-;12037:4;12054:129;230:10;12077:7;12086:96;12125:15;12086:96;;;;;;;;;;;;;;;;;230:10;12086:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;12086:34:0;;;;;;;;;;;;:38;:96::i;9272:175::-;9358:4;9375:42;230:10;9399:9;9410:6;9375:9;:42::i;34598:182::-;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34683:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;34683:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;34738:34;;1647:41:1;;;34738:34:0::1;::::0;1620:18:1;34738:34:0::1;;;;;;;34598:182:::0;;:::o;34444:146::-;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34514:22:0::1;:15;:22:::0;;;::::1;::::0;;;;;;;34539:1:::1;34514:26:::0;;;;34551:27;;;;;34581:1:::1;34551:31:::0;;34444:146::o;22526:244::-;21793:6;;-1:-1:-1;;;;;21793:6:0;230:10;21793:22;21785:67;;;;-1:-1:-1;;;21785:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22615:22:0;::::1;22607:73;;;::::0;-1:-1:-1;;;22607:73:0;;6103:2:1;22607:73:0::1;::::0;::::1;6085:21:1::0;6142:2;6122:18;;;6115:30;6181:34;6161:18;;;6154:62;-1:-1:-1;;;6232:18:1;;;6225:36;6278:19;;22607:73:0::1;5901:402:1::0;22607:73:0::1;22717:6;::::0;22696:38:::1;::::0;-1:-1:-1;;;;;22696:38:0;;::::1;::::0;22717:6:::1;::::0;22696:38:::1;::::0;22717:6:::1;::::0;22696:38:::1;22745:6;:17:::0;;-1:-1:-1;;;;;;22745:17:0::1;-1:-1:-1::0;;;;;22745:17:0;;;::::1;::::0;;;::::1;::::0;;22526:244::o;16625:181::-;16683:7;;16715:5;16719:1;16715;:5;:::i;:::-;16703:17;;16744:1;16739;:6;;16731:46;;;;-1:-1:-1;;;16731:46:0;;6510:2:1;16731:46:0;;;6492:21:1;6549:2;6529:18;;;6522:30;6588:29;6568:18;;;6561:57;6635:18;;16731:46:0;6308:351:1;16731:46:0;16797:1;16625:181;-1:-1:-1;;;16625:181:0:o;15130:497::-;-1:-1:-1;;;;;15266:19:0;;15258:68;;;;-1:-1:-1;;;15258:68:0;;6866:2:1;15258:68:0;;;6848:21:1;6905:2;6885:18;;;6878:30;6944:34;6924:18;;;6917:62;-1:-1:-1;;;6995:18:1;;;6988:34;7039:19;;15258:68:0;6664:400:1;15258:68:0;-1:-1:-1;;;;;15345:21:0;;15337:68;;;;-1:-1:-1;;;15337:68:0;;7271:2:1;15337:68:0;;;7253:21:1;7310:2;7290:18;;;7283:30;7349:34;7329:18;;;7322:62;-1:-1:-1;;;7400:18:1;;;7393:32;7442:19;;15337:68:0;7069:398:1;15337:68:0;-1:-1:-1;;;;;15418:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;:36;;;15468:27;;;:20;:27;;;;;15465:106;;-1:-1:-1;;;;;15517:27:0;;;;;;:20;:27;;;;;15547:12;15517:42;;15465:106;15603:7;-1:-1:-1;;;;;15587:32:0;15596:5;-1:-1:-1;;;;;15587:32:0;;15612:6;15587:32;;;;413:25:1;;401:2;386:18;;267:177;15587:32:0;;;;;;;;15130:497;;;:::o;35601:4543::-;-1:-1:-1;;;;;35733:18:0;;35725:68;;;;-1:-1:-1;;;35725:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;35812:16:0;;35804:64;;;;-1:-1:-1;;;35804:64:0;;;;;;;:::i;:::-;35896:1;35887:6;:10;35879:64;;;;-1:-1:-1;;;35879:64:0;;8484:2:1;35879:64:0;;;8466:21:1;8523:2;8503:18;;;8496:30;8562:34;8542:18;;;8535:62;-1:-1:-1;;;8613:18:1;;;8606:39;8662:19;;35879:64:0;8282:405:1;35879:64:0;-1:-1:-1;;;;;36018:26:0;;35956:17;36018:26;;;:20;:26;;;;;;35956:17;;36018:30;;;;:59;;-1:-1:-1;;;;;;36052:21:0;;36076:1;36052:21;;;;;;;;;;;:25;;36018:59;:117;;;;-1:-1:-1;;;;;;36110:21:0;;:15;:21;;;;;;;;;;;:25;;36134:1;36110:25;:::i;:::-;-1:-1:-1;;;;;36081:26:0;;;;;;:20;:26;;;;;;:54;36018:117;:130;;;;-1:-1:-1;36139:9:0;;-1:-1:-1;;;36139:9:0;;;;36018:130;36007:142;-1:-1:-1;36166:11:0;36163:92;;36194:28;36210:4;36216:2;36220:1;36194:15;:28::i;:::-;36237:7;;35601:4543;;;:::o;36163:92::-;36278:14;;-1:-1:-1;;;36278:14:0;;;;36275:1264;;;21646:6;;-1:-1:-1;;;;;36330:15:0;;;21646:6;;36330:15;;;;:49;;-1:-1:-1;21646:6:0;;-1:-1:-1;;;;;36366:13:0;;;21646:6;;36366:13;;36330:49;:86;;;;-1:-1:-1;;;;;;36400:16:0;;;;36330:86;:128;;;;-1:-1:-1;;;;;;36437:21:0;;36451:6;36437:21;;36330:128;:158;;;;-1:-1:-1;36480:8:0;;-1:-1:-1;;;36480:8:0;;;;36479:9;36330:158;36308:1220;;;36526:13;;-1:-1:-1;;;36526:13:0;;;;36522:148;;-1:-1:-1;;;;;36571:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;36600:23:0;;;;;;:19;:23;;;;;;;;36571:52;36563:87;;;;-1:-1:-1;;;36563:87:0;;8894:2:1;36563:87:0;;;8876:21:1;8933:2;8913:18;;;8906:30;-1:-1:-1;;;8952:18:1;;;8945:52;9014:18;;36563:87:0;8692:346:1;36563:87:0;-1:-1:-1;;;;;36739:31:0;;;;;;:25;:31;;;;;;;;:71;;;;-1:-1:-1;;;;;;36775:35:0;;;;;;:31;:35;;;;;;;;36774:36;36739:71;36735:778;;;36857:20;;36847:6;:30;;36839:96;;;;-1:-1:-1;;;36839:96:0;;9245:2:1;36839:96:0;;;9227:21:1;9284:2;9264:18;;;9257:30;9323:34;9303:18;;;9296:62;-1:-1:-1;;;9374:18:1;;;9367:51;9435:19;;36839:96:0;9043:417:1;36839:96:0;36996:9;;-1:-1:-1;;;;;9033:18:0;;9006:7;9033:18;;;:9;:18;;;;;;36970:22;;:6;:22;:::i;:::-;:35;;36962:67;;;;-1:-1:-1;;;36962:67:0;;9667:2:1;36962:67:0;;;9649:21:1;9706:2;9686:18;;;9679:30;-1:-1:-1;;;9725:18:1;;;9718:49;9784:18;;36962:67:0;9465:343:1;36962:67:0;36735:778;;;-1:-1:-1;;;;;37123:29:0;;;;;;:25;:29;;;;;;;;:71;;;;-1:-1:-1;;;;;;37157:37:0;;;;;;:31;:37;;;;;;;;37156:38;37123:71;37119:394;;;37241:20;;37231:6;:30;;37223:97;;;;-1:-1:-1;;;37223:97:0;;10015:2:1;37223:97:0;;;9997:21:1;10054:2;10034:18;;;10027:30;10093:34;10073:18;;;10066:62;-1:-1:-1;;;10144:18:1;;;10137:52;10206:19;;37223:97:0;9813:418:1;37119:394:0;-1:-1:-1;;;;;37367:35:0;;;;;;:31;:35;;;;;;;;37363:150;;37460:9;;-1:-1:-1;;;;;9033:18:0;;9006:7;9033:18;;;:9;:18;;;;;;37434:22;;:6;:22;:::i;:::-;:35;;37426:67;;;;-1:-1:-1;;;37426:67:0;;9667:2:1;37426:67:0;;;9649:21:1;9706:2;9686:18;;;9679:30;-1:-1:-1;;;9725:18:1;;;9718:49;9784:18;;37426:67:0;9465:343:1;37426:67:0;37598:4;37549:28;9033:18;;;:9;:18;;;;;;37664;;37640:42;;;;;;;37713:33;;-1:-1:-1;37738:8:0;;-1:-1:-1;;;37738:8:0;;;;37737:9;37713:33;:61;;;;-1:-1:-1;37763:11:0;;-1:-1:-1;;;37763:11:0;;;;37713:61;:110;;;;-1:-1:-1;;;;;;37792:31:0;;;;;;:25;:31;;;;;;;;37791:32;37713:110;:153;;;;-1:-1:-1;;;;;;37841:25:0;;;;;;:19;:25;;;;;;;;37840:26;37713:153;:194;;;;-1:-1:-1;;;;;;37884:23:0;;;;;;:19;:23;;;;;;;;37883:24;37713:194;37695:338;;;37934:8;:15;;-1:-1:-1;;;;37934:15:0;-1:-1:-1;;;37934:15:0;;;37978:10;:8;:10::i;:::-;38005:8;:16;;-1:-1:-1;;;;38005:16:0;;;37695:338;38069:8;;-1:-1:-1;;;;;38093:25:0;;38053:12;38093:25;;;:19;:25;;;;;;38069:8;-1:-1:-1;;;38069:8:0;;;;;38068:9;;38093:25;;:52;;-1:-1:-1;;;;;;38122:23:0;;;;;;:19;:23;;;;;;;;38093:52;38090:99;;;-1:-1:-1;38172:5:0;38090:99;38209:12;38241:7;38238:1853;;;-1:-1:-1;;;;;38292:29:0;;;;;;:25;:29;;;;;;;;:50;;;;;38341:1;38325:13;;:17;38292:50;38288:1393;;;38372:13;;;-1:-1:-1;38411:34:0;38441:3;38411:25;:6;38372:13;38411:10;:25::i;:::-;:29;;:34::i;:::-;38404:41;;38471:7;38468:76;;;38518:2;38506:14;;38468:76;38569:30;38595:3;38569:21;:6;38580:9;38569:10;:21::i;:30::-;38562:37;;38656:13;;38642:11;;38635:4;:18;;;;:::i;:::-;:34;;;;:::i;:::-;38618:13;;:51;;;;;;;:::i;:::-;;;;-1:-1:-1;;38732:13:0;;38715:14;;38708:21;;:4;:21;:::i;:::-;:37;;;;:::i;:::-;38688:16;;:57;;;;;;;:::i;:::-;;;;-1:-1:-1;38288:1393:0;;-1:-1:-1;38288:1393:0;;-1:-1:-1;;;;;38785:31:0;;;;;;:25;:31;;;;;;;;38784:32;:66;;;;-1:-1:-1;;;;;;38821:29:0;;;;;;:25;:29;;;;;;;;38820:30;38784:66;38780:901;;;38883:1;38871:13;;38910:7;38907:76;;;38957:2;38945:14;;39008:30;39034:3;39008:21;:6;39019:9;39008:10;:21::i;38780:901::-;-1:-1:-1;;;;;39247:31:0;;;;;;:25;:31;;;;;;;;:51;;;;;39297:1;39282:12;;:16;39247:51;39244:437;;;39325:33;39354:3;39325:24;39336:12;;39325:6;:10;;:24;;;;:::i;:33::-;39318:40;;39411:12;;39398:10;;39391:4;:17;;;;:::i;:::-;:32;;;;:::i;:::-;39374:13;;:49;;;;;;;:::i;:::-;;;;-1:-1:-1;;39485:12:0;;39469:13;;39462:20;;:4;:20;:::i;:::-;:35;;;;:::i;:::-;39442:16;;:55;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;;;39520:19:0;;:15;:19;;;;;;;;;;;:24;:68;;;;-1:-1:-1;39566:10:0;;:22;;39579:9;39566:22;:::i;:::-;39548:15;:40;39520:68;39516:150;;;-1:-1:-1;;;;;39612:19:0;;:15;:19;;;;;;;;;;39634:12;39612:34;;39516:150;39712:8;;39709:334;;39744:42;39760:4;39774;39781;39744:15;:42::i;:::-;39809:13;;:17;39805:223;;39851:35;39865:4;39872:13;;39851:5;:35::i;:::-;8849:12;;39909:6;:22;39954:14;:12;:14::i;:::-;40007:1;39991:13;:17;39805:223;40065:14;40075:4;40065:14;;:::i;:::-;;;38238:1853;40103:33;40119:4;40125:2;40129:6;40103:15;:33::i;:::-;35714:4430;;;;;;35601:4543;;;:::o;17528:192::-;17614:7;17650:12;17642:6;;;;17634:29;;;;-1:-1:-1;;;17634:29:0;;;;;;;;:::i;:::-;-1:-1:-1;17674:9:0;17686:5;17690:1;17686;:5;:::i;:::-;17674:17;17528:192;-1:-1:-1;;;;;17528:192:0:o;35268:188::-;-1:-1:-1;;;;;35351:31:0;;;;;;:25;:31;;;;;;:39;;-1:-1:-1;;35351:39:0;;;;;;;;;;35408:40;;35351:39;;:31;35408:40;;;35268:188;;:::o;12703:573::-;-1:-1:-1;;;;;12843:20:0;;12835:70;;;;-1:-1:-1;;;12835:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12924:23:0;;12916:71;;;;-1:-1:-1;;;12916:71:0;;;;;;;:::i;:::-;13080;13102:6;13080:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;13080:17:0;;;;;;:9;:17;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;13060:17:0;;;;;;;:9;:17;;;;;;:91;;;;13185:20;;;;;;;:32;;13210:6;13185:24;:32::i;:::-;-1:-1:-1;;;;;13162:20:0;;;;;;;:9;:20;;;;;;;:55;;;;13233:35;;;;;;;;;;13261:6;413:25:1;;401:2;386:18;;267:177;40765:470:0;40848:4;40804:23;9033:18;;;:9;:18;;;;;;;;40898:34;;40924:7;;40765:470::o;40898:34::-;40965:18;;:22;;40986:1;40965:22;:::i;:::-;40947:15;:40;40944:109;;;41019:18;;:22;;41040:1;41019:22;:::i;:::-;41001:40;;40944:109;41065:33;41082:15;41065:16;:33::i;:::-;41139:1;41120:16;:20;;;41174:13;;41166:61;;-1:-1:-1;;;;;41174:13:0;;;;41201:21;;41166:61;;41139:1;41166:61;41201:21;41174:13;41166:61;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17979:471;18037:7;18282:6;18278:47;;-1:-1:-1;18312:1:0;18305:8;;18278:47;18337:9;18349:5;18353:1;18349;:5;:::i;:::-;18337:17;-1:-1:-1;18382:1:0;18373:5;18377:1;18337:17;18373:5;:::i;:::-;:10;18365:56;;;;-1:-1:-1;;;18365:56:0;;11173:2:1;18365:56:0;;;11155:21:1;11212:2;11192:18;;;11185:30;11251:34;11231:18;;;11224:62;-1:-1:-1;;;11302:18:1;;;11295:31;11343:19;;18365:56:0;10971:397:1;18926:132:0;18984:7;19011:39;19015:1;19018;19011:39;;;;;;;;;;;;;;;;;:3;:39::i;14274:418::-;-1:-1:-1;;;;;14358:21:0;;14350:67;;;;-1:-1:-1;;;14350:67:0;;11575:2:1;14350:67:0;;;11557:21:1;11614:2;11594:18;;;11587:30;11653:34;11633:18;;;11626:62;-1:-1:-1;;;11704:18:1;;;11697:31;11745:19;;14350:67:0;11373:397:1;14350:67:0;14513:68;14536:6;14513:68;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;14513:18:0;;;;;;:9;:18;;;;;;;:68;:22;:68::i;:::-;-1:-1:-1;;;;;14492:18:0;;;;;;:9;:18;;;;;:89;14607:12;;:24;;14624:6;14607:16;:24::i;:::-;14592:12;:39;14647:37;;413:25:1;;;14673:1:0;;-1:-1:-1;;;;;14647:37:0;;;;;401:2:1;386:18;14647:37:0;;;;;;;14274:418;;:::o;34788:220::-;34876:3;34863:10;;34854:6;;:19;;;;:::i;:::-;:25;;;;:::i;:::-;34831:20;:48;34911:6;;34924:5;;34911:10;;34920:1;34911:10;:::i;:::-;:18;;;;:::i;:::-;34890;:39;34983:11;;34974:6;;34997:3;;34974:20;;;:::i;:::-;:26;;;;:::i;:::-;34962:9;:38;34788:220::o;40152:601::-;40304:16;;;40318:1;40304:16;;;;;;;;40280:21;;40304:16;;;;;;;;;;-1:-1:-1;40304:16:0;40280:40;;40349:4;40331;40336:1;40331:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;40331:23:0;;;-1:-1:-1;;;;;40331:23:0;;;;;40375:15;-1:-1:-1;;;;;40375:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;40365:4;40370:1;40365:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;40365:32:0;;;-1:-1:-1;;;;;40365:32:0;;;;;40410:62;40427:4;40442:15;40460:11;40410:8;:62::i;:::-;40511:224;;-1:-1:-1;;;40511:224:0;;-1:-1:-1;;;;;40511:15:0;:66;;;;:224;;40592:11;;40618:1;;40662:4;;40689;;40709:15;;40511:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;40207:546;40152:601;:::o;19554:278::-;19640:7;19675:12;19668:5;19660:28;;;;-1:-1:-1;;;19660:28:0;;;;;;;;:::i;:::-;-1:-1:-1;19699:9:0;19711:5;19715:1;19711;:5;:::i;17089:136::-;17147:7;17174:43;17178:1;17181;17174:43;;;;;;;;;;;;;;;;;:3;:43::i;14:248:1:-;82:6;90;143:2;131:9;122:7;118:23;114:32;111:52;;;159:1;156;149:12;111:52;-1:-1:-1;;182:23:1;;;252:2;237:18;;;224:32;;-1:-1:-1;14:248:1:o;449:597::-;561:4;590:2;619;608:9;601:21;651:6;645:13;694:6;689:2;678:9;674:18;667:34;719:1;729:140;743:6;740:1;737:13;729:140;;;838:14;;;834:23;;828:30;804:17;;;823:2;800:26;793:66;758:10;;729:140;;;887:6;884:1;881:13;878:91;;;957:1;952:2;943:6;932:9;928:22;924:31;917:42;878:91;-1:-1:-1;1030:2:1;1009:15;-1:-1:-1;;1005:29:1;990:45;;;;1037:2;986:54;;449:597;-1:-1:-1;;;449:597:1:o;1051:131::-;-1:-1:-1;;;;;1126:31:1;;1116:42;;1106:70;;1172:1;1169;1162:12;1106:70;1051:131;:::o;1187:315::-;1255:6;1263;1316:2;1304:9;1295:7;1291:23;1287:32;1284:52;;;1332:1;1329;1322:12;1284:52;1371:9;1358:23;1390:31;1415:5;1390:31;:::i;:::-;1440:5;1492:2;1477:18;;;;1464:32;;-1:-1:-1;;;1187:315:1:o;1699:247::-;1758:6;1811:2;1799:9;1790:7;1786:23;1782:32;1779:52;;;1827:1;1824;1817:12;1779:52;1866:9;1853:23;1885:31;1910:5;1885:31;:::i;2186:456::-;2263:6;2271;2279;2332:2;2320:9;2311:7;2307:23;2303:32;2300:52;;;2348:1;2345;2338:12;2300:52;2387:9;2374:23;2406:31;2431:5;2406:31;:::i;:::-;2456:5;-1:-1:-1;2513:2:1;2498:18;;2485:32;2526:33;2485:32;2526:33;:::i;:::-;2186:456;;2578:7;;-1:-1:-1;;;2632:2:1;2617:18;;;;2604:32;;2186:456::o;3044:160::-;3109:20;;3165:13;;3158:21;3148:32;;3138:60;;3194:1;3191;3184:12;3138:60;3044:160;;;:::o;3209:315::-;3274:6;3282;3335:2;3323:9;3314:7;3310:23;3306:32;3303:52;;;3351:1;3348;3341:12;3303:52;3390:9;3377:23;3409:31;3434:5;3409:31;:::i;:::-;3459:5;-1:-1:-1;3483:35:1;3514:2;3499:18;;3483:35;:::i;:::-;3473:45;;3209:315;;;;;:::o;3529:180::-;3585:6;3638:2;3626:9;3617:7;3613:23;3609:32;3606:52;;;3654:1;3651;3644:12;3606:52;3677:26;3693:9;3677:26;:::i;3714:388::-;3782:6;3790;3843:2;3831:9;3822:7;3818:23;3814:32;3811:52;;;3859:1;3856;3849:12;3811:52;3898:9;3885:23;3917:31;3942:5;3917:31;:::i;:::-;3967:5;-1:-1:-1;4024:2:1;4009:18;;3996:32;4037:33;3996:32;4037:33;:::i;:::-;4089:7;4079:17;;;3714:388;;;;;:::o;4107:356::-;4309:2;4291:21;;;4328:18;;;4321:30;4387:34;4382:2;4367:18;;4360:62;4454:2;4439:18;;4107:356::o;4468:127::-;4529:10;4524:3;4520:20;4517:1;4510:31;4560:4;4557:1;4550:15;4584:4;4581:1;4574:15;4600:128;4640:3;4671:1;4667:6;4664:1;4661:13;4658:39;;;4677:18;;:::i;:::-;-1:-1:-1;4713:9:1;;4600:128::o;5090:380::-;5169:1;5165:12;;;;5212;;;5233:61;;5287:4;5279:6;5275:17;5265:27;;5233:61;5340:2;5332:6;5329:14;5309:18;5306:38;5303:161;;;5386:10;5381:3;5377:20;5374:1;5367:31;5421:4;5418:1;5411:15;5449:4;5446:1;5439:15;5303:161;;5090:380;;;:::o;7472:401::-;7674:2;7656:21;;;7713:2;7693:18;;;7686:30;7752:34;7747:2;7732:18;;7725:62;-1:-1:-1;;;7818:2:1;7803:18;;7796:35;7863:3;7848:19;;7472:401::o;7878:399::-;8080:2;8062:21;;;8119:2;8099:18;;;8092:30;8158:34;8153:2;8138:18;;8131:62;-1:-1:-1;;;8224:2:1;8209:18;;8202:33;8267:3;8252:19;;7878:399::o;10236:168::-;10276:7;10342:1;10338;10334:6;10330:14;10327:1;10324:21;10319:1;10312:9;10305:17;10301:45;10298:71;;;10349:18;;:::i;:::-;-1:-1:-1;10389:9:1;;10236:168::o;10409:217::-;10449:1;10475;10465:132;;10519:10;10514:3;10510:20;10507:1;10500:31;10554:4;10551:1;10544:15;10582:4;10579:1;10572:15;10465:132;-1:-1:-1;10611:9:1;;10409:217::o;10631:125::-;10671:4;10699:1;10696;10693:8;10690:34;;;10704:18;;:::i;:::-;-1:-1:-1;10741:9:1;;10631:125::o;11907:127::-;11968:10;11963:3;11959:20;11956:1;11949:31;11999:4;11996:1;11989:15;12023:4;12020:1;12013:15;12039:251;12109:6;12162:2;12150:9;12141:7;12137:23;12133:32;12130:52;;;12178:1;12175;12168:12;12130:52;12210:9;12204:16;12229:31;12254:5;12229:31;:::i;12295:980::-;12557:4;12605:3;12594:9;12590:19;12636:6;12625:9;12618:25;12662:2;12700:6;12695:2;12684:9;12680:18;12673:34;12743:3;12738:2;12727:9;12723:18;12716:31;12767:6;12802;12796:13;12833:6;12825;12818:22;12871:3;12860:9;12856:19;12849:26;;12910:2;12902:6;12898:15;12884:29;;12931:1;12941:195;12955:6;12952:1;12949:13;12941:195;;;13020:13;;-1:-1:-1;;;;;13016:39:1;13004:52;;13111:15;;;;13076:12;;;;13052:1;12970:9;12941:195;;;-1:-1:-1;;;;;;;13192:32:1;;;;13187:2;13172:18;;13165:60;-1:-1:-1;;;13256:3:1;13241:19;13234:35;13153:3;12295:980;-1:-1:-1;;;12295:980:1:o

Swarm Source

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