Token Ethereum Vault

 

Overview [ERC-20]

Max Total Supply:
1,000,000,000 eVAULT

Holders:
254

Transfers:
-

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

OVERVIEW

$eVAULT’s vision is to reward holders in USDC and auto delivering your dividends directly to your wallet. There is a 12% tax on all transactions. 6% is allocated to holder passive income, and 6% will be used to cover project operations.

# Exchange Pair Price  24H Volume % Volume
Loading
This contract contains unverified libraries: IterableMapping
This contract may be a proxy contract. Click on More Options and select Is this a proxy? to confirm and enable the "Read as Proxy" & "Write as Proxy" tabs.

Contract Source Code Verified (Exact Match)

Contract Name:
eVAULT

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2021-07-21
*/

// SPDX-License-Identifier: Unlicensed

pragma solidity ^0.8.4;

////////////////////////////////
///////////// ERC //////////////
////////////////////////////////

/*
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with GSN meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address payable) {
        return payable(msg.sender);
    }

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

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract 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 virtual 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;
    }
}

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);
}

/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 * For a generic mechanism see {ERC20PresetMinterPauser}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin guidelines: functions revert instead
 * of returning `false` on failure. This behavior is nonetheless conventional
 * and does not conflict with the expectations of ERC20 applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 *
 * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
 * functions have been added to mitigate the well-known issues around setting
 * allowances. See {IERC20-approve}.
 */
contract ERC20 is Context, IERC20 {
    using SafeMath for uint256;

    mapping (address => uint256) private _balances;

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

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;
    uint8 private _decimals;

    /**
     * @dev Sets the values for {name} and {symbol}, initializes {decimals} with
     * a default value of 18.
     *
     * To select a different value for {decimals}, use {_setupDecimals}.
     *
     * All three of these values are immutable: they can only be set once during
     * construction.
     */
    constructor (string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
        _decimals = 18;
    }

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

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual 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 {_setupDecimals} is
     * called.
     *
     * 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 returns (uint8) {
        return _decimals;
    }

    /**
     * @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:
     *
     * - `to` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

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

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

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

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

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

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

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

    /**
     * @dev Sets {decimals} to a value other than the default one of 18.
     *
     * WARNING: This function should only be called from the constructor. Most
     * applications that interact with token contracts will not expect
     * {decimals} to ever change, and may work incorrectly if it does.
     */
    function _setupDecimals(uint8 decimals_) internal virtual {
        _decimals = decimals_;
    }

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

////////////////////////////////
////////// Dividend ////////////
////////////////////////////////

/*
@title Dividend-Paying Token Interface
@author Roger Wu (https://github.com/roger-wu)
@dev An interface for a dividend-paying token contract.
*/
interface IDividendPayingToken {
  /// @notice View the amount of dividend in wei that an address can withdraw.
  /// @param _owner The address of a token holder.
  /// @return The amount of dividend in wei that `_owner` can withdraw.
  function dividendOf(address _owner) external view returns(uint256);

  /// @notice Distributes ether to token holders as dividends.
  /// @dev SHOULD distribute the paid ether to token holders as dividends.
  ///  SHOULD NOT directly transfer ether to token holders in this function.
  ///  MUST emit a `DividendsDistributed` event when the amount of distributed ether is greater than 0.
  function distributeDividends() external payable;

  /// @notice Withdraws the ether distributed to the sender.
  /// @dev SHOULD transfer `dividendOf(msg.sender)` wei to `msg.sender`, and `dividendOf(msg.sender)` SHOULD be 0 after the transfer.
  ///  MUST emit a `DividendWithdrawn` event if the amount of ether transferred is greater than 0.
  function withdrawDividend() external;

  /// @dev This event MUST emit when ether is distributed to token holders.
  /// @param from The address which sends ether to this contract.
  /// @param weiAmount The amount of distributed ether in wei.
  event DividendsDistributed(
    address indexed from,
    uint256 weiAmount
  );

  /// @dev This event MUST emit when an address withdraws their dividend.
  /// @param to The address which withdraws ether from this contract.
  /// @param weiAmount The amount of withdrawn ether in wei.
  event DividendWithdrawn(
    address indexed to,
    uint256 weiAmount
  );
}

/*
@title Dividend-Paying Token Optional Interface
@author Roger Wu (https://github.com/roger-wu)
@dev OPTIONAL functions for a dividend-paying token contract.
*/
interface IDividendPayingTokenOptional {
  /// @notice View the amount of dividend in wei that an address can withdraw.
  /// @param _owner The address of a token holder.
  /// @return The amount of dividend in wei that `_owner` can withdraw.
  function withdrawableDividendOf(address _owner) external view returns(uint256);

  /// @notice View the amount of dividend in wei that an address has withdrawn.
  /// @param _owner The address of a token holder.
  /// @return The amount of dividend in wei that `_owner` has withdrawn.
  function withdrawnDividendOf(address _owner) external view returns(uint256);

  /// @notice View the amount of dividend in wei that an address has earned in total.
  /// @dev accumulativeDividendOf(_owner) = withdrawableDividendOf(_owner) + withdrawnDividendOf(_owner)
  /// @param _owner The address of a token holder.
  /// @return The amount of dividend in wei that `_owner` has earned in total.
  function accumulativeDividendOf(address _owner) external view returns(uint256);
}

/*
@title Dividend-Paying Token
@author Roger Wu (https://github.com/roger-wu)
@dev A mintable ERC20 token that allows anyone to pay and distribute ether
to token holders as dividends and allows token holders to withdraw their dividends.
Reference: the source code of PoWH3D: https://etherscan.io/address/0xB3775fB83F7D12A36E0475aBdD1FCA35c091efBe#code
*/
contract DividendPayingToken is ERC20, IDividendPayingToken, IDividendPayingTokenOptional {
  using SafeMath for uint256;
  using SafeMathUint for uint256;
  using SafeMathInt for int256;

  // With `magnitude`, we can properly distribute dividends even if the amount of received ether is small.
  // For more discussion about choosing the value of `magnitude`,
  //  see https://github.com/ethereum/EIPs/issues/1726#issuecomment-472352728
  uint256 constant internal magnitude = 2**128;

  uint256 internal magnifiedDividendPerShare;
  uint256 internal lastAmount;
  
  address public dividendToken = 0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48;

  // About dividendCorrection:
  // If the token balance of a `_user` is never changed, the dividend of `_user` can be computed with:
  //   `dividendOf(_user) = dividendPerShare * balanceOf(_user)`.
  // When `balanceOf(_user)` is changed (via minting/burning/transferring tokens),
  //   `dividendOf(_user)` should not be changed,
  //   but the computed value of `dividendPerShare * balanceOf(_user)` is changed.
  // To keep the `dividendOf(_user)` unchanged, we add a correction term:
  //   `dividendOf(_user) = dividendPerShare * balanceOf(_user) + dividendCorrectionOf(_user)`,
  //   where `dividendCorrectionOf(_user)` is updated whenever `balanceOf(_user)` is changed:
  //   `dividendCorrectionOf(_user) = dividendPerShare * (old balanceOf(_user)) - (new balanceOf(_user))`.
  // So now `dividendOf(_user)` returns the same value before and after `balanceOf(_user)` is changed.
  mapping(address => int256) internal magnifiedDividendCorrections;
  mapping(address => uint256) internal withdrawnDividends;

  uint256 public totalDividendsDistributed;
  uint256 public gasForTransfer;

  constructor(string memory _name, string memory _symbol) ERC20(_name, _symbol) {
        gasForTransfer = 3000;
  }
  

  receive() external payable {
  }

  /// @notice Distributes ether to token holders as dividends.
  /// @dev It reverts if the total supply of tokens is 0.
  /// It emits the `DividendsDistributed` event if the amount of received ether is greater than 0.
  /// About undistributed ether:
  ///   In each distribution, there is a small amount of ether not distributed,
  ///     the magnified amount of which is
  ///     `(msg.value * magnitude) % totalSupply()`.
  ///   With a well-chosen `magnitude`, the amount of undistributed ether
  ///     (de-magnified) in a distribution can be less than 1 wei.
  ///   We can actually keep track of the undistributed ether in a distribution
  ///     and try to distribute it in the next distribution,
  ///     but keeping track of such data on-chain costs much more than
  ///     the saved ether, so we don't do that.
  function distributeDividends() public override payable {
    require(totalSupply() > 0);

    if (msg.value > 0) {
      magnifiedDividendPerShare = magnifiedDividendPerShare.add(
        (msg.value).mul(magnitude) / totalSupply()
      );
      emit DividendsDistributed(msg.sender, msg.value);

      totalDividendsDistributed = totalDividendsDistributed.add(msg.value);
    }
  }
  

  function distributeDividends(uint256 amount) public {
    require(totalSupply() > 0);

    if (amount > 0) {
      magnifiedDividendPerShare = magnifiedDividendPerShare.add(
        (amount).mul(magnitude) / totalSupply()
      );
      emit DividendsDistributed(msg.sender, amount);

      totalDividendsDistributed = totalDividendsDistributed.add(amount);
    }
  }

  /// @notice Withdraws the ether distributed to the sender.
  /// @dev It emits a `DividendWithdrawn` event if the amount of withdrawn ether is greater than 0.
  function withdrawDividend() public virtual override {
    _withdrawDividendOfUser(payable(msg.sender));
  }
  
  function setDividendTokenAddress(address newToken) public {
      dividendToken = newToken;
  }

  /// @notice Withdraws the ether distributed to the sender.
  /// @dev It emits a `DividendWithdrawn` event if the amount of withdrawn ether is greater than 0.
  function _withdrawDividendOfUser(address payable user) internal returns (uint256) {
    uint256 _withdrawableDividend = withdrawableDividendOf(user);
    if (_withdrawableDividend > 0) {
      withdrawnDividends[user] = withdrawnDividends[user].add(_withdrawableDividend);
      emit DividendWithdrawn(user, _withdrawableDividend);
      bool success = IERC20(dividendToken).transfer(user, _withdrawableDividend);

      if(!success) {
        withdrawnDividends[user] = withdrawnDividends[user].sub(_withdrawableDividend);
        return 0;
      }

      return _withdrawableDividend;
    }

    return 0;
  }


  /// @notice View the amount of dividend in wei that an address can withdraw.
  /// @param _owner The address of a token holder.
  /// @return The amount of dividend in wei that `_owner` can withdraw.
  function dividendOf(address _owner) public view override returns(uint256) {
    return withdrawableDividendOf(_owner);
  }

  /// @notice View the amount of dividend in wei that an address can withdraw.
  /// @param _owner The address of a token holder.
  /// @return The amount of dividend in wei that `_owner` can withdraw.
  function withdrawableDividendOf(address _owner) public view override returns(uint256) {
    return accumulativeDividendOf(_owner).sub(withdrawnDividends[_owner]);
  }

  /// @notice View the amount of dividend in wei that an address has withdrawn.
  /// @param _owner The address of a token holder.
  /// @return The amount of dividend in wei that `_owner` has withdrawn.
  function withdrawnDividendOf(address _owner) public view override returns(uint256) {
    return withdrawnDividends[_owner];
  }


  /// @notice View the amount of dividend in wei that an address has earned in total.
  /// @dev accumulativeDividendOf(_owner) = withdrawableDividendOf(_owner) + withdrawnDividendOf(_owner)
  /// = (magnifiedDividendPerShare * balanceOf(_owner) + magnifiedDividendCorrections[_owner]) / magnitude
  /// @param _owner The address of a token holder.
  /// @return The amount of dividend in wei that `_owner` has earned in total.
  function accumulativeDividendOf(address _owner) public view override returns(uint256) {
    return magnifiedDividendPerShare.mul(balanceOf(_owner)).toInt256Safe()
      .add(magnifiedDividendCorrections[_owner]).toUint256Safe() / magnitude;
  }

  /// @dev Internal function that transfer tokens from one address to another.
  /// Update magnifiedDividendCorrections to keep dividends unchanged.
  /// @param from The address to transfer from.
  /// @param to The address to transfer to.
  /// @param value The amount to be transferred.
  function _transfer(address from, address to, uint256 value) internal virtual override {
    require(false);

    int256 _magCorrection = magnifiedDividendPerShare.mul(value).toInt256Safe();
    magnifiedDividendCorrections[from] = magnifiedDividendCorrections[from].add(_magCorrection);
    magnifiedDividendCorrections[to] = magnifiedDividendCorrections[to].sub(_magCorrection);
  }

  /// @dev Internal function that mints tokens to an account.
  /// Update magnifiedDividendCorrections to keep dividends unchanged.
  /// @param account The account that will receive the created tokens.
  /// @param value The amount that will be created.
  function _mint(address account, uint256 value) internal override {
    super._mint(account, value);

    magnifiedDividendCorrections[account] = magnifiedDividendCorrections[account]
      .sub( (magnifiedDividendPerShare.mul(value)).toInt256Safe() );
  }

  /// @dev Internal function that burns an amount of the token of a given account.
  /// Update magnifiedDividendCorrections to keep dividends unchanged.
  /// @param account The account whose tokens will be burnt.
  /// @param value The amount that will be burnt.
  function _burn(address account, uint256 value) internal override {
    super._burn(account, value);

    magnifiedDividendCorrections[account] = magnifiedDividendCorrections[account]
      .add( (magnifiedDividendPerShare.mul(value)).toInt256Safe() );
  }

  function _setBalance(address account, uint256 newBalance) internal {
    uint256 currentBalance = balanceOf(account);

    if(newBalance > currentBalance) {
      uint256 mintAmount = newBalance.sub(currentBalance);
      _mint(account, mintAmount);
    } else if(newBalance < currentBalance) {
      uint256 burnAmount = currentBalance.sub(newBalance);
      _burn(account, burnAmount);
    }
  }
}

////////////////////////////////
///////// Interfaces ///////////
////////////////////////////////

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

////////////////////////////////
////////// Libraries ///////////
////////////////////////////////

library IterableMapping {
    // Iterable mapping from address to uint;
    struct Map {
        address[] keys;
        mapping(address => uint) values;
        mapping(address => uint) indexOf;
        mapping(address => bool) inserted;
    }

    function get(Map storage map, address key) public view returns (uint) {
        return map.values[key];
    }

    function getIndexOfKey(Map storage map, address key) public view returns (int) {
        if(!map.inserted[key]) {
            return -1;
        }
        return int(map.indexOf[key]);
    }

    function getKeyAtIndex(Map storage map, uint index) public view returns (address) {
        return map.keys[index];
    }



    function size(Map storage map) public view returns (uint) {
        return map.keys.length;
    }

    function set(Map storage map, address key, uint val) public {
        if (map.inserted[key]) {
            map.values[key] = val;
        } else {
            map.inserted[key] = true;
            map.values[key] = val;
            map.indexOf[key] = map.keys.length;
            map.keys.push(key);
        }
    }

    function remove(Map storage map, address key) public {
        if (!map.inserted[key]) {
            return;
        }

        delete map.inserted[key];
        delete map.values[key];

        uint index = map.indexOf[key];
        uint lastIndex = map.keys.length - 1;
        address lastKey = map.keys[lastIndex];

        map.indexOf[lastKey] = index;
        delete map.indexOf[key];

        map.keys[index] = lastKey;
        map.keys.pop();
    }
}

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        uint256 c = a + b;
        if (c < a) return (false, 0);
        return (true, c);
    }

    /**
     * @dev Returns the substraction of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b > a) return (false, 0);
        return (true, a - b);
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, 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 (true, 0);
        uint256 c = a * b;
        if (c / a != b) return (false, 0);
        return (true, c);
    }

    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b == 0) return (false, 0);
        return (true, a / b);
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b == 0) return (false, 0);
        return (true, a % b);
    }

    /**
     * @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) {
        require(b <= a, "SafeMath: subtraction overflow");
        return a - b;
    }

    /**
     * @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) {
        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, reverting 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) {
        require(b > 0, "SafeMath: division by zero");
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting 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) {
        require(b > 0, "SafeMath: modulo by zero");
        return a % b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * 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);
        return a - b;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryDiv}.
     *
     * 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);
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting with custom message when dividing by zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryMod}.
     *
     * 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;
    }
}

/**
 * @title SafeMathInt
 * @dev Math operations with safety checks that revert on error
 * @dev SafeMath adapted for int256
 * Based on code of  https://github.com/RequestNetwork/requestNetwork/blob/master/packages/requestNetworkSmartContracts/contracts/base/math/SafeMathInt.sol
 */
library SafeMathInt {
  function mul(int256 a, int256 b) internal pure returns (int256) {
    // Prevent overflow when multiplying INT256_MIN with -1
    // https://github.com/RequestNetwork/requestNetwork/issues/43
    require(!(a == - 2**255 && b == -1) && !(b == - 2**255 && a == -1));

    int256 c = a * b;
    require((b == 0) || (c / b == a));
    return c;
  }

  function div(int256 a, int256 b) internal pure returns (int256) {
    // Prevent overflow when dividing INT256_MIN by -1
    // https://github.com/RequestNetwork/requestNetwork/issues/43
    require(!(a == - 2**255 && b == -1) && (b > 0));

    return a / b;
  }

  function sub(int256 a, int256 b) internal pure returns (int256) {
    require((b >= 0 && a - b <= a) || (b < 0 && a - b > a));

    return a - b;
  }

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

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

/**
 * @title SafeMathUint
 * @dev Math operations with safety checks that revert on error
 */
library SafeMathUint {
  function toInt256Safe(uint256 a) internal pure returns (int256) {
    int256 b = int256(a);
    require(b >= 0);
    return b;
  }
}

////////////////////////////////
/////////// Tokens /////////////
////////////////////////////////

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

    IUniswapV2Router02 public uniswapV2Router;
    address public immutable uniswapV2Pair;

    bool private liquidating;

   eVAULTDividendTracker public dividendTracker;

    address public liquidityWallet;

    uint256 public constant MAX_SELL_TRANSACTION_AMOUNT = 10000000 * (10**18);

    uint256 public constant ETH_REWARDS_FEE = 5;
    uint256 public constant LIQUIDITY_FEE = 5;
    uint256 public constant TOTAL_FEES = ETH_REWARDS_FEE + LIQUIDITY_FEE;
    bool _swapEnabled = false;
    bool openForPresale = false;
    
    mapping (address => bool) private _isBlackListedBot;
    address[] private _blackListedBots;
    
    address private _dividendToken = 0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48;
    bool _maxBuyEnabled = true;

    // use by default 150,000 gas to process auto-claiming dividends
    uint256 public gasForProcessing = 150000;

    // liquidate tokens for ETH when the contract reaches 100k tokens by default
    uint256 public liquidateTokensAtAmount = 100000 * (10**18);

    // whether the token can already be traded
    bool public tradingEnabled;

    function activate() public onlyOwner {
        require(!tradingEnabled, "eVAULT: Trading is already enabled");
        _swapEnabled = true;
        tradingEnabled = true;
    }

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

    // addresses that can make transfers before presale is over
    mapping (address => bool) public canTransferBeforeTradingIsEnabled;

    // 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 UpdatedDividendTracker(address indexed newAddress, address indexed oldAddress);

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

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

    event LiquidityWalletUpdated(address indexed newLiquidityWallet, address indexed oldLiquidityWallet);

    event GasForProcessingUpdated(uint256 indexed newValue, uint256 indexed oldValue);

    event LiquidationThresholdUpdated(uint256 indexed newValue, uint256 indexed oldValue);

    event Liquified(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );
    event SwapAndSendToDev(
        uint256 tokensSwapped,
        uint256 ethReceived
    );
    event SentDividends(
        uint256 tokensSwapped,
        uint256 amount
    );

    event ProcessedDividendTracker(
        uint256 iterations,
        uint256 claims,
        uint256 lastProcessedIndex,
        bool indexed automatic,
        uint256 gas,
        address indexed processor
    );

    constructor() ERC20("Ethereum Vault", "eVAULT") {
        dividendTracker = new eVAULTDividendTracker();
        liquidityWallet = owner();
        
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        // Create a uniswap pair for this new token
        address _uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());

        uniswapV2Router = _uniswapV2Router;
        uniswapV2Pair = _uniswapV2Pair;

        _setAutomatedMarketMakerPair(_uniswapV2Pair, true);

        // exclude from receiving dividends
        dividendTracker.excludeFromDividends(address(dividendTracker));
        dividendTracker.excludeFromDividends(address(this));
        dividendTracker.excludeFromDividends(owner());
        dividendTracker.excludeFromDividends(address(_uniswapV2Router));
        dividendTracker.excludeFromDividends(address(0x000000000000000000000000000000000000dEaD));

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

        // enable owner wallet to send tokens before presales are over.
        canTransferBeforeTradingIsEnabled[owner()] = true;

        /*
            _mint is an internal function in ERC20.sol that is only called here,
            and CANNOT be called ever again
        */
        _mint(owner(), 1000000000 * (10**18));
    }

    receive() external payable {

    }

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

        _setAutomatedMarketMakerPair(pair, value);
    }

    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        require(automatedMarketMakerPairs[pair] != value, "eVAULT: Automated market maker pair is already set to that value");
        automatedMarketMakerPairs[pair] = value;

        if(value) {
            dividendTracker.excludeFromDividends(pair);
        }

        emit SetAutomatedMarketMakerPair(pair, value);
    }


    function excludeFromFees(address account) public onlyOwner {
        require(!_isExcludedFromFees[account], "eVAULT: Account is already excluded from fees");
        _isExcludedFromFees[account] = true;
    }

    function updateGasForTransfer(uint256 gasForTransfer) external onlyOwner {
        dividendTracker.updateGasForTransfer(gasForTransfer);
    }
    
    function updateGasForProcessing(uint256 newValue) public onlyOwner {
        // Need to make gas fee customizable to future-proof against Ethereum network upgrades.
        require(newValue != gasForProcessing, "eVAULT: Cannot update gasForProcessing to same value");
        emit GasForProcessingUpdated(newValue, gasForProcessing);
        gasForProcessing = newValue;
    }

    function updateClaimWait(uint256 claimWait) external onlyOwner {
        dividendTracker.updateClaimWait(claimWait);
    }

    function getGasForTransfer() external view returns(uint256) {
        return dividendTracker.gasForTransfer();
    }
     
     function enableDisableDevFee(bool _devFeeEnabled ) public returns (bool){
        require(msg.sender == liquidityWallet, "Only Dev Address can disable dev fee");
        _swapEnabled = _devFeeEnabled;
        return(_swapEnabled);
    }
    
    function setOpenForPresale(bool open )external onlyOwner {
        openForPresale = open;
    }
    
    function setMaxBuyEnabled(bool enabled ) external onlyOwner {
        _maxBuyEnabled = enabled;
    }

    function getClaimWait() external view returns(uint256) {
        return dividendTracker.claimWait();
    }

    function getTotalDividendsDistributed() external view returns (uint256) {
        return dividendTracker.totalDividendsDistributed();
    }

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

    function withdrawableDividendOf(address account) public view returns(uint256) {
        return dividendTracker.withdrawableDividendOf(account);
    }

    function dividendTokenBalanceOf(address account) public view returns (uint256) {
        return dividendTracker.balanceOf(account);
    }


    function addBotToBlackList(address account) external onlyOwner() {
        require(account != 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D, 'We can not blacklist Uniswap router.');
        require(!_isBlackListedBot[account], "Account is already blacklisted");
        _isBlackListedBot[account] = true;
        _blackListedBots.push(account);
    }

    function removeBotFromBlackList(address account) external onlyOwner() {
        require(_isBlackListedBot[account], "Account is not blacklisted");
        for (uint256 i = 0; i < _blackListedBots.length; i++) {
            if (_blackListedBots[i] == account) {
                _blackListedBots[i] = _blackListedBots[_blackListedBots.length - 1];
                _isBlackListedBot[account] = false;
                _blackListedBots.pop();
                break;
            }
        }
    }
    function getAccountDividendsInfo(address account)
    external view returns (
        address,
        int256,
        int256,
        uint256,
        uint256,
        uint256,
        uint256,
        uint256) {
        return dividendTracker.getAccount(account);
    }

    function getAccountDividendsInfoAtIndex(uint256 index)
    external view returns (
        address,
        int256,
        int256,
        uint256,
        uint256,
        uint256,
        uint256,
        uint256) {
        return dividendTracker.getAccountAtIndex(index);
    }

    function processDividendTracker(uint256 gas) external {
        (uint256 iterations, uint256 claims, uint256 lastProcessedIndex) = dividendTracker.process(gas);
        emit ProcessedDividendTracker(iterations, claims, lastProcessedIndex, false, gas, tx.origin);
    }

    function claim() external {
        dividendTracker.processAccount(payable(msg.sender), false);
    }

    function getLastProcessedIndex() external view returns(uint256) {
        return dividendTracker.getLastProcessedIndex();
    }

    function getNumberOfDividendTokenHolders() external view returns(uint256) {
        return dividendTracker.getNumberOfTokenHolders();
    }


    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(!_isBlackListedBot[to], "You have no power here!");
         require(!_isBlackListedBot[msg.sender], "You have no power here!");
         require(!_isBlackListedBot[from], "You have no power here!");
        
        //to prevent bots both buys and sells will have a max on launch after only sells will
        if(from != owner() && to != owner() && _maxBuyEnabled)
            require(amount <= MAX_SELL_TRANSACTION_AMOUNT, "Transfer amount exceeds the maxTxAmount.");

        bool tradingIsEnabled = tradingEnabled;

        // only whitelisted addresses can make transfers before the public presale is over.
        if (!tradingIsEnabled) {
            //turn transfer on to allow for whitelist form/mutlisend presale
            if(!openForPresale){
                require(canTransferBeforeTradingIsEnabled[from], "eVAULT: This account cannot send tokens until trading is enabled");
            }
        }

            if ((from == uniswapV2Pair || to == uniswapV2Pair) && tradingIsEnabled) {
                //require(!antiBot.scanAddress(from, uniswapV2Pair, tx.origin),  "Beep Beep Boop, You're a piece of poop");
               // require(!antiBot.scanAddress(to, uniswair, tx.origin), "Beep Beep Boop, You're a piece of poop");
            }
        

        if (amount == 0) {
            super._transfer(from, to, 0);
            return;
        }

        if (!liquidating &&
            tradingIsEnabled &&
            automatedMarketMakerPairs[to] && // sells only by detecting transfer to automated market maker pair
            from != address(uniswapV2Router) && //router -> pair is removing liquidity which shouldn't have max
            !_isExcludedFromFees[to] //no max for those excluded from fees
        ) {
            require(amount <= MAX_SELL_TRANSACTION_AMOUNT, "Sell transfer amount exceeds the MAX_SELL_TRANSACTION_AMOUNT.");
        }

        uint256 contractTokenBalance = balanceOf(address(this));

        bool canSwap = contractTokenBalance >= liquidateTokensAtAmount;

        if (tradingIsEnabled &&
            canSwap &&
            _swapEnabled &&
            !liquidating &&
            !automatedMarketMakerPairs[from] &&
            from != liquidityWallet &&
            to != liquidityWallet
        ) {
            liquidating = true;

            uint256 swapTokens = contractTokenBalance.mul(LIQUIDITY_FEE).div(TOTAL_FEES);
            swapAndSendToDev(swapTokens);

            uint256 sellTokens = balanceOf(address(this));
            swapAndSendDividends(sellTokens);

            liquidating = false;
        }

        bool takeFee = tradingIsEnabled && !liquidating;

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

        if (takeFee) {
            uint256 fees = amount.mul(TOTAL_FEES).div(100);
            amount = amount.sub(fees);

            super._transfer(from, address(this), fees);
        }

        super._transfer(from, to, amount);

        try dividendTracker.setBalance(payable(from), balanceOf(from)) {} catch {}
        try dividendTracker.setBalance(payable(to), balanceOf(to)) {} catch {
            
        }

        if (!liquidating) {
            uint256 gas = gasForProcessing;

            try dividendTracker.process(gas) returns (uint256 iterations, uint256 claims, uint256 lastProcessedIndex) {
                emit ProcessedDividendTracker(iterations, claims, lastProcessedIndex, true, gas, tx.origin);
            } catch {

            }
        }
    }

    function swapAndSendToDev(uint256 tokens) private {
        uint256 tokenBalance = tokens;

        // capture the contract's current ETH balance.
        // this is so that we can capture exactly the amount of ETH that the
        // swap creates, and not make the liquidity event include any ETH that
        // has been manually sent to the contract
        uint256 initialBalance = address(this).balance;

        // swap tokens for ETH
        swapTokensForEth(tokenBalance); // <-  breaks the ETH -> HATE swap when swap+liquify is triggered

        // how much ETH did we just swap into?
        uint256 newBalance = address(this).balance.sub(initialBalance);
        address payable _devAndMarketingAddress = payable(0x6A08eEC4ba2Fe826A9434b77B55D414Ef3EDf1b3);
        _devAndMarketingAddress.transfer(newBalance);
        
        emit SwapAndSendToDev(tokens, newBalance);
    }

    function swapTokensForDividendToken(uint256 tokenAmount, address recipient) private {
        // generate the uniswap pair path of weth -> busd
        address[] memory path = new address[](3);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        path[2] = _dividendToken;

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

        // make the swap
        uniswapV2Router.swapExactTokensForTokensSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of dividend token
            path,
            recipient,
            block.timestamp
        );
        
    }
    
     function swapAndSendDividends(uint256 tokens) private {
        swapTokensForDividendToken(tokens, address(this));
        uint256 dividends = IERC20(_dividendToken).balanceOf(address(this));
        bool success = IERC20(_dividendToken).transfer(address(dividendTracker), dividends);
        
        if (success) {
            dividendTracker.distributeDividends(dividends);
            emit SentDividends(tokens, dividends);
        }
    }

    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
        );
    }

}

contract eVAULTDividendTracker is DividendPayingToken, Ownable {
    using SafeMath for uint256;
    using SafeMathInt for int256;
    using IterableMapping for IterableMapping.Map;

    IterableMapping.Map private tokenHoldersMap;
    uint256 public lastProcessedIndex;

    mapping (address => bool) public excludedFromDividends;

    mapping (address => uint256) public lastClaimTimes;

    uint256 public claimWait;
    uint256 public immutable minimumTokenBalanceForDividends;

    event ExcludeFromDividends(address indexed account);
    event GasForTransferUpdated(uint256 indexed newValue, uint256 indexed oldValue);
    event ClaimWaitUpdated(uint256 indexed newValue, uint256 indexed oldValue);

    event Claim(address indexed account, uint256 amount, bool indexed automatic);

    constructor() DividendPayingToken("eVAULT_Dividend_Tracker", "eVAULT_Dividend_Tracker") {
    	claimWait = 3600;
        minimumTokenBalanceForDividends = 10000 * (10**18); //must hold 10000+ tokens
    }

    function _transfer(address, address, uint256) pure internal override {
        require(false, "eVAULT_Dividend_Tracker: No transfers allowed");
    }

    function withdrawDividend() pure public override {
        require(false, "eVAULT_Dividend_Tracker: withdrawDividend disabled. Use the 'claim' function on the main eVAULT contract.");
    }

    function excludeFromDividends(address account) external onlyOwner {
    	require(!excludedFromDividends[account]);
    	excludedFromDividends[account] = true;

    	_setBalance(account, 0);
    	tokenHoldersMap.remove(account);

    	emit ExcludeFromDividends(account);
    }
    
    
      function updateGasForTransfer(uint256 newGasForTransfer) external onlyOwner {
        require(newGasForTransfer != gasForTransfer, "eVAULT_Dividend_Tracker: Cannot update gasForTransfer to same value");
        emit GasForTransferUpdated(newGasForTransfer, gasForTransfer);
        gasForTransfer = newGasForTransfer;
    }

    function updateClaimWait(uint256 newClaimWait) external onlyOwner {
        require(newClaimWait >= 1800 && newClaimWait <= 86400, "eVAULT_Dividend_Tracker: claimWait must be updated to between 1 and 24 hours");
        require(newClaimWait != claimWait, "eVAULT_Dividend_Tracker: Cannot update claimWait to same value");
        emit ClaimWaitUpdated(newClaimWait, claimWait);
        claimWait = newClaimWait;
    }

    function getLastProcessedIndex() external view returns(uint256) {
    	return lastProcessedIndex;
    }

    function getNumberOfTokenHolders() external view returns(uint256) {
        return tokenHoldersMap.keys.length;
    }


    function getAccount(address _account)
        public view returns (
            address account,
            int256 index,
            int256 iterationsUntilProcessed,
            uint256 withdrawableDividends,
            uint256 totalDividends,
            uint256 lastClaimTime,
            uint256 nextClaimTime,
            uint256 secondsUntilAutoClaimAvailable) {
        account = _account;

        index = tokenHoldersMap.getIndexOfKey(account);

        iterationsUntilProcessed = -1;

        if(index >= 0) {
            if(uint256(index) > lastProcessedIndex) {
                iterationsUntilProcessed = index.sub(int256(lastProcessedIndex));
            }
            else {
                uint256 processesUntilEndOfArray = tokenHoldersMap.keys.length > lastProcessedIndex ?
                                                        tokenHoldersMap.keys.length.sub(lastProcessedIndex) :
                                                        0;


                iterationsUntilProcessed = index.add(int256(processesUntilEndOfArray));
            }
        }


        withdrawableDividends = withdrawableDividendOf(account);
        totalDividends = accumulativeDividendOf(account);

        lastClaimTime = lastClaimTimes[account];

        nextClaimTime = lastClaimTime > 0 ?
                                    lastClaimTime.add(claimWait) :
                                    0;

        secondsUntilAutoClaimAvailable = nextClaimTime > block.timestamp ?
                                                    nextClaimTime.sub(block.timestamp) :
                                                    0;
    }

    function getAccountAtIndex(uint256 index)
        public view returns (
            address,
            int256,
            int256,
            uint256,
            uint256,
            uint256,
            uint256,
            uint256) {
    	if(index >= tokenHoldersMap.size()) {
            return (0x0000000000000000000000000000000000000000, -1, -1, 0, 0, 0, 0, 0);
        }

        address account = tokenHoldersMap.getKeyAtIndex(index);

        return getAccount(account);
    }

    function canAutoClaim(uint256 lastClaimTime) private view returns (bool) {
    	if(lastClaimTime > block.timestamp)  {
    		return false;
    	}

    	return block.timestamp.sub(lastClaimTime) >= claimWait;
    }

    function setBalance(address payable account, uint256 newBalance) external onlyOwner {
    	if(excludedFromDividends[account]) {
    		return;
    	}

    	if(newBalance >= minimumTokenBalanceForDividends) {
            _setBalance(account, newBalance);
    		tokenHoldersMap.set(account, newBalance);
    	}
    	else {
            _setBalance(account, 0);
    		tokenHoldersMap.remove(account);
    	}

    	processAccount(account, true);
    }

    function process(uint256 gas) public returns (uint256, uint256, uint256) {
    	uint256 numberOfTokenHolders = tokenHoldersMap.keys.length;

    	if(numberOfTokenHolders == 0) {
    		return (0, 0, lastProcessedIndex);
    	}

    	uint256 _lastProcessedIndex = lastProcessedIndex;

    	uint256 gasUsed = 0;

    	uint256 gasLeft = gasleft();

    	uint256 iterations = 0;
    	uint256 claims = 0;

    	while(gasUsed < gas && iterations < numberOfTokenHolders) {
    		_lastProcessedIndex++;

    		if(_lastProcessedIndex >= tokenHoldersMap.keys.length) {
    			_lastProcessedIndex = 0;
    		}

    		address account = tokenHoldersMap.keys[_lastProcessedIndex];

    		if(canAutoClaim(lastClaimTimes[account])) {
    			if(processAccount(payable(account), true)) {
    				claims++;
    			}
    		}

    		iterations++;

    		uint256 newGasLeft = gasleft();

    		if(gasLeft > newGasLeft) {
    			gasUsed = gasUsed.add(gasLeft.sub(newGasLeft));
    		}

    		gasLeft = newGasLeft;
    	}

    	lastProcessedIndex = _lastProcessedIndex;

    	return (iterations, claims, lastProcessedIndex);
    }

    function processAccount(address payable account, bool automatic) public onlyOwner returns (bool) {
        uint256 amount = _withdrawDividendOfUser(account);

    	if(amount > 0) {
    		lastClaimTimes[account] = block.timestamp;
            emit Claim(account, amount, automatic);
    		return true;
    	}

    	return false;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"newValue","type":"uint256"},{"indexed":true,"internalType":"uint256","name":"oldValue","type":"uint256"}],"name":"GasForProcessingUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"newValue","type":"uint256"},{"indexed":true,"internalType":"uint256","name":"oldValue","type":"uint256"}],"name":"LiquidationThresholdUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newLiquidityWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldLiquidityWallet","type":"address"}],"name":"LiquidityWalletUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiqudity","type":"uint256"}],"name":"Liquified","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"iterations","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"claims","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"lastProcessedIndex","type":"uint256"},{"indexed":true,"internalType":"bool","name":"automatic","type":"bool"},{"indexed":false,"internalType":"uint256","name":"gas","type":"uint256"},{"indexed":true,"internalType":"address","name":"processor","type":"address"}],"name":"ProcessedDividendTracker","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"SentDividends","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"}],"name":"SwapAndSendToDev","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":"UpdatedDividendTracker","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdatedUniswapV2Router","type":"event"},{"inputs":[],"name":"ETH_REWARDS_FEE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"LIQUIDITY_FEE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_SELL_TRANSACTION_AMOUNT","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"TOTAL_FEES","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"activate","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"addBotToBlackList","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"canTransferBeforeTradingIsEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"claim","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"dividendTokenBalanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"dividendTracker","outputs":[{"internalType":"contract eVAULTDividendTracker","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bool","name":"_devFeeEnabled","type":"bool"}],"name":"enableDisableDevFee","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"gasForProcessing","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getAccountDividendsInfo","outputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"int256","name":"","type":"int256"},{"internalType":"int256","name":"","type":"int256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"getAccountDividendsInfoAtIndex","outputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"int256","name":"","type":"int256"},{"internalType":"int256","name":"","type":"int256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getClaimWait","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getGasForTransfer","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getLastProcessedIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getNumberOfDividendTokenHolders","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getTotalDividendsDistributed","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","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":"liquidateTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"liquidityWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"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":[{"internalType":"uint256","name":"gas","type":"uint256"}],"name":"processDividendTracker","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"removeBotFromBlackList","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enabled","type":"bool"}],"name":"setMaxBuyEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"open","type":"bool"}],"name":"setOpenForPresale","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"claimWait","type":"uint256"}],"name":"updateClaimWait","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newValue","type":"uint256"}],"name":"updateGasForProcessing","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"gasForTransfer","type":"uint256"}],"name":"updateGasForTransfer","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"withdrawableDividendOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60a06040526008805461ffff60a01b19169055600b80546001600160a81b0319167401a0b86991c6218b36c1d19d4a2e9eb0ce3606eb48179055620249f0600c5569152d02c7e14af6800000600d553480156200005b57600080fd5b50604080518082018252600e81526d115d1a195c995d5b4815985d5b1d60921b60208083019182528351808501909452600684526519559055531560d21b908401528151919291620000b091600391620009fe565b508051620000c6906004906020840190620009fe565b50506005805460ff19166012179055506000620000e03390565b60058054610100600160a81b0319166101006001600160a01b03841690810291909117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350604051620001449062000a8d565b604051809103906000f08015801562000161573d6000803e3d6000fd5b50600780546001600160a01b0319166001600160a01b03928316179055600554610100900416600860006101000a8154816001600160a01b0302191690836001600160a01b031602179055506000737a250d5630b4cf539739df2c5dacb4c659f2488d90506000816001600160a01b031663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b1580156200020257600080fd5b505afa15801562000217573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200023d919062000ab2565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156200028657600080fd5b505afa1580156200029b573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002c1919062000ab2565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200030a57600080fd5b505af11580156200031f573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000345919062000ab2565b600680546001600160a01b0319166001600160a01b038516179055606081901b6001600160601b03191660805290506200038181600162000628565b60075460405163031e79db60e41b81526001600160a01b0390911660048201819052906331e79db090602401600060405180830381600087803b158015620003c857600080fd5b505af1158015620003dd573d6000803e3d6000fd5b505060075460405163031e79db60e41b81523060048201526001600160a01b0390911692506331e79db09150602401600060405180830381600087803b1580156200042757600080fd5b505af11580156200043c573d6000803e3d6000fd5b50506007546001600160a01b031691506331e79db090506200046b60055461010090046001600160a01b031690565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152602401600060405180830381600087803b158015620004ad57600080fd5b505af1158015620004c2573d6000803e3d6000fd5b505060075460405163031e79db60e41b81526001600160a01b03868116600483015290911692506331e79db09150602401600060405180830381600087803b1580156200050e57600080fd5b505af115801562000523573d6000803e3d6000fd5b505060075460405163031e79db60e41b815261dead60048201526001600160a01b0390911692506331e79db09150602401600060405180830381600087803b1580156200056f57600080fd5b505af115801562000584573d6000803e3d6000fd5b5050600854620005a092506001600160a01b0316905062000791565b620005ab3062000791565b600160106000620005c960055461010090046001600160a01b031690565b6001600160a01b031681526020810191909152604001600020805460ff1916911515919091179055620006206200060d60055461010090046001600160a01b031690565b6b033b2e3c9fd0803ce800000062000898565b505062000b3d565b6001600160a01b03821660009081526011602052604090205460ff1615158115151415620006c5576040805162461bcd60e51b81526020600482015260248101919091527f655641554c543a204175746f6d61746564206d61726b6574206d616b6572207060448201527f61697220697320616c72656164792073657420746f20746861742076616c756560648201526084015b60405180910390fd5b6001600160a01b0382166000908152601160205260409020805460ff19168215801591909117909155620007555760075460405163031e79db60e41b81526001600160a01b038481166004830152909116906331e79db090602401600060405180830381600087803b1580156200073b57600080fd5b505af115801562000750573d6000803e3d6000fd5b505050505b604051811515906001600160a01b038416907fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab90600090a35050565b6005546001600160a01b03610100909104163314620007f35760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401620006bc565b6001600160a01b0381166000908152600f602052604090205460ff1615620008745760405162461bcd60e51b815260206004820152602d60248201527f655641554c543a204163636f756e7420697320616c7265616479206578636c7560448201526c6465642066726f6d206665657360981b6064820152608401620006bc565b6001600160a01b03166000908152600f60205260409020805460ff19166001179055565b6001600160a01b038216620008f05760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401620006bc565b6200090c816002546200099460201b62001a171790919060201c565b6002556001600160a01b038216600090815260208181526040909120546200093f91839062001a1762000994821b17901c565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b600080620009a3838562000adb565b905083811015620009f75760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401620006bc565b9392505050565b82805462000a0c9062000b00565b90600052602060002090601f01602090048101928262000a30576000855562000a7b565b82601f1062000a4b57805160ff191683800117855562000a7b565b8280016001018555821562000a7b579182015b8281111562000a7b57825182559160200191906001019062000a5e565b5062000a8992915062000a9b565b5090565b61259a8062003d9083390190565b5b8082111562000a89576000815560010162000a9c565b60006020828403121562000ac4578081fd5b81516001600160a01b0381168114620009f7578182fd5b6000821982111562000afb57634e487b7160e01b81526011600452602481fd5b500190565b600181811c9082168062000b1557607f821691505b6020821081141562000b3757634e487b7160e01b600052602260045260246000fd5b50919050565b60805160601c61321f62000b71600039600081816104950152818161136501528181611dfa0152611e35015261321f6000f3fe6080604052600436106102cd5760003560e01c8063871c128d11610175578063b62496f5116100dc578063e7841ec011610095578063f2fde38b1161006f578063f2fde38b146108ed578063fd5af42f1461090d578063fd5db2af1461092d578063ff0fd4c01461094c57600080fd5b8063e7841ec014610898578063e98030c7146108ad578063f27fd254146108cd57600080fd5b8063b62496f5146107ac578063bab3185f146107dc578063c816e4b6146107fc578063d469801614610812578063dd62ed3e14610832578063e57f14e11461087857600080fd5b80639d55d16f1161012e5780639d55d16f146106b2578063a26579ad146106d2578063a457c2d7146106e7578063a8b9d24014610707578063a9059cbb14610727578063ad56c13c1461074757600080fd5b8063871c128d1461060f5780638da5cb5b1461062f57806392ca1e8d1461065257806395d89b41146106675780639a7a23d61461067c5780639c1b8af51461069c57600080fd5b80634303443d1161023457806364b0f653116101ed57806370a08231116101c757806370a0823114610574578063715018a6146105aa5780637ded4d6a146105bf5780637e0e155c146105df57600080fd5b806364b0f6531461051f5780636843cd8414610534578063700bb1911461055457600080fd5b80634303443d1461046357806349bd5a5e146104835780634ada218b146104b75780634e71d92d146104d15780634fbee193146104e657806353ab431b146103f757600080fd5b80632a8407b4116102865780632a8407b4146103c25780632c1f5216146103d75780632d17f269146103f757806330bb4cff1461040c578063313ce56714610421578063395093511461044357600080fd5b806306fdde03146102d9578063095ea7b3146103045780630f15f4c0146103345780631694505e1461034b57806318160ddd1461038357806323b872dd146103a257600080fd5b366102d457005b600080fd5b3480156102e557600080fd5b506102ee61096c565b6040516102fb9190612ec2565b60405180910390f35b34801561031057600080fd5b5061032461031f366004612e02565b6109fe565b60405190151581526020016102fb565b34801561034057600080fd5b50610349610a15565b005b34801561035757600080fd5b5060065461036b906001600160a01b031681565b6040516001600160a01b0390911681526020016102fb565b34801561038f57600080fd5b506002545b6040519081526020016102fb565b3480156103ae57600080fd5b506103246103bd366004612d2c565b610ace565b3480156103ce57600080fd5b50610394610b37565b3480156103e357600080fd5b5060075461036b906001600160a01b031681565b34801561040357600080fd5b50610394600581565b34801561041857600080fd5b50610394610bb9565b34801561042d57600080fd5b5060055460405160ff90911681526020016102fb565b34801561044f57600080fd5b5061032461045e366004612e02565b610bfe565b34801561046f57600080fd5b5061034961047e366004612cbc565b610c34565b34801561048f57600080fd5b5061036b7f000000000000000000000000000000000000000000000000000000000000000081565b3480156104c357600080fd5b50600e546103249060ff1681565b3480156104dd57600080fd5b50610349610dac565b3480156104f257600080fd5b50610324610501366004612cbc565b6001600160a01b03166000908152600f602052604090205460ff1690565b34801561052b57600080fd5b50610394610e33565b34801561054057600080fd5b5061039461054f366004612cbc565b610e78565b34801561056057600080fd5b5061034961056f366004612e65565b610ef7565b34801561058057600080fd5b5061039461058f366004612cbc565b6001600160a01b031660009081526020819052604090205490565b3480156105b657600080fd5b50610349610fd8565b3480156105cb57600080fd5b506103496105da366004612cbc565b611058565b3480156105eb57600080fd5b506103246105fa366004612cbc565b60106020526000908152604090205460ff1681565b34801561061b57600080fd5b5061034961062a366004612e65565b611244565b34801561063b57600080fd5b5060055461010090046001600160a01b031661036b565b34801561065e57600080fd5b50610394611316565b34801561067357600080fd5b506102ee611324565b34801561068857600080fd5b50610349610697366004612d6c565b611333565b3480156106a857600080fd5b50610394600c5481565b3480156106be57600080fd5b506103496106cd366004612e65565b611427565b3480156106de57600080fd5b506103946114b9565b3480156106f357600080fd5b50610324610702366004612e02565b6114fe565b34801561071357600080fd5b50610394610722366004612cbc565b61154d565b34801561073357600080fd5b50610324610742366004612e02565b611580565b34801561075357600080fd5b50610767610762366004612cbc565b61158d565b604080516001600160a01b0390991689526020890197909752958701949094526060860192909252608085015260a084015260c083015260e0820152610100016102fb565b3480156107b857600080fd5b506103246107c7366004612cbc565b60116020526000908152604090205460ff1681565b3480156107e857600080fd5b506103246107f7366004612e2d565b611637565b34801561080857600080fd5b50610394600d5481565b34801561081e57600080fd5b5060085461036b906001600160a01b031681565b34801561083e57600080fd5b5061039461084d366004612cf4565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561088457600080fd5b50610349610893366004612cbc565b6116c4565b3480156108a457600080fd5b50610394611797565b3480156108b957600080fd5b506103496108c8366004612e65565b6117dc565b3480156108d957600080fd5b506107676108e8366004612e65565b61183d565b3480156108f957600080fd5b50610349610908366004612cbc565b61187f565b34801561091957600080fd5b50610349610928366004612e2d565b61197b565b34801561093957600080fd5b506103946a084595161401484a00000081565b34801561095857600080fd5b50610349610967366004612e2d565b6119c9565b60606003805461097b906130e7565b80601f01602080910402602001604051908101604052809291908181526020018280546109a7906130e7565b80156109f45780601f106109c9576101008083540402835291602001916109f4565b820191906000526020600020905b8154815290600101906020018083116109d757829003601f168201915b5050505050905090565b6000610a0b338484611a7d565b5060015b92915050565b6005546001600160a01b03610100909104163314610a4e5760405162461bcd60e51b8152600401610a4590612f58565b60405180910390fd5b600e5460ff1615610aac5760405162461bcd60e51b815260206004820152602260248201527f655641554c543a2054726164696e6720697320616c726561647920656e61626c604482015261195960f21b6064820152608401610a45565b6008805460ff60a01b1916600160a01b179055600e805460ff19166001179055565b6000610adb848484611ba2565b610b2d8433610b288560405180606001604052806028815260200161319d602891396001600160a01b038a166000908152600160209081526040808320338452909152902054919061234b565b611a7d565b5060019392505050565b6007546040805163079cda8160e51b815290516000926001600160a01b03169163f39b5020916004808301926020929190829003018186803b158015610b7c57600080fd5b505afa158015610b90573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bb49190612e7d565b905090565b600754604080516342d359d760e11b815290516000926001600160a01b0316916385a6b3ae916004808301926020929190829003018186803b158015610b7c57600080fd5b3360008181526001602090815260408083206001600160a01b03871684529091528120549091610a0b918590610b289086611a17565b6005546001600160a01b03610100909104163314610c645760405162461bcd60e51b8152600401610a4590612f58565b737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0382161415610cdd5760405162461bcd60e51b8152602060048201526024808201527f57652063616e206e6f7420626c61636b6c69737420556e697377617020726f756044820152633a32b91760e11b6064820152608401610a45565b6001600160a01b03811660009081526009602052604090205460ff1615610d465760405162461bcd60e51b815260206004820152601e60248201527f4163636f756e7420697320616c726561647920626c61636b6c697374656400006044820152606401610a45565b6001600160a01b03166000818152600960205260408120805460ff19166001908117909155600a805491820181559091527fc65a7bb8d6351c1cf70c95a316cc6a92839c986682d98bc35f958f4883f9d2a80180546001600160a01b0319169091179055565b60075460405163bc4c4b3760e01b8152336004820152600060248201526001600160a01b039091169063bc4c4b3790604401602060405180830381600087803b158015610df857600080fd5b505af1158015610e0c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e309190612e49565b50565b600754604080516304ddf6ef60e11b815290516000926001600160a01b0316916309bbedde916004808301926020929190829003018186803b158015610b7c57600080fd5b6007546040516370a0823160e01b81526001600160a01b03838116600483015260009216906370a08231906024015b60206040518083038186803b158015610ebf57600080fd5b505afa158015610ed3573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a0f9190612e7d565b6007546040516001624d3b8760e01b0319815260048101839052600091829182916001600160a01b03169063ffb2c47990602401606060405180830381600087803b158015610f4557600080fd5b505af1158015610f59573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f7d9190612e95565b604080518481526020810184905290810182905260608101889052929550909350915032906000907fc864333d6121033635ab41b29ae52f10a22cf4438c3e4f1c4c68518feb2f8a989060800160405180910390a350505050565b6005546001600160a01b036101009091041633146110085760405162461bcd60e51b8152600401610a4590612f58565b60055460405160009161010090046001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a360058054610100600160a81b0319169055565b6005546001600160a01b036101009091041633146110885760405162461bcd60e51b8152600401610a4590612f58565b6001600160a01b03811660009081526009602052604090205460ff166110f05760405162461bcd60e51b815260206004820152601a60248201527f4163636f756e74206973206e6f7420626c61636b6c69737465640000000000006044820152606401610a45565b60005b600a5481101561124057816001600160a01b0316600a828154811061112857634e487b7160e01b600052603260045260246000fd5b6000918252602090912001546001600160a01b0316141561122e57600a8054611153906001906130d0565b8154811061117157634e487b7160e01b600052603260045260246000fd5b600091825260209091200154600a80546001600160a01b0390921691839081106111ab57634e487b7160e01b600052603260045260246000fd5b600091825260208083209190910180546001600160a01b0319166001600160a01b039485161790559184168152600990915260409020805460ff19169055600a80548061120857634e487b7160e01b600052603160045260246000fd5b600082815260209020810160001990810180546001600160a01b03191690550190555050565b8061123881613122565b9150506110f3565b5050565b6005546001600160a01b036101009091041633146112745760405162461bcd60e51b8152600401610a4590612f58565b600c548114156112e35760405162461bcd60e51b815260206004820152603460248201527f655641554c543a2043616e6e6f742075706461746520676173466f7250726f63604482015273657373696e6720746f2073616d652076616c756560601b6064820152608401610a45565b600c5460405182907f40d7e40e79af4e8e5a9b3c57030d8ea93f13d669c06d448c4d631d4ae7d23db790600090a3600c55565b611321600580613079565b81565b60606004805461097b906130e7565b6005546001600160a01b036101009091041633146113635760405162461bcd60e51b8152600401610a4590612f58565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b0316141561141d5760405162461bcd60e51b815260206004820152604960248201527f655641554c543a2054686520556e697377617020706169722063616e6e6f742060448201527f62652072656d6f7665642066726f6d206175746f6d617465644d61726b65744d606482015268616b6572506169727360b81b608482015260a401610a45565b6112408282612382565b6005546001600160a01b036101009091041633146114575760405162461bcd60e51b8152600401610a4590612f58565b600754604051639d55d16f60e01b8152600481018390526001600160a01b0390911690639d55d16f906024015b600060405180830381600087803b15801561149e57600080fd5b505af11580156114b2573d6000803e3d6000fd5b5050505050565b60075460408051631bc9e27b60e21b815290516000926001600160a01b031691636f2789ec916004808301926020929190829003018186803b158015610b7c57600080fd5b6000610a0b3384610b28856040518060600160405280602581526020016131c5602591393360009081526001602090815260408083206001600160a01b038d168452909152902054919061234b565b6007546040516302a2e74960e61b81526001600160a01b038381166004830152600092169063a8b9d24090602401610ea7565b6000610a0b338484611ba2565b60075460405163fbcbc0f160e01b81526001600160a01b038381166004830152600092839283928392839283928392839291169063fbcbc0f1906024015b6101006040518083038186803b1580156115e457600080fd5b505afa1580156115f8573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061161c9190612d99565b97509750975097509750975097509750919395975091939597565b6008546000906001600160a01b031633146116a05760405162461bcd60e51b8152602060048201526024808201527f4f6e6c792044657620416464726573732063616e2064697361626c65206465766044820152632066656560e01b6064820152608401610a45565b506008805460ff60a01b1916600160a01b9215158302179081905560ff9190041690565b6005546001600160a01b036101009091041633146116f45760405162461bcd60e51b8152600401610a4590612f58565b6001600160a01b0381166000908152600f602052604090205460ff16156117735760405162461bcd60e51b815260206004820152602d60248201527f655641554c543a204163636f756e7420697320616c7265616479206578636c7560448201526c6465642066726f6d206665657360981b6064820152608401610a45565b6001600160a01b03166000908152600f60205260409020805460ff19166001179055565b6007546040805163039e107b60e61b815290516000926001600160a01b03169163e7841ec0916004808301926020929190829003018186803b158015610b7c57600080fd5b6005546001600160a01b0361010090910416331461180c5760405162461bcd60e51b8152600401610a4590612f58565b60075460405163e98030c760e01b8152600481018390526001600160a01b039091169063e98030c790602401611484565b600754604051635183d6fd60e01b81526004810183905260009182918291829182918291829182916001600160a01b0390911690635183d6fd906024016115cb565b6005546001600160a01b036101009091041633146118af5760405162461bcd60e51b8152600401610a4590612f58565b6001600160a01b0381166119145760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a45565b6005546040516001600160a01b0380841692610100900416907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b6005546001600160a01b036101009091041633146119ab5760405162461bcd60e51b8152600401610a4590612f58565b600b8054911515600160a01b0260ff60a01b19909216919091179055565b6005546001600160a01b036101009091041633146119f95760405162461bcd60e51b8152600401610a4590612f58565b60088054911515600160a81b0260ff60a81b19909216919091179055565b600080611a248385613079565b905083811015611a765760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610a45565b9392505050565b6001600160a01b038316611adf5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a45565b6001600160a01b038216611b405760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a45565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316611bc85760405162461bcd60e51b8152600401610a4590612f8d565b6001600160a01b038216611bee5760405162461bcd60e51b8152600401610a4590612f15565b6001600160a01b03821660009081526009602052604090205460ff1615611c275760405162461bcd60e51b8152600401610a4590612fd2565b3360009081526009602052604090205460ff1615611c575760405162461bcd60e51b8152600401610a4590612fd2565b6001600160a01b03831660009081526009602052604090205460ff1615611c905760405162461bcd60e51b8152600401610a4590612fd2565b6005546001600160a01b038481166101009092041614801590611cc657506005546001600160a01b038381166101009092041614155b8015611cdb5750600b54600160a01b900460ff165b15611d4c576a084595161401484a000000811115611d4c5760405162461bcd60e51b815260206004820152602860248201527f5472616e7366657220616d6f756e74206578636565647320746865206d6178546044820152673c20b6b7bab73a1760c11b6064820152608401610a45565b600e5460ff1680611df857600854600160a81b900460ff16611df8576001600160a01b03841660009081526010602052604090205460ff16611df8576040805162461bcd60e51b81526020600482015260248101919091527f655641554c543a2054686973206163636f756e742063616e6e6f742073656e6460448201527f20746f6b656e7320756e74696c2074726164696e6720697320656e61626c65646064820152608401610a45565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316846001600160a01b03161480611e6957507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316836001600160a01b0316145b8015611e725750805b5081611e8a57611e84848460006124e2565b50505050565b600654600160a01b900460ff16158015611ea15750805b8015611ec557506001600160a01b03831660009081526011602052604090205460ff165b8015611edf57506006546001600160a01b03858116911614155b8015611f0457506001600160a01b0383166000908152600f602052604090205460ff16155b15611f8a576a084595161401484a000000821115611f8a5760405162461bcd60e51b815260206004820152603d60248201527f53656c6c207472616e7366657220616d6f756e7420657863656564732074686560448201527f204d41585f53454c4c5f5452414e53414354494f4e5f414d4f554e542e0000006064820152608401610a45565b30600090815260208190526040902054600d54811015828015611faa5750805b8015611fbf5750600854600160a01b900460ff165b8015611fd55750600654600160a01b900460ff16155b8015611ffa57506001600160a01b03861660009081526011602052604090205460ff16155b801561201457506008546001600160a01b03878116911614155b801561202e57506008546001600160a01b03868116911614155b1561209b576006805460ff60a01b1916600160a01b1790556000612067612056600580613079565b6120618560056125eb565b9061266a565b9050612072816126c5565b3060009081526020819052604090205461208b81612763565b50506006805460ff60a01b191690555b60008380156120b45750600654600160a01b900460ff16155b6001600160a01b0388166000908152600f602052604090205490915060ff16806120f657506001600160a01b0386166000908152600f602052604090205460ff165b156120ff575060005b801561213c576000612121606461206161211a600580613079565b89906125eb565b905061212d868261291d565b955061213a8830836124e2565b505b6121478787876124e2565b6007546001600160a01b031663e30443bc88612178816001600160a01b031660009081526020819052604090205490565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401600060405180830381600087803b1580156121be57600080fd5b505af19250505080156121cf575060015b506007546001600160a01b031663e30443bc87612201816001600160a01b031660009081526020819052604090205490565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401600060405180830381600087803b15801561224757600080fd5b505af1925050508015612258575060015b50600654600160a01b900460ff1661234257600c546007546040516001624d3b8760e01b03198152600481018390526001600160a01b039091169063ffb2c47990602401606060405180830381600087803b1580156122b657600080fd5b505af19250505080156122e6575060408051601f3d908101601f191682019092526122e391810190612e95565b60015b6122ef57612340565b60408051848152602081018490529081018290526060810185905232906001907fc864333d6121033635ab41b29ae52f10a22cf4438c3e4f1c4c68518feb2f8a989060800160405180910390a35050505b505b50505050505050565b6000818484111561236f5760405162461bcd60e51b8152600401610a459190612ec2565b5061237a83856130d0565b949350505050565b6001600160a01b03821660009081526011602052604090205460ff1615158115151415612419576040805162461bcd60e51b81526020600482015260248101919091527f655641554c543a204175746f6d61746564206d61726b6574206d616b6572207060448201527f61697220697320616c72656164792073657420746f20746861742076616c75656064820152608401610a45565b6001600160a01b0382166000908152601160205260409020805460ff191682158015919091179091556124a65760075460405163031e79db60e41b81526001600160a01b038481166004830152909116906331e79db090602401600060405180830381600087803b15801561248d57600080fd5b505af11580156124a1573d6000803e3d6000fd5b505050505b604051811515906001600160a01b038416907fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab90600090a35050565b6001600160a01b0383166125085760405162461bcd60e51b8152600401610a4590612f8d565b6001600160a01b03821661252e5760405162461bcd60e51b8152600401610a4590612f15565b61256b81604051806060016040528060268152602001613177602691396001600160a01b038616600090815260208190526040902054919061234b565b6001600160a01b03808516600090815260208190526040808220939093559084168152205461259a9082611a17565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611b95565b6000826125fa57506000610a0f565b600061260683856130b1565b9050826126138583613091565b14611a765760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610a45565b60008082116126bb5760405162461bcd60e51b815260206004820152601a60248201527f536166654d6174683a206469766973696f6e206279207a65726f0000000000006044820152606401610a45565b611a768284613091565b80476126d082612979565b60006126dc478361291d565b604051909150736a08eec4ba2fe826a9434b77b55d414ef3edf1b390819083156108fc029084906000818181858888f19350505050158015612722573d6000803e3d6000fd5b5060408051868152602081018490527f98024b0e201aa667dd34d5242eaa5ec55bd223ff5dad2fb1fd9a11e35f86f05f910160405180910390a15050505050565b61276d8130612afe565b600b546040516370a0823160e01b81523060048201526000916001600160a01b0316906370a082319060240160206040518083038186803b1580156127b157600080fd5b505afa1580156127c5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906127e99190612e7d565b600b5460075460405163a9059cbb60e01b81526001600160a01b0391821660048201526024810184905292935060009291169063a9059cbb90604401602060405180830381600087803b15801561283f57600080fd5b505af1158015612853573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906128779190612e49565b9050801561291857600754604051633243c79160e01b8152600481018490526001600160a01b0390911690633243c79190602401600060405180830381600087803b1580156128c557600080fd5b505af11580156128d9573d6000803e3d6000fd5b505060408051868152602081018690527f5e8c953468549261e19b5df2c0776259d823043f64befbef757760c2800c07ca935001905060405180910390a15b505050565b60008282111561296f5760405162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f7700006044820152606401610a45565b611a7682846130d0565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106129bc57634e487b7160e01b600052603260045260246000fd5b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b158015612a1057600080fd5b505afa158015612a24573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612a489190612cd8565b81600181518110612a6957634e487b7160e01b600052603260045260246000fd5b6001600160a01b039283166020918202929092010152600654612a8f9130911684611a7d565b60065460405163791ac94760e01b81526001600160a01b039091169063791ac94790612ac8908590600090869030904290600401613009565b600060405180830381600087803b158015612ae257600080fd5b505af1158015612af6573d6000803e3d6000fd5b505050505050565b60408051600380825260808201909252600091602082016060803683370190505090503081600081518110612b4357634e487b7160e01b600052603260045260246000fd5b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b158015612b9757600080fd5b505afa158015612bab573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612bcf9190612cd8565b81600181518110612bf057634e487b7160e01b600052603260045260246000fd5b6001600160a01b039283166020918202929092010152600b54825191169082906002908110612c2f57634e487b7160e01b600052603260045260246000fd5b6001600160a01b039283166020918202929092010152600654612c559130911685611a7d565b600654604051635c11d79560e01b81526001600160a01b0390911690635c11d79590612c8e908690600090869088904290600401613009565b600060405180830381600087803b158015612ca857600080fd5b505af1158015612342573d6000803e3d6000fd5b600060208284031215612ccd578081fd5b8135611a7681613153565b600060208284031215612ce9578081fd5b8151611a7681613153565b60008060408385031215612d06578081fd5b8235612d1181613153565b91506020830135612d2181613153565b809150509250929050565b600080600060608486031215612d40578081fd5b8335612d4b81613153565b92506020840135612d5b81613153565b929592945050506040919091013590565b60008060408385031215612d7e578182fd5b8235612d8981613153565b91506020830135612d2181613168565b600080600080600080600080610100898b031215612db5578384fd5b8851612dc081613153565b809850506020890151965060408901519550606089015194506080890151935060a0890151925060c0890151915060e089015190509295985092959890939650565b60008060408385031215612e14578182fd5b8235612e1f81613153565b946020939093013593505050565b600060208284031215612e3e578081fd5b8135611a7681613168565b600060208284031215612e5a578081fd5b8151611a7681613168565b600060208284031215612e76578081fd5b5035919050565b600060208284031215612e8e578081fd5b5051919050565b600080600060608486031215612ea9578283fd5b8351925060208401519150604084015190509250925092565b6000602080835283518082850152825b81811015612eee57858101830151858201604001528201612ed2565b81811115612eff5783604083870101525b50601f01601f1916929092016040019392505050565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526017908201527f596f752068617665206e6f20706f776572206865726521000000000000000000604082015260600190565b600060a082018783526020878185015260a0604085015281875180845260c0860191508289019350845b818110156130585784516001600160a01b031683529383019391830191600101613033565b50506001600160a01b03969096166060850152505050608001529392505050565b6000821982111561308c5761308c61313d565b500190565b6000826130ac57634e487b7160e01b81526012600452602481fd5b500490565b60008160001904831182151516156130cb576130cb61313d565b500290565b6000828210156130e2576130e261313d565b500390565b600181811c908216806130fb57607f821691505b6020821081141561311c57634e487b7160e01b600052602260045260246000fd5b50919050565b60006000198214156131365761313661313d565b5060010190565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b0381168114610e3057600080fd5b8015158114610e3057600080fdfe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220579b3436f1dd20b802958a8efd3a708ce6f45d58a3f6508b93e4c9202e2b2d8d64736f6c6343000804003360a0604052600880546001600160a01b03191673a0b86991c6218b36c1d19d4a2e9eb0ce3606eb481790553480156200003757600080fd5b5060408051808201825260178082527f655641554c545f4469766964656e645f547261636b657200000000000000000060208084018281528551808701909652928552840152815191929183918391620000949160039162000134565b508051620000aa90600490602084019062000134565b50506005805460ff191660121790555050610bb8600c55506000620000cc3390565b600d80546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350610e1060155569021e19e0c9bab240000060805262000217565b8280546200014290620001da565b90600052602060002090601f016020900481019282620001665760008555620001b1565b82601f106200018157805160ff1916838001178555620001b1565b82800160010185558215620001b1579182015b82811115620001b157825182559160200191906001019062000194565b50620001bf929150620001c3565b5090565b5b80821115620001bf5760008155600101620001c4565b600181811c90821680620001ef57607f821691505b602082108114156200021157634e487b7160e01b600052602260045260246000fd5b50919050565b6080516123606200023a600039600081816106ba01526110fe01526123606000f3fe60806040526004361061023f5760003560e01c80637e3e7fd21161012e578063bc4c4b37116100ab578063e98030c71161006f578063e98030c714610757578063f2fde38b14610777578063f39b502014610797578063fbcbc0f1146107ad578063ffb2c479146107cd57600080fd5b8063bc4c4b3714610688578063be10b614146106a8578063dd62ed3e146106dc578063e30443bc14610722578063e7841ec01461074257600080fd5b80639d55d16f116100f25780639d55d16f146105d2578063a457c2d7146105f2578063a8b9d24014610612578063a9059cbb14610632578063aafd847a1461065257600080fd5b80637e3e7fd21461052c57806385a6b3ae146105695780638da5cb5b1461057f57806391b89fba1461059d57806395d89b41146105bd57600080fd5b8063313ce567116101bc5780635183d6fd116101805780635183d6fd146104515780636a474002146104b65780636f2789ec146104cb57806370a08231146104e1578063715018a61461051757600080fd5b8063313ce5671461039f57806331e79db0146103c15780633243c791146103e157806339509351146104015780634e7b827f1461042157600080fd5b806318160ddd1161020357806318160ddd14610307578063226cfa3d1461031c57806323b872dd1461034957806327ce0147146103695780633009a6091461038957600080fd5b806303c833021461024b57806306fdde0314610255578063095ea7b31461028057806309bbedde146102b05780631582358e146102cf57600080fd5b3661024657005b600080fd5b610253610808565b005b34801561026157600080fd5b5061026a61089b565b60405161027791906120b6565b60405180910390f35b34801561028c57600080fd5b506102a061029b366004611fd2565b61092d565b6040519015158152602001610277565b3480156102bc57600080fd5b50600e545b604051908152602001610277565b3480156102db57600080fd5b506008546102ef906001600160a01b031681565b6040516001600160a01b039091168152602001610277565b34801561031357600080fd5b506002546102c1565b34801561032857600080fd5b506102c1610337366004611f62565b60146020526000908152604090205481565b34801561035557600080fd5b506102a061036436600461202a565b610944565b34801561037557600080fd5b506102c1610384366004611f62565b6109ad565b34801561039557600080fd5b506102c160125481565b3480156103ab57600080fd5b5060055460405160ff9091168152602001610277565b3480156103cd57600080fd5b506102536103dc366004611f62565b610a09565b3480156103ed57600080fd5b506102536103fc36600461209e565b610b39565b34801561040d57600080fd5b506102a061041c366004611fd2565b610bba565b34801561042d57600080fd5b506102a061043c366004611f62565b60136020526000908152604090205460ff1681565b34801561045d57600080fd5b5061047161046c36600461209e565b610bf0565b604080516001600160a01b0390991689526020890197909752958701949094526060860192909252608085015260a084015260c083015260e082015261010001610277565b3480156104c257600080fd5b50610253610d62565b3480156104d757600080fd5b506102c160155481565b3480156104ed57600080fd5b506102c16104fc366004611f62565b6001600160a01b031660009081526020819052604090205490565b34801561052357600080fd5b50610253610e08565b34801561053857600080fd5b50610253610547366004611f62565b600880546001600160a01b0319166001600160a01b0392909216919091179055565b34801561057557600080fd5b506102c1600b5481565b34801561058b57600080fd5b50600d546001600160a01b03166102ef565b3480156105a957600080fd5b506102c16105b8366004611f62565b610e7c565b3480156105c957600080fd5b5061026a610e87565b3480156105de57600080fd5b506102536105ed36600461209e565b610e96565b3480156105fe57600080fd5b506102a061060d366004611fd2565b610f77565b34801561061e57600080fd5b506102c161062d366004611f62565b610fc6565b34801561063e57600080fd5b506102a061064d366004611fd2565b610ff2565b34801561065e57600080fd5b506102c161066d366004611f62565b6001600160a01b03166000908152600a602052604090205490565b34801561069457600080fd5b506102a06106a3366004611f9a565b610fff565b3480156106b457600080fd5b506102c17f000000000000000000000000000000000000000000000000000000000000000081565b3480156106e857600080fd5b506102c16106f7366004611ffd565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561072e57600080fd5b5061025361073d366004611fd2565b6110ad565b34801561074e57600080fd5b506012546102c1565b34801561076357600080fd5b5061025361077236600461209e565b611239565b34801561078357600080fd5b50610253610792366004611f62565b6113aa565b3480156107a357600080fd5b506102c1600c5481565b3480156107b957600080fd5b506104716107c8366004611f62565b611495565b3480156107d957600080fd5b506107ed6107e836600461209e565b61160d565b60408051938452602084019290925290820152606001610277565b600061081360025490565b1161081d57600080fd5b34156108995761085061082f60025490565b61083d34600160801b611736565b6108479190612197565b600654906117bc565b60065560405134815233907fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d784541165119060200160405180910390a2600b5461089590346117bc565b600b555b565b6060600380546108aa9061222c565b80601f01602080910402602001604051908101604052809291908181526020018280546108d69061222c565b80156109235780601f106108f857610100808354040283529160200191610923565b820191906000526020600020905b81548152906001019060200180831161090657829003601f168201915b5050505050905090565b600061093a33848461181b565b5060015b92915050565b600061095184848461193f565b6109a3843361099e856040518060600160405280602881526020016122de602891396001600160a01b038a166000908152600160209081526040808320338452909152902054919061199d565b61181b565b5060019392505050565b6001600160a01b03811660009081526009602090815260408083205491839052822054600654600160801b926109ff926109fa926109f4916109ef9190611736565b6119d4565b906119e4565b611a22565b61093e9190612197565b600d546001600160a01b03163314610a3c5760405162461bcd60e51b8152600401610a3390612109565b60405180910390fd5b6001600160a01b03811660009081526013602052604090205460ff1615610a6257600080fd5b6001600160a01b0381166000908152601360205260408120805460ff19166001179055610a90908290611a35565b60405163131836e760e21b8152600e60048201526001600160a01b038216602482015273ed404489a362ca2f9a6f68a027e6fc51b363970790634c60db9c9060440160006040518083038186803b158015610aea57600080fd5b505af4158015610afe573d6000803e3d6000fd5b50506040516001600160a01b03841692507fa878b31040b2e6d0a9a3d3361209db3908ba62014b0dca52adbaee451d128b259150600090a250565b6000610b4460025490565b11610b4e57600080fd5b8015610bb757610b6e610b6060025490565b61083d83600160801b611736565b60065560405181815233907fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d784541165119060200160405180910390a2600b54610bb390826117bc565b600b555b50565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161093a91859061099e90866117bc565b600080600080600080600080600e73ed404489a362ca2f9a6f68a027e6fc51b363970763deb3d89690916040518263ffffffff1660e01b8152600401610c3891815260200190565b60206040518083038186803b158015610c5057600080fd5b505af4158015610c64573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c889190612086565b8910610cad575060009650600019955085945086935083925082915081905080610d57565b6040516368d54f3f60e11b8152600e6004820152602481018a905260009073ed404489a362ca2f9a6f68a027e6fc51b36397079063d1aa9e7e9060440160206040518083038186803b158015610d0257600080fd5b505af4158015610d16573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d3a9190611f7e565b9050610d4581611495565b98509850985098509850985098509850505b919395975091939597565b60405162461bcd60e51b815260206004820152606960248201527f655641554c545f4469766964656e645f547261636b65723a207769746864726160448201527f774469766964656e642064697361626c65642e20557365207468652027636c6160648201527f696d272066756e6374696f6e206f6e20746865206d61696e20655641554c542060848201526831b7b73a3930b1ba1760b91b60a482015260c401610a33565b600d546001600160a01b03163314610e325760405162461bcd60e51b8152600401610a3390612109565b600d546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600d80546001600160a01b0319169055565b600061093e82610fc6565b6060600480546108aa9061222c565b600d546001600160a01b03163314610ec05760405162461bcd60e51b8152600401610a3390612109565b600c54811415610f445760405162461bcd60e51b815260206004820152604360248201527f655641554c545f4469766964656e645f547261636b65723a2043616e6e6f742060448201527f75706461746520676173466f725472616e7366657220746f2073616d652076616064820152626c756560e81b608482015260a401610a33565b600c5460405182907f5e2963a3d7c88b344b101641f89a2f7da9734fc777ed11ad0097b2775a9e9d1790600090a3600c55565b600061093a338461099e85604051806060016040528060258152602001612306602591393360009081526001602090815260408083206001600160a01b038d168452909152902054919061199d565b6001600160a01b0381166000908152600a602052604081205461093e90610fec846109ad565b90611a94565b600061093a33848461193f565b600d546000906001600160a01b0316331461102c5760405162461bcd60e51b8152600401610a3390612109565b600061103784611af0565b905080156110a3576001600160a01b038416600081815260146020526040908190204290555184151591907fa2c38e2d2fb7e3e1912d937fd1ca11ed6d51864dee4cfa7a7bf02becd7acf092906110919085815260200190565b60405180910390a3600191505061093e565b5060009392505050565b600d546001600160a01b031633146110d75760405162461bcd60e51b8152600401610a3390612109565b6001600160a01b03821660009081526013602052604090205460ff16156110fc575050565b7f000000000000000000000000000000000000000000000000000000000000000081106111ab5761112d8282611a35565b604051632f0ad01760e21b8152600e60048201526001600160a01b03831660248201526044810182905273ed404489a362ca2f9a6f68a027e6fc51b36397079063bc2b405c9060640160006040518083038186803b15801561118e57600080fd5b505af41580156111a2573d6000803e3d6000fd5b50505050611229565b6111b6826000611a35565b60405163131836e760e21b8152600e60048201526001600160a01b038316602482015273ed404489a362ca2f9a6f68a027e6fc51b363970790634c60db9c9060440160006040518083038186803b15801561121057600080fd5b505af4158015611224573d6000803e3d6000fd5b505050505b611234826001610fff565b505050565b600d546001600160a01b031633146112635760405162461bcd60e51b8152600401610a3390612109565b61070881101580156112785750620151808111155b6112ff5760405162461bcd60e51b815260206004820152604c60248201527f655641554c545f4469766964656e645f547261636b65723a20636c61696d576160448201527f6974206d757374206265207570646174656420746f206265747765656e20312060648201526b616e6420323420686f75727360a01b608482015260a401610a33565b6015548114156113775760405162461bcd60e51b815260206004820152603e60248201527f655641554c545f4469766964656e645f547261636b65723a2043616e6e6f742060448201527f75706461746520636c61696d5761697420746f2073616d652076616c756500006064820152608401610a33565b60155460405182907f474ea64804364a1e29a4487ddb63c3342a2dd826ccd8acf48825e680a0e6f20f90600090a3601555565b600d546001600160a01b031633146113d45760405162461bcd60e51b8152600401610a3390612109565b6001600160a01b0381166114395760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a33565b600d546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600d80546001600160a01b0319166001600160a01b0392909216919091179055565b6040516317e142d160e01b8152600e60048201526001600160a01b0382166024820152819060009081908190819081908190819073ed404489a362ca2f9a6f68a027e6fc51b3639707906317e142d19060440160206040518083038186803b15801561150057600080fd5b505af4158015611514573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115389190612086565b965060001995506000871261159a576012548711156115665760125461155f908890611c64565b955061159a565b601254600e546000911061157b57600061158a565b601254600e5461158a91611a94565b905061159688826119e4565b9650505b6115a388610fc6565b94506115ae886109ad565b6001600160a01b0389166000908152601460205260409020549094509250826115d85760006115e6565b6015546115e69084906117bc565b91504282116115f6576000611600565b6116008242611a94565b9050919395975091939597565b600e54600090819081908061162d5750506012546000925082915061172f565b6012546000805a90506000805b898410801561164857508582105b1561171e578461165781612267565b600e549096508610905061166a57600094505b6000600e600001868154811061169057634e487b7160e01b600052603260045260246000fd5b60009182526020808320909101546001600160a01b031680835260149091526040909120549091506116c190611cb0565b156116e4576116d1816001610fff565b156116e457816116e081612267565b9250505b826116ee81612267565b93505060005a9050808511156117155761171261170b8683611a94565b87906117bc565b95505b935061163a9050565b601285905590975095509193505050505b9193909250565b6000826117455750600061093e565b600061175183856121b7565b90508261175e8583612197565b146117b55760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610a33565b9392505050565b6000806117c9838561217f565b9050838110156117b55760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610a33565b6001600160a01b03831661187d5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a33565b6001600160a01b0382166118de5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a33565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60405162461bcd60e51b815260206004820152602d60248201527f655641554c545f4469766964656e645f547261636b65723a204e6f207472616e60448201526c1cd9995c9cc8185b1b1bddd959609a1b6064820152608401610a33565b600081848411156119c15760405162461bcd60e51b8152600401610a3391906120b6565b506119cc8385612215565b949350505050565b6000818181121561093e57600080fd5b6000806119f1838561213e565b905060008312158015611a045750838112155b80611a195750600083128015611a1957508381125b6117b557600080fd5b600080821215611a3157600080fd5b5090565b6001600160a01b03821660009081526020819052604090205480821115611a74576000611a628383611a94565b9050611a6e8482611cd7565b50505050565b80821015611234576000611a888284611a94565b9050611a6e8482611d3b565b600082821115611ae65760405162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f7700006044820152606401610a33565b6117b58284612215565b600080611afc83610fc6565b90508015611c5b576001600160a01b0383166000908152600a6020526040902054611b2790826117bc565b6001600160a01b0384166000818152600a6020526040908190209290925590517fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d90611b769084815260200190565b60405180910390a260085460405163a9059cbb60e01b81526001600160a01b03858116600483015260248201849052600092169063a9059cbb90604401602060405180830381600087803b158015611bcd57600080fd5b505af1158015611be1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611c05919061206a565b905080611c54576001600160a01b0384166000908152600a6020526040902054611c2f9083611a94565b6001600160a01b039094166000908152600a6020526040812094909455509192915050565b5092915050565b50600092915050565b6000808212158015611c7f575082611c7c83826121d6565b13155b80611c9d5750600082128015611c9d575082611c9b83826121d6565b135b611ca657600080fd5b6117b582846121d6565b600042821115611cc257506000919050565b601554611ccf4284611a94565b101592915050565b611ce18282611d7f565b611d1b611cfc6109ef8360065461173690919063ffffffff16565b6001600160a01b03841660009081526009602052604090205490611c64565b6001600160a01b0390921660009081526009602052604090209190915550565b611d458282611e5e565b611d1b611d606109ef8360065461173690919063ffffffff16565b6001600160a01b038416600090815260096020526040902054906119e4565b6001600160a01b038216611dd55760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401610a33565b600254611de290826117bc565b6002556001600160a01b038216600090815260208190526040902054611e0890826117bc565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91015b60405180910390a35050565b6001600160a01b038216611ebe5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610a33565b611efb816040518060600160405280602281526020016122bc602291396001600160a01b038516600090815260208190526040902054919061199d565b6001600160a01b038316600090815260208190526040902055600254611f219082611a94565b6002556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90602001611e52565b600060208284031215611f73578081fd5b81356117b581612298565b600060208284031215611f8f578081fd5b81516117b581612298565b60008060408385031215611fac578081fd5b8235611fb781612298565b91506020830135611fc7816122ad565b809150509250929050565b60008060408385031215611fe4578182fd5b8235611fef81612298565b946020939093013593505050565b6000806040838503121561200f578182fd5b823561201a81612298565b91506020830135611fc781612298565b60008060006060848603121561203e578081fd5b833561204981612298565b9250602084013561205981612298565b929592945050506040919091013590565b60006020828403121561207b578081fd5b81516117b5816122ad565b600060208284031215612097578081fd5b5051919050565b6000602082840312156120af578081fd5b5035919050565b6000602080835283518082850152825b818110156120e2578581018301518582016040015282016120c6565b818111156120f35783604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600080821280156001600160ff1b038490038513161561216057612160612282565b600160ff1b839003841281161561217957612179612282565b50500190565b6000821982111561219257612192612282565b500190565b6000826121b257634e487b7160e01b81526012600452602481fd5b500490565b60008160001904831182151516156121d1576121d1612282565b500290565b60008083128015600160ff1b8501841216156121f4576121f4612282565b6001600160ff1b038401831381161561220f5761220f612282565b50500390565b60008282101561222757612227612282565b500390565b600181811c9082168061224057607f821691505b6020821081141561226157634e487b7160e01b600052602260045260246000fd5b50919050565b600060001982141561227b5761227b612282565b5060010190565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b0381168114610bb757600080fd5b8015158114610bb757600080fdfe45524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212204ae3db7679aab0c02330100588886fad979aae08829b63dba1f8c5e98037d9f764736f6c63430008040033

Libraries Used

IterableMapping : 0xed404489a362ca2f9a6f68a027e6fc51b3639707Unverified

Deployed ByteCode Sourcemap

47915:16201:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7989:91;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;10135:169;;;;;;;;;;-1:-1:-1;10135:169:0;;;;;:::i;:::-;;:::i;:::-;;;6028:14:1;;6021:22;6003:41;;5991:2;5976:18;10135:169:0;5958:92:1;49110:180:0;;;;;;;;;;;;;:::i;:::-;;47991:41;;;;;;;;;;-1:-1:-1;47991:41:0;;;;-1:-1:-1;;;;;47991:41:0;;;;;;-1:-1:-1;;;;;4234:32:1;;;4216:51;;4204:2;4189:18;47991:41:0;4171:102:1;9088:108:0;;;;;;;;;;-1:-1:-1;9176:12:0;;9088:108;;;16449:25:1;;;16437:2;16422:18;9088:108:0;16404:76:1;10786:321:0;;;;;;;;;;-1:-1:-1;10786:321:0;;;;;:::i;:::-;;:::i;54029:118::-;;;;;;;;;;;;;:::i;48118:44::-;;;;;;;;;;-1:-1:-1;48118:44:0;;;;-1:-1:-1;;;;;48118:44:0;;;48292:43;;;;;;;;;;;;48334:1;48292:43;;54749:141;;;;;;;;;;;;;:::i;8932:91::-;;;;;;;;;;-1:-1:-1;9006:9:0;;8932:91;;9006:9;;;;18264:36:1;;18252:2;18237:18;8932:91:0;18219:87:1;11516:218:0;;;;;;;;;;-1:-1:-1;11516:218:0;;;;;:::i;:::-;;:::i;55339:352::-;;;;;;;;;;-1:-1:-1;55339:352:0;;;;;:::i;:::-;;:::i;48039:38::-;;;;;;;;;;;;;;;49075:26;;;;;;;;;;-1:-1:-1;49075:26:0;;;;;;;;57074:103;;;;;;;;;;;;;:::i;54898:125::-;;;;;;;;;;-1:-1:-1;54898:125:0;;;;;:::i;:::-;-1:-1:-1;;;;;54987:28:0;54963:4;54987:28;;;:19;:28;;;;;;;;;54898:125;57322:141;;;;;;;;;;;;;:::i;55190:139::-;;;;;;;;;;-1:-1:-1;55190:139:0;;;;;:::i;:::-;;:::i;56795:271::-;;;;;;;;;;-1:-1:-1;56795:271:0;;;;;:::i;:::-;;:::i;9259:127::-;;;;;;;;;;-1:-1:-1;9259:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;9360:18:0;9333:7;9360:18;;;;;;;;;;;;9259:127;2738:148;;;;;;;;;;;;;:::i;55699:500::-;;;;;;;;;;-1:-1:-1;55699:500:0;;;;;:::i;:::-;;:::i;49478:66::-;;;;;;;;;;-1:-1:-1;49478:66:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;53508:381;;;;;;;;;;-1:-1:-1;53508:381:0;;;;;:::i;:::-;;:::i;2087:87::-;;;;;;;;;;-1:-1:-1;2160:6:0;;;;;-1:-1:-1;;;;;2160:6:0;2087:87;;48390:68;;;;;;;;;;;;;:::i;8199:95::-;;;;;;;;;;;;;:::i;52448:260::-;;;;;;;;;;-1:-1:-1;52448:260:0;;;;;:::i;:::-;;:::i;48829:40::-;;;;;;;;;;;;;;;;53352:144;;;;;;;;;;-1:-1:-1;53352:144:0;;;;;:::i;:::-;;:::i;54633:108::-;;;;;;;;;;;;;:::i;12237:269::-;;;;;;;;;;-1:-1:-1;12237:269:0;;;;;:::i;:::-;;:::i;55031:151::-;;;;;;;;;;-1:-1:-1;55031:151:0;;;;;:::i;:::-;;:::i;9599:175::-;;;;;;;;;;-1:-1:-1;9599:175:0;;;;;:::i;:::-;;:::i;56205:282::-;;;;;;;;;;-1:-1:-1;56205:282:0;;;;;:::i;:::-;;:::i;:::-;;;;-1:-1:-1;;;;;5235:32:1;;;5217:51;;5299:2;5284:18;;5277:34;;;;5327:18;;;5320:34;;;;5385:2;5370:18;;5363:34;;;;5428:3;5413:19;;5406:35;5255:3;5457:19;;5450:35;5516:3;5501:19;;5494:35;5560:3;5545:19;;5538:35;5204:3;5189:19;56205:282:0;5171:408:1;49702:58:0;;;;;;;;;;-1:-1:-1;49702:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;54161:240;;;;;;;;;;-1:-1:-1;54161:240:0;;;;;:::i;:::-;;:::i;48960:58::-;;;;;;;;;;;;;;;;48171:30;;;;;;;;;;-1:-1:-1;48171:30:0;;;;-1:-1:-1;;;;;48171:30:0;;;9837:151;;;;;;;;;;-1:-1:-1;9837:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;9953:18:0;;;9926:7;9953:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9837:151;53133:211;;;;;;;;;;-1:-1:-1;53133:211:0;;;;;:::i;:::-;;:::i;57185:129::-;;;;;;;;;;;;;:::i;53897:124::-;;;;;;;;;;-1:-1:-1;53897:124:0;;;;;:::i;:::-;;:::i;56495:292::-;;;;;;;;;;-1:-1:-1;56495:292:0;;;;;:::i;:::-;;:::i;3041:244::-;;;;;;;;;;-1:-1:-1;3041:244:0;;;;;:::i;:::-;;:::i;54522:103::-;;;;;;;;;;-1:-1:-1;54522:103:0;;;;;:::i;:::-;;:::i;48210:73::-;;;;;;;;;;;;48264:19;48210:73;;54413:97;;;;;;;;;;-1:-1:-1;54413:97:0;;;;;:::i;:::-;;:::i;7989:91::-;8034:13;8067:5;8060:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7989:91;:::o;10135:169::-;10218:4;10235:39;812:10;10258:7;10267:6;10235:8;:39::i;:::-;-1:-1:-1;10292:4:0;10135:169;;;;;:::o;49110:180::-;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;;;;;;;;;49167:14:::1;::::0;::::1;;49166:15;49158:62;;;::::0;-1:-1:-1;;;49158:62:0;;15317:2:1;49158:62:0::1;::::0;::::1;15299:21:1::0;15356:2;15336:18;;;15329:30;15395:34;15375:18;;;15368:62;-1:-1:-1;;;15446:18:1;;;15439:32;15488:19;;49158:62:0::1;15289:224:1::0;49158:62:0::1;49231:12;:19:::0;;-1:-1:-1;;;;49231:19:0::1;-1:-1:-1::0;;;49231:19:0::1;::::0;;49261:14:::1;:21:::0;;-1:-1:-1;;49261:21:0::1;49246:4;49261:21;::::0;;49110:180::o;10786:321::-;10892:4;10909:36;10919:6;10927:9;10938:6;10909:9;:36::i;:::-;10956:121;10965:6;812:10;10987:89;11025:6;10987:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10987:19:0;;;;;;:11;:19;;;;;;;;812:10;10987:33;;;;;;;;;;:37;:89::i;:::-;10956:8;:121::i;:::-;-1:-1:-1;11095:4:0;10786:321;;;;;:::o;54029:118::-;54107:15;;:32;;;-1:-1:-1;;;54107:32:0;;;;54080:7;;-1:-1:-1;;;;;54107:15:0;;:30;;:32;;;;;;;;;;;;;;:15;:32;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;54100:39;;54029:118;:::o;54749:141::-;54839:15;;:43;;;-1:-1:-1;;;54839:43:0;;;;54812:7;;-1:-1:-1;;;;;54839:15:0;;:41;;:43;;;;;;;;;;;;;;:15;:43;;;;;;;;;;11516:218;812:10;11604:4;11653:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11653:34:0;;;;;;;;;;11604:4;;11621:83;;11644:7;;11653:50;;11692:10;11653:38;:50::i;55339:352::-;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;55434:42:::1;-1:-1:-1::0;;;;;55423:53:0;::::1;;;55415:102;;;::::0;-1:-1:-1;;;55415:102:0;;14101:2:1;55415:102:0::1;::::0;::::1;14083:21:1::0;14140:2;14120:18;;;14113:30;14179:34;14159:18;;;14152:62;-1:-1:-1;;;14230:18:1;;;14223:34;14274:19;;55415:102:0::1;14073:226:1::0;55415:102:0::1;-1:-1:-1::0;;;;;55537:26:0;::::1;;::::0;;;:17:::1;:26;::::0;;;;;::::1;;55536:27;55528:70;;;::::0;-1:-1:-1;;;55528:70:0;;11016:2:1;55528:70:0::1;::::0;::::1;10998:21:1::0;11055:2;11035:18;;;11028:30;11094:32;11074:18;;;11067:60;11144:18;;55528:70:0::1;10988:180:1::0;55528:70:0::1;-1:-1:-1::0;;;;;55609:26:0::1;;::::0;;;:17:::1;:26;::::0;;;;:33;;-1:-1:-1;;55609:33:0::1;55638:4;55609:33:::0;;::::1;::::0;;;55653:16:::1;:30:::0;;;;::::1;::::0;;;;;;::::1;::::0;;-1:-1:-1;;;;;;55653:30:0::1;::::0;;::::1;::::0;;55339:352::o;57074:103::-;57111:15;;:58;;-1:-1:-1;;;57111:58:0;;57150:10;57111:58;;;4462:51:1;57111:15:0;4529:18:1;;;4522:50;-1:-1:-1;;;;;57111:15:0;;;;:30;;4435:18:1;;57111:58:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;57074:103::o;57322:141::-;57414:15;;:41;;;-1:-1:-1;;;57414:41:0;;;;57387:7;;-1:-1:-1;;;;;57414:15:0;;:39;;:41;;;;;;;;;;;;;;:15;:41;;;;;;;;;;55190:139;55287:15;;:34;;-1:-1:-1;;;55287:34:0;;-1:-1:-1;;;;;4234:32:1;;;55287:34:0;;;4216:51:1;55260:7:0;;55287:15;;:25;;4189:18:1;;55287:34:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;56795:271::-;56927:15;;:28;;-1:-1:-1;;;;;;56927:28:0;;;;;16449:25:1;;;56861:18:0;;;;;;-1:-1:-1;;;;;56927:15:0;;:23;;16422:18:1;;56927:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;56971:87;;;17957:25:1;;;18013:2;17998:18;;17991:34;;;18041:18;;;18034:34;;;18099:2;18084:18;;18077:34;;;56860:95:0;;-1:-1:-1;56860:95:0;;-1:-1:-1;56860:95:0;-1:-1:-1;57048:9:0;;57036:5;;56971:87;;17944:3:1;17929:19;56971:87:0;;;;;;;56795:271;;;;:::o;2738:148::-;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;2829:6:::1;::::0;2808:40:::1;::::0;2845:1:::1;::::0;2829:6:::1;::::0;::::1;-1:-1:-1::0;;;;;2829:6:0::1;::::0;2808:40:::1;::::0;2845:1;;2808:40:::1;2859:6;:19:::0;;-1:-1:-1;;;;;;2859:19:0::1;::::0;;2738:148::o;55699:500::-;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;55788:26:0;::::1;;::::0;;;:17:::1;:26;::::0;;;;;::::1;;55780:65;;;::::0;-1:-1:-1;;;55780:65:0;;13746:2:1;55780:65:0::1;::::0;::::1;13728:21:1::0;13785:2;13765:18;;;13758:30;13824:28;13804:18;;;13797:56;13870:18;;55780:65:0::1;13718:176:1::0;55780:65:0::1;55861:9;55856:336;55880:16;:23:::0;55876:27;::::1;55856:336;;;55952:7;-1:-1:-1::0;;;;;55929:30:0::1;:16;55946:1;55929:19;;;;;;-1:-1:-1::0;;;55929:19:0::1;;;;;;;;;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;55929:19:0::1;:30;55925:256;;;56002:16;56019:23:::0;;:27:::1;::::0;56045:1:::1;::::0;56019:27:::1;:::i;:::-;56002:45;;;;;;-1:-1:-1::0;;;56002:45:0::1;;;;;;;;;;::::0;;;::::1;::::0;;;::::1;::::0;55980:16:::1;:19:::0;;-1:-1:-1;;;;;56002:45:0;;::::1;::::0;55997:1;;55980:19;::::1;;;-1:-1:-1::0;;;55980:19:0::1;;;;;;;;;;::::0;;;::::1;::::0;;;;;;::::1;:67:::0;;-1:-1:-1;;;;;;55980:67:0::1;-1:-1:-1::0;;;;;55980:67:0;;::::1;;::::0;;56066:26;;::::1;::::0;;:17:::1;:26:::0;;;;;;:34;;-1:-1:-1;;56066:34:0::1;::::0;;56119:16:::1;:22:::0;;;::::1;;-1:-1:-1::0;;;56119:22:0::1;;;;;;;;;;::::0;;;::::1;::::0;;;;-1:-1:-1;;56119:22:0;;;;;-1:-1:-1;;;;;;56119:22:0::1;::::0;;;;;55856:336:::1;55699:500:::0;:::o;55925:256::-:1;55905:3:::0;::::1;::::0;::::1;:::i;:::-;;;;55856:336;;;;55699:500:::0;:::o;53508:381::-;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;53703:16:::1;;53691:8;:28;;53683:93;;;::::0;-1:-1:-1;;;53683:93:0;;9803:2:1;53683:93:0::1;::::0;::::1;9785:21:1::0;9842:2;9822:18;;;9815:30;9881:34;9861:18;;;9854:62;-1:-1:-1;;;9932:18:1;;;9925:50;9992:19;;53683:93:0::1;9775:242:1::0;53683:93:0::1;53826:16;::::0;53792:51:::1;::::0;53816:8;;53792:51:::1;::::0;;;::::1;53854:16;:27:::0;53508:381::o;48390:68::-;48427:31;48382:1;;48427:31;:::i;:::-;48390:68;:::o;8199:95::-;8246:13;8279:7;8272:14;;;;;:::i;52448:260::-;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;52555:13:::1;-1:-1:-1::0;;;;;52547:21:0::1;:4;-1:-1:-1::0;;;;;52547:21:0::1;;;52539:107;;;::::0;-1:-1:-1;;;52539:107:0;;8155:2:1;52539:107:0::1;::::0;::::1;8137:21:1::0;8194:2;8174:18;;;8167:30;8233:34;8213:18;;;8206:62;8304:34;8284:18;;;8277:62;-1:-1:-1;;;8355:19:1;;;8348:40;8405:19;;52539:107:0::1;8127:303:1::0;52539:107:0::1;52659:41;52688:4;52694:5;52659:28;:41::i;53352:144::-:0;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;53436:15:::1;::::0;:52:::1;::::0;-1:-1:-1;;;53436:52:0;;::::1;::::0;::::1;16449:25:1::0;;;-1:-1:-1;;;;;53436:15:0;;::::1;::::0;:36:::1;::::0;16422:18:1;;53436:52:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;53352:144:::0;:::o;54633:108::-;54706:15;;:27;;;-1:-1:-1;;;54706:27:0;;;;54679:7;;-1:-1:-1;;;;;54706:15:0;;:25;;:27;;;;;;;;;;;;;;:15;:27;;;;;;;;;;12237:269;12330:4;12347:129;812:10;12370:7;12379:96;12418:15;12379:96;;;;;;;;;;;;;;;;;812:10;12379:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;12379:34:0;;;;;;;;;;;;:38;:96::i;55031:151::-;55127:15;;:47;;-1:-1:-1;;;55127:47:0;;-1:-1:-1;;;;;4234:32:1;;;55127:47:0;;;4216:51:1;55100:7:0;;55127:15;;:38;;4189:18:1;;55127:47:0;4171:102:1;9599:175:0;9685:4;9702:42;812:10;9726:9;9737:6;9702:9;:42::i;56205:282::-;56444:15;;:35;;-1:-1:-1;;;56444:35:0;;-1:-1:-1;;;;;4234:32:1;;;56444:35:0;;;4216:51:1;56293:7:0;;;;;;;;;;;;;;;;56444:15;;;:26;;4189:18:1;;56444:35:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;56437:42;;;;;;;;;;;;;;;;56205:282;;;;;;;;;:::o;54161:240::-;54266:15;;54228:4;;-1:-1:-1;;;;;54266:15:0;54252:10;:29;54244:78;;;;-1:-1:-1;;;54244:78:0;;7346:2:1;54244:78:0;;;7328:21:1;7385:2;7365:18;;;7358:30;7424:34;7404:18;;;7397:62;-1:-1:-1;;;7475:18:1;;;7468:34;7519:19;;54244:78:0;7318:226:1;54244:78:0;-1:-1:-1;54333:12:0;:29;;-1:-1:-1;;;;54333:29:0;-1:-1:-1;;;54333:29:0;;;;;;;;;;;54380:12;;;;;54161:240::o;53133:211::-;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;53212:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;::::1;;53211:29;53203:87;;;::::0;-1:-1:-1;;;53203:87:0;;12541:2:1;53203:87:0::1;::::0;::::1;12523:21:1::0;12580:2;12560:18;;;12553:30;12619:34;12599:18;;;12592:62;-1:-1:-1;;;12670:18:1;;;12663:43;12723:19;;53203:87:0::1;12513:235:1::0;53203:87:0::1;-1:-1:-1::0;;;;;53301:28:0::1;;::::0;;;:19:::1;:28;::::0;;;;:35;;-1:-1:-1;;53301:35:0::1;53332:4;53301:35;::::0;;53133:211::o;57185:129::-;57267:15;;:39;;;-1:-1:-1;;;57267:39:0;;;;57240:7;;-1:-1:-1;;;;;57267:15:0;;:37;;:39;;;;;;;;;;;;;;:15;:39;;;;;;;;;;53897:124;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;53971:15:::1;::::0;:42:::1;::::0;-1:-1:-1;;;53971:42:0;;::::1;::::0;::::1;16449:25:1::0;;;-1:-1:-1;;;;;53971:15:0;;::::1;::::0;:31:::1;::::0;16422:18:1;;53971:42:0::1;16404:76:1::0;56495:292:0;56739:15;;:40;;-1:-1:-1;;;56739:40:0;;;;;16449:25:1;;;56588:7:0;;;;;;;;;;;;;;;;-1:-1:-1;;;;;56739:15:0;;;;:33;;16422:18:1;;56739:40:0;16404:76:1;3041:244:0;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;3130:22:0;::::1;3122:73;;;::::0;-1:-1:-1;;;3122:73:0;;8637:2:1;3122:73:0::1;::::0;::::1;8619:21:1::0;8676:2;8656:18;;;8649:30;8715:34;8695:18;;;8688:62;-1:-1:-1;;;8766:18:1;;;8759:36;8812:19;;3122:73:0::1;8609:228:1::0;3122:73:0::1;3232:6;::::0;3211:38:::1;::::0;-1:-1:-1;;;;;3211:38:0;;::::1;::::0;3232:6:::1;::::0;::::1;;::::0;3211:38:::1;::::0;;;::::1;3260:6;:17:::0;;-1:-1:-1;;;;;3260:17:0;;::::1;;;-1:-1:-1::0;;;;;;3260:17:0;;::::1;::::0;;;::::1;::::0;;3041:244::o;54522:103::-;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;54593:14:::1;:24:::0;;;::::1;;-1:-1:-1::0;;;54593:24:0::1;-1:-1:-1::0;;;;54593:24:0;;::::1;::::0;;;::::1;::::0;;54522:103::o;54413:97::-;2160:6;;-1:-1:-1;;;;;2160:6:0;;;;;812:10;2307:23;2299:68;;;;-1:-1:-1;;;2299:68:0;;;;;;;:::i;:::-;54481:14:::1;:21:::0;;;::::1;;-1:-1:-1::0;;;54481:21:0::1;-1:-1:-1::0;;;;54481:21:0;;::::1;::::0;;;::::1;::::0;;54413:97::o;41478:179::-;41536:7;;41568:5;41572:1;41568;:5;:::i;:::-;41556:17;;41597:1;41592;:6;;41584:46;;;;-1:-1:-1;;;41584:46:0;;9447:2:1;41584:46:0;;;9429:21:1;9486:2;9466:18;;;9459:30;9525:29;9505:18;;;9498:57;9572:18;;41584:46:0;9419:177:1;41584:46:0;41648:1;41478:179;-1:-1:-1;;;41478:179:0:o;15384:346::-;-1:-1:-1;;;;;15486:19:0;;15478:68;;;;-1:-1:-1;;;15478:68:0;;14912:2:1;15478:68:0;;;14894:21:1;14951:2;14931:18;;;14924:30;14990:34;14970:18;;;14963:62;-1:-1:-1;;;15041:18:1;;;15034:34;15085:19;;15478:68:0;14884:226:1;15478:68:0;-1:-1:-1;;;;;15565:21:0;;15557:68;;;;-1:-1:-1;;;15557:68:0;;9044:2:1;15557:68:0;;;9026:21:1;9083:2;9063:18;;;9056:30;9122:34;9102:18;;;9095:62;-1:-1:-1;;;9173:18:1;;;9166:32;9215:19;;15557:68:0;9016:224:1;15557:68:0;-1:-1:-1;;;;;15638:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15690:32;;16449:25:1;;;15690:32:0;;16422:18:1;15690:32:0;;;;;;;;15384:346;;;:::o;57473:3981::-;-1:-1:-1;;;;;57605:18:0;;57597:68;;;;-1:-1:-1;;;57597:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;57684:16:0;;57676:64;;;;-1:-1:-1;;;57676:64:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;57771:21:0;;;;;;:17;:21;;;;;;;;57770:22;57762:58;;;;-1:-1:-1;;;57762:58:0;;;;;;;:::i;:::-;57859:10;57841:29;;;;:17;:29;;;;;;;;57840:30;57832:66;;;;-1:-1:-1;;;57832:66:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;57919:23:0;;;;;;:17;:23;;;;;;;;57918:24;57910:60;;;;-1:-1:-1;;;57910:60:0;;;;;;;:::i;:::-;2160:6;;-1:-1:-1;;;;;58089:15:0;;;2160:6;;;;;58089:15;;;;:32;;-1:-1:-1;2160:6:0;;-1:-1:-1;;;;;58108:13:0;;;2160:6;;;;;58108:13;;58089:32;:50;;;;-1:-1:-1;58125:14:0;;-1:-1:-1;;;58125:14:0;;;;58089:50;58086:158;;;48264:19;58162:6;:37;;58154:90;;;;-1:-1:-1;;;58154:90:0;;11730:2:1;58154:90:0;;;11712:21:1;11769:2;11749:18;;;11742:30;11808:34;11788:18;;;11781:62;-1:-1:-1;;;11859:18:1;;;11852:38;11907:19;;58154:90:0;11702:230:1;58154:90:0;58281:14;;;;;58401:297;;58521:14;;-1:-1:-1;;;58521:14:0;;;;58517:170;;-1:-1:-1;;;;;58563:39:0;;;;;;:33;:39;;;;;;;;58555:116;;;;;-1:-1:-1;;;58555:116:0;;15720:2:1;58555:116:0;;;15702:21:1;15739:18;;;15732:30;;;;15798:34;15778:18;;;15771:62;15869:34;15849:18;;;15842:62;15921:19;;58555:116:0;15692:254:1;58555:116:0;58727:13;-1:-1:-1;;;;;58719:21:0;:4;-1:-1:-1;;;;;58719:21:0;;:44;;;;58750:13;-1:-1:-1;;;;;58744:19:0;:2;-1:-1:-1;;;;;58744:19:0;;58719:44;58718:66;;;;;58768:16;58718:66;58714:330;59070:11;59066:93;;59098:28;59114:4;59120:2;59124:1;59098:15;:28::i;:::-;59141:7;57473:3981;;;:::o;59066:93::-;59176:11;;-1:-1:-1;;;59176:11:0;;;;59175:12;:45;;;;;59204:16;59175:45;:91;;;;-1:-1:-1;;;;;;59237:29:0;;;;;;:25;:29;;;;;;;;59175:91;:207;;;;-1:-1:-1;59366:15:0;;-1:-1:-1;;;;;59350:32:0;;;59366:15;;59350:32;;59175:207;:312;;;;-1:-1:-1;;;;;;59464:23:0;;;;;;:19;:23;;;;;;;;59463:24;59175:312;59171:504;;;48264:19;59560:6;:37;;59552:111;;;;-1:-1:-1;;;59552:111:0;;13316:2:1;59552:111:0;;;13298:21:1;13355:2;13335:18;;;13328:30;13394:34;13374:18;;;13367:62;13465:31;13445:18;;;13438:59;13514:19;;59552:111:0;13288:251:1;59552:111:0;59736:4;59687:28;9360:18;;;;;;;;;;;59794:23;;59770:47;;;59834:16;:40;;;;;59867:7;59834:40;:69;;;;-1:-1:-1;59891:12:0;;-1:-1:-1;;;59891:12:0;;;;59834:69;:98;;;;-1:-1:-1;59921:11:0;;-1:-1:-1;;;59921:11:0;;;;59920:12;59834:98;:147;;;;-1:-1:-1;;;;;;59950:31:0;;;;;;:25;:31;;;;;;;;59949:32;59834:147;:187;;;;-1:-1:-1;60006:15:0;;-1:-1:-1;;;;;59998:23:0;;;60006:15;;59998:23;;59834:187;:225;;;;-1:-1:-1;60044:15:0;;-1:-1:-1;;;;;60038:21:0;;;60044:15;;60038:21;;59834:225;59830:567;;;60086:11;:18;;-1:-1:-1;;;;60086:18:0;-1:-1:-1;;;60086:18:0;;;;60142:55;48427:31;48382:1;;48427:31;:::i;:::-;60142:39;:20;48382:1;60142:24;:39::i;:::-;:43;;:55::i;:::-;60121:76;;60212:28;60229:10;60212:16;:28::i;:::-;60296:4;60257:18;9360;;;;;;;;;;;60317:32;9360:18;60317:20;:32::i;:::-;-1:-1:-1;;60366:11:0;:19;;-1:-1:-1;;;;60366:19:0;;;59830:567;60409:12;60424:16;:32;;;;-1:-1:-1;60445:11:0;;-1:-1:-1;;;60445:11:0;;;;60444:12;60424:32;-1:-1:-1;;;;;60558:25:0;;;;;;:19;:25;;;;;;60409:47;;-1:-1:-1;60558:25:0;;;:52;;-1:-1:-1;;;;;;60587:23:0;;;;;;:19;:23;;;;;;;;60558:52;60554:100;;;-1:-1:-1;60637:5:0;60554:100;60670:7;60666:185;;;60694:12;60709:31;60736:3;60709:22;48427:31;48382:1;;48427:31;:::i;:::-;60709:6;;:10;:22::i;:31::-;60694:46;-1:-1:-1;60764:16:0;:6;60694:46;60764:10;:16::i;:::-;60755:25;;60797:42;60813:4;60827;60834;60797:15;:42::i;:::-;60666:185;;60863:33;60879:4;60885:2;60889:6;60863:15;:33::i;:::-;60913:15;;-1:-1:-1;;;;;60913:15:0;:26;60948:4;60955:15;60948:4;-1:-1:-1;;;;;9360:18:0;9333:7;9360:18;;;;;;;;;;;;9259:127;60955:15;60913:58;;-1:-1:-1;;;;;;60913:58:0;;;;;;;-1:-1:-1;;;;;4791:32:1;;;60913:58:0;;;4773:51:1;4840:18;;;4833:34;4746:18;;60913:58:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;60909:74;60997:15;;-1:-1:-1;;;;;60997:15:0;:26;61032:2;61037:13;61032:2;-1:-1:-1;;;;;9360:18:0;9333:7;9360:18;;;;;;;;;;;;9259:127;61037:13;60997:54;;-1:-1:-1;;;;;;60997:54:0;;;;;;;-1:-1:-1;;;;;4791:32:1;;;60997:54:0;;;4773:51:1;4840:18;;;4833:34;4746:18;;60997:54:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;60993:94;61104:11;;-1:-1:-1;;;61104:11:0;;;;61099:348;;61146:16;;61183:15;;:28;;-1:-1:-1;;;;;;61183:28:0;;;;;16449:25:1;;;-1:-1:-1;;;;;61183:15:0;;;;:23;;16422:18:1;;61183:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;61183:28:0;;;;;;;;-1:-1:-1;;61183:28:0;;;;;;;;;;;;:::i;:::-;;;61179:257;;;;;61309:86;;;17957:25:1;;;18013:2;17998:18;;17991:34;;;18041:18;;;18034:34;;;18099:2;18084:18;;18077:34;;;61385:9:0;;61374:4;;61309:86;;17944:3:1;17929:19;61309:86:0;;;;;;;61212:199;;;61179:257;61099:348;;57473:3981;;;;;;;:::o;44305:166::-;44391:7;44427:12;44419:6;;;;44411:29;;;;-1:-1:-1;;;44411:29:0;;;;;;;;:::i;:::-;-1:-1:-1;44458:5:0;44462:1;44458;:5;:::i;:::-;44451:12;44305:166;-1:-1:-1;;;;44305:166:0:o;52716:407::-;-1:-1:-1;;;;;52807:31:0;;;;;;:25;:31;;;;;;;;:40;;;;;;;52799:117;;;;;-1:-1:-1;;;52799:117:0;;10224:2:1;52799:117:0;;;10206:21:1;10243:18;;;10236:30;;;;10302:34;10282:18;;;10275:62;10373:34;10353:18;;;10346:62;10425:19;;52799:117:0;10196:254:1;52799:117:0;-1:-1:-1;;;;;52927:31:0;;;;;;:25;:31;;;;;:39;;-1:-1:-1;;52927:39:0;;;;;;;;;;;;52979:79;;53004:15;;:42;;-1:-1:-1;;;53004:42:0;;-1:-1:-1;;;;;4234:32:1;;;53004:42:0;;;4216:51:1;53004:15:0;;;;:36;;4189:18:1;;53004:42:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;52979:79;53075:40;;;;;;-1:-1:-1;;;;;53075:40:0;;;;;;;;52716:407;;:::o;12996:539::-;-1:-1:-1;;;;;13102:20:0;;13094:70;;;;-1:-1:-1;;;13094:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;13183:23:0;;13175:71;;;;-1:-1:-1;;;13175:71:0;;;;;;;:::i;:::-;13339;13361:6;13339:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;13339:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;13319:17:0;;;:9;:17;;;;;;;;;;;:91;;;;13444:20;;;;;;;:32;;13469:6;13444:24;:32::i;:::-;-1:-1:-1;;;;;13421:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;13492:35;16449:25:1;;;13421:20:0;;13492:35;;;;;;16422:18:1;13492:35:0;16404:76:1;42357:220:0;42415:7;42439:6;42435:20;;-1:-1:-1;42454:1:0;42447:8;;42435:20;42466:9;42478:5;42482:1;42478;:5;:::i;:::-;42466:17;-1:-1:-1;42511:1:0;42502:5;42506:1;42466:17;42502:5;:::i;:::-;:10;42494:56;;;;-1:-1:-1;;;42494:56:0;;12139:2:1;42494:56:0;;;12121:21:1;12178:2;12158:18;;;12151:30;12217:34;12197:18;;;12190:62;-1:-1:-1;;;12268:18:1;;;12261:31;12309:19;;42494:56:0;12111:223:1;43055:153:0;43113:7;43145:1;43141;:5;43133:44;;;;-1:-1:-1;;;43133:44:0;;11375:2:1;43133:44:0;;;11357:21:1;11414:2;11394:18;;;11387:30;11453:28;11433:18;;;11426:56;11499:18;;43133:44:0;11347:176:1;43133:44:0;43195:5;43199:1;43195;:5;:::i;61462:907::-;61546:6;61855:21;61921:30;61546:6;61921:16;:30::i;:::-;62078:18;62099:41;:21;62125:14;62099:25;:41::i;:::-;62255:44;;62078:62;;-1:-1:-1;62201:42:0;;;;62255:44;;;;;62078:62;;62151:39;62255:44;62151:39;62255:44;62078:62;62201:42;62255:44;;;;;;;;;;;;;;;;;;;;-1:-1:-1;62325:36:0;;;17647:25:1;;;17703:2;17688:18;;17681:34;;;62325:36:0;;17620:18:1;62325:36:0;;;;;;;61462:907;;;;;:::o;63062:452::-;63127:49;63154:6;63170:4;63127:26;:49::i;:::-;63214:14;;63207:47;;-1:-1:-1;;;63207:47:0;;63248:4;63207:47;;;4216:51:1;63187:17:0;;-1:-1:-1;;;;;63214:14:0;;63207:32;;4189:18:1;;63207:47:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;63287:14;;63320:15;;63280:68;;-1:-1:-1;;;63280:68:0;;-1:-1:-1;;;;;63320:15:0;;;63280:68;;;4773:51:1;4840:18;;;4833:34;;;63187:67:0;;-1:-1:-1;63265:12:0;;63287:14;;;63280:31;;4746:18:1;;63280:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;63265:83;;63373:7;63369:138;;;63397:15;;:46;;-1:-1:-1;;;63397:46:0;;;;;16449:25:1;;;-1:-1:-1;;;;;63397:15:0;;;;:35;;16422:18:1;;63397:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;63463:32:0;;;17647:25:1;;;17703:2;17688:18;;17681:34;;;63463:32:0;;-1:-1:-1;17620:18:1;;-1:-1:-1;63463:32:0;;;;;;;63369:138;63062:452;;;:::o;41940:158::-;41998:7;42031:1;42026;:6;;42018:49;;;;-1:-1:-1;;;42018:49:0;;10657:2:1;42018:49:0;;;10639:21:1;10696:2;10676:18;;;10669:30;10735:32;10715:18;;;10708:60;10785:18;;42018:49:0;10629:180:1;42018:49:0;42085:5;42089:1;42085;:5;:::i;63522:589::-;63672:16;;;63686:1;63672:16;;;;;;;;63648:21;;63672:16;;;;;;;;;;-1:-1:-1;63672:16:0;63648:40;;63717:4;63699;63704:1;63699:7;;;;;;-1:-1:-1;;;63699:7:0;;;;;;;;;-1:-1:-1;;;;;63699:23:0;;;:7;;;;;;;;;;:23;;;;63743:15;;:22;;;-1:-1:-1;;;63743:22:0;;;;:15;;;;;:20;;:22;;;;;63699:7;;63743:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;63733:4;63738:1;63733:7;;;;;;-1:-1:-1;;;63733:7:0;;;;;;;;;-1:-1:-1;;;;;63733:32:0;;;:7;;;;;;;;;:32;63810:15;;63778:62;;63795:4;;63810:15;63828:11;63778:8;:62::i;:::-;63879:15;;:224;;-1:-1:-1;;;63879:224:0;;-1:-1:-1;;;;;63879:15:0;;;;:66;;:224;;63960:11;;63879:15;;64030:4;;64057;;64077:15;;63879:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;63522:589;;:::o;62377:672::-;62555:16;;;62569:1;62555:16;;;;;;;;;62531:21;;62555:16;;;;;;;;;;-1:-1:-1;62555:16:0;62531:40;;62600:4;62582;62587:1;62582:7;;;;;;-1:-1:-1;;;62582:7:0;;;;;;;;;-1:-1:-1;;;;;62582:23:0;;;:7;;;;;;;;;;:23;;;;62626:15;;:22;;;-1:-1:-1;;;62626:22:0;;;;:15;;;;;:20;;:22;;;;;62582:7;;62626:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;62616:4;62621:1;62616:7;;;;;;-1:-1:-1;;;62616:7:0;;;;;;;;;-1:-1:-1;;;;;62616:32:0;;;:7;;;;;;;;;:32;62669:14;;62659:7;;62669:14;;;62659:4;;62664:1;;62659:7;;;;-1:-1:-1;;;62659:7:0;;;;;;;;;-1:-1:-1;;;;;62659:24:0;;;:7;;;;;;;;;:24;62728:15;;62696:62;;62713:4;;62728:15;62746:11;62696:8;:62::i;:::-;62797:15;;:234;;-1:-1:-1;;;62797:234:0;;-1:-1:-1;;;;;62797:15:0;;;;:69;;:234;;62881:11;;62797:15;;62962:4;;62981:9;;63005:15;;62797:234;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14:257:1;73:6;126:2;114:9;105:7;101:23;97:32;94:2;;;147:6;139;132:22;94:2;191:9;178:23;210:31;235:5;210:31;:::i;276:261::-;346:6;399:2;387:9;378:7;374:23;370:32;367:2;;;420:6;412;405:22;367:2;457:9;451:16;476:31;501:5;476:31;:::i;542:398::-;610:6;618;671:2;659:9;650:7;646:23;642:32;639:2;;;692:6;684;677:22;639:2;736:9;723:23;755:31;780:5;755:31;:::i;:::-;805:5;-1:-1:-1;862:2:1;847:18;;834:32;875:33;834:32;875:33;:::i;:::-;927:7;917:17;;;629:311;;;;;:::o;945:466::-;1022:6;1030;1038;1091:2;1079:9;1070:7;1066:23;1062:32;1059:2;;;1112:6;1104;1097:22;1059:2;1156:9;1143:23;1175:31;1200:5;1175:31;:::i;:::-;1225:5;-1:-1:-1;1282:2:1;1267:18;;1254:32;1295:33;1254:32;1295:33;:::i;:::-;1049:362;;1347:7;;-1:-1:-1;;;1401:2:1;1386:18;;;;1373:32;;1049:362::o;1416:392::-;1481:6;1489;1542:2;1530:9;1521:7;1517:23;1513:32;1510:2;;;1563:6;1555;1548:22;1510:2;1607:9;1594:23;1626:31;1651:5;1626:31;:::i;:::-;1676:5;-1:-1:-1;1733:2:1;1718:18;;1705:32;1746:30;1705:32;1746:30;:::i;1813:691::-;1944:6;1952;1960;1968;1976;1984;1992;2000;2053:3;2041:9;2032:7;2028:23;2024:33;2021:2;;;2075:6;2067;2060:22;2021:2;2112:9;2106:16;2131:31;2156:5;2131:31;:::i;:::-;2181:5;2171:15;;;2226:2;2215:9;2211:18;2205:25;2195:35;;2270:2;2259:9;2255:18;2249:25;2239:35;;2314:2;2303:9;2299:18;2293:25;2283:35;;2358:3;2347:9;2343:19;2337:26;2327:36;;2403:3;2392:9;2388:19;2382:26;2372:36;;2448:3;2437:9;2433:19;2427:26;2417:36;;2493:3;2482:9;2478:19;2472:26;2462:36;;2011:493;;;;;;;;;;;:::o;2509:325::-;2577:6;2585;2638:2;2626:9;2617:7;2613:23;2609:32;2606:2;;;2659:6;2651;2644:22;2606:2;2703:9;2690:23;2722:31;2747:5;2722:31;:::i;:::-;2772:5;2824:2;2809:18;;;;2796:32;;-1:-1:-1;;;2596:238:1:o;2839:251::-;2895:6;2948:2;2936:9;2927:7;2923:23;2919:32;2916:2;;;2969:6;2961;2954:22;2916:2;3013:9;3000:23;3032:28;3054:5;3032:28;:::i;3095:255::-;3162:6;3215:2;3203:9;3194:7;3190:23;3186:32;3183:2;;;3236:6;3228;3221:22;3183:2;3273:9;3267:16;3292:28;3314:5;3292:28;:::i;3355:190::-;3414:6;3467:2;3455:9;3446:7;3442:23;3438:32;3435:2;;;3488:6;3480;3473:22;3435:2;-1:-1:-1;3516:23:1;;3425:120;-1:-1:-1;3425:120:1:o;3550:194::-;3620:6;3673:2;3661:9;3652:7;3648:23;3644:32;3641:2;;;3694:6;3686;3679:22;3641:2;-1:-1:-1;3722:16:1;;3631:113;-1:-1:-1;3631:113:1:o;3749:316::-;3837:6;3845;3853;3906:2;3894:9;3885:7;3881:23;3877:32;3874:2;;;3927:6;3919;3912:22;3874:2;3961:9;3955:16;3945:26;;4011:2;4000:9;3996:18;3990:25;3980:35;;4055:2;4044:9;4040:18;4034:25;4024:35;;3864:201;;;;;:::o;6536:603::-;6648:4;6677:2;6706;6695:9;6688:21;6738:6;6732:13;6781:6;6776:2;6765:9;6761:18;6754:34;6806:4;6819:140;6833:6;6830:1;6827:13;6819:140;;;6928:14;;;6924:23;;6918:30;6894:17;;;6913:2;6890:26;6883:66;6848:10;;6819:140;;;6977:6;6974:1;6971:13;6968:2;;;7047:4;7042:2;7033:6;7022:9;7018:22;7014:31;7007:45;6968:2;-1:-1:-1;7123:2:1;7102:15;-1:-1:-1;;7098:29:1;7083:45;;;;7130:2;7079:54;;6657:482;-1:-1:-1;;;6657:482:1:o;7549:399::-;7751:2;7733:21;;;7790:2;7770:18;;;7763:30;7829:34;7824:2;7809:18;;7802:62;-1:-1:-1;;;7895:2:1;7880:18;;7873:33;7938:3;7923:19;;7723:225::o;12753:356::-;12955:2;12937:21;;;12974:18;;;12967:30;13033:34;13028:2;13013:18;;13006:62;13100:2;13085:18;;12927:182::o;14304:401::-;14506:2;14488:21;;;14545:2;14525:18;;;14518:30;14584:34;14579:2;14564:18;;14557:62;-1:-1:-1;;;14650:2:1;14635:18;;14628:35;14695:3;14680:19;;14478:227::o;15951:347::-;16153:2;16135:21;;;16192:2;16172:18;;;16165:30;16231:25;16226:2;16211:18;;16204:53;16289:2;16274:18;;16125:173::o;16485:983::-;16747:4;16795:3;16784:9;16780:19;16826:6;16815:9;16808:25;16852:2;16890:6;16885:2;16874:9;16870:18;16863:34;16933:3;16928:2;16917:9;16913:18;16906:31;16957:6;16992;16986:13;17023:6;17015;17008:22;17061:3;17050:9;17046:19;17039:26;;17100:2;17092:6;17088:15;17074:29;;17121:4;17134:195;17148:6;17145:1;17142:13;17134:195;;;17213:13;;-1:-1:-1;;;;;17209:39:1;17197:52;;17304:15;;;;17269:12;;;;17245:1;17163:9;17134:195;;;-1:-1:-1;;;;;;;17385:32:1;;;;17380:2;17365:18;;17358:60;-1:-1:-1;;;17449:3:1;17434:19;17427:35;17346:3;16756:712;-1:-1:-1;;;16756:712:1:o;18311:128::-;18351:3;18382:1;18378:6;18375:1;18372:13;18369:2;;;18388:18;;:::i;:::-;-1:-1:-1;18424:9:1;;18359:80::o;18444:217::-;18484:1;18510;18500:2;;-1:-1:-1;;;18535:31:1;;18589:4;18586:1;18579:15;18617:4;18542:1;18607:15;18500:2;-1:-1:-1;18646:9:1;;18490:171::o;18666:168::-;18706:7;18772:1;18768;18764:6;18760:14;18757:1;18754:21;18749:1;18742:9;18735:17;18731:45;18728:2;;;18779:18;;:::i;:::-;-1:-1:-1;18819:9:1;;18718:116::o;18839:125::-;18879:4;18907:1;18904;18901:8;18898:2;;;18912:18;;:::i;:::-;-1:-1:-1;18949:9:1;;18888:76::o;18969:380::-;19048:1;19044:12;;;;19091;;;19112:2;;19166:4;19158:6;19154:17;19144:27;;19112:2;19219;19211:6;19208:14;19188:18;19185:38;19182:2;;;19265:10;19260:3;19256:20;19253:1;19246:31;19300:4;19297:1;19290:15;19328:4;19325:1;19318:15;19182:2;;19024:325;;;:::o;19354:135::-;19393:3;-1:-1:-1;;19414:17:1;;19411:2;;;19434:18;;:::i;:::-;-1:-1:-1;19481:1:1;19470:13;;19401:88::o;19494:127::-;19555:10;19550:3;19546:20;19543:1;19536:31;19586:4;19583:1;19576:15;19610:4;19607:1;19600:15;19626:131;-1:-1:-1;;;;;19701:31:1;;19691:42;;19681:2;;19747:1;19744;19737:12;19762:118;19848:5;19841:13;19834:21;19827:5;19824:32;19814:2;;19870:1;19867;19860:12

Swarm Source

ipfs://4ae3db7679aab0c02330100588886fad979aae08829b63dba1f8c5e98037d9f7

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.