Contract 0xad20482ff101633cd758b13ff6bec45398418dda 3

 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0x24765848a64f16b6ebc804cb6e46e7cef558bbe94ddedc5d8fe4fd972623da92Swap110625612021-09-19 22:46:156 days 17 hrs ago0xb9de3bbf582bb4d3661f12ad50790daeb680117a IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.005556345
0x23609dbc7ff04843e7eea79e5c6b731eb87b866ecf3d6649a6091e4a0634c3ccSwap110568822021-09-19 18:02:176 days 21 hrs ago0x2f7a5dd8e0a055f2491d00f3cc9a2b617ef80457 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.005556345
0x3cd444572acad2d141685cc8ac82d38a2277fb7dc6f567cef1d1be21a546fe6aSwap110388872021-09-19 2:48:307 days 13 hrs ago0x53fe1264c0b3190133479449b7770403bdf255e6 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.005631345
0x0238f55c463bdc2f4e6140ca09867bb2d50dc3369fc3f4a80458009b33079e6cSwap109965732021-09-17 15:27:219 days 30 mins ago0xc0bbf18e732d19ee1e7d7ae17eb433015e77d899 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.005631345
0xd9b0b568f9cc5fe27b1581304d41361407b70b17268099f39d5a98211ce4042fSwap109335532021-09-15 10:51:3411 days 5 hrs ago0xba4a749f5a9b9a835c20ca1f191e956e71a24ab7 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.005631405
0x73f8208248f80ed941ed0ec659c932f64c945e87f0121a623e25f10122084050Swap108980672021-09-14 5:08:2612 days 10 hrs ago0xea935890c69940566cc0ee76f2a88a7afc94e758 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.005706405
0x68bfe0ab5f376c9738ede6bfa7d244d4315a8e32f3fce0ecbbfce6addd4906e6Swap108810972021-09-13 14:59:2113 days 58 mins ago0xea935890c69940566cc0ee76f2a88a7afc94e758 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.004437015
0x0b31524b61ecafe190f107e7c2f116c6de361bc14e3cf84c20a125ad61929953Swap108462772021-09-12 9:54:2314 days 6 hrs ago0x5640524a27fa4b122c82b7a239212dd155f7b8b2 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.005556285
0x82a17e778e0b66a5982283c0a3e0594e211674334afef8ac973c75f6ee38d2c4Swap107982392021-09-10 17:32:1415 days 22 hrs ago0x45847dba305ea24fd0869efbeb28d30bdec53350 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.005556345
0x7b07f2ae2a9e9803041d797f184695f2f4b7574369072c32c674d6ada4c2afb7Swap107565602021-09-09 6:23:1217 days 9 hrs ago0x005bd3742b35c43a90a835bc5b07d6562c36f619 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.005631345
0x8c7095d1ad8c5a909a926c8263a3d74894a7340fd8ef580ec468090894c46e4bSwap107320772021-09-08 9:47:5618 days 6 hrs ago0x1bacd9b84287f02b0aabc68e3b4df1943efc6866 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.007268895
0xefbbfa3a83a36af010edb4b84d9ed1fdf2014903ffcdc88332c3f256d8e58c53Swap107106042021-09-07 15:36:0219 days 22 mins ago0x43cd550a148bb727b09d886b1fd635d392b43ed3 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.007418955
0x965a4594180e2b9e87e90b6c25db26ea27388b5fa1032bde2b3970d4b8a5f9d4Swap107099232021-09-07 14:56:3619 days 1 hr ago0x43cd550a148bb727b09d886b1fd635d392b43ed3 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.004437015
0x57e155cd270a2d2b64fd18d7cd5bb5247842c2073721eb7e23f3acc0a68ed0d0Swap105926622021-09-03 12:33:2523 days 3 hrs ago0x8bd3ceec5d32c92013eff90bd79854c3ba275426 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.007343955
0x4af1fad3a32a1ad2d29bea5cd430f7465ac956cedaafa8f77d80c2302da510c4Swap105466112021-09-01 21:43:5724 days 18 hrs ago0x415e6da1b71c55cea737d14ed07b42ad692b5b6e IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.007343895
0xe442c3d0b4d10f31de966ecaafc1a3afce6119e96397bbb73d741abce1fde709Swap105404552021-09-01 16:32:0724 days 23 hrs ago0x8dbea8c0573e1574e212a85776ca5f218e7cd7f9 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.00027514
0x092d619c355774e29bb177abfceb674797cc92a88423d5c31be2cd394b8d68a7Swap105395642021-09-01 15:47:2625 days 10 mins ago0x8dbea8c0573e1574e212a85776ca5f218e7cd7f9 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.00027514
0xcd3be8fe2330af193c1ccbfbae337f03fc9330bdcb1e023291ae3aae83829b09Swap105395382021-09-01 15:46:0825 days 12 mins ago0x8dbea8c0573e1574e212a85776ca5f218e7cd7f9 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.007418895
0x21b9356dbc16ceb83b062b78c7497e6c8d10d20f88aecf22f042d684f90220d5Swap105243702021-09-01 2:54:2325 days 13 hrs ago0xfea3214242a4f59928f8abd4e2ee83781486178e IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.007343955
0x09a95fc1cd7e2590d38cf8836db79b3c6dfb5fcc59752e904b36bfa4a2c9fdceSwap104899232021-08-30 21:43:0326 days 18 hrs ago0x10c2467002c48bb34453675061c796207e3e9b80 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.00027514
0x2b338ecb576b2c8b7a109c638466de147b6f020468f31e08d6a9960c73b400cbSwap104898772021-08-30 21:40:4526 days 18 hrs ago0x10c2467002c48bb34453675061c796207e3e9b80 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.00027514
0xe851475dca5584c99268191e06fbf8ed9c278ac9a8055b8cfe121bbd6286ee46Swap104300122021-08-28 19:22:1528 days 20 hrs ago0xe62431e531ffba9162e47902c4fb43f88ba45ff9 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.00027514
0x3260eb5b9e0e9e0fd999be0e6d1c70a6bb2b6726cada1143a0f18ef4cfb2112aSwap104256352021-08-28 15:38:3329 days 19 mins ago0xbd88f3b5112de984d10a121ce233bd59ac96339f IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.007343895
0xfdbf436206f6d84a6ea6cacf9060aebaa945a7c912ac44bf5c1334441b042ed5Swap103613612021-08-26 8:54:3731 days 7 hrs ago0x2ad683dcc8a89c469b15f2e0d13b792ad507ecb6 IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.00027514
0x8483c81415a717076d98a839b066f0eee80660175e4154ea4f548a5067f16cf9Swap103184442021-08-24 21:00:2232 days 18 hrs ago0x71284c9528f47cdbc565932b38fbf8895cf77f8a IN  0xad20482ff101633cd758b13ff6bec45398418dda0 BNB0.009467964
[ Download CSV Export 
Parent Txn Hash Block From To Value
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
ThoreumSwap

Compiler Version
v0.6.12+commit.27d51765

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

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

// Sources flattened with hardhat v2.3.0 https://hardhat.org

// File @openzeppelin/contracts/math/[email protected]

// SPDX-License-Identifier: MIT

pragma solidity >=0.6.0 <0.8.0;

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

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

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

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

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

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

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

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

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

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

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

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

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


// File @openzeppelin/contracts/utils/[email protected]



pragma solidity >=0.6.0 <0.8.0;

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

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


// File @openzeppelin/contracts/access/[email protected]



pragma solidity >=0.6.0 <0.8.0;

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

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

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

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

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

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

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


// File interfaces/IBEP20.sol



pragma solidity >=0.4.0;

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


// File @openzeppelin/contracts/utils/[email protected]



pragma solidity >=0.6.2 <0.8.0;

/**
 * @dev Collection of functions related to the address type
 */
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) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        // solhint-disable-next-line no-inline-assembly
        assembly { size := extcodesize(account) }
        return size > 0;
    }

    /**
     * @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");
        require(isContract(target), "Address: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{ value: value }(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
        return functionStaticCall(target, data, "Address: low-level static call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data, string memory errorMessage) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.staticcall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionDelegateCall(target, data, "Address: low-level delegate call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    function _verifyCallResult(bool success, bytes memory returndata, string memory errorMessage) private pure returns(bytes memory) {
        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);
            }
        }
    }
}


// File libraries/SafeBEP20.sol



pragma solidity ^0.6.0;



/**
 * @title SafeBEP20
 * @dev Wrappers around BEP20 operations that throw on failure (when the token
 * contract returns false). Tokens that return no value (and instead revert or
 * throw on failure) are also supported, non-reverting calls are assumed to be
 * successful.
 * To use this library you can add a `using SafeBEP20 for IBEP20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
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');
        }
    }
}


// File ThoreumSwap.sol



pragma solidity >=0.6.2;



contract ThoreumSwap is Ownable {
    using SafeMath for uint256;
    using SafeBEP20 for IBEP20;

    address  public token0;
    address  public token1;

    bool public isSwapStarted = false;

    //Will set to 910 when transferTaxRate = 9%
    uint256 public swapRate = 1000;

    //Will used to protect buyer when Farming Token set transferTaxRate > 0
    uint256 public MIN_SWAP_RATE = 910;
    uint256 public MAX_SWAP_RATE = 1000;

    address private _owner;

    event Swap(address indexed user, uint256 inAmount, uint256 outAmount);
    event AdminTokenRecovery(address tokenRecovered, uint256 amount);

    constructor(
        address payable _ownerAddress,
        address _presaleToken,
        address _officialToken
    ) public {
        token0 = _presaleToken;
        token1 = _officialToken;
        _owner = _ownerAddress;
    }

    function swap(uint256 inAmount) public {
        uint256 quota = IBEP20(token1).balanceOf(address(this));
        uint256 total = IBEP20(token0).balanceOf(msg.sender);
        uint256 outAmount = inAmount.mul(1000).div(swapRate);

        require(isSwapStarted == true, 'ThoreumSwap:: Swap not started.');
        require(inAmount <= total, "ThoreumSwap:: Insufficient fund.");
        require(outAmount <= quota, "ThoreumSwap:: Quota not enough.");

        IBEP20(token0).safeTransferFrom(msg.sender, address(this), inAmount);
        IBEP20(token1).safeTransfer(msg.sender, outAmount);

        emit Swap(msg.sender, inAmount, outAmount);
    }

    function startSwap() public onlyOwner returns (bool) {
        isSwapStarted = true;
        return true;
    }

    function stopSwap() public onlyOwner returns (bool) {
        isSwapStarted = false;
        return true;
    }

    function setSwapRate(uint256 newRate) public onlyOwner returns (bool) {
        require(newRate <= MAX_SWAP_RATE, 'ThoreumSwap:: MAX_SWAP_RATE 1000');
        require(newRate >= MIN_SWAP_RATE, 'ThoreumSwap:: MIN_SWAP_RATE 910');

        swapRate = newRate;
        return true;
    }

    function recoverWrongTokens(address _tokenAddress, uint256 _tokenAmount) external onlyOwner {
        IBEP20(_tokenAddress).safeTransfer(address(msg.sender), _tokenAmount);
        emit AdminTokenRecovery(_tokenAddress, _tokenAmount);
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address payable","name":"_ownerAddress","type":"address"},{"internalType":"address","name":"_presaleToken","type":"address"},{"internalType":"address","name":"_officialToken","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"tokenRecovered","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"AdminTokenRecovery","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":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"inAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"outAmount","type":"uint256"}],"name":"Swap","type":"event"},{"inputs":[],"name":"MAX_SWAP_RATE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MIN_SWAP_RATE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isSwapStarted","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_tokenAddress","type":"address"},{"internalType":"uint256","name":"_tokenAmount","type":"uint256"}],"name":"recoverWrongTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newRate","type":"uint256"}],"name":"setSwapRate","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startSwap","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"stopSwap","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"inAmount","type":"uint256"}],"name":"swap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapRate","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"token0","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"token1","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]

60806040526002805460ff60a01b191690556103e8600381905561038e60045560055534801561002e57600080fd5b50604051610fba380380610fba8339818101604052606081101561005157600080fd5b5080516020820151604090920151909190600061006c6100fb565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600180546001600160a01b039384166001600160a01b0319918216179091556002805492841692821692909217909155600680549390921692169190911790556100ff565b3390565b610eac8061010e6000396000f3fe608060405234801561001057600080fd5b50600436106100ea5760003560e01c8063b633b3641161008c578063d21220a711610066578063d21220a7146101bc578063dc1bc51d146101c4578063f2fde38b146101cc578063f4cde469146101f2576100ea565b8063b633b36414610190578063c992b5b2146101ac578063cfed802c146101b4576100ea565b8063698518e5116100c8578063698518e51461015b578063715018a6146101635780638da5cb5b1461016b57806394b918de14610173576100ea565b80630dfe1681146100ef578063159702ba146101135780633f138d4b1461012d575b600080fd5b6100f761020f565b604080516001600160a01b039092168252519081900360200190f35b61011b61021e565b60408051918252519081900360200190f35b6101596004803603604081101561014357600080fd5b506001600160a01b038135169060200135610224565b005b61011b6102e2565b6101596102e8565b6100f7610394565b6101596004803603602081101561018957600080fd5b50356103a3565b610198610635565b604080519115158252519081900360200190f35b6101986106ac565b61011b610729565b6100f761072f565b61019861073e565b610159600480360360208110156101e257600080fd5b50356001600160a01b031661074e565b6101986004803603602081101561020857600080fd5b5035610850565b6001546001600160a01b031681565b60045481565b61022c61096b565b6001600160a01b031661023d610394565b6001600160a01b031614610286576040805162461bcd60e51b81526020600482018190526024820152600080516020610e57833981519152604482015290519081900360640190fd5b61029a6001600160a01b038316338361096f565b604080516001600160a01b03841681526020810183905281517f74545154aac348a3eac92596bd1971957ca94795f4e954ec5f613b55fab78129929181900390910190a15050565b60035481565b6102f061096b565b6001600160a01b0316610301610394565b6001600160a01b03161461034a576040805162461bcd60e51b81526020600482018190526024820152600080516020610e57833981519152604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031690565b600254604080516370a0823160e01b815230600482015290516000926001600160a01b0316916370a08231916024808301926020929190829003018186803b1580156103ee57600080fd5b505afa158015610402573d6000803e3d6000fd5b505050506040513d602081101561041857600080fd5b5051600154604080516370a0823160e01b815233600482015290519293506000926001600160a01b03909216916370a0823191602480820192602092909190829003018186803b15801561046b57600080fd5b505afa15801561047f573d6000803e3d6000fd5b505050506040513d602081101561049557600080fd5b50516003549091506000906104b6906104b0866103e86109c6565b90610a28565b600254909150600160a01b900460ff16151560011461051c576040805162461bcd60e51b815260206004820152601f60248201527f54686f7265756d537761703a3a2053776170206e6f7420737461727465642e00604482015290519081900360640190fd5b81841115610571576040805162461bcd60e51b815260206004820181905260248201527f54686f7265756d537761703a3a20496e73756666696369656e742066756e642e604482015290519081900360640190fd5b828111156105c6576040805162461bcd60e51b815260206004820152601f60248201527f54686f7265756d537761703a3a2051756f7461206e6f7420656e6f7567682e00604482015290519081900360640190fd5b6001546105de906001600160a01b0316333087610a8f565b6002546105f5906001600160a01b0316338361096f565b6040805185815260208101839052815133927f77f92a1b6a1a11de8ca49515ad4c1fad45632dd3442167d74b90b304a3c7a758928290030190a250505050565b600061063f61096b565b6001600160a01b0316610650610394565b6001600160a01b031614610699576040805162461bcd60e51b81526020600482018190526024820152600080516020610e57833981519152604482015290519081900360640190fd5b506002805460ff60a01b19169055600190565b60006106b661096b565b6001600160a01b03166106c7610394565b6001600160a01b031614610710576040805162461bcd60e51b81526020600482018190526024820152600080516020610e57833981519152604482015290519081900360640190fd5b506002805460ff60a01b1916600160a01b179055600190565b60055481565b6002546001600160a01b031681565b600254600160a01b900460ff1681565b61075661096b565b6001600160a01b0316610767610394565b6001600160a01b0316146107b0576040805162461bcd60e51b81526020600482018190526024820152600080516020610e57833981519152604482015290519081900360640190fd5b6001600160a01b0381166107f55760405162461bcd60e51b8152600401808060200182810382526026815260200180610dea6026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b600061085a61096b565b6001600160a01b031661086b610394565b6001600160a01b0316146108b4576040805162461bcd60e51b81526020600482018190526024820152600080516020610e57833981519152604482015290519081900360640190fd5b60055482111561090b576040805162461bcd60e51b815260206004820181905260248201527f54686f7265756d537761703a3a204d41585f535741505f524154452031303030604482015290519081900360640190fd5b600454821015610962576040805162461bcd60e51b815260206004820152601f60248201527f54686f7265756d537761703a3a204d494e5f535741505f524154452039313000604482015290519081900360640190fd5b50600355600190565b3390565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b1790526109c1908490610aef565b505050565b6000826109d557506000610a22565b828202828482816109e257fe5b0414610a1f5760405162461bcd60e51b8152600401808060200182810382526021815260200180610e366021913960400191505060405180910390fd5b90505b92915050565b6000808211610a7e576040805162461bcd60e51b815260206004820152601a60248201527f536166654d6174683a206469766973696f6e206279207a65726f000000000000604482015290519081900360640190fd5b818381610a8757fe5b049392505050565b604080516001600160a01b0380861660248301528416604482015260648082018490528251808303909101815260849091019091526020810180516001600160e01b03166323b872dd60e01b179052610ae9908590610aef565b50505050565b6060610b44826040518060400160405280602081526020017f5361666542455032303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b0316610ba09092919063ffffffff16565b8051909150156109c157808060200190516020811015610b6357600080fd5b50516109c15760405162461bcd60e51b815260040180806020018281038252602a815260200180610dc0602a913960400191505060405180910390fd5b6060610baf8484600085610bb9565b90505b9392505050565b606082471015610bfa5760405162461bcd60e51b8152600401808060200182810382526026815260200180610e106026913960400191505060405180910390fd5b610c0385610d15565b610c54576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b60208310610c935780518252601f199092019160209182019101610c74565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114610cf5576040519150601f19603f3d011682016040523d82523d6000602084013e610cfa565b606091505b5091509150610d0a828286610d1b565b979650505050505050565b3b151590565b60608315610d2a575081610bb2565b825115610d3a5782518084602001fd5b8160405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015610d84578181015183820152602001610d6c565b50505050905090810190601f168015610db15780820380516001836020036101000a031916815260200191505b509250505060405180910390fdfe5361666542455032303a204245503230206f7065726174696f6e20646964206e6f7420737563636565644f776e61626c653a206e6577206f776e657220697320746865207a65726f2061646472657373416464726573733a20696e73756666696369656e742062616c616e636520666f722063616c6c536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572a2646970667358221220cb894bfed0d81ae21adef024262fadfcd0bd7c2022152b85756b24462150952064736f6c634300060c00330000000000000000000000006a963573b9a7aaef9cb9eee747e1b6b2c21b0520000000000000000000000000bb43322fd340891c8a880660fefeff2b9b477ef8000000000000000000000000580de58c1bd593a43dadcf0a739d504621817c05

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

0000000000000000000000006a963573b9a7aaef9cb9eee747e1b6b2c21b0520000000000000000000000000bb43322fd340891c8a880660fefeff2b9b477ef8000000000000000000000000580de58c1bd593a43dadcf0a739d504621817c05

-----Decoded View---------------
Arg [0] : _ownerAddress (address): 0x6a963573b9a7aaef9cb9eee747e1b6b2c21b0520
Arg [1] : _presaleToken (address): 0xbb43322fd340891c8a880660fefeff2b9b477ef8
Arg [2] : _officialToken (address): 0x580de58c1bd593a43dadcf0a739d504621817c05

-----Encoded View---------------
3 Constructor Arguments found :
Arg [0] : 0000000000000000000000006a963573b9a7aaef9cb9eee747e1b6b2c21b0520
Arg [1] : 000000000000000000000000bb43322fd340891c8a880660fefeff2b9b477ef8
Arg [2] : 000000000000000000000000580de58c1bd593a43dadcf0a739d504621817c05


Deployed ByteCode Sourcemap

26156:2342:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26263:22;;;:::i;:::-;;;;-1:-1:-1;;;;;26263:22:0;;;;;;;;;;;;;;26530:34;;;:::i;:::-;;;;;;;;;;;;;;;;28252:243;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;28252:243:0;;;;;;;;:::i;:::-;;26414:30;;;:::i;10333:148::-;;;:::i;9682:87::-;;;:::i;27042:660::-;;;;;;;;;;;;;;;;-1:-1:-1;27042:660:0;;:::i;27832:114::-;;;:::i;:::-;;;;;;;;;;;;;;;;;;27710;;;:::i;26571:35::-;;;:::i;26292:22::-;;;:::i;26323:33::-;;;:::i;10636:244::-;;;;;;;;;;;;;;;;-1:-1:-1;10636:244:0;-1:-1:-1;;;;;10636:244:0;;:::i;27954:290::-;;;;;;;;;;;;;;;;-1:-1:-1;27954:290:0;;:::i;26263:22::-;;;-1:-1:-1;;;;;26263:22:0;;:::o;26530:34::-;;;;:::o;28252:243::-;9913:12;:10;:12::i;:::-;-1:-1:-1;;;;;9902:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;9902:23:0;;9894:68;;;;;-1:-1:-1;;;9894:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9894:68:0;;;;;;;;;;;;;;;28355:69:::1;-1:-1:-1::0;;;;;28355:34:0;::::1;28398:10;28411:12:::0;28355:34:::1;:69::i;:::-;28440:47;::::0;;-1:-1:-1;;;;;28440:47:0;::::1;::::0;;::::1;::::0;::::1;::::0;;;;;::::1;::::0;;;;;;;;;::::1;28252:243:::0;;:::o;26414:30::-;;;;:::o;10333:148::-;9913:12;:10;:12::i;:::-;-1:-1:-1;;;;;9902:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;9902:23:0;;9894:68;;;;;-1:-1:-1;;;9894:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9894:68:0;;;;;;;;;;;;;;;10440:1:::1;10424:6:::0;;10403:40:::1;::::0;-1:-1:-1;;;;;10424:6:0;;::::1;::::0;10403:40:::1;::::0;10440:1;;10403:40:::1;10471:1;10454:19:::0;;-1:-1:-1;;;;;;10454:19:0::1;::::0;;10333:148::o;9682:87::-;9728:7;9755:6;-1:-1:-1;;;;;9755:6:0;9682:87;:::o;27042:660::-;27115:6;;27108:39;;;-1:-1:-1;;;27108:39:0;;27141:4;27108:39;;;;;;27092:13;;-1:-1:-1;;;;;27115:6:0;;27108:24;;:39;;;;;;;;;;;;;;27115:6;27108:39;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;27108:39:0;27181:6;;27174:36;;;-1:-1:-1;;;27174:36:0;;27199:10;27174:36;;;;;;27108:39;;-1:-1:-1;27158:13:0;;-1:-1:-1;;;;;27181:6:0;;;;27174:24;;:36;;;;;27108:39;;27174:36;;;;;;;;27181:6;27174:36;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;27174:36:0;27264:8;;27174:36;;-1:-1:-1;27221:17:0;;27241:32;;:18;:8;27254:4;27241:12;:18::i;:::-;:22;;:32::i;:::-;27294:13;;27221:52;;-1:-1:-1;;;;27294:13:0;;;;:21;;27311:4;27294:21;27286:65;;;;;-1:-1:-1;;;27286:65:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;27382:5;27370:8;:17;;27362:62;;;;;-1:-1:-1;;;27362:62:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27456:5;27443:9;:18;;27435:62;;;;;-1:-1:-1;;;27435:62:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;27517:6;;27510:68;;-1:-1:-1;;;;;27517:6:0;27542:10;27562:4;27569:8;27510:31;:68::i;:::-;27596:6;;27589:50;;-1:-1:-1;;;;;27596:6:0;27617:10;27629:9;27589:27;:50::i;:::-;27657:37;;;;;;;;;;;;;;27662:10;;27657:37;;;;;;;;27042:660;;;;:::o;27832:114::-;27878:4;9913:12;:10;:12::i;:::-;-1:-1:-1;;;;;9902:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;9902:23:0;;9894:68;;;;;-1:-1:-1;;;9894:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9894:68:0;;;;;;;;;;;;;;;-1:-1:-1;27895:13:0::1;:21:::0;;-1:-1:-1;;;;27895:21:0::1;::::0;;;27832:114;:::o;27710:::-;27757:4;9913:12;:10;:12::i;:::-;-1:-1:-1;;;;;9902:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;9902:23:0;;9894:68;;;;;-1:-1:-1;;;9894:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9894:68:0;;;;;;;;;;;;;;;-1:-1:-1;27774:13:0::1;:20:::0;;-1:-1:-1;;;;27774:20:0::1;-1:-1:-1::0;;;27774:20:0::1;::::0;;27790:4:::1;27710:114:::0;:::o;26571:35::-;;;;:::o;26292:22::-;;;-1:-1:-1;;;;;26292:22:0;;:::o;26323:33::-;;;-1:-1:-1;;;26323:33:0;;;;;:::o;10636:244::-;9913:12;:10;:12::i;:::-;-1:-1:-1;;;;;9902:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;9902:23:0;;9894:68;;;;;-1:-1:-1;;;9894:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9894:68:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;10725:22:0;::::1;10717:73;;;;-1:-1:-1::0;;;10717:73:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10827:6;::::0;;10806:38:::1;::::0;-1:-1:-1;;;;;10806:38:0;;::::1;::::0;10827:6;::::1;::::0;10806:38:::1;::::0;::::1;10855:6;:17:::0;;-1:-1:-1;;;;;;10855:17:0::1;-1:-1:-1::0;;;;;10855:17:0;;;::::1;::::0;;;::::1;::::0;;10636:244::o;27954:290::-;28018:4;9913:12;:10;:12::i;:::-;-1:-1:-1;;;;;9902:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;9902:23:0;;9894:68;;;;;-1:-1:-1;;;9894:68:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;9894:68:0;;;;;;;;;;;;;;;28054:13:::1;;28043:7;:24;;28035:69;;;::::0;;-1:-1:-1;;;28035:69:0;;::::1;;::::0;::::1;::::0;;;;;;;::::1;::::0;;;;;;;;;;;;;::::1;;28134:13;;28123:7;:24;;28115:68;;;::::0;;-1:-1:-1;;;28115:68:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;::::1;::::0;;;;;;;;;;;;;::::1;;-1:-1:-1::0;28196:8:0::1;:18:::0;28232:4:::1;::::0;27954:290::o;8209:106::-;8297:10;8209:106;:::o;22775:211::-;22919:58;;;-1:-1:-1;;;;;22919:58:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;22919:58:0;-1:-1:-1;;;22919:58:0;;;22892:86;;22912:5;;22892:19;:86::i;:::-;22775:211;;;:::o;3777:220::-;3835:7;3859:6;3855:20;;-1:-1:-1;3874:1:0;3867:8;;3855:20;3898:5;;;3902:1;3898;:5;:1;3922:5;;;;;:10;3914:56;;;;-1:-1:-1;;;3914:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3988:1;-1:-1:-1;3777:220:0;;;;;:::o;4475:153::-;4533:7;4565:1;4561;:5;4553:44;;;;;-1:-1:-1;;;4553:44:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;4619:1;4615;:5;;;;;;;4475:153;-1:-1:-1;;;4475:153:0:o;22994:248::-;23165:68;;;-1:-1:-1;;;;;23165:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;23165:68:0;-1:-1:-1;;;23165:68:0;;;23138:96;;23158:5;;23138:19;:96::i;:::-;22994:248;;;;:::o;25310:774::-;25734:23;25760:69;25788:4;25760:69;;;;;;;;;;;;;;;;;25768:5;-1:-1:-1;;;;;25760:27:0;;;:69;;;;;:::i;:::-;25844:17;;25734:95;;-1:-1:-1;25844:21:0;25840:237;;25999:10;25988:30;;;;;;;;;;;;;;;-1:-1:-1;25988:30:0;25980:85;;;;-1:-1:-1;;;25980:85:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17803:195;17906:12;17938:52;17960:6;17968:4;17974:1;17977:12;17938:21;:52::i;:::-;17931:59;;17803:195;;;;;;:::o;18855:530::-;18982:12;19040:5;19015:21;:30;;19007:81;;;;-1:-1:-1;;;19007:81:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;19107:18;19118:6;19107:10;:18::i;:::-;19099:60;;;;;-1:-1:-1;;;19099:60:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;19233:12;19247:23;19274:6;-1:-1:-1;;;;;19274:11:0;19294:5;19302:4;19274:33;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;19274:33:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;19232:75;;;;19325:52;19343:7;19352:10;19364:12;19325:17;:52::i;:::-;19318:59;18855:530;-1:-1:-1;;;;;;;18855:530:0:o;14885:422::-;15252:20;15291:8;;;14885:422::o;21395:742::-;21510:12;21539:7;21535:595;;;-1:-1:-1;21570:10:0;21563:17;;21535:595;21684:17;;:21;21680:439;;21947:10;21941:17;22008:15;21995:10;21991:2;21987:19;21980:44;21895:148;22090:12;22083:20;;-1:-1:-1;;;22083:20:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

Swarm Source

ipfs://cb894bfed0d81ae21adef024262fadfcd0bd7c2022152b85756b244621509520
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.