Contract Address Details

0x3030BbB60574f7DFC989f3ab6cf4fDd1E8A519A9

Token
Sphynx Loop (SPHYNX)
Creator
0x895d90–eda745 at 0x035c17–e68597
Balance
0 LOOP ( )
Tokens
Fetching tokens...
Transactions
576 Transactions
Transfers
10,079 Transfers
Gas Used
17,840,904
Last Balance Update
19263607
Contract name:
SphynxToken




Optimization enabled
true
Compiler version
v0.6.12+commit.27d51765




Optimization runs
200
EVM Version
default




Verified at
2022-09-21T20:54:48.735735Z

Contract source code

// SPDX-License-Identifier: MIT

pragma solidity 0.6.12;

contract Context {
    // Empty internal constructor, to prevent people from mistakenly deploying
    // an instance of this contract, which should be used via inheritance.
    constructor() internal {}

    function _msgSender() internal view returns (address payable) {
        return msg.sender;
    }

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

contract Manageable is Context {
    address private _manager;

    event ManagementTransferred(address indexed previousManager, address indexed newManager);

    /**
     * @dev Initializes the contract setting the deployer as the initial manager.
     */
    constructor() internal {
        address msgSender = _msgSender();
        _manager = msgSender;
        emit ManagementTransferred(address(0), msgSender);
    }

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

    /**
     * @dev Throws if called by any account other than the manager.
     */
    modifier onlyManager() {
        require(_manager == _msgSender(), 'Manageable: caller is not the manager');
        _;
    }

    /**
     * @dev Leaves the contract without manager. It will not be possible to call
     * `onlyManager` functions anymore. Can only be called by the current manager.
     *
     * NOTE: Renouncing management will leave the contract without an manager,
     * thereby removing any functionality that is only available to the manager.
     */
    function renounceManagement() public onlyManager {
        emit ManagementTransferred(_manager, address(0));
        _manager = address(0);
    }

    /**
     * @dev Transfers management of the contract to a new account (`newManager`).
     * Can only be called by the current manager.
     */
    function transferManagement(address newManager) public onlyManager {
        _transferManagement(newManager);
    }

    /**
     * @dev Transfers management of the contract to a new account (`newManager`).
     */
    function _transferManagement(address newManager) internal {
        require(newManager != address(0), 'Manageable: new manager is the zero address');
        emit ManagementTransferred(_manager, newManager);
        _manager = newManager;
    }
}

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

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

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

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public 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 onlyOwner {
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     */
    function _transferOwnership(address newOwner) internal {
        require(newOwner != address(0), 'Ownable: new owner is the zero address');
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

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

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

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

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

    /**
     * @dev Returns the bep token owner.
     */
    function getOwner() external view returns (address);

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

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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

        return c;
    }

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

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

    function min(uint256 x, uint256 y) internal pure returns (uint256 z) {
        z = x < y ? x : y;
    }

    // babylonian method (https://en.wikipedia.org/wiki/Methods_of_computing_square_roots#Babylonian_method)
    function sqrt(uint256 y) internal pure returns (uint256 z) {
        if (y > 3) {
            z = y;
            uint256 x = y / 2 + 1;
            while (x < z) {
                z = x;
                x = (y / x + x) / 2;
            }
        } else if (y != 0) {
            z = 1;
        }
    }
}

library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // According to EIP-1052, 0x0 is the value returned for not-yet created accounts
        // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
        // for accounts without code, i.e. `keccak256('')`
        bytes32 codehash;
        bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
        // solhint-disable-next-line no-inline-assembly
        assembly {
            codehash := extcodehash(account)
        }
        return (codehash != accountHash && codehash != 0x0);
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, 'Address: insufficient balance');

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success, ) = recipient.call{value: amount}('');
        require(success, 'Address: unable to send value, recipient may have reverted');
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain`call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionCall(target, data, 'Address: low-level call failed');
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        return _functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, 'Address: low-level call with value failed');
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(address(this).balance >= value, 'Address: insufficient balance for call');
        return _functionCallWithValue(target, data, value, errorMessage);
    }

    function _functionCallWithValue(
        address target,
        bytes memory data,
        uint256 weiValue,
        string memory errorMessage
    ) private returns (bytes memory) {
        require(isContract(target), 'Address: call to non-contract');

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{value: weiValue}(data);
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}


contract BEP20 is Context, IBEP20, Ownable {
    using SafeMath for uint256;
    using Address for address;

    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) public {
        _name = name;
        _symbol = symbol;
        _decimals = 18;
    }

    /**
     * @dev Returns the bep token owner.
     */
    function getOwner() external override view returns (address) {
        return owner();
    }

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

    /**
     * @dev Returns the token decimals.
     */
    function decimals() public override view returns (uint8) {
        return _decimals;
    }

    /**
     * @dev Returns the token symbol.
     */
    function symbol() public override view returns (string memory) {
        return _symbol;
    }

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

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

    /**
     * @dev See {BEP20-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 override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

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

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

    /**
     * @dev See {BEP20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {BEP20};
     *
     * 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 override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(
            sender,
            _msgSender(),
            _allowances[sender][_msgSender()].sub(amount, 'BEP20: 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 {BEP20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue) public 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 {BEP20-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 returns (bool) {
        _approve(
            _msgSender(),
            spender,
            _allowances[_msgSender()][spender].sub(subtractedValue, 'BEP20: decreased allowance below zero')
        );
        return true;
    }

    /**
     * @dev Destroys `amount` tokens from `msg.sender`, decreasing the total supply.
     *
     */
    function burn(uint256 amount) public returns (bool) {
        _burn(_msgSender(), amount);
        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), 'BEP20: transfer from the zero address');
        require(recipient != address(0), 'BEP20: transfer to the zero address');

        _balances[sender] = _balances[sender].sub(amount, 'BEP20: 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 {
        require(account != address(0), 'BEP20: mint to the zero address');

        _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 {
        require(account != address(0), 'BEP20: burn from the zero address');

        _balances[account] = _balances[account].sub(amount, 'BEP20: 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 is 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 {
        require(owner != address(0), 'BEP20: approve from the zero address');
        require(spender != address(0), 'BEP20: approve to the zero address');

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

    /**
     * @dev Destroys `amount` tokens from `account`.`amount` is then deducted
     * from the caller's allowance.
     *
     * See {_burn} and {_approve}.
     */
    function _burnFrom(address account, uint256 amount) internal {
        _burn(account, amount);
        _approve(
            account,
            _msgSender(),
            _allowances[account][_msgSender()].sub(amount, 'BEP20: burn amount exceeds allowance')
        );
    }
}

library SafeBEP20 {
    using SafeMath for uint256;
    using Address for address;

    function safeTransfer(
        IBEP20 token,
        address to,
        uint256 value
    ) internal {
        _callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value));
    }

    function safeTransferFrom(
        IBEP20 token,
        address from,
        address to,
        uint256 value
    ) internal {
        _callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value));
    }

    /**
     * @dev Deprecated. This function has issues similar to the ones found in
     * {IBEP20-approve}, and its usage is discouraged.
     *
     * Whenever possible, use {safeIncreaseAllowance} and
     * {safeDecreaseAllowance} instead.
     */
    function safeApprove(
        IBEP20 token,
        address spender,
        uint256 value
    ) internal {
        // safeApprove should only be called when setting an initial allowance,
        // or when resetting it to zero. To increase and decrease it, use
        // 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
        // solhint-disable-next-line max-line-length
        require(
            (value == 0) || (token.allowance(address(this), spender) == 0),
            'SafeBEP20: approve from non-zero to non-zero allowance'
        );
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value));
    }

    function safeIncreaseAllowance(
        IBEP20 token,
        address spender,
        uint256 value
    ) internal {
        uint256 newAllowance = token.allowance(address(this), spender).add(value);
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance));
    }

    function safeDecreaseAllowance(
        IBEP20 token,
        address spender,
        uint256 value
    ) internal {
        uint256 newAllowance = token.allowance(address(this), spender).sub(
            value,
            'SafeBEP20: decreased allowance below zero'
        );
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance));
    }

    /**
     * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement
     * on the return value: the return value is optional (but if data is returned, it must not be false).
     * @param token The token targeted by the call.
     * @param data The call data (encoded using abi.encode or one of its variants).
     */
    function _callOptionalReturn(IBEP20 token, bytes memory data) private {
        // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since
        // we're implementing it ourselves. We use {Address.functionCall} to perform this call, which verifies that
        // the target address contains contract code and also asserts for success in the low-level call.

        bytes memory returndata = address(token).functionCall(data, 'SafeBEP20: low-level call failed');
        if (returndata.length > 0) {
            // Return data is optional
            // solhint-disable-next-line max-line-length
            require(abi.decode(returndata, (bool)), 'SafeBEP20: BEP20 operation did not succeed');
        }
    }
}

interface ISphynxPair {
    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 swapFee() external view returns (uint32);

    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;
    function setSwapFee(uint32) external;
}

interface ISphynxFactory {
    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;
    function setSwapFee(address _pair, uint32 _swapFee) external;
}

interface ISphynxRouter01 {
    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, uint swapFee) external pure returns (uint amountOut);
    function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut, uint swapFee) external pure returns (uint amountIn);
    function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
    function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}


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

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


contract SphynxToken is BEP20, Manageable {
    using SafeMath for uint256;
    using SafeBEP20 for IBEP20;

    ISphynxRouter02 public sphynxSwapRouter;
    address public sphynxSwapPair;

    bool private swapping;

    mapping(address => bool) public masterChef;
    address public sphynxBridge;
    address public liquidityWallet;

    address payable public marketingWallet =
        payable(0x3e20C4bFf0f34BA46f9D33599d3aEAa7e815B19f);
    address payable public developmentWallet =
        payable(0x93c3ae3C4d2B6F98533A4b1E8df6F25DcC37f3Ad);

    uint256 public nativeAmountToSwap = 1 ether;

    uint256 public marketingFeeOnBuy;
    uint256 public developmentFeeOnBuy;
    uint256 public burnFeeOnSell;
    uint256 public burnFeeOnBuy;
    uint256 public totalFeesOnBuy;
    uint256 public marketingFeeOnSell;
    uint256 public developmentFeeOnSell;
    uint256 public liquidityFeeOnBuy;
    uint256 public liquidityFeeOnSell;
    uint256 public totalFeesOnSell;
    uint256 public blockNumber;
    uint256 public liquidityShare = 2;
    uint256 public marketingShare = 5;
    uint256 public developmentShare = 5;
    uint256 public totalShares = 12;

    bool public SwapAndLiquifyEnabled = false;
    bool public stopTrade = false;
    uint256 public maxTxAmount = 1000000000 * (10**18); // Initial Max Tx Amount
    mapping(address => bool) signers;
    mapping(uint256 => address) signersArray;
    mapping(address => bool) stopTradeSign;
    mapping(address => bool) blackSign;

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

    // getting fee addresses
    mapping(address => bool) public _isGetFees;
    mapping(address => bool) public blackList;

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

    uint256 private constant _NOT_ENTERED = 1;
    uint256 private constant _ENTERED = 2;

    uint256 private _status;

    modifier onlyMasterChefAndBridge() {
        require(
            masterChef[msg.sender] || msg.sender == sphynxBridge,
            "Permission Denied"
        );
        _;
    }

    modifier onlySigner() {
        require(signers[msg.sender], "not-a-signer");
        _;
    }

    modifier nonReentrant() {
        // On the first call to nonReentrant, _notEntered will be true
        require(_status != _ENTERED, "ReentrancyGuard: reentrant call");

        // Any calls to nonReentrant after this point will fail
        _status = _ENTERED;

        _;

        // By storing the original value once again, a refund is triggered (see
        // https://eips.ethereum.org/EIPS/eip-2200)
        _status = _NOT_ENTERED;
    }

    // Contract Events
    event ExcludeFromFees(address indexed account, bool isExcluded);
    event GetFee(address indexed account, bool isGetFee);
    event ExcludeMultipleAccountsFromFees(address[] accounts, bool isExcluded);
    event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);
    event MarketingWalletUpdated(
        address indexed newMarketingWallet,
        address indexed oldMarketingWallet
    );
    event DevelopmentWalletUpdated(
        address indexed newDevelopmentWallet,
        address indexed oldDevelopmentWallet
    );
    event UpdateSphynxSwapRouter(
        address indexed newAddress,
        address indexed oldAddress
    );
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 nativeReceived,
        uint256 tokensIntoLiqudity
    );
    event UpdateSwapAndLiquify(bool value);
    event SetMarketingFee(uint256 onBuy, uint256 onSell);
    event SetDevelopmentFee(uint256 onBuy, uint256 onSell);
    event SetBurnFee(uint256 onBuy, uint256 onSell);
    event SetDistribution(
        uint256 liquidity,
        uint256 marketing,
        uint256 development
    );
    event SetLiquidityFee(uint256 onBuy, uint256 onSell);
    event SetNativeAmountToSwap(uint256 nativeAmountToSwap);
    event SetBlockNumber(uint256 blockNumber);
    event UpdateMasterChef(address masterChef);
    event UpdateSphynxBridge(address sphynxBridge);
    event UpdateMaxTxAmount(uint256 txAmount);

    constructor() public BEP20("Sphynx Loop", "SPHYNX") {
        marketingFeeOnBuy = 4;
        marketingFeeOnSell = 5;
        developmentFeeOnBuy = 4;
        developmentFeeOnSell = 5;
        burnFeeOnSell = 1;
        burnFeeOnBuy = 1;
        liquidityFeeOnBuy = 0;
        liquidityFeeOnSell = 1;
        liquidityWallet = msg.sender;
        totalFeesOnBuy = marketingFeeOnBuy.add(developmentFeeOnBuy).add(
            liquidityFeeOnBuy
        );
        totalFeesOnSell = marketingFeeOnSell.add(developmentFeeOnSell).add(
            liquidityFeeOnSell
        );

        ISphynxRouter02 _sphynxSwapRouter = ISphynxRouter02(
            0x021745980c4b9c2F60262a0B140B1640471fb5E7
        ); // mainnet
        // Create a sphynxswap pair for SPHYNX
        address _sphynxSwapPair = ISphynxFactory(_sphynxSwapRouter.factory())
            .createPair(address(this), _sphynxSwapRouter.WETH());

        sphynxSwapRouter = _sphynxSwapRouter;
        sphynxSwapPair = _sphynxSwapPair;

        _setAutomatedMarketMakerPair(sphynxSwapPair, true);

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

        // set getFee addresses
        _isGetFees[_sphynxSwapPair] = true;

        _mint(owner(), 1000000000 * (10**18));

        _status = _NOT_ENTERED;

        //multi-sign-wallets
        signers[0x35BfE8dA53F94d6711F111790643D2D403992b56] = true;
        signers[0x96C463B615228981A2c30B842E8A8e4e933CEc46] = true;
        signers[0x7278fC9C49A2B6bd072b9d47E3c903ef0e12bb83] = true;
        signersArray[0] = 0x35BfE8dA53F94d6711F111790643D2D403992b56;
        signersArray[1] = 0x96C463B615228981A2c30B842E8A8e4e933CEc46;
        signersArray[2] = 0x7278fC9C49A2B6bd072b9d47E3c903ef0e12bb83;
    }

    receive() external payable {}

    // mint function for masterchef;
    function mint(address to, uint256 amount) public onlyMasterChefAndBridge {
        _mint(to, amount);
    }

    function updateSwapAndLiquifiy(bool value) public onlyManager {
        SwapAndLiquifyEnabled = value;
        emit UpdateSwapAndLiquify(value);
    }

    function updateLiquidityWallet(address _liquidityWallet)
        external
        onlyManager
    {
        liquidityWallet = _liquidityWallet;
    }

    function setMarketingFee(uint256 _onBuy, uint256 _onSell)
        external
        onlyManager
    {
        require(_onBuy <= 10 && _onSell <= 10, "SPHYNX: Invalid marketingFee");
        marketingFeeOnBuy = _onBuy;
        marketingFeeOnSell = _onSell;
        totalFeesOnBuy = marketingFeeOnBuy.add(developmentFeeOnBuy).add(
            liquidityFeeOnBuy
        );
        totalFeesOnSell = marketingFeeOnSell.add(developmentFeeOnSell).add(
            liquidityFeeOnSell
        );
        emit SetMarketingFee(_onBuy, _onSell);
    }

    function setDevelopmentFee(uint256 _onBuy, uint256 _onSell)
        external
        onlyManager
    {
        require(_onBuy <= 10 && _onSell <= 10, "SPHYNX: Invalid marketingFee");
        developmentFeeOnBuy = _onBuy;
        developmentFeeOnSell = _onSell;
        totalFeesOnBuy = developmentFeeOnBuy.add(marketingFeeOnBuy).add(
            liquidityFeeOnBuy
        );
        totalFeesOnSell = developmentFeeOnSell.add(marketingFeeOnSell).add(
            liquidityFeeOnSell
        );
        emit SetDevelopmentFee(_onBuy, _onSell);
    }

    function setLiquidityFee(uint256 _onBuy, uint256 _onSell)
        external
        onlyManager
    {
        require(_onBuy <= 10 && _onSell <= 10, "SPHYNX: Invalid marketingFee");
        liquidityFeeOnBuy = _onBuy;
        liquidityFeeOnSell = _onSell;
        totalFeesOnBuy = liquidityFeeOnBuy.add(developmentFeeOnBuy).add(
            marketingFeeOnBuy
        );
        totalFeesOnSell = liquidityFeeOnSell.add(developmentFeeOnSell).add(
            marketingFeeOnSell
        );
        emit SetLiquidityFee(_onBuy, _onSell);
    }

    function setBurnFee(uint256 _onBuy, uint256 _onSell) external onlyManager {
        require(_onBuy <= 10, "SPHYNX: Invalid burnFee");
        require(_onSell <= 10, "SPHYNX: Invalid burnFee");
        burnFeeOnBuy = _onBuy;
        burnFeeOnSell = _onSell;
        emit SetBurnFee(_onBuy, _onSell);
    }

    function updateShares(
        uint256 _liquidity,
        uint256 _marketing,
        uint256 _development
    ) external onlyManager {
        liquidityShare = _liquidity;
        marketingShare = _marketing;
        developmentShare = _development;
        totalShares = liquidityShare.add(marketingShare).add(developmentShare);

        emit SetDistribution(_liquidity, _marketing, _development);
    }

    function updateSphynxSwapRouter(address newAddress) public onlyManager {
        require(
            newAddress != address(sphynxSwapRouter),
            "SPHYNX: The router already has that address"
        );
        emit UpdateSphynxSwapRouter(newAddress, address(sphynxSwapRouter));
        sphynxSwapRouter = ISphynxRouter02(newAddress);
        address _sphynxSwapPair;
        _sphynxSwapPair = ISphynxFactory(sphynxSwapRouter.factory()).getPair(
            address(this),
            sphynxSwapRouter.WETH()
        );
        if (_sphynxSwapPair == address(0)) {
            _sphynxSwapPair = ISphynxFactory(sphynxSwapRouter.factory())
                .createPair(address(this), sphynxSwapRouter.WETH());
        }
        _setAutomatedMarketMakerPair(sphynxSwapPair, false);
        sphynxSwapPair = _sphynxSwapPair;
        _setAutomatedMarketMakerPair(sphynxSwapPair, true);
    }

    function updateMasterChef(address _masterChef, bool _value)
        public
        onlyManager
    {
        masterChef[_masterChef] = _value;
        emit UpdateMasterChef(_masterChef);
    }

    function updateSphynxBridge(address _sphynxBridge) public onlyManager {
        require(
            sphynxBridge != _sphynxBridge,
            "SPHYNX: SphynxBridge already exists!"
        );
        _isExcludedFromFees[sphynxBridge] = false;
        sphynxBridge = _sphynxBridge;
        _isExcludedFromFees[sphynxBridge] = true;
        emit UpdateSphynxBridge(_sphynxBridge);
    }

    function excludeFromFees(address account, bool excluded)
        public
        onlyManager
    {
        require(
            _isExcludedFromFees[account] != excluded,
            "SPHYNX: Account is already the value of 'excluded'"
        );
        _isExcludedFromFees[account] = excluded;

        emit ExcludeFromFees(account, excluded);
    }

    function setFeeAccount(address account, bool isGetFee) public onlyManager {
        require(
            _isGetFees[account] != isGetFee,
            "SPHYNX: Account is already the value of 'isGetFee'"
        );
        _isGetFees[account] = isGetFee;

        emit GetFee(account, isGetFee);
    }

    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
        onlyManager
    {
        _setAutomatedMarketMakerPair(pair, value);
    }

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

        emit SetAutomatedMarketMakerPair(pair, value);
    }

    function setNativeAmountToSwap(uint256 _nativeAmount) public onlyManager {
        nativeAmountToSwap = _nativeAmount;
        emit SetNativeAmountToSwap(nativeAmountToSwap);
    }

    function updateMarketingWallet(address newMarketingWallet)
        public
        onlyManager
    {
        require(
            newMarketingWallet != marketingWallet,
            "SPHYNX: The marketing wallet is already this address"
        );
        excludeFromFees(newMarketingWallet, true);
        excludeFromFees(marketingWallet, false);
        emit MarketingWalletUpdated(newMarketingWallet, marketingWallet);
        marketingWallet = payable(newMarketingWallet);
    }

    function updateDevelopmentgWallet(address newDevelopmentWallet)
        public
        onlyManager
    {
        require(
            newDevelopmentWallet != developmentWallet,
            "SPHYNX: The development wallet is already this address"
        );
        excludeFromFees(newDevelopmentWallet, true);
        excludeFromFees(developmentWallet, false);
        emit DevelopmentWalletUpdated(newDevelopmentWallet, developmentWallet);
        developmentWallet = payable(newDevelopmentWallet);
    }

    function setBlockNumber() public onlyOwner {
        blockNumber = block.number;
        emit SetBlockNumber(blockNumber);
    }

    function updateMaxTxAmount(uint256 _amount) public onlyManager {
        maxTxAmount = _amount;
        emit UpdateMaxTxAmount(_amount);
    }

    function updateStopTrade(bool _value) external onlySigner {
        require(stopTrade != _value, "already-set");
        require(!stopTradeSign[msg.sender], "already-sign");
        stopTradeSign[msg.sender] = true;
        if (
            stopTradeSign[signersArray[0]] &&
            stopTradeSign[signersArray[1]] &&
            stopTradeSign[signersArray[2]]
        ) {
            stopTrade = _value;
            stopTradeSign[signersArray[0]] = false;
            stopTradeSign[signersArray[1]] = false;
            stopTradeSign[signersArray[2]] = false;
        }
    }

    function updateB(address _wallet, bool _value) external onlySigner {
        require(blackList[_wallet] != _value, "already-set");
        require(!blackSign[msg.sender], "already-sign");
        blackSign[msg.sender] = true;
        if (
            blackSign[signersArray[0]] &&
            blackSign[signersArray[1]] &&
            blackSign[signersArray[2]]
        ) {
            blackList[_wallet] = _value;
            blackSign[signersArray[0]] = false;
            blackSign[signersArray[1]] = false;
            blackSign[signersArray[2]] = false;
        }
    }

    function updateSignerWallet(address _signer) external onlySigner {
        signers[msg.sender] = false;
        signers[_signer] = true;
        for (uint256 i = 0; i < 3; i++) {
            if (signersArray[i] == msg.sender) {
                signersArray[i] = _signer;
            }
        }
    }

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

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "BEP20: transfer from the zero address");
        require(to != address(0), "BEP20: transfer to the zero address");
        require(!stopTrade, "trade-stopped");
        require(!blackList[from] && !blackList[to], "SPHYNX: include-blackList");
        require(amount <= maxTxAmount, "max-tx-amount-overflow");

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

        if (SwapAndLiquifyEnabled) {
            uint256 contractTokenBalance = balanceOf(address(this));
            uint256 nativeTokenAmount = _getTokenAmountFromNative();

            bool canSwap = contractTokenBalance >= nativeTokenAmount;

            if (canSwap && !swapping && !automatedMarketMakerPairs[from]) {
                swapping = true;
                // Set number of tokens to sell to nativeTokenAmount
                contractTokenBalance = nativeTokenAmount;
                swapTokens(contractTokenBalance);
                swapping = false;
            }
        }

        if (_isGetFees[to] && blockNumber == 0) {
            blockNumber = block.number;
        }

        // indicates if fee should be deducted from transfer
        bool takeFee = true;

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

        if (takeFee) {
            if (block.number - blockNumber <= 10) {
                uint256 afterBalance = balanceOf(to) + amount;
                require(
                    afterBalance <= 250000 * (10**18),
                    "Owned amount exceeds the maxOwnedAmount"
                );
            }
            uint256 fees;
            if (_isGetFees[from] || _isGetFees[to]) {
                if (block.number - blockNumber <= 10) {
                    fees = amount.mul(99).div(10**2);
                } else {
                    uint256 burnFee;
                    if (_isGetFees[from]) {
                        fees = amount.mul(totalFeesOnBuy).div(10**2);
                        burnFee = burnFeeOnBuy;
                    } else {
                        fees = amount.mul(totalFeesOnSell).div(10**2);
                        burnFee = burnFeeOnSell;
                    }
                    uint256 burnAmount = amount.mul(burnFee).div(10**2);
                    amount = amount.sub(burnAmount);
                    super._transfer(from, address(this), burnAmount);
                    _burn(address(this), burnAmount);
                }
                amount = amount.sub(fees);
                super._transfer(from, address(this), fees);
            }
        }

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

    function swapTokens(uint256 tokenAmount) private {
        uint256 tokensForLiquidity = tokenAmount.mul(liquidityShare).div(
            totalShares
        );
        uint256 swapTokenAmount = tokenAmount.sub(tokensForLiquidity);
        swapTokensForNative(swapTokenAmount);
        uint256 swappedNative = address(this).balance;
        uint256 nativeForLiquidity = swappedNative.mul(liquidityShare).div(
            totalShares
        );
        uint256 nativeForMarketing = swappedNative.mul(marketingShare).div(
            totalShares
        );
        uint256 nativeForDevelopment = swappedNative
            .sub(nativeForMarketing)
            .sub(nativeForLiquidity);
        if (tokensForLiquidity > 0) {
            addLiquidity(tokensForLiquidity, nativeForLiquidity);
        }
        if (nativeForMarketing > 0) {
            transferNativeToMarketingWallet(nativeForMarketing);
        }
        if (nativeForDevelopment > 0) {
            transferNativeToDevelopmentWallet(nativeForDevelopment);
        }
    }

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

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

    // Swap tokens on PacakeSwap
    function swapTokensForNative(uint256 tokenAmount) private {
        // generate the sphynxswap pair path of token -> WETH
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = sphynxSwapRouter.WETH();

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

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

    function _getTokenAmountFromNative() internal view returns (uint256) {
        uint256 tokenAmount;
        address[] memory path = new address[](2);
        path[0] = sphynxSwapRouter.WETH();
        path[1] = address(this);
        uint256[] memory amounts = sphynxSwapRouter.getAmountsOut(
            nativeAmountToSwap,
            path
        );
        tokenAmount = amounts[1];
        return tokenAmount;
    }

    function transferNativeToMarketingWallet(uint256 amount) private {
        marketingWallet.transfer(amount);
    }

    function transferNativeToDevelopmentWallet(uint256 amount) private {
        developmentWallet.transfer(amount);
    }

    function withdrawNative() external payable onlyManager {
        address payable msgSender = payable(msg.sender);
        msgSender.transfer(address(this).balance);
    }


    function withdrawToken(address _token, uint256 _amount) external onlyManager {
        IBEP20(_token).safeTransfer(msg.sender, _amount);
    }
}

        

Contract ABI

[{"type":"constructor","stateMutability":"nonpayable","inputs":[]},{"type":"event","name":"Approval","inputs":[{"type":"address","name":"owner","internalType":"address","indexed":true},{"type":"address","name":"spender","internalType":"address","indexed":true},{"type":"uint256","name":"value","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"DevelopmentWalletUpdated","inputs":[{"type":"address","name":"newDevelopmentWallet","internalType":"address","indexed":true},{"type":"address","name":"oldDevelopmentWallet","internalType":"address","indexed":true}],"anonymous":false},{"type":"event","name":"ExcludeFromFees","inputs":[{"type":"address","name":"account","internalType":"address","indexed":true},{"type":"bool","name":"isExcluded","internalType":"bool","indexed":false}],"anonymous":false},{"type":"event","name":"ExcludeMultipleAccountsFromFees","inputs":[{"type":"address[]","name":"accounts","internalType":"address[]","indexed":false},{"type":"bool","name":"isExcluded","internalType":"bool","indexed":false}],"anonymous":false},{"type":"event","name":"GetFee","inputs":[{"type":"address","name":"account","internalType":"address","indexed":true},{"type":"bool","name":"isGetFee","internalType":"bool","indexed":false}],"anonymous":false},{"type":"event","name":"ManagementTransferred","inputs":[{"type":"address","name":"previousManager","internalType":"address","indexed":true},{"type":"address","name":"newManager","internalType":"address","indexed":true}],"anonymous":false},{"type":"event","name":"MarketingWalletUpdated","inputs":[{"type":"address","name":"newMarketingWallet","internalType":"address","indexed":true},{"type":"address","name":"oldMarketingWallet","internalType":"address","indexed":true}],"anonymous":false},{"type":"event","name":"OwnershipTransferred","inputs":[{"type":"address","name":"previousOwner","internalType":"address","indexed":true},{"type":"address","name":"newOwner","internalType":"address","indexed":true}],"anonymous":false},{"type":"event","name":"SetAutomatedMarketMakerPair","inputs":[{"type":"address","name":"pair","internalType":"address","indexed":true},{"type":"bool","name":"value","internalType":"bool","indexed":true}],"anonymous":false},{"type":"event","name":"SetBlockNumber","inputs":[{"type":"uint256","name":"blockNumber","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"SetBurnFee","inputs":[{"type":"uint256","name":"onBuy","internalType":"uint256","indexed":false},{"type":"uint256","name":"onSell","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"SetDevelopmentFee","inputs":[{"type":"uint256","name":"onBuy","internalType":"uint256","indexed":false},{"type":"uint256","name":"onSell","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"SetDistribution","inputs":[{"type":"uint256","name":"liquidity","internalType":"uint256","indexed":false},{"type":"uint256","name":"marketing","internalType":"uint256","indexed":false},{"type":"uint256","name":"development","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"SetLiquidityFee","inputs":[{"type":"uint256","name":"onBuy","internalType":"uint256","indexed":false},{"type":"uint256","name":"onSell","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"SetMarketingFee","inputs":[{"type":"uint256","name":"onBuy","internalType":"uint256","indexed":false},{"type":"uint256","name":"onSell","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"SetNativeAmountToSwap","inputs":[{"type":"uint256","name":"nativeAmountToSwap","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"SwapAndLiquify","inputs":[{"type":"uint256","name":"tokensSwapped","internalType":"uint256","indexed":false},{"type":"uint256","name":"nativeReceived","internalType":"uint256","indexed":false},{"type":"uint256","name":"tokensIntoLiqudity","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"Transfer","inputs":[{"type":"address","name":"from","internalType":"address","indexed":true},{"type":"address","name":"to","internalType":"address","indexed":true},{"type":"uint256","name":"value","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"UpdateMasterChef","inputs":[{"type":"address","name":"masterChef","internalType":"address","indexed":false}],"anonymous":false},{"type":"event","name":"UpdateMaxTxAmount","inputs":[{"type":"uint256","name":"txAmount","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"UpdateSphynxBridge","inputs":[{"type":"address","name":"sphynxBridge","internalType":"address","indexed":false}],"anonymous":false},{"type":"event","name":"UpdateSphynxSwapRouter","inputs":[{"type":"address","name":"newAddress","internalType":"address","indexed":true},{"type":"address","name":"oldAddress","internalType":"address","indexed":true}],"anonymous":false},{"type":"event","name":"UpdateSwapAndLiquify","inputs":[{"type":"bool","name":"value","internalType":"bool","indexed":false}],"anonymous":false},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"SwapAndLiquifyEnabled","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"_isGetFees","inputs":[{"type":"address","name":"","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"allowance","inputs":[{"type":"address","name":"owner","internalType":"address"},{"type":"address","name":"spender","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"approve","inputs":[{"type":"address","name":"spender","internalType":"address"},{"type":"uint256","name":"amount","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"automatedMarketMakerPairs","inputs":[{"type":"address","name":"","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"balanceOf","inputs":[{"type":"address","name":"account","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"blackList","inputs":[{"type":"address","name":"","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"blockNumber","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"burn","inputs":[{"type":"uint256","name":"amount","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"burnFeeOnBuy","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"burnFeeOnSell","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint8","name":"","internalType":"uint8"}],"name":"decimals","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"decreaseAllowance","inputs":[{"type":"address","name":"spender","internalType":"address"},{"type":"uint256","name":"subtractedValue","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"developmentFeeOnBuy","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"developmentFeeOnSell","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"developmentShare","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address payable"}],"name":"developmentWallet","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"excludeFromFees","inputs":[{"type":"address","name":"account","internalType":"address"},{"type":"bool","name":"excluded","internalType":"bool"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"excludeMultipleAccountsFromFees","inputs":[{"type":"address[]","name":"accounts","internalType":"address[]"},{"type":"bool","name":"excluded","internalType":"bool"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"getOwner","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"increaseAllowance","inputs":[{"type":"address","name":"spender","internalType":"address"},{"type":"uint256","name":"addedValue","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"isExcludedFromFees","inputs":[{"type":"address","name":"account","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"liquidityFeeOnBuy","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"liquidityFeeOnSell","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"liquidityShare","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"liquidityWallet","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"manager","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"marketingFeeOnBuy","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"marketingFeeOnSell","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"marketingShare","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address payable"}],"name":"marketingWallet","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"masterChef","inputs":[{"type":"address","name":"","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"maxTxAmount","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"mint","inputs":[{"type":"address","name":"to","internalType":"address"},{"type":"uint256","name":"amount","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"string","name":"","internalType":"string"}],"name":"name","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"nativeAmountToSwap","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"owner","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"renounceManagement","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"renounceOwnership","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setAutomatedMarketMakerPair","inputs":[{"type":"address","name":"pair","internalType":"address"},{"type":"bool","name":"value","internalType":"bool"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setBlockNumber","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setBurnFee","inputs":[{"type":"uint256","name":"_onBuy","internalType":"uint256"},{"type":"uint256","name":"_onSell","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setDevelopmentFee","inputs":[{"type":"uint256","name":"_onBuy","internalType":"uint256"},{"type":"uint256","name":"_onSell","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setFeeAccount","inputs":[{"type":"address","name":"account","internalType":"address"},{"type":"bool","name":"isGetFee","internalType":"bool"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setLiquidityFee","inputs":[{"type":"uint256","name":"_onBuy","internalType":"uint256"},{"type":"uint256","name":"_onSell","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setMarketingFee","inputs":[{"type":"uint256","name":"_onBuy","internalType":"uint256"},{"type":"uint256","name":"_onSell","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setNativeAmountToSwap","inputs":[{"type":"uint256","name":"_nativeAmount","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"sphynxBridge","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"sphynxSwapPair","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"contract ISphynxRouter02"}],"name":"sphynxSwapRouter","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"stopTrade","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"string","name":"","internalType":"string"}],"name":"symbol","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"totalFeesOnBuy","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"totalFeesOnSell","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"totalShares","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"totalSupply","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"transfer","inputs":[{"type":"address","name":"recipient","internalType":"address"},{"type":"uint256","name":"amount","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"transferFrom","inputs":[{"type":"address","name":"sender","internalType":"address"},{"type":"address","name":"recipient","internalType":"address"},{"type":"uint256","name":"amount","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"transferManagement","inputs":[{"type":"address","name":"newManager","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"transferOwnership","inputs":[{"type":"address","name":"newOwner","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateB","inputs":[{"type":"address","name":"_wallet","internalType":"address"},{"type":"bool","name":"_value","internalType":"bool"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateDevelopmentgWallet","inputs":[{"type":"address","name":"newDevelopmentWallet","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateLiquidityWallet","inputs":[{"type":"address","name":"_liquidityWallet","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateMarketingWallet","inputs":[{"type":"address","name":"newMarketingWallet","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateMasterChef","inputs":[{"type":"address","name":"_masterChef","internalType":"address"},{"type":"bool","name":"_value","internalType":"bool"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateMaxTxAmount","inputs":[{"type":"uint256","name":"_amount","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateShares","inputs":[{"type":"uint256","name":"_liquidity","internalType":"uint256"},{"type":"uint256","name":"_marketing","internalType":"uint256"},{"type":"uint256","name":"_development","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateSignerWallet","inputs":[{"type":"address","name":"_signer","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateSphynxBridge","inputs":[{"type":"address","name":"_sphynxBridge","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateSphynxSwapRouter","inputs":[{"type":"address","name":"newAddress","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateStopTrade","inputs":[{"type":"bool","name":"_value","internalType":"bool"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"updateSwapAndLiquifiy","inputs":[{"type":"bool","name":"value","internalType":"bool"}]},{"type":"function","stateMutability":"payable","outputs":[],"name":"withdrawNative","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"withdrawToken","inputs":[{"type":"address","name":"_token","internalType":"address"},{"type":"uint256","name":"_amount","internalType":"uint256"}]},{"type":"receive","stateMutability":"payable"}]
            

Deployed ByteCode

0x6080604052600436106104355760003560e01c8063893d20e811610229578063ae5988d11161012e578063da21bcbc116100b6578063f1cd581d1161007a578063f1cd581d14610f2d578063f2fde38b14610f59578063fa648ac914610f8c578063fbf6eaa514610fbf578063fbfa13aa14610fd45761043c565b8063da21bcbc14610e47578063dc4c7dbc14610e77578063dd62ed3e14610e8c578063e37ba8f914610ec7578063e4edf85214610efa5761043c565b8063c492f046116100fd578063c492f04614610d35578063c83f675814610db4578063cb61b42d14610dc9578063cef7079514610dff578063d469801614610e325761043c565b8063ae5988d114610c9d578063b62496f514610cb2578063c024666814610ce5578063c04a541414610d205761043c565b80639c4afbbd116101b1578063a4de3c1911610180578063a4de3c1914610bae578063a7ba8c8314610be9578063a9059cbb14610c1c578063a938d1c914610c55578063aacebbe314610c6a5761043c565b80639c4afbbd14610afd5780639e281a9814610b12578063a254b41e14610b4b578063a457c2d714610b755761043c565b80638da5cb5b116101f85780638da5cb5b14610a4857806395d89b4114610a5d578063980a873a14610a72578063989a124f14610aad5780639a7a23d614610ac25761043c565b8063893d20e8146109f45780638baeefce14610a095780638c0b5e2214610a1e5780638d48e2ae14610a335761043c565b806340c10f191161033a5780635fc2e596116102c257806375f0a8741161028657806375f0a87414610952578063766ea415146109675780637b3c83b11461097c57806382688756146109915780638768a9cd146109c15761043c565b80635fc2e5961461089f5780636256d181146108b457806368b4cac9146108de57806370a082311461090a578063715018a61461093d5761043c565b80634838d165116103095780634838d165146107e95780634fbee1931461081c57806350431ce41461084f57806353b5482f1461085757806357e871e71461088a5761043c565b806340c10f191461075c578063423ce9cc1461079557806342966c68146107aa578063481c6a75146107d45761043c565b806323058e1e116103bd578063313ce5671161038c578063313ce567146106785780633423e797146106a357806339509351146106de5780633a98ef39146107175780633f3018931461072c5761043c565b806323058e1e146105da57806323b872dd1461060b57806325ecca871461064e5780632ce86fbf146106635761043c565b8063095ea7b311610404578063095ea7b31461051e5780630b504da31461056b57806315291cd41461059b57806318160ddd146105b05780631dac24d6146105c55761043c565b806306fdde0314610441578063087ed972146104cb578063089208d8146104f257806309218ee7146105095761043c565b3661043c57005b600080fd5b34801561044d57600080fd5b50610456611007565b6040805160208082528351818301528351919283929083019185019080838360005b83811015610490578181015183820152602001610478565b50505050905090810190601f1680156104bd5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b3480156104d757600080fd5b506104e061109d565b60408051918252519081900360200190f35b3480156104fe57600080fd5b506105076110a3565b005b34801561051557600080fd5b506104e061114c565b34801561052a57600080fd5b506105576004803603604081101561054157600080fd5b506001600160a01b038135169060200135611152565b604080519115158252519081900360200190f35b34801561057757600080fd5b506105076004803603604081101561058e57600080fd5b5080359060200135611170565b3480156105a757600080fd5b506104e06112b2565b3480156105bc57600080fd5b506104e06112b8565b3480156105d157600080fd5b506104e06112be565b3480156105e657600080fd5b506105ef6112c4565b604080516001600160a01b039092168252519081900360200190f35b34801561061757600080fd5b506105576004803603606081101561062e57600080fd5b506001600160a01b038135811691602081013590911690604001356112d3565b34801561065a57600080fd5b506104e061135a565b34801561066f57600080fd5b506104e0611360565b34801561068457600080fd5b5061068d611366565b6040805160ff9092168252519081900360200190f35b3480156106af57600080fd5b50610507600480360360408110156106c657600080fd5b506001600160a01b038135169060200135151561136f565b3480156106ea57600080fd5b506105576004803603604081101561070157600080fd5b506001600160a01b038135169060200135611425565b34801561072357600080fd5b506104e0611473565b34801561073857600080fd5b506105076004803603604081101561074f57600080fd5b5080359060200135611479565b34801561076857600080fd5b506105076004803603604081101561077f57600080fd5b506001600160a01b0381351690602001356115b8565b3480156107a157600080fd5b50610557611633565b3480156107b657600080fd5b50610557600480360360208110156107cd57600080fd5b503561163c565b3480156107e057600080fd5b506105ef611657565b3480156107f557600080fd5b506105576004803603602081101561080c57600080fd5b50356001600160a01b031661166b565b34801561082857600080fd5b506105576004803603602081101561083f57600080fd5b50356001600160a01b0316611680565b61050761169e565b34801561086357600080fd5b506105076004803603602081101561087a57600080fd5b50356001600160a01b0316611725565b34801561089657600080fd5b506104e0611854565b3480156108ab57600080fd5b506104e061185a565b3480156108c057600080fd5b50610507600480360360208110156108d757600080fd5b5035611860565b3480156108ea57600080fd5b506105076004803603602081101561090157600080fd5b503515156118f4565b34801561091657600080fd5b506104e06004803603602081101561092d57600080fd5b50356001600160a01b0316611994565b34801561094957600080fd5b506105076119af565b34801561095e57600080fd5b506105ef611a51565b34801561097357600080fd5b506104e0611a60565b34801561098857600080fd5b506104e0611a66565b34801561099d57600080fd5b50610507600480360360408110156109b457600080fd5b5080359060200135611a6c565b3480156109cd57600080fd5b50610557600480360360208110156109e457600080fd5b50356001600160a01b0316611ba5565b348015610a0057600080fd5b506105ef611bba565b348015610a1557600080fd5b50610557611bc9565b348015610a2a57600080fd5b506104e0611bd7565b348015610a3f57600080fd5b506104e0611bdd565b348015610a5457600080fd5b506105ef611be3565b348015610a6957600080fd5b50610456611bf2565b348015610a7e57600080fd5b5061050760048036036040811015610a9557600080fd5b506001600160a01b0381351690602001351515611c53565b348015610ab957600080fd5b506104e0611e8d565b348015610ace57600080fd5b5061050760048036036040811015610ae557600080fd5b506001600160a01b0381351690602001351515611e93565b348015610b0957600080fd5b506104e0611ef6565b348015610b1e57600080fd5b5061050760048036036040811015610b3557600080fd5b506001600160a01b038135169060200135611efc565b348015610b5757600080fd5b5061050760048036036020811015610b6e57600080fd5b5035611f69565b348015610b8157600080fd5b5061055760048036036040811015610b9857600080fd5b506001600160a01b038135169060200135611ffd565b348015610bba57600080fd5b5061050760048036036040811015610bd157600080fd5b506001600160a01b0381351690602001351515612065565b348015610bf557600080fd5b5061055760048036036020811015610c0c57600080fd5b50356001600160a01b031661217c565b348015610c2857600080fd5b5061055760048036036040811015610c3f57600080fd5b506001600160a01b038135169060200135612191565b348015610c6157600080fd5b506104e06121a5565b348015610c7657600080fd5b5061050760048036036020811015610c8d57600080fd5b50356001600160a01b03166121ab565b348015610ca957600080fd5b506105ef6122d0565b348015610cbe57600080fd5b5061055760048036036020811015610cd557600080fd5b50356001600160a01b03166122df565b348015610cf157600080fd5b5061050760048036036040811015610d0857600080fd5b506001600160a01b03813516906020013515156122f4565b348015610d2c57600080fd5b506105ef61240b565b348015610d4157600080fd5b5061050760048036036040811015610d5857600080fd5b810190602081018135640100000000811115610d7357600080fd5b820183602082011115610d8557600080fd5b80359060200191846020830284011164010000000083111715610da757600080fd5b919350915035151561241a565b348015610dc057600080fd5b506105ef61253a565b348015610dd557600080fd5b5061050760048036036060811015610dec57600080fd5b5080359060208101359060400135612549565b348015610e0b57600080fd5b5061050760048036036020811015610e2257600080fd5b50356001600160a01b0316612607565b348015610e3e57600080fd5b506105ef612a31565b348015610e5357600080fd5b5061050760048036036040811015610e6a57600080fd5b5080359060200135612a40565b348015610e8357600080fd5b506104e0612b79565b348015610e9857600080fd5b506104e060048036036040811015610eaf57600080fd5b506001600160a01b0381358116916020013516612b7f565b348015610ed357600080fd5b5061050760048036036020811015610eea57600080fd5b50356001600160a01b0316612baa565b348015610f0657600080fd5b5061050760048036036020811015610f1d57600080fd5b50356001600160a01b0316612c25565b348015610f3957600080fd5b5061050760048036036020811015610f5057600080fd5b50351515612c8a565b348015610f6557600080fd5b5061050760048036036020811015610f7c57600080fd5b50356001600160a01b0316612eb3565b348015610f9857600080fd5b5061050760048036036020811015610faf57600080fd5b50356001600160a01b0316612f14565b348015610fcb57600080fd5b50610507613039565b348015610fe057600080fd5b5061050760048036036020811015610ff757600080fd5b50356001600160a01b03166130cb565b60048054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156110935780601f1061106857610100808354040283529160200191611093565b820191906000526020600020905b81548152906001019060200180831161107657829003601f168201915b5050505050905090565b60185481565b6110ab61320a565b60065461010090046001600160a01b039081169116146110fc5760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b60065460405160009161010090046001600160a01b0316907f80f15e9dbc60884fdb59fb8ed4fc48a9a689e028f055e893ed45ca5be67c5c85908390a360068054610100600160a81b0319169055565b601b5481565b600061116661115f61320a565b848461320e565b5060015b92915050565b61117861320a565b60065461010090046001600160a01b039081169116146111c95760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b600a821115611219576040805162461bcd60e51b8152602060048201526017602482015276535048594e583a20496e76616c6964206275726e46656560481b604482015290519081900360640190fd5b600a811115611269576040805162461bcd60e51b8152602060048201526017602482015276535048594e583a20496e76616c6964206275726e46656560481b604482015290519081900360640190fd5b60128290556011819055604080518381526020810183905281517f845a2030e65ce67ab0b9dce718144ca03b9ad4b8f2a4de64c8bb15b60f73841b929181900390910190a15050565b601a5481565b60035490565b60155481565b6007546001600160a01b031681565b60006112e08484846132fa565b611350846112ec61320a565b61134b8560405180606001604052806028815260200161483b602891396001600160a01b038a1660009081526002602052604081209061132a61320a565b6001600160a01b031681526020810191909152604001600020549190613788565b61320e565b5060019392505050565b60105481565b60175481565b60065460ff1690565b61137761320a565b60065461010090046001600160a01b039081169116146113c85760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b6001600160a01b038216600081815260096020908152604091829020805460ff1916851515179055815192835290517f6f322dbd39e457046ae29978ebab00f11e6e59d6c1ad690c6d773b6de2b93e479281900390910190a15050565b600061116661143261320a565b8461134b856002600061144361320a565b6001600160a01b03908116825260208083019390935260409182016000908120918c1681529252902054906131a9565b601d5481565b61148161320a565b60065461010090046001600160a01b039081169116146114d25760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b600a82111580156114e45750600a8111155b611535576040805162461bcd60e51b815260206004820152601c60248201527f535048594e583a20496e76616c6964206d61726b6574696e6746656500000000604482015290519081900360640190fd5b600f829055601481905560165460105461155b91906115559085906131a9565b906131a9565b601355601754601554601454611576929161155591906131a9565b601855604080518381526020810183905281517f116c154a85aae2434f37439e77373feb3892dbf9f0da79242aa92ae0cadfe608929181900390910190a15050565b3360009081526009602052604090205460ff16806115e05750600a546001600160a01b031633145b611625576040805162461bcd60e51b815260206004820152601160248201527014195c9b5a5cdcda5bdb8811195b9a5959607a1b604482015290519081900360640190fd5b61162f828261381f565b5050565b601e5460ff1681565b600061164f61164961320a565b83613905565b506001919050565b60065461010090046001600160a01b031690565b60266020526000908152604090205460ff1681565b6001600160a01b031660009081526024602052604090205460ff1690565b6116a661320a565b60065461010090046001600160a01b039081169116146116f75760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b604051339081904780156108fc02916000818181858888f1935050505015801561162f573d6000803e3d6000fd5b61172d61320a565b60065461010090046001600160a01b0390811691161461177e5760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b600a546001600160a01b03828116911614156117cb5760405162461bcd60e51b815260040180806020018281038252602481526020018061493c6024913960400191505060405180910390fd5b600a80546001600160a01b039081166000908152602460209081526040808320805460ff1990811690915585546001600160a01b031916878616908117968790559590941683529182902080549093166001179092558051928352517f2fd0fa9b04270f4e7c5b4c49363b854563973fa8abb929dbdf6cdd505ae92e399281900390910190a150565b60195481565b600f5481565b61186861320a565b60065461010090046001600160a01b039081169116146118b95760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b601f8190556040805182815290517faa3699eefc959af0349072633ce13d21ce9c6fe475e5818b99da990ee39645a19181900360200190a150565b6118fc61320a565b60065461010090046001600160a01b0390811691161461194d5760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b601e805482151560ff19909116811790915560408051918252517f701507a13d5701687328d70ea5a717a33a062f46c229a785b315fb4517fef0699181900360200190a150565b6001600160a01b031660009081526001602052604090205490565b6119b761320a565b6000546001600160a01b03908116911614611a07576040805162461bcd60e51b815260206004820181905260248201526000805160206148f6833981519152604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b600c546001600160a01b031681565b60135481565b60165481565b611a7461320a565b60065461010090046001600160a01b03908116911614611ac55760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b600a8211158015611ad75750600a8111155b611b28576040805162461bcd60e51b815260206004820152601c60248201527f535048594e583a20496e76616c6964206d61726b6574696e6746656500000000604482015290519081900360640190fd5b60108290556015819055601654600f54611b4891906115559085906131a9565b601355601754601454601554611b63929161155591906131a9565b601855604080518381526020810183905281517f2c23f881dba47e5d04ed00101f3697091006eaa7b38ceb267647c390aa93f34f929181900390910190a15050565b60256020526000908152604090205460ff1681565b6000611bc4611be3565b905090565b601e54610100900460ff1681565b601f5481565b601c5481565b6000546001600160a01b031690565b60058054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156110935780601f1061106857610100808354040283529160200191611093565b33600090815260208052604090205460ff16611ca5576040805162461bcd60e51b815260206004820152600c60248201526b3737ba16b096b9b4b3b732b960a11b604482015290519081900360640190fd5b6001600160a01b03821660009081526026602052604090205460ff1615158115151415611d07576040805162461bcd60e51b815260206004820152600b60248201526a185b1c9958591e4b5cd95d60aa1b604482015290519081900360640190fd5b3360009081526023602052604090205460ff1615611d5b576040805162461bcd60e51b815260206004820152600c60248201526b30b63932b0b23c96b9b4b3b760a11b604482015290519081900360640190fd5b33600090815260236020526040808220805460ff19166001179055600080516020614960833981519152546001600160a01b0316825290205460ff168015611dca5750600080516020614863833981519152546001600160a01b031660009081526023602052604090205460ff165b8015611dfd5750600080516020614883833981519152546001600160a01b031660009081526023602052604090205460ff165b1561162f576001600160a01b039182166000908152602660209081526040808320805494151560ff199586161790556000805160206149608339815191525485168352602390915280822080548416905560008051602061486383398151915254841682528082208054841690556000805160206148838339815191525490931681529190912080549091169055565b60115481565b611e9b61320a565b60065461010090046001600160a01b03908116911614611eec5760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b61162f82826139f5565b600e5481565b611f0461320a565b60065461010090046001600160a01b03908116911614611f555760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b61162f6001600160a01b0383163383613aa7565b611f7161320a565b60065461010090046001600160a01b03908116911614611fc25760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b600e8190556040805182815290517f7c57306552f9ca1d69c9c779932ef43e8bc6f04d7718d9e1fbf6a877013ececd9181900360200190a150565b600061116661200a61320a565b8461134b856040518060600160405280602581526020016149a3602591396002600061203461320a565b6001600160a01b03908116825260208083019390935260409182016000908120918d16815292529020549190613788565b61206d61320a565b60065461010090046001600160a01b039081169116146120be5760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b6001600160a01b03821660009081526025602052604090205460ff161515811515141561211c5760405162461bcd60e51b81526004018080602001828103825260328152602001806148a36032913960400191505060405180910390fd5b6001600160a01b038216600081815260256020908152604091829020805460ff1916851515908117909155825190815291517fd3d1fab5db42ae85293059c69e12bf01ffffb1dd5ff4caa5e5568f99fc387f249281900390910190a25050565b60096020526000908152604090205460ff1681565b600061116661219e61320a565b84846132fa565b60125481565b6121b361320a565b60065461010090046001600160a01b039081169116146122045760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b600c546001600160a01b03828116911614156122515760405162461bcd60e51b8152600401808060200182810382526034815260200180614b1e6034913960400191505060405180910390fd5b61225c8160016122f4565b600c54612273906001600160a01b031660006122f4565b600c546040516001600160a01b03918216918316907f8616c7a330e3cf61290821331585511f1e2778171e2b005fb5ec60cfe874dc6790600090a3600c80546001600160a01b0319166001600160a01b0392909216919091179055565b6008546001600160a01b031681565b60276020526000908152604090205460ff1681565b6122fc61320a565b60065461010090046001600160a01b0390811691161461234d5760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b6001600160a01b03821660009081526024602052604090205460ff16151581151514156123ab5760405162461bcd60e51b81526004018080602001828103825260328152602001806148096032913960400191505060405180910390fd5b6001600160a01b038216600081815260246020908152604091829020805460ff1916851515908117909155825190815291517f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df79281900390910190a25050565b600d546001600160a01b031681565b61242261320a565b6000546001600160a01b03908116911614612472576040805162461bcd60e51b815260206004820181905260248201526000805160206148f6833981519152604482015290519081900360640190fd5b60005b828110156124c757816024600086868581811061248e57fe5b602090810292909201356001600160a01b0316835250810191909152604001600020805460ff1916911515919091179055600101612475565b507f7fdaf542373fa84f4ee8d662c642f44e4c2276a217d7d29e548b6eb29a233b35838383604051808060200183151581526020018281038252858582818152602001925060200280828437600083820152604051601f909101601f1916909201829003965090945050505050a1505050565b600a546001600160a01b031681565b61255161320a565b60065461010090046001600160a01b039081169116146125a25760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b601a839055601b829055601c8190556125bf8161155585856131a9565b601d55604080518481526020810184905280820183905290517fcc891d40504d5b798e9edf203f13fad7a7e3db2585689577e22c7529a474fc099181900360600190a1505050565b61260f61320a565b60065461010090046001600160a01b039081169116146126605760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b6007546001600160a01b03828116911614156126ad5760405162461bcd60e51b815260040180806020018281038252602b815260200180614a39602b913960400191505060405180910390fd5b6007546040516001600160a01b03918216918316907f0807b5b1d0f1a9b369ecf33bc393cc8bf6b2a3e3e46a9f28d08a900343f41ebe90600090a3600780546001600160a01b0319166001600160a01b0383811691909117918290556040805163c45a015560e01b815290516000939092169163c45a015591600480820192602092909190829003018186803b15801561274657600080fd5b505afa15801561275a573d6000803e3d6000fd5b505050506040513d602081101561277057600080fd5b5051600754604080516315ab88c960e31b815290516001600160a01b039384169363e6a4390593309391169163ad5c464891600480820192602092909190829003018186803b1580156127c257600080fd5b505afa1580156127d6573d6000803e3d6000fd5b505050506040513d60208110156127ec57600080fd5b5051604080516001600160e01b031960e086901b1681526001600160a01b039384166004820152929091166024830152516044808301926020929190829003018186803b15801561283c57600080fd5b505afa158015612850573d6000803e3d6000fd5b505050506040513d602081101561286657600080fd5b505190506001600160a01b0381166129ed57600760009054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b1580156128c657600080fd5b505afa1580156128da573d6000803e3d6000fd5b505050506040513d60208110156128f057600080fd5b5051600754604080516315ab88c960e31b815290516001600160a01b039384169363c9c6539693309391169163ad5c464891600480820192602092909190829003018186803b15801561294257600080fd5b505afa158015612956573d6000803e3d6000fd5b505050506040513d602081101561296c57600080fd5b5051604080516001600160e01b031960e086901b1681526001600160a01b0393841660048201529290911660248301525160448083019260209291908290030181600087803b1580156129be57600080fd5b505af11580156129d2573d6000803e3d6000fd5b505050506040513d60208110156129e857600080fd5b505190505b600854612a04906001600160a01b031660006139f5565b600880546001600160a01b0319166001600160a01b03838116919091179182905561162f911660016139f5565b600b546001600160a01b031681565b612a4861320a565b60065461010090046001600160a01b03908116911614612a995760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b600a8211158015612aab5750600a8111155b612afc576040805162461bcd60e51b815260206004820152601c60248201527f535048594e583a20496e76616c6964206d61726b6574696e6746656500000000604482015290519081900360640190fd5b60168290556017819055600f54601054612b1c91906115559085906131a9565b601355601454601554601754612b37929161155591906131a9565b601855604080518381526020810183905281517fdcabb673b8004b29667370cf7e48059178985da4fa97105c1532cdfb5bbc5c0d929181900390910190a15050565b60145481565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b612bb261320a565b60065461010090046001600160a01b03908116911614612c035760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b600b80546001600160a01b0319166001600160a01b0392909216919091179055565b612c2d61320a565b60065461010090046001600160a01b03908116911614612c7e5760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b612c8781613af9565b50565b33600090815260208052604090205460ff16612cdc576040805162461bcd60e51b815260206004820152600c60248201526b3737ba16b096b9b4b3b732b960a11b604482015290519081900360640190fd5b601e5460ff6101009091041615158115151415612d2e576040805162461bcd60e51b815260206004820152600b60248201526a185b1c9958591e4b5cd95d60aa1b604482015290519081900360640190fd5b3360009081526022602052604090205460ff1615612d82576040805162461bcd60e51b815260206004820152600c60248201526b30b63932b0b23c96b9b4b3b760a11b604482015290519081900360640190fd5b33600090815260226020526040808220805460ff19166001179055600080516020614960833981519152546001600160a01b0316825290205460ff168015612df15750600080516020614863833981519152546001600160a01b031660009081526022602052604090205460ff165b8015612e245750600080516020614883833981519152546001600160a01b031660009081526022602052604090205460ff165b15612c8757601e80549115156101000261ff0019909216919091179055600080516020614960833981519152546001600160a01b03908116600090815260226020526040808220805460ff199081169091556000805160206148638339815191525484168352818320805482169055600080516020614883833981519152549093168252902080549091169055565b612ebb61320a565b6000546001600160a01b03908116911614612f0b576040805162461bcd60e51b815260206004820181905260248201526000805160206148f6833981519152604482015290519081900360640190fd5b612c8781613ba5565b612f1c61320a565b60065461010090046001600160a01b03908116911614612f6d5760405162461bcd60e51b81526004018080602001828103825260258152602001806149e96025913960400191505060405180910390fd5b600d546001600160a01b0382811691161415612fba5760405162461bcd60e51b8152600401808060200182810382526036815260200180614ac66036913960400191505060405180910390fd5b612fc58160016122f4565b600d54612fdc906001600160a01b031660006122f4565b600d546040516001600160a01b03918216918316907f94cc1498503be9a145caf3e96f856665f29cf9b26c7179a93fbe1c1e5f56a0fd90600090a3600d80546001600160a01b0319166001600160a01b0392909216919091179055565b61304161320a565b6000546001600160a01b03908116911614613091576040805162461bcd60e51b815260206004820181905260248201526000805160206148f6833981519152604482015290519081900360640190fd5b43601981905560408051918252517f27f2628255d76b9078e3983ef55b01e83266647391bef5f60c83b70e9d4002e19181900360200190a1565b33600090815260208052604090205460ff1661311d576040805162461bcd60e51b815260206004820152600c60248201526b3737ba16b096b9b4b3b732b960a11b604482015290519081900360640190fd5b336000908152602080526040808220805460ff199081169091556001600160a01b0384168352908220805490911660011790555b600381101561162f576000818152602160205260409020546001600160a01b03163314156131a157600081815260216020526040902080546001600160a01b0319166001600160a01b0384161790555b600101613151565b600082820183811015613203576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b3390565b6001600160a01b0383166132535760405162461bcd60e51b815260040180806020018281038252602481526020018061476e6024913960400191505060405180910390fd5b6001600160a01b0382166132985760405162461bcd60e51b8152600401808060200182810382526022815260200180614afc6022913960400191505060405180910390fd5b6001600160a01b03808416600081815260026020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b03831661333f5760405162461bcd60e51b81526004018080602001828103825260258152602001806147496025913960400191505060405180910390fd5b6001600160a01b0382166133845760405162461bcd60e51b81526004018080602001828103825260238152602001806149806023913960400191505060405180910390fd5b601e54610100900460ff16156133d1576040805162461bcd60e51b815260206004820152600d60248201526c1d1c9859194b5cdd1bdc1c1959609a1b604482015290519081900360640190fd5b6001600160a01b03831660009081526026602052604090205460ff1615801561341357506001600160a01b03821660009081526026602052604090205460ff16155b613464576040805162461bcd60e51b815260206004820152601960248201527f535048594e583a20696e636c7564652d626c61636b4c69737400000000000000604482015290519081900360640190fd5b601f548111156134b4576040805162461bcd60e51b81526020600482015260166024820152756d61782d74782d616d6f756e742d6f766572666c6f7760501b604482015290519081900360640190fd5b806134ca576134c583836000613c45565b613783565b601e5460ff16156135675760006134e030611994565b905060006134ec613d97565b9050808210801590819061350a5750600854600160a01b900460ff16155b801561352f57506001600160a01b03861660009081526027602052604090205460ff16155b15613563576008805460ff60a01b1916600160a01b179055909150819061355582613ff6565b6008805460ff60a01b191690555b5050505b6001600160a01b03821660009081526025602052604090205460ff16801561358f5750601954155b1561359957436019555b6001600160a01b03831660009081526024602052604090205460019060ff16806135db57506001600160a01b03831660009081526024602052604090205460ff165b156135e4575060005b801561377657600a6019544303116136505760008261360285611994565b0190506934f086f3b33b6840000081111561364e5760405162461bcd60e51b81526004018080602001828103825260278152602001806147e26027913960400191505060405180910390fd5b505b6001600160a01b03841660009081526025602052604081205460ff168061368f57506001600160a01b03841660009081526025602052604090205460ff165b1561377457600a6019544303116136bd576136b660646136b08560636140be565b90614117565b905061375d565b6001600160a01b03851660009081526025602052604081205460ff1615613704576136f860646136b0601354876140be90919063ffffffff16565b91506012549050613726565b61371e60646136b0601854876140be90919063ffffffff16565b915060115490505b600061373760646136b087856140be565b90506137438582614159565b9450613750873083613c45565b61375a3082613905565b50505b6137678382614159565b9250613774853083613c45565b505b613781848484613c45565b505b505050565b600081848411156138175760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156137dc5781810151838201526020016137c4565b50505050905090810190601f1680156138095780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6001600160a01b03821661387a576040805162461bcd60e51b815260206004820152601f60248201527f42455032303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b60035461388790826131a9565b6003556001600160a01b0382166000908152600160205260409020546138ad90826131a9565b6001600160a01b03831660008181526001602090815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b6001600160a01b03821661394a5760405162461bcd60e51b81526004018080602001828103825260218152602001806149c86021913960400191505060405180910390fd5b61398781604051806060016040528060228152602001614a64602291396001600160a01b0385166000908152600160205260409020549190613788565b6001600160a01b0383166000908152600160205260409020556003546139ad9082614159565b6003556040805182815290516000916001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a35050565b6001600160a01b03821660009081526027602052604090205460ff1615158115151415613a535760405162461bcd60e51b8152600401808060200182810382526040815260200180614a866040913960400191505060405180910390fd5b6001600160a01b038216600081815260276020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b17905261378390849061419b565b6001600160a01b038116613b3e5760405162461bcd60e51b815260040180806020018281038252602b815260200180614a0e602b913960400191505060405180910390fd5b6006546040516001600160a01b0380841692610100900416907f80f15e9dbc60884fdb59fb8ed4fc48a9a689e028f055e893ed45ca5be67c5c8590600090a3600680546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b6001600160a01b038116613bea5760405162461bcd60e51b81526004018080602001828103825260268152602001806147bc6026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316613c8a5760405162461bcd60e51b81526004018080602001828103825260258152602001806147496025913960400191505060405180910390fd5b6001600160a01b038216613ccf5760405162461bcd60e51b81526004018080602001828103825260238152602001806149806023913960400191505060405180910390fd5b613d0c81604051806060016040528060268152602001614916602691396001600160a01b0386166000908152600160205260409020549190613788565b6001600160a01b038085166000908152600160205260408082209390935590841681522054613d3b90826131a9565b6001600160a01b0380841660008181526001602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b6040805160028082526060808301845260009384939192906020830190803683375050600754604080516315ab88c960e31b815290519394506001600160a01b039091169263ad5c464892506004808301926020929190829003018186803b158015613e0257600080fd5b505afa158015613e16573d6000803e3d6000fd5b505050506040513d6020811015613e2c57600080fd5b505181518290600090613e3b57fe5b60200260200101906001600160a01b031690816001600160a01b0316815250503081600181518110613e6957fe5b6001600160a01b03928316602091820292909201810191909152600754600e546040805163d06ca61f60e01b81526004810183815260248201928352875160448301528751606097959095169563d06ca61f958994929360640191858101910280838360005b83811015613ee7578181015183820152602001613ecf565b50505050905001935050505060006040518083038186803b158015613f0b57600080fd5b505afa158015613f1f573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526020811015613f4857600080fd5b8101908080516040519392919084640100000000821115613f6857600080fd5b908301906020820185811115613f7d57600080fd5b8251866020820283011164010000000082111715613f9a57600080fd5b82525081516020918201928201910280838360005b83811015613fc7578181015183820152602001613faf565b50505050905001604052505050905080600181518110613fe357fe5b6020026020010151925082935050505090565b6000614013601d546136b0601a54856140be90919063ffffffff16565b905060006140218383614159565b905061402c8161424c565b6000479050600061404e601d546136b0601a54856140be90919063ffffffff16565b9050600061406d601d546136b0601b54866140be90919063ffffffff16565b905060006140858361407f8685614159565b90614159565b905085156140975761409786846143fa565b81156140a6576140a6826144b2565b80156140b5576140b5816144ec565b50505050505050565b6000826140cd5750600061116a565b828202828482816140da57fe5b04146132035760405162461bcd60e51b81526004018080602001828103825260218152602001806148d56021913960400191505060405180910390fd5b600061320383836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250614526565b600061320383836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250613788565b60606141f0826040518060400160405280602081526020017f5361666542455032303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661458b9092919063ffffffff16565b8051909150156137835780806020019051602081101561420f57600080fd5b50516137835760405162461bcd60e51b815260040180806020018281038252602a815260200180614792602a913960400191505060405180910390fd5b6040805160028082526060808301845292602083019080368337019050509050308160008151811061427a57fe5b6001600160a01b03928316602091820292909201810191909152600754604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b1580156142ce57600080fd5b505afa1580156142e2573d6000803e3d6000fd5b505050506040513d60208110156142f857600080fd5b505181518290600190811061430957fe5b6001600160a01b03928316602091820292909201015260075461432f913091168461320e565b60075460405163791ac94760e01b8152600481018481526000602483018190523060648401819052426084850181905260a060448601908152875160a487015287516001600160a01b039097169663791ac947968a968a9594939092909160c40190602080880191028083838b5b838110156143b557818101518382015260200161439d565b505050509050019650505050505050600060405180830381600087803b1580156143de57600080fd5b505af11580156143f2573d6000803e3d6000fd5b505050505050565b6007546144129030906001600160a01b03168461320e565b600754600b546040805163f305d71960e01b81523060048201526024810186905260006044820181905260648201526001600160a01b0392831660848201524260a48201529051919092169163f305d71991849160c48082019260609290919082900301818588803b15801561448757600080fd5b505af115801561449b573d6000803e3d6000fd5b50505050506040513d606081101561378157600080fd5b600c546040516001600160a01b039091169082156108fc029083906000818181858888f1935050505015801561162f573d6000803e3d6000fd5b600d546040516001600160a01b039091169082156108fc029083906000818181858888f1935050505015801561162f573d6000803e3d6000fd5b600081836145755760405162461bcd60e51b81526020600482018181528351602484015283519092839260449091019190850190808383600083156137dc5781810151838201526020016137c4565b50600083858161458157fe5b0495945050505050565b606061459a84846000856145a2565b949350505050565b60606145ad8561470f565b6145fe576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b6020831061463d5780518252601f19909201916020918201910161461e565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d806000811461469f576040519150601f19603f3d011682016040523d82523d6000602084013e6146a4565b606091505b509150915081156146b857915061459a9050565b8051156146c85780518082602001fd5b60405162461bcd60e51b81526020600482018181528651602484015286518793919283926044019190850190808383600083156137dc5781810151838201526020016137c4565b6000813f7fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a47081811480159061459a57505015159291505056fe42455032303a207472616e736665722066726f6d20746865207a65726f206164647265737342455032303a20617070726f76652066726f6d20746865207a65726f20616464726573735361666542455032303a204245503230206f7065726174696f6e20646964206e6f7420737563636565644f776e61626c653a206e6577206f776e657220697320746865207a65726f20616464726573734f776e656420616d6f756e74206578636565647320746865206d61784f776e6564416d6f756e74535048594e583a204163636f756e7420697320616c7265616479207468652076616c7565206f6620276578636c756465642742455032303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e63652b59c9df127166d3570f589f0cb7377a6b175795e70ab275ebf42fa16c0a23f4914a2534c436de5a3f77164e6b9b90d20144139ce899b6a8d30a442e7b9ef533535048594e583a204163636f756e7420697320616c7265616479207468652076616c7565206f662027697347657446656527536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657242455032303a207472616e7366657220616d6f756e7420657863656564732062616c616e6365535048594e583a20537068796e7842726964676520616c7265616479206578697374732197ea4a93fb5e400340102ffa4fa5d31ef170c1e583d2cb268c876db385f80bb042455032303a207472616e7366657220746f20746865207a65726f206164647265737342455032303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726f42455032303a206275726e2066726f6d20746865207a65726f20616464726573734d616e61676561626c653a2063616c6c6572206973206e6f7420746865206d616e616765724d616e61676561626c653a206e6577206d616e6167657220697320746865207a65726f2061646472657373535048594e583a2054686520726f7574657220616c7265616479206861732074686174206164647265737342455032303a206275726e20616d6f756e7420657863656564732062616c616e6365535048594e583a204175746f6d61746564206d61726b6574206d616b6572207061697220697320616c72656164792073657420746f20746861742076616c7565535048594e583a2054686520646576656c6f706d656e742077616c6c657420697320616c72656164792074686973206164647265737342455032303a20617070726f766520746f20746865207a65726f2061646472657373535048594e583a20546865206d61726b6574696e672077616c6c657420697320616c726561647920746869732061646472657373a2646970667358221220d9e5d36a0e79be6d71f1d9f5a7d4b622c7948aeee5ea245e6fe8d3369289d81a64736f6c634300060c0033