More Info
Private Name Tags
ContractCreator
TokenTracker
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Loading...
Loading
Contract Source Code Verified (Exact Match)
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)
// 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 {IRouter03} from "./interfaces/IRouter03.sol"; import {IPairFactory} from "./interfaces/IPairFactory.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; uint256 public immutable fixedMigrationFee; uint256 public immutable poolCreationFee; address public immutable creator; address public immutable treasury; address public immutable dexTreasury; address public immutable factory; bool public tradingStopped; bool public sendingToPairNotAllowed = true; uint256 public constant MAX_BPS = 10_000; IRouter03 public immutable solidlyRouter; modifier buyChecks() { if (tradingStopped) revert TradingStopped(); _; _checkMcLower(); _checkMcUpperLimit(); } modifier sellChecks() { if (tradingStopped) revert TradingStopped(); _; } modifier onlyFactory() { if (msg.sender != factory) revert OnlyFactory(); _; } constructor(ConstructorParams memory _params) ERC20(_params.name, _params.symbol) { _mint(address(this), _params.totalSupply); initalTokenSupply = _params.totalSupply; virtualCollateralReserves = _params.virtualCollateralReserves; virtualCollateralReservesInitial = _params.virtualCollateralReserves; virtualTokenReserves = _params.virtualTokenReserves; creator = _params.creator; feeBPS = _params.feeBasisPoints; dexFeeBPS = _params.dexFeeBasisPoints; treasury = _params.treasury; dexTreasury = _params.dexTreasury; fixedMigrationFee = _params.migrationFeeFixed; poolCreationFee = _params.poolCreationFee; mcLowerLimit = _params.mcLowerLimit; mcUpperLimit = _params.mcUpperLimit; tokensMigrationThreshold = _params.tokensMigrationThreshold; solidlyRouter = IRouter03(_params.solidlyRouter); factory = msg.sender; } /** * @dev Buys tokenAmount of tokens for eth, refunding excess eth * * @param _tokenAmount - amount of tokens to buy * @param _maxCollateralAmount - maximum amount of collateral a caller is willing to spend */ function buyExactOut( uint256 _tokenAmount, uint256 _maxCollateralAmount ) external payable onlyFactory buyChecks returns (uint256 collateralToPayWithFee, uint256 helioFee, uint256 dexFee) { if (balanceOf(address(this)) <= _tokenAmount) revert InsufficientTokenReserves(); uint256 collateralToSpend = (_tokenAmount * virtualCollateralReserves) / (virtualTokenReserves - _tokenAmount); (helioFee, dexFee) = _calculateFee(collateralToSpend); collateralToPayWithFee = collateralToSpend + helioFee + dexFee; if (collateralToPayWithFee > _maxCollateralAmount) revert SlippageCheckFailed(); _transferCollateral(treasury, helioFee); _transferCollateral(dexTreasury, dexFee); virtualTokenReserves -= _tokenAmount; virtualCollateralReserves += collateralToSpend; uint256 refund; if (msg.value > collateralToPayWithFee) { // refund the user refund = msg.value - collateralToPayWithFee; _transferCollateral(msg.sender, refund); } else if (msg.value < collateralToPayWithFee) { revert NotEnoughtETHToBuyTokens(); } _transfer(address(this), msg.sender, _tokenAmount); } /** * @dev Buys tokens specifing minimal amount of tokens a caller gets * * @param _amountOutMin - minimal amount of tokens a caller will get */ function buyExactIn( uint256 _amountOutMin ) external payable onlyFactory buyChecks returns (uint256 collateralToPayWithFee, uint256 helioFee, uint256 dexFee) { if (balanceOf(address(this)) <= _amountOutMin) revert InsufficientTokenReserves(); collateralToPayWithFee = msg.value; (helioFee, dexFee) = _calculateFee(collateralToPayWithFee); uint256 collateralToSpendMinusFee = collateralToPayWithFee - helioFee - dexFee; _transferCollateral(treasury, helioFee); _transferCollateral(dexTreasury, dexFee); uint256 tokensOut = (collateralToSpendMinusFee * virtualTokenReserves) / (virtualCollateralReserves + collateralToSpendMinusFee); if (tokensOut < _amountOutMin) revert SlippageCheckFailed(); virtualTokenReserves -= tokensOut; virtualCollateralReserves += collateralToSpendMinusFee; _transfer(address(this), msg.sender, tokensOut); } /** * @dev Sells given amount of tokens for eth * * @param _tokenAmount - amount of tokens a caller wants to sell * @param _amountCollateralMin - minimum amount of collateral a seller will get */ function sellExactIn( uint256 _tokenAmount, uint256 _amountCollateralMin ) external payable onlyFactory sellChecks returns (uint256 collateralToReceiveMinusFee, uint256 helioFee, uint256 dexFee) { uint256 collaterallToReceive = (_tokenAmount * virtualCollateralReserves) / (virtualTokenReserves + _tokenAmount); (helioFee, dexFee) = _calculateFee(collaterallToReceive); collateralToReceiveMinusFee = collaterallToReceive - helioFee - dexFee; _transferCollateral(treasury, helioFee); _transferCollateral(dexTreasury, dexFee); if (collateralToReceiveMinusFee < _amountCollateralMin) revert SlippageCheckFailed(); virtualTokenReserves += _tokenAmount; virtualCollateralReserves -= collaterallToReceive; _transferCollateral(msg.sender, collateralToReceiveMinusFee); _transfer(msg.sender, address(this), _tokenAmount); } /** * @dev Sells given amount of tokens for eth * * @param _tokenAmountMax - max amount of tokens a caller wants to sell */ function sellExactOut( uint256 _tokenAmountMax, uint256 _amountCollateral ) external payable onlyFactory sellChecks returns (uint256 collateralToReceiveMinusFee, uint256 tokensOut, uint256 helioFee, uint256 dexFee) { (helioFee, dexFee) = _calculateFee(_amountCollateral); collateralToReceiveMinusFee = _amountCollateral - helioFee - dexFee; _transferCollateral(treasury, helioFee); _transferCollateral(dexTreasury, dexFee); tokensOut = (_amountCollateral * virtualTokenReserves) / (virtualCollateralReserves - _amountCollateral); if (tokensOut > _tokenAmountMax) revert SlippageCheckFailed(); _transfer(msg.sender, address(this), tokensOut); virtualTokenReserves += tokensOut; virtualCollateralReserves -= _amountCollateral; _transferCollateral(msg.sender, collateralToReceiveMinusFee); } /** * @dev Calculates amountOut for a given amountIn * * @param _amountIn - amount in which will be transfered to the contract * @param _reserveIn - reserve in * @param _reserveOut - reserve out * @param _paymentTokenIsIn - if token in is a collateral token */ function getAmountOutAndFee( uint256 _amountIn, uint256 _reserveIn, uint256 _reserveOut, bool _paymentTokenIsIn ) external view returns (uint256 amountOut, uint256 fee) { if (_paymentTokenIsIn) { (uint256 helioFee, uint256 dexFee) = _calculateFee(_amountIn); fee = helioFee + dexFee; amountOut = (_amountIn * _reserveOut) / (_reserveIn + _amountIn); } else { amountOut = (_amountIn * _reserveOut) / (_reserveIn + _amountIn); (uint256 helioFee, uint256 dexFee) = _calculateFee(amountOut); fee = helioFee + dexFee; } } /** * @dev Calculates amountIn for a given amountOut * * @param _amountOut - amount out which will be transfered from the contract * @param _reserveIn - reserve in * @param _reserveOut - reserve out * @param _paymentTokenIsOut - if token out is a payment token */ function getAmountInAndFee( uint256 _amountOut, uint256 _reserveIn, uint256 _reserveOut, bool _paymentTokenIsOut ) external view returns (uint256 amountIn, uint256 fee) { if (_paymentTokenIsOut) { (uint256 helioFee, uint256 dexFee) = _calculateFee(_amountOut); fee = helioFee + dexFee; amountIn = (_amountOut * _reserveIn) / (_reserveOut - _amountOut); } else { amountIn = (_amountOut * _reserveIn) / (_reserveOut - _amountOut); (uint256 helioFee, uint256 dexFee) = _calculateFee(amountIn); fee = helioFee + dexFee; } } /** * @dev migrates tokens and collateral to uniswap-v2 and burns LP tokens */ function migrate() external onlyFactory returns (uint256 tokensToMigrate, uint256 tokensToBurn, uint256 collateralAmount, address pair) { sendingToPairNotAllowed = false; uint256 tokensRemaining = balanceOf(address(this)); this.approve(address(solidlyRouter), tokensRemaining); tokensToMigrate = _tokensToMigrate(); tokensToBurn = tokensRemaining - tokensToMigrate; _burn(address(this), tokensToBurn); (uint256 treasuryFee, uint256 dexFee) = _splitFee(fixedMigrationFee); _transferCollateral(treasury, treasuryFee + poolCreationFee); _transferCollateral(dexTreasury, dexFee); collateralAmount = virtualCollateralReserves - virtualCollateralReservesInitial - treasuryFee - dexFee - poolCreationFee; (, , uint256 liquidity) = solidlyRouter.addLiquidityETH{value: collateralAmount}( address(this), false, tokensToMigrate, tokensToMigrate, collateralAmount, address(this), block.timestamp + 120 // 2 minutes ); pair = IPairFactory(solidlyRouter.factory()).getPair(address(this), solidlyRouter.weth(), false); if (pair == address(0)) revert PairNotCreated(); if (address(this).balance > 0) { _transferCollateral(treasury, address(this).balance); } IERC20(pair).transfer(address(0), liquidity); } function getMarketCap() public view returns (uint256) { uint256 mc = (virtualCollateralReserves * 10 ** 18 * totalSupply()) / virtualTokenReserves; return mc / 10 ** 18; } function getCurveProgressBps() external view returns (uint256) { uint256 progress = ((initalTokenSupply - balanceOf(address(this))) * MAX_BPS) / tokensMigrationThreshold; return progress < 100 ? 100 : (progress > MAX_BPS ? MAX_BPS : progress); } function transfer(address _to, uint256 _value) public override(ERC20, IERC20) returns (bool) { if (sendingToPairNotAllowed) { if (IPairFactory(solidlyRouter.factory()).isPair(_to)) revert SendingToPairIsNotAllowedBeforeMigration(); } return super.transfer(_to, _value); } function transferFrom(address from, address to, uint256 amount) public override(ERC20, IERC20) returns (bool) { if (sendingToPairNotAllowed) { if (IPairFactory(solidlyRouter.factory()).isPair(to)) revert SendingToPairIsNotAllowedBeforeMigration(); } return super.transferFrom(from, to, amount); } function _tokensToMigrate() internal view returns (uint256) { uint256 collateralDeductedFee = address(this).balance - fixedMigrationFee - poolCreationFee; return (virtualTokenReserves * collateralDeductedFee) / virtualCollateralReserves; } function _calculateFee(uint256 _amount) internal view returns (uint256 treasuryFee, uint256 dexFee) { treasuryFee = (_amount * feeBPS) / MAX_BPS; dexFee = (treasuryFee * dexFeeBPS) / MAX_BPS; treasuryFee -= dexFee; } function _splitFee(uint256 _feeAmount) internal view returns (uint256 treasuryFee, uint256 dexFee) { dexFee = (_feeAmount * dexFeeBPS) / MAX_BPS; treasuryFee = _feeAmount - dexFee; } function _transferCollateral(address _to, uint256 _amount) internal { (bool sent, ) = _to.call{value: _amount}(""); if (!sent) revert FailedToSendETH(); } function _checkMcUpperLimit() internal view { uint256 mc = getMarketCap(); if (mc > mcUpperLimit) revert MarketcapThresholdReached(); } function _checkMcLower() internal { uint256 mc = getMarketCap(); if (mc > mcLowerLimit) { tradingStopped = true; } } }
// 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. */ error ERC20InvalidReceiver(address receiver); /** * @dev Indicates a failure with the `spender`’s `allowance`. Used in transfers. * @param spender Address that may be allowed to operate on tokens without being their owner. * @param allowance Amount of tokens a `spender` is allowed to operate with. * @param needed Minimum amount required to perform a transfer. */ error ERC20InsufficientAllowance(address spender, uint256 allowance, uint256 needed); /** * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals. * @param approver Address initiating an approval operation. */ error ERC20InvalidApprover(address approver); /** * @dev Indicates a failure with the `spender` to be approved. Used in approvals. * @param spender Address that may be allowed to operate on tokens without being their owner. */ error ERC20InvalidSpender(address spender); } /** * @dev Standard ERC721 Errors * Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC721 tokens. */ interface IERC721Errors { /** * @dev Indicates that an address can't be an owner. For example, `address(0)` is a forbidden owner in EIP-20. * Used in balance queries. * @param owner Address of the current owner of a token. */ error ERC721InvalidOwner(address owner); /** * @dev Indicates a `tokenId` whose `owner` is the zero address. * @param tokenId Identifier number of a token. */ error ERC721NonexistentToken(uint256 tokenId); /** * @dev Indicates an error related to the ownership over a particular token. Used in transfers. * @param sender Address whose tokens are being transferred. * @param tokenId Identifier number of a token. * @param owner Address of the current owner of a token. */ error ERC721IncorrectOwner(address sender, uint256 tokenId, address owner); /** * @dev Indicates a failure with the token `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. */ error ERC721InvalidSender(address sender); /** * @dev Indicates a failure with the token `receiver`. Used in transfers. * @param receiver Address to which tokens are being transferred. */ error ERC721InvalidReceiver(address receiver); /** * @dev Indicates a failure with the `operator`’s approval. Used in transfers. * @param operator Address that may be allowed to operate on tokens without being their owner. * @param tokenId Identifier number of a token. */ error ERC721InsufficientApproval(address operator, uint256 tokenId); /** * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals. * @param approver Address initiating an approval operation. */ error ERC721InvalidApprover(address approver); /** * @dev Indicates a failure with the `operator` to be approved. Used in approvals. * @param operator Address that may be allowed to operate on tokens without being their owner. */ error ERC721InvalidOperator(address operator); } /** * @dev Standard ERC1155 Errors * Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC1155 tokens. */ interface IERC1155Errors { /** * @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. * @param tokenId Identifier number of a token. */ error ERC1155InsufficientBalance(address sender, uint256 balance, uint256 needed, uint256 tokenId); /** * @dev Indicates a failure with the token `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. */ error ERC1155InvalidSender(address sender); /** * @dev Indicates a failure with the token `receiver`. Used in transfers. * @param receiver Address to which tokens are being transferred. */ error ERC1155InvalidReceiver(address receiver); /** * @dev Indicates a failure with the `operator`’s approval. Used in transfers. * @param operator Address that may be allowed to operate on tokens without being their owner. * @param owner Address of the current owner of a token. */ error ERC1155MissingApprovalForAll(address operator, address owner); /** * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals. * @param approver Address initiating an approval operation. */ error ERC1155InvalidApprover(address approver); /** * @dev Indicates a failure with the `operator` to be approved. Used in approvals. * @param operator Address that may be allowed to operate on tokens without being their owner. */ error ERC1155InvalidOperator(address operator); /** * @dev Indicates an array length mismatch between ids and values in a safeBatchTransferFrom operation. * Used in batch transfers. * @param idsLength Length of the array of token identifiers * @param valuesLength Length of the array of token amounts */ error ERC1155InvalidArrayLength(uint256 idsLength, uint256 valuesLength); }
// 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 * applications. * * Additionally, an {Approval} event is emitted on calls to {transferFrom}. * This allows applications to reconstruct the allowance for all accounts just * by listening to said events. Other implementations of the EIP may not emit * these events, as it isn't required by the specification. */ abstract contract ERC20 is Context, IERC20, IERC20Metadata, IERC20Errors { mapping(address account => uint256) private _balances; mapping(address account => mapping(address spender => uint256)) private _allowances; uint256 private _totalSupply; string private _name; string private _symbol; /** * @dev Sets the values for {name} and {symbol}. * * All two of these values are immutable: they can only be set once during * construction. */ constructor(string memory name_, string memory symbol_) { _name = name_; _symbol = symbol_; } /** * @dev Returns the name of the token. */ function name() public view virtual returns (string memory) { return _name; } /** * @dev Returns the symbol of the token, usually a shorter version of the * name. */ function symbol() public view virtual returns (string memory) { return _symbol; } /** * @dev Returns the number of decimals used to get its user representation. * For example, if `decimals` equals `2`, a balance of `505` tokens should * be displayed to a user as `5.05` (`505 / 10 ** 2`). * * Tokens usually opt for a value of 18, imitating the relationship between * Ether and Wei. This is the default value returned by this function, unless * it's overridden. * * NOTE: This information is only used for _display_ purposes: it in * no way affects any of the arithmetic of the contract, including * {IERC20-balanceOf} and {IERC20-transfer}. */ function decimals() public view virtual returns (uint8) { return 18; } /** * @dev See {IERC20-totalSupply}. */ function totalSupply() public view virtual returns (uint256) { return _totalSupply; } /** * @dev See {IERC20-balanceOf}. */ function balanceOf(address account) public view virtual returns (uint256) { return _balances[account]; } /** * @dev See {IERC20-transfer}. * * Requirements: * * - `to` cannot be the zero address. * - the caller must have a balance of at least `value`. */ function transfer(address to, uint256 value) public virtual returns (bool) { address owner = _msgSender(); _transfer(owner, to, value); return true; } /** * @dev See {IERC20-allowance}. */ function allowance(address owner, address spender) public view virtual returns (uint256) { return _allowances[owner][spender]; } /** * @dev See {IERC20-approve}. * * NOTE: If `value` is the maximum `uint256`, the allowance is not updated on * `transferFrom`. This is semantically equivalent to an infinite approval. * * Requirements: * * - `spender` cannot be the zero address. */ function approve(address spender, uint256 value) public virtual returns (bool) { address owner = _msgSender(); _approve(owner, spender, value); return true; } /** * @dev See {IERC20-transferFrom}. * * Emits an {Approval} event indicating the updated allowance. This is not * required by the EIP. See the note at the beginning of {ERC20}. * * NOTE: Does not update the allowance if the current allowance * is the maximum `uint256`. * * Requirements: * * - `from` and `to` cannot be the zero address. * - `from` must have a balance of at least `value`. * - the caller must have allowance for ``from``'s tokens of at least * `value`. */ function transferFrom(address from, address to, uint256 value) public virtual returns (bool) { address spender = _msgSender(); _spendAllowance(from, spender, value); _transfer(from, to, value); return true; } /** * @dev Moves a `value` amount of tokens from `from` to `to`. * * This internal function is equivalent to {transfer}, and can be used to * e.g. implement automatic token fees, slashing mechanisms, etc. * * Emits a {Transfer} event. * * NOTE: This function is not virtual, {_update} should be overridden instead. */ function _transfer(address from, address to, uint256 value) internal { if (from == address(0)) { revert ERC20InvalidSender(address(0)); } if (to == address(0)) { revert ERC20InvalidReceiver(address(0)); } _update(from, to, value); } /** * @dev Transfers a `value` amount of tokens from `from` to `to`, or alternatively mints (or burns) if `from` * (or `to`) is the zero address. All customizations to transfers, mints, and burns should be done by overriding * this function. * * Emits a {Transfer} event. */ function _update(address from, address to, uint256 value) internal virtual { if (from == address(0)) { // Overflow check required: The rest of the code assumes that totalSupply never overflows _totalSupply += value; } else { uint256 fromBalance = _balances[from]; if (fromBalance < value) { revert ERC20InsufficientBalance(from, fromBalance, value); } unchecked { // Overflow not possible: value <= fromBalance <= totalSupply. _balances[from] = fromBalance - value; } } if (to == address(0)) { unchecked { // Overflow not possible: value <= totalSupply or value <= fromBalance <= totalSupply. _totalSupply -= value; } } else { unchecked { // Overflow not possible: balance + value is at most totalSupply, which we know fits into a uint256. _balances[to] += value; } } emit Transfer(from, to, value); } /** * @dev Creates a `value` amount of tokens and assigns them to `account`, by transferring it from address(0). * Relies on the `_update` mechanism * * Emits a {Transfer} event with `from` set to the zero address. * * NOTE: This function is not virtual, {_update} should be overridden instead. */ function _mint(address account, uint256 value) internal { if (account == address(0)) { revert ERC20InvalidReceiver(address(0)); } _update(address(0), account, value); } /** * @dev Destroys a `value` amount of tokens from `account`, lowering the total supply. * Relies on the `_update` mechanism. * * Emits a {Transfer} event with `to` set to the zero address. * * NOTE: This function is not virtual, {_update} should be overridden instead */ function _burn(address account, uint256 value) internal { if (account == address(0)) { revert ERC20InvalidSender(address(0)); } _update(account, address(0), value); } /** * @dev Sets `value` as the allowance of `spender` over the `owner` s tokens. * * This internal function is equivalent to `approve`, and can be used to * e.g. set automatic allowances for certain subsystems, etc. * * Emits an {Approval} event. * * Requirements: * * - `owner` cannot be the zero address. * - `spender` cannot be the zero address. * * Overrides to this logic should be done to the variant with an additional `bool emitEvent` argument. */ function _approve(address owner, address spender, uint256 value) internal { _approve(owner, spender, value, true); } /** * @dev Variant of {_approve} with an optional flag to enable or disable the {Approval} event. * * By default (when calling {_approve}) the flag is set to true. On the other hand, approval changes made by * `_spendAllowance` during the `transferFrom` operation set the flag to false. This saves gas by not emitting any * `Approval` event during `transferFrom` operations. * * Anyone who wishes to continue emitting `Approval` events on the`transferFrom` operation can force the flag to * true using the following override: * ``` * function _approve(address owner, address spender, uint256 value, bool) internal virtual override { * super._approve(owner, spender, value, true); * } * ``` * * Requirements are the same as {_approve}. */ function _approve(address owner, address spender, uint256 value, bool emitEvent) internal virtual { if (owner == address(0)) { revert ERC20InvalidApprover(address(0)); } if (spender == address(0)) { revert ERC20InvalidSpender(address(0)); } _allowances[owner][spender] = value; if (emitEvent) { emit Approval(owner, spender, value); } } /** * @dev Updates `owner` s allowance for `spender` based on spent `value`. * * Does not update the allowance value in case of infinite allowance. * Revert if not enough allowance is available. * * Does not emit an {Approval} event. */ function _spendAllowance(address owner, address spender, uint256 value) internal virtual { uint256 currentAllowance = allowance(owner, spender); if (currentAllowance != type(uint256).max) { if (currentAllowance < value) { revert ERC20InsufficientAllowance(spender, currentAllowance, value); } unchecked { _approve(owner, spender, currentAllowance - value, false); } } } }
// 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. * * See {ERC20-_burn} and {ERC20-allowance}. * * Requirements: * * - the caller must have allowance for ``accounts``'s tokens of at least * `value`. */ function burnFrom(address account, uint256 value) public virtual { _spendAllowance(account, _msgSender(), value); _burn(account, value); } }
// 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); }
// 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. */ function totalSupply() external view returns (uint256); /** * @dev Returns the value of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves a `value` amount of tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 value) 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 a `value` amount of tokens 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 value) external returns (bool); /** * @dev Moves a `value` amount of tokens from `from` to `to` using the * allowance mechanism. `value` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom(address from, address to, uint256 value) external returns (bool); }
// 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; } }
// 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 // pointer aliasing, and it cannot be disabled. // The values being non-zero value makes deployment a bit more expensive, // but in exchange the refund on every call to nonReentrant will be lower in // amount. Since refunds are capped to a percentage of the total // transaction's gas, it is best to keep them low in cases like this one, to // increase the likelihood of the full refund coming into effect. uint256 private constant NOT_ENTERED = 1; uint256 private constant ENTERED = 2; uint256 private _status; /** * @dev Unauthorized reentrant call. */ error ReentrancyGuardReentrantCall(); constructor() { _status = NOT_ENTERED; } /** * @dev Prevents a contract from calling itself, directly or indirectly. * Calling a `nonReentrant` function from another `nonReentrant` * function is not supported. It is possible to prevent this from happening * by making the `nonReentrant` function external, and making it call a * `private` function that does the actual work. */ modifier nonReentrant() { _nonReentrantBefore(); _; _nonReentrantAfter(); } function _nonReentrantBefore() private { // On the first call to nonReentrant, _status will be NOT_ENTERED if (_status == ENTERED) { revert ReentrancyGuardReentrantCall(); } // Any calls to nonReentrant after this point will fail _status = ENTERED; } function _nonReentrantAfter() private { // By storing the original value once again, a refund is triggered (see // https://eips.ethereum.org/EIPS/eip-2200) _status = NOT_ENTERED; } /** * @dev Returns true if the reentrancy guard is currently set to "entered", which indicates there is a * `nonReentrant` function in the call stack. */ function _reentrancyGuardEntered() internal view returns (bool) { return _status == ENTERED; } }
// 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; address dexTreasury; } error NotEnoughETHReserves(); error InsufficientTokenReserves(); error FailedToSendETH(); error NotEnoughtETHToBuyTokens(); error SlippageCheckFailed(); error MarketcapThresholdReached(); error SendingToPairIsNotAllowedBeforeMigration(); error PairNotCreated(); error TradingStopped(); error OnlyFactory(); function buyExactOut( uint256 _tokenAmount, uint256 _maxCollateralAmount ) external payable returns (uint256 collateralToPayWithFee, uint256 helioFee, uint256 dexFee); function buyExactIn( uint256 _amountOutMin ) external payable returns (uint256 collateralToPayWithFee, uint256 helioFee, uint256 dexFee); function sellExactIn( uint256 _tokenAmount, uint256 _amountOutMin ) external payable returns (uint256 collateralToReceiveMinusFee, uint256 helioFee, uint256 dexFee); function sellExactOut( uint256 _tokenAmountMax, uint256 _amountCollateral ) external payable returns (uint256 collateralToReceiveMinusFee, uint256 tokensOut, uint256 helioFee, uint256 dexFee); function getAmountOutAndFee( uint256 _amountIn, uint256 _reserveIn, uint256 _reserveOut, bool _paymentTokenIsIn ) external view returns (uint256 amountOut, uint256 fee); function getAmountInAndFee( uint256 _amountOut, uint256 _reserveIn, uint256 _reserveOut, bool _paymentTokenIsOut ) external view returns (uint256 amountIn, uint256 fee); function migrate() external returns (uint256 tokensToMigrate, uint256 tokensToBurn, uint256 collateralAmount, address pair); function getCurveProgressBps() external view returns (uint256); function getMarketCap() external view returns (uint256); }
// SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.23; interface IPairFactory { function allPairsLength() external view returns (uint); function isPair(address pair) external view returns (bool); function isPaused() external view returns (bool); function pairCodeHash() external pure returns (bytes32); function getPair(address tokenA, address token, bool stable) external view returns (address); function getInitializable() external view returns (address, address, bool); function createPair(address tokenA, address tokenB, bool stable) external returns (address pair); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.23; interface IRouter03 { struct Route { address from; address to; bool stable; } function factory() external view returns (address); function weth() external view returns (address); function pairCodeHash() external view returns (bytes32); function voter() 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, address tokenOut, bool stable ) external view returns (uint amount); function getAmountsOut(uint amountIn, Route[] memory routes) external view returns (uint[] memory amounts); function isPair(address pair) external view returns (bool); function quoteAddLiquidity( address tokenA, address tokenB, bool stable, uint amountADesired, uint amountBDesired ) external view returns (uint amountA, uint amountB, uint liquidity); function quoteRemoveLiquidity( address tokenA, address tokenB, bool stable, uint liquidity ) external view returns (uint amountA, uint amountB); function addLiquidity( address tokenA, address tokenB, bool stable, uint amountADesired, uint amountBDesired, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB, uint liquidity); function addLiquidityETH( address token, bool stable, uint amountTokenDesired, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external payable returns (uint amountToken, uint amountETH, uint liquidity); function removeLiquidity( address tokenA, address tokenB, bool stable, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB); function removeLiquidityETH( address token, bool stable, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external returns (uint amountToken, uint amountETH); function removeLiquidityWithPermit( address tokenA, address tokenB, bool stable, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountA, uint amountB); function removeLiquidityETHWithPermit( address token, bool stable, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountToken, uint amountETH); function removeLiquidityETHSupportingFeeOnTransferTokens( address token, bool stable, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external returns (uint amountToken, uint amountETH); function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens( address token, bool stable, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountToken, uint amountETH); function swapExactTokensForTokensSimple( uint amountIn, uint amountOutMin, address tokenFrom, address tokenTo, bool stable, address to, uint deadline ) external returns (uint[] memory amounts); function swapExactTokensForTokens( uint amountIn, uint amountOutMin, Route[] calldata routes, address to, uint deadline ) external returns (uint[] memory amounts); function swapExactETHForTokens( uint amountOutMin, Route[] calldata routes, address to, uint deadline ) external payable returns (uint[] memory amounts); function swapExactTokensForETH( uint amountIn, uint amountOutMin, Route[] calldata routes, address to, uint deadline ) external returns (uint[] memory amounts); function UNSAFE_swapExactTokensForTokens( uint[] memory amounts, Route[] calldata routes, address to, uint deadline ) external returns (uint[] memory); function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, Route[] calldata routes, address to, uint deadline ) external; function swapExactETHForTokensSupportingFeeOnTransferTokens( uint amountOutMin, Route[] calldata routes, address to, uint deadline ) external payable; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, Route[] calldata routes, address to, uint deadline ) external; }
{ "optimizer": { "enabled": true, "runs": 200 }, "viaIR": true, "evmVersion": "paris", "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "metadata": { "useLiteralContent": true }, "libraries": {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"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 IRouter03","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"}]
Contract Creation Code
610220604052346200072b5762002524803803806200001e8162000730565b92833981016020828203126200072b5781516001600160401b0381116200072b576102008184018303126200072b576040519161020083016001600160401b038111848210176200060a57604052838201516001600160401b0381116200072b57816200008f918487010162000756565b835283820160200151916001600160401b0383116200072b57620000bf6101e0926200017b948388010162000756565b94856020860152620000d6604083830101620007c8565b6040860152808201606081810151908701526080808201519087015260a0808201519087015260c0808201519087015260e080820151908701526101008082015190870152610120808201519087015261014080820151908701526101608082015190870152610180808201519087015262000156906101a001620007c8565b6101a08601526200016d6101c083830101620007c8565b6101c08601520101620007c8565b6101e0820152805180519092906001600160401b0381116200060a57600354600181811c9116801562000720575b6020821014620005e957601f8111620006b6575b506020601f82116001146200062c578192939460009262000620575b50508160011b916000199060031b1c1916176003555b8051906001600160401b0382116200060a5760045490600182811c92168015620005ff575b6020831014620005e95781601f84931162000577575b50602090601f8311600114620004e857600092620004dc575b50508160011b916000199060031b1c1916176004555b600160055561010061ff0019600954161760095560608101513015620004c3576002548181018111620004ad578101600255306000526000602052604060002081815401905560405190815260007fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60203093a3606081015160065560a08101518060085560805260808101516007556101c060018060a01b0391826040820151166101805260c081015160a05260e081015160c052826101a0820151166101a052826101e0820151168252610100810151610140526101208101516101605261014081015160e052610160810151610100526101808101516101205201511661020052336101e052604051611d469081620007de823960805181818161055901526109c4015260a05181818161150c015261196d015260c05181818161092b01528181610ce40152611999015260e051818181610e9701526119d30152610100518181816110be0152611a120152610120518181816101f3015261148d01526101405181818161049f015261089801526101605181818161051e01526108d40152610180518161176b01526101a0518181816102e60152818161095e01528181610d6f01528181610ecf01528181610fc1015261123701526101c0518181816103100152818161099801528181610c6701528181610d9901528181610feb015261126101526101e051818181610266015281816104d70152818161080601528181610d1601528181610f5601526111a10152610200518181816105da0152818161084901528181610f13015261137d0152f35b634e487b7160e01b600052601160045260246000fd5b60405163ec442f0560e01b815260006004820152602490fd5b01519050388062000243565b6004600090815293507f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b91905b601f19841685106200055b576001945083601f1981161062000541575b505050811b0160045562000259565b015160001960f88460031b161c1916905538808062000532565b8181015183556020948501946001909301929091019062000515565b60046000529091507f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b601f840160051c810160208510620005e1575b90849392915b601f830160051c82018110620005d15750506200022a565b60008155859450600101620005b9565b5080620005b3565b634e487b7160e01b600052602260045260246000fd5b91607f169162000214565b634e487b7160e01b600052604160045260246000fd5b015190503880620001d9565b600360009081527fc2575a0e9e593c00f959f8c92f12db2869c3395a3b0502d05e2516446f71f85b9190601f198416905b8181106200069d5750958360019596971062000683575b505050811b01600355620001ef565b015160001960f88460031b161c1916905538808062000674565b9192602060018192868b0151815501940192016200065d565b60036000527fc2575a0e9e593c00f959f8c92f12db2869c3395a3b0502d05e2516446f71f85b601f830160051c8101916020841062000715575b601f0160051c01905b818110620007085750620001bd565b60008155600101620006f9565b9091508190620006f0565b90607f1690620001a9565b600080fd5b6040519190601f01601f191682016001600160401b038111838210176200060a57604052565b919080601f840112156200072b5782516001600160401b0381116200060a576020906200078c601f8201601f1916830162000730565b928184528282870101116200072b5760005b818110620007b457508260009394955001015290565b85810183015184820184015282016200079e565b51906001600160a01b03821682036200072b5756fe608060408181526004918236101561001657600080fd5b600092833560e01c91826302d05d3f146117575750816306fdde0314611660578163095ea7b3146115b6578163152044811461156d5781631655bc621461154e57816318160ddd1461152f5781631a1c6e53146114f45781632368da321461144457816323b872dd1461131057816325e17b571461118f578163313ce5671461117357816342966c681461115557816349a30246146110e15781634c7766b5146110a65781634fb3fbe714610f4257816361b3815514610efe57816361d027b314610eba5781636d04eb9f14610e7f57816370a0823114610e485781637187631814610d0757816371ea0d8e14610ccc57816379cc679014610c9657816385f377ca14610c525781638fd3ab80146107ea57816390825c28146107c657816395d89b41146106c5578163a9059cbb1461057c578163b026a12114610541578163be74615f14610506578163c45a0155146104c2578163c48afe1614610487578163c6d8b77814610460578163c78d0b0e14610441578163d3728de414610426578163dd62ed3e146103dd578163e8e70c4c146103be578163e98d5cd51461025957508063fd62bcd714610236578063fd967f471461021a5763fe94c269146101dd57600080fd5b34610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000000008152f35b5080fd5b5034610216578160031936011261021657602090516127108152f35b503461021657816003193601126102165760209060ff6009541690519015158152f35b826102633661183b565b917f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031633036103af5760ff600954166103a0576102bf6102ad60085484611889565b6102b9846007546118b2565b906118bf565b916102c98361195e565b9390956102df856102da89856118df565b6118df565b9561030a887f0000000000000000000000000000000000000000000000000000000000000000611a4a565b610334867f0000000000000000000000000000000000000000000000000000000000000000611a4a565b861061039257508161035f6103739261035461038e9796956007546118b2565b6007556008546118df565b60085561036c8633611a4a565b3033611ac0565b51938493846040919493926060820195825260208201520152565b0390f35b8351630a1c173f60e41b8152fd5b5163058aab2d60e21b81528390fd5b51630636a15760e11b81528390fd5b5050346102165781600319360112610216576020906008549051908152f35b505034610216578060031936011261021657806020926103fb6117e3565b6104036117fe565b6001600160a01b0391821683526001865283832091168252845220549051908152f35b50503461021657816003193601126102165751908152602090f35b5050346102165781600319360112610216576020906006549051908152f35b50503461021657816003193601126102165760209060ff60095460081c1690519015158152f35b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000000008152f35b505034610216578160031936011261021657517f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03168152602090f35b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000000008152f35b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000000008152f35b9050346106c157816003193601126106c1576105966117e3565b9260ff60095460081c166105bc575b6020836105b56024358733611ac0565b5160018152f35b825163c45a015560e01b81526001600160a01b0390602090818186817f000000000000000000000000000000000000000000000000000000000000000087165afa9081156106b757908291859161068a575b50602487518095819363e5e31b1360e01b8352818c168a840152165afa92831561067f5792610652575b505061064457806105a5565b9051633b95747f60e21b8152fd5b6106719250803d10610678575b6106698183611851565b81019061190b565b3880610638565b503d61065f565b8551903d90823e3d90fd5b6106aa9150823d84116106b0575b6106a28183611851565b8101906118ec565b3861060e565b503d610698565b86513d86823e3d90fd5b8280fd5b83833461021657816003193601126102165780519180938054916001908360011c92600185169485156107bc575b60209586861081146107a957858952908115610785575060011461072d575b61038e8787610723828c0383611851565b519182918261179a565b81529295507f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b5b828410610772575050508261038e9461072392820101948680610712565b8054868501880152928601928101610754565b60ff19168887015250505050151560051b83010192506107238261038e8680610712565b634e487b7160e01b845260228352602484fd5b93607f16936106f3565b5050346102165781600319360112610216576020906107e3611923565b9051908152f35b9050346106c157826003193601126106c1576001600160a01b037f000000000000000000000000000000000000000000000000000000000000000081163303610c435761ff0019600954166009553084526020928484528085205493827f00000000000000000000000000000000000000000000000000000000000000001690825163095ea7b360e01b8152828682015286602482015281816044818b305af18015610b3957610c26575b507f0000000000000000000000000000000000000000000000000000000000000000946108c286476118df565b926109e961091261090b6109026108fa7f000000000000000000000000000000000000000000000000000000000000000080996118df565b600754611889565b600854906118bf565b809a6118df565b9461091d8630611b9e565b6102da6109586127106109507f00000000000000000000000000000000000000000000000000000000000000008d611889565b04809b6118df565b996102da7f00000000000000000000000000000000000000000000000000000000000000009b6109928d61098c87846118b2565b90611a4a565b6109bc837f0000000000000000000000000000000000000000000000000000000000000000611a4a565b6102da6008547f0000000000000000000000000000000000000000000000000000000000000000906118df565b956078420191824211610c13578a908751936302df835360e61b855230868601528260248601528b60448601528b60648601528960848601523060a486015260c485015260608460e4818c855af1938415610c09578294610bd3575b50875163c45a015560e01b81529086828781845afa918215610baa5786929188918593610bb4575b508a51633fc8cef360e01b815293849182905afa918215610baa5787928580936064938793610b8b575b508c5196879586946306801cc360e41b8652308d8701521660248501526044840152165afa908115610b81578b91610b64575b5016968715610b545747610b43575b50845163a9059cbb60e01b8152918201899052602482015281816044818b8a5af18015610b395760809850610b1c575b5082519586528501528301526060820152f35b610b3290823d8411610678576106698183611851565b5038610b09565b84513d8a823e3d90fd5b610b4e904790611a4a565b38610ad9565b855163c6bcf59960e01b81528390fd5b610b7b9150853d87116106b0576106a28183611851565b38610aca565b87513d8d823e3d90fd5b610ba3919350863d88116106b0576106a28183611851565b9138610a97565b89513d85823e3d90fd5b610bcc919350823d84116106b0576106a28183611851565b9138610a6d565b9093506060813d606011610c01575b81610bef60609383611851565b81010312610216578701519238610a45565b3d9150610be2565b88513d84823e3d90fd5b634e487b7160e01b8b526011845260248bfd5b610c3c90823d8411610678576106698183611851565b5038610895565b509051630636a15760e11b8152fd5b505034610216578160031936011261021657517f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03168152602090f35b50503461021657366003190112610cc957610cc6610cb26117e3565b60243590610cc1823383611c3d565b611b9e565b80f35b80fd5b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000000008152f35b9050610d123661183b565b92907f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03163303610e3a5760ff60095416610e2c57610d578461195e565b929091610d68846102da85896118df565b94610d93847f0000000000000000000000000000000000000000000000000000000000000000611a4a565b610dbd857f0000000000000000000000000000000000000000000000000000000000000000611a4a565b610dd8610dcc60075489611889565b6102b9896008546118df565b918211610e1e5750610dfd608096610df1833033611ac0565b610354836007546118b2565b600855610e0a8533611a4a565b815194855260208501528301526060820152f35b8251630a1c173f60e41b8152fd5b505163058aab2d60e21b8152fd5b5051630636a15760e11b8152fd5b5050346102165760203660031901126102165760209181906001600160a01b03610e706117e3565b16815280845220549051908152f35b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000000008152f35b505034610216578160031936011261021657517f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03168152602090f35b505034610216578160031936011261021657517f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03168152602090f35b91905060203660031901126106c1578135927f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03163303610e3a5760ff60095416610e2c57818491308152806020522054111561109957610fa93461195e565b939092610fba856102da86346118df565b90610fe5857f0000000000000000000000000000000000000000000000000000000000000000611a4a565b61100f867f0000000000000000000000000000000000000000000000000000000000000000611a4a565b60075461101c8184611889565b9161102e600854936102b986866118b2565b94851061108b575061105f92849261104d61038e9796611055946118df565b6007556118b2565b6008553330611ac0565b6110676119c9565b61106f611a08565b5192839234846040919493926060820195825260208201520152565b8551630a1c173f60e41b8152fd5b5163904db1ff60e01b8152fd5b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000000008152f35b828434610cc9576110f136611814565b91935091901561113357906102b98261111f6111186111126111259661195e565b906118b2565b9582611889565b926118df565b905b82519182526020820152f35b8061111f611144946102b993611889565b6111506111128261195e565b611127565b83903461021657602036600319011261021657610cc6903533611b9e565b5050346102165781600319360112610216576020905160128152f35b905061119a3661183b565b90939092907f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03163303610e3a5760ff60095416610e2c578185913081528060205220541115611099576112066111fa60085486611889565b6102b9866007546118df565b936112108561195e565b9390956112268561122189846118b2565b6118b2565b9586116113015761129c9061125b887f0000000000000000000000000000000000000000000000000000000000000000611a4a565b611285867f0000000000000000000000000000000000000000000000000000000000000000611a4a565b611291846007546118df565b6007556008546118b2565b6008558434116000146112dd5750906112cd61038e93926112c66112c087346118df565b33611a4a565b3330611ac0565b6112d56119c9565b610373611a08565b8434106112f35750906112cd61038e93926112c6565b82516367c45b4f60e11b8152fd5b508251630a1c173f60e41b8152fd5b9050346106c15760603660031901126106c15761132b6117e3565b6113336117fe565b916044359460ff60095460081c1661135f575b6020856105b588878761135a833383611c3d565b611ac0565b845163c45a015560e01b81526001600160a01b0390602090818186817f000000000000000000000000000000000000000000000000000000000000000087165afa90811561143a57908291859161141d575b50602489518095819363e5e31b1360e01b8352818c168a840152165afa92831561141257926113f5575b50506113e75780611346565b8351633b95747f60e21b8152fd5b61140b9250803d10610678576106698183611851565b38806113db565b8751903d90823e3d90fd5b6114349150823d84116106b0576106a28183611851565b386113b1565b88513d86823e3d90fd5b828434610cc95780600319360112610cc95761146d6006543083528260205283832054906118df565b9061271091828102908082048414901517156114e157602094506114b2907f0000000000000000000000000000000000000000000000000000000000000000906118bf565b9060648210156114c9575050506064905b51908152f35b50818111156114da57505b906114c3565b90506114d4565b634e487b7160e01b825260118552602482fd5b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000000008152f35b5050346102165781600319360112610216576020906002549051908152f35b5050346102165781600319360112610216576020906007549051908152f35b828434610cc95761157d36611814565b909350909190156115a557906102b98261159f6111186111126111259661195e565b926118b2565b8061159f611144946102b993611889565b9050346106c157816003193601126106c1576115d06117e3565b602435903315611649576001600160a01b031691821561163257508083602095338152600187528181208582528752205582519081527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925843392a35160018152f35b8351634a1406b160e11b8152908101859052602490fd5b835163e602df0560e01b8152808401869052602490fd5b919050346106c157826003193601126106c15780519183600354906001908260011c9260018116801561174d575b602095868610821461173a575084885290811561171857506001146116bf575b61038e8686610723828b0383611851565b929550600383527fc2575a0e9e593c00f959f8c92f12db2869c3395a3b0502d05e2516446f71f85b5b828410611705575050508261038e946107239282010194386116ae565b80548685018801529286019281016116e8565b60ff191687860152505050151560051b83010192506107238261038e386116ae565b634e487b7160e01b845260229052602483fd5b93607f169361168e565b8490346102165781600319360112610216577f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03168152602090f35b6020808252825181830181905290939260005b8281106117cf57505060409293506000838284010152601f8019910116010190565b8181018601518482016040015285016117ad565b600435906001600160a01b03821682036117f957565b600080fd5b602435906001600160a01b03821682036117f957565b60809060031901126117f95760043590602435906044359060643580151581036117f95790565b60409060031901126117f9576004359060243590565b90601f8019910116810190811067ffffffffffffffff82111761187357604052565b634e487b7160e01b600052604160045260246000fd5b8181029291811591840414171561189c57565b634e487b7160e01b600052601160045260246000fd5b9190820180921161189c57565b81156118c9570490565b634e487b7160e01b600052601260045260246000fd5b9190820391821161189c57565b908160209103126117f957516001600160a01b03811681036117f95790565b908160209103126117f9575180151581036117f95790565b600854670de0b6b3a7640000908181029080820483149015171561189c5761195161195a9160025490611889565b600754906118bf565b0490565b6119c6611992916127109283917f000000000000000000000000000000000000000000000000000000000000000090611889565b04916119be7f000000000000000000000000000000000000000000000000000000000000000084611889565b0480926118df565b91565b6119d1611923565b7f0000000000000000000000000000000000000000000000000000000000000000106119f957565b600160ff196009541617600955565b611a10611923565b7f000000000000000000000000000000000000000000000000000000000000000010611a3857565b6040516353dfa97560e01b8152600490fd5b60008080809481945af1903d15611aba573d9067ffffffffffffffff8211611aa65760405191611a84601f8201601f191660200184611851565b825260203d92013e5b15611a9457565b6040516338822c1360e11b8152600490fd5b634e487b7160e01b81526041600452602490fd5b50611a8d565b916001600160a01b03808416928315611b855716928315611b6c5760009083825281602052604082205490838210611b3a575091604082827fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef958760209652828652038282205586815220818154019055604051908152a3565b60405163391434e360e21b81526001600160a01b03919091166004820152602481019190915260448101839052606490fd5b60405163ec442f0560e01b815260006004820152602490fd5b604051634b637e8f60e11b815260006004820152602490fd5b906001600160a01b038216908115611b855760009282845283602052604084205490828210611c0b5750817fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef926020928587528684520360408620558060025403600255604051908152a3565b60405163391434e360e21b81526001600160a01b03919091166004820152602481019190915260448101829052606490fd5b9160018060a01b038093169160009383855260016020526040938486209183169182875260205284862054926000198403611c7c575b50505050505050565b848410611ce057508015611cc8578115611cb057855260016020528385209085526020520391205538808080808080611c73565b8451634a1406b160e11b815260048101879052602490fd5b845163e602df0560e01b815260048101879052602490fd5b8551637dc7a0d960e11b81526001600160a01b039190911660048201526024810184905260448101859052606490fdfea26469706673582212203af95082c259da89df993ce151da8ce3f9bd01f83b2bd46e03833ab8c3358c4a64736f6c6343000817003300000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000024000000000000000000000000056c4f0504f577a283073ab780b6850fec41213890000000000000000000000000000000000000000033b2e3c9fd0803ce80000000000000000000000000000000000000000000000036ccfbb244887eea40000000000000000000000000000000000000000000000000001043561a882930000000000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000177000000000000000000000000000000000000000000000001043561a88293000000000000000000000000000000000000000000000000000056bc75e2d631000000000000000000000000000000000000000000000000001969368974c05b000000000000000000000000000000000000000000000000010f0cf064dd592000000000000000000000000000000000000000000000000c380f8e0bc1c7ed0d305ab00000000000000000000000056c4f0504f577a283073ab780b6850fec41213890000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e1590000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d805903200000000000000000000000000000000000000000000000000000000000000084d6f6f6e73686f7400000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000054d53484f54000000000000000000000000000000000000000000000000000000
Deployed Bytecode
0x608060408181526004918236101561001657600080fd5b600092833560e01c91826302d05d3f146117575750816306fdde0314611660578163095ea7b3146115b6578163152044811461156d5781631655bc621461154e57816318160ddd1461152f5781631a1c6e53146114f45781632368da321461144457816323b872dd1461131057816325e17b571461118f578163313ce5671461117357816342966c681461115557816349a30246146110e15781634c7766b5146110a65781634fb3fbe714610f4257816361b3815514610efe57816361d027b314610eba5781636d04eb9f14610e7f57816370a0823114610e485781637187631814610d0757816371ea0d8e14610ccc57816379cc679014610c9657816385f377ca14610c525781638fd3ab80146107ea57816390825c28146107c657816395d89b41146106c5578163a9059cbb1461057c578163b026a12114610541578163be74615f14610506578163c45a0155146104c2578163c48afe1614610487578163c6d8b77814610460578163c78d0b0e14610441578163d3728de414610426578163dd62ed3e146103dd578163e8e70c4c146103be578163e98d5cd51461025957508063fd62bcd714610236578063fd967f471461021a5763fe94c269146101dd57600080fd5b34610216578160031936011261021657602090517f000000000000000000000000000000000000000000c380f8e0bc1c7ed0d305ab8152f35b5080fd5b5034610216578160031936011261021657602090516127108152f35b503461021657816003193601126102165760209060ff6009541690519015158152f35b826102633661183b565b917f00000000000000000000000056c4f0504f577a283073ab780b6850fec41213896001600160a01b031633036103af5760ff600954166103a0576102bf6102ad60085484611889565b6102b9846007546118b2565b906118bf565b916102c98361195e565b9390956102df856102da89856118df565b6118df565b9561030a887f00000000000000000000000056c4f0504f577a283073ab780b6850fec4121389611a4a565b610334867f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032611a4a565b861061039257508161035f6103739261035461038e9796956007546118b2565b6007556008546118df565b60085561036c8633611a4a565b3033611ac0565b51938493846040919493926060820195825260208201520152565b0390f35b8351630a1c173f60e41b8152fd5b5163058aab2d60e21b81528390fd5b51630636a15760e11b81528390fd5b5050346102165781600319360112610216576020906008549051908152f35b505034610216578060031936011261021657806020926103fb6117e3565b6104036117fe565b6001600160a01b0391821683526001865283832091168252845220549051908152f35b50503461021657816003193601126102165751908152602090f35b5050346102165781600319360112610216576020906006549051908152f35b50503461021657816003193601126102165760209060ff60095460081c1690519015158152f35b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000001043561a88293000008152f35b505034610216578160031936011261021657517f00000000000000000000000056c4f0504f577a283073ab780b6850fec41213896001600160a01b03168152602090f35b505034610216578160031936011261021657602090517f0000000000000000000000000000000000000000000000056bc75e2d631000008152f35b505034610216578160031936011261021657602090517f0000000000000000000000000000000000000000000001043561a882930000008152f35b9050346106c157816003193601126106c1576105966117e3565b9260ff60095460081c166105bc575b6020836105b56024358733611ac0565b5160018152f35b825163c45a015560e01b81526001600160a01b0390602090818186817f0000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e159087165afa9081156106b757908291859161068a575b50602487518095819363e5e31b1360e01b8352818c168a840152165afa92831561067f5792610652575b505061064457806105a5565b9051633b95747f60e21b8152fd5b6106719250803d10610678575b6106698183611851565b81019061190b565b3880610638565b503d61065f565b8551903d90823e3d90fd5b6106aa9150823d84116106b0575b6106a28183611851565b8101906118ec565b3861060e565b503d610698565b86513d86823e3d90fd5b8280fd5b83833461021657816003193601126102165780519180938054916001908360011c92600185169485156107bc575b60209586861081146107a957858952908115610785575060011461072d575b61038e8787610723828c0383611851565b519182918261179a565b81529295507f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b5b828410610772575050508261038e9461072392820101948680610712565b8054868501880152928601928101610754565b60ff19168887015250505050151560051b83010192506107238261038e8680610712565b634e487b7160e01b845260228352602484fd5b93607f16936106f3565b5050346102165781600319360112610216576020906107e3611923565b9051908152f35b9050346106c157826003193601126106c1576001600160a01b037f00000000000000000000000056c4f0504f577a283073ab780b6850fec412138981163303610c435761ff0019600954166009553084526020928484528085205493827f0000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e15901690825163095ea7b360e01b8152828682015286602482015281816044818b305af18015610b3957610c26575b507f00000000000000000000000000000000000000000000001043561a8829300000946108c286476118df565b926109e961091261090b6109026108fa7f0000000000000000000000000000000000000000000000056bc75e2d6310000080996118df565b600754611889565b600854906118bf565b809a6118df565b9461091d8630611b9e565b6102da6109586127106109507f00000000000000000000000000000000000000000000000000000000000017708d611889565b04809b6118df565b996102da7f00000000000000000000000056c4f0504f577a283073ab780b6850fec41213899b6109928d61098c87846118b2565b90611a4a565b6109bc837f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032611a4a565b6102da6008547f0000000000000000000000000000000000000000000001043561a88293000000906118df565b956078420191824211610c13578a908751936302df835360e61b855230868601528260248601528b60448601528b60648601528960848601523060a486015260c485015260608460e4818c855af1938415610c09578294610bd3575b50875163c45a015560e01b81529086828781845afa918215610baa5786929188918593610bb4575b508a51633fc8cef360e01b815293849182905afa918215610baa5787928580936064938793610b8b575b508c5196879586946306801cc360e41b8652308d8701521660248501526044840152165afa908115610b81578b91610b64575b5016968715610b545747610b43575b50845163a9059cbb60e01b8152918201899052602482015281816044818b8a5af18015610b395760809850610b1c575b5082519586528501528301526060820152f35b610b3290823d8411610678576106698183611851565b5038610b09565b84513d8a823e3d90fd5b610b4e904790611a4a565b38610ad9565b855163c6bcf59960e01b81528390fd5b610b7b9150853d87116106b0576106a28183611851565b38610aca565b87513d8d823e3d90fd5b610ba3919350863d88116106b0576106a28183611851565b9138610a97565b89513d85823e3d90fd5b610bcc919350823d84116106b0576106a28183611851565b9138610a6d565b9093506060813d606011610c01575b81610bef60609383611851565b81010312610216578701519238610a45565b3d9150610be2565b88513d84823e3d90fd5b634e487b7160e01b8b526011845260248bfd5b610c3c90823d8411610678576106698183611851565b5038610895565b509051630636a15760e11b8152fd5b505034610216578160031936011261021657517f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d80590326001600160a01b03168152602090f35b50503461021657366003190112610cc957610cc6610cb26117e3565b60243590610cc1823383611c3d565b611b9e565b80f35b80fd5b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000017708152f35b9050610d123661183b565b92907f00000000000000000000000056c4f0504f577a283073ab780b6850fec41213896001600160a01b03163303610e3a5760ff60095416610e2c57610d578461195e565b929091610d68846102da85896118df565b94610d93847f00000000000000000000000056c4f0504f577a283073ab780b6850fec4121389611a4a565b610dbd857f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032611a4a565b610dd8610dcc60075489611889565b6102b9896008546118df565b918211610e1e5750610dfd608096610df1833033611ac0565b610354836007546118b2565b600855610e0a8533611a4a565b815194855260208501528301526060820152f35b8251630a1c173f60e41b8152fd5b505163058aab2d60e21b8152fd5b5051630636a15760e11b8152fd5b5050346102165760203660031901126102165760209181906001600160a01b03610e706117e3565b16815280845220549051908152f35b505034610216578160031936011261021657602090517f0000000000000000000000000000000000000000000001969368974c05b000008152f35b505034610216578160031936011261021657517f00000000000000000000000056c4f0504f577a283073ab780b6850fec41213896001600160a01b03168152602090f35b505034610216578160031936011261021657517f0000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e15906001600160a01b03168152602090f35b91905060203660031901126106c1578135927f00000000000000000000000056c4f0504f577a283073ab780b6850fec41213896001600160a01b03163303610e3a5760ff60095416610e2c57818491308152806020522054111561109957610fa93461195e565b939092610fba856102da86346118df565b90610fe5857f00000000000000000000000056c4f0504f577a283073ab780b6850fec4121389611a4a565b61100f867f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032611a4a565b60075461101c8184611889565b9161102e600854936102b986866118b2565b94851061108b575061105f92849261104d61038e9796611055946118df565b6007556118b2565b6008553330611ac0565b6110676119c9565b61106f611a08565b5192839234846040919493926060820195825260208201520152565b8551630a1c173f60e41b8152fd5b5163904db1ff60e01b8152fd5b505034610216578160031936011261021657602090517f0000000000000000000000000000000000000000000010f0cf064dd5920000008152f35b828434610cc9576110f136611814565b91935091901561113357906102b98261111f6111186111126111259661195e565b906118b2565b9582611889565b926118df565b905b82519182526020820152f35b8061111f611144946102b993611889565b6111506111128261195e565b611127565b83903461021657602036600319011261021657610cc6903533611b9e565b5050346102165781600319360112610216576020905160128152f35b905061119a3661183b565b90939092907f00000000000000000000000056c4f0504f577a283073ab780b6850fec41213896001600160a01b03163303610e3a5760ff60095416610e2c578185913081528060205220541115611099576112066111fa60085486611889565b6102b9866007546118df565b936112108561195e565b9390956112268561122189846118b2565b6118b2565b9586116113015761129c9061125b887f00000000000000000000000056c4f0504f577a283073ab780b6850fec4121389611a4a565b611285867f000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032611a4a565b611291846007546118df565b6007556008546118b2565b6008558434116000146112dd5750906112cd61038e93926112c66112c087346118df565b33611a4a565b3330611ac0565b6112d56119c9565b610373611a08565b8434106112f35750906112cd61038e93926112c6565b82516367c45b4f60e11b8152fd5b508251630a1c173f60e41b8152fd5b9050346106c15760603660031901126106c15761132b6117e3565b6113336117fe565b916044359460ff60095460081c1661135f575b6020856105b588878761135a833383611c3d565b611ac0565b845163c45a015560e01b81526001600160a01b0390602090818186817f0000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e159087165afa90811561143a57908291859161141d575b50602489518095819363e5e31b1360e01b8352818c168a840152165afa92831561141257926113f5575b50506113e75780611346565b8351633b95747f60e21b8152fd5b61140b9250803d10610678576106698183611851565b38806113db565b8751903d90823e3d90fd5b6114349150823d84116106b0576106a28183611851565b386113b1565b88513d86823e3d90fd5b828434610cc95780600319360112610cc95761146d6006543083528260205283832054906118df565b9061271091828102908082048414901517156114e157602094506114b2907f000000000000000000000000000000000000000000c380f8e0bc1c7ed0d305ab906118bf565b9060648210156114c9575050506064905b51908152f35b50818111156114da57505b906114c3565b90506114d4565b634e487b7160e01b825260118552602482fd5b505034610216578160031936011261021657602090517f00000000000000000000000000000000000000000000000000000000000000648152f35b5050346102165781600319360112610216576020906002549051908152f35b5050346102165781600319360112610216576020906007549051908152f35b828434610cc95761157d36611814565b909350909190156115a557906102b98261159f6111186111126111259661195e565b926118b2565b8061159f611144946102b993611889565b9050346106c157816003193601126106c1576115d06117e3565b602435903315611649576001600160a01b031691821561163257508083602095338152600187528181208582528752205582519081527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925843392a35160018152f35b8351634a1406b160e11b8152908101859052602490fd5b835163e602df0560e01b8152808401869052602490fd5b919050346106c157826003193601126106c15780519183600354906001908260011c9260018116801561174d575b602095868610821461173a575084885290811561171857506001146116bf575b61038e8686610723828b0383611851565b929550600383527fc2575a0e9e593c00f959f8c92f12db2869c3395a3b0502d05e2516446f71f85b5b828410611705575050508261038e946107239282010194386116ae565b80548685018801529286019281016116e8565b60ff191687860152505050151560051b83010192506107238261038e386116ae565b634e487b7160e01b845260229052602483fd5b93607f169361168e565b8490346102165781600319360112610216577f00000000000000000000000056c4f0504f577a283073ab780b6850fec41213896001600160a01b03168152602090f35b6020808252825181830181905290939260005b8281106117cf57505060409293506000838284010152601f8019910116010190565b8181018601518482016040015285016117ad565b600435906001600160a01b03821682036117f957565b600080fd5b602435906001600160a01b03821682036117f957565b60809060031901126117f95760043590602435906044359060643580151581036117f95790565b60409060031901126117f9576004359060243590565b90601f8019910116810190811067ffffffffffffffff82111761187357604052565b634e487b7160e01b600052604160045260246000fd5b8181029291811591840414171561189c57565b634e487b7160e01b600052601160045260246000fd5b9190820180921161189c57565b81156118c9570490565b634e487b7160e01b600052601260045260246000fd5b9190820391821161189c57565b908160209103126117f957516001600160a01b03811681036117f95790565b908160209103126117f9575180151581036117f95790565b600854670de0b6b3a7640000908181029080820483149015171561189c5761195161195a9160025490611889565b600754906118bf565b0490565b6119c6611992916127109283917f000000000000000000000000000000000000000000000000000000000000006490611889565b04916119be7f000000000000000000000000000000000000000000000000000000000000177084611889565b0480926118df565b91565b6119d1611923565b7f0000000000000000000000000000000000000000000001969368974c05b00000106119f957565b600160ff196009541617600955565b611a10611923565b7f0000000000000000000000000000000000000000000010f0cf064dd59200000010611a3857565b6040516353dfa97560e01b8152600490fd5b60008080809481945af1903d15611aba573d9067ffffffffffffffff8211611aa65760405191611a84601f8201601f191660200184611851565b825260203d92013e5b15611a9457565b6040516338822c1360e11b8152600490fd5b634e487b7160e01b81526041600452602490fd5b50611a8d565b916001600160a01b03808416928315611b855716928315611b6c5760009083825281602052604082205490838210611b3a575091604082827fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef958760209652828652038282205586815220818154019055604051908152a3565b60405163391434e360e21b81526001600160a01b03919091166004820152602481019190915260448101839052606490fd5b60405163ec442f0560e01b815260006004820152602490fd5b604051634b637e8f60e11b815260006004820152602490fd5b906001600160a01b038216908115611b855760009282845283602052604084205490828210611c0b5750817fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef926020928587528684520360408620558060025403600255604051908152a3565b60405163391434e360e21b81526001600160a01b03919091166004820152602481019190915260448101829052606490fd5b9160018060a01b038093169160009383855260016020526040938486209183169182875260205284862054926000198403611c7c575b50505050505050565b848410611ce057508015611cc8578115611cb057855260016020528385209085526020520391205538808080808080611c73565b8451634a1406b160e11b815260048101879052602490fd5b845163e602df0560e01b815260048101879052602490fd5b8551637dc7a0d960e11b81526001600160a01b039190911660048201526024810184905260448101859052606490fdfea26469706673582212203af95082c259da89df993ce151da8ce3f9bd01f83b2bd46e03833ab8c3358c4a64736f6c63430008170033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000024000000000000000000000000056c4f0504f577a283073ab780b6850fec41213890000000000000000000000000000000000000000033b2e3c9fd0803ce80000000000000000000000000000000000000000000000036ccfbb244887eea40000000000000000000000000000000000000000000000000001043561a882930000000000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000177000000000000000000000000000000000000000000000001043561a88293000000000000000000000000000000000000000000000000000056bc75e2d631000000000000000000000000000000000000000000000000001969368974c05b000000000000000000000000000000000000000000000000010f0cf064dd592000000000000000000000000000000000000000000000000c380f8e0bc1c7ed0d305ab00000000000000000000000056c4f0504f577a283073ab780b6850fec41213890000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e1590000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d805903200000000000000000000000000000000000000000000000000000000000000084d6f6f6e73686f7400000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000054d53484f54000000000000000000000000000000000000000000000000000000
-----Decoded View---------------
Arg [0] : _params (tuple): System.Collections.Generic.List`1[Nethereum.ABI.FunctionEncoding.ParameterOutput]
-----Encoded View---------------
21 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000020
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000200
Arg [2] : 0000000000000000000000000000000000000000000000000000000000000240
Arg [3] : 00000000000000000000000056c4f0504f577a283073ab780b6850fec4121389
Arg [4] : 0000000000000000000000000000000000000000033b2e3c9fd0803ce8000000
Arg [5] : 0000000000000000000000000000000000000000036ccfbb244887eea4000000
Arg [6] : 0000000000000000000000000000000000000000000001043561a88293000000
Arg [7] : 0000000000000000000000000000000000000000000000000000000000000064
Arg [8] : 0000000000000000000000000000000000000000000000000000000000001770
Arg [9] : 00000000000000000000000000000000000000000000001043561a8829300000
Arg [10] : 0000000000000000000000000000000000000000000000056bc75e2d63100000
Arg [11] : 0000000000000000000000000000000000000000000001969368974c05b00000
Arg [12] : 0000000000000000000000000000000000000000000010f0cf064dd592000000
Arg [13] : 000000000000000000000000000000000000000000c380f8e0bc1c7ed0d305ab
Arg [14] : 00000000000000000000000056c4f0504f577a283073ab780b6850fec4121389
Arg [15] : 0000000000000000000000009f3a7410229510e45eced62db58ce4fb4a3e1590
Arg [16] : 000000000000000000000000377cee6040c7300c6b31ab0f17d3a6e5d8059032
Arg [17] : 0000000000000000000000000000000000000000000000000000000000000008
Arg [18] : 4d6f6f6e73686f74000000000000000000000000000000000000000000000000
Arg [19] : 0000000000000000000000000000000000000000000000000000000000000005
Arg [20] : 4d53484f54000000000000000000000000000000000000000000000000000000
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 30 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
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.