Sonic Blaze Testnet
    /

    Contract

    0xf565ca2cefbC8264B608505c342eC3c491887Bb8

    Overview

    S Balance

    Sonic Blaze LogoSonic Blaze LogoSonic Blaze Logo0 S

    Token Holdings

    Multichain Info

    No addresses found
    Transaction Hash
    Method
    Block
    Age
    From
    To

    There are no matching entries

    1 Internal Transaction and 1 Token Transfer found.

    Latest 1 internal transaction

    Parent Transaction Hash Block Age From To Amount
    50539002024-12-18 11:56:427 days ago1734523002
     Contract Creation
    0 S
    Loading...
    Loading

    Similar Match Source Code
    This contract matches the deployed Bytecode of the Source Code for Contract 0x8594Dc32...F76f657bc
    The constructor portion of the code might be different and could alter the actual behaviour of the contract

    Contract Name:
    MoonshotToken

    Compiler Version
    v0.8.23+commit.f704f362

    Optimization Enabled:
    Yes with 200 runs

    Other Settings:
    paris EvmVersion

    Contract Source Code (Solidity Standard Json-Input format)

    File 1 of 11 : MoonshotToken.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: UNLICENSED
    pragma solidity ^0.8.23;
    import {ERC20} from "@openzeppelin/contracts/token/ERC20/ERC20.sol";
    import {IERC20} from "@openzeppelin/contracts/token/ERC20/IERC20.sol";
    import {ReentrancyGuard} from "@openzeppelin/contracts/utils/ReentrancyGuard.sol";
    import {ERC20Burnable} from "@openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol";
    import {IRouter02} from "./interfaces/IRouter02.sol";
    import {IBaseV1Factory} from "./interfaces/IBaseV1Factory.sol";
    import {IMoonshotToken} from "./interfaces/IMoonshotToken.sol";
    contract MoonshotToken is ERC20Burnable, IMoonshotToken, ReentrancyGuard {
    CurveType public constant curveType = CurveType.ConstantProductV1;
    uint256 public initalTokenSupply;
    uint256 public virtualTokenReserves;
    uint256 public virtualCollateralReserves;
    uint256 public immutable virtualCollateralReservesInitial;
    uint256 public immutable feeBPS;
    uint256 public immutable dexFeeBPS;
    uint256 public immutable mcLowerLimit;
    uint256 public immutable mcUpperLimit;
    uint256 public immutable tokensMigrationThreshold;
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 2 of 11 : draft-IERC6093.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.0.0) (interfaces/draft-IERC6093.sol)
    pragma solidity ^0.8.20;
    /**
    * @dev Standard ERC20 Errors
    * Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC20 tokens.
    */
    interface IERC20Errors {
    /**
    * @dev Indicates an error related to the current `balance` of a `sender`. Used in transfers.
    * @param sender Address whose tokens are being transferred.
    * @param balance Current balance for the interacting account.
    * @param needed Minimum amount required to perform a transfer.
    */
    error ERC20InsufficientBalance(address sender, uint256 balance, uint256 needed);
    /**
    * @dev Indicates a failure with the token `sender`. Used in transfers.
    * @param sender Address whose tokens are being transferred.
    */
    error ERC20InvalidSender(address sender);
    /**
    * @dev Indicates a failure with the token `receiver`. Used in transfers.
    * @param receiver Address to which tokens are being transferred.
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 3 of 11 : ERC20.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/ERC20.sol)
    pragma solidity ^0.8.20;
    import {IERC20} from "./IERC20.sol";
    import {IERC20Metadata} from "./extensions/IERC20Metadata.sol";
    import {Context} from "../../utils/Context.sol";
    import {IERC20Errors} from "../../interfaces/draft-IERC6093.sol";
    /**
    * @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}.
    *
    * TIP: For a detailed writeup see our guide
    * https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How
    * to implement supply mechanisms].
    *
    * The default value of {decimals} is 18. To change this, you should override
    * this function so it returns a different value.
    *
    * We have followed general OpenZeppelin Contracts guidelines: functions revert
    * instead returning `false` on failure. This behavior is nonetheless
    * conventional and does not conflict with the expectations of ERC20
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 4 of 11 : ERC20Burnable.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/extensions/ERC20Burnable.sol)
    pragma solidity ^0.8.20;
    import {ERC20} from "../ERC20.sol";
    import {Context} from "../../../utils/Context.sol";
    /**
    * @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 a `value` amount of tokens from the caller.
    *
    * See {ERC20-_burn}.
    */
    function burn(uint256 value) public virtual {
    _burn(_msgSender(), value);
    }
    /**
    * @dev Destroys a `value` amount of tokens from `account`, deducting from
    * the caller's allowance.
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 5 of 11 : IERC20Metadata.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/extensions/IERC20Metadata.sol)
    pragma solidity ^0.8.20;
    import {IERC20} from "../IERC20.sol";
    /**
    * @dev Interface for the optional metadata functions from the ERC20 standard.
    */
    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);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 6 of 11 : IERC20.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/IERC20.sol)
    pragma solidity ^0.8.20;
    /**
    * @dev Interface of the ERC20 standard as defined in the EIP.
    */
    interface IERC20 {
    /**
    * @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 Returns the value of tokens in existence.
    */
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 7 of 11 : Context.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.0.1) (utils/Context.sol)
    pragma solidity ^0.8.20;
    /**
    * @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;
    }
    function _contextSuffixLength() internal view virtual returns (uint256) {
    return 0;
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 8 of 11 : ReentrancyGuard.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.0.0) (utils/ReentrancyGuard.sol)
    pragma solidity ^0.8.20;
    /**
    * @dev Contract module that helps prevent reentrant calls to a function.
    *
    * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier
    * available, which can be applied to functions to make sure there are no nested
    * (reentrant) calls to them.
    *
    * Note that because there is a single `nonReentrant` guard, functions marked as
    * `nonReentrant` may not call one another. This can be worked around by making
    * those functions `private`, and then adding `external` `nonReentrant` entry
    * points to them.
    *
    * TIP: If you would like to learn more about reentrancy and alternative ways
    * to protect against it, check out our blog post
    * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].
    */
    abstract contract ReentrancyGuard {
    // Booleans are more expensive than uint256 or any type that takes up a full
    // word because each write operation emits an extra SLOAD to first read the
    // slot's contents, replace the bits taken up by the boolean, and then write
    // back. This is the compiler's defense against contract upgrades and
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 9 of 11 : IBaseV1Factory.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    // SPDX-License-Identifier: UNLICENSED
    pragma solidity ^0.8.23;
    interface IBaseV1Factory {
    function allPairsLength() external view returns (uint);
    function isPair(address pair) external view returns (bool);
    function pairCodeHash() external pure returns (bytes32);
    function getPair(address tokenA, address token, bool stable) external view returns (address);
    function createPair(address tokenA, address tokenB, bool stable) external returns (address pair);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 10 of 11 : IMoonshotToken.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: UNLICENSED
    pragma solidity ^0.8.23;
    import {IERC20} from "@openzeppelin/contracts/token/ERC20/IERC20.sol";
    interface IMoonshotToken is IERC20 {
    enum CurveType {
    ConstantProductV1
    }
    struct ConstructorParams {
    string name;
    string symbol;
    address creator;
    uint256 totalSupply;
    uint256 virtualTokenReserves;
    uint256 virtualCollateralReserves;
    uint256 feeBasisPoints;
    uint256 dexFeeBasisPoints;
    uint256 migrationFeeFixed;
    uint256 poolCreationFee;
    uint256 mcLowerLimit;
    uint256 mcUpperLimit;
    uint256 tokensMigrationThreshold;
    address treasury;
    address solidlyRouter;
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 11 of 11 : IRouter02.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    pragma solidity ^0.8.23;
    interface IRouter02 {
    struct Route {
    address from;
    address to;
    bool stable;
    }
    function factory() external view returns (address);
    function weth() external view returns (address);
    function pairFor(address tokenA, address tokenB, bool stable) external view returns (address pair);
    function getReserves(
    address tokenA,
    address tokenB,
    bool stable
    ) external view returns (uint reserveA, uint reserveB);
    function getAmountOut(
    uint amountIn,
    address tokenIn,
    address tokenOut
    ) external view returns (uint amount, bool stable);
    function getAmountOut(
    uint amountIn,
    address tokenIn,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Settings
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    {
    "optimizer": {
    "enabled": true,
    "runs": 200
    },
    "viaIR": true,
    "evmVersion": "paris",
    "outputSelection": {
    "*": {
    "*": [
    "evm.bytecode",
    "evm.deployedBytecode",
    "devdoc",
    "userdoc",
    "metadata",
    "abi"
    ]
    }
    },
    "metadata": {
    "useLiteralContent": true
    },
    "libraries": {}
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Contract ABI

    [{"inputs":[{"components":[{"internalType":"string","name":"name","type":"string"},{"internalType":"string","name":"symbol","type":"string"},{"internalType":"address","name":"creator","type":"address"},{"internalType":"uint256","name":"totalSupply","type":"uint256"},{"internalType":"uint256","name":"virtualTokenReserves","type":"uint256"},{"internalType":"uint256","name":"virtualCollateralReserves","type":"uint256"},{"internalType":"uint256","name":"feeBasisPoints","type":"uint256"},{"internalType":"uint256","name":"dexFeeBasisPoints","type":"uint256"},{"internalType":"uint256","name":"migrationFeeFixed","type":"uint256"},{"internalType":"uint256","name":"poolCreationFee","type":"uint256"},{"internalType":"uint256","name":"mcLowerLimit","type":"uint256"},{"internalType":"uint256","name":"mcUpperLimit","type":"uint256"},{"internalType":"uint256","name":"tokensMigrationThreshold","type":"uint256"},{"internalType":"address","name":"treasury","type":"address"},{"internalType":"address","name":"solidlyRouter","type":"address"},{"internalType":"address","name":"dexTreasury","type":"address"}],"internalType":"struct IMoonshotToken.ConstructorParams","name":"_params","type":"tuple"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"allowance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientAllowance","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"uint256","name":"balance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientBalance","type":"error"},{"inputs":[{"internalType":"address","name":"approver","type":"address"}],"name":"ERC20InvalidApprover","type":"error"},{"inputs":[{"internalType":"address","name":"receiver","type":"address"}],"name":"ERC20InvalidReceiver","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"}],"name":"ERC20InvalidSender","type":"error"},{"inputs":[{"internalType":"address","name":"spender","type":"address"}],"name":"ERC20InvalidSpender","type":"error"},{"inputs":[],"name":"FailedToSendETH","type":"error"},{"inputs":[],"name":"InsufficientTokenReserves","type":"error"},{"inputs":[],"name":"MarketcapThresholdReached","type":"error"},{"inputs":[],"name":"NotEnoughETHReserves","type":"error"},{"inputs":[],"name":"NotEnoughtETHToBuyTokens","type":"error"},{"inputs":[],"name":"OnlyFactory","type":"error"},{"inputs":[],"name":"PairNotCreated","type":"error"},{"inputs":[],"name":"ReentrancyGuardReentrantCall","type":"error"},{"inputs":[],"name":"SendingToPairIsNotAllowedBeforeMigration","type":"error"},{"inputs":[],"name":"SlippageCheckFailed","type":"error"},{"inputs":[],"name":"TradingStopped","type":"error"},{"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":"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":"MAX_BPS","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","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":"value","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"burnFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amountOutMin","type":"uint256"}],"name":"buyExactIn","outputs":[{"internalType":"uint256","name":"collateralToPayWithFee","type":"uint256"},{"internalType":"uint256","name":"helioFee","type":"uint256"},{"internalType":"uint256","name":"dexFee","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenAmount","type":"uint256"},{"internalType":"uint256","name":"_maxCollateralAmount","type":"uint256"}],"name":"buyExactOut","outputs":[{"internalType":"uint256","name":"collateralToPayWithFee","type":"uint256"},{"internalType":"uint256","name":"helioFee","type":"uint256"},{"internalType":"uint256","name":"dexFee","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"creator","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"curveType","outputs":[{"internalType":"enum IMoonshotToken.CurveType","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"dexFeeBPS","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"dexTreasury","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"factory","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feeBPS","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"fixedMigrationFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amountOut","type":"uint256"},{"internalType":"uint256","name":"_reserveIn","type":"uint256"},{"internalType":"uint256","name":"_reserveOut","type":"uint256"},{"internalType":"bool","name":"_paymentTokenIsOut","type":"bool"}],"name":"getAmountInAndFee","outputs":[{"internalType":"uint256","name":"amountIn","type":"uint256"},{"internalType":"uint256","name":"fee","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amountIn","type":"uint256"},{"internalType":"uint256","name":"_reserveIn","type":"uint256"},{"internalType":"uint256","name":"_reserveOut","type":"uint256"},{"internalType":"bool","name":"_paymentTokenIsIn","type":"bool"}],"name":"getAmountOutAndFee","outputs":[{"internalType":"uint256","name":"amountOut","type":"uint256"},{"internalType":"uint256","name":"fee","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getCurveProgressBps","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getMarketCap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"initalTokenSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"mcLowerLimit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"mcUpperLimit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"migrate","outputs":[{"internalType":"uint256","name":"tokensToMigrate","type":"uint256"},{"internalType":"uint256","name":"tokensToBurn","type":"uint256"},{"internalType":"uint256","name":"collateralAmount","type":"uint256"},{"internalType":"address","name":"pair","type":"address"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"poolCreationFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenAmount","type":"uint256"},{"internalType":"uint256","name":"_amountCollateralMin","type":"uint256"}],"name":"sellExactIn","outputs":[{"internalType":"uint256","name":"collateralToReceiveMinusFee","type":"uint256"},{"internalType":"uint256","name":"helioFee","type":"uint256"},{"internalType":"uint256","name":"dexFee","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenAmountMax","type":"uint256"},{"internalType":"uint256","name":"_amountCollateral","type":"uint256"}],"name":"sellExactOut","outputs":[{"internalType":"uint256","name":"collateralToReceiveMinusFee","type":"uint256"},{"internalType":"uint256","name":"tokensOut","type":"uint256"},{"internalType":"uint256","name":"helioFee","type":"uint256"},{"internalType":"uint256","name":"dexFee","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"sendingToPairNotAllowed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"solidlyRouter","outputs":[{"internalType":"contract IRouter02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensMigrationThreshold","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingStopped","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"treasury","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"virtualCollateralReserves","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"virtualCollateralReservesInitial","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"virtualTokenReserves","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"}]

    Deployed Bytecode

    0x608060408181526004918236101561001657600080fd5b600092833560e01c91826302d05d3f146119575750816306fdde0314611860578163095ea7b3146117b6578163152044811461176d5781631655bc621461174e57816318160ddd1461172f5781631a1c6e53146116f45781632368da321461164457816323b872dd1461151a57816325e17b5714611399578163313ce5671461137d57816342966c681461135f57816349a30246146112eb5781634c7766b5146112b05781634fb3fbe71461114c57816361b381551461110857816361d027b3146110c45781636d04eb9f1461108957816370a08231146110525781637187631814610f1157816371ea0d8e14610ed657816379cc679014610ea057816385f377ca14610e5c5781638fd3ab80146107ea57816390825c28146107c657816395d89b41146106c5578163a9059cbb1461057c578163b026a12114610541578163be74615f14610506578163c45a0155146104c2578163c48afe1614610487578163c6d8b77814610460578163c78d0b0e14610441578163d3728de414610426578163dd62ed3e146103dd578163e8e70c4c146103be578163e98d5cd51461025957508063fd62bcd714610236578063fd967f471461021a5763fe94c269146101dd57600080fd5b34610216578160031936011261021657602090517f000000000000000000000000000000000000000000c380f8e0bc1c7ed49f84008152f35b5080fd5b5034610216578160031936011261021657602090516127108152f35b503461021657816003193601126102165760209060ff6009541690519015158152f35b8261026336611a3b565b917f000000000000000000000000412af46b6327443e730c92360e710b4f70d531d36001600160a01b031633036103af5760ff600954166103a0576102bf6102ad60085484611a89565b6102b984600754611ab2565b90611abf565b916102c983611b5e565b9390956102df856102da8985611adf565b611adf565b9561030a887f00000000000000000000000056c4f0504f577a283073ab780b6850fec4121389611c4a565b610334867f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032611c4a565b861061039257508161035f6103739261035461038e979695600754611ab2565b600755600854611adf565b60085561036c8633611c4a565b3033611cc0565b51938493846040919493926060820195825260208201520152565b0390f35b8351630a1c173f60e41b8152fd5b5163058aab2d60e21b81528390fd5b51630636a15760e11b81528390fd5b5050346102165781600319360112610216576020906008549051908152f35b505034610216578060031936011261021657806020926103fb6119e3565b6104036119fe565b6001600160a01b0391821683526001865283832091168252845220549051908152f35b50503461021657816003193601126102165751908152602090f35b5050346102165781600319360112610216576020906006549051908152f35b50503461021657816003193601126102165760209060ff60095460081c1690519015158152f35b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000001043561a88293000008152f35b505034610216578160031936011261021657517f000000000000000000000000412af46b6327443e730c92360e710b4f70d531d36001600160a01b03168152602090f35b505034610216578160031936011261021657602090517f0000000000000000000000000000000000000000000000056bc75e2d631000008152f35b505034610216578160031936011261021657602090517f0000000000000000000000000000000000000000000001043561a882930000008152f35b9050346106c157816003193601126106c1576105966119e3565b9260ff60095460081c166105bc575b6020836105b56024358733611cc0565b5160018152f35b825163c45a015560e01b81526001600160a01b0390602090818186817f0000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e159087165afa9081156106b757908291859161068a575b50602487518095819363e5e31b1360e01b8352818c168a840152165afa92831561067f5792610652575b505061064457806105a5565b9051633b95747f60e21b8152fd5b6106719250803d10610678575b6106698183611a51565b810190611b0b565b3880610638565b503d61065f565b8551903d90823e3d90fd5b6106aa9150823d84116106b0575b6106a28183611a51565b810190611aec565b3861060e565b503d610698565b86513d86823e3d90fd5b8280fd5b83833461021657816003193601126102165780519180938054916001908360011c92600185169485156107bc575b60209586861081146107a957858952908115610785575060011461072d575b61038e8787610723828c0383611a51565b519182918261199a565b81529295507f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b5b828410610772575050508261038e9461072392820101948680610712565b8054868501880152928601928101610754565b60ff19168887015250505050151560051b83010192506107238261038e8680610712565b634e487b7160e01b845260228352602484fd5b93607f16936106f3565b5050346102165781600319360112610216576020906107e3611b23565b9051908152f35b9050346106c157826003193601126106c1576001600160a01b03917f000000000000000000000000412af46b6327443e730c92360e710b4f70d531d383163303610e4f576009805461ff0019169055805163c45a015560e01b8082527f0000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e15908516948694939260209190828187818b5afa908115610e45578791610e28575b508451633fc8cef360e01b8082529094848689818d5afa958615610e1e5790899392918497610dff575b5087518681876306801cc360e41b968783528d30908401528160249c168c84015260449e8f84015216815a91606492fa908115610d8b57918688928e95948891610de2575b501615610ce5575b8a8a518095819382525afa918215610cbc578b93929187918693610cc6575b508a8a518096819382525afa928315610cbc5791858a9288948796610c98575b50606493949596828c51988997889687523090870152168b8501528d840152165afa908115610c8e578991610c71575b5016938415610c6357308852878252838820549584519763095ea7b360e01b895280838a015287858a0152838983818d305af1988915610c5957610aa0979899610c3c575b507f00000000000000000000000000000000000000000000001043561a882930000094610b016109e28747611adf565b6102da610a31610a2a610a21610a197f0000000000000000000000000000000000000000000000056bc75e2d631000008096611adf565b600754611a89565b60085490611abf565b809e611adf565b986102da610a6d612710610a657f000000000000000000000000000000000000000000000000000000000000177085611a89565b048093611adf565b7f00000000000000000000000056c4f0504f577a283073ab780b6850fec41213899d8e610a9a8784611ab2565b90611c4a565b610aca837f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032611c4a565b610ad48c30611d9e565b6102da6008547f0000000000000000000000000000000000000000000001043561a8829300000090611adf565b97600a4201804211610c2a579060608d969594939260e48e8d8d5197889485936302df835360e61b8552308d8601528d8a860152808c86015260648501528260848501523060a485015260c48401525af1928315610c2057908795949392918793610be3575b5047610bd2575b50885195869463a9059cbb60e01b8652850152830152818b8a5af18015610bc85760809850610bab575b5082519586528501528301526060820152f35b610bc190823d8411610678576106698183611a51565b5038610b98565b84513d8a823e3d90fd5b610bdd904790611c4a565b38610b6e565b955091506060853d606011610c18575b81610c0060609383611a51565b81010312610c145788879501519138610b67565b8580fd5b3d9150610bf3565b89513d88823e3d90fd5b634e487b7160e01b8d5260118652828dfd5b610c5290853d8711610678576106698183611a51565b50386109b2565b86513d8c823e3d90fd5b835163c6bcf59960e01b8152fd5b610c889150833d85116106b0576106a28183611a51565b3861096d565b85513d8b823e3d90fd5b859650610cb490606495963d89116106b0576106a28183611a51565b95949361093d565b88513d86823e3d90fd5b610cde919350823d84116106b0576106a28183611a51565b913861091d565b9192908a918a51928380928682525afa908115610d8b57908a918691610dc5575b50878d8b51938480928882525afa918215610dbb5787928c888f8c958f95918f89938597610d95575b5090849160649798519a8b998a986320b7f73960e21b8a5230908a01521690870152850152165af18015610d8b579187918d9493610d6e575b506108fe565b610d8490833d85116106b0576106a28183611a51565b5038610d68565b89513d87823e3d90fd5b6064975090610db28693928b3d8d116106b0576106a28183611a51565b97509091610d2f565b8a513d88823e3d90fd5b610ddc9150883d8a116106b0576106a28183611a51565b38610d06565b610df99150843d86116106b0576106a28183611a51565b386108f6565b610e17919750863d88116106b0576106a28183611a51565b95386108b1565b87513d8b823e3d90fd5b610e3f9150833d85116106b0576106a28183611a51565b38610887565b85513d89823e3d90fd5b51630636a15760e11b8152fd5b505034610216578160031936011261021657517f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d80590326001600160a01b03168152602090f35b50503461021657366003190112610ed357610ed0610ebc6119e3565b60243590610ecb823383611e3d565b611d9e565b80f35b80fd5b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000017708152f35b9050610f1c36611a3b565b92907f000000000000000000000000412af46b6327443e730c92360e710b4f70d531d36001600160a01b031633036110445760ff6009541661103657610f6184611b5e565b929091610f72846102da8589611adf565b94610f9d847f00000000000000000000000056c4f0504f577a283073ab780b6850fec4121389611c4a565b610fc7857f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032611c4a565b610fe2610fd660075489611a89565b6102b989600854611adf565b9182116110285750611007608096610ffb833033611cc0565b61035483600754611ab2565b6008556110148533611c4a565b815194855260208501528301526060820152f35b8251630a1c173f60e41b8152fd5b505163058aab2d60e21b8152fd5b5051630636a15760e11b8152fd5b5050346102165760203660031901126102165760209181906001600160a01b0361107a6119e3565b16815280845220549051908152f35b505034610216578160031936011261021657602090517f000000000000000000000000000000000000000000000fe1c215e8f838e000008152f35b505034610216578160031936011261021657517f00000000000000000000000056c4f0504f577a283073ab780b6850fec41213896001600160a01b03168152602090f35b505034610216578160031936011261021657517f0000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e15906001600160a01b03168152602090f35b91905060203660031901126106c1578135927f000000000000000000000000412af46b6327443e730c92360e710b4f70d531d36001600160a01b031633036110445760ff600954166110365781849130815280602052205411156112a3576111b334611b5e565b9390926111c4856102da8634611adf565b906111ef857f00000000000000000000000056c4f0504f577a283073ab780b6850fec4121389611c4a565b611219867f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032611c4a565b6007546112268184611a89565b91611238600854936102b98686611ab2565b948510611295575061126992849261125761038e979661125f94611adf565b600755611ab2565b6008553330611cc0565b611271611bc9565b611279611c08565b5192839234846040919493926060820195825260208201520152565b8551630a1c173f60e41b8152fd5b5163904db1ff60e01b8152fd5b505034610216578160031936011261021657602090517f0000000000000000000000000000000000000000000010f0cf064dd5920000008152f35b828434610ed3576112fb36611a14565b91935091901561133d57906102b98261132961132261131c61132f96611b5e565b90611ab2565b9582611a89565b92611adf565b905b82519182526020820152f35b8061132961134e946102b993611a89565b61135a61131c82611b5e565b611331565b83903461021657602036600319011261021657610ed0903533611d9e565b5050346102165781600319360112610216576020905160128152f35b90506113a436611a3b565b90939092907f000000000000000000000000412af46b6327443e730c92360e710b4f70d531d36001600160a01b031633036110445760ff600954166110365781859130815280602052205411156112a35761141061140460085486611a89565b6102b986600754611adf565b9361141a85611b5e565b9390956114308561142b8984611ab2565b611ab2565b95861161150b576114a690611465887f00000000000000000000000056c4f0504f577a283073ab780b6850fec4121389611c4a565b61148f867f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032611c4a565b61149b84600754611adf565b600755600854611ab2565b6008558434116000146114e75750906114d761038e93926114d06114ca8734611adf565b33611c4a565b3330611cc0565b6114df611bc9565b610373611c08565b8434106114fd5750906114d761038e93926114d0565b82516367c45b4f60e11b8152fd5b508251630a1c173f60e41b8152fd5b9050346106c15760603660031901126106c1576115356119e3565b61153d6119fe565b916044359460ff60095460081c16611569575b6020856105b5888787611564833383611e3d565b611cc0565b845163c45a015560e01b81526001600160a01b0390602090818186817f0000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e159087165afa908115610cbc579082918591611627575b50602489518095819363e5e31b1360e01b8352818c168a840152165afa92831561161c57926115ff575b50506115f15780611550565b8351633b95747f60e21b8152fd5b6116159250803d10610678576106698183611a51565b38806115e5565b8751903d90823e3d90fd5b61163e9150823d84116106b0576106a28183611a51565b386115bb565b828434610ed35780600319360112610ed35761166d600654308352826020528383205490611adf565b9061271091828102908082048414901517156116e157602094506116b2907f000000000000000000000000000000000000000000c380f8e0bc1c7ed49f840090611abf565b9060648210156116c9575050506064905b51908152f35b50818111156116da57505b906116c3565b90506116d4565b634e487b7160e01b825260118552602482fd5b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000000648152f35b5050346102165781600319360112610216576020906002549051908152f35b5050346102165781600319360112610216576020906007549051908152f35b828434610ed35761177d36611a14565b909350909190156117a557906102b98261179f61132261131c61132f96611b5e565b92611ab2565b8061179f61134e946102b993611a89565b9050346106c157816003193601126106c1576117d06119e3565b602435903315611849576001600160a01b031691821561183257508083602095338152600187528181208582528752205582519081527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925843392a35160018152f35b8351634a1406b160e11b8152908101859052602490fd5b835163e602df0560e01b8152808401869052602490fd5b919050346106c157826003193601126106c15780519183600354906001908260011c9260018116801561194d575b602095868610821461193a575084885290811561191857506001146118bf575b61038e8686610723828b0383611a51565b929550600383527fc2575a0e9e593c00f959f8c92f12db2869c3395a3b0502d05e2516446f71f85b5b828410611905575050508261038e946107239282010194386118ae565b80548685018801529286019281016118e8565b60ff191687860152505050151560051b83010192506107238261038e386118ae565b634e487b7160e01b845260229052602483fd5b93607f169361188e565b8490346102165781600319360112610216577f00000000000000000000000078c768d132da62aa86cb5df2fe19de9e612a5efe6001600160a01b03168152602090f35b6020808252825181830181905290939260005b8281106119cf57505060409293506000838284010152601f8019910116010190565b8181018601518482016040015285016119ad565b600435906001600160a01b03821682036119f957565b600080fd5b602435906001600160a01b03821682036119f957565b60809060031901126119f95760043590602435906044359060643580151581036119f95790565b60409060031901126119f9576004359060243590565b90601f8019910116810190811067ffffffffffffffff821117611a7357604052565b634e487b7160e01b600052604160045260246000fd5b81810292918115918404141715611a9c57565b634e487b7160e01b600052601160045260246000fd5b91908201809211611a9c57565b8115611ac9570490565b634e487b7160e01b600052601260045260246000fd5b91908203918211611a9c57565b908160209103126119f957516001600160a01b03811681036119f95790565b908160209103126119f9575180151581036119f95790565b600854670de0b6b3a76400009081810290808204831490151715611a9c57611b51611b5a9160025490611a89565b60075490611abf565b0490565b611bc6611b92916127109283917f000000000000000000000000000000000000000000000000000000000000006490611a89565b0491611bbe7f000000000000000000000000000000000000000000000000000000000000177084611a89565b048092611adf565b91565b611bd1611b23565b7f000000000000000000000000000000000000000000000fe1c215e8f838e0000010611bf957565b600160ff196009541617600955565b611c10611b23565b7f0000000000000000000000000000000000000000000010f0cf064dd59200000010611c3857565b6040516353dfa97560e01b8152600490fd5b60008080809481945af1903d15611cba573d9067ffffffffffffffff8211611ca65760405191611c84601f8201601f191660200184611a51565b825260203d92013e5b15611c9457565b6040516338822c1360e11b8152600490fd5b634e487b7160e01b81526041600452602490fd5b50611c8d565b916001600160a01b03808416928315611d855716928315611d6c5760009083825281602052604082205490838210611d3a575091604082827fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef958760209652828652038282205586815220818154019055604051908152a3565b60405163391434e360e21b81526001600160a01b03919091166004820152602481019190915260448101839052606490fd5b60405163ec442f0560e01b815260006004820152602490fd5b604051634b637e8f60e11b815260006004820152602490fd5b906001600160a01b038216908115611d855760009282845283602052604084205490828210611e0b5750817fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef926020928587528684520360408620558060025403600255604051908152a3565b60405163391434e360e21b81526001600160a01b03919091166004820152602481019190915260448101829052606490fd5b9160018060a01b038093169160009383855260016020526040938486209183169182875260205284862054926000198403611e7c575b50505050505050565b848410611ee057508015611ec8578115611eb057855260016020528385209085526020520391205538808080808080611e73565b8451634a1406b160e11b815260048101879052602490fd5b845163e602df0560e01b815260048101879052602490fd5b8551637dc7a0d960e11b81526001600160a01b039190911660048201526024810184905260448101859052606490fdfea26469706673582212209a74b311730e917319e2b340893566f12d3b33c7a9275b849905bcf523c03fb364736f6c63430008170033

    Block Age Transaction Gas Used Reward
    view all blocks produced

    Block Age Uncle Number Difficulty Gas Used Reward
    View All Uncles
    Loading...
    Loading
    Loading...
    Loading

    Validator Index Block Age Amount
    View All Withdrawals

    Transaction Hash Block Age Value Eth2 PubKey Valid
    View All Deposits
    [ Download: CSV Export  ]

    A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.