Contract 0xff00da868f1ca57a3c13ec8a77f6c3cdf06139c3 1

 
 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0xa3571e70b26db20ba0d1253614faa6a0c56e9dc19194b006d9271cae7e399246Approve144106502022-01-16 8:14:502 days 1 hr ago0xfb0803de2c3293f85c424ae36f2254d2bd54f312 IN  Pet World: PW Token0 BNB0.0000757276
0x5b5b13bde78c8d30e00c2e18deb7ff933b0ea30a6332358bca748d38d0334da7Approve144018522022-01-16 0:54:552 days 9 hrs ago0x7945eb784f81ca27c7f4df54e0ebe3a8ea4d664d IN  Pet World: PW Token0 BNB0.000222545
0xf943cdd656d6b110cb106f53bed5d6689829f724bcf370521378520ad5635fa9Approve143909072022-01-15 15:43:422 days 18 hrs ago0x4d8638da9dc4830df414eafedc6207335004b558 IN  Pet World: PW Token0 BNB0.000222545
0x23807a44663af014110ae5e0defb35316a5c722d7eeee28331fd141b7d364eb2Approve143639592022-01-14 17:14:553 days 16 hrs ago0x6b0d9a479e9a245b2c3464ea6d92a908936595ff IN  Pet World: PW Token0 BNB0.000077984865
0x7bb1837dce531ad533a1f33bac4c0282335a96f915bb3d6ad87b80ad41c94743Approve143049862022-01-12 16:00:275 days 18 hrs ago0x8e1eccdc07152767c5f48f0f7236d7c2519b00af IN  Pet World: PW Token0 BNB0.000072815
0x3522a25cb6edf2c41ff3d75ae7f3fe1a0da287d38c0d87f9babb07c4710a5ec3Approve142955982022-01-12 8:08:096 days 1 hr ago0x680c5ffcdc98a90786b952144b05ce8acc0b479e IN  Pet World: PW Token0 BNB0.000222545
0xbc30b1c18afb7c972ace47a4ec7c5d5fdd7114758541dd619642cb037b647b63Approve142675282022-01-11 8:42:317 days 1 hr ago0x1c59a25867be8cc5d2d530b3ff8107d5141ca198 IN  Pet World: PW Token0 BNB0.000072815
0x86dd7cf1f1ae6fd4873a46d9803011fc2a59143491b30e7473387a2316974067Approve142673082022-01-11 8:31:317 days 1 hr ago0x87bfbb97063be625a0258ec035988785160838ac IN  Pet World: PW Token0 BNB0.000072815
0x2f4dda7b5917bdf6dcf3fef9f33f0dc336bf057c47aeba38e3fcf90ec7f37e5eApprove142571922022-01-11 0:02:507 days 9 hrs ago0xce6c245e32504026f411187e9bffeb838806da1d IN  Pet World: PW Token0 BNB0.000124625
0xb3d537f9f5ee41c7df4dac0fe26ed70adcb6cf00a7d7532482c6ad2c478ad2cfApprove142565722022-01-10 23:31:507 days 10 hrs ago0xce6c245e32504026f411187e9bffeb838806da1d IN  Pet World: PW Token0 BNB0.000124565
0x859c0152060f1fed5f89aab186f4a57feaade29e50373bed5473203adc8da3aeApprove142565612022-01-10 23:31:177 days 10 hrs ago0xce6c245e32504026f411187e9bffeb838806da1d IN  Pet World: PW Token0 BNB0.000124625
0x0b44b2b8edd2b618df8190cc876b4ef565011ba71361122b49ca8d946619f635Approve142549352022-01-10 22:08:507 days 11 hrs ago0xce6c245e32504026f411187e9bffeb838806da1d IN  Pet World: PW Token0 BNB0.000133409115
0xd40f198469692b680ce732bc163e5cbd4ccd3f839c610143f38e086d2b9ded93Approve142549262022-01-10 22:08:237 days 11 hrs ago0xce6c245e32504026f411187e9bffeb838806da1d IN  Pet World: PW Token0 BNB0.000133473375
0x712f45e47323e844747235da868e62b605b3b7129d071b2df5962c9d5e7b4885Approve142326752022-01-10 3:35:218 days 6 hrs ago0xbd2cfa29b64f07a0701a5799979b5d712c731659 IN  Pet World: PW Token0 BNB0.000222545
0x2b278501f4db1a41010ddd2bf490dc472fa515f2830d0c3bfb7ef2e0a957313bApprove142178972022-01-09 15:16:278 days 18 hrs ago0x467e32c6a67a072e1c00b4256bcf4329da49a099 IN  Pet World: PW Token0 BNB0.000077984865
0x09d568a5da19eff4f1ab65d1b41b1e45c25945561c4a908cea6f52e6f446bf14Approve142172402022-01-09 14:43:368 days 19 hrs ago0x02bfa5079fb71155c25f87abb75ababab6584f3f IN  Pet World: PW Token0 BNB0.000077984865
0x3bc9869cec2424c9cfa6426dc116083643285164c4457fa5c84cc05f25843d86Approve141963792022-01-08 21:19:349 days 12 hrs ago0xc3b6ec3197931da90e9ecf04eb660f12b0674ea8 IN  Pet World: PW Token0 BNB0.000072815
0x57f8d0ec8c55925d90ead7508458d44fd9d92ded1789c743216f47e63151efb0Approve141768622022-01-08 5:02:0910 days 4 hrs ago0x68f650b528aeaf33ebef1627a1f36aa5d355c97f IN  Pet World: PW Token0 BNB0.000072815
0x89e01cbb3de139f47eaae87e2d2851e7644c3f1ecd9a6872a87c50fa95e87bd1Approve141665372022-01-07 20:25:1010 days 13 hrs ago0xe88cfeea85d02c36bf58b71028a46a84256f029d IN  Pet World: PW Token0 BNB0.000077984865
0x3842ac8fc8db83b9504adf3d1182b896ba43a46661e914100a1215e8298ee697Approve141573492022-01-07 12:45:0110 days 21 hrs ago0x074ae4795dbbc07fa044c7cd61bd0da395e67fd8 IN  Pet World: PW Token0 BNB0.000072815
0xfd22f5f58409a1df4fe8642c8778e87ac812b357d18bde58e533d6dae5b8bce9Approve141566262022-01-07 12:08:5010 days 21 hrs ago0x9cb90ff86545f478b7725e0895b499c86b6f678c IN  Pet World: PW Token0 BNB0.000238345695
0x88d109096ea5b9deaa8f1df2b7dd75e058c10658e65f09a1ff3c20b228f79ed7Approve141495712022-01-07 6:15:1011 days 3 hrs ago0xe0006f6025f48780445ab06c35130220aad9e47a IN  Pet World: PW Token0 BNB0.000222545
0x7f1451fea56abf5e545643ce3d66f8dd5689e7d01117580adcb67ef84e319d30Approve141091082022-01-05 20:26:5112 days 13 hrs ago0x9464f70a290bfb6bce03068b117bc69bf709a8e3 IN  Pet World: PW Token0 BNB0.000087378
0x6105058e5512a0b1c4b9ae9d6d7a3535412eb06e5515c0da0981c00c2bcbbdb4Approve141023462022-01-05 14:47:5412 days 19 hrs ago0x3485ea244065a130e96cd7e4f75cbda32bdb6e6c IN  Pet World: PW Token0 BNB0.000077984865
0x95fee319dd437b2542367d2b05c89f70d594326c4b13ea8c7ccefc1774844cbaApprove140756572022-01-04 16:29:0113 days 17 hrs ago0x93e512f0f7d3ea29e6dea4c68a2014a072f8c1a2 IN  Pet World: PW Token0 BNB0.000126545
[ Download CSV Export 

OVERVIEW

Pet World is an online game based on blockchain. Users can adopt pets, trade and work to make money.

Parent Txn Hash Block From To Value
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
PetWorld

Compiler Version
v0.8.2+commit.661d1103

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

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

pragma solidity ^0.8.2;


library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

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

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) return (true, 0);
        uint256 c = a * b;
        if (c / a != b) return (false, 0);
        return (true, c);
    }
}

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

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

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

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

/**
 * @dev Returns the multiplication of two unsigned integers, reverting on
 * overflow.
 *
 * Counterpart to Solidity's `*` operator.
 *
 * Requirements:
 *
 * - Multiplication cannot overflow.
 */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

/**
 * @dev Returns the integer division of two unsigned integers, reverting on
 * division by zero. The result is rounded towards zero.
 *
 * Counterpart to Solidity's `/` operator.
 *
 * Requirements:
 *
 * - The divisor cannot be zero.
 */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

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

/**
 * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
 * overflow (when the result is negative).
 *
 * CAUTION: This function is deprecated because it requires allocating memory for the error
 * message unnecessarily. For custom revert reasons use {trySub}.
 *
 * Counterpart to Solidity's `-` operator.
 *
 * Requirements:
 *
 * - Subtraction cannot overflow.
 */
    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
        ) internal pure returns (uint256) {
            unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

/**
 * @dev Returns the integer division of two unsigned integers, reverting with custom message on
 * division by zero. The result is rounded towards zero.
 *
 * 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) {
        unchecked {
        require(b > 0, errorMessage);
        return a / b;
        }
    }

/**
 * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
 * reverting with custom message when dividing by zero.
 *
 * CAUTION: This function is deprecated because it requires allocating memory for the error
 * message unnecessarily. For custom revert reasons use {tryMod}.
 *
 * Counterpart to Solidity's `%` operator. This function uses a `revert`
 * opcode (which leaves remaining gas untouched) while Solidity uses an
 * invalid opcode to revert (consuming all remaining gas).
 *
 * Requirements:
 *
 * - The divisor cannot be zero.
 */
    function mod(
    uint256 a,
    uint256 b,
    string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}

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

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}


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

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

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

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

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

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

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

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);
}
/**
 * @dev Interface for the optional metadata functions from the ERC20 standard.
 *
 * _Available since v4.1._
 */
interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

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

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


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

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

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

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

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

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

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

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

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

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

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

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

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

        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");
        unchecked {
    _approve(sender, _msgSender(), currentAllowance - amount);
    }

        return true;
    }

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

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

        return true;
    }

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

        _beforeTokenTransfer(sender, recipient, amount);

        uint256 senderBalance = _balances[sender];
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");
        unchecked {
    _balances[sender] = senderBalance - amount;
    }
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);

        _afterTokenTransfer(sender, recipient, amount);
    }

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

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

        _totalSupply += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);

        _afterTokenTransfer(address(0), account, amount);
    }

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

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

        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        unchecked {
    _balances[account] = accountBalance - amount;
    }
        _totalSupply -= amount;

        emit Transfer(account, address(0), amount);

        _afterTokenTransfer(account, address(0), amount);
    }

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

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

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

    /**
     * @dev Hook that is called after any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * has been transferred to `to`.
     * - when `from` is zero, `amount` tokens have been minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens have been burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _afterTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}
/**
 * @dev Extension of {ERC20} that allows token holders to destroy both their own
 * tokens and those that they have an allowance for, in a way that can be
 * recognized off-chain (via event analysis).
 */
abstract contract ERC20Burnable is Context, ERC20 {
    /**
     * @dev Destroys `amount` tokens from the caller.
     *
     * See {ERC20-_burn}.
     */
    function burn(uint256 amount) public virtual {
        _burn(_msgSender(), amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, deducting from the caller's
     * allowance.
     *
     * See {ERC20-_burn} and {ERC20-allowance}.
     *
     * Requirements:
     *
     * - the caller must have allowance for ``accounts``'s tokens of at least
     * `amount`.
     */
    function burnFrom(address account, uint256 amount) public virtual {
        uint256 currentAllowance = allowance(account, _msgSender());
        require(currentAllowance >= amount, "ERC20: burn amount exceeds allowance");
        unchecked {
    _approve(account, _msgSender(), currentAllowance - amount);
    }
        _burn(account, amount);
    }
}


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

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _setOwner(_msgSender());
    }

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

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

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

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

    function _setOwner(address newOwner) private {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}



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

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

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

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

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

interface IUniswapV2Router01 {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);
    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountToken, uint amountETH);
    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
    external
    payable
    returns (uint[] memory amounts);
    function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
    external
    returns (uint[] memory amounts);
    function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
    external
    returns (uint[] memory amounts);
    function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
    external
    payable
    returns (uint[] memory amounts);

    function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
    function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
    function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
    function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
    function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}


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

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




contract PetWorld is ERC20, ERC20Burnable, Ownable {
    using SafeMath for uint256;

    uint256 MAX_TOTAL_SUPPLY         = 100000000 * 10 ** 9;
    uint256 MAX_TOKENS_FOR_REWARDS   = 38000000  * 10 ** 9;


    address public BurnAddr = 0x000000000000000000000000000000000000dEaD;
    address public mintContract;

    mapping(address => bool)    botAddresses;
    mapping (address => bool) private _isExcludedFromFee;



    address public uniswapV2Pair;
    address public addressForMarketing;

    uint256 public tokensForRewards   = MAX_TOKENS_FOR_REWARDS;

    // Anti bot-trade
    bool public antiBotEnabled;
    uint256 public antiBotDuration = 10 minutes;
    uint256 public antiBotTime;
    uint256 public antiBotAmount;

    // Transfer fee
    uint256 public sellFeeRate = 8;
    uint256 public buyFeeRate = 5;


    constructor() ERC20("PetWorld", "PW") {
        addressForMarketing =address(0x97244DF3715C57Ceca3df28c5727d78b16f666c7);
        mintContract=address(this);
        
        _mint(_msgSender(), MAX_TOTAL_SUPPLY.sub(tokensForRewards));
        _mint(mintContract, tokensForRewards);


        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x10ED43C718714eb63d5aA57B78B54704E256024E);
        IUniswapV2Factory  _uniswapV2Factory = IUniswapV2Factory(_uniswapV2Router.factory());

        uniswapV2Pair   = _uniswapV2Factory.createPair(address(this), _uniswapV2Router.WETH());

    }

    function decimals() public view virtual override returns (uint8) {
        return 9;
    }

 

    function setBotAddresses (address[] memory _addresses) external onlyOwner {
        require(_addresses.length > 0);

        for (uint256 index = 0; index < _addresses.length; index++) {
            botAddresses[address(_addresses[index])] = true;
        }
    }

    function addBotAddress (address _address) external onlyOwner {
        require(!botAddresses[_address]);

        botAddresses[_address] = true;
    }

    /**
     * To prevent bot trading, limit the number of tokens that can be transferred.
     */
    function antiBot(uint256 amount) external onlyOwner {
        require(amount > 0, "not accept 0 value");
        require(!antiBotEnabled);

        antiBotAmount = amount;
        antiBotTime = block.timestamp + antiBotDuration;
        antiBotEnabled = true;
    }


    
    
    function excludeFromFee(address account) public onlyOwner {
        _isExcludedFromFee[account] = true;
    }

    function includeInFee(address account) public onlyOwner {
        _isExcludedFromFee[account] = false;
    }
    
    function SetMintContract(address contrat_addr) external onlyOwner {
        super._transfer(mintContract,contrat_addr,balanceOf(address(this)));
        mintContract = contrat_addr;
    }


    /**
     * Add a bot prevention feature by overriding the _transfer function.
     */
    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual override {
        if (
            botAddresses[sender] &&
            amount > antiBotAmount &&
            antiBotTime > block.timestamp
        ) {
            revert("Anti Bot");
        }


        if(recipient == uniswapV2Pair){
            if (
                sender != address(this) &&
                recipient != address(this) &&
                !_isExcludedFromFee[sender]
            ) {
                uint256 _fee = amount.mul(sellFeeRate).div(100);
                super._transfer(sender,mintContract, _fee.mul(50).div(100));
                super._transfer(sender, addressForMarketing, _fee.mul(375).div(1000));
                super._transfer(sender, BurnAddr, _fee.mul(125).div(1000));
                amount = amount.sub(_fee);
            }
        }else if(sender == uniswapV2Pair){
            if (
                sender != address(this) &&
                recipient != address(this) &&
                !_isExcludedFromFee[sender]
            ) {
                uint256 _fee = amount.mul(buyFeeRate).div(100);
                super._transfer(sender,mintContract, _fee.mul(60).div(100));
                super._transfer(sender, addressForMarketing, _fee.sub(_fee.mul(60).div(100)));
                amount = amount.sub(_fee);
            }
        }
    
        super._transfer(sender, recipient, amount);
    }

    // receive eth from uniswap swap
    receive() external payable {}
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"BurnAddr","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"contrat_addr","type":"address"}],"name":"SetMintContract","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"addBotAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"addressForMarketing","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"antiBot","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"antiBotAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"antiBotDuration","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"antiBotEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"antiBotTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burnFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"buyFeeRate","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"excludeFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"includeInFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"mintContract","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sellFeeRate","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"_addresses","type":"address[]"}],"name":"setBotAddresses","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForRewards","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

608060405267016345785d8a0000600655668700cc757700006007819055600880546001600160a01b03191661dead178155600e9190915561025860105560135560056014553480156200005257600080fd5b50604080518082018252600881526714195d15dbdc9b1960c21b602080830191825283518085019094526002845261505760f01b9084015281519192916200009d9160039162000466565b508051620000b390600490602084019062000466565b505050620000d0620000ca6200031360201b60201c565b62000317565b600d80546001600160a01b03199081167397244df3715c57ceca3df28c5727d78b16f666c717909155600980549091163017905562000134620001103390565b6200012e600e546006546200036960201b62000cb41790919060201c565b6200037e565b600954600e546200014f916001600160a01b0316906200037e565b60007310ed43c718714eb63d5aa57b78b54704e256024e90506000816001600160a01b031663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b158015620001a457600080fd5b505afa158015620001b9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001df91906200050c565b9050806001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156200022b57600080fd5b505afa15801562000240573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200026691906200050c565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b158015620002af57600080fd5b505af1158015620002c4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002ea91906200050c565b600c80546001600160a01b0319166001600160a01b039290921691909117905550620005bd9050565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b600062000377828462000550565b9392505050565b6001600160a01b038216620003d95760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640160405180910390fd5b8060026000828254620003ed919062000535565b90915550506001600160a01b038216600090815260208190526040812080548392906200041c90849062000535565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b82805462000474906200056a565b90600052602060002090601f016020900481019282620004985760008555620004e3565b82601f10620004b357805160ff1916838001178555620004e3565b82800160010185558215620004e3579182015b82811115620004e3578251825591602001919060010190620004c6565b50620004f1929150620004f5565b5090565b5b80821115620004f15760008155600101620004f6565b6000602082840312156200051e578081fd5b81516001600160a01b038116811462000377578182fd5b600082198211156200054b576200054b620005a7565b500190565b600082821015620005655762000565620005a7565b500390565b6002810460018216806200057f57607f821691505b60208210811415620005a157634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b61171a80620005cd6000396000f3fe6080604052600436106101f25760003560e01c8063715018a61161010d578063d8c6404b116100a0578063e5cda0e51161006f578063e5cda0e514610588578063ea2f0b37146105a8578063f2fde38b146105c8578063f54afa78146105e8578063f73b2e9d146105fe576101f9565b8063d8c6404b146104e8578063dcf1ac0514610502578063dd62ed3e14610522578063e41765de14610568576101f9565b80639dbb156a116100dc5780639dbb156a14610468578063a457c2d714610488578063a9059cbb146104a8578063d0b6b6db146104c8576101f9565b8063715018a61461040057806379cc6790146104155780638da5cb5b1461043557806395d89b4114610453576101f9565b806341a671f7116101855780634fab2bbb116101545780634fab2bbb1461039e5780635b149feb146103b45780636b1b4987146103ca57806370a08231146103e0576101f9565b806341a671f71461030457806342966c6814610326578063437823ec1461034657806349bd5a5e14610366576101f9565b806318160ddd116101c157806318160ddd1461029357806323b872dd146102a8578063313ce567146102c857806339509351146102e4576101f9565b806306fdde03146101fe578063095ea7b3146102295780631069fdd41461025957806317574ce01461027d576101f9565b366101f957005b600080fd5b34801561020a57600080fd5b5061021361061e565b604051610220919061156c565b60405180910390f35b34801561023557600080fd5b50610249610244366004611465565b6106b0565b6040519015158152602001610220565b34801561026557600080fd5b5061026f60105481565b604051908152602001610220565b34801561028957600080fd5b5061026f60125481565b34801561029f57600080fd5b5060025461026f565b3480156102b457600080fd5b506102496102c336600461142a565b6106c6565b3480156102d457600080fd5b5060405160098152602001610220565b3480156102f057600080fd5b506102496102ff366004611465565b610775565b34801561031057600080fd5b5061032461031f3660046113de565b6107b1565b005b34801561033257600080fd5b50610324610341366004611554565b61081c565b34801561035257600080fd5b506103246103613660046113de565b610829565b34801561037257600080fd5b50600c54610386906001600160a01b031681565b6040516001600160a01b039091168152602001610220565b3480156103aa57600080fd5b5061026f60115481565b3480156103c057600080fd5b5061026f60135481565b3480156103d657600080fd5b5061026f60145481565b3480156103ec57600080fd5b5061026f6103fb3660046113de565b610877565b34801561040c57600080fd5b50610324610896565b34801561042157600080fd5b50610324610430366004611465565b6108cc565b34801561044157600080fd5b506005546001600160a01b0316610386565b34801561045f57600080fd5b50610213610952565b34801561047457600080fd5b5061032461048336600461148e565b610961565b34801561049457600080fd5b506102496104a3366004611465565b610a13565b3480156104b457600080fd5b506102496104c3366004611465565b610aac565b3480156104d457600080fd5b50600954610386906001600160a01b031681565b3480156104f457600080fd5b50600f546102499060ff1681565b34801561050e57600080fd5b50600854610386906001600160a01b031681565b34801561052e57600080fd5b5061026f61053d3660046113f8565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561057457600080fd5b506103246105833660046113de565b610ab9565b34801561059457600080fd5b50600d54610386906001600160a01b031681565b3480156105b457600080fd5b506103246105c33660046113de565b610b2d565b3480156105d457600080fd5b506103246105e33660046113de565b610b78565b3480156105f457600080fd5b5061026f600e5481565b34801561060a57600080fd5b50610324610619366004611554565b610c10565b60606003805461062d90611662565b80601f016020809104026020016040519081016040528092919081815260200182805461065990611662565b80156106a65780601f1061067b576101008083540402835291602001916106a6565b820191906000526020600020905b81548152906001019060200180831161068957829003601f168201915b5050505050905090565b60006106bd338484610cc7565b50600192915050565b60006106d3848484610deb565b6001600160a01b03841660009081526001602090815260408083203384529091529020548281101561075d5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b61076a8533858403610cc7565b506001949350505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916106bd9185906107ac9086906115f4565b610cc7565b6005546001600160a01b031633146107db5760405162461bcd60e51b8152600401610754906115bf565b6009546107fa906001600160a01b0316826107f530610877565b611040565b600980546001600160a01b0319166001600160a01b0392909216919091179055565b610826338261120f565b50565b6005546001600160a01b031633146108535760405162461bcd60e51b8152600401610754906115bf565b6001600160a01b03166000908152600b60205260409020805460ff19166001179055565b6001600160a01b0381166000908152602081905260409020545b919050565b6005546001600160a01b031633146108c05760405162461bcd60e51b8152600401610754906115bf565b6108ca600061135d565b565b60006108d8833361053d565b9050818110156109365760405162461bcd60e51b8152602060048201526024808201527f45524332303a206275726e20616d6f756e74206578636565647320616c6c6f77604482015263616e636560e01b6064820152608401610754565b6109438333848403610cc7565b61094d838361120f565b505050565b60606004805461062d90611662565b6005546001600160a01b0316331461098b5760405162461bcd60e51b8152600401610754906115bf565b600081511161099957600080fd5b60005b8151811015610a0f576001600a60008484815181106109cb57634e487b7160e01b600052603260045260246000fd5b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff191691151591909117905580610a078161169d565b91505061099c565b5050565b3360009081526001602090815260408083206001600160a01b038616845290915281205482811015610a955760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610754565b610aa23385858403610cc7565b5060019392505050565b60006106bd338484610deb565b6005546001600160a01b03163314610ae35760405162461bcd60e51b8152600401610754906115bf565b6001600160a01b0381166000908152600a602052604090205460ff1615610b0957600080fd5b6001600160a01b03166000908152600a60205260409020805460ff19166001179055565b6005546001600160a01b03163314610b575760405162461bcd60e51b8152600401610754906115bf565b6001600160a01b03166000908152600b60205260409020805460ff19169055565b6005546001600160a01b03163314610ba25760405162461bcd60e51b8152600401610754906115bf565b6001600160a01b038116610c075760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610754565b6108268161135d565b6005546001600160a01b03163314610c3a5760405162461bcd60e51b8152600401610754906115bf565b60008111610c7f5760405162461bcd60e51b81526020600482015260126024820152716e6f742061636365707420302076616c756560701b6044820152606401610754565b600f5460ff1615610c8f57600080fd5b6012819055601054610ca190426115f4565b60115550600f805460ff19166001179055565b6000610cc0828461164b565b9392505050565b6001600160a01b038316610d295760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610754565b6001600160a01b038216610d8a5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610754565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166000908152600a602052604090205460ff168015610e14575060125481115b8015610e21575042601154115b15610e595760405162461bcd60e51b8152602060048201526008602482015267105b9d1a48109bdd60c21b6044820152606401610754565b600c546001600160a01b0383811691161415610f5c576001600160a01b0383163014801590610e9157506001600160a01b0382163014155b8015610eb657506001600160a01b0383166000908152600b602052604090205460ff16155b15610f57576000610edd6064610ed7601354856113af90919063ffffffff16565b906113bb565b600954909150610f029085906001600160a01b03166107f56064610ed78660326113af565b600d54610f269085906001600160a01b03166107f56103e8610ed7866101776113af565b600854610f499085906001600160a01b03166107f56103e8610ed786607d6113af565b610f538282610cb4565b9150505b611039565b600c546001600160a01b0384811691161415611039576001600160a01b0383163014801590610f9457506001600160a01b0382163014155b8015610fb957506001600160a01b0383166000908152600b602052604090205460ff16155b15611039576000610fda6064610ed7601454856113af90919063ffffffff16565b600954909150610fff9085906001600160a01b03166107f56064610ed786603c6113af565b600d5461102b9085906001600160a01b03166107f56110246064610ed787603c6113af565b8590610cb4565b6110358282610cb4565b9150505b61094d8383835b6001600160a01b0383166110a45760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610754565b6001600160a01b0382166111065760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610754565b6001600160a01b0383166000908152602081905260409020548181101561117e5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610754565b6001600160a01b038085166000908152602081905260408082208585039055918516815290812080548492906111b59084906115f4565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161120191815260200190565b60405180910390a350505050565b6001600160a01b03821661126f5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610754565b6001600160a01b038216600090815260208190526040902054818110156112e35760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b6064820152608401610754565b6001600160a01b038316600090815260208190526040812083830390556002805484929061131290849061164b565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a361094d565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6000610cc0828461162c565b6000610cc0828461160c565b80356001600160a01b038116811461089157600080fd5b6000602082840312156113ef578081fd5b610cc0826113c7565b6000806040838503121561140a578081fd5b611413836113c7565b9150611421602084016113c7565b90509250929050565b60008060006060848603121561143e578081fd5b611447846113c7565b9250611455602085016113c7565b9150604084013590509250925092565b60008060408385031215611477578182fd5b611480836113c7565b946020939093013593505050565b600060208083850312156114a0578182fd5b823567ffffffffffffffff808211156114b7578384fd5b818501915085601f8301126114ca578384fd5b8135818111156114dc576114dc6116ce565b838102604051601f19603f83011681018181108582111715611500576115006116ce565b604052828152858101935084860182860187018a101561151e578788fd5b8795505b8386101561154757611533816113c7565b855260019590950194938601938601611522565b5098975050505050505050565b600060208284031215611565578081fd5b5035919050565b6000602080835283518082850152825b818110156115985785810183015185820160400152820161157c565b818111156115a95783604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60008219821115611607576116076116b8565b500190565b60008261162757634e487b7160e01b81526012600452602481fd5b500490565b6000816000190483118215151615611646576116466116b8565b500290565b60008282101561165d5761165d6116b8565b500390565b60028104600182168061167657607f821691505b6020821081141561169757634e487b7160e01b600052602260045260246000fd5b50919050565b60006000198214156116b1576116b16116b8565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052604160045260246000fdfea26469706673582212204bfe66bd04908e1863b74c153887ae3c45b81f7cd72ae7c0a090b7358e22b2bb64736f6c63430008020033

Deployed ByteCode Sourcemap

30848:4521:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12108:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;14275:169;;;;;;;;;;-1:-1:-1;14275:169:0;;;;;:::i;:::-;;:::i;:::-;;;3031:14:1;;3024:22;3006:41;;2994:2;2979:18;14275:169:0;2961:92:1;31491:43:0;;;;;;;;;;;;;;;;;;;9313:25:1;;;9301:2;9286:18;31491:43:0;9268:76:1;31574:28:0;;;;;;;;;;;;;;;;13228:108;;;;;;;;;;-1:-1:-1;13316:12:0;;13228:108;;14926:480;;;;;;;;;;-1:-1:-1;14926:480:0;;;;;:::i;:::-;;:::i;32322:92::-;;;;;;;;;;-1:-1:-1;32322:92:0;;32405:1;9491:36:1;;9479:2;9464:18;32322:92:0;9446:87:1;15815:215:0;;;;;;;;;;-1:-1:-1;15815:215:0;;;;;:::i;:::-;;:::i;33503:190::-;;;;;;;;;;-1:-1:-1;33503:190:0;;;;;:::i;:::-;;:::i;:::-;;22398:91;;;;;;;;;;-1:-1:-1;22398:91:0;;;;;:::i;:::-;;:::i;33262:111::-;;;;;;;;;;-1:-1:-1;33262:111:0;;;;;:::i;:::-;;:::i;31290:28::-;;;;;;;;;;-1:-1:-1;31290:28:0;;;;-1:-1:-1;;;;;31290:28:0;;;;;;-1:-1:-1;;;;;2822:32:1;;;2804:51;;2792:2;2777:18;31290:28:0;2759:102:1;31541:26:0;;;;;;;;;;;;;;;;31632:30;;;;;;;;;;;;;;;;31669:29;;;;;;;;;;;;;;;;13399:127;;;;;;;;;;-1:-1:-1;13399:127:0;;;;;:::i;:::-;;:::i;24734:94::-;;;;;;;;;;;;;:::i;22808:356::-;;;;;;;;;;-1:-1:-1;22808:356:0;;;;;:::i;:::-;;:::i;24083:87::-;;;;;;;;;;-1:-1:-1;24156:6:0;;-1:-1:-1;;;;;24156:6:0;24083:87;;12327:104;;;;;;;;;;;;;:::i;32427:269::-;;;;;;;;;;-1:-1:-1;32427:269:0;;;;;:::i;:::-;;:::i;16533:401::-;;;;;;;;;;-1:-1:-1;16533:401:0;;;;;:::i;:::-;;:::i;13739:175::-;;;;;;;;;;-1:-1:-1;13739:175:0;;;;;:::i;:::-;;:::i;31142:27::-;;;;;;;;;;-1:-1:-1;31142:27:0;;;;-1:-1:-1;;;;;31142:27:0;;;31458:26;;;;;;;;;;-1:-1:-1;31458:26:0;;;;;;;;31067:68;;;;;;;;;;-1:-1:-1;31067:68:0;;;;-1:-1:-1;;;;;31067:68:0;;;13977:151;;;;;;;;;;-1:-1:-1;13977:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;14093:18:0;;;14066:7;14093:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;13977:151;32704:154;;;;;;;;;;-1:-1:-1;32704:154:0;;;;;:::i;:::-;;:::i;31325:34::-;;;;;;;;;;-1:-1:-1;31325:34:0;;;;-1:-1:-1;;;;;31325:34:0;;;33381:110;;;;;;;;;;-1:-1:-1;33381:110:0;;;;;:::i;:::-;;:::i;24983:192::-;;;;;;;;;;-1:-1:-1;24983:192:0;;;;;:::i;:::-;;:::i;31368:58::-;;;;;;;;;;;;;;;;32968:272;;;;;;;;;;-1:-1:-1;32968:272:0;;;;;:::i;:::-;;:::i;12108:100::-;12162:13;12195:5;12188:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12108:100;:::o;14275:169::-;14358:4;14375:39;6712:10;14398:7;14407:6;14375:8;:39::i;:::-;-1:-1:-1;14432:4:0;14275:169;;;;:::o;14926:480::-;15066:4;15083:36;15093:6;15101:9;15112:6;15083:9;:36::i;:::-;-1:-1:-1;;;;;15159:19:0;;15132:24;15159:19;;;:11;:19;;;;;;;;6712:10;15159:33;;;;;;;;15211:26;;;;15203:79;;;;-1:-1:-1;;;15203:79:0;;6228:2:1;15203:79:0;;;6210:21:1;6267:2;6247:18;;;6240:30;6306:34;6286:18;;;6279:62;-1:-1:-1;;;6357:18:1;;;6350:38;6405:19;;15203:79:0;;;;;;;;;15310:57;15319:6;6712:10;15360:6;15341:16;:25;15310:8;:57::i;:::-;-1:-1:-1;15394:4:0;;14926:480;-1:-1:-1;;;;14926:480:0:o;15815:215::-;6712:10;15903:4;15952:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;15952:34:0;;;;;;;;;;15903:4;;15920:80;;15943:7;;15952:47;;15989:10;;15952:47;:::i;:::-;15920:8;:80::i;33503:190::-;24156:6;;-1:-1:-1;;;;;24156:6:0;6712:10;24303:23;24295:68;;;;-1:-1:-1;;;24295:68:0;;;;;;;:::i;:::-;33596:12:::1;::::0;33580:67:::1;::::0;-1:-1:-1;;;;;33596:12:0::1;33609::::0;33622:24:::1;33640:4;33622:9;:24::i;:::-;33580:15;:67::i;:::-;33658:12;:27:::0;;-1:-1:-1;;;;;;33658:27:0::1;-1:-1:-1::0;;;;;33658:27:0;;;::::1;::::0;;;::::1;::::0;;33503:190::o;22398:91::-;22454:27;6712:10;22474:6;22454:5;:27::i;:::-;22398:91;:::o;33262:111::-;24156:6;;-1:-1:-1;;;;;24156:6:0;6712:10;24303:23;24295:68;;;;-1:-1:-1;;;24295:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33331:27:0::1;;::::0;;;:18:::1;:27;::::0;;;;:34;;-1:-1:-1;;33331:34:0::1;33361:4;33331:34;::::0;;33262:111::o;13399:127::-;-1:-1:-1;;;;;13500:18:0;;13473:7;13500:18;;;;;;;;;;;13399:127;;;;:::o;24734:94::-;24156:6;;-1:-1:-1;;;;;24156:6:0;6712:10;24303:23;24295:68;;;;-1:-1:-1;;;24295:68:0;;;;;;;:::i;:::-;24799:21:::1;24817:1;24799:9;:21::i;:::-;24734:94::o:0;22808:356::-;22885:24;22912:32;22922:7;6712:10;22931:12;6632:98;22912:32;22885:59;;22983:6;22963:16;:26;;22955:75;;;;-1:-1:-1;;;22955:75:0;;6998:2:1;22955:75:0;;;6980:21:1;7037:2;7017:18;;;7010:30;7076:34;7056:18;;;7049:62;-1:-1:-1;;;7127:18:1;;;7120:34;7171:19;;22955:75:0;6970:226:1;22955:75:0;23058:58;23067:7;6712:10;23109:6;23090:16;:25;23058:8;:58::i;:::-;23134:22;23140:7;23149:6;23134:5;:22::i;:::-;22808:356;;;:::o;12327:104::-;12383:13;12416:7;12409:14;;;;;:::i;32427:269::-;24156:6;;-1:-1:-1;;;;;24156:6:0;6712:10;24303:23;24295:68;;;;-1:-1:-1;;;24295:68:0;;;;;;;:::i;:::-;32540:1:::1;32520:10;:17;:21;32512:30;;;::::0;::::1;;32560:13;32555:134;32587:10;:17;32579:5;:25;32555:134;;;32673:4;32630:12;:40;32651:10;32662:5;32651:17;;;;;;-1:-1:-1::0;;;32651:17:0::1;;;;;;;;;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;32630:40:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;32630:40:0;:47;;-1:-1:-1;;32630:47:0::1;::::0;::::1;;::::0;;;::::1;::::0;;32606:7;::::1;::::0;::::1;:::i;:::-;;;;32555:134;;;;32427:269:::0;:::o;16533:401::-;6712:10;16626:4;16670:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;16670:34:0;;;;;;;;;;16723:35;;;;16715:85;;;;-1:-1:-1;;;16715:85:0;;8963:2:1;16715:85:0;;;8945:21:1;9002:2;8982:18;;;8975:30;9041:34;9021:18;;;9014:62;-1:-1:-1;;;9092:18:1;;;9085:35;9137:19;;16715:85:0;8935:227:1;16715:85:0;16828:67;6712:10;16851:7;16879:15;16860:16;:34;16828:8;:67::i;:::-;-1:-1:-1;16922:4:0;;16533:401;-1:-1:-1;;;16533:401:0:o;13739:175::-;13825:4;13842:42;6712:10;13866:9;13877:6;13842:9;:42::i;32704:154::-;24156:6;;-1:-1:-1;;;;;24156:6:0;6712:10;24303:23;24295:68;;;;-1:-1:-1;;;24295:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;32785:22:0;::::1;;::::0;;;:12:::1;:22;::::0;;;;;::::1;;32784:23;32776:32;;;::::0;::::1;;-1:-1:-1::0;;;;;32821:22:0::1;;::::0;;;:12:::1;:22;::::0;;;;:29;;-1:-1:-1;;32821:29:0::1;32846:4;32821:29;::::0;;32704:154::o;33381:110::-;24156:6;;-1:-1:-1;;;;;24156:6:0;6712:10;24303:23;24295:68;;;;-1:-1:-1;;;24295:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33448:27:0::1;33478:5;33448:27:::0;;;:18:::1;:27;::::0;;;;:35;;-1:-1:-1;;33448:35:0::1;::::0;;33381:110::o;24983:192::-;24156:6;;-1:-1:-1;;;;;24156:6:0;6712:10;24303:23;24295:68;;;;-1:-1:-1;;;24295:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;25072:22:0;::::1;25064:73;;;::::0;-1:-1:-1;;;25064:73:0;;4675:2:1;25064:73:0::1;::::0;::::1;4657:21:1::0;4714:2;4694:18;;;4687:30;4753:34;4733:18;;;4726:62;-1:-1:-1;;;4804:18:1;;;4797:36;4850:19;;25064:73:0::1;4647:228:1::0;25064:73:0::1;25148:19;25158:8;25148:9;:19::i;32968:272::-:0;24156:6;;-1:-1:-1;;;;;24156:6:0;6712:10;24303:23;24295:68;;;;-1:-1:-1;;;24295:68:0;;;;;;;:::i;:::-;33048:1:::1;33039:6;:10;33031:41;;;::::0;-1:-1:-1;;;33031:41:0;;8616:2:1;33031:41:0::1;::::0;::::1;8598:21:1::0;8655:2;8635:18;;;8628:30;-1:-1:-1;;;8674:18:1;;;8667:48;8732:18;;33031:41:0::1;8588:168:1::0;33031:41:0::1;33092:14;::::0;::::1;;33091:15;33083:24;;;::::0;::::1;;33120:13;:22:::0;;;33185:15:::1;::::0;33167:33:::1;::::0;:15:::1;:33;:::i;:::-;33153:11;:47:::0;-1:-1:-1;33211:14:0::1;:21:::0;;-1:-1:-1;;33211:21:0::1;33228:4;33211:21;::::0;;32968:272::o;2605:98::-;2663:7;2690:5;2694:1;2690;:5;:::i;:::-;2683:12;2605:98;-1:-1:-1;;;2605:98:0:o;20181:380::-;-1:-1:-1;;;;;20317:19:0;;20309:68;;;;-1:-1:-1;;;20309:68:0;;8211:2:1;20309:68:0;;;8193:21:1;8250:2;8230:18;;;8223:30;8289:34;8269:18;;;8262:62;-1:-1:-1;;;8340:18:1;;;8333:34;8384:19;;20309:68:0;8183:226:1;20309:68:0;-1:-1:-1;;;;;20396:21:0;;20388:68;;;;-1:-1:-1;;;20388:68:0;;5082:2:1;20388:68:0;;;5064:21:1;5121:2;5101:18;;;5094:30;5160:34;5140:18;;;5133:62;-1:-1:-1;;;5211:18:1;;;5204:32;5253:19;;20388:68:0;5054:224:1;20388:68:0;-1:-1:-1;;;;;20469:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;20521:32;;9313:25:1;;;20521:32:0;;9286:18:1;20521:32:0;;;;;;;20181:380;;;:::o;33796:1495::-;-1:-1:-1;;;;;33955:20:0;;;;;;:12;:20;;;;;;;;:59;;;;;34001:13;;33992:6;:22;33955:59;:105;;;;;34045:15;34031:11;;:29;33955:105;33937:180;;;34087:18;;-1:-1:-1;;;34087:18:0;;5892:2:1;34087:18:0;;;5874:21:1;5931:1;5911:18;;;5904:29;-1:-1:-1;;;5949:18:1;;;5942:38;5997:18;;34087::0;5864:157:1;33937:180:0;34147:13;;-1:-1:-1;;;;;34134:26:0;;;34147:13;;34134:26;34131:1094;;;-1:-1:-1;;;;;34198:23:0;;34216:4;34198:23;;;;:70;;-1:-1:-1;;;;;;34242:26:0;;34263:4;34242:26;;34198:70;:118;;;;-1:-1:-1;;;;;;34290:26:0;;;;;;:18;:26;;;;;;;;34289:27;34198:118;34176:525;;;34351:12;34366:32;34394:3;34366:23;34377:11;;34366:6;:10;;:23;;;;:::i;:::-;:27;;:32::i;:::-;34440:12;;34351:47;;-1:-1:-1;34417:59:0;;34433:6;;-1:-1:-1;;;;;34440:12:0;34454:21;34471:3;34454:12;34351:47;34463:2;34454:8;:12::i;34417:59::-;34519:19;;34495:69;;34511:6;;-1:-1:-1;;;;;34519:19:0;34540:23;34558:4;34540:13;:4;34549:3;34540:8;:13::i;34495:69::-;34607:8;;34583:58;;34599:6;;-1:-1:-1;;;;;34607:8:0;34617:23;34635:4;34617:13;:4;34626:3;34617:8;:13::i;34583:58::-;34669:16;:6;34680:4;34669:10;:16::i;:::-;34660:25;;34176:525;;34131:1094;;;34730:13;;-1:-1:-1;;;;;34720:23:0;;;34730:13;;34720:23;34717:508;;;-1:-1:-1;;;;;34781:23:0;;34799:4;34781:23;;;;:70;;-1:-1:-1;;;;;;34825:26:0;;34846:4;34825:26;;34781:70;:118;;;;-1:-1:-1;;;;;;34873:26:0;;;;;;:18;:26;;;;;;;;34872:27;34781:118;34759:455;;;34934:12;34949:31;34976:3;34949:22;34960:10;;34949:6;:10;;:22;;;;:::i;:31::-;35022:12;;34934:46;;-1:-1:-1;34999:59:0;;35015:6;;-1:-1:-1;;;;;35022:12:0;35036:21;35053:3;35036:12;34934:46;35045:2;35036:8;:12::i;34999:59::-;35101:19;;35077:77;;35093:6;;-1:-1:-1;;;;;35101:19:0;35122:31;35131:21;35148:3;35131:12;:4;35140:2;35131:8;:12::i;:21::-;35122:4;;:8;:31::i;35077:77::-;35182:16;:6;35193:4;35182:10;:16::i;:::-;35173:25;;34759:455;;35241:42;35257:6;35265:9;35276:6;17424:721;-1:-1:-1;;;;;17564:20:0;;17556:70;;;;-1:-1:-1;;;17556:70:0;;7805:2:1;17556:70:0;;;7787:21:1;7844:2;7824:18;;;7817:30;7883:34;7863:18;;;7856:62;-1:-1:-1;;;7934:18:1;;;7927:35;7979:19;;17556:70:0;7777:227:1;17556:70:0;-1:-1:-1;;;;;17645:23:0;;17637:71;;;;-1:-1:-1;;;17637:71:0;;3868:2:1;17637:71:0;;;3850:21:1;3907:2;3887:18;;;3880:30;3946:34;3926:18;;;3919:62;-1:-1:-1;;;3997:18:1;;;3990:33;4040:19;;17637:71:0;3840:225:1;17637:71:0;-1:-1:-1;;;;;17805:17:0;;17781:21;17805:17;;;;;;;;;;;17841:23;;;;17833:74;;;;-1:-1:-1;;;17833:74:0;;5485:2:1;17833:74:0;;;5467:21:1;5524:2;5504:18;;;5497:30;5563:34;5543:18;;;5536:62;-1:-1:-1;;;5614:18:1;;;5607:36;5660:19;;17833:74:0;5457:228:1;17833:74:0;-1:-1:-1;;;;;17935:17:0;;;:9;:17;;;;;;;;;;;17955:22;;;17935:42;;17995:20;;;;;;;;:30;;17971:6;;17935:9;17995:30;;17971:6;;17995:30;:::i;:::-;;;;;;;;18060:9;-1:-1:-1;;;;;18043:35:0;18052:6;-1:-1:-1;;;;;18043:35:0;;18071:6;18043:35;;;;9313:25:1;;9301:2;9286:18;;9268:76;18043:35:0;;;;;;;;17424:721;;;;:::o;19164:579::-;-1:-1:-1;;;;;19248:21:0;;19240:67;;;;-1:-1:-1;;;19240:67:0;;7403:2:1;19240:67:0;;;7385:21:1;7442:2;7422:18;;;7415:30;7481:34;7461:18;;;7454:62;-1:-1:-1;;;7532:18:1;;;7525:31;7573:19;;19240:67:0;7375:223:1;19240:67:0;-1:-1:-1;;;;;19407:18:0;;19382:22;19407:18;;;;;;;;;;;19444:24;;;;19436:71;;;;-1:-1:-1;;;19436:71:0;;4272:2:1;19436:71:0;;;4254:21:1;4311:2;4291:18;;;4284:30;4350:34;4330:18;;;4323:62;-1:-1:-1;;;4401:18:1;;;4394:32;4443:19;;19436:71:0;4244:224:1;19436:71:0;-1:-1:-1;;;;;19535:18:0;;:9;:18;;;;;;;;;;19556:23;;;19535:44;;19597:12;:22;;19573:6;;19535:9;19597:22;;19573:6;;19597:22;:::i;:::-;;;;-1:-1:-1;;19637:37:0;;9313:25:1;;;19663:1:0;;-1:-1:-1;;;;;19637:37:0;;;;;9301:2:1;9286:18;19637:37:0;;;;;;;19687:48;22808:356;25183:173;25258:6;;;-1:-1:-1;;;;;25275:17:0;;;-1:-1:-1;;;;;;25275:17:0;;;;;;;25308:40;;25258:6;;;25275:17;25258:6;;25308:40;;25239:16;;25308:40;25183:173;;:::o;2922:98::-;2980:7;3007:5;3011:1;3007;:5;:::i;3281:98::-;3339:7;3366:5;3370:1;3366;:5;:::i;14:173:1:-;82:20;;-1:-1:-1;;;;;131:31:1;;121:42;;111:2;;177:1;174;167:12;192:196;;304:2;292:9;283:7;279:23;275:32;272:2;;;325:6;317;310:22;272:2;353:29;372:9;353:29;:::i;393:270::-;;;522:2;510:9;501:7;497:23;493:32;490:2;;;543:6;535;528:22;490:2;571:29;590:9;571:29;:::i;:::-;561:39;;619:38;653:2;642:9;638:18;619:38;:::i;:::-;609:48;;480:183;;;;;:::o;668:338::-;;;;814:2;802:9;793:7;789:23;785:32;782:2;;;835:6;827;820:22;782:2;863:29;882:9;863:29;:::i;:::-;853:39;;911:38;945:2;934:9;930:18;911:38;:::i;:::-;901:48;;996:2;985:9;981:18;968:32;958:42;;772:234;;;;;:::o;1011:264::-;;;1140:2;1128:9;1119:7;1115:23;1111:32;1108:2;;;1161:6;1153;1146:22;1108:2;1189:29;1208:9;1189:29;:::i;:::-;1179:39;1265:2;1250:18;;;;1237:32;;-1:-1:-1;;;1098:177:1:o;1280:1178::-;;1395:2;1438;1426:9;1417:7;1413:23;1409:32;1406:2;;;1459:6;1451;1444:22;1406:2;1504:9;1491:23;1533:18;1574:2;1566:6;1563:14;1560:2;;;1595:6;1587;1580:22;1560:2;1638:6;1627:9;1623:22;1613:32;;1683:7;1676:4;1672:2;1668:13;1664:27;1654:2;;1710:6;1702;1695:22;1654:2;1751;1738:16;1773:2;1769;1766:10;1763:2;;;1779:18;;:::i;:::-;1826:2;1822;1818:11;1858:2;1852:9;1921:2;1917:7;1912:2;1908;1904:11;1900:25;1892:6;1888:38;1976:6;1964:10;1961:22;1956:2;1944:10;1941:18;1938:46;1935:2;;;1987:18;;:::i;:::-;2023:2;2016:22;2073:18;;;2107:15;;;;-1:-1:-1;2142:11:1;;;2172;;;2168:20;;2165:33;-1:-1:-1;2162:2:1;;;2216:6;2208;2201:22;2162:2;2243:6;2234:15;;2258:169;2272:2;2269:1;2266:9;2258:169;;;2329:23;2348:3;2329:23;:::i;:::-;2317:36;;2290:1;2283:9;;;;;2373:12;;;;2405;;2258:169;;;-1:-1:-1;2446:6:1;1375:1083;-1:-1:-1;;;;;;;;1375:1083:1:o;2463:190::-;;2575:2;2563:9;2554:7;2550:23;2546:32;2543:2;;;2596:6;2588;2581:22;2543:2;-1:-1:-1;2624:23:1;;2533:120;-1:-1:-1;2533:120:1:o;3058:603::-;;3199:2;3228;3217:9;3210:21;3260:6;3254:13;3303:6;3298:2;3287:9;3283:18;3276:34;3328:4;3341:140;3355:6;3352:1;3349:13;3341:140;;;3450:14;;;3446:23;;3440:30;3416:17;;;3435:2;3412:26;3405:66;3370:10;;3341:140;;;3499:6;3496:1;3493:13;3490:2;;;3569:4;3564:2;3555:6;3544:9;3540:22;3536:31;3529:45;3490:2;-1:-1:-1;3645:2:1;3624:15;-1:-1:-1;;3620:29:1;3605:45;;;;3652:2;3601:54;;3179:482;-1:-1:-1;;;3179:482:1:o;6435:356::-;6637:2;6619:21;;;6656:18;;;6649:30;6715:34;6710:2;6695:18;;6688:62;6782:2;6767:18;;6609:182::o;9538:128::-;;9609:1;9605:6;9602:1;9599:13;9596:2;;;9615:18;;:::i;:::-;-1:-1:-1;9651:9:1;;9586:80::o;9671:217::-;;9737:1;9727:2;;-1:-1:-1;;;9762:31:1;;9816:4;9813:1;9806:15;9844:4;9769:1;9834:15;9727:2;-1:-1:-1;9873:9:1;;9717:171::o;9893:168::-;;9999:1;9995;9991:6;9987:14;9984:1;9981:21;9976:1;9969:9;9962:17;9958:45;9955:2;;;10006:18;;:::i;:::-;-1:-1:-1;10046:9:1;;9945:116::o;10066:125::-;;10134:1;10131;10128:8;10125:2;;;10139:18;;:::i;:::-;-1:-1:-1;10176:9:1;;10115:76::o;10196:380::-;10281:1;10271:12;;10328:1;10318:12;;;10339:2;;10393:4;10385:6;10381:17;10371:27;;10339:2;10446;10438:6;10435:14;10415:18;10412:38;10409:2;;;10492:10;10487:3;10483:20;10480:1;10473:31;10527:4;10524:1;10517:15;10555:4;10552:1;10545:15;10409:2;;10251:325;;;:::o;10581:135::-;;-1:-1:-1;;10641:17:1;;10638:2;;;10661:18;;:::i;:::-;-1:-1:-1;10708:1:1;10697:13;;10628:88::o;10721:127::-;10782:10;10777:3;10773:20;10770:1;10763:31;10813:4;10810:1;10803:15;10837:4;10834:1;10827:15;10853:127;10914:10;10909:3;10905:20;10902:1;10895:31;10945:4;10942:1;10935:15;10969:4;10966:1;10959:15

Swarm Source

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