Contract 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4

Contract Overview

Balance:
0.000004224283300251 BNB

Token:
Txn Hash Method
Block
From
To
Value [Txn Fee]
0x5bb61da48199cb87b15ebfe17f316e1fbc9e3e3489deac154dbad0e6daaa3b43Approve108239442021-07-22 20:59:5766 days 11 hrs ago0x2029daadbcd424fd93e9f24f5395edad7e637074 IN  0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB0.00044452
0x4803f73e31b24ad9ee3e5ee1370e322de179d721c522f5b81978103454656800Transfer108237662021-07-22 20:50:0666 days 11 hrs ago0x226e5922681ee29f515db739e556c59133329921 IN  0x77c540f5a03b7aec2d09f1018a0314bfad3f02b41.001 BNB0.00021055
0x03249a12c9af013ed32135031454ae259ffdd234d12e47d29e227a0d87d6692fTransfer108237202021-07-22 20:47:2666 days 11 hrs ago0x39f8734db4a27305cd72a8517f3ab721499833b5 IN  0x77c540f5a03b7aec2d09f1018a0314bfad3f02b41 BNB0.00021055
0x8bfacacf180acd55ca4e5105a61245d664607abad732ee9d616e23611478a9bfSet Swap Bnb For...108237072021-07-22 20:46:4766 days 11 hrs ago0x39f8734db4a27305cd72a8517f3ab721499833b5 IN  0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB0.00027413
0x5e8e68ba229b239608f62d94e241af2a547a3b657005e8e60d714f354aec061fTransfer108236842021-07-22 20:45:3866 days 11 hrs ago0x39f8734db4a27305cd72a8517f3ab721499833b5 IN  0x77c540f5a03b7aec2d09f1018a0314bfad3f02b41 BNB0.00021055
0x0822b20451062edfecf8ac9a59de6d0cb977583e8f5c87450a8562a25823b790Set Swap Enabled108236802021-07-22 20:45:2666 days 11 hrs ago0x39f8734db4a27305cd72a8517f3ab721499833b5 IN  0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB0.00028181
0x4b4638fc01585625e6eea2183e99c3e4353f5b64e4bd7ec249b722a9de4e4b3fApprove108236652021-07-22 20:44:4166 days 11 hrs ago0x226e5922681ee29f515db739e556c59133329921 IN  0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB0.00044452
0xcdae0670acf11851e7aa2930ae325b592958ad0e9a2bc8164f6a2b99402d582aApprove108236372021-07-22 20:43:1766 days 11 hrs ago0x39f8734db4a27305cd72a8517f3ab721499833b5 IN  0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB0.00044452
0x68870837a554dea85b24ea705406b7690f826cde6b36449bb410f48de7d7b2190x60a06040108235952021-07-22 20:41:1166 days 11 hrs ago0x39f8734db4a27305cd72a8517f3ab721499833b5 IN  Contract Creation0 BNB0.08736922
[ Download CSV Export 
Latest 25 internal transaction
Parent Txn Hash Block From To Value
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0xa7c811bce72f1e5c6d4537cedae1951799945210 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x9ac64cc6e4415144c455bd8e4837fea55603e5c3 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x18ef5b4449eb36a2d80f84d32c94413f988e99420 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x18ef5b4449eb36a2d80f84d32c94413f988e99420 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x18ef5b4449eb36a2d80f84d32c94413f988e99420 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x18ef5b4449eb36a2d80f84d32c94413f988e99420 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x78867bbeef44f2326bf8ddd1941a4439382ef2a70 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x78867bbeef44f2326bf8ddd1941a4439382ef2a70 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x9ac64cc6e4415144c455bd8e4837fea55603e5c3 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40.000000224700715383 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0xa7c811bce72f1e5c6d4537cedae1951799945210 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x9ac64cc6e4415144c455bd8e4837fea55603e5c3 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x18ef5b4449eb36a2d80f84d32c94413f988e99420 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x18ef5b4449eb36a2d80f84d32c94413f988e99420 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x9ac64cc6e4415144c455bd8e4837fea55603e5c3 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x9ac64cc6e4415144c455bd8e4837fea55603e5c30 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x9ac64cc6e4415144c455bd8e4837fea55603e5c30 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40x333e5922681ee29f515db739e556c591333299210.000000336213594299 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x9ac64cc6e4415144c455bd8e4837fea55603e5c3 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40.000000336213594299 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0xa7c811bce72f1e5c6d4537cedae1951799945210 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x9ac64cc6e4415144c455bd8e4837fea55603e5c3 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x18ef5b4449eb36a2d80f84d32c94413f988e99420 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x18ef5b4449eb36a2d80f84d32c94413f988e99420 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x9ac64cc6e4415144c455bd8e4837fea55603e5c3 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b40 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x9ac64cc6e4415144c455bd8e4837fea55603e5c30 BNB
0x07b2dd76c01bc336cebc3bdcbbd216b47bb07fe69be680a38ccfa6e91703bc04108250422021-07-22 21:54:5166 days 10 hrs ago 0x77c540f5a03b7aec2d09f1018a0314bfad3f02b4 0x9ac64cc6e4415144c455bd8e4837fea55603e5c30 BNB
[ Download CSV Export 
Loading
This contract contains unverified libraries: IterableMapping

Contract Source Code Verified (Exact Match)

Contract Name:
Claim63

Compiler Version
v0.6.12+commit.27d51765

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at BscScan.com on 2021-07-22
*/

// SPDX-License-Identifier: Unlicensed
 
pragma solidity ^0.6.2;


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

/**
 * @title SafeMathInt
 * @dev Math operations for int256 with overflow safety checks.
 */
library SafeMathInt {
    int256 private constant MIN_INT256 = int256(1) << 255;
    int256 private constant MAX_INT256 = ~(int256(1) << 255);

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

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

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

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

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

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

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


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


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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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


/*
 * @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 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 Interface of the ERC20 standard as defined in the EIP.
 */
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 Interface for the optional metadata functions from the ERC20 standard.
 *
 * _Available since v4.1._
 */
interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

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

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

contract 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 () public {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

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

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

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

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


/**
 * @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, IERC20Metadata {
    using SafeMath for uint256;

    mapping(address => uint256) private _balances;

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

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

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

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

        _beforeTokenTransfer(sender, recipient, amount);

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

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

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

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

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

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

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

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

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

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

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

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 immutable RewordToken;

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

    constructor(string memory _name, string memory _symbol, address _rewardToken) public ERC20(_name, _symbol) {
        RewordToken = _rewardToken;
    }


    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 distributeDogeDividends(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(_msgSender());
    }

    /// @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(RewordToken).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);
        }
    }
}

contract TokenDividendTracker is DividendPayingToken, Ownable {
    using SafeMath for uint256;
    using SafeMathUint 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 ClaimWaitUpdated(uint256 indexed newValue, uint256 indexed oldValue);

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

    constructor(string memory _name, string memory _symbol, address rewardToken) public DividendPayingToken(_name, _symbol, rewardToken) {
        claimWait = 60;
        minimumTokenBalanceForDividends = 1000000 * (10 ** 18);
    }

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

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

        emit ExcludeFromDividends(account);
    }

    function updateClaimWait(uint256 newClaimWait) external onlyOwner {
        require(newClaimWait >= 60 && newClaimWait <= 86400, "63Claim_Dividend_Tracker: claimWait must be updated to between 1 and 24 hours");
        require(newClaimWait != claimWait, "63Claim_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;
    }
}

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

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;
}
 
 
contract Claim63 is ERC20, Ownable {
    using SafeMath for uint256;
 
    IUniswapV2Router02 public uniswapV2Router;
    address public immutable uniswapV2Pair;

    
    bool private swapping;
 
    TokenDividendTracker public dividendTracker;
 
    address public DOGEToken = 0x78867BbEeF44f2326bF8DDd1941a4439382EF2A7;
    
    uint256 public maxSellTransactionAmount = 150000000 * (10**18);
    uint256 public swapTokensAtAmount = 20000 * (10**18);
    uint256 public swapBnbForDogeAmount = 1 * (10 ** 18);
    uint256 private minimumTokensBeforeSwap = 20000000 * 10**18;
 
    uint256 public  ETHRewardsFee = 2;
    uint256 public  marketingFee = 3;
    uint256 public  liquidityFee = 5;
    uint256 public  totalFees = ETHRewardsFee.add(marketingFee).add(liquidityFee);
 
    bool public swapEnabled = false;
    
    address payable _marketingWallet;
 
    // use by default 300,000 gas to process auto-claiming dividends
    uint256 public gasForProcessing = 300000;
 
    mapping (address => bool) private _isExcludedFromFees;
 
    // 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 UpdateDividendTracker(address indexed newAddress, address indexed oldAddress);
 
    event UpdateUniswapV2Router(address indexed newAddress, address indexed oldAddress);
 
    event ExcludeFromFees(address indexed account, bool isExcluded);
    event ExcludeMultipleAccountsFromFees(address[] accounts, bool isExcluded);
 
    event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);
 

    event GasForProcessingUpdated(uint256 indexed newValue, uint256 indexed oldValue);
 
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );
 
    event SwapETHForTokens(
        uint256 amountIn,
        address[] path
    );
 
    event SendDividends(
    	uint256 tokensSwapped,
    	uint256 amount
    );
 
    event ProcessedDividendTracker(
    	uint256 iterations,
    	uint256 claims,
        uint256 lastProcessedIndex,
    	bool indexed automatic,
    	uint256 gas,
    	address indexed processor
    );
 
     modifier lockTheSwap {
        swapping = true;
        _;
        swapping = false;
    }
 
    constructor() public ERC20("63Claim", "63Claim") {

        _marketingWallet = 0x333e5922681EE29f515Db739e556c59133329921;
    	dividendTracker = new TokenDividendTracker("63Claim_Dividend_Tracker", "63Claim_Dividend_Tracker", DOGEToken);
 
    	IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x9Ac64Cc6e4415144C455BD8E4837Fea55603e5c3);
         // 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));
 
        // exclude from paying fees or having max transaction amount
        excludeFromFees(owner(), true);
        excludeFromFees(_marketingWallet, true);
        excludeFromFees(address(this), true);
 
        /*
            _mint is an internal function in ERC20.sol that is only called here,
            and CANNOT be called ever again
        */
        _mint(owner(), 100000000000 * (10**18));
    }
 
    receive() external payable {
 
  	}
 
    function updateUniswapV2Router(address newAddress) public onlyOwner {
        require(newAddress != address(uniswapV2Router), "63Claim: The router already has that address");
        emit UpdateUniswapV2Router(newAddress, address(uniswapV2Router));
        uniswapV2Router = IUniswapV2Router02(newAddress);
    }
 
    function excludeFromFees(address account, bool excluded) public onlyOwner {
        require(_isExcludedFromFees[account] != excluded, "63Claim: Account is already the value of 'excluded'");
        _isExcludedFromFees[account] = excluded;
 
        emit ExcludeFromFees(account, excluded);
    }
 
    function excludeMultipleAccountsFromFees(address[] calldata accounts, bool excluded) public onlyOwner {
        for(uint256 i = 0; i < accounts.length; i++) {
            _isExcludedFromFees[accounts[i]] = excluded;
        }
 
        emit ExcludeMultipleAccountsFromFees(accounts, excluded);
    }
 
 
    function setAutomatedMarketMakerPair(address pair, bool value) public onlyOwner {
        require(pair != uniswapV2Pair, "63Claim: The PancakeSwap pair cannot be removed from automatedMarketMakerPairs");
 
        _setAutomatedMarketMakerPair(pair, value);
    }
 
    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        require(automatedMarketMakerPairs[pair] != value, "63Claim: Automated market maker pair is already set to that value");
        automatedMarketMakerPairs[pair] = value;
 
        if(value) {
            dividendTracker.excludeFromDividends(pair);
        }
 
        emit SetAutomatedMarketMakerPair(pair, value);
    }
 

    function updateGasForProcessing(uint256 newValue) public onlyOwner {
        require(newValue >= 200000 && newValue <= 500000, "63Claim: gasForProcessing must be between 200,000 and 500,000");
        require(newValue != gasForProcessing, "63Claim: Cannot update gasForProcessing to same value");
        emit GasForProcessingUpdated(newValue, gasForProcessing);
        gasForProcessing = newValue;
    }
 
    function updateClaimWait(uint256 claimWait) external onlyOwner {
        dividendTracker.updateClaimWait(claimWait);
    }
 
    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 minimumTokensBeforeSwapAmount() public view returns (uint256) {
        return minimumTokensBeforeSwap;
    }
 
    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(msg.sender, false);
    }
 
    function getLastProcessedIndex() external view returns(uint256) {
    	return dividendTracker.getLastProcessedIndex();
    }
 
    function getNumberOfDividendTokenHolders() external view returns(uint256) {
        return dividendTracker.getNumberOfTokenHolders();
    }
 
    function setMaxSellTxAMount(uint256 amount) external onlyOwner{
        maxSellTransactionAmount = amount;
    }
    
    function setMarketingWallet(address newWallet) external onlyOwner{
        _marketingWallet = payable(newWallet);
    }
 
    function setSwapEnabled(bool value) external onlyOwner{
        swapEnabled = value;
    }
    
    function setSwapBnbForDogeAmount(uint256 amount) external onlyOwner {
        swapBnbForDogeAmount = amount * (10 ** 18);
    }
 
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        
        if(amount == 0) {
            super._transfer(from, to, 0);
            return;
        }
 
        if( 
        	!swapping &&
        	swapEnabled &&
            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[from]
        ) {
            require(amount <= maxSellTransactionAmount, "Sell transfer amount exceeds the maxSellTransactionAmount.");
        }
        uint256 contractTokenBalance = balanceOf(address(this));
        bool overMinimumTokenBalance = contractTokenBalance >= swapTokensAtAmount;
        if(swapEnabled && !swapping && from != uniswapV2Pair) {
           if (overMinimumTokenBalance) {
                uint256 swapTokens = contractTokenBalance.mul(liquidityFee).div(totalFees);
                swapAndLiquify(swapTokens);

                uint256 marketingTokens = contractTokenBalance.mul(marketingFee).div(totalFees);
                swapAndSendToMarketing(marketingTokens);
 
                uint256 sellTokens = balanceOf(address(this));
                swapAndSendDividends(sellTokens);
           }
 
        }
 
        bool takeFee = true;
 
        // if any account belongs to _isExcludedFromFee account then remove the fee
        if(_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }
 
        if(takeFee) {
        	uint256 fees = amount.mul(totalFees).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(!swapping) {
	    	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 swapAndSendToMarketing(uint256 tokens) private lockTheSwap {
 
        uint256 initialBalance = address(this).balance;
 
        swapTokensForEth(tokens);
        // how much ETH did we just swap into?
        uint256 newBalance = address(this).balance.sub(initialBalance);
         _marketingWallet.transfer(newBalance); 
    }
    
     function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // add the liquidity
        uniswapV2Router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            owner(),
            block.timestamp
        );
        
    }
    
    function swapAndLiquify(uint256 tokens) private lockTheSwap{
        // split the contract balance into halves
        uint256 half = tokens.div(2);
        uint256 otherHalf = tokens.sub(half);

        uint256 initialBalance = address(this).balance;

        // swap tokens for ETH
        swapTokensForEth(half); // <- this 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);

        // add liquidity to uniswap
        addLiquidity(otherHalf, newBalance);
        
        emit SwapAndLiquify(half, newBalance, otherHalf);
    }
 
    function swapTokensForEth(uint256 tokenAmount) private {
 
 
        // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
 
        _approve(address(this), address(uniswapV2Router), tokenAmount);
 
        // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
 
    }

 
    function swapAndSendDividends(uint256 tokens) private lockTheSwap{
        swapTokensForEth(tokens);
        if(address(this).balance > swapBnbForDogeAmount) { 
            swapBNBForDoge();
        }
        uint256 dividends = IERC20(DOGEToken).balanceOf(address(this));
        bool success = IERC20(DOGEToken).transfer(address(dividendTracker), dividends);
 
        if(success) {
            dividendTracker.distributeDogeDividends(dividends);
        }
    }
    
    function swapBNBForDoge() private {
        address[] memory path = new address[](2);
        path[0] = uniswapV2Router.WETH();
        path[1] = DOGEToken;
        // make the swap
        uniswapV2Router.swapExactETHForTokens{value : address(this).balance}(
            0,
            path,
            address(this),
            block.timestamp
        );
    }
}

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address[]","name":"accounts","type":"address[]"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeMultipleAccountsFromFees","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":"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":"SendDividends","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"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiqudity","type":"uint256"}],"name":"SwapAndLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"amountIn","type":"uint256"},{"indexed":false,"internalType":"address[]","name":"path","type":"address[]"}],"name":"SwapETHForTokens","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":"UpdateDividendTracker","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdateUniswapV2Router","type":"event"},{"inputs":[],"name":"DOGEToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"ETHRewardsFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"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 TokenDividendTracker","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"accounts","type":"address[]"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeMultipleAccountsFromFees","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":"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":"liquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"marketingFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxSellTransactionAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minimumTokensBeforeSwapAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"gas","type":"uint256"}],"name":"processDividendTracker","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":"address","name":"newWallet","type":"address"}],"name":"setMarketingWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"setMaxSellTxAMount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"setSwapBnbForDogeAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"value","type":"bool"}],"name":"setSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapBnbForDogeAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"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":"address","name":"newAddress","type":"address"}],"name":"updateUniswapV2Router","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"}]

60a0604052600880547378867bbeef44f2326bf8ddd1941a4439382ef2a76001600160a01b03199091161790556a7c13bc4b2c133c5600000060095569043c33c1937564800000600a55670de0b6b3a7640000600b556a108b2a2c28029094000000600c556002600d8190556003600e8190556005600f819055620000ac92909162000098919062000648602090811b62001cd017901c565b6200064860201b62001cd01790919060201c565b6010556011805460ff19169055620493e0601255348015620000cd57600080fd5b506040805180820182526007808252663633436c61696d60c81b602080840182815285518087019096529285528401528151919291620001109160039162000a31565b5080516200012690600490602084019062000a31565b50505060006200013b620006aa60201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35060118054610100600160a81b03191674333e5922681ee29f515db739e556c59133329921001790556008546040516001600160a01b0390911690620001ce9062000ab6565b6001600160a01b03909116604080830191909152606080835260189083018190527f3633436c61696d5f4469766964656e645f547261636b657200000000000000006080840181905260a06020850181905284019190915260c0830152519081900360e001906000f0801580156200024a573d6000803e3d6000fd5b50600760006101000a8154816001600160a01b0302191690836001600160a01b031602179055506000739ac64cc6e4415144c455bd8e4837fea55603e5c390506000816001600160a01b031663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b158015620002c657600080fd5b505afa158015620002db573d6000803e3d6000fd5b505050506040513d6020811015620002f257600080fd5b5051604080516315ab88c960e31b815290516001600160a01b039283169263c9c653969230929187169163ad5c464891600480820192602092909190829003018186803b1580156200034357600080fd5b505afa15801562000358573d6000803e3d6000fd5b505050506040513d60208110156200036f57600080fd5b5051604080516001600160e01b031960e086901b1681526001600160a01b0393841660048201529290911660248301525160448083019260209291908290030181600087803b158015620003c257600080fd5b505af1158015620003d7573d6000803e3d6000fd5b505050506040513d6020811015620003ee57600080fd5b5051600680546001600160a01b0319166001600160a01b038516179055606081901b6001600160601b03191660805290506200042c816001620006ae565b6007546040805163031e79db60e41b81526001600160a01b0390921660048301819052905190916331e79db091602480830192600092919082900301818387803b1580156200047a57600080fd5b505af11580156200048f573d6000803e3d6000fd5b50506007546040805163031e79db60e41b815230600482015290516001600160a01b0390921693506331e79db0925060248082019260009290919082900301818387803b158015620004e057600080fd5b505af1158015620004f5573d6000803e3d6000fd5b50506007546001600160a01b031691506331e79db0905062000516620007e1565b6040518263ffffffff1660e01b815260040180826001600160a01b03168152602001915050600060405180830381600087803b1580156200055657600080fd5b505af11580156200056b573d6000803e3d6000fd5b50506007546040805163031e79db60e41b81526001600160a01b03878116600483015291519190921693506331e79db09250602480830192600092919082900301818387803b158015620005be57600080fd5b505af1158015620005d3573d6000803e3d6000fd5b50505050620005f3620005eb620007e160201b60201c565b6001620007f0565b601154620006119061010090046001600160a01b03166001620007f0565b6200061e306001620007f0565b620006406200062c620007e1565b6c01431e0fae6d7217caa00000006200091d565b505062000adb565b600082820183811015620006a3576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b3390565b6001600160a01b03821660009081526014602052604090205460ff16151581151514156200070e5760405162461bcd60e51b8152600401808060200182810382526041815260200180620062b46041913960600191505060405180910390fd5b6001600160a01b0382166000908152601460205260409020805460ff19168215801591909117909155620007a5576007546040805163031e79db60e41b81526001600160a01b038581166004830152915191909216916331e79db091602480830192600092919082900301818387803b1580156200078b57600080fd5b505af1158015620007a0573d6000803e3d6000fd5b505050505b604051811515906001600160a01b038416907fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab90600090a35050565b6005546001600160a01b031690565b620007fa620006aa565b6005546001600160a01b039081169116146200085d576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6001600160a01b03821660009081526013602052604090205460ff1615158115151415620008bd5760405162461bcd60e51b8152600401808060200182810382526033815260200180620062f56033913960400191505060405180910390fd5b6001600160a01b038216600081815260136020908152604091829020805460ff1916851515908117909155825190815291517f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df79281900390910190a25050565b6001600160a01b03821662000979576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b620009876000838362000a2c565b620009a3816002546200064860201b62001cd01790919060201c565b6002556001600160a01b03821660009081526020818152604090912054620009d691839062001cd062000648821b17901c565b6001600160a01b0383166000818152602081815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b505050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f1062000a7457805160ff191683800117855562000aa4565b8280016001018555821562000aa4579182015b8281111562000aa457825182559160200191906001019062000a87565b5062000ab292915062000ac4565b5090565b6125988062003d1c83390190565b5b8082111562000ab2576000815560010162000ac5565b60805160601c61321962000b0360003980610d8052806115085280611fc052506132196000f3fe6080604052600436106102cd5760003560e01c8063871c128d11610175578063a9059cbb116100dc578063e01af92c11610095578063e7841ec01161006f578063e7841ec014610aae578063e98030c714610ac3578063f27fd25414610aed578063f2fde38b14610b17576102d4565b8063e01af92c14610a58578063e2f4560514610a84578063e741923514610a99576102d4565b8063a9059cbb14610879578063ad56c13c146108b2578063b62496f514610930578063c024666814610963578063c492f0461461099e578063dd62ed3e14610a1d576102d4565b80639a7a23d61161012e5780639a7a23d6146107935780639c1b8af5146107ce578063a073d37f146107e3578063a26579ad146107f8578063a457c2d71461080d578063a8b9d24014610846576102d4565b8063871c128d146106eb57806387f7f5ad146107155780638c0344db1461073f5780638da5cb5b1461075457806395d89b411461076957806398118cb41461077e576102d4565b80634e71d92d116102345780636b67c4df116101ed57806370a08231116101c757806370a0823114610664578063710ee68e14610697578063715018a6146106ac57806378d42e53146106c1576102d4565b80636b67c4df146106105780636ddd171314610625578063700bb1911461063a576102d4565b80634e71d92d146105185780634fbee1931461052f5780635d098b381461056257806364b0f6531461059557806365b8dbc0146105aa5780636843cd84146105dd576102d4565b806323b872dd1161028657806323b872dd146104325780632c1f52161461047557806330bb4cff1461048a578063313ce5671461049f57806339509351146104ca57806349bd5a5e14610503576102d4565b806302259e9e146102d957806306fdde0314610300578063095ea7b31461038a57806313114a9d146103d75780631694505e146103ec57806318160ddd1461041d576102d4565b366102d457005b600080fd5b3480156102e557600080fd5b506102ee610b4a565b60408051918252519081900360200190f35b34801561030c57600080fd5b50610315610b50565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561034f578181015183820152602001610337565b50505050905090810190601f16801561037c5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34801561039657600080fd5b506103c3600480360360408110156103ad57600080fd5b506001600160a01b038135169060200135610be6565b604080519115158252519081900360200190f35b3480156103e357600080fd5b506102ee610c04565b3480156103f857600080fd5b50610401610c0a565b604080516001600160a01b039092168252519081900360200190f35b34801561042957600080fd5b506102ee610c19565b34801561043e57600080fd5b506103c36004803603606081101561045557600080fd5b506001600160a01b03813581169160208101359091169060400135610c1f565b34801561048157600080fd5b50610401610ca6565b34801561049657600080fd5b506102ee610cb5565b3480156104ab57600080fd5b506104b4610d2b565b6040805160ff9092168252519081900360200190f35b3480156104d657600080fd5b506103c3600480360360408110156104ed57600080fd5b506001600160a01b038135169060200135610d30565b34801561050f57600080fd5b50610401610d7e565b34801561052457600080fd5b5061052d610da2565b005b34801561053b57600080fd5b506103c36004803603602081101561055257600080fd5b50356001600160a01b0316610e27565b34801561056e57600080fd5b5061052d6004803603602081101561058557600080fd5b50356001600160a01b0316610e45565b3480156105a157600080fd5b506102ee610ec5565b3480156105b657600080fd5b5061052d600480360360208110156105cd57600080fd5b50356001600160a01b0316610f0a565b3480156105e957600080fd5b506102ee6004803603602081101561060057600080fd5b50356001600160a01b031661100c565b34801561061c57600080fd5b506102ee61108f565b34801561063157600080fd5b506103c3611095565b34801561064657600080fd5b5061052d6004803603602081101561065d57600080fd5b503561109e565b34801561067057600080fd5b506102ee6004803603602081101561068757600080fd5b50356001600160a01b0316611185565b3480156106a357600080fd5b506104016111a0565b3480156106b857600080fd5b5061052d6111af565b3480156106cd57600080fd5b5061052d600480360360208110156106e457600080fd5b5035611251565b3480156106f757600080fd5b5061052d6004803603602081101561070e57600080fd5b50356112b8565b34801561072157600080fd5b5061052d6004803603602081101561073857600080fd5b50356113d5565b34801561074b57600080fd5b506102ee611432565b34801561076057600080fd5b50610401611438565b34801561077557600080fd5b50610315611447565b34801561078a57600080fd5b506102ee6114a8565b34801561079f57600080fd5b5061052d600480360360408110156107b657600080fd5b506001600160a01b03813516906020013515156114ae565b3480156107da57600080fd5b506102ee611581565b3480156107ef57600080fd5b506102ee611587565b34801561080457600080fd5b506102ee61158d565b34801561081957600080fd5b506103c36004803603604081101561083057600080fd5b506001600160a01b0381351690602001356115d2565b34801561085257600080fd5b506102ee6004803603602081101561086957600080fd5b50356001600160a01b031661163a565b34801561088557600080fd5b506103c36004803603604081101561089c57600080fd5b506001600160a01b03813516906020013561168b565b3480156108be57600080fd5b506108e5600480360360208110156108d557600080fd5b50356001600160a01b031661169f565b604080516001600160a01b0390991689526020890197909752878701959095526060870193909352608086019190915260a085015260c084015260e083015251908190036101000190f35b34801561093c57600080fd5b506103c36004803603602081101561095357600080fd5b50356001600160a01b031661177f565b34801561096f57600080fd5b5061052d6004803603604081101561098657600080fd5b506001600160a01b0381351690602001351515611794565b3480156109aa57600080fd5b5061052d600480360360408110156109c157600080fd5b8101906020810181356401000000008111156109dc57600080fd5b8201836020820111156109ee57600080fd5b80359060200191846020830284011164010000000083111715610a1057600080fd5b91935091503515156118aa565b348015610a2957600080fd5b506102ee60048036036040811015610a4057600080fd5b506001600160a01b03813581169160200135166119ca565b348015610a6457600080fd5b5061052d60048036036020811015610a7b57600080fd5b503515156119f5565b348015610a9057600080fd5b506102ee611a60565b348015610aa557600080fd5b506102ee611a66565b348015610aba57600080fd5b506102ee611a6c565b348015610acf57600080fd5b5061052d60048036036020811015610ae657600080fd5b5035611ab1565b348015610af957600080fd5b506108e560048036036020811015610b1057600080fd5b5035611b71565b348015610b2357600080fd5b5061052d60048036036020811015610b3a57600080fd5b50356001600160a01b0316611bd7565b60095481565b60038054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610bdc5780601f10610bb157610100808354040283529160200191610bdc565b820191906000526020600020905b815481529060010190602001808311610bbf57829003601f168201915b5050505050905090565b6000610bfa610bf3611d31565b8484611d35565b5060015b92915050565b60105481565b6006546001600160a01b031681565b60025490565b6000610c2c848484611e21565b610c9c84610c38611d31565b610c978560405180606001604052806028815260200161300a602891396001600160a01b038a16600090815260016020526040812090610c76611d31565b6001600160a01b0316815260208101919091526040016000205491906122e6565b611d35565b5060019392505050565b6007546001600160a01b031681565b600754604080516342d359d760e11b815290516000926001600160a01b0316916385a6b3ae916004808301926020929190829003018186803b158015610cfa57600080fd5b505afa158015610d0e573d6000803e3d6000fd5b505050506040513d6020811015610d2457600080fd5b5051905090565b601290565b6000610bfa610d3d611d31565b84610c978560016000610d4e611d31565b6001600160a01b03908116825260208083019390935260409182016000908120918c168152925290205490611cd0565b7f000000000000000000000000000000000000000000000000000000000000000081565b6007546040805163bc4c4b3760e01b815233600482015260006024820181905291516001600160a01b039093169263bc4c4b3792604480840193602093929083900390910190829087803b158015610df957600080fd5b505af1158015610e0d573d6000803e3d6000fd5b505050506040513d6020811015610e2357600080fd5b5050565b6001600160a01b031660009081526013602052604090205460ff1690565b610e4d611d31565b6005546001600160a01b03908116911614610e9d576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b601180546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b600754604080516304ddf6ef60e11b815290516000926001600160a01b0316916309bbedde916004808301926020929190829003018186803b158015610cfa57600080fd5b610f12611d31565b6005546001600160a01b03908116911614610f62576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b6006546001600160a01b0382811691161415610faf5760405162461bcd60e51b815260040180806020018281038252602c815260200180613193602c913960400191505060405180910390fd5b6006546040516001600160a01b03918216918316907f8fc842bbd331dfa973645f4ed48b11683d501ebf1352708d77a5da2ab49a576e90600090a3600680546001600160a01b0319166001600160a01b0392909216919091179055565b600754604080516370a0823160e01b81526001600160a01b038481166004830152915160009392909216916370a0823191602480820192602092909190829003018186803b15801561105d57600080fd5b505afa158015611071573d6000803e3d6000fd5b505050506040513d602081101561108757600080fd5b505192915050565b600e5481565b60115460ff1681565b600754604080516001624d3b8760e01b03198152600481018490529051600092839283926001600160a01b039092169163ffb2c4799160248082019260609290919082900301818787803b1580156110f557600080fd5b505af1158015611109573d6000803e3d6000fd5b505050506040513d606081101561111f57600080fd5b5080516020808301516040938401518451848152928301829052828501819052606083018990529351929650945091925032916000917fc864333d6121033635ab41b29ae52f10a22cf4438c3e4f1c4c68518feb2f8a989181900360800190a350505050565b6001600160a01b031660009081526020819052604090205490565b6008546001600160a01b031681565b6111b7611d31565b6005546001600160a01b03908116911614611207576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b611259611d31565b6005546001600160a01b039081169116146112a9576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b670de0b6b3a764000002600b55565b6112c0611d31565b6005546001600160a01b03908116911614611310576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b62030d40811015801561132657506207a1208111155b6113615760405162461bcd60e51b815260040180806020018281038252603d815260200180613156603d913960400191505060405180910390fd5b6012548114156113a25760405162461bcd60e51b8152600401808060200182810382526035815260200180612fb46035913960400191505060405180910390fd5b60125460405182907f40d7e40e79af4e8e5a9b3c57030d8ea93f13d669c06d448c4d631d4ae7d23db790600090a3601255565b6113dd611d31565b6005546001600160a01b0390811691161461142d576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b600955565b600d5481565b6005546001600160a01b031690565b60048054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610bdc5780601f10610bb157610100808354040283529160200191610bdc565b600f5481565b6114b6611d31565b6005546001600160a01b03908116911614611506576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614156115775760405162461bcd60e51b815260040180806020018281038252604e815260200180613052604e913960600191505060405180910390fd5b610e23828261237d565b60125481565b600c5490565b60075460408051631bc9e27b60e21b815290516000926001600160a01b031691636f2789ec916004808301926020929190829003018186803b158015610cfa57600080fd5b6000610bfa6115df611d31565b84610c97856040518060600160405280602581526020016131bf6025913960016000611609611d31565b6001600160a01b03908116825260208083019390935260409182016000908120918d168152925290205491906122e6565b600754604080516302a2e74960e61b81526001600160a01b0384811660048301529151600093929092169163a8b9d24091602480820192602092909190829003018186803b15801561105d57600080fd5b6000610bfa611698611d31565b8484611e21565b600080600080600080600080600760009054906101000a90046001600160a01b03166001600160a01b031663fbcbc0f18a6040518263ffffffff1660e01b815260040180826001600160a01b031681526020019150506101006040518083038186803b15801561170e57600080fd5b505afa158015611722573d6000803e3d6000fd5b505050506040513d61010081101561173957600080fd5b508051602082015160408301516060840151608085015160a086015160c087015160e090970151959e50939c50919a509850965094509092509050919395975091939597565b60146020526000908152604090205460ff1681565b61179c611d31565b6005546001600160a01b039081169116146117ec576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b6001600160a01b03821660009081526013602052604090205460ff161515811515141561184a5760405162461bcd60e51b81526004018080602001828103825260338152602001806130ff6033913960400191505060405180910390fd5b6001600160a01b038216600081815260136020908152604091829020805460ff1916851515908117909155825190815291517f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df79281900390910190a25050565b6118b2611d31565b6005546001600160a01b03908116911614611902576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b60005b8281101561195757816013600086868581811061191e57fe5b602090810292909201356001600160a01b0316835250810191909152604001600020805460ff1916911515919091179055600101611905565b507f7fdaf542373fa84f4ee8d662c642f44e4c2276a217d7d29e548b6eb29a233b35838383604051808060200183151581526020018281038252858582818152602001925060200280828437600083820152604051601f909101601f1916909201829003965090945050505050a1505050565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6119fd611d31565b6005546001600160a01b03908116911614611a4d576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b6011805460ff1916911515919091179055565b600a5481565b600b5481565b6007546040805163039e107b60e61b815290516000926001600160a01b03169163e7841ec0916004808301926020929190829003018186803b158015610cfa57600080fd5b611ab9611d31565b6005546001600160a01b03908116911614611b09576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b6007546040805163e98030c760e01b81526004810184905290516001600160a01b039092169163e98030c79160248082019260009290919082900301818387803b158015611b5657600080fd5b505af1158015611b6a573d6000803e3d6000fd5b5050505050565b600080600080600080600080600760009054906101000a90046001600160a01b03166001600160a01b0316635183d6fd8a6040518263ffffffff1660e01b8152600401808281526020019150506101006040518083038186803b15801561170e57600080fd5b611bdf611d31565b6005546001600160a01b03908116911614611c2f576040805162461bcd60e51b81526020600482018190526024820152600080516020613032833981519152604482015290519081900360640190fd5b6001600160a01b038116611c745760405162461bcd60e51b8152600401808060200182810382526026815260200180612f056026913960400191505060405180910390fd5b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600082820183811015611d2a576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b3390565b6001600160a01b038316611d7a5760405162461bcd60e51b81526004018080602001828103825260248152602001806131326024913960400191505060405180910390fd5b6001600160a01b038216611dbf5760405162461bcd60e51b8152600401808060200182810382526022815260200180612f2b6022913960400191505060405180910390fd5b6001600160a01b03808416600081815260016020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316611e665760405162461bcd60e51b81526004018080602001828103825260258152602001806130a06025913960400191505060405180910390fd5b6001600160a01b038216611eab5760405162461bcd60e51b8152600401808060200182810382526023815260200180612ee26023913960400191505060405180910390fd5b80611ec157611ebc838360006124ab565b6122e1565b600654600160a01b900460ff16158015611edd575060115460ff165b8015611f0157506001600160a01b03821660009081526014602052604090205460ff165b8015611f1b57506006546001600160a01b03848116911614155b8015611f4057506001600160a01b03831660009081526013602052604090205460ff16155b15611f8657600954811115611f865760405162461bcd60e51b815260040180806020018281038252603a8152602001806130c5603a913960400191505060405180910390fd5b6000611f9130611185565b600a546011549192508210159060ff168015611fb75750600654600160a01b900460ff16155b8015611ff557507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b031614155b1561207057801561207057600061202360105461201d600f548661260690919063ffffffff16565b9061265f565b905061202e816126a1565b600061204b60105461201d600e548761260690919063ffffffff16565b905061205681612747565b600061206130611185565b905061206c816127c3565b5050505b6001600160a01b03851660009081526013602052604090205460019060ff16806120b257506001600160a01b03851660009081526013602052604090205460ff165b156120bb575060005b80156120f85760006120dd606461201d6010548861260690919063ffffffff16565b90506120e98582612972565b94506120f68730836124ab565b505b6121038686866124ab565b6007546001600160a01b031663e30443bc8761211e81611185565b6040518363ffffffff1660e01b815260040180836001600160a01b0316815260200182815260200192505050600060405180830381600087803b15801561216457600080fd5b505af1925050508015612175575060015b506007546001600160a01b031663e30443bc8661219181611185565b6040518363ffffffff1660e01b815260040180836001600160a01b0316815260200182815260200192505050600060405180830381600087803b1580156121d757600080fd5b505af19250505080156121e8575060015b50600654600160a01b900460ff166122dd57601254600754604080516001624d3b8760e01b031981526004810184905290516001600160a01b039092169163ffb2c479916024808201926060929091908290030181600087803b15801561224e57600080fd5b505af192505050801561228257506040513d606081101561226e57600080fd5b508051602082015160409092015190919060015b61228b576122db565b604080518481526020810184905280820183905260608101869052905132916001917fc864333d6121033635ab41b29ae52f10a22cf4438c3e4f1c4c68518feb2f8a989181900360800190a35050505b505b5050505b505050565b600081848411156123755760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561233a578181015183820152602001612322565b50505050905090810190601f1680156123675780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6001600160a01b03821660009081526014602052604090205460ff16151581151514156123db5760405162461bcd60e51b8152600401808060200182810382526041815260200180612f4d6041913960600191505060405180910390fd5b6001600160a01b0382166000908152601460205260409020805460ff1916821580159190911790915561246f576007546040805163031e79db60e41b81526001600160a01b038581166004830152915191909216916331e79db091602480830192600092919082900301818387803b15801561245657600080fd5b505af115801561246a573d6000803e3d6000fd5b505050505b604051811515906001600160a01b038416907fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab90600090a35050565b6001600160a01b0383166124f05760405162461bcd60e51b81526004018080602001828103825260258152602001806130a06025913960400191505060405180910390fd5b6001600160a01b0382166125355760405162461bcd60e51b8152600401808060200182810382526023815260200180612ee26023913960400191505060405180910390fd5b6125408383836122e1565b61257d81604051806060016040528060268152602001612f8e602691396001600160a01b03861660009081526020819052604090205491906122e6565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546125ac9082611cd0565b6001600160a01b038084166000818152602081815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b60008261261557506000610bfe565b8282028284828161262257fe5b0414611d2a5760405162461bcd60e51b8152600401808060200182810382526021815260200180612fe96021913960400191505060405180910390fd5b6000611d2a83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506129b4565b6006805460ff60a01b1916600160a01b17905560006126c182600261265f565b905060006126cf8383612972565b9050476126db83612a19565b60006126e74783612972565b90506126f38382612bbf565b604080518581526020810183905280820185905290517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a150506006805460ff60a01b19169055505050565b6006805460ff60a01b1916600160a01b1790554761276482612a19565b60006127704783612972565b60115460405191925061010090046001600160a01b0316906108fc8315029083906000818181858888f193505050501580156127b0573d6000803e3d6000fd5b50506006805460ff60a01b191690555050565b6006805460ff60a01b1916600160a01b1790556127df81612a19565b600b544711156127f1576127f1612c92565b600854604080516370a0823160e01b815230600482015290516000926001600160a01b0316916370a08231916024808301926020929190829003018186803b15801561283c57600080fd5b505afa158015612850573d6000803e3d6000fd5b505050506040513d602081101561286657600080fd5b50516008546007546040805163a9059cbb60e01b81526001600160a01b039283166004820152602481018590529051939450600093919092169163a9059cbb91604480830192602092919082900301818787803b1580156128c657600080fd5b505af11580156128da573d6000803e3d6000fd5b505050506040513d60208110156128f057600080fd5b505190508015612960576007546040805163cf4837df60e01b81526004810185905290516001600160a01b039092169163cf4837df9160248082019260009290919082900301818387803b15801561294757600080fd5b505af115801561295b573d6000803e3d6000fd5b505050505b50506006805460ff60a01b1916905550565b6000611d2a83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506122e6565b60008183612a035760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561233a578181015183820152602001612322565b506000838581612a0f57fe5b0495945050505050565b60408051600280825260608083018452926020830190803683370190505090503081600081518110612a4757fe5b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b158015612a9b57600080fd5b505afa158015612aaf573d6000803e3d6000fd5b505050506040513d6020811015612ac557600080fd5b5051815182906001908110612ad657fe5b6001600160a01b039283166020918202929092010152600654612afc9130911684611d35565b60065460405163791ac94760e01b8152600481018481526000602483018190523060648401819052426084850181905260a060448601908152875160a487015287516001600160a01b039097169663791ac947968a968a9594939092909160c40190602080880191028083838b5b83811015612b82578181015183820152602001612b6a565b505050509050019650505050505050600060405180830381600087803b158015612bab57600080fd5b505af11580156122dd573d6000803e3d6000fd5b600654612bd79030906001600160a01b031684611d35565b6006546001600160a01b031663f305d719823085600080612bf6611438565b426040518863ffffffff1660e01b815260040180876001600160a01b03168152602001868152602001858152602001848152602001836001600160a01b0316815260200182815260200196505050505050506060604051808303818588803b158015612c6157600080fd5b505af1158015612c75573d6000803e3d6000fd5b50505050506040513d6060811015612c8c57600080fd5b50505050565b60408051600280825260608083018452926020830190803683375050600654604080516315ab88c960e31b815290519394506001600160a01b039091169263ad5c464892506004808301926020929190829003018186803b158015612cf657600080fd5b505afa158015612d0a573d6000803e3d6000fd5b505050506040513d6020811015612d2057600080fd5b505181518290600090612d2f57fe5b6001600160a01b039283166020918202929092010152600854825191169082906001908110612d5a57fe5b6001600160a01b03928316602091820292909201810191909152600654604051637ff36ab560e01b8152600060048201818152306044840181905242606485018190526080602486019081528951608487015289519690981697637ff36ab597479795968b969495939460a49091019187810191028083838b5b83811015612dec578181015183820152602001612dd4565b50505050905001955050505050506000604051808303818588803b158015612e1357600080fd5b505af1158015612e27573d6000803e3d6000fd5b50505050506040513d6000823e601f3d908101601f191682016040526020811015612e5157600080fd5b8101908080516040519392919084640100000000821115612e7157600080fd5b908301906020820185811115612e8657600080fd5b8251866020820283011164010000000082111715612ea357600080fd5b82525081516020918201928201910280838360005b83811015612ed0578181015183820152602001612eb8565b50505050905001604052505050505056fe45524332303a207472616e7366657220746f20746865207a65726f20616464726573734f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737345524332303a20617070726f766520746f20746865207a65726f20616464726573733633436c61696d3a204175746f6d61746564206d61726b6574206d616b6572207061697220697320616c72656164792073657420746f20746861742076616c756545524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e63653633436c61696d3a2043616e6e6f742075706461746520676173466f7250726f63657373696e6720746f2073616d652076616c7565536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f7745524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e63654f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65723633436c61696d3a205468652050616e63616b655377617020706169722063616e6e6f742062652072656d6f7665642066726f6d206175746f6d617465644d61726b65744d616b6572506169727345524332303a207472616e736665722066726f6d20746865207a65726f206164647265737353656c6c207472616e7366657220616d6f756e74206578636565647320746865206d617853656c6c5472616e73616374696f6e416d6f756e742e3633436c61696d3a204163636f756e7420697320616c7265616479207468652076616c7565206f6620276578636c756465642745524332303a20617070726f76652066726f6d20746865207a65726f20616464726573733633436c61696d3a20676173466f7250726f63657373696e67206d757374206265206265747765656e203230302c30303020616e64203530302c3030303633436c61696d3a2054686520726f7574657220616c7265616479206861732074686174206164647265737345524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220e80b63df991bf52df17ef4f34edad49313c6f0a9d9529c8d8302e634b711997c64736f6c634300060c003360c06040523480156200001157600080fd5b506040516200259838038062002598833981810160405260608110156200003757600080fd5b81019080805160405193929190846401000000008211156200005857600080fd5b9083019060208201858111156200006e57600080fd5b82516401000000008111828201881017156200008957600080fd5b82525081516020918201929091019080838360005b83811015620000b85781810151838201526020016200009e565b50505050905090810190601f168015620000e65780820380516001836020036101000a031916815260200191505b50604052602001805160405193929190846401000000008211156200010a57600080fd5b9083019060208201858111156200012057600080fd5b82516401000000008111828201881017156200013b57600080fd5b82525081516020918201929091019080838360005b838110156200016a57818101518382015260200162000150565b50505050905090810190601f168015620001985780820380516001836020036101000a031916815260200191505b5060405260209081015185519093508592508491849184918491620001c491600391908501906200026a565b508051620001da9060049060208401906200026a565b50505060601b6001600160601b0319166080525060009050620001fc62000266565b600a80546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35050603c601255505069d3c21bcecceda100000060a05262000306565b3390565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10620002ad57805160ff1916838001178555620002dd565b82800160010185558215620002dd579182015b82811115620002dd578251825591602001919060010190620002c0565b50620002eb929150620002ef565b5090565b5b80821115620002eb5760008155600101620002f0565b60805160601c60a051612261620003376000398061119352806112df525080610e935280611c3152506122616000f3fe60806040526004361061021e5760003560e01c8063715018a611610123578063bc4c4b37116100ab578063e7841ec01161006f578063e7841ec01461081f578063e98030c714610834578063f2fde38b1461085e578063fbcbc0f114610891578063ffb2c479146108c457610225565b8063bc4c4b3714610731578063be10b6141461076c578063cf4837df14610781578063dd62ed3e146107ab578063e30443bc146107e657610225565b806395d89b41116100f257806395d89b4114610644578063a457c2d714610659578063a8b9d24014610692578063a9059cbb146106c5578063aafd847a146106fe57610225565b8063715018a6146105d257806385a6b3ae146105e75780638da5cb5b146105fc57806391b89fba1461061157610225565b8063313ce567116101a65780635183d6fd116101755780635183d6fd146104cf5780636a474002146105445780636c092510146105595780636f2789ec1461058a57806370a082311461059f57610225565b8063313ce5671461040557806331e79db01461043057806339509351146104635780634e7b827f1461049c57610225565b806318160ddd116101ed57806318160ddd14610332578063226cfa3d1461034757806323b872dd1461037a57806327ce0147146103bd5780633009a609146103f057610225565b806303c833021461022a57806306fdde0314610234578063095ea7b3146102be57806309bbedde1461030b57610225565b3661022557005b600080fd5b61023261090c565b005b34801561024057600080fd5b5061024961099d565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561028357818101518382015260200161026b565b50505050905090810190601f1680156102b05780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b3480156102ca57600080fd5b506102f7600480360360408110156102e157600080fd5b506001600160a01b038135169060200135610a33565b604080519115158252519081900360200190f35b34801561031757600080fd5b50610320610a51565b60408051918252519081900360200190f35b34801561033e57600080fd5b50610320610a57565b34801561035357600080fd5b506103206004803603602081101561036a57600080fd5b50356001600160a01b0316610a5d565b34801561038657600080fd5b506102f76004803603606081101561039d57600080fd5b506001600160a01b03813581169160208101359091169060400135610a6f565b3480156103c957600080fd5b50610320600480360360208110156103e057600080fd5b50356001600160a01b0316610af6565b3480156103fc57600080fd5b50610320610b55565b34801561041157600080fd5b5061041a610b5b565b6040805160ff9092168252519081900360200190f35b34801561043c57600080fd5b506102326004803603602081101561045357600080fd5b50356001600160a01b0316610b60565b34801561046f57600080fd5b506102f76004803603604081101561048657600080fd5b506001600160a01b038135169060200135610cbc565b3480156104a857600080fd5b506102f7600480360360208110156104bf57600080fd5b50356001600160a01b0316610d0a565b3480156104db57600080fd5b506104f9600480360360208110156104f257600080fd5b5035610d1f565b604080516001600160a01b0390991689526020890197909752878701959095526060870193909352608086019190915260a085015260c084015260e083015251908190036101000190f35b34801561055057600080fd5b50610232610e7e565b34801561056557600080fd5b5061056e610e91565b604080516001600160a01b039092168252519081900360200190f35b34801561059657600080fd5b50610320610eb5565b3480156105ab57600080fd5b50610320600480360360208110156105c257600080fd5b50356001600160a01b0316610ebb565b3480156105de57600080fd5b50610232610ed6565b3480156105f357600080fd5b50610320610f78565b34801561060857600080fd5b5061056e610f7e565b34801561061d57600080fd5b506103206004803603602081101561063457600080fd5b50356001600160a01b0316610f8d565b34801561065057600080fd5b50610249610f98565b34801561066557600080fd5b506102f76004803603604081101561067c57600080fd5b506001600160a01b038135169060200135610ff9565b34801561069e57600080fd5b50610320600480360360208110156106b557600080fd5b50356001600160a01b0316611061565b3480156106d157600080fd5b506102f7600480360360408110156106e857600080fd5b506001600160a01b03813516906020013561108d565b34801561070a57600080fd5b506103206004803603602081101561072157600080fd5b50356001600160a01b03166110a1565b34801561073d57600080fd5b506102f76004803603604081101561075457600080fd5b506001600160a01b03813516906020013515156110bc565b34801561077857600080fd5b50610320611191565b34801561078d57600080fd5b50610232600480360360208110156107a457600080fd5b50356111b5565b3480156107b757600080fd5b50610320600480360360408110156107ce57600080fd5b506001600160a01b0381358116916020013516611234565b3480156107f257600080fd5b506102326004803603604081101561080957600080fd5b506001600160a01b03813516906020013561125f565b34801561082b57600080fd5b50610320611429565b34801561084057600080fd5b506102326004803603602081101561085757600080fd5b503561142f565b34801561086a57600080fd5b506102326004803603602081101561088157600080fd5b50356001600160a01b031661154a565b34801561089d57600080fd5b506104f9600480360360208110156108b457600080fd5b50356001600160a01b0316611643565b3480156108d057600080fd5b506108ee600480360360208110156108e757600080fd5b50356117b6565b60408051938452602084019290925282820152519081900360600190f35b6000610916610a57565b1161092057600080fd5b341561099b57610951610931610a57565b61093f34600160801b6118b4565b8161094657fe5b600554919004611914565b60055560408051348152905133917fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d78454116511919081900360200190a26009546109979034611914565b6009555b565b60038054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610a295780601f106109fe57610100808354040283529160200191610a29565b820191906000526020600020905b815481529060010190602001808311610a0c57829003601f168201915b5050505050905090565b6000610a47610a4061196e565b8484611972565b5060015b92915050565b600b5490565b60025490565b60116020526000908152604090205481565b6000610a7c848484610225565b610aec84610a8861196e565b610ae78560405180606001604052806028815260200161217a602891396001600160a01b038a16600090815260016020526040812090610ac661196e565b6001600160a01b031681526020810191909152604001600020549190611a5e565b611972565b5060019392505050565b6001600160a01b038116600090815260076020526040812054600160801b90610b4590610b4090610b3a610b35610b2c88610ebb565b600554906118b4565b611af5565b90611b05565b611b38565b81610b4c57fe5b0490505b919050565b600f5481565b601290565b610b6861196e565b600a546001600160a01b03908116911614610bb8576040805162461bcd60e51b815260206004820181905260248201526000805160206121a2833981519152604482015290519081900360640190fd5b6001600160a01b03811660009081526010602052604090205460ff1615610bde57600080fd5b6001600160a01b0381166000908152601060205260408120805460ff19166001179055610c0c908290611b4b565b6040805163131836e760e21b8152600b60048201526001600160a01b03831660248201529051730b980b94f3ba307f5304f5f7e254895031e68c4291634c60db9c916044808301926000929190829003018186803b158015610c6d57600080fd5b505af4158015610c81573d6000803e3d6000fd5b50506040516001600160a01b03841692507fa878b31040b2e6d0a9a3d3361209db3908ba62014b0dca52adbaee451d128b259150600090a250565b6000610a47610cc961196e565b84610ae78560016000610cda61196e565b6001600160a01b03908116825260208083019390935260409182016000908120918c168152925290205490611914565b60106020526000908152604090205460ff1681565b600080600080600080600080600b730b980b94f3ba307f5304f5f7e254895031e68c4263deb3d89690916040518263ffffffff1660e01b81526004018082815260200191505060206040518083038186803b158015610d7d57600080fd5b505af4158015610d91573d6000803e3d6000fd5b505050506040513d6020811015610da757600080fd5b50518910610dce575060009650600019955085945086935083925082915081905080610e73565b6000600b730b980b94f3ba307f5304f5f7e254895031e68c4263d1aa9e7e90918c6040518363ffffffff1660e01b8152600401808381526020018281526020019250505060206040518083038186803b158015610e2a57600080fd5b505af4158015610e3e573d6000803e3d6000fd5b505050506040513d6020811015610e5457600080fd5b50519050610e6181611643565b98509850985098509850985098509850505b919395975091939597565b610e8e610e8961196e565b611ba4565b50565b7f000000000000000000000000000000000000000000000000000000000000000081565b60125481565b6001600160a01b031660009081526020819052604090205490565b610ede61196e565b600a546001600160a01b03908116911614610f2e576040805162461bcd60e51b815260206004820181905260248201526000805160206121a2833981519152604482015290519081900360640190fd5b600a546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600a80546001600160a01b0319169055565b60095481565b600a546001600160a01b031690565b6000610a4b82611061565b60048054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610a295780601f106109fe57610100808354040283529160200191610a29565b6000610a4761100661196e565b84610ae785604051806060016040528060258152602001612207602591396001600061103061196e565b6001600160a01b03908116825260208083019390935260409182016000908120918d16815292529020549190611a5e565b6001600160a01b038116600090815260086020526040812054610a4b9061108784610af6565b90611d33565b6000610a4761109a61196e565b8484610225565b6001600160a01b031660009081526008602052604090205490565b60006110c661196e565b600a546001600160a01b03908116911614611116576040805162461bcd60e51b815260206004820181905260248201526000805160206121a2833981519152604482015290519081900360640190fd5b600061112184611ba4565b90508015611187576001600160a01b0384166000818152601160209081526040918290204290558151848152915186151593927fa2c38e2d2fb7e3e1912d937fd1ca11ed6d51864dee4cfa7a7bf02becd7acf09292908290030190a36001915050610a4b565b5060009392505050565b7f000000000000000000000000000000000000000000000000000000000000000081565b60006111bf610a57565b116111c957600080fd5b8015610e8e576111e86111da610a57565b61093f83600160801b6118b4565b60055560408051828152905133917fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d78454116511919081900360200190a260095461122e9082611914565b60095550565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b61126761196e565b600a546001600160a01b039081169116146112b7576040805162461bcd60e51b815260206004820181905260248201526000805160206121a2833981519152604482015290519081900360640190fd5b6001600160a01b03821660009081526010602052604090205460ff16156112dd57611425565b7f000000000000000000000000000000000000000000000000000000000000000081106113935761130e8282611b4b565b60408051632f0ad01760e21b8152600b60048201526001600160a01b0384166024820152604481018390529051730b980b94f3ba307f5304f5f7e254895031e68c429163bc2b405c916064808301926000929190829003018186803b15801561137657600080fd5b505af415801561138a573d6000803e3d6000fd5b50505050611418565b61139e826000611b4b565b6040805163131836e760e21b8152600b60048201526001600160a01b03841660248201529051730b980b94f3ba307f5304f5f7e254895031e68c4291634c60db9c916044808301926000929190829003018186803b1580156113ff57600080fd5b505af4158015611413573d6000803e3d6000fd5b505050505b6114238260016110bc565b505b5050565b600f5490565b61143761196e565b600a546001600160a01b03908116911614611487576040805162461bcd60e51b815260206004820181905260248201526000805160206121a2833981519152604482015290519081900360640190fd5b603c811015801561149b5750620151808111155b6114d65760405162461bcd60e51b815260040180806020018281038252604d8152602001806120c4604d913960600191505060405180910390fd5b6012548114156115175760405162461bcd60e51b815260040180806020018281038252603f815260200180612085603f913960400191505060405180910390fd5b60125460405182907f474ea64804364a1e29a4487ddb63c3342a2dd826ccd8acf48825e680a0e6f20f90600090a3601255565b61155261196e565b600a546001600160a01b039081169116146115a2576040805162461bcd60e51b815260206004820181905260248201526000805160206121a2833981519152604482015290519081900360640190fd5b6001600160a01b0381166115e75760405162461bcd60e51b81526004018080602001828103825260268152602001806121116026913960400191505060405180910390fd5b600a546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600a80546001600160a01b0319166001600160a01b0392909216919091179055565b600080600080600080600080889750600b730b980b94f3ba307f5304f5f7e254895031e68c426317e142d190918a6040518363ffffffff1660e01b815260040180838152602001826001600160a01b031681526020019250505060206040518083038186803b1580156116b557600080fd5b505af41580156116c9573d6000803e3d6000fd5b505050506040513d60208110156116df57600080fd5b5051965060001995506000871261174357600f5487111561170f57600f54611708908890611d75565b9550611743565b600f54600b5460009110611724576000611733565b600f54600b5461173391611d33565b905061173f8882611b05565b9650505b61174c88611061565b945061175788610af6565b6001600160a01b03891660009081526011602052604090205490945092508261178157600061178f565b60125461178f908490611914565b915042821161179f5760006117a9565b6117a98242611d33565b9050919395975091939597565b600b5460009081908190806117d6575050600f54600092508291506118ad565b600f546000805a90506000805b89841080156117f157508582105b1561189c57600b54600190950194851061180a57600094505b6000600b600001868154811061181c57fe5b60009182526020808320909101546001600160a01b0316808352601190915260409091205490915061184d90611da7565b156118695761185d8160016110bc565b15611869576001909101905b60019092019160005a905080851115611893576118906118898683611d33565b8790611914565b95505b93506117e39050565b600f85905590975095509193505050505b9193909250565b6000826118c357506000610a4b565b828202828482816118d057fe5b041461190d5760405162461bcd60e51b81526004018080602001828103825260218152602001806121596021913960400191505060405180910390fd5b9392505050565b60008282018381101561190d576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b3390565b6001600160a01b0383166119b75760405162461bcd60e51b81526004018080602001828103825260248152602001806121e36024913960400191505060405180910390fd5b6001600160a01b0382166119fc5760405162461bcd60e51b81526004018080602001828103825260228152602001806121376022913960400191505060405180910390fd5b6001600160a01b03808416600081815260016020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b60008184841115611aed5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611ab2578181015183820152602001611a9a565b50505050905090810190601f168015611adf5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b60008181811215610a4b57600080fd5b6000828201818312801590611b1a5750838112155b80611b2f5750600083128015611b2f57508381125b61190d57600080fd5b600080821215611b4757600080fd5b5090565b6000611b5683610ebb565b905080821115611b7e576000611b6c8383611d33565b9050611b788482611dce565b50611423565b80821015611423576000611b928284611d33565b9050611b9e8482611e32565b50505050565b600080611bb083611061565b90508015611d2a576001600160a01b038316600090815260086020526040902054611bdb9082611914565b6001600160a01b038416600081815260086020908152604091829020939093558051848152905191927fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d92918290030190a260007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663a9059cbb85846040518363ffffffff1660e01b815260040180836001600160a01b0316815260200182815260200192505050602060405180830381600087803b158015611ca657600080fd5b505af1158015611cba573d6000803e3d6000fd5b505050506040513d6020811015611cd057600080fd5b5051905080611d22576001600160a01b038416600090815260086020526040902054611cfc9083611d33565b6001600160a01b0385166000908152600860205260408120919091559250610b50915050565b509050610b50565b50600092915050565b600061190d83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611a5e565b6000818303818312801590611d8a5750838113155b80611b2f5750600083128015611b2f575083811361190d57600080fd5b600042821115611db957506000610b50565b601254611dc64284611d33565b101592915050565b611dd88282611e76565b611e12611df3610b35836005546118b490919063ffffffff16565b6001600160a01b03841660009081526007602052604090205490611d75565b6001600160a01b0390921660009081526007602052604090209190915550565b611e3c8282611f66565b611e12611e57610b35836005546118b490919063ffffffff16565b6001600160a01b03841660009081526007602052604090205490611b05565b6001600160a01b038216611ed1576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b611edd60008383611423565b600254611eea9082611914565b6002556001600160a01b038216600090815260208190526040902054611f109082611914565b6001600160a01b0383166000818152602081815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b6001600160a01b038216611fab5760405162461bcd60e51b81526004018080602001828103825260218152602001806121c26021913960400191505060405180910390fd5b611fb782600083611423565b611ff481604051806060016040528060228152602001612063602291396001600160a01b0385166000908152602081905260409020549190611a5e565b6001600160a01b03831660009081526020819052604090205560025461201a9082611d33565b6002556040805182815290516000916001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a3505056fe45524332303a206275726e20616d6f756e7420657863656564732062616c616e63653633436c61696d5f4469766964656e645f547261636b65723a2043616e6e6f742075706461746520636c61696d5761697420746f2073616d652076616c75653633436c61696d5f4469766964656e645f547261636b65723a20636c61696d57616974206d757374206265207570646174656420746f206265747765656e203120616e6420323420686f7572734f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737345524332303a20617070726f766520746f20746865207a65726f2061646472657373536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f7745524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e63654f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657245524332303a206275726e2066726f6d20746865207a65726f206164647265737345524332303a20617070726f76652066726f6d20746865207a65726f206164647265737345524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220a5e4196f4c02f300a26c4f78b3826076a98c2d3c366a66f58de245619479ecf264736f6c634300060c00333633436c61696d3a204175746f6d61746564206d61726b6574206d616b6572207061697220697320616c72656164792073657420746f20746861742076616c75653633436c61696d3a204163636f756e7420697320616c7265616479207468652076616c7565206f6620276578636c7564656427

Library Used

IterableMapping : 0x0b980b94f3ba307f5304f5f7e254895031e68c42Unverified


Deployed ByteCode Sourcemap

51285:14378:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;51630:62;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;14868:100;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17035:169;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;17035:169:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;52004:77;;;;;;;;;;;;;:::i;51363:41::-;;;;;;;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;51363:41:0;;;;;;;;;;;;;;15988:108;;;;;;;;;;;;;:::i;17686:355::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;17686:355:0;;;;;;;;;;;;;;;;;:::i;51495:43::-;;;;;;;;;;;;;:::i;57538:141::-;;;;;;;;;;;;;:::i;15830:93::-;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;18450:218;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;18450:218:0;;;;;;;;:::i;51411:38::-;;;;;;;;;;;;;:::i;59169:88::-;;;;;;;;;;;;;:::i;:::-;;57688:125;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57688:125:0;-1:-1:-1;;;;;57688:125:0;;:::i;59677:121::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;59677:121:0;-1:-1:-1;;;;;59677:121:0;;:::i;59401:141::-;;;;;;;;;;;;;:::i;55222:316::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;55222:316:0;-1:-1:-1;;;;;55222:316:0;;:::i;57975:130::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57975:130:0;-1:-1:-1;;;;;57975:130:0;;:::i;51926:32::-;;;;;;;;;;;;;:::i;52091:31::-;;;;;;;;;;;;;:::i;58901:259::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;58901:259:0;;:::i;16159:127::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;16159:127:0;-1:-1:-1;;;;;16159:127:0;;:::i;51548:69::-;;;;;;;;;;;;;:::i;12303:148::-;;;;;;;;;;;;;:::i;59911:129::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;59911:129:0;;:::i;56869:410::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;56869:410:0;;:::i;59551:114::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;59551:114:0;;:::i;51886:33::-;;;;;;;;;;;;;:::i;11661:79::-;;;;;;;;;;;;;:::i;15087:104::-;;;;;;;;;;;;;:::i;51965:32::-;;;;;;;;;;;;;:::i;56173:266::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;56173:266:0;;;;;;;;;;:::i;52247:40::-;;;;;;;;;;;;;:::i;58117:120::-;;;;;;;;;;;;;:::i;57421:108::-;;;;;;;;;;;;;:::i;19171:269::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;19171:269:0;;;;;;;;:::i;57822:147::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57822:147:0;-1:-1:-1;;;;;57822:147:0;;:::i;16499:175::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;16499:175:0;;;;;;;;:::i;58246:318::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;58246:318:0;-1:-1:-1;;;;;58246:318:0;;:::i;:::-;;;;-1:-1:-1;;;;;58246:318:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;52509:58;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;52509:58:0;-1:-1:-1;;;;;52509:58:0;;:::i;55547:300::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;55547:300:0;;;;;;;;;;:::i;55856:305::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;55856:305:0;-1:-1:-1;55856:305:0;;;;:::i;16737:151::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;16737:151:0;;;;;;;;;;:::i;59807:92::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;59807:92:0;;;;:::i;51699:52::-;;;;;;;;;;;;;:::i;51758:::-;;;;;;;;;;;;;:::i;59266:126::-;;;;;;;;;;;;;:::i;57288:124::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57288:124:0;;:::i;58570:325::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;58570:325:0;;:::i;12606:244::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;12606:244:0;-1:-1:-1;;;;;12606:244:0;;:::i;51630:62::-;;;;:::o;14868:100::-;14955:5;14948:12;;;;;;;;-1:-1:-1;;14948:12:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14922:13;;14948:12;;14955:5;;14948:12;;14955:5;14948:12;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14868:100;:::o;17035:169::-;17118:4;17135:39;17144:12;:10;:12::i;:::-;17158:7;17167:6;17135:8;:39::i;:::-;-1:-1:-1;17192:4:0;17035:169;;;;;:::o;52004:77::-;;;;:::o;51363:41::-;;;-1:-1:-1;;;;;51363:41:0;;:::o;15988:108::-;16076:12;;15988:108;:::o;17686:355::-;17826:4;17843:36;17853:6;17861:9;17872:6;17843:9;:36::i;:::-;17890:121;17899:6;17907:12;:10;:12::i;:::-;17921:89;17959:6;17921:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;17921:19:0;;;;;;:11;:19;;;;;;17941:12;:10;:12::i;:::-;-1:-1:-1;;;;;17921:33:0;;;;;;;;;;;;-1:-1:-1;17921:33:0;;;:89;:37;:89::i;:::-;17890:8;:121::i;:::-;-1:-1:-1;18029:4:0;17686:355;;;;;:::o;51495:43::-;;;-1:-1:-1;;;;;51495:43:0;;:::o;57538:141::-;57628:15;;:43;;;-1:-1:-1;;;57628:43:0;;;;57601:7;;-1:-1:-1;;;;;57628:15:0;;:41;;:43;;;;;;;;;;;;;;:15;:43;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57628:43:0;;-1:-1:-1;57538:141:0;:::o;15830:93::-;15913:2;15830:93;:::o;18450:218::-;18538:4;18555:83;18564:12;:10;:12::i;:::-;18578:7;18587:50;18626:10;18587:11;:25;18599:12;:10;:12::i;:::-;-1:-1:-1;;;;;18587:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;18587:25:0;;;:34;;;;;;;;;;;:38;:50::i;51411:38::-;;;:::o;59169:88::-;59200:15;;:49;;;-1:-1:-1;;;59200:49:0;;59231:10;59200:49;;;;:15;:49;;;;;;;;-1:-1:-1;;;;;59200:15:0;;;;:30;;:49;;;;;;;;;;;;;;;;;;:15;:49;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;59169:88:0:o;57688:125::-;-1:-1:-1;;;;;57777:28:0;57753:4;57777:28;;;:19;:28;;;;;;;;;57688:125::o;59677:121::-;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;59753:16:::1;:37:::0;;-1:-1:-1;;;;;59753:37:0;;::::1;;;-1:-1:-1::0;;;;;;59753:37:0;;::::1;::::0;;;::::1;::::0;;59677:121::o;59401:141::-;59493:15;;:41;;;-1:-1:-1;;;59493:41:0;;;;59466:7;;-1:-1:-1;;;;;59493:15:0;;:39;;:41;;;;;;;;;;;;;;:15;:41;;;;;;;;;;55222:316;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;55331:15:::1;::::0;-1:-1:-1;;;;;55309:38:0;;::::1;55331:15:::0;::::1;55309:38;;55301:95;;;;-1:-1:-1::0;;;55301:95:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;55454:15;::::0;55412:59:::1;::::0;-1:-1:-1;;;;;55454:15:0;;::::1;::::0;55412:59;::::1;::::0;::::1;::::0;55454:15:::1;::::0;55412:59:::1;55482:15;:48:::0;;-1:-1:-1;;;;;;55482:48:0::1;-1:-1:-1::0;;;;;55482:48:0;;;::::1;::::0;;;::::1;::::0;;55222:316::o;57975:130::-;58066:15;;:34;;;-1:-1:-1;;;58066:34:0;;-1:-1:-1;;;;;58066:34:0;;;;;;;;;58045:7;;58066:15;;;;;:25;;:34;;;;;;;;;;;;;;;:15;:34;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;58066:34:0;;57975:130;-1:-1:-1;;57975:130:0:o;51926:32::-;;;;:::o;52091:31::-;;;;;;:::o;58901:259::-;59027:15;;:28;;;-1:-1:-1;;;;;;59027:28:0;;;;;;;;;;58961:18;;;;;;-1:-1:-1;;;;;59027:15:0;;;;:23;;:28;;;;;;;;;;;;;;;58961:18;59027:15;:28;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;59027:28:0;;;;;;;;;;;;59065:87;;;;;;;;;;;;;;;;;59027:28;59065:87;;;;;;;59027:28;;-1:-1:-1;59027:28:0;-1:-1:-1;59027:28:0;;-1:-1:-1;59142:9:0;;59130:5;;59065:87;;;;;;;;;58901:259;;;;:::o;16159:127::-;-1:-1:-1;;;;;16260:18:0;16233:7;16260:18;;;;;;;;;;;;16159:127::o;51548:69::-;;;-1:-1:-1;;;;;51548:69:0;;:::o;12303:148::-;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;12394:6:::1;::::0;12373:40:::1;::::0;12410:1:::1;::::0;-1:-1:-1;;;;;12394:6:0::1;::::0;12373:40:::1;::::0;12410:1;;12373:40:::1;12424:6;:19:::0;;-1:-1:-1;;;;;;12424:19:0::1;::::0;;12303:148::o;59911:129::-;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;60023:8:::1;60013:19;59990:20;:42:::0;59911:129::o;56869:410::-;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;56967:6:::1;56955:8;:18;;:40;;;;;56989:6;56977:8;:18;;56955:40;56947:114;;;;-1:-1:-1::0;;;56947:114:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;57092:16;;57080:8;:28;;57072:94;;;;-1:-1:-1::0;;;57072:94:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;57216:16;::::0;57182:51:::1;::::0;57206:8;;57182:51:::1;::::0;;;::::1;57244:16;:27:::0;56869:410::o;59551:114::-;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;59624:24:::1;:33:::0;59551:114::o;51886:33::-;;;;:::o;11661:79::-;11726:6;;-1:-1:-1;;;;;11726:6:0;11661:79;:::o;15087:104::-;15176:7;15169:14;;;;;;;;-1:-1:-1;;15169:14:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15143:13;;15169:14;;15176:7;;15169:14;;15176:7;15169:14;;;;;;;;;;;;;;;;;;;;;;;;51965:32;;;;:::o;56173:266::-;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;56280:13:::1;-1:-1:-1::0;;;;;56272:21:0::1;:4;-1:-1:-1::0;;;;;56272:21:0::1;;;56264:112;;;;-1:-1:-1::0;;;56264:112:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56390:41;56419:4;56425:5;56390:28;:41::i;52247:40::-:0;;;;:::o;58117:120::-;58206:23;;58117:120;:::o;57421:108::-;57494:15;;:27;;;-1:-1:-1;;;57494:27:0;;;;57467:7;;-1:-1:-1;;;;;57494:15:0;;:25;;:27;;;;;;;;;;;;;;:15;:27;;;;;;;;;;19171:269;19264:4;19281:129;19290:12;:10;:12::i;:::-;19304:7;19313:96;19352:15;19313:96;;;;;;;;;;;;;;;;;:11;:25;19325:12;:10;:12::i;:::-;-1:-1:-1;;;;;19313:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;19313:25:0;;;:34;;;;;;;;;;;:96;:38;:96::i;57822:147::-;57915:15;;:47;;;-1:-1:-1;;;57915:47:0;;-1:-1:-1;;;;;57915:47:0;;;;;;;;;57891:7;;57915:15;;;;;:38;;:47;;;;;;;;;;;;;;;:15;:47;;;;;;;;;;16499:175;16585:4;16602:42;16612:12;:10;:12::i;:::-;16626:9;16637:6;16602:9;:42::i;58246:318::-;58342:7;58364:6;58385;58406:7;58428;58450;58472;58494;58521:15;;;;;;;;;-1:-1:-1;;;;;58521:15:0;-1:-1:-1;;;;;58521:26:0;;58548:7;58521:35;;;;;;;;;;;;;-1:-1:-1;;;;;58521:35:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;58521:35:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;58521:35:0;;-1:-1:-1;58521:35:0;;-1:-1:-1;58521:35:0;-1:-1:-1;58521:35:0;-1:-1:-1;58521:35:0;-1:-1:-1;58521:35:0;;-1:-1:-1;58521:35:0;-1:-1:-1;58246:318:0;;;;;;;;;:::o;52509:58::-;;;;;;;;;;;;;;;:::o;55547:300::-;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;55640:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;::::1;;:40;;::::0;::::1;;;;55632:104;;;;-1:-1:-1::0;;;55632:104:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1::0;;;;;55747:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;55747:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;55805:34;;;;;;;::::1;::::0;;;;;;;;::::1;55547:300:::0;;:::o;55856:305::-;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;55973:9:::1;55969:115;55988:19:::0;;::::1;55969:115;;;56064:8;56029:19;:32;56049:8;;56058:1;56049:11;;;;;;;;::::0;;::::1;::::0;;;::::1;;-1:-1:-1::0;;;;;56049:11:0::1;56029:32:::0;;-1:-1:-1;56029:32:0;::::1;::::0;;;;;;-1:-1:-1;56029:32:0;:43;;-1:-1:-1;;56029:43:0::1;::::0;::::1;;::::0;;;::::1;::::0;;-1:-1:-1;56009:3:0::1;55969:115;;;;56102:51;56134:8;;56144;56102:51;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;;::::1;::::0;::::1;::::0;::::1;::::0;;::::1;-1:-1:-1::0;;56102:51:0::1;::::0;;::::1;::::0;;::::1;::::0;-1:-1:-1;56102:51:0;;-1:-1:-1;;;;;56102:51:0::1;55856:305:::0;;;:::o;16737:151::-;-1:-1:-1;;;;;16853:18:0;;;16826:7;16853:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;16737:151::o;59807:92::-;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;59872:11:::1;:19:::0;;-1:-1:-1;;59872:19:0::1;::::0;::::1;;::::0;;;::::1;::::0;;59807:92::o;51699:52::-;;;;:::o;51758:::-;;;;:::o;59266:126::-;59345:15;;:39;;;-1:-1:-1;;;59345:39:0;;;;59321:7;;-1:-1:-1;;;;;59345:15:0;;:37;;:39;;;;;;;;;;;;;;:15;:39;;;;;;;;;;57288:124;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;57362:15:::1;::::0;:42:::1;::::0;;-1:-1:-1;;;57362:42:0;;::::1;::::0;::::1;::::0;;;;;-1:-1:-1;;;;;57362:15:0;;::::1;::::0;:31:::1;::::0;:42;;;;;:15:::1;::::0;:42;;;;;;;;:15;;:42;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;57288:124:::0;:::o;58570:325::-;58671:7;58693:6;58714;58735:7;58757;58779;58801;58823;58847:15;;;;;;;;;-1:-1:-1;;;;;58847:15:0;-1:-1:-1;;;;;58847:33:0;;58881:5;58847:40;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12606:244;11883:12;:10;:12::i;:::-;11873:6;;-1:-1:-1;;;;;11873:6:0;;;:22;;;11865:67;;;;;-1:-1:-1;;;11865:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;11865:67:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;12695:22:0;::::1;12687:73;;;;-1:-1:-1::0;;;12687:73:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12797:6;::::0;12776:38:::1;::::0;-1:-1:-1;;;;;12776:38:0;;::::1;::::0;12797:6:::1;::::0;12776:38:::1;::::0;12797:6:::1;::::0;12776:38:::1;12825:6;:17:::0;;-1:-1:-1;;;;;;12825:17:0::1;-1:-1:-1::0;;;;;12825:17:0;;;::::1;::::0;;;::::1;::::0;;12606:244::o;2492:181::-;2550:7;2582:5;;;2606:6;;;;2598:46;;;;;-1:-1:-1;;;2598:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;2664:1;2492:181;-1:-1:-1;;;2492:181:0:o;7493:115::-;7589:10;7493:115;:::o;22357:380::-;-1:-1:-1;;;;;22493:19:0;;22485:68;;;;-1:-1:-1;;;22485:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;22572:21:0;;22564:68;;;;-1:-1:-1;;;22564:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;22645:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;22697:32;;;;;;;;;;;;;;;;;22357:380;;;:::o;60049:2539::-;-1:-1:-1;;;;;60181:18:0;;60173:68;;;;-1:-1:-1;;;60173:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;60260:16:0;;60252:64;;;;-1:-1:-1;;;60252:64:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;60340:11;60337:92;;60368:28;60384:4;60390:2;60394:1;60368:15;:28::i;:::-;60411:7;;60337:92;60458:8;;-1:-1:-1;;;60458:8:0;;;;60457:9;:34;;;;-1:-1:-1;60480:11:0;;;;60457:34;:80;;;;-1:-1:-1;;;;;;60508:29:0;;;;;;:25;:29;;;;;;;;60457:80;:193;;;;-1:-1:-1;60634:15:0;;-1:-1:-1;;;;;60618:32:0;;;60634:15;;60618:32;;60457:193;:300;;;;-1:-1:-1;;;;;;60732:25:0;;;;;;:19;:25;;;;;;;;60731:26;60457:300;60442:459;;;60802:24;;60792:6;:34;;60784:105;;;;-1:-1:-1;;;60784:105:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;60911:28;60942:24;60960:4;60942:9;:24::i;:::-;61032:18;;61064:11;;60911:55;;-1:-1:-1;61008:42:0;;;;61064:11;;:24;;;;-1:-1:-1;61080:8:0;;-1:-1:-1;;;61080:8:0;;;;61079:9;61064:24;:49;;;;;61100:13;-1:-1:-1;;;;;61092:21:0;:4;-1:-1:-1;;;;;61092:21:0;;;61064:49;61061:540;;;61133:23;61129:458;;;61177:18;61198:53;61241:9;;61198:38;61223:12;;61198:20;:24;;:38;;;;:::i;:::-;:42;;:53::i;:::-;61177:74;;61270:26;61285:10;61270:14;:26::i;:::-;61317:23;61343:53;61386:9;;61343:38;61368:12;;61343:20;:24;;:38;;;;:::i;:53::-;61317:79;;61415:39;61438:15;61415:22;:39::i;:::-;61476:18;61497:24;61515:4;61497:9;:24::i;:::-;61476:45;;61540:32;61561:10;61540:20;:32::i;:::-;61129:458;;;;-1:-1:-1;;;;;61735:25:0;;61614:12;61735:25;;;:19;:25;;;;;;61629:4;;61735:25;;;:52;;-1:-1:-1;;;;;;61764:23:0;;;;;;:19;:23;;;;;;;;61735:52;61732:99;;;-1:-1:-1;61814:5:0;61732:99;61847:7;61844:189;;;61868:12;61883:30;61909:3;61883:21;61894:9;;61883:6;:10;;:21;;;;:::i;:30::-;61868:45;-1:-1:-1;61945:16:0;:6;61868:45;61945:10;:16::i;:::-;61936:25;;61979:42;61995:4;62009;62016;61979:15;:42::i;:::-;61844:189;;62046:33;62062:4;62068:2;62072:6;62046:15;:33::i;:::-;62097:15;;-1:-1:-1;;;;;62097:15:0;:26;62132:4;62139:15;62132:4;62139:9;:15::i;:::-;62097:58;;;;;;;;;;;;;-1:-1:-1;;;;;62097:58:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;62093:74;62181:15;;-1:-1:-1;;;;;62181:15:0;:26;62216:2;62221:13;62216:2;62221:9;:13::i;:::-;62181:54;;;;;;;;;;;;;-1:-1:-1;;;;;62181:54:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;62177:70;62264:8;;-1:-1:-1;;;62264:8:0;;;;62260:321;;62297:16;;62329:15;;:28;;;-1:-1:-1;;;;;;62329:28:0;;;;;;;;;;-1:-1:-1;;;;;62329:15:0;;;;:23;;:28;;;;;;;;;;;;;;;62283:11;62329:15;:28;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;62329:28:0;;;;;;;;;;;;;;;;62325:245;;;;;62446:86;;;;;;;;;;;;;;;;;;;;;;;;;;62522:9;;62511:4;;62446:86;;;;;;;;;62358:184;;;62325:245;62260:321;;60049:2539;;;;;;;:::o;3395:192::-;3481:7;3517:12;3509:6;;;;3501:29;;;;-1:-1:-1;;;3501:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;3553:5:0;;;3395:192::o;56448:410::-;-1:-1:-1;;;;;56539:31:0;;;;;;:25;:31;;;;;;;;:40;;;;;;;56531:118;;;;-1:-1:-1;;;56531:118:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;56660:31:0;;;;;;:25;:31;;;;;:39;;-1:-1:-1;;56660:39:0;;;;;;;;;;;;56713:79;;56738:15;;:42;;;-1:-1:-1;;;56738:42:0;;-1:-1:-1;;;;;56738:42:0;;;;;;;;;:15;;;;;:36;;:42;;;;;:15;;:42;;;;;;;:15;;:42;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56713:79;56810:40;;;;;;-1:-1:-1;;;;;56810:40:0;;;;;;;;56448:410;;:::o;19930:573::-;-1:-1:-1;;;;;20070:20:0;;20062:70;;;;-1:-1:-1;;;20062:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;20151:23:0;;20143:71;;;;-1:-1:-1;;;20143:71:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20227:47;20248:6;20256:9;20267:6;20227:20;:47::i;:::-;20307:71;20329:6;20307:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;20307:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;20287:17:0;;;:9;:17;;;;;;;;;;;:91;;;;20412:20;;;;;;;:32;;20437:6;20412:24;:32::i;:::-;-1:-1:-1;;;;;20389:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;20460:35;;;;;;;20389:20;;20460:35;;;;;;;;;;;;;19930:573;;;:::o;3846:471::-;3904:7;4149:6;4145:47;;-1:-1:-1;4179:1:0;4172:8;;4145:47;4216:5;;;4220:1;4216;:5;:1;4240:5;;;;;:10;4232:56;;;;-1:-1:-1;;;4232:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4793:132;4851:7;4878:39;4882:1;4885;4878:39;;;;;;;;;;;;;;;;;:3;:39::i;63501:677::-;53656:8;:15;;-1:-1:-1;;;;53656:15:0;-1:-1:-1;;;53656:15:0;;;;63637:13:::1;:6:::0;63648:1:::1;63637:10;:13::i;:::-;63622:28:::0;-1:-1:-1;63661:17:0::1;63681:16;:6:::0;63622:28;63681:10:::1;:16::i;:::-;63661:36:::0;-1:-1:-1;63735:21:0::1;63801:22;63818:4:::0;63801:16:::1;:22::i;:::-;63954:18;63975:41;:21;64001:14:::0;63975:25:::1;:41::i;:::-;63954:62;;64066:35;64079:9;64090:10;64066:12;:35::i;:::-;64127:43;::::0;;;;;::::1;::::0;::::1;::::0;;;;;;;;;;;::::1;::::0;;;;;;;::::1;-1:-1:-1::0;;53694:8:0;:16;;-1:-1:-1;;;;53694:16:0;;;-1:-1:-1;;;63501:677:0:o;62598:345::-;53656:8;:15;;-1:-1:-1;;;;53656:15:0;-1:-1:-1;;;53656:15:0;;;62705:21:::1;62740:24;62757:6:::0;62740:16:::1;:24::i;:::-;62823:18;62844:41;:21;62870:14:::0;62844:25:::1;:41::i;:::-;62897:16;::::0;:37:::1;::::0;62823:62;;-1:-1:-1;62897:16:0::1;::::0;::::1;-1:-1:-1::0;;;;;62897:16:0::1;::::0;:37:::1;::::0;::::1;;::::0;62823:62;;62897:37:::1;::::0;;;62823:62;62897:16;:37;::::1;;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;53694:8:0;:16;;-1:-1:-1;;;;53694:16:0;;;-1:-1:-1;;62598:345:0:o;64798:475::-;53656:8;:15;;-1:-1:-1;;;;53656:15:0;-1:-1:-1;;;53656:15:0;;;64874:24:::1;64891:6:::0;64874:16:::1;:24::i;:::-;64936:20;;64912:21;:44;64909:93;;;64974:16;:14;:16::i;:::-;65039:9;::::0;65032:42:::1;::::0;;-1:-1:-1;;;65032:42:0;;65068:4:::1;65032:42;::::0;::::1;::::0;;;65012:17:::1;::::0;-1:-1:-1;;;;;65039:9:0::1;::::0;65032:27:::1;::::0;:42;;;;;::::1;::::0;;;;;;;;65039:9;65032:42;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;65032:42:0;65107:9:::1;::::0;65135:15:::1;::::0;65100:63:::1;::::0;;-1:-1:-1;;;65100:63:0;;-1:-1:-1;;;;;65135:15:0;;::::1;65100:63;::::0;::::1;::::0;;;;;;;;;65032:42;;-1:-1:-1;65085:12:0::1;::::0;65107:9;;;::::1;::::0;65100:26:::1;::::0;:63;;;;;65032:42:::1;::::0;65100:63;;;;;;;65085:12;65107:9;65100:63;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;65100:63:0;;-1:-1:-1;65177:89:0;::::1;;;65204:15;::::0;:50:::1;::::0;;-1:-1:-1;;;65204:50:0;;::::1;::::0;::::1;::::0;;;;;-1:-1:-1;;;;;65204:15:0;;::::1;::::0;:39:::1;::::0;:50;;;;;:15:::1;::::0;:50;;;;;;;;:15;;:50;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;65177:89;-1:-1:-1::0;;53694:8:0;:16;;-1:-1:-1;;;;53694:16:0;;;-1:-1:-1;64798:475:0:o;2956:136::-;3014:7;3041:43;3045:1;3048;3041:43;;;;;;;;;;;;;;;;;:3;:43::i;5421:278::-;5507:7;5542:12;5535:5;5527:28;;;;-1:-1:-1;;;5527:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5566:9;5582:1;5578;:5;;;;;;;5421:278;-1:-1:-1;;;;;5421:278:0:o;64187:600::-;64343:16;;;64357:1;64343:16;;;64319:21;64343:16;;;;;64319:21;64343:16;;;;;;;;;;-1:-1:-1;64343:16:0;64319:40;;64388:4;64370;64375:1;64370:7;;;;;;;;-1:-1:-1;;;;;64370:23:0;;;:7;;;;;;;;;;:23;;;;64414:15;;:22;;;-1:-1:-1;;;64414:22:0;;;;:15;;;;;:20;;:22;;;;;64370:7;;64414:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;64414:22:0;64404:7;;:4;;64409:1;;64404:7;;;;;;-1:-1:-1;;;;;64404:32:0;;;:7;;;;;;;;;:32;64482:15;;64450:62;;64467:4;;64482:15;64500:11;64450:8;:62::i;:::-;64552:15;;:224;;-1:-1:-1;;;64552:224:0;;;;;;;;:15;:224;;;;;;64730:4;64552:224;;;;;;64750:15;64552:224;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;64552:15:0;;;;:66;;64633:11;;64703:4;;64730;64750:15;64552:224;;;;;;;;;;;;;;;;:15;:224;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;62956:533;63146:15;;63114:62;;63131:4;;-1:-1:-1;;;;;63146:15:0;63164:11;63114:8;:62::i;:::-;63219:15;;-1:-1:-1;;;;;63219:15:0;:31;63258:9;63291:4;63311:11;63219:15;;63423:7;:5;:7::i;:::-;63445:15;63219:252;;;;;;;;;;;;;-1:-1:-1;;;;;63219:252:0;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;63219:252:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;62956:533:0:o;65285:375::-;65354:16;;;65368:1;65354:16;;;65330:21;65354:16;;;;;65330:21;65354:16;;;;;;;;-1:-1:-1;;65391:15:0;;:22;;;-1:-1:-1;;;65391:22:0;;;;65330:40;;-1:-1:-1;;;;;;65391:15:0;;;;:20;;-1:-1:-1;65391:22:0;;;;;;;;;;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;65391:22:0;65381:7;;:4;;65386:1;;65381:7;;;;-1:-1:-1;;;;;65381:32:0;;;:7;;;;;;;;;:32;65434:9;;65424:7;;65434:9;;;65424:4;;65434:9;;65424:7;;;;;;-1:-1:-1;;;;;65424:19:0;;;:7;;;;;;;;;;:19;;;;65480:15;;:172;;-1:-1:-1;;;65480:172:0;;:15;:172;;;;;;65606:4;65480:172;;;;;;65626:15;65480:172;;;;;;;;;;;;;;;;;;;;;:15;;;;;:37;;65526:21;;65480:15;;65579:4;;65606;;65626:15;;65480:172;;;;;;;;;;;;;:15;:172;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;65480:172:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;65480:172:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;65285:375;:::o

Swarm Source

ipfs://a5e4196f4c02f300a26c4f78b3826076a98c2d3c366a66f58de245619479ecf2
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Block Uncle Number Difficulty Gas Used Reward
Loading