Contract 0x3ded3b39709d8292d7bcece99d80f72c09dfdaff

 
 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0xac2994ea304c1a1cab4926aad45817716d526ea8f44abc40082c66958e6652a8Approve95471562021-07-28 12:01:59132 days 8 hrs ago0x52d96a78e51405e9ef7e3529d949c7d0599f2575 IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.000288938889
0x5717ef74a484aef2d48f16b8bbaef42ec56b33119abbc791acf8f2e9a3ca124eApprove90420322021-07-10 19:05:21150 days 1 hr ago0x278737e92c19c7114dd2c4ca1cc24e5195d1e22a IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0x4bf2ac7abcb7f54f5ee47425fcaf6f491cc8ecd98d03d08ea22ba9740504e498Transfer90399642021-07-10 17:21:55150 days 3 hrs ago0xac56b7738b2009bef1127f730e558a5c5603a36e IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00120526
0xc8a94c0b3468441a42265812eabecaba0427d844758cadbaf5bd3689f79e8900Transfer90399522021-07-10 17:21:19150 days 3 hrs ago0xac56b7738b2009bef1127f730e558a5c5603a36e IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00013905
0x9db860bbb2fc8c723b8e8d09138ea38db3aa18cb623a235a6566a989bbe951ccClaim90397922021-07-10 17:13:18150 days 3 hrs ago0xac56b7738b2009bef1127f730e558a5c5603a36e IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.000145905
0xf297beaa4d463d8afc71e2b077b7b35bf2acf0be25403ea2b6fd2352c72e0df2Approve90396562021-07-10 17:06:30150 days 3 hrs ago0xe65ff201b9c883be6b9bd66d9f7959f4474ea912 IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.000266712889
0x727c12f9c5a082ebc17e1fc2546916df9e1062c0d67bbc6cfd9a55748e4fe97dApprove90390682021-07-10 16:37:06150 days 4 hrs ago0x5b9a09b587560e3d26f9e2c6d656d82c09a48efa IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0xfa4a79eade0634ce22bd9f958ea03c3b428969f0ae108e4f579dbb46084fc4a5Approve90390482021-07-10 16:36:06150 days 4 hrs ago0x7807b391abd07de2eb79b205824cd08d5a659f0c IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0xbfccfc7b91a0fb83ee11779bc2daa45eae87910db0a87ce6c15ce535e29a2321Approve90390452021-07-10 16:35:57150 days 4 hrs ago0xca3adc928a1c953075d75468a15fce99397d419c IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0xa071183f11df4e7d523c8b56d33bdda5f64b0020e68655b142dd3ab29c8a7947Approve90390412021-07-10 16:35:45150 days 4 hrs ago0x96a44404f7209812bc0de8b0cf949f21c22319ca IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0xf7904fdbeee1b6f52cc007137fd406069103bd265c5b44bb733c789b8f76952cApprove90390302021-07-10 16:35:12150 days 4 hrs ago0x0a76c58127bb63666ecf7a0c235f1d30fe46bb7f IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0x5b072b0972e5a0b22f763a9845b59f7fb836d400fce8d44d0ee26efb230ccdcaApprove90389802021-07-10 16:32:42150 days 4 hrs ago0x5c631a81dbfe8881fd34bf337271ca08403a5b35 IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0x03e0953247cdacea463699c98c1f2c69f384002b6d415a52cf4f3806a4e2531dApprove90389802021-07-10 16:32:42150 days 4 hrs ago0x5ec6f8c5242f8725063de8abb54e510800f3bdf2 IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0x81bbfefbc9fa3de0715966f7bd03858335f6c63e9870d9d8bdb79353ec610426Approve90389762021-07-10 16:32:30150 days 4 hrs ago0x497e51d4fddfbd6e0f14c53aec96eec18bba7949 IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0xf916ead1e07b3e827d958025c52dd1596b0b08aaef97efa1e5467847187eb15dApprove90389692021-07-10 16:32:09150 days 4 hrs ago0x4f11a5ba0bc3af595b6f017364c58a59fa8249e9 IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0xd18c546021ba3ae8f085b74120f93187be167ca15a1d6f9d4636f4586cf27dbcApprove90389622021-07-10 16:31:48150 days 4 hrs ago0x1b5a741759c6b08feffc885c982fc6b13b6a35ef IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0x393ff4915e0f619909c95d926afe9a62812d0aa433ec4079be99cbae4bb4092dApprove90389592021-07-10 16:31:39150 days 4 hrs ago0xc7c4b12c7bd219854be6e3018ec9467601a218ef IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.000266712
0xd3359f137e9cae4283be8a326bad30049dc8c613f15b506b72b2848f1cee6bc9Approve90389582021-07-10 16:31:36150 days 4 hrs ago0xe74a45dc594f0c7f3df8c4c51fd771452004f7ad IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0x11cb69fafc5ef63238ad89c7b676e4c56540d20980c9a0d2ed5e4aa96372bedbApprove90389562021-07-10 16:31:30150 days 4 hrs ago0x7fdec1f98b65691d6abd7b0a81dab9c2bf38911b IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022228
0x4d89eb4324d00ac8b85ef9f2622c48a7220cd3a12fa6d3ad67dff8a1e2d8307cApprove90389482021-07-10 16:31:06150 days 4 hrs ago0x67457c61a981186d9da796ab841eec4eb7867aa7 IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0x2b8291a2d5c8aaee7ae602869887d4ef133ad83954e4f405549419ad795d39faApprove90389352021-07-10 16:30:27150 days 4 hrs ago0xc6c7c121b2534552a07777828586a0487a4efba4 IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0x1ce2f823d9365932c043366601f3cfbb727f36e494cf4f8f7c9b19a111383b78Approve90388212021-07-10 16:24:45150 days 4 hrs ago0xac56b7738b2009bef1127f730e558a5c5603a36e IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0x84f4e891ab9ae4b63ddb2288a8ec82fda141f9ace1f1d6aa843a1682784ccd95Transfer90387872021-07-10 16:23:03150 days 4 hrs ago0x9ca309ed68522cb7b1410b39ac8af6b78fe2e45c IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.000369475
0x29b3d9572ecd0b8fd76bac40ce529a6d22e5f803b9b632c7f82ba19eae5a070fApprove90386382021-07-10 16:15:36150 days 4 hrs ago0x97a32d98ab88027308feba7debdad29dc6d40bed IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
0x45f49aa15d4ab2ae5a8b614f8854375354a5e672cdeda944bdcdeb19fe2d1a25Approve90384372021-07-10 16:05:33150 days 4 hrs ago0x9ca309ed68522cb7b1410b39ac8af6b78fe2e45c IN  0x3ded3b39709d8292d7bcece99d80f72c09dfdaff0 BNB0.00022226
[ Download CSV Export 
Latest 1 internal transaction
Parent Txn Hash Block From To Value
0xa252198257c7c9eac30a188ca778feff9c5b92a8ee074becddbf3a3484a7520c89590312021-07-07 21:53:38152 days 22 hrs ago 0x3ded3b39709d8292d7bcece99d80f72c09dfdaff  Contract Creation0 BNB
[ Download CSV Export 
Loading
This contract contains unverified libraries: IterableMapping

Contract Source Code Verified (Exact Match)

Contract Name:
TOKEN

Compiler Version
v0.7.6+commit.7338295f

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

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

// SPDX-License-Identifier: MIT
 
pragma solidity ^0.7.0;
 
/**
 * @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);
}
 
// File: contracts/Context.sol
 
pragma solidity >=0.6.0 <0.8.0;
 
/*
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with GSN meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address payable) {
        return 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;
    }
}
 
// File: contracts/IUniswapV2Router01.sol
 
pragma solidity >=0.6.2;
 
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);
}
// File: contracts/IUniswapV2Router02.sol
 
pragma solidity >=0.6.2;
 
 
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;
}
// File: contracts/IUniswapV2Factory.sol
 
pragma solidity >=0.5.0;
 
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;
}
// File: contracts/IUniswapV2Pair.sol
 
pragma solidity >=0.5.0;
 
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;
}
// File: contracts/IterableMapping.sol
 
// 
pragma solidity ^0.7.6;
 
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();
    }
}
// File: contracts/Ownable.sol
 
// 
 
pragma solidity ^0.7.0;
 
/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;
 
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
 
    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }
 
    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual returns (address) {
        return _owner;
    }
 
    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }
 
    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }
 
    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}
// File: contracts/IDividendPayingTokenOptional.sol
 
pragma solidity ^0.7.6;
 
 
/// @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);
}
// File: contracts/IDividendPayingToken.sol
 
pragma solidity ^0.7.6;
 
 
/// @title Dividend-Paying Token Interface
/// @author Roger Wu (https://github.com/roger-wu)
/// @dev An interface for a dividend-paying token contract.
interface IDividendPayingToken {
  /// @notice View the amount of dividend in wei that an address can withdraw.
  /// @param _owner The address of a token holder.
  /// @return The amount of dividend in wei that `_owner` can withdraw.
  function dividendOf(address _owner) external view returns(uint256);
 
  /// @notice Distributes ether to token holders as dividends.
  /// @dev SHOULD distribute the paid ether to token holders as dividends.
  ///  SHOULD NOT directly transfer ether to token holders in this function.
  ///  MUST emit a `DividendsDistributed` event when the amount of distributed ether is greater than 0.
  function distributeDividends() external payable;
 
  /// @notice Withdraws the ether distributed to the sender.
  /// @dev SHOULD transfer `dividendOf(msg.sender)` wei to `msg.sender`, and `dividendOf(msg.sender)` SHOULD be 0 after the transfer.
  ///  MUST emit a `DividendWithdrawn` event if the amount of ether transferred is greater than 0.
  function withdrawDividend() external;
 
  /// @dev This event MUST emit when ether is distributed to token holders.
  /// @param from The address which sends ether to this contract.
  /// @param weiAmount The amount of distributed ether in wei.
  event DividendsDistributed(
    address indexed from,
    uint256 weiAmount
  );
 
  /// @dev This event MUST emit when an address withdraws their dividend.
  /// @param to The address which withdraws ether from this contract.
  /// @param weiAmount The amount of withdrawn ether in wei.
  event DividendWithdrawn(
    address indexed to,
    uint256 weiAmount
  );
}
// File: contracts/SafeMathInt.sol
 
pragma solidity ^0.7.6;
 
/**
 * @title SafeMathInt
 * @dev Math operations with safety checks that revert on error
 * @dev SafeMath adapted for int256
 * Based on code of  https://github.com/RequestNetwork/requestNetwork/blob/master/packages/requestNetworkSmartContracts/contracts/base/math/SafeMathInt.sol
 */
library SafeMathInt {
  function mul(int256 a, int256 b) internal pure returns (int256) {
    // Prevent overflow when multiplying INT256_MIN with -1
    // https://github.com/RequestNetwork/requestNetwork/issues/43
    require(!(a == - 2**255 && b == -1) && !(b == - 2**255 && a == -1));
 
    int256 c = a * b;
    require((b == 0) || (c / b == a));
    return c;
  }
 
  function div(int256 a, int256 b) internal pure returns (int256) {
    // Prevent overflow when dividing INT256_MIN by -1
    // https://github.com/RequestNetwork/requestNetwork/issues/43
    require(!(a == - 2**255 && b == -1) && (b > 0));
 
    return a / b;
  }
 
  function sub(int256 a, int256 b) internal pure returns (int256) {
    require((b >= 0 && a - b <= a) || (b < 0 && a - b > a));
 
    return a - b;
  }
 
  function add(int256 a, int256 b) internal pure returns (int256) {
    int256 c = a + b;
    require((b >= 0 && c >= a) || (b < 0 && c < a));
    return c;
  }
 
  function toUint256Safe(int256 a) internal pure returns (uint256) {
    require(a >= 0);
    return uint256(a);
  }
}
// File: contracts/SafeMathUint.sol
 
pragma solidity ^0.7.6;
 
/**
 * @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;
  }
}
 
// File: contracts/ERC20.sol
 
// 
 
pragma solidity ^0.7.0;
 
 
 
 
/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 * For a generic mechanism see {ERC20PresetMinterPauser}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin guidelines: functions revert instead
 * of returning `false` on failure. This behavior is nonetheless conventional
 * and does not conflict with the expectations of ERC20 applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 *
 * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
 * functions have been added to mitigate the well-known issues around setting
 * allowances. See {IERC20-approve}.
 */
contract ERC20 is Context, IERC20 {
    using SafeMath for uint256;
 
    mapping (address => uint256) private _balances;
 
    mapping (address => mapping (address => uint256)) private _allowances;
 
    uint256 private _totalSupply;
 
    string private _name;
    string private _symbol;
    uint8 private _decimals;
 
    /**
     * @dev Sets the values for {name} and {symbol}, initializes {decimals} with
     * a default value of 18.
     *
     * To select a different value for {decimals}, use {_setupDecimals}.
     *
     * All three of these values are immutable: they can only be set once during
     * construction.
     */
    constructor (string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
        _decimals = 18;
    }
 
    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual returns (string memory) {
        return _name;
    }
 
    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual returns (string memory) {
        return _symbol;
    }
 
    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5,05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless {_setupDecimals} is
     * called.
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual returns (uint8) {
        return _decimals;
    }
 
    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }
 
    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account) public view virtual override returns (uint256) {
        return _balances[account];
    }
 
    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }
 
    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }
 
    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }
 
    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }
 
    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
        return true;
    }
 
    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
        return true;
    }
 
    /**
     * @dev Moves tokens `amount` from `sender` to `recipient`.
     *
     * This is internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(address sender, address recipient, uint256 amount) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
 
        _beforeTokenTransfer(sender, recipient, amount);
 
        _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
    }
 
    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");
 
        _beforeTokenTransfer(address(0), account, amount);
 
        _totalSupply = _totalSupply.add(amount);
        _balances[account] = _balances[account].add(amount);
        emit Transfer(address(0), account, amount);
    }
 
    /**
     * @dev Destroys `amount` tokens from `account`, reducing the
     * total supply.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     * - `account` must have at least `amount` tokens.
     */
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");
 
        _beforeTokenTransfer(account, address(0), amount);
 
        _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
        _totalSupply = _totalSupply.sub(amount);
        emit Transfer(account, address(0), amount);
    }
 
    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    function _approve(address owner, address spender, uint256 amount) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
 
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }
 
    /**
     * @dev Sets {decimals} to a value other than the default one of 18.
     *
     * WARNING: This function should only be called from the constructor. Most
     * applications that interact with token contracts will not expect
     * {decimals} to ever change, and may work incorrectly if it does.
     */
    function _setupDecimals(uint8 decimals_) internal virtual {
        _decimals = decimals_;
    }
 
    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be to transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual { }
}
// File: contracts/SafeMath.sol
 
// 
 
pragma solidity ^0.7.0;
 
/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        uint256 c = a + b;
        if (c < a) return (false, 0);
        return (true, c);
    }
 
    /**
     * @dev Returns the substraction of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b > a) return (false, 0);
        return (true, a - b);
    }
 
    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) return (true, 0);
        uint256 c = a * b;
        if (c / a != b) return (false, 0);
        return (true, c);
    }
 
    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b == 0) return (false, 0);
        return (true, a / b);
    }
 
    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b == 0) return (false, 0);
        return (true, a % b);
    }
 
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }
 
    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a, "SafeMath: subtraction overflow");
        return a - b;
    }
 
    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) return 0;
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }
 
    /**
     * @dev Returns the integer division of two unsigned integers, reverting on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: division by zero");
        return a / b;
    }
 
    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: modulo by zero");
        return a % b;
    }
 
    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        return a - b;
    }
 
    /**
     * @dev Returns the integer division of two unsigned integers, reverting with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryDiv}.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        return a / b;
    }
 
    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting with custom message when dividing by zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryMod}.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        return a % b;
    }
}
 
// File: contracts/99XDOGEDividendPayingToken.sol
 
// 
 
pragma solidity ^0.7.6;
 
 
 
 
 
 
 
 
 
/// @title Dividend-Paying Token
/// @author Roger Wu (https://github.com/roger-wu)
/// @dev A mintable ERC20 token that allows anyone to pay and distribute ether
///  to token holders as dividends and allows token holders to withdraw their dividends.
///  Reference: the source code of PoWH3D: https://etherscan.io/address/0xB3775fB83F7D12A36E0475aBdD1FCA35c091efBe#code
contract DividendPayingToken is ERC20, IDividendPayingToken, IDividendPayingTokenOptional {
  using SafeMath for uint256;
  using SafeMathUint for uint256;
  using SafeMathInt for int256;
 
  // With `magnitude`, we can properly distribute dividends even if the amount of received ether is small.
  // For more discussion about choosing the value of `magnitude`,
  //  see https://github.com/ethereum/EIPs/issues/1726#issuecomment-472352728
  uint256 constant internal magnitude = 2**128;
 
  uint256 internal magnifiedDividendPerShare;
  uint256 internal lastAmount;
 
  address public immutable DOGEToken = address(0xbA2aE424d960c26247Dd6c32edC70B295c744C43);
 
  // 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) public ERC20(_name, _symbol) {
 
  }
 
 
  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(msg.sender);
  }
 
  /// @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(DOGEToken).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);
    }
  }
}
 
// File: contracts/99XDOGE.sol
 
// 
 
pragma solidity ^0.7.6;
 
 
 
 
 
 
 
 
 
contract TOKEN is ERC20, Ownable {
    using SafeMath for uint256;
 
    IUniswapV2Router02 public uniswapV2Router;
    address public immutable uniswapV2Pair;
 
    address public immutable DOGEToken = address(0xbA2aE424d960c26247Dd6c32edC70B295c744C43);
 
    bool private swapping;
    bool public swapEnabled;
 
    XDOGEDividendTracker public dividendTracker;
 
    address public liquidityWallet;
 
    uint256 public maxSellTransactionAmount = 1000000 * (10**18);
    uint256 public swapTokensAtAmount = 200000 * (10**18);
 
    uint256 public  DOGERewardsFee = 9;
    uint256 public  buyBackFee = 6;
    uint256 public  totalFees = DOGERewardsFee.add(buyBackFee);
 
    uint256 public buyBackUpperLimit = 1 * 10**18;
    bool public buyBackEnabled = true;
    // use by default 300,000 gas to process auto-claiming dividends
    uint256 public gasForProcessing = 300000;
 
    // exlcude from fees and max transaction amount
    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 LiquidityWalletUpdated(address indexed newLiquidityWallet, address indexed oldLiquidityWallet);
 
    event GasForProcessingUpdated(uint256 indexed newValue, uint256 indexed oldValue);
 
 
    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("99XDOGE", "99XDOGE") {
 
    	dividendTracker = new XDOGEDividendTracker();
 
    	liquidityWallet = owner();
 
 
    	IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x10ED43C718714eb63d5aA57B78B54704E256024E);
         // 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(0));
        dividendTracker.excludeFromDividends(address(_uniswapV2Router));
 
 
        // exclude from paying fees or having max transaction amount
        excludeFromFees(liquidityWallet, 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(), 1000000000000000000 * (10**18));
    }
 
    receive() external payable {
 
  	}
 
 
  	function whitelistDxSale(address _presaleAddress, address _routerAddress) public onlyOwner {
        dividendTracker.excludeFromDividends(_presaleAddress);
        excludeFromFees(_presaleAddress, true);
 
        dividendTracker.excludeFromDividends(_routerAddress);
        excludeFromFees(_routerAddress, true);
  	}
 
    function updateDividendTracker(address newAddress) public onlyOwner {
        require(newAddress != address(dividendTracker), "99XDOGE: The dividend tracker already has that address");
 
        XDOGEDividendTracker newDividendTracker = XDOGEDividendTracker(payable(newAddress));
 
        require(newDividendTracker.owner() == address(this), "99XDOGE: The new dividend tracker must be owned by the 99XDOGE token contract");
 
        newDividendTracker.excludeFromDividends(address(newDividendTracker));
        newDividendTracker.excludeFromDividends(address(this));
        newDividendTracker.excludeFromDividends(owner());
        newDividendTracker.excludeFromDividends(address(uniswapV2Router));
 
        emit UpdateDividendTracker(newAddress, address(dividendTracker));
 
        dividendTracker = newDividendTracker;
    }
 
    function updateUniswapV2Router(address newAddress) public onlyOwner {
        require(newAddress != address(uniswapV2Router), "99XDOGE: 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, "99XDOGE: 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, "99XDOGE: The PancakeSwap pair cannot be removed from automatedMarketMakerPairs");
 
        _setAutomatedMarketMakerPair(pair, value);
    }
 
    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        require(automatedMarketMakerPairs[pair] != value, "99XDOGE: Automated market maker pair is already set to that value");
        automatedMarketMakerPairs[pair] = value;
 
        if(value) {
            dividendTracker.excludeFromDividends(pair);
        }
 
        emit SetAutomatedMarketMakerPair(pair, value);
    }
 
 
    function updateLiquidityWallet(address newLiquidityWallet) public onlyOwner {
        require(newLiquidityWallet != liquidityWallet, "99XDOGE: The liquidity wallet is already this address");
        excludeFromFees(newLiquidityWallet, true);
        emit LiquidityWalletUpdated(newLiquidityWallet, liquidityWallet);
        liquidityWallet = newLiquidityWallet;
    }
 
    function setMaxSellTxAMount(uint256 amount) external onlyOwner{
        maxSellTransactionAmount = amount;
    }
 
    function setDOGErewardsFee(uint256 newFee) external onlyOwner{
        DOGERewardsFee = newFee;
        totalFees = DOGERewardsFee.add(buyBackFee);
    }
 
 
    function updateGasForProcessing(uint256 newValue) public onlyOwner {
        require(newValue >= 200000 && newValue <= 500000, "99XDOGE: gasForProcessing must be between 200,000 and 500,000");
        require(newValue != gasForProcessing, "99XDOGE: 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 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 _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
 
        if(amount == 0) {
            super._transfer(from, to, 0);
            return;
        }
 
	    if( 
        	!swapping &&
            automatedMarketMakerPairs[to] && // sells only by detecting transfer to automated market maker pair
            !_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) {
            uint256 balance = address(this).balance;
            if(to == uniswapV2Pair){
                if (buyBackEnabled && balance > uint256(1 * 10**18)) {
 
                    if (balance > buyBackUpperLimit)
                        balance = buyBackUpperLimit;
 
                    buyBackTokens(balance.div(100));
                }
            }
 
           if (overMinimumTokenBalance) {
               contractTokenBalance = swapTokensAtAmount;
 
                uint256 buybackTokens = contractTokenBalance.mul(buyBackFee).div(totalFees);
                swapBuyBackTokens(buybackTokens);
 
                uint256 sellTokens = balanceOf(address(this));
                swapAndSendDividends(sellTokens);
           }
 
        }
 
 
        bool takeFee =  !swapping;
 
        // 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 swapETHForTokens(uint256 amount) private {
        // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = uniswapV2Router.WETH();
        path[1] = address(this);
 
      // make the swap
        uniswapV2Router.swapExactETHForTokensSupportingFeeOnTransferTokens{value: amount}(
            0, // accept any amount of Tokens
            path,
            address(0), // Burn address
            block.timestamp.add(300)
        );
 
    }
 
    function buyBackTokens(uint256 amount) private lockTheSwap{
    	if (amount > 0) {
    	    swapETHForTokens(amount);
	    }
    }
 
    function swapBuyBackTokens(uint256 tokens) private lockTheSwap{
        swapTokensForEth(tokens);
    }
 
    function setBuybackFee(uint256 newFee) external onlyOwner{
        buyBackFee = newFee;
        totalFees = DOGERewardsFee.add(buyBackFee);
    }
 
    function setBuyBackEnabled(bool _enabled) public onlyOwner {
        buyBackEnabled = _enabled;
    }
 
    function setBuybackUpperLimit(uint256 buyBackLimit) external onlyOwner() {
        buyBackUpperLimit = buyBackLimit * 10**18;
    }
 
    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 swapTokensForDoge(uint256 tokenAmount, address recipient) private {
 
        // generate the uniswap pair path of weth -> busd
        address[] memory path = new address[](3);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        path[2] = DOGEToken;
 
        _approve(address(this), address(uniswapV2Router), tokenAmount);
 
        // make the swap
        uniswapV2Router.swapExactTokensForTokensSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of DOGE
            path,
            recipient,
            block.timestamp
        );
 
    }
 
 
    function swapAndSendDividends(uint256 tokens) private lockTheSwap{
        swapTokensForDoge(tokens, address(this));
        uint256 dividends = IERC20(DOGEToken).balanceOf(address(this));
        bool success = IERC20(DOGEToken).transfer(address(dividendTracker), dividends);
 
        if (success) {
            dividendTracker.distributeDogeDividends(dividends);
            emit SendDividends(tokens, dividends);
        }
    }
 
}
 
contract XDOGEDividendTracker is DividendPayingToken, Ownable {
    using SafeMath for uint256;
    using SafeMathInt for int256;
    using IterableMapping for IterableMapping.Map;
 
    IterableMapping.Map private tokenHoldersMap;
    uint256 public lastProcessedIndex;
 
    mapping (address => bool) public excludedFromDividends;
 
    mapping (address => uint256) public lastClaimTimes;
 
    uint256 public claimWait;
    uint256 public immutable minimumTokenBalanceForDividends;
 
    event ExcludeFromDividends(address indexed account);
    event ClaimWaitUpdated(uint256 indexed newValue, uint256 indexed oldValue);
 
    event Claim(address indexed account, uint256 amount, bool indexed automatic);
 
    constructor() public DividendPayingToken("99XDOGE_Dividend_Tracker", "99XDOGE_Dividend_Tracker") {
    	claimWait = 86400; //24h
        minimumTokenBalanceForDividends = 10000000000000 * (10**18); //must hold 10T tokens
    }
 
    function _transfer(address, address, uint256) internal override {
        require(false, "99XDOGE_Dividend_Tracker: No transfers allowed");
    }
 
    function withdrawDividend() public override {
        require(false, "99XDOGE_Dividend_Tracker: withdrawDividend disabled. Use the 'claim' function on the main 99XDOGE contract.");
    }
 
    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 >= 3600 && newClaimWait <= 86400, "99XDOGE_Dividend_Tracker: claimWait must be updated to between 1 and 24 hours");
        require(newClaimWait != claimWait, "99XDOGE_Dividend_Tracker: Cannot update claimWait to same value");
        emit ClaimWaitUpdated(newClaimWait, claimWait);
        claimWait = newClaimWait;
    }
 
    function getLastProcessedIndex() external view returns(uint256) {
    	return lastProcessedIndex;
    }
 
    function getNumberOfTokenHolders() external view returns(uint256) {
        return tokenHoldersMap.keys.length;
    }
 
 
    function getAccount(address _account)
        public view returns (
            address account,
            int256 index,
            int256 iterationsUntilProcessed,
            uint256 withdrawableDividends,
            uint256 totalDividends,
            uint256 lastClaimTime,
            uint256 nextClaimTime,
            uint256 secondsUntilAutoClaimAvailable) {
        account = _account;
 
        index = tokenHoldersMap.getIndexOfKey(account);
 
        iterationsUntilProcessed = -1;
 
        if(index >= 0) {
            if(uint256(index) > lastProcessedIndex) {
                iterationsUntilProcessed = index.sub(int256(lastProcessedIndex));
            }
            else {
                uint256 processesUntilEndOfArray = tokenHoldersMap.keys.length > lastProcessedIndex ?
                                                        tokenHoldersMap.keys.length.sub(lastProcessedIndex) :
                                                        0;
 
 
                iterationsUntilProcessed = index.add(int256(processesUntilEndOfArray));
            }
        }
 
 
        withdrawableDividends = withdrawableDividendOf(account);
        totalDividends = accumulativeDividendOf(account);
 
        lastClaimTime = lastClaimTimes[account];
 
        nextClaimTime = lastClaimTime > 0 ?
                                    lastClaimTime.add(claimWait) :
                                    0;
 
        secondsUntilAutoClaimAvailable = nextClaimTime > block.timestamp ?
                                                    nextClaimTime.sub(block.timestamp) :
                                                    0;
    }
 
    function getAccountAtIndex(uint256 index)
        public view returns (
            address,
            int256,
            int256,
            uint256,
            uint256,
            uint256,
            uint256,
            uint256) {
    	if(index >= tokenHoldersMap.size()) {
            return (0x0000000000000000000000000000000000000000, -1, -1, 0, 0, 0, 0, 0);
        }
 
        address account = tokenHoldersMap.getKeyAtIndex(index);
 
        return getAccount(account);
    }
 
    function canAutoClaim(uint256 lastClaimTime) private view returns (bool) {
    	if(lastClaimTime > block.timestamp)  {
    		return false;
    	}
 
    	return block.timestamp.sub(lastClaimTime) >= claimWait;
    }
 
    function setBalance(address payable account, uint256 newBalance) external onlyOwner {
    	if(excludedFromDividends[account]) {
    		return;
    	}
 
    	if(newBalance >= minimumTokenBalanceForDividends) {
            _setBalance(account, newBalance);
    		tokenHoldersMap.set(account, newBalance);
    	}
    	else {
            _setBalance(account, 0);
    		tokenHoldersMap.remove(account);
    	}
 
    	processAccount(account, true);
    }
 
    function process(uint256 gas) public returns (uint256, uint256, uint256) {
    	uint256 numberOfTokenHolders = tokenHoldersMap.keys.length;
 
    	if(numberOfTokenHolders == 0) {
    		return (0, 0, lastProcessedIndex);
    	}
 
    	uint256 _lastProcessedIndex = lastProcessedIndex;
 
    	uint256 gasUsed = 0;
 
    	uint256 gasLeft = gasleft();
 
    	uint256 iterations = 0;
    	uint256 claims = 0;
 
    	while(gasUsed < gas && iterations < numberOfTokenHolders) {
    		_lastProcessedIndex++;
 
    		if(_lastProcessedIndex >= tokenHoldersMap.keys.length) {
    			_lastProcessedIndex = 0;
    		}
 
    		address account = tokenHoldersMap.keys[_lastProcessedIndex];
 
    		if(canAutoClaim(lastClaimTimes[account])) {
    			if(processAccount(payable(account), true)) {
    				claims++;
    			}
    		}
 
    		iterations++;
 
    		uint256 newGasLeft = gasleft();
 
    		if(gasLeft > newGasLeft) {
    			gasUsed = gasUsed.add(gasLeft.sub(newGasLeft));
    		}
 
    		gasLeft = newGasLeft;
    	}
 
    	lastProcessedIndex = _lastProcessedIndex;
 
    	return (iterations, claims, lastProcessedIndex);
    }
 
    function processAccount(address payable account, bool automatic) public onlyOwner returns (bool) {
        uint256 amount = _withdrawDividendOfUser(account);
 
    	if(amount > 0) {
    		lastClaimTimes[account] = block.timestamp;
            emit Claim(account, amount, automatic);
    		return true;
    	}
 
    	return false;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"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":"newLiquidityWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldLiquidityWallet","type":"address"}],"name":"LiquidityWalletUpdated","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":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":"DOGERewardsFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"DOGEToken","outputs":[{"internalType":"address","name":"","type":"address"}],"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":"buyBackEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyBackFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyBackUpperLimit","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 XDOGEDividendTracker","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":"liquidityWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxSellTransactionAmount","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":"bool","name":"_enabled","type":"bool"}],"name":"setBuyBackEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newFee","type":"uint256"}],"name":"setBuybackFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"buyBackLimit","type":"uint256"}],"name":"setBuybackUpperLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newFee","type":"uint256"}],"name":"setDOGErewardsFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"setMaxSellTxAMount","outputs":[],"stateMutability":"nonpayable","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":"address","name":"newAddress","type":"address"}],"name":"updateDividendTracker","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newValue","type":"uint256"}],"name":"updateGasForProcessing","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newLiquidityWallet","type":"address"}],"name":"updateLiquidityWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newAddress","type":"address"}],"name":"updateUniswapV2Router","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_presaleAddress","type":"address"},{"internalType":"address","name":"_routerAddress","type":"address"}],"name":"whitelistDxSale","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"}]

60c06040527fba2ae424d960c26247dd6c32edc70b295c744c4300000000000000000000000060a05269d3c21bcecceda10000006009908155692a5a058fc295ed000000600a55600b8190556006600c8190556200006a9190620005fe602090811b620024d917901c565b600d55670de0b6b3a7640000600e55600f805460ff19166001179055620493e06010553480156200009a57600080fd5b50604080518082018252600780825266393958444f474560c81b602080840182815285518087019096529285528401528151919291620000dd91600391620009f8565b508051620000f3906004906020840190620009f8565b50506005805460ff191660121790555060006200010f62000660565b60058054610100600160a81b0319166101006001600160a01b03841690810291909117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350604051620001739062000a8d565b604051809103906000f08015801562000190573d6000803e3d6000fd5b50600780546001600160a01b0319166001600160a01b0392909216919091179055620001bb62000664565b600860006101000a8154816001600160a01b0302191690836001600160a01b0316021790555060007310ed43c718714eb63d5aa57b78b54704e256024e90506000816001600160a01b031663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b1580156200023657600080fd5b505afa1580156200024b573d6000803e3d6000fd5b505050506040513d60208110156200026257600080fd5b5051604080516315ab88c960e31b815290516001600160a01b039283169263c9c653969230929187169163ad5c464891600480820192602092909190829003018186803b158015620002b357600080fd5b505afa158015620002c8573d6000803e3d6000fd5b505050506040513d6020811015620002df57600080fd5b5051604080516001600160e01b031960e086901b1681526001600160a01b0393841660048201529290911660248301525160448083019260209291908290030181600087803b1580156200033257600080fd5b505af115801562000347573d6000803e3d6000fd5b505050506040513d60208110156200035e57600080fd5b5051600680546001600160a01b0319166001600160a01b038516179055606081901b6001600160601b03191660805290506200039c81600162000678565b6007546040805163031e79db60e41b81526001600160a01b0390921660048301819052905190916331e79db091602480830192600092919082900301818387803b158015620003ea57600080fd5b505af1158015620003ff573d6000803e3d6000fd5b50506007546040805163031e79db60e41b815230600482015290516001600160a01b0390921693506331e79db0925060248082019260009290919082900301818387803b1580156200045057600080fd5b505af115801562000465573d6000803e3d6000fd5b50506007546001600160a01b031691506331e79db090506200048662000664565b6040518263ffffffff1660e01b815260040180826001600160a01b03168152602001915050600060405180830381600087803b158015620004c657600080fd5b505af1158015620004db573d6000803e3d6000fd5b50506007546040805163031e79db60e41b815260006004820181905291516001600160a01b0390931694506331e79db093506024808201939182900301818387803b1580156200052a57600080fd5b505af11580156200053f573d6000803e3d6000fd5b50506007546040805163031e79db60e41b81526001600160a01b03878116600483015291519190921693506331e79db09250602480830192600092919082900301818387803b1580156200059257600080fd5b505af1158015620005a7573d6000803e3d6000fd5b5050600854620005c592506001600160a01b031690506001620007ab565b620005d2306001620007ab565b620005f6620005e062000664565b6ec097ce7bc90715b34b9f1000000000620008e4565b505062000ab2565b60008282018381101562000659576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b3390565b60055461010090046001600160a01b031690565b6001600160a01b03821660009081526012602052604090205460ff1615158115151415620006d85760405162461bcd60e51b815260040180806020018281038252604181526020018062006b766041913960600191505060405180910390fd5b6001600160a01b0382166000908152601260205260409020805460ff191682158015919091179091556200076f576007546040805163031e79db60e41b81526001600160a01b038581166004830152915191909216916331e79db091602480830192600092919082900301818387803b1580156200075557600080fd5b505af11580156200076a573d6000803e3d6000fd5b505050505b604051811515906001600160a01b038416907fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab90600090a35050565b620007b562000660565b6001600160a01b0316620007c862000664565b6001600160a01b03161462000824576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6001600160a01b03821660009081526011602052604090205460ff1615158115151415620008845760405162461bcd60e51b815260040180806020018281038252603381526020018062006bb76033913960400191505060405180910390fd5b6001600160a01b038216600081815260116020908152604091829020805460ff1916851515908117909155825190815291517f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df79281900390910190a25050565b6001600160a01b03821662000940576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b6200094e60008383620009f3565b6200096a81600254620005fe60201b620024d91790919060201c565b6002556001600160a01b038216600090815260208181526040909120546200099d918390620024d9620005fe821b17901c565b6001600160a01b0383166000818152602081815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b505050565b828054600181600116156101000203166002900490600052602060002090601f01602090048101928262000a30576000855562000a7b565b82601f1062000a4b57805160ff191683800117855562000a7b565b8280016001018555821562000a7b579182015b8281111562000a7b57825182559160200191906001019062000a5e565b5062000a8992915062000a9b565b5090565b6125c980620045ad83390190565b5b8082111562000a89576000815560010162000a9c565b60805160601c60a05160601c613ab362000afa600039806114a75280612f41528061300a52806135c2525080610fa15280611c29528061276352806127a45250613ab36000f3fe6080604052600436106103395760003560e01c8063715018a6116101ab578063a9059cbb116100f7578063e2f4560511610095578063e98030c71161006f578063e98030c714610bdc578063e9c5efbf14610c06578063f27fd25414610c1b578063f2fde38b14610c4557610340565b8063e2f4560514610b7f578063e37ba8f914610b94578063e7841ec014610bc757610340565b8063c0246668116100d1578063c024666814610a75578063c492f04614610ab0578063d469801614610b2f578063dd62ed3e14610b4457610340565b8063a9059cbb1461098b578063ad56c13c146109c4578063b62496f514610a4257610340565b806395d89b41116101645780639c1b8af51161013e5780639c1b8af5146108f5578063a26579ad1461090a578063a457c2d71461091f578063a8b9d2401461095857610340565b806395d89b411461087b57806395e01b1f146108905780639a7a23d6146108ba57610340565b8063715018a6146107a057806382d2a4bb146107b5578063871c128d146107df57806387f7f5ad1461080957806388bdd9be146108335780638da5cb5b1461086657610340565b806349bd5a5e1161028557806365b8dbc011610223578063700bb191116101fd578063700bb1911461071957806370a082311461074357806370e5024114610776578063710ee68e1461078b57610340565b806365b8dbc01461069e5780636843cd84146106d15780636ddd17131461070457610340565b80634e83ff6f1161025f5780634e83ff6f146106065780634fbee193146106415780636053a0e31461067457806364b0f6531461068957610340565b806349bd5a5e146105c75780634be8f8b1146105dc5780634e71d92d146105f157610340565b806323b872dd116102f257806330bb4cff116102cc57806330bb4cff14610524578063313ce5671461053957806339509351146105645780634567bfba1461059d57610340565b806323b872dd1461049e57806329370cc6146104e15780632c1f52161461050f57610340565b806302259e9e1461034557806306fdde031461036c578063095ea7b3146103f657806313114a9d146104435780631694505e1461045857806318160ddd1461048957610340565b3661034057005b600080fd5b34801561035157600080fd5b5061035a610c78565b60408051918252519081900360200190f35b34801561037857600080fd5b50610381610c7e565b6040805160208082528351818301528351919283929083019185019080838360005b838110156103bb5781810151838201526020016103a3565b50505050905090810190601f1680156103e85780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34801561040257600080fd5b5061042f6004803603604081101561041957600080fd5b506001600160a01b038135169060200135610d14565b604080519115158252519081900360200190f35b34801561044f57600080fd5b5061035a610d32565b34801561046457600080fd5b5061046d610d38565b604080516001600160a01b039092168252519081900360200190f35b34801561049557600080fd5b5061035a610d47565b3480156104aa57600080fd5b5061042f600480360360608110156104c157600080fd5b506001600160a01b03813581169160208101359091169060400135610d4d565b3480156104ed57600080fd5b5061050d6004803603602081101561050457600080fd5b50351515610dd4565b005b34801561051b57600080fd5b5061046d610e49565b34801561053057600080fd5b5061035a610e58565b34801561054557600080fd5b5061054e610ece565b6040805160ff9092168252519081900360200190f35b34801561057057600080fd5b5061042f6004803603604081101561058757600080fd5b506001600160a01b038135169060200135610ed7565b3480156105a957600080fd5b5061050d600480360360208110156105c057600080fd5b5035610f25565b3480156105d357600080fd5b5061046d610f9f565b3480156105e857600080fd5b5061035a610fc3565b3480156105fd57600080fd5b5061050d610fc9565b34801561061257600080fd5b5061050d6004803603604081101561062957600080fd5b506001600160a01b038135811691602001351661104e565b34801561064d57600080fd5b5061042f6004803603602081101561066457600080fd5b50356001600160a01b0316611192565b34801561068057600080fd5b5061042f6111b0565b34801561069557600080fd5b5061035a6111b9565b3480156106aa57600080fd5b5061050d600480360360208110156106c157600080fd5b50356001600160a01b03166111fe565b3480156106dd57600080fd5b5061035a600480360360208110156106f457600080fd5b50356001600160a01b031661130a565b34801561071057600080fd5b5061042f61138d565b34801561072557600080fd5b5061050d6004803603602081101561073c57600080fd5b503561139d565b34801561074f57600080fd5b5061035a6004803603602081101561076657600080fd5b50356001600160a01b0316611484565b34801561078257600080fd5b5061035a61149f565b34801561079757600080fd5b5061046d6114a5565b3480156107ac57600080fd5b5061050d6114c9565b3480156107c157600080fd5b5061050d600480360360208110156107d857600080fd5b503561157b565b3480156107eb57600080fd5b5061050d6004803603602081101561080257600080fd5b50356115ec565b34801561081557600080fd5b5061050d6004803603602081101561082c57600080fd5b5035611713565b34801561083f57600080fd5b5061050d6004803603602081101561085657600080fd5b50356001600160a01b031661177a565b34801561087257600080fd5b5061046d611adb565b34801561088757600080fd5b50610381611aef565b34801561089c57600080fd5b5061050d600480360360208110156108b357600080fd5b5035611b50565b3480156108c657600080fd5b5061050d600480360360408110156108dd57600080fd5b506001600160a01b0381351690602001351515611bc5565b34801561090157600080fd5b5061035a611ca2565b34801561091657600080fd5b5061035a611ca8565b34801561092b57600080fd5b5061042f6004803603604081101561094257600080fd5b506001600160a01b038135169060200135611ced565b34801561096457600080fd5b5061035a6004803603602081101561097b57600080fd5b50356001600160a01b0316611d55565b34801561099757600080fd5b5061042f600480360360408110156109ae57600080fd5b506001600160a01b038135169060200135611da6565b3480156109d057600080fd5b506109f7600480360360208110156109e757600080fd5b50356001600160a01b0316611dba565b604080516001600160a01b0390991689526020890197909752878701959095526060870193909352608086019190915260a085015260c084015260e083015251908190036101000190f35b348015610a4e57600080fd5b5061042f60048036036020811015610a6557600080fd5b50356001600160a01b0316611e9a565b348015610a8157600080fd5b5061050d60048036036040811015610a9857600080fd5b506001600160a01b0381351690602001351515611eaf565b348015610abc57600080fd5b5061050d60048036036040811015610ad357600080fd5b810190602081018135640100000000811115610aee57600080fd5b820183602082011115610b0057600080fd5b80359060200191846020830284011164010000000083111715610b2257600080fd5b9193509150351515611fcf565b348015610b3b57600080fd5b5061046d6120f9565b348015610b5057600080fd5b5061035a60048036036040811015610b6757600080fd5b506001600160a01b0381358116916020013516612108565b348015610b8b57600080fd5b5061035a612133565b348015610ba057600080fd5b5061050d60048036036020811015610bb757600080fd5b50356001600160a01b0316612139565b348015610bd357600080fd5b5061035a612250565b348015610be857600080fd5b5061050d60048036036020811015610bff57600080fd5b5035612295565b348015610c1257600080fd5b5061035a61235f565b348015610c2757600080fd5b506109f760048036036020811015610c3e57600080fd5b5035612365565b348015610c5157600080fd5b5061050d60048036036020811015610c6857600080fd5b50356001600160a01b03166123cb565b60095481565b60038054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610d0a5780601f10610cdf57610100808354040283529160200191610d0a565b820191906000526020600020905b815481529060010190602001808311610ced57829003601f168201915b5050505050905090565b6000610d28610d2161253a565b848461253e565b5060015b92915050565b600d5481565b6006546001600160a01b031681565b60025490565b6000610d5a84848461262a565b610dca84610d6661253a565b610dc5856040518060600160405280602881526020016138ac602891396001600160a01b038a16600090815260016020526040812090610da461253a565b6001600160a01b031681526020810191909152604001600020549190612af2565b61253e565b5060019392505050565b610ddc61253a565b6001600160a01b0316610ded611adb565b6001600160a01b031614610e36576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b600f805460ff1916911515919091179055565b6007546001600160a01b031681565b600754604080516342d359d760e11b815290516000926001600160a01b0316916385a6b3ae916004808301926020929190829003018186803b158015610e9d57600080fd5b505afa158015610eb1573d6000803e3d6000fd5b505050506040513d6020811015610ec757600080fd5b5051905090565b60055460ff1690565b6000610d28610ee461253a565b84610dc58560016000610ef561253a565b6001600160a01b03908116825260208083019390935260409182016000908120918c1681529252902054906124d9565b610f2d61253a565b6001600160a01b0316610f3e611adb565b6001600160a01b031614610f87576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b600c819055600b54610f9990826124d9565b600d5550565b7f000000000000000000000000000000000000000000000000000000000000000081565b600c5481565b6007546040805163bc4c4b3760e01b815233600482015260006024820181905291516001600160a01b039093169263bc4c4b3792604480840193602093929083900390910190829087803b15801561102057600080fd5b505af1158015611034573d6000803e3d6000fd5b505050506040513d602081101561104a57600080fd5b5050565b61105661253a565b6001600160a01b0316611067611adb565b6001600160a01b0316146110b0576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b6007546040805163031e79db60e41b81526001600160a01b038581166004830152915191909216916331e79db091602480830192600092919082900301818387803b1580156110fe57600080fd5b505af1158015611112573d6000803e3d6000fd5b50505050611121826001611eaf565b6007546040805163031e79db60e41b81526001600160a01b038481166004830152915191909216916331e79db091602480830192600092919082900301818387803b15801561116f57600080fd5b505af1158015611183573d6000803e3d6000fd5b5050505061104a816001611eaf565b6001600160a01b031660009081526011602052604090205460ff1690565b600f5460ff1681565b600754604080516304ddf6ef60e11b815290516000926001600160a01b0316916309bbedde916004808301926020929190829003018186803b158015610e9d57600080fd5b61120661253a565b6001600160a01b0316611217611adb565b6001600160a01b031614611260576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b6006546001600160a01b03828116911614156112ad5760405162461bcd60e51b815260040180806020018281038252602c815260200180613977602c913960400191505060405180910390fd5b6006546040516001600160a01b03918216918316907f8fc842bbd331dfa973645f4ed48b11683d501ebf1352708d77a5da2ab49a576e90600090a3600680546001600160a01b0319166001600160a01b0392909216919091179055565b600754604080516370a0823160e01b81526001600160a01b038481166004830152915160009392909216916370a0823191602480820192602092909190829003018186803b15801561135b57600080fd5b505afa15801561136f573d6000803e3d6000fd5b505050506040513d602081101561138557600080fd5b505192915050565b600654600160a81b900460ff1681565b600754604080516001624d3b8760e01b03198152600481018490529051600092839283926001600160a01b039092169163ffb2c4799160248082019260609290919082900301818787803b1580156113f457600080fd5b505af1158015611408573d6000803e3d6000fd5b505050506040513d606081101561141e57600080fd5b5080516020808301516040938401518451848152928301829052828501819052606083018990529351929650945091925032916000917fc864333d6121033635ab41b29ae52f10a22cf4438c3e4f1c4c68518feb2f8a989181900360800190a350505050565b6001600160a01b031660009081526020819052604090205490565b600e5481565b7f000000000000000000000000000000000000000000000000000000000000000081565b6114d161253a565b6001600160a01b03166114e2611adb565b6001600160a01b03161461152b576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b60055460405160009161010090046001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a360058054610100600160a81b0319169055565b61158361253a565b6001600160a01b0316611594611adb565b6001600160a01b0316146115dd576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b670de0b6b3a764000002600e55565b6115f461253a565b6001600160a01b0316611605611adb565b6001600160a01b03161461164e576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b62030d40811015801561166457506207a1208111155b61169f5760405162461bcd60e51b815260040180806020018281038252603d815260200180613819603d913960400191505060405180910390fd5b6010548114156116e05760405162461bcd60e51b81526004018080602001828103825260358152602001806138566035913960400191505060405180910390fd5b60105460405182907f40d7e40e79af4e8e5a9b3c57030d8ea93f13d669c06d448c4d631d4ae7d23db790600090a3601055565b61171b61253a565b6001600160a01b031661172c611adb565b6001600160a01b031614611775576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b600955565b61178261253a565b6001600160a01b0316611793611adb565b6001600160a01b0316146117dc576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b6007546001600160a01b03828116911614156118295760405162461bcd60e51b81526004018080602001828103825260368152602001806136e76036913960400191505060405180910390fd5b6000819050306001600160a01b0316816001600160a01b0316638da5cb5b6040518163ffffffff1660e01b815260040160206040518083038186803b15801561187157600080fd5b505afa158015611885573d6000803e3d6000fd5b505050506040513d602081101561189b57600080fd5b50516001600160a01b0316146118e25760405162461bcd60e51b815260040180806020018281038252604d8152602001806137a6604d913960600191505060405180910390fd5b806001600160a01b03166331e79db0826040518263ffffffff1660e01b815260040180826001600160a01b03168152602001915050600060405180830381600087803b15801561193157600080fd5b505af1158015611945573d6000803e3d6000fd5b50506040805163031e79db60e41b815230600482015290516001600160a01b03851693506331e79db09250602480830192600092919082900301818387803b15801561199057600080fd5b505af11580156119a4573d6000803e3d6000fd5b50505050806001600160a01b03166331e79db06119bf611adb565b6040518263ffffffff1660e01b815260040180826001600160a01b03168152602001915050600060405180830381600087803b1580156119fe57600080fd5b505af1158015611a12573d6000803e3d6000fd5b50506006546040805163031e79db60e41b81526001600160a01b039283166004820152905191851693506331e79db0925060248082019260009290919082900301818387803b158015611a6457600080fd5b505af1158015611a78573d6000803e3d6000fd5b50506007546040516001600160a01b03918216935090851691507f90c7d74461c613da5efa97d90740869367d74ab3aa5837aa4ae9a975f954b7a890600090a3600780546001600160a01b0319166001600160a01b039290921691909117905550565b60055461010090046001600160a01b031690565b60048054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610d0a5780601f10610cdf57610100808354040283529160200191610d0a565b611b5861253a565b6001600160a01b0316611b69611adb565b6001600160a01b031614611bb2576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b600b819055600c54610f999082906124d9565b611bcd61253a565b6001600160a01b0316611bde611adb565b6001600160a01b031614611c27576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b03161415611c985760405162461bcd60e51b815260040180806020018281038252604e815260200180613a0b604e913960600191505060405180910390fd5b61104a8282612b89565b60105481565b60075460408051631bc9e27b60e21b815290516000926001600160a01b031691636f2789ec916004808301926020929190829003018186803b158015610e9d57600080fd5b6000610d28611cfa61253a565b84610dc585604051806060016040528060258152602001613a596025913960016000611d2461253a565b6001600160a01b03908116825260208083019390935260409182016000908120918d16815292529020549190612af2565b600754604080516302a2e74960e61b81526001600160a01b0384811660048301529151600093929092169163a8b9d24091602480820192602092909190829003018186803b15801561135b57600080fd5b6000610d28611db361253a565b848461262a565b600080600080600080600080600760009054906101000a90046001600160a01b03166001600160a01b031663fbcbc0f18a6040518263ffffffff1660e01b815260040180826001600160a01b031681526020019150506101006040518083038186803b158015611e2957600080fd5b505afa158015611e3d573d6000803e3d6000fd5b505050506040513d610100811015611e5457600080fd5b508051602082015160408301516060840151608085015160a086015160c087015160e090970151959e50939c50919a509850965094509092509050919395975091939597565b60126020526000908152604090205460ff1681565b611eb761253a565b6001600160a01b0316611ec8611adb565b6001600160a01b031614611f11576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b6001600160a01b03821660009081526011602052604090205460ff1615158115151415611f6f5760405162461bcd60e51b81526004018080602001828103825260338152602001806139a36033913960400191505060405180910390fd5b6001600160a01b038216600081815260116020908152604091829020805460ff1916851515908117909155825190815291517f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df79281900390910190a25050565b611fd761253a565b6001600160a01b0316611fe8611adb565b6001600160a01b031614612031576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b60005b8281101561208657816011600086868581811061204d57fe5b602090810292909201356001600160a01b0316835250810191909152604001600020805460ff1916911515919091179055600101612034565b507f7fdaf542373fa84f4ee8d662c642f44e4c2276a217d7d29e548b6eb29a233b35838383604051808060200183151581526020018281038252858582818152602001925060200280828437600083820152604051601f909101601f1916909201829003965090945050505050a1505050565b6008546001600160a01b031681565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b600a5481565b61214161253a565b6001600160a01b0316612152611adb565b6001600160a01b03161461219b576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b6008546001600160a01b03828116911614156121e85760405162461bcd60e51b81526004018080602001828103825260358152602001806139d66035913960400191505060405180910390fd5b6121f3816001611eaf565b6008546040516001600160a01b03918216918316907f6080503d1da552ae8eb4b7b8a20245d9fabed014180510e7d1a05ea08fdb0f3e90600090a3600880546001600160a01b0319166001600160a01b0392909216919091179055565b6007546040805163039e107b60e61b815290516000926001600160a01b03169163e7841ec0916004808301926020929190829003018186803b158015610e9d57600080fd5b61229d61253a565b6001600160a01b03166122ae611adb565b6001600160a01b0316146122f7576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b6007546040805163e98030c760e01b81526004810184905290516001600160a01b039092169163e98030c79160248082019260009290919082900301818387803b15801561234457600080fd5b505af1158015612358573d6000803e3d6000fd5b5050505050565b600b5481565b600080600080600080600080600760009054906101000a90046001600160a01b03166001600160a01b0316635183d6fd8a6040518263ffffffff1660e01b8152600401808281526020019150506101006040518083038186803b158015611e2957600080fd5b6123d361253a565b6001600160a01b03166123e4611adb565b6001600160a01b03161461242d576040805162461bcd60e51b815260206004820181905260248201526000805160206138d4833981519152604482015290519081900360640190fd5b6001600160a01b0381166124725760405162461bcd60e51b815260040180806020018281038252602681526020018061375e6026913960400191505060405180910390fd5b6005546040516001600160a01b0380841692610100900416907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b600082820183811015612533576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b3390565b6001600160a01b0383166125835760405162461bcd60e51b81526004018080602001828103825260248152602001806139536024913960400191505060405180910390fd5b6001600160a01b0382166125c85760405162461bcd60e51b81526004018080602001828103825260228152602001806137846022913960400191505060405180910390fd5b6001600160a01b03808416600081815260016020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b03831661266f5760405162461bcd60e51b81526004018080602001828103825260258152602001806138f46025913960400191505060405180910390fd5b806126855761268083836000612cb7565b612aed565b600654600160a01b900460ff161580156126b757506001600160a01b03821660009081526012602052604090205460ff165b80156126dc57506001600160a01b03831660009081526011602052604090205460ff16155b15612722576009548111156127225760405162461bcd60e51b815260040180806020018281038252603a815260200180613919603a913960400191505060405180910390fd5b600061272d30611484565b600a5460065491925082101590600160a81b900460ff16801561275a5750600654600160a01b900460ff16155b801561279857507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b031614155b156128705760004790507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b0316141561281c57600f5460ff1680156127f55750670de0b6b3a764000081115b1561281c57600e548111156128095750600e545b61281c612817826064612e12565b612e79565b811561286e57600a549250600061284a600d54612844600c5487612eab90919063ffffffff16565b90612e12565b905061285581612f04565b600061286030611484565b905061286b81612f20565b50505b505b6006546001600160a01b03861660009081526011602052604090205460ff600160a01b9092048216159116806128be57506001600160a01b03851660009081526011602052604090205460ff165b156128c7575060005b80156129045760006128e96064612844600d5488612eab90919063ffffffff16565b90506128f5858261313b565b9450612902873083612cb7565b505b61290f868686612cb7565b6007546001600160a01b031663e30443bc8761292a81611484565b6040518363ffffffff1660e01b815260040180836001600160a01b0316815260200182815260200192505050600060405180830381600087803b15801561297057600080fd5b505af1925050508015612981575060015b506007546001600160a01b031663e30443bc8661299d81611484565b6040518363ffffffff1660e01b815260040180836001600160a01b0316815260200182815260200192505050600060405180830381600087803b1580156129e357600080fd5b505af19250505080156129f4575060015b50600654600160a01b900460ff16612ae957601054600754604080516001624d3b8760e01b031981526004810184905290516001600160a01b039092169163ffb2c479916024808201926060929091908290030181600087803b158015612a5a57600080fd5b505af1925050508015612a8e57506040513d6060811015612a7a57600080fd5b508051602082015160409092015190919060015b612a9757612ae7565b604080518481526020810184905280820183905260608101869052905132916001917fc864333d6121033635ab41b29ae52f10a22cf4438c3e4f1c4c68518feb2f8a989181900360800190a35050505b505b5050505b505050565b60008184841115612b815760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015612b46578181015183820152602001612b2e565b50505050905090810190601f168015612b735780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6001600160a01b03821660009081526012602052604090205460ff1615158115151415612be75760405162461bcd60e51b815260040180806020018281038252604181526020018061371d6041913960600191505060405180910390fd5b6001600160a01b0382166000908152601260205260409020805460ff19168215801591909117909155612c7b576007546040805163031e79db60e41b81526001600160a01b038581166004830152915191909216916331e79db091602480830192600092919082900301818387803b158015612c6257600080fd5b505af1158015612c76573d6000803e3d6000fd5b505050505b604051811515906001600160a01b038416907fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab90600090a35050565b6001600160a01b038316612cfc5760405162461bcd60e51b81526004018080602001828103825260258152602001806138f46025913960400191505060405180910390fd5b6001600160a01b038216612d415760405162461bcd60e51b81526004018080602001828103825260238152602001806136c46023913960400191505060405180910390fd5b612d4c838383612aed565b612d89816040518060600160405280602681526020016137f3602691396001600160a01b0386166000908152602081905260409020549190612af2565b6001600160a01b038085166000908152602081905260408082209390935590841681522054612db890826124d9565b6001600160a01b038084166000818152602081815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b6000808211612e68576040805162461bcd60e51b815260206004820152601a60248201527f536166654d6174683a206469766973696f6e206279207a65726f000000000000604482015290519081900360640190fd5b818381612e7157fe5b049392505050565b6006805460ff60a01b1916600160a01b1790558015612e9b57612e9b81613198565b506006805460ff60a01b19169055565b600082612eba57506000610d2c565b82820282848281612ec757fe5b04146125335760405162461bcd60e51b815260040180806020018281038252602181526020018061388b6021913960400191505060405180910390fd5b6006805460ff60a01b1916600160a01b179055612e9b81613339565b6006805460ff60a01b1916600160a01b179055612f3d81306134e0565b60007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b158015612fac57600080fd5b505afa158015612fc0573d6000803e3d6000fd5b505050506040513d6020811015612fd657600080fd5b50516007546040805163a9059cbb60e01b81526001600160a01b0392831660048201526024810184905290519293506000927f00000000000000000000000000000000000000000000000000000000000000009092169163a9059cbb9160448082019260209290919082900301818787803b15801561305457600080fd5b505af1158015613068573d6000803e3d6000fd5b505050506040513d602081101561307e57600080fd5b505190508015613129576007546040805163cf4837df60e01b81526004810185905290516001600160a01b039092169163cf4837df9160248082019260009290919082900301818387803b1580156130d557600080fd5b505af11580156130e9573d6000803e3d6000fd5b5050604080518681526020810186905281517f80195cc573b02cc48460cbca6e6e4cc85ddb91959d946e1c3025ea3d87942dc39450908190039091019150a15b50506006805460ff60a01b1916905550565b600082821115613192576040805162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015290519081900360640190fd5b50900390565b6040805160028082526060820183526000926020830190803683375050600654604080516315ab88c960e31b815290519394506001600160a01b039091169263ad5c464892506004808301926020929190829003018186803b1580156131fd57600080fd5b505afa158015613211573d6000803e3d6000fd5b505050506040513d602081101561322757600080fd5b50518151829060009061323657fe5b60200260200101906001600160a01b031690816001600160a01b031681525050308160018151811061326457fe5b6001600160a01b0392831660209182029290920101526006541663b6f9de9583600084816132944261012c6124d9565b6040518663ffffffff1660e01b81526004018085815260200180602001846001600160a01b03168152602001838152602001828103825285818151815260200191508051906020019060200280838360005b838110156132fe5781810151838201526020016132e6565b50505050905001955050505050506000604051808303818588803b15801561332557600080fd5b505af1158015612ae7573d6000803e3d6000fd5b604080516002808252606082018352600092602083019080368337019050509050308160008151811061336857fe5b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b1580156133bc57600080fd5b505afa1580156133d0573d6000803e3d6000fd5b505050506040513d60208110156133e657600080fd5b50518151829060019081106133f757fe5b6001600160a01b03928316602091820292909201015260065461341d913091168461253e565b60065460405163791ac94760e01b8152600481018481526000602483018190523060648401819052426084850181905260a060448601908152875160a487015287516001600160a01b039097169663791ac947968a968a9594939092909160c40190602080880191028083838b5b838110156134a357818101518382015260200161348b565b505050509050019650505050505050600060405180830381600087803b1580156134cc57600080fd5b505af1158015612ae9573d6000803e3d6000fd5b6040805160038082526080820190925260009160208201606080368337019050509050308160008151811061351157fe5b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b15801561356557600080fd5b505afa158015613579573d6000803e3d6000fd5b505050506040513d602081101561358f57600080fd5b50518151829060019081106135a057fe5b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000000000000000000000000000000000000000000000816002815181106135ee57fe5b6001600160a01b039283166020918202929092010152600654613614913091168561253e565b600654604051635c11d79560e01b8152600481018581526000602483018190526001600160a01b038681166064850152426084850181905260a060448601908152875160a487015287519290961695635c11d795958a9589948b9493919260c40190602080880191028083838b5b8381101561369a578181015183820152602001613682565b505050509050019650505050505050600060405180830381600087803b15801561332557600080fdfe45524332303a207472616e7366657220746f20746865207a65726f2061646472657373393958444f47453a20546865206469766964656e6420747261636b657220616c72656164792068617320746861742061646472657373393958444f47453a204175746f6d61746564206d61726b6574206d616b6572207061697220697320616c72656164792073657420746f20746861742076616c75654f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737345524332303a20617070726f766520746f20746865207a65726f2061646472657373393958444f47453a20546865206e6577206469766964656e6420747261636b6572206d757374206265206f776e65642062792074686520393958444f474520746f6b656e20636f6e747261637445524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e6365393958444f47453a20676173466f7250726f63657373696e67206d757374206265206265747765656e203230302c30303020616e64203530302c303030393958444f47453a2043616e6e6f742075706461746520676173466f7250726f63657373696e6720746f2073616d652076616c7565536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f7745524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e63654f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657245524332303a207472616e736665722066726f6d20746865207a65726f206164647265737353656c6c207472616e7366657220616d6f756e74206578636565647320746865206d617853656c6c5472616e73616374696f6e416d6f756e742e45524332303a20617070726f76652066726f6d20746865207a65726f2061646472657373393958444f47453a2054686520726f7574657220616c72656164792068617320746861742061646472657373393958444f47453a204163636f756e7420697320616c7265616479207468652076616c7565206f6620276578636c7564656427393958444f47453a20546865206c69717569646974792077616c6c657420697320616c726561647920746869732061646472657373393958444f47453a205468652050616e63616b655377617020706169722063616e6e6f742062652072656d6f7665642066726f6d206175746f6d617465644d61726b65744d616b6572506169727345524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa264697066735822122021c61ab6e7c9c423ef2190cfe79b437493ca3795f63711a790dd0995e1274a1164736f6c6343000706003360c06040527fba2ae424d960c26247dd6c32edc70b295c744c430000000000000000000000006080523480156200003557600080fd5b5060408051808201825260188082527f393958444f47455f4469766964656e645f547261636b6572000000000000000060208084018281528551808701909652928552840152815191929183918391620000929160039162000138565b508051620000a890600490602084019062000138565b50506005805460ff191660121790555060009150620000c8905062000134565b600b80546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350620151806013556c7e37be2022c0914b268000000060a052620001e4565b3390565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282620001705760008555620001bb565b82601f106200018b57805160ff1916838001178555620001bb565b82800160010185558215620001bb579182015b82811115620001bb5782518255916020019190600101906200019e565b50620001c9929150620001cd565b5090565b5b80821115620001c95760008155600101620001ce565b60805160601c60a0516123b462000215600039806111d95280611330525080610ee65280611d2b52506123b46000f3fe60806040526004361061021e5760003560e01c8063715018a611610123578063bc4c4b37116100ab578063e7841ec01161006f578063e7841ec01461081f578063e98030c714610834578063f2fde38b1461085e578063fbcbc0f114610891578063ffb2c479146108c457610225565b8063bc4c4b3714610731578063be10b6141461076c578063cf4837df14610781578063dd62ed3e146107ab578063e30443bc146107e657610225565b806395d89b41116100f257806395d89b4114610644578063a457c2d714610659578063a8b9d24014610692578063a9059cbb146106c5578063aafd847a146106fe57610225565b8063715018a6146105d257806385a6b3ae146105e75780638da5cb5b146105fc57806391b89fba1461061157610225565b8063313ce567116101a65780635183d6fd116101755780635183d6fd146104cf5780636a474002146105445780636f2789ec1461055957806370a082311461056e578063710ee68e146105a157610225565b8063313ce5671461040557806331e79db01461043057806339509351146104635780634e7b827f1461049c57610225565b806318160ddd116101ed57806318160ddd14610332578063226cfa3d1461034757806323b872dd1461037a57806327ce0147146103bd5780633009a609146103f057610225565b806303c833021461022a57806306fdde0314610234578063095ea7b3146102be57806309bbedde1461030b57610225565b3661022557005b600080fd5b61023261090c565b005b34801561024057600080fd5b5061024961099d565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561028357818101518382015260200161026b565b50505050905090810190601f1680156102b05780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b3480156102ca57600080fd5b506102f7600480360360408110156102e157600080fd5b506001600160a01b038135169060200135610a33565b604080519115158252519081900360200190f35b34801561031757600080fd5b50610320610a51565b60408051918252519081900360200190f35b34801561033e57600080fd5b50610320610a57565b34801561035357600080fd5b506103206004803603602081101561036a57600080fd5b50356001600160a01b0316610a5d565b34801561038657600080fd5b506102f76004803603606081101561039d57600080fd5b506001600160a01b03813581169160208101359091169060400135610a6f565b3480156103c957600080fd5b50610320600480360360208110156103e057600080fd5b50356001600160a01b0316610af6565b3480156103fc57600080fd5b50610320610b55565b34801561041157600080fd5b5061041a610b5b565b6040805160ff9092168252519081900360200190f35b34801561043c57600080fd5b506102326004803603602081101561045357600080fd5b50356001600160a01b0316610b64565b34801561046f57600080fd5b506102f76004803603604081101561048657600080fd5b506001600160a01b038135169060200135610cca565b3480156104a857600080fd5b506102f7600480360360208110156104bf57600080fd5b50356001600160a01b0316610d18565b3480156104db57600080fd5b506104f9600480360360208110156104f257600080fd5b5035610d2d565b604080516001600160a01b0390991689526020890197909752878701959095526060870193909352608086019190915260a085015260c084015260e083015251908190036101000190f35b34801561055057600080fd5b50610232610e8c565b34801561056557600080fd5b50610320610ec3565b34801561057a57600080fd5b506103206004803603602081101561059157600080fd5b50356001600160a01b0316610ec9565b3480156105ad57600080fd5b506105b6610ee4565b604080516001600160a01b039092168252519081900360200190f35b3480156105de57600080fd5b50610232610f08565b3480156105f357600080fd5b50610320610fb4565b34801561060857600080fd5b506105b6610fba565b34801561061d57600080fd5b506103206004803603602081101561063457600080fd5b50356001600160a01b0316610fc9565b34801561065057600080fd5b50610249610fd4565b34801561066557600080fd5b506102f76004803603604081101561067c57600080fd5b506001600160a01b038135169060200135611035565b34801561069e57600080fd5b50610320600480360360208110156106b557600080fd5b50356001600160a01b031661109d565b3480156106d157600080fd5b506102f7600480360360408110156106e857600080fd5b506001600160a01b0381351690602001356110c9565b34801561070a57600080fd5b506103206004803603602081101561072157600080fd5b50356001600160a01b03166110dd565b34801561073d57600080fd5b506102f76004803603604081101561075457600080fd5b506001600160a01b03813516906020013515156110f8565b34801561077857600080fd5b506103206111d7565b34801561078d57600080fd5b50610232600480360360208110156107a457600080fd5b50356111fb565b3480156107b757600080fd5b50610320600480360360408110156107ce57600080fd5b506001600160a01b038135811691602001351661127b565b3480156107f257600080fd5b506102326004803603604081101561080957600080fd5b506001600160a01b0381351690602001356112a6565b34801561082b57600080fd5b5061032061147a565b34801561084057600080fd5b506102326004803603602081101561085757600080fd5b5035611480565b34801561086a57600080fd5b506102326004803603602081101561088157600080fd5b50356001600160a01b03166115a6565b34801561089d57600080fd5b506104f9600480360360208110156108b457600080fd5b50356001600160a01b03166116a9565b3480156108d057600080fd5b506108ee600480360360208110156108e757600080fd5b503561181c565b60408051938452602084019290925282820152519081900360600190f35b6000610916610a57565b1161092057600080fd5b341561099b57610951610931610a57565b61093f34600160801b61191a565b8161094657fe5b60065491900461197a565b60065560408051348152905133917fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d78454116511919081900360200190a2600a54610997903461197a565b600a555b565b60038054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610a295780601f106109fe57610100808354040283529160200191610a29565b820191906000526020600020905b815481529060010190602001808311610a0c57829003601f168201915b5050505050905090565b6000610a47610a406119d4565b84846119d8565b5060015b92915050565b600c5490565b60025490565b60126020526000908152604090205481565b6000610a7c848484611ac4565b610aec84610a886119d4565b610ae785604051806060016040528060288152602001612215602891396001600160a01b038a16600090815260016020526040812090610ac66119d4565b6001600160a01b031681526020810191909152604001600020549190611afb565b6119d8565b5060019392505050565b6001600160a01b038116600090815260086020526040812054600160801b90610b4590610b4090610b3a610b35610b2c88610ec9565b6006549061191a565b611b92565b90611ba2565b611bd5565b81610b4c57fe5b0490505b919050565b60105481565b60055460ff1690565b610b6c6119d4565b6001600160a01b0316610b7d610fba565b6001600160a01b031614610bc6576040805162461bcd60e51b8152602060048201819052602482015260008051602061223d833981519152604482015290519081900360640190fd5b6001600160a01b03811660009081526011602052604090205460ff1615610bec57600080fd5b6001600160a01b0381166000908152601160205260408120805460ff19166001179055610c1a908290611be8565b6040805163131836e760e21b8152600c60048201526001600160a01b0383166024820152905173725a92728406d7e38e973fd2f8b79423bf5108d391634c60db9c916044808301926000929190829003018186803b158015610c7b57600080fd5b505af4158015610c8f573d6000803e3d6000fd5b50506040516001600160a01b03841692507fa878b31040b2e6d0a9a3d3361209db3908ba62014b0dca52adbaee451d128b259150600090a250565b6000610a47610cd76119d4565b84610ae78560016000610ce86119d4565b6001600160a01b03908116825260208083019390935260409182016000908120918c16815292529020549061197a565b60116020526000908152604090205460ff1681565b600080600080600080600080600c73725a92728406d7e38e973fd2f8b79423bf5108d363deb3d89690916040518263ffffffff1660e01b81526004018082815260200191505060206040518083038186803b158015610d8b57600080fd5b505af4158015610d9f573d6000803e3d6000fd5b505050506040513d6020811015610db557600080fd5b50518910610ddc575060009650600019955085945086935083925082915081905080610e81565b6000600c73725a92728406d7e38e973fd2f8b79423bf5108d363d1aa9e7e90918c6040518363ffffffff1660e01b8152600401808381526020018281526020019250505060206040518083038186803b158015610e3857600080fd5b505af4158015610e4c573d6000803e3d6000fd5b505050506040513d6020811015610e6257600080fd5b50519050610e6f816116a9565b98509850985098509850985098509850505b919395975091939597565b60405162461bcd60e51b815260040180806020018281038252606b8152602001806122ef606b913960800191505060405180910390fd5b60135481565b6001600160a01b031660009081526020819052604090205490565b7f000000000000000000000000000000000000000000000000000000000000000081565b610f106119d4565b6001600160a01b0316610f21610fba565b6001600160a01b031614610f6a576040805162461bcd60e51b8152602060048201819052602482015260008051602061223d833981519152604482015290519081900360640190fd5b600b546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600b80546001600160a01b0319169055565b600a5481565b600b546001600160a01b031690565b6000610a4b8261109d565b60048054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610a295780601f106109fe57610100808354040283529160200191610a29565b6000610a476110426119d4565b84610ae78560405180606001604052806025815260200161235a602591396001600061106c6119d4565b6001600160a01b03908116825260208083019390935260409182016000908120918d16815292529020549190611afb565b6001600160a01b038116600090815260096020526040812054610a4b906110c384610af6565b90611c41565b6000610a476110d66119d4565b8484611ac4565b6001600160a01b031660009081526009602052604090205490565b60006111026119d4565b6001600160a01b0316611113610fba565b6001600160a01b03161461115c576040805162461bcd60e51b8152602060048201819052602482015260008051602061223d833981519152604482015290519081900360640190fd5b600061116784611c9e565b905080156111cd576001600160a01b0384166000818152601260209081526040918290204290558151848152915186151593927fa2c38e2d2fb7e3e1912d937fd1ca11ed6d51864dee4cfa7a7bf02becd7acf09292908290030190a36001915050610a4b565b5060009392505050565b7f000000000000000000000000000000000000000000000000000000000000000081565b6000611205610a57565b1161120f57600080fd5b80156112785761122e611220610a57565b61093f83600160801b61191a565b60065560408051828152905133917fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d78454116511919081900360200190a2600a54611274908261197a565b600a555b50565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6112ae6119d4565b6001600160a01b03166112bf610fba565b6001600160a01b031614611308576040805162461bcd60e51b8152602060048201819052602482015260008051602061223d833981519152604482015290519081900360640190fd5b6001600160a01b03821660009081526011602052604090205460ff161561132e57611476565b7f000000000000000000000000000000000000000000000000000000000000000081106113e45761135f8282611be8565b60408051632f0ad01760e21b8152600c60048201526001600160a01b038416602482015260448101839052905173725a92728406d7e38e973fd2f8b79423bf5108d39163bc2b405c916064808301926000929190829003018186803b1580156113c757600080fd5b505af41580156113db573d6000803e3d6000fd5b50505050611469565b6113ef826000611be8565b6040805163131836e760e21b8152600c60048201526001600160a01b0384166024820152905173725a92728406d7e38e973fd2f8b79423bf5108d391634c60db9c916044808301926000929190829003018186803b15801561145057600080fd5b505af4158015611464573d6000803e3d6000fd5b505050505b6114748260016110f8565b505b5050565b60105490565b6114886119d4565b6001600160a01b0316611499610fba565b6001600160a01b0316146114e2576040805162461bcd60e51b8152602060048201819052602482015260008051602061223d833981519152604482015290519081900360640190fd5b610e1081101580156114f75750620151808111155b6115325760405162461bcd60e51b815260040180806020018281038252604d8152602001806122a2604d913960600191505060405180910390fd5b6013548114156115735760405162461bcd60e51b815260040180806020018281038252603f81526020018061211d603f913960400191505060405180910390fd5b60135460405182907f474ea64804364a1e29a4487ddb63c3342a2dd826ccd8acf48825e680a0e6f20f90600090a3601355565b6115ae6119d4565b6001600160a01b03166115bf610fba565b6001600160a01b031614611608576040805162461bcd60e51b8152602060048201819052602482015260008051602061223d833981519152604482015290519081900360640190fd5b6001600160a01b03811661164d5760405162461bcd60e51b815260040180806020018281038252602681526020018061217e6026913960400191505060405180910390fd5b600b546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600b80546001600160a01b0319166001600160a01b0392909216919091179055565b600080600080600080600080889750600c73725a92728406d7e38e973fd2f8b79423bf5108d36317e142d190918a6040518363ffffffff1660e01b815260040180838152602001826001600160a01b031681526020019250505060206040518083038186803b15801561171b57600080fd5b505af415801561172f573d6000803e3d6000fd5b505050506040513d602081101561174557600080fd5b505196506000199550600087126117a9576010548711156117755760105461176e908890611e2d565b95506117a9565b601054600c546000911061178a576000611799565b601054600c5461179991611c41565b90506117a58882611ba2565b9650505b6117b28861109d565b94506117bd88610af6565b6001600160a01b0389166000908152601260205260409020549094509250826117e75760006117f5565b6013546117f590849061197a565b915042821161180557600061180f565b61180f8242611c41565b9050919395975091939597565b600c54600090819081908061183c57505060105460009250829150611913565b6010546000805a90506000805b898410801561185757508582105b1561190257600c54600190950194851061187057600094505b6000600c600001868154811061188257fe5b60009182526020808320909101546001600160a01b031680835260129091526040909120549091506118b390611e61565b156118cf576118c38160016110f8565b156118cf576001909101905b60019092019160005a9050808511156118f9576118f66118ef8683611c41565b879061197a565b95505b93506118499050565b601085905590975095509193505050505b9193909250565b60008261192957506000610a4b565b8282028284828161193657fe5b04146119735760405162461bcd60e51b81526004018080602001828103825260218152602001806121f46021913960400191505060405180910390fd5b9392505050565b600082820183811015611973576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b3390565b6001600160a01b038316611a1d5760405162461bcd60e51b815260040180806020018281038252602481526020018061227e6024913960400191505060405180910390fd5b6001600160a01b038216611a625760405162461bcd60e51b81526004018080602001828103825260228152602001806121a46022913960400191505060405180910390fd5b6001600160a01b03808416600081815260016020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b60405162461bcd60e51b815260040180806020018281038252602e8152602001806121c6602e913960400191505060405180910390fd5b60008184841115611b8a5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611b4f578181015183820152602001611b37565b50505050905090810190601f168015611b7c5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b60008181811215610a4b57600080fd5b6000828201818312801590611bb75750838112155b80611bcc5750600083128015611bcc57508381125b61197357600080fd5b600080821215611be457600080fd5b5090565b6000611bf383610ec9565b905080821115611c1b576000611c098383611c41565b9050611c158482611e88565b50611474565b80821015611474576000611c2f8284611c41565b9050611c3b8482611eec565b50505050565b600082821115611c98576040805162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015290519081900360640190fd5b50900390565b600080611caa8361109d565b90508015611e24576001600160a01b038316600090815260096020526040902054611cd5908261197a565b6001600160a01b038416600081815260096020908152604091829020939093558051848152905191927fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d92918290030190a260007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663a9059cbb85846040518363ffffffff1660e01b815260040180836001600160a01b0316815260200182815260200192505050602060405180830381600087803b158015611da057600080fd5b505af1158015611db4573d6000803e3d6000fd5b505050506040513d6020811015611dca57600080fd5b5051905080611e1c576001600160a01b038416600090815260096020526040902054611df69083611c41565b6001600160a01b0385166000908152600960205260408120919091559250610b50915050565b509050610b50565b50600092915050565b6000808212158015611e4157508282840313155b80611e585750600082128015611e58575082828403135b611c9857600080fd5b600042821115611e7357506000610b50565b601354611e804284611c41565b101592915050565b611e928282611f30565b611ecc611ead610b358360065461191a90919063ffffffff16565b6001600160a01b03841660009081526008602052604090205490611e2d565b6001600160a01b0390921660009081526008602052604090209190915550565b611ef68282612020565b611ecc611f11610b358360065461191a90919063ffffffff16565b6001600160a01b03841660009081526008602052604090205490611ba2565b6001600160a01b038216611f8b576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b611f9760008383611474565b600254611fa4908261197a565b6002556001600160a01b038216600090815260208190526040902054611fca908261197a565b6001600160a01b0383166000818152602081815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b6001600160a01b0382166120655760405162461bcd60e51b815260040180806020018281038252602181526020018061225d6021913960400191505060405180910390fd5b61207182600083611474565b6120ae8160405180606001604052806022815260200161215c602291396001600160a01b0385166000908152602081905260409020549190611afb565b6001600160a01b0383166000908152602081905260409020556002546120d49082611c41565b6002556040805182815290516000916001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a3505056fe393958444f47455f4469766964656e645f547261636b65723a2043616e6e6f742075706461746520636c61696d5761697420746f2073616d652076616c756545524332303a206275726e20616d6f756e7420657863656564732062616c616e63654f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737345524332303a20617070726f766520746f20746865207a65726f2061646472657373393958444f47455f4469766964656e645f547261636b65723a204e6f207472616e736665727320616c6c6f776564536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f7745524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e63654f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657245524332303a206275726e2066726f6d20746865207a65726f206164647265737345524332303a20617070726f76652066726f6d20746865207a65726f2061646472657373393958444f47455f4469766964656e645f547261636b65723a20636c61696d57616974206d757374206265207570646174656420746f206265747765656e203120616e6420323420686f757273393958444f47455f4469766964656e645f547261636b65723a2077697468647261774469766964656e642064697361626c65642e20557365207468652027636c61696d272066756e6374696f6e206f6e20746865206d61696e20393958444f474520636f6e74726163742e45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212209fa4f837eb82e0a471cb0271506dc67b875e113be98b83b76c287bdb0ace1e6764736f6c63430007060033393958444f47453a204175746f6d61746564206d61726b6574206d616b6572207061697220697320616c72656164792073657420746f20746861742076616c7565393958444f47453a204163636f756e7420697320616c7265616479207468652076616c7565206f6620276578636c7564656427

Library Used

IterableMapping : 0x725a92728406d7e38e973fd2f8b79423bf5108d3Unverified

Deployed ByteCode Sourcemap

48606:15298:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49030:60;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;23133:91;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25286:169;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;25286:169:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;49238:58;;;;;;;;;;;;;:::i;48682:41::-;;;;;;;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;48682:41:0;;;;;;;;;;;;;;24235:108;;;;;;;;;;;;;:::i;25938:321::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;25938:321:0;;;;;;;;;;;;;;;;;:::i;61933:103::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;61933:103:0;;;;:::i;:::-;;48937:43;;;;;;;;;;;;;:::i;56493:141::-;;;;;;;;;;;;;:::i;24078:91::-;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;26669:218;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;26669:218:0;;;;;;;;:::i;61776:148::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;61776:148:0;;:::i;48730:38::-;;;;;;;;;;;;;:::i;49201:30::-;;;;;;;;;;;;;:::i;57992:88::-;;;;;;;;;;;;;:::i;52318:325::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;52318:325:0;;;;;;;;;;:::i;56643:125::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;56643:125:0;-1:-1:-1;;;;;56643:125:0;;:::i;49358:33::-;;;;;;;;;;;;;:::i;58224:141::-;;;;;;;;;;;;;:::i;53507:316::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;53507:316:0;-1:-1:-1;;;;;53507:316:0;;:::i;56930:130::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;56930:130:0;-1:-1:-1;;;;;56930:130:0;;:::i;48904:23::-;;;;;;;;;;;;;:::i;57724:259::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57724:259:0;;:::i;24407:127::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;24407:127:0;-1:-1:-1;;;;;24407:127:0;;:::i;49306:45::-;;;;;;;;;;;;;:::i;48778:88::-;;;;;;;;;;;;;:::i;15479:148::-;;;;;;;;;;;;;:::i;62045:133::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;62045:133:0;;:::i;55824:410::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;55824:410:0;;:::i;55533:114::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;55533:114:0;;:::i;52652:846::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;52652:846:0;-1:-1:-1;;;;;52652:846:0;;:::i;14826:87::-;;;;;;;;;;;;;:::i;23344:95::-;;;;;;;;;;;;;:::i;55656:156::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;55656:156:0;;:::i;54455:266::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;54455:266:0;;;;;;;;;;:::i;49468:40::-;;;;;;;;;;;;;:::i;56376:108::-;;;;;;;;;;;;;:::i;27391:269::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;27391:269:0;;;;;;;;:::i;56777:147::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;56777:147:0;-1:-1:-1;;;;;56777:147:0;;:::i;24748:175::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;24748:175:0;;;;;;;;:::i;57069:318::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57069:318:0;-1:-1:-1;;;;;57069:318:0;;:::i;:::-;;;;-1:-1:-1;;;;;57069:318:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49786:58;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;49786:58:0;-1:-1:-1;;;;;49786:58:0;;:::i;53832:300::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;53832:300:0;;;;;;;;;;:::i;54141:305::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;54141:305:0;-1:-1:-1;54141:305:0;;;;:::i;48990:30::-;;;;;;;;;;;;;:::i;24987:151::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;24987:151:0;;;;;;;;;;:::i;49097:53::-;;;;;;;;;;;;;:::i;55152:372::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;55152:372:0;-1:-1:-1;;;;;55152:372:0;;:::i;58089:126::-;;;;;;;;;;;;;:::i;56243:124::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;56243:124:0;;:::i;49160:34::-;;;;;;;;;;;;;:::i;57393:325::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57393:325:0;;:::i;15783:244::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;15783:244:0;-1:-1:-1;;;;;15783:244:0;;:::i;49030:60::-;;;;:::o;23133:91::-;23211:5;23204:12;;;;;;;;-1:-1:-1;;23204:12:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23178:13;;23204:12;;23211:5;;23204:12;;23211:5;23204:12;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23133:91;:::o;25286:169::-;25369:4;25386:39;25395:12;:10;:12::i;:::-;25409:7;25418:6;25386:8;:39::i;:::-;-1:-1:-1;25443:4:0;25286:169;;;;;:::o;49238:58::-;;;;:::o;48682:41::-;;;-1:-1:-1;;;;;48682:41:0;;:::o;24235:108::-;24323:12;;24235:108;:::o;25938:321::-;26044:4;26061:36;26071:6;26079:9;26090:6;26061:9;:36::i;:::-;26108:121;26117:6;26125:12;:10;:12::i;:::-;26139:89;26177:6;26139:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;26139:19:0;;;;;;:11;:19;;;;;;26159:12;:10;:12::i;:::-;-1:-1:-1;;;;;26139:33:0;;;;;;;;;;;;-1:-1:-1;26139:33:0;;;:89;:37;:89::i;:::-;26108:8;:121::i;:::-;-1:-1:-1;26247:4:0;25938:321;;;;;:::o;61933:103::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;62003:14:::1;:25:::0;;-1:-1:-1;;62003:25:0::1;::::0;::::1;;::::0;;;::::1;::::0;;61933:103::o;48937:43::-;;;-1:-1:-1;;;;;48937:43:0;;:::o;56493:141::-;56583:15;;:43;;;-1:-1:-1;;;56583:43:0;;;;56556:7;;-1:-1:-1;;;;;56583:15:0;;:41;;:43;;;;;;;;;;;;;;:15;:43;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;56583:43:0;;-1:-1:-1;56493:141:0;:::o;24078:91::-;24152:9;;;;24078:91;:::o;26669:218::-;26757:4;26774:83;26783:12;:10;:12::i;:::-;26797:7;26806:50;26845:10;26806:11;:25;26818:12;:10;:12::i;:::-;-1:-1:-1;;;;;26806:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;26806:25:0;;;:34;;;;;;;;;;;:38;:50::i;61776:148::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;61844:10:::1;:19:::0;;;61886:14:::1;::::0;:30:::1;::::0;61857:6;61886:18:::1;:30::i;:::-;61874:9;:42:::0;-1:-1:-1;61776:148:0:o;48730:38::-;;;:::o;49201:30::-;;;;:::o;57992:88::-;58023:15;;:49;;;-1:-1:-1;;;58023:49:0;;58054:10;58023:49;;;;:15;:49;;;;;;;;-1:-1:-1;;;;;58023:15:0;;;;:30;;:49;;;;;;;;;;;;;;;;;;:15;:49;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;57992:88:0:o;52318:325::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;52420:15:::1;::::0;:53:::1;::::0;;-1:-1:-1;;;52420:53:0;;-1:-1:-1;;;;;52420:53:0;;::::1;;::::0;::::1;::::0;;;:15;;;::::1;::::0;:36:::1;::::0;:53;;;;;:15:::1;::::0;:53;;;;;;;:15;;:53;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;52484:38;52500:15;52517:4;52484:15;:38::i;:::-;52536:15;::::0;:52:::1;::::0;;-1:-1:-1;;;52536:52:0;;-1:-1:-1;;;;;52536:52:0;;::::1;;::::0;::::1;::::0;;;:15;;;::::1;::::0;:36:::1;::::0;:52;;;;;:15:::1;::::0;:52;;;;;;;:15;;:52;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;52599:37;52615:14;52631:4;52599:15;:37::i;56643:125::-:0;-1:-1:-1;;;;;56732:28:0;56708:4;56732:28;;;:19;:28;;;;;;;;;56643:125::o;49358:33::-;;;;;;:::o;58224:141::-;58316:15;;:41;;;-1:-1:-1;;;58316:41:0;;;;58289:7;;-1:-1:-1;;;;;58316:15:0;;:39;;:41;;;;;;;;;;;;;;:15;:41;;;;;;;;;;53507:316;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;53616:15:::1;::::0;-1:-1:-1;;;;;53594:38:0;;::::1;53616:15:::0;::::1;53594:38;;53586:95;;;;-1:-1:-1::0;;;53586:95:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53739:15;::::0;53697:59:::1;::::0;-1:-1:-1;;;;;53739:15:0;;::::1;::::0;53697:59;::::1;::::0;::::1;::::0;53739:15:::1;::::0;53697:59:::1;53767:15;:48:::0;;-1:-1:-1;;;;;;53767:48:0::1;-1:-1:-1::0;;;;;53767:48:0;;;::::1;::::0;;;::::1;::::0;;53507:316::o;56930:130::-;57021:15;;:34;;;-1:-1:-1;;;57021:34:0;;-1:-1:-1;;;;;57021:34:0;;;;;;;;;57000:7;;57021:15;;;;;:25;;:34;;;;;;;;;;;;;;;:15;:34;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57021:34:0;;56930:130;-1:-1:-1;;56930:130:0:o;48904:23::-;;;-1:-1:-1;;;48904:23:0;;;;;:::o;57724:259::-;57850:15;;:28;;;-1:-1:-1;;;;;;57850:28:0;;;;;;;;;;57784:18;;;;;;-1:-1:-1;;;;;57850:15:0;;;;:23;;:28;;;;;;;;;;;;;;;57784:18;57850:15;:28;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57850:28:0;;;;;;;;;;;;57888:87;;;;;;;;;;;;;;;;;57850:28;57888:87;;;;;;;57850:28;;-1:-1:-1;57850:28:0;-1:-1:-1;57850:28:0;;-1:-1:-1;57965:9:0;;57953:5;;57888:87;;;;;;;;;57724:259;;;;:::o;24407:127::-;-1:-1:-1;;;;;24508:18:0;24481:7;24508:18;;;;;;;;;;;;24407:127::o;49306:45::-;;;;:::o;48778:88::-;;;:::o;15479:148::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;15570:6:::1;::::0;15549:40:::1;::::0;15586:1:::1;::::0;15570:6:::1;::::0;::::1;-1:-1:-1::0;;;;;15570:6:0::1;::::0;15549:40:::1;::::0;15586:1;;15549:40:::1;15600:6;:19:::0;;-1:-1:-1;;;;;;15600:19:0::1;::::0;;15479:148::o;62045:133::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;62164:6:::1;62149:21;62129:17;:41:::0;62045:133::o;55824:410::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;55922:6:::1;55910:8;:18;;:40;;;;;55944:6;55932:8;:18;;55910:40;55902:114;;;;-1:-1:-1::0;;;55902:114:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56047:16;;56035:8;:28;;56027:94;;;;-1:-1:-1::0;;;56027:94:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56171:16;::::0;56137:51:::1;::::0;56161:8;;56137:51:::1;::::0;;;::::1;56199:16;:27:::0;55824:410::o;55533:114::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;55606:24:::1;:33:::0;55533:114::o;52652:846::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;52761:15:::1;::::0;-1:-1:-1;;;;;52739:38:0;;::::1;52761:15:::0;::::1;52739:38;;52731:105;;;;-1:-1:-1::0;;;52731:105:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;52850:39;52921:10;52850:83;;52993:4;-1:-1:-1::0;;;;;52955:43:0::1;:18;-1:-1:-1::0;;;;;52955:24:0::1;;:26;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;52955:26:0;-1:-1:-1;;;;;52955:43:0::1;;52947:133;;;;-1:-1:-1::0;;;52947:133:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53094:18;-1:-1:-1::0;;;;;53094:39:0::1;;53142:18;53094:68;;;;;;;;;;;;;-1:-1:-1::0;;;;;53094:68:0::1;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;53173:54:0::1;::::0;;-1:-1:-1;;;53173:54:0;;53221:4:::1;53173:54;::::0;::::1;::::0;;;-1:-1:-1;;;;;53173:39:0;::::1;::::0;-1:-1:-1;53173:39:0::1;::::0;-1:-1:-1;53173:54:0;;;;;-1:-1:-1;;53173:54:0;;;;;;;-1:-1:-1;53173:39:0;:54;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;53238:18;-1:-1:-1::0;;;;;53238:39:0::1;;53278:7;:5;:7::i;:::-;53238:48;;;;;;;;;;;;;-1:-1:-1::0;;;;;53238:48:0::1;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;53345:15:0::1;::::0;53297:65:::1;::::0;;-1:-1:-1;;;53297:65:0;;-1:-1:-1;;;;;53345:15:0;;::::1;53297:65;::::0;::::1;::::0;;;:39;;::::1;::::0;-1:-1:-1;53297:39:0::1;::::0;-1:-1:-1;53297:65:0;;;;;53345:15:::1;::::0;53297:65;;;;;;;;53345:15;53297:39;:65;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;53423:15:0::1;::::0;53381:59:::1;::::0;-1:-1:-1;;;;;53423:15:0;;::::1;::::0;-1:-1:-1;53381:59:0;;::::1;::::0;-1:-1:-1;53381:59:0::1;::::0;53423:15:::1;::::0;53381:59:::1;53454:15;:36:::0;;-1:-1:-1;;;;;;53454:36:0::1;-1:-1:-1::0;;;;;53454:36:0;;;::::1;::::0;;;::::1;::::0;;-1:-1:-1;52652:846:0:o;14826:87::-;14899:6;;;;;-1:-1:-1;;;;;14899:6:0;;14826:87::o;23344:95::-;23424:7;23417:14;;;;;;;;-1:-1:-1;;23417:14:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23391:13;;23417:14;;23424:7;;23417:14;;23424:7;23417:14;;;;;;;;;;;;;;;;;;;;;;;;55656:156;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;55728:14:::1;:23:::0;;;55793:10:::1;::::0;55774:30:::1;::::0;55745:6;;55774:18:::1;:30::i;54455:266::-:0;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;54562:13:::1;-1:-1:-1::0;;;;;54554:21:0::1;:4;-1:-1:-1::0;;;;;54554:21:0::1;;;54546:112;;;;-1:-1:-1::0;;;54546:112:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;54672:41;54701:4;54707:5;54672:28;:41::i;49468:40::-:0;;;;:::o;56376:108::-;56449:15;;:27;;;-1:-1:-1;;;56449:27:0;;;;56422:7;;-1:-1:-1;;;;;56449:15:0;;:25;;:27;;;;;;;;;;;;;;:15;:27;;;;;;;;;;27391:269;27484:4;27501:129;27510:12;:10;:12::i;:::-;27524:7;27533:96;27572:15;27533:96;;;;;;;;;;;;;;;;;:11;:25;27545:12;:10;:12::i;:::-;-1:-1:-1;;;;;27533:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;27533:25:0;;;:34;;;;;;;;;;;:96;:38;:96::i;56777:147::-;56870:15;;:47;;;-1:-1:-1;;;56870:47:0;;-1:-1:-1;;;;;56870:47:0;;;;;;;;;56846:7;;56870:15;;;;;:38;;:47;;;;;;;;;;;;;;;:15;:47;;;;;;;;;;24748:175;24834:4;24851:42;24861:12;:10;:12::i;:::-;24875:9;24886:6;24851:9;:42::i;57069:318::-;57165:7;57187:6;57208;57229:7;57251;57273;57295;57317;57344:15;;;;;;;;;-1:-1:-1;;;;;57344:15:0;-1:-1:-1;;;;;57344:26:0;;57371:7;57344:35;;;;;;;;;;;;;-1:-1:-1;;;;;57344:35:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57344:35:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;57344:35:0;;-1:-1:-1;57344:35:0;;-1:-1:-1;57344:35:0;-1:-1:-1;57344:35:0;-1:-1:-1;57344:35:0;-1:-1:-1;57344:35:0;;-1:-1:-1;57344:35:0;-1:-1:-1;57069:318:0;;;;;;;;;:::o;49786:58::-;;;;;;;;;;;;;;;:::o;53832:300::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;53925:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;::::1;;:40;;::::0;::::1;;;;53917:104;;;;-1:-1:-1::0;;;53917:104:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1::0;;;;;54032:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;54032:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;54090:34;;;;;;;::::1;::::0;;;;;;;;::::1;53832:300:::0;;:::o;54141:305::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;54258:9:::1;54254:115;54273:19:::0;;::::1;54254:115;;;54349:8;54314:19;:32;54334:8;;54343:1;54334:11;;;;;;;;::::0;;::::1;::::0;;;::::1;;-1:-1:-1::0;;;;;54334:11:0::1;54314:32:::0;;-1:-1:-1;54314:32:0;::::1;::::0;;;;;;-1:-1:-1;54314:32:0;:43;;-1:-1:-1;;54314:43:0::1;::::0;::::1;;::::0;;;::::1;::::0;;-1:-1:-1;54294:3:0::1;54254:115;;;;54387:51;54419:8;;54429;54387:51;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;;::::1;::::0;::::1;::::0;::::1;::::0;;::::1;-1:-1:-1::0;;54387:51:0::1;::::0;;::::1;::::0;;::::1;::::0;-1:-1:-1;54387:51:0;;-1:-1:-1;;;;;54387:51:0::1;54141:305:::0;;;:::o;48990:30::-;;;-1:-1:-1;;;;;48990:30:0;;:::o;24987:151::-;-1:-1:-1;;;;;25103:18:0;;;25076:7;25103:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;24987:151::o;49097:53::-;;;;:::o;55152:372::-;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;55269:15:::1;::::0;-1:-1:-1;;;;;55247:37:0;;::::1;55269:15:::0;::::1;55247:37;;55239:103;;;;-1:-1:-1::0;;;55239:103:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;55353:41;55369:18;55389:4;55353:15;:41::i;:::-;55453:15;::::0;55410:59:::1;::::0;-1:-1:-1;;;;;55453:15:0;;::::1;::::0;55410:59;::::1;::::0;::::1;::::0;55453:15:::1;::::0;55410:59:::1;55480:15;:36:::0;;-1:-1:-1;;;;;;55480:36:0::1;-1:-1:-1::0;;;;;55480:36:0;;;::::1;::::0;;;::::1;::::0;;55152:372::o;58089:126::-;58168:15;;:39;;;-1:-1:-1;;;58168:39:0;;;;58144:7;;-1:-1:-1;;;;;58168:15:0;;:37;;:39;;;;;;;;;;;;;;:15;:39;;;;;;;;;;56243:124;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;56317:15:::1;::::0;:42:::1;::::0;;-1:-1:-1;;;56317:42:0;;::::1;::::0;::::1;::::0;;;;;-1:-1:-1;;;;;56317:15:0;;::::1;::::0;:31:::1;::::0;:42;;;;;:15:::1;::::0;:42;;;;;;;;:15;;:42;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;56243:124:::0;:::o;49160:34::-;;;;:::o;57393:325::-;57494:7;57516:6;57537;57558:7;57580;57602;57624;57646;57670:15;;;;;;;;;-1:-1:-1;;;;;57670:15:0;-1:-1:-1;;;;;57670:33:0;;57704:5;57670:40;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15783:244;15058:12;:10;:12::i;:::-;-1:-1:-1;;;;;15047:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;15047:23:0;;15039:68;;;;;-1:-1:-1;;;15039:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;15039:68:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;15872:22:0;::::1;15864:73;;;;-1:-1:-1::0;;;15864:73:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15974:6;::::0;15953:38:::1;::::0;-1:-1:-1;;;;;15953:38:0;;::::1;::::0;15974:6:::1;::::0;::::1;;::::0;15953:38:::1;::::0;;;::::1;16002:6;:17:::0;;-1:-1:-1;;;;;16002:17:0;;::::1;;;-1:-1:-1::0;;;;;;16002:17:0;;::::1;::::0;;;::::1;::::0;;15783:244::o;34808:179::-;34866:7;34898:5;;;34922:6;;;;34914:46;;;;;-1:-1:-1;;;34914:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;34978:1;34808:179;-1:-1:-1;;;34808:179:0:o;3399:106::-;3487:10;3399:106;:::o;30548:347::-;-1:-1:-1;;;;;30650:19:0;;30642:68;;;;-1:-1:-1;;;30642:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;30729:21:0;;30721:68;;;;-1:-1:-1;;;30721:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;30803:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;30855:32;;;;;;;;;;;;;;;;;30548:347;;;:::o;58377:2599::-;-1:-1:-1;;;;;58509:18:0;;58501:68;;;;-1:-1:-1;;;58501:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;58586:11;58583:92;;58614:28;58630:4;58636:2;58640:1;58614:15;:28::i;:::-;58657:7;;58583:92;58701:8;;-1:-1:-1;;;58701:8:0;;;;58700:9;:55;;;;-1:-1:-1;;;;;;58726:29:0;;;;;;:25;:29;;;;;;;;58700:55;:165;;;;-1:-1:-1;;;;;;58840:25:0;;;;;;:19;:25;;;;;;;;58839:26;58700:165;58685:324;;;58910:24;;58900:6;:34;;58892:105;;;;-1:-1:-1;;;58892:105:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;59022:28;59053:24;59071:4;59053:9;:24::i;:::-;59143:18;;59175:11;;59022:55;;-1:-1:-1;59119:42:0;;;;-1:-1:-1;;;59175:11:0;;;;:24;;;;-1:-1:-1;59191:8:0;;-1:-1:-1;;;59191:8:0;;;;59190:9;59175:24;:49;;;;;59211:13;-1:-1:-1;;;;;59203:21:0;:4;-1:-1:-1;;;;;59203:21:0;;;59175:49;59172:820;;;59241:15;59259:21;59241:39;;59304:13;-1:-1:-1;;;;;59298:19:0;:2;-1:-1:-1;;;;;59298:19:0;;59295:298;;;59341:14;;;;:47;;;;;59377:10;59359:7;:29;59341:47;59337:241;;;59430:17;;59420:7;:27;59416:85;;;-1:-1:-1;59484:17:0;;59416:85;59527:31;59541:16;:7;59553:3;59541:11;:16::i;:::-;59527:13;:31::i;:::-;59613:23;59609:369;;;59679:18;;59656:41;;59719:21;59743:51;59784:9;;59743:36;59768:10;;59743:20;:24;;:36;;;;:::i;:::-;:40;;:51::i;:::-;59719:75;;59813:32;59831:13;59813:17;:32::i;:::-;59867:18;59888:24;59906:4;59888:9;:24::i;:::-;59867:45;;59931:32;59952:10;59931:20;:32::i;:::-;59609:369;;;59172:820;;60025:8;;-1:-1:-1;;;;;60135:25:0;;60008:12;60135:25;;;:19;:25;;;;;;60025:8;-1:-1:-1;;;60025:8:0;;;;;60024:9;;60135:25;;:52;;-1:-1:-1;;;;;;60164:23:0;;;;;;:19;:23;;;;;;;;60135:52;60132:99;;;-1:-1:-1;60214:5:0;60132:99;60247:7;60244:178;;;60268:12;60283:30;60309:3;60283:21;60294:9;;60283:6;:10;;:21;;;;:::i;:30::-;60268:45;-1:-1:-1;60334:16:0;:6;60268:45;60334:10;:16::i;:::-;60325:25;;60368:42;60384:4;60398;60405;60368:15;:42::i;:::-;60244:178;;60435:33;60451:4;60457:2;60461:6;60435:15;:33::i;:::-;60486:15;;-1:-1:-1;;;;;60486:15:0;:26;60521:4;60528:15;60521:4;60528:9;:15::i;:::-;60486:58;;;;;;;;;;;;;-1:-1:-1;;;;;60486:58:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;60482:74;60570:15;;-1:-1:-1;;;;;60570:15:0;:26;60605:2;60610:13;60605:2;60610:9;:13::i;:::-;60570:54;;;;;;;;;;;;;-1:-1:-1;;;;;60570:54:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;60566:70;60653:8;;-1:-1:-1;;;60653:8:0;;;;60649:320;;60686:16;;60718:15;;:28;;;-1:-1:-1;;;;;;60718:28:0;;;;;;;;;;-1:-1:-1;;;;;60718:15:0;;;;:23;;:28;;;;;;;;;;;;;;;60672:11;60718:15;:28;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;60718:28:0;;;;;;;;;;;;;;;;60714:244;;;;;60835:86;;;;;;;;;;;;;;;;;;;;;;;;;;60911:9;;60900:4;;60835:86;;;;;;;;;60747:184;;;60714:244;60649:320;;58377:2599;;;;;;;:::o;37640:166::-;37726:7;37762:12;37754:6;;;;37746:29;;;;-1:-1:-1;;;37746:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;37793:5:0;;;37640:166::o;54730:410::-;-1:-1:-1;;;;;54821:31:0;;;;;;:25;:31;;;;;;;;:40;;;;;;;54813:118;;;;-1:-1:-1;;;54813:118:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;54942:31:0;;;;;;:25;:31;;;;;:39;;-1:-1:-1;;54942:39:0;;;;;;;;;;;;54995:79;;55020:15;;:42;;;-1:-1:-1;;;55020:42:0;;-1:-1:-1;;;;;55020:42:0;;;;;;;;;:15;;;;;:36;;:42;;;;;:15;;:42;;;;;;;:15;;:42;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;54995:79;55092:40;;;;;;-1:-1:-1;;;;;55092:40:0;;;;;;;;54730:410;;:::o;28151:541::-;-1:-1:-1;;;;;28257:20:0;;28249:70;;;;-1:-1:-1;;;28249:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;28338:23:0;;28330:71;;;;-1:-1:-1;;;28330:71:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28415:47;28436:6;28444:9;28455:6;28415:20;:47::i;:::-;28496:71;28518:6;28496:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;28496:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;28476:17:0;;;:9;:17;;;;;;;;;;;:91;;;;28601:20;;;;;;;:32;;28626:6;28601:24;:32::i;:::-;-1:-1:-1;;;;;28578:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;28649:35;;;;;;;28578:20;;28649:35;;;;;;;;;;;;;28151:541;;;:::o;36388:153::-;36446:7;36478:1;36474;:5;36466:44;;;;;-1:-1:-1;;;36466:44:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;36532:1;36528;:5;;;;;;;36388:153;-1:-1:-1;;;36388:153:0:o;61519:134::-;50817:8;:15;;-1:-1:-1;;;;50817:15:0;-1:-1:-1;;;50817:15:0;;;61589:10;;61585:61:::1;;61613:24;61630:6;61613:16;:24::i;:::-;-1:-1:-1::0;50855:8:0;:16;;-1:-1:-1;;;;50855:16:0;;;61519:134::o;35689:220::-;35747:7;35771:6;35767:20;;-1:-1:-1;35786:1:0;35779:8;;35767:20;35810:5;;;35814:1;35810;:5;:1;35834:5;;;;;:10;35826:56;;;;-1:-1:-1;;;35826:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;61662:105;50817:8;:15;;-1:-1:-1;;;;50817:15:0;-1:-1:-1;;;50817:15:0;;;61735:24:::1;61752:6:::0;61735:16:::1;:24::i;63457:441::-:0;50817:8;:15;;-1:-1:-1;;;;50817:15:0;-1:-1:-1;;;50817:15:0;;;63533:40:::1;63551:6:::0;63567:4:::1;63533:17;:40::i;:::-;63584:17;63611:9;-1:-1:-1::0;;;;;63604:27:0::1;;63640:4;63604:42;;;;;;;;;;;;;-1:-1:-1::0;;;;;63604:42:0::1;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;63604:42:0;63707:15:::1;::::0;63672:63:::1;::::0;;-1:-1:-1;;;63672:63:0;;-1:-1:-1;;;;;63707:15:0;;::::1;63672:63;::::0;::::1;::::0;;;;;;;;;63604:42;;-1:-1:-1;;;63679:9:0::1;63672:26:::0;;::::1;::::0;::::1;::::0;:63;;;;;63604:42:::1;::::0;63672:63;;;;;;;;-1:-1:-1;63672:26:0;:63;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;63672:63:0;;-1:-1:-1;63749:142:0;::::1;;;63777:15;::::0;:50:::1;::::0;;-1:-1:-1;;;63777:50:0;;::::1;::::0;::::1;::::0;;;;;-1:-1:-1;;;;;63777:15:0;;::::1;::::0;:39:::1;::::0;:50;;;;;:15:::1;::::0;:50;;;;;;;;:15;;:50;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;63847:32:0::1;::::0;;;;;::::1;::::0;::::1;::::0;;;;;::::1;::::0;-1:-1:-1;63847:32:0;;;;;;;;-1:-1:-1;63847:32:0::1;63749:142;-1:-1:-1::0;;50855:8:0;:16;;-1:-1:-1;;;;50855:16:0;;;-1:-1:-1;63457:441:0:o;35271:158::-;35329:7;35362:1;35357;:6;;35349:49;;;;;-1:-1:-1;;;35349:49:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;35416:5:0;;;35271:158::o;60985:525::-;61130:16;;;61144:1;61130:16;;;;;;;;61106:21;;61130:16;;;;;;;;-1:-1:-1;;61167:15:0;;:22;;;-1:-1:-1;;;61167:22:0;;;;61106:40;;-1:-1:-1;;;;;;61167:15:0;;;;:20;;-1:-1:-1;61167:22:0;;;;;;;;;;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;61167:22:0;61157:7;;:4;;61162:1;;61157:7;;;;;;;;;:32;-1:-1:-1;;;;;61157:32:0;;;-1:-1:-1;;;;;61157:32:0;;;;;61218:4;61200;61205:1;61200:7;;;;;;;;-1:-1:-1;;;;;61200:23:0;;;:7;;;;;;;;;:23;61261:15;;;:66;61335:6;61261:15;61404:4;61261:15;61464:24;:15;61484:3;61464:19;:24::i;:::-;61261:238;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;61261:238:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;62187:600;62343:16;;;62357:1;62343:16;;;;;;;;62319:21;;62343:16;;;;;;;;;;-1:-1:-1;62343:16:0;62319:40;;62388:4;62370;62375:1;62370:7;;;;;;;;-1:-1:-1;;;;;62370:23:0;;;:7;;;;;;;;;;:23;;;;62414:15;;:22;;;-1:-1:-1;;;62414:22:0;;;;:15;;;;;:20;;:22;;;;;62370:7;;62414:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;62414:22:0;62404:7;;:4;;62409:1;;62404:7;;;;;;-1:-1:-1;;;;;62404:32:0;;;:7;;;;;;;;;:32;62482:15;;62450:62;;62467:4;;62482:15;62500:11;62450:8;:62::i;:::-;62552:15;;:224;;-1:-1:-1;;;62552:224:0;;;;;;;;:15;:224;;;;;;62730:4;62552:224;;;;;;62750:15;62552:224;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;62552:15:0;;;;:66;;62633:11;;62703:4;;62730;62750:15;62552:224;;;;;;;;;;;;;;;;:15;:224;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;62799:646;62971:16;;;62985:1;62971:16;;;;;;;;;62947:21;;62971:16;;;;;;;;;;-1:-1:-1;62971:16:0;62947:40;;63016:4;62998;63003:1;62998:7;;;;;;;;-1:-1:-1;;;;;62998:23:0;;;:7;;;;;;;;;;:23;;;;63042:15;;:22;;;-1:-1:-1;;;63042:22:0;;;;:15;;;;;:20;;:22;;;;;62998:7;;63042:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;63042:22:0;63032:7;;:4;;63037:1;;63032:7;;;;;;;;;;;:32;-1:-1:-1;;;;;63032:32:0;;;-1:-1:-1;;;;;63032:32:0;;;;;63085:9;63075:4;63080:1;63075:7;;;;;;;;-1:-1:-1;;;;;63075:19:0;;;:7;;;;;;;;;:19;63140:15;;63108:62;;63125:4;;63140:15;63158:11;63108:8;:62::i;:::-;63210:15;;:224;;-1:-1:-1;;;63210:224:0;;;;;;;;:15;:224;;;;;;-1:-1:-1;;;;;63210:224:0;;;;;;;63408:15;63210:224;;;;;;;;;;;;;;;;;;;;;:15;;;;;:69;;63294:11;;63365:4;;63384:9;;63408:15;63210:224;;;;;;;;;;;;;;:15;:224;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

Swarm Source

ipfs://9fa4f837eb82e0a471cb0271506dc67b875e113be98b83b76c287bdb0ace1e67
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.