ETH Price: $1,972.37 (+0.19%)
Gas: 0.04 Gwei
 

Overview

Max Total Supply

1,000,000,000 SUPERGROK

Holders

1,594 ( 0.063%)

Market

Price

$0.00 @ 0.000000 ETH (+7.13%)

Onchain Market Cap

$39,660.00

Circulating Supply Market Cap

$39,656.00

Other Info

Token Contract (WITH 18 Decimals)

Balance
0.000000000001504263 SUPERGROK

Value
$0.00 ( ~0 Eth) [0.0000%]
0xd97c3d4e6f36d0aed73cf3bc83d38b9ce4ba91bc
Loading...
Loading
Loading...
Loading
Loading...
Loading

OVERVIEW

SUPERGROK is a meme based token inspired by SUPERGROK AI bot on X. Its been hyped recently with the release of companions and elon constantly tweeting about it.

# Exchange Pair Price  24H Volume % Volume

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

Contract Name:
Token

Compiler Version
v0.8.24+commit.e11b9ed9

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license
/**
 *Submitted for verification at Etherscan.io on 2025-07-04
*/

// SPDX-License-Identifier: MIT

// Deployed On TWAP.DEV

pragma solidity ^0.8.20;

interface IToken {
    function creator() external view returns (address);
}

interface IWETH {
    function withdraw(uint256 amount) external;
}

interface IUniswapV3Factory {
    function getPool(
        address tokenA,
        address tokenB,
        uint24 fee
    ) external view returns (address);
}

interface ISwapRouter02 {
    struct ExactInputSingleParams {
        address tokenIn;
        address tokenOut;
        uint24 fee;
        address recipient;
        uint256 amountIn;
        uint256 amountOutMinimum;
        uint160 sqrtPriceLimitX96;
    }

    function exactInputSingle(
        ExactInputSingleParams calldata params
    ) external payable returns (uint256 amountOut);
}

interface INonfungiblePositionManager {
    struct MintParams {
        address token0;
        address token1;
        uint24 fee;
        int24 tickLower;
        int24 tickUpper;
        uint256 amount0Desired;
        uint256 amount1Desired;
        uint256 amount0Min;
        uint256 amount1Min;
        address recipient;
        uint256 deadline;
    }

    function factory() external view returns (address);

    function WETH9() external view returns (address);

    function positions(
        uint256 tokenId
    )
        external
        view
        returns (
            uint96 nonce,
            address operator,
            address token0,
            address token1,
            uint24 fee,
            int24 tickLower,
            int24 tickUpper,
            uint128 liquidity,
            uint256 feeGrowthInside0LastX128,
            uint256 feeGrowthInside1LastX128,
            uint128 tokensOwed0,
            uint128 tokensOwed1
        );

    function createAndInitializePoolIfNecessary(
        address token0,
        address token1,
        uint24 fee,
        uint160 sqrtPriceX96
    ) external returns (address pool);

    function mint(
        MintParams calldata params
    )
        external
        returns (
            uint256 tokenId,
            uint128 liquidity,
            uint256 amount0,
            uint256 amount1
        );

    struct CollectParams {
        uint256 tokenId;
        address recipient;
        uint128 amount0Max;
        uint128 amount1Max;
    }

    function collect(
        CollectParams calldata params
    ) external payable returns (uint256 amount0, uint256 amount1);

    function getApproved(uint256 tokenId) external view returns (address);

    function isApprovedForAll(
        address owner,
        address operator
    ) external view returns (bool);

    function ownerOf(uint256 tokenId) external view returns (address);
}

contract Factory {
    event ERC20TokenCreated(address tokenAddress);
    event DeploymentStatusChanged(bool enabled);

    struct TokenInfo {
        address tokenAddress;
        string name;
        string symbol;
        address deployer;
        uint256 time;
        string metadata;
        uint256 marketCapInETH;
        uint24 feeTier;
    }

    mapping(uint256 => TokenInfo) public deployedTokens;
    uint256 public tokenCount = 0;
    address public platformController;

    bool private _isDeploymentActive = false;

    address public constant POSITION_MANAGER = 0xC36442b4a4522E871399CD717aBDD847Ab11FE88;
    address public constant WETH = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2;
    address public constant SWAP_ROUTER = 0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45;

    uint24 public constant FEE_TIER_LOW = 500;
    uint24 public constant FEE_TIER_MEDIUM = 3000;
    uint24 public constant FEE_TIER_HIGH = 10000;

    uint256 private constant VIRTUAL_ETH = 1.5 ether;

    event TokenPurchased(
        address buyer,
        address tokenOut,
        uint256 ethSpent,
        uint256 tokensReceived
    );

    mapping(uint24 => int24) private tickSpacings;

    INonfungiblePositionManager private immutable positionManager;

    constructor() {
        platformController = msg.sender;
        
        positionManager = INonfungiblePositionManager(POSITION_MANAGER);
        
        IERC20(WETH).approve(POSITION_MANAGER, type(uint256).max);
        IERC20(WETH).approve(SWAP_ROUTER, type(uint256).max);

        tickSpacings[FEE_TIER_LOW] = 10;
        tickSpacings[FEE_TIER_MEDIUM] = 60;
        tickSpacings[FEE_TIER_HIGH] = 200;
    }

    receive() external payable {}

    function isDeploymentActive() external view returns (bool) {
        return _isDeploymentActive;
    }

    function deployToken(
        string memory _name,
        string memory _symbol,
        string memory _metadata,
        bytes32 salt,
        uint24 feeTier
    ) public payable {
        require(_isDeploymentActive, "Token deployment is currently disabled");
        require(bytes(_name).length > 0, "Token name cannot be empty");
        require(bytes(_symbol).length > 0, "Token symbol cannot be empty");
        require(
            feeTier == FEE_TIER_LOW ||
                feeTier == FEE_TIER_MEDIUM ||
                feeTier == FEE_TIER_HIGH,
            "Invalid fee tier. Must be 500, 3000, or 10000"
        );

        Token t = new Token{salt: salt}(
            _name,
            _symbol,
            msg.sender,
            address(this)
        );
        emit ERC20TokenCreated(address(t));

        address token_address = address(t);
        provideLiquidity(token_address, WETH, feeTier);

        if (msg.value > 0) {
            uint256 taxBps = getPenalty(msg.value);
            uint256 tax = (msg.value * taxBps) / 10000;
            uint256 amountAfterTax = msg.value - tax;

            ISwapRouter02(SWAP_ROUTER).exactInputSingle{value: amountAfterTax}(
                ISwapRouter02.ExactInputSingleParams({
                    tokenIn: WETH,
                    tokenOut: token_address,
                    fee: feeTier,
                    recipient: msg.sender,
                    amountIn: amountAfterTax,
                    amountOutMinimum: 0,
                    sqrtPriceLimitX96: 0
                })
            );
        }

        deployedTokens[tokenCount] = TokenInfo({
            tokenAddress: token_address,
            name: _name,
            symbol: _symbol,
            deployer: msg.sender,
            time: block.timestamp,
            metadata: _metadata,
            marketCapInETH: 0,
            feeTier: feeTier
        });
        tokenCount++;
    }

    function getTokenBytecode(
        string memory _name,
        string memory _symbol,
        address creator
    ) public view returns (bytes memory bytecode) {
        bytecode = abi.encodePacked(
            type(Token).creationCode,
            abi.encode(_name, _symbol, creator, address(this))
        );
    }

    function getPenalty(uint256 ethAmount) public pure returns (uint256) {
        if (ethAmount < 0.08 ether) return 0;
        if (ethAmount >= 0.5 ether) return 2000;

        uint256 delta = ethAmount - 0.08 ether;
        uint256 deltaSquared = (delta * delta) / 1 ether;
        uint256 penalty = (deltaSquared * 11338) / 1 ether;

        return penalty;
    }

    function getTokensByPage(
        uint256 page,
        uint256 order
    ) public view returns (TokenInfo[] memory) {
        uint256 itemsPerPage = 80;
        require(tokenCount > 0, "No tokens deployed");

        uint256 totalPages = (tokenCount + itemsPerPage - 1) / itemsPerPage;
        require(page < totalPages, "Page out of range");

        uint256 start;
        uint256 end;
        uint256 j = 0;

        if (order == 0) {
            start = tokenCount > (page + 1) * itemsPerPage
                ? tokenCount - (page + 1) * itemsPerPage
                : 0;
            end = tokenCount - page * itemsPerPage;
            if (end > tokenCount) end = tokenCount;
        } else {
            start = page * itemsPerPage;
            end = start + itemsPerPage;
            if (end > tokenCount) end = tokenCount;
        }

        TokenInfo[] memory tokens = new TokenInfo[](end - start);
        address weth = positionManager.WETH9();
        address factory = positionManager.factory();

        for (uint256 i = start; i < end; i++) {
            uint256 index = order == 0 ? end - 1 - (i - start) : i;
            TokenInfo memory info = deployedTokens[index];

            uint256 marketCap = 0;
            address pool = IUniswapV3Factory(factory).getPool(
                info.tokenAddress,
                weth,
                info.feeTier
            );
            if (pool != address(0)) {
                uint256 wethInPool = IERC20(weth).balanceOf(pool);
                uint256 tokenInPool = IERC20(info.tokenAddress).balanceOf(pool);
                uint256 totalSupply = IERC20(info.tokenAddress).totalSupply();

                if (tokenInPool > 0) {
                    marketCap =
                        ((wethInPool + VIRTUAL_ETH) * totalSupply) /
                        tokenInPool;
                }
            }

            tokens[j++] = TokenInfo({
                tokenAddress: info.tokenAddress,
                name: info.name,
                symbol: info.symbol,
                deployer: info.deployer,
                time: info.time,
                metadata: info.metadata,
                marketCapInETH: marketCap,
                feeTier: info.feeTier
            });
        }

        return tokens;
    }

    function getTokens(uint256 page) public view returns (TokenInfo[] memory) {
        require(tokenCount > 0, "No tokens deployed");

        uint256 itemsPerPage = 2000;
        uint256 totalPages = (tokenCount + itemsPerPage - 1) / itemsPerPage;
        require(page < totalPages, "Page out of range");

        uint256 start = tokenCount > (page + 1) * itemsPerPage
            ? tokenCount - (page + 1) * itemsPerPage
            : 0;
        uint256 end = tokenCount - page * itemsPerPage;
        if (end > tokenCount) end = tokenCount;

        TokenInfo[] memory tokens = new TokenInfo[](end - start);

        for (uint256 i = start; i < end; i++) {
            uint256 index = end - 1 - (i - start);
            TokenInfo memory info = deployedTokens[index];

            tokens[i - start] = TokenInfo({
                tokenAddress: info.tokenAddress,
                name: info.name,
                symbol: info.symbol,
                deployer: info.deployer,
                time: info.time,
                metadata: info.metadata,
                marketCapInETH: 0,
                feeTier: info.feeTier
            });
        }

        return tokens;
    }

    function getTokenByAddress(
        address tokenAddress
    ) public view returns (TokenInfo memory) {
        require(tokenAddress != address(0), "Invalid token address");
        require(tokenCount > 0, "No tokens deployed");

        address weth = positionManager.WETH9();
        address factory = positionManager.factory();

        for (uint256 i = 0; i < tokenCount; i++) {
            TokenInfo memory info = deployedTokens[i];
            if (info.tokenAddress == tokenAddress) {
                uint256 marketCap = 0;
                address pool = IUniswapV3Factory(factory).getPool(
                    info.tokenAddress,
                    weth,
                    info.feeTier
                );
                if (pool != address(0)) {
                    uint256 wethInPool = IERC20(weth).balanceOf(pool);
                    uint256 tokenInPool = IERC20(info.tokenAddress).balanceOf(
                        pool
                    );
                    uint256 totalSupply = IERC20(info.tokenAddress)
                        .totalSupply();

                    if (tokenInPool > 0) {
                        marketCap =
                            ((wethInPool + VIRTUAL_ETH) * totalSupply) /
                            tokenInPool;
                    }
                }

                return
                    TokenInfo({
                        tokenAddress: info.tokenAddress,
                        name: info.name,
                        symbol: info.symbol,
                        deployer: info.deployer,
                        time: info.time,
                        metadata: info.metadata,
                        marketCapInETH: marketCap,
                        feeTier: info.feeTier
                    });
            }
        }

        revert("Token not found");
    }

    function getTokenByMetadata(
        string memory metadata
    ) public view returns (TokenInfo memory) {
        require(bytes(metadata).length > 0, "Invalid metadata");
        require(tokenCount > 0, "No tokens deployed");

        address weth = positionManager.WETH9();
        address factory = positionManager.factory();

        for (uint256 i = 0; i < tokenCount; i++) {
            TokenInfo memory info = deployedTokens[i];
            if (keccak256(bytes(info.metadata)) == keccak256(bytes(metadata))) {
                uint256 marketCap = 0;
                address pool = IUniswapV3Factory(factory).getPool(
                    info.tokenAddress,
                    weth,
                    info.feeTier
                );
                if (pool != address(0)) {
                    uint256 wethInPool = IERC20(weth).balanceOf(pool);
                    uint256 tokenInPool = IERC20(info.tokenAddress).balanceOf(
                        pool
                    );
                    uint256 totalSupply = IERC20(info.tokenAddress)
                        .totalSupply();

                    if (tokenInPool > 0) {
                        marketCap =
                            ((wethInPool + VIRTUAL_ETH) * totalSupply) /
                            tokenInPool;
                    }
                }

                return
                    TokenInfo({
                        tokenAddress: info.tokenAddress,
                        name: info.name,
                        symbol: info.symbol,
                        deployer: info.deployer,
                        time: info.time,
                        metadata: info.metadata,
                        marketCapInETH: marketCap,
                        feeTier: info.feeTier
                    });
            }
        }

        revert("Token not found");
    }

    function rescueWETH() external {
        require(msg.sender == platformController, "Caller is not controller");
        uint256 wethBalance = IERC20(WETH).balanceOf(address(this));
        require(wethBalance > 0, "No WETH to withdraw");

        IWETH(WETH).withdraw(wethBalance);

        (bool success, ) = msg.sender.call{value: wethBalance}("");
        require(success, "ETH transfer failed");
    }

    function rescueETH() external {
        require(msg.sender == platformController, "Caller is not controller");

        uint256 ethBalance = address(this).balance;
        require(ethBalance > 0, "No ETH to withdraw");

        (bool success, ) = msg.sender.call{value: ethBalance}("");
        require(success, "ETH transfer failed");
    }

    function toggleDeployToken() external {
        require(msg.sender == platformController, "Caller is not controller");
        _isDeploymentActive = !_isDeploymentActive;
        emit DeploymentStatusChanged(_isDeploymentActive);
    }

    function getTickSpacing(uint24 feeTier) internal view returns (int24) {
        return tickSpacings[feeTier];
    }

    function provideLiquidity(
        address tokenA,
        address tokenB,
        uint24 feeTier
    ) internal {
        bool tokenAIsToken0 = tokenA < tokenB;
        address token0 = tokenAIsToken0 ? tokenA : tokenB;
        address token1 = tokenAIsToken0 ? tokenB : tokenA;

        if (token0 == WETH) {
            IERC20(token1).approve(POSITION_MANAGER, type(uint256).max);
        } else {
            IERC20(token0).approve(POSITION_MANAGER, type(uint256).max);
        }

        uint160 sqrtPriceX96 = tokenAIsToken0
            ? 3068365595550320841079178
            : 2045645379722529521098596513701367;

        int24 tickSpacing = getTickSpacing(feeTier);

        int24 tickLower;
        int24 tickUpper;

        if (tokenAIsToken0) {
            tickLower = -203000;
            tickUpper = 887200;
        } else {
            tickLower = -887200;
            tickUpper = 203000;
        }

        tickLower = (tickLower / tickSpacing) * tickSpacing;
        tickUpper = (tickUpper / tickSpacing) * tickSpacing;

        uint256 amount0Desired = tokenAIsToken0
            ? 1000000000000000000000000000
            : 0;
        uint256 amount1Desired = tokenAIsToken0
            ? 0
            : 1000000000000000000000000000;

        positionManager.createAndInitializePoolIfNecessary(
            token0,
            token1,
            feeTier,
            sqrtPriceX96
        );

        positionManager.mint(
            INonfungiblePositionManager.MintParams({
                token0: token0,
                token1: token1,
                fee: feeTier,
                tickLower: tickLower,
                tickUpper: tickUpper,
                amount0Desired: amount0Desired,
                amount1Desired: amount1Desired,
                amount0Min: 0,
                amount1Min: 0,
                recipient: address(this),
                deadline: block.timestamp
            })
        );
    }

    function collectFees(
        uint256 tokenId
    ) external returns (uint256 amount0, uint256 amount1) {
        (
            ,
            ,
            address token0Raw,
            address token1Raw,
            ,
            ,
            ,
            ,
            ,
            ,
            ,
        ) = positionManager.positions(tokenId);

        require(
            token0Raw != address(0) && token1Raw != address(0),
            "Invalid tokenId: position does not exist"
        );

        address createdToken;
        address wethToken;

        if (token0Raw == WETH) {
            createdToken = token1Raw;
            wethToken = token0Raw;
        } else if (token1Raw == WETH) {
            createdToken = token0Raw;
            wethToken = token1Raw;
        } else {
            revert("Neither token is WETH");
        }

        address creator = IToken(createdToken).creator();
        require(
            msg.sender == creator || msg.sender == platformController,
            "Not authorized"
        );

        uint256 beforeCreatedToken = IERC20(createdToken).balanceOf(
            address(this)
        );
        uint256 beforeWETH = IERC20(wethToken).balanceOf(address(this));

        INonfungiblePositionManager.CollectParams
            memory params = INonfungiblePositionManager.CollectParams({
                tokenId: tokenId,
                recipient: address(this),
                amount0Max: type(uint128).max,
                amount1Max: type(uint128).max
            });

        positionManager.collect(params);

        uint256 collectedCreatedToken = IERC20(createdToken).balanceOf(
            address(this)
        ) - beforeCreatedToken;
        uint256 collectedWETH = IERC20(wethToken).balanceOf(address(this)) -
            beforeWETH;

        if (collectedCreatedToken > 0) {
            IERC20(createdToken).transfer(
                address(0x000000000000000000000000000000000000dEaD),
                collectedCreatedToken
            );
        }

        if (collectedWETH > 0) {
            uint256 half = collectedWETH / 2;

            IWETH(wethToken).withdraw(half);

            (bool success, ) = payable(creator).call{value: half}("");
            require(success, "ETH transfer to creator failed");
        }

        if (token0Raw == WETH) {
            return (collectedWETH, collectedCreatedToken);
        } else {
            return (collectedCreatedToken, collectedWETH);
        }
    }
}

interface IERC20Errors {
    error ERC20InsufficientBalance(
        address sender,
        uint256 balance,
        uint256 needed
    );
    error ERC20InvalidSender(address sender);
    error ERC20InvalidReceiver(address receiver);
    error ERC20InsufficientAllowance(
        address spender,
        uint256 allowance,
        uint256 needed
    );
    error ERC20InvalidApprover(address approver);
    error ERC20InvalidSpender(address spender);
}

interface IERC20 {
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );

    function totalSupply() external view returns (uint256);

    function balanceOf(address account) external view returns (uint256);

    function transfer(address to, uint256 value) external returns (bool);

    function allowance(
        address owner,
        address spender
    ) external view returns (uint256);

    function approve(address spender, uint256 value) external returns (bool);

    function transferFrom(
        address from,
        address to,
        uint256 value
    ) external returns (bool);
}

interface IERC20Metadata is IERC20 {
    function name() external view returns (string memory);

    function symbol() external view returns (string memory);

    function decimals() external view returns (uint8);
}

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

abstract contract ERC20 is Context, IERC20, IERC20Metadata, IERC20Errors {
    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    uint256 private _totalSupply;
    string private _name;
    string private _symbol;

    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    function name() public view virtual returns (string memory) {
        return _name;
    }

    function symbol() public view virtual returns (string memory) {
        return _symbol;
    }

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

    function totalSupply() public view virtual returns (uint256) {
        return _totalSupply;
    }

    function balanceOf(address account) public view virtual returns (uint256) {
        return _balances[account];
    }

    function transfer(address to, uint256 value) public virtual returns (bool) {
        address owner = _msgSender();
        _transfer(owner, to, value);
        return true;
    }

    function allowance(
        address owner,
        address spender
    ) public view virtual returns (uint256) {
        return _allowances[owner][spender];
    }

    function approve(
        address spender,
        uint256 value
    ) public virtual returns (bool) {
        address owner = _msgSender();
        _approve(owner, spender, value);
        return true;
    }

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

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

    function _update(address from, address to, uint256 value) internal virtual {
        if (from == address(0)) {
            _totalSupply += value;
        } else {
            uint256 fromBalance = _balances[from];
            if (fromBalance < value) {
                revert ERC20InsufficientBalance(from, fromBalance, value);
            }
            unchecked {
                _balances[from] = fromBalance - value;
            }
        }

        if (to == address(0)) {
            unchecked {
                _totalSupply -= value;
            }
        } else {
            unchecked {
                _balances[to] += value;
            }
        }

        emit Transfer(from, to, value);
    }

    function _mint(address account, uint256 value) internal {
        if (account == address(0)) {
            revert ERC20InvalidReceiver(address(0));
        }
        _update(address(0), account, value);
    }

    function _burn(address account, uint256 value) internal {
        if (account == address(0)) {
            revert ERC20InvalidSender(address(0));
        }
        _update(account, address(0), value);
    }

    function _approve(address owner, address spender, uint256 value) internal {
        _approve(owner, spender, value, true);
    }

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

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

abstract contract ERC20Burnable is Context, ERC20 {
    function burn(uint256 value) public virtual {
        _burn(_msgSender(), value);
    }

    function burnFrom(address account, uint256 value) public virtual {
        _spendAllowance(account, _msgSender(), value);
        _burn(account, value);
    }
}

contract Token is ERC20, ERC20Burnable {
    address public platform;
    address public creator;
    uint256 private launchTime;
    uint256 private maxTxAmount;
    uint256 private constant INITIAL_TIMELOCK = 60;
    uint256 private constant WALLET_CAP_PERCENT = 2;

    constructor(
        string memory _name,
        string memory _symbol,
        address _creator,
        address _platform
    ) ERC20(_name, _symbol) {
        uint256 totalTokens = 1000000000 * 10 ** decimals();

        platform = _platform;
        creator = _creator;
        launchTime = block.timestamp;
        maxTxAmount = (totalTokens * WALLET_CAP_PERCENT) / 100;

        _mint(_platform, totalTokens);
    }

    function _update(
        address from,
        address to,
        uint256 value
    ) internal override {
        if (
            from == address(0) ||
            to == address(0) ||
            to == creator ||
            to == platform ||
            from == platform
        ) {
            super._update(from, to, value);
            return;
        }

        uint256 currentTime = block.timestamp;

        if (currentTime == launchTime) revert("No buys at launch block");

        if (
            currentTime < launchTime + INITIAL_TIMELOCK &&
            balanceOf(to) + value > maxTxAmount
        ) {
            revert("Max 2% wallet limit during launch");
        }

        super._update(from, to, value);
    }

    function isLaunchPeriodActive() public view returns (bool) {
        return block.timestamp < launchTime + INITIAL_TIMELOCK;
    }
}

Contract Security Audit

Contract ABI

API
[{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"},{"internalType":"address","name":"_creator","type":"address"},{"internalType":"address","name":"_platform","type":"address"}],"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"},{"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":[{"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":[],"name":"creator","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isLaunchPeriodActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"platform","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":"value","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"}]

0x608060405234801562000010575f80fd5b50604051620011dd380380620011dd8339810160408190526200003391620004cd565b83836003620000438382620005e0565b506004620000528282620005e0565b5050505f62000066620000ee60201b60201c565b6200007390600a620007bb565b6200008390633b9aca00620007d2565b600580546001600160a01b038086166001600160a01b03199283161790925560068054928716929091169190911790554260075590506064620000c8600283620007d2565b620000d49190620007ec565b600855620000e38282620000f3565b505050505062000822565b601290565b6001600160a01b038216620001225760405163ec442f0560e01b81525f60048201526024015b60405180910390fd5b6200012f5f838362000133565b5050565b6001600160a01b03831615806200015157506001600160a01b038216155b806200016a57506006546001600160a01b038381169116145b806200018357506005546001600160a01b038381169116145b806200019c57506005546001600160a01b038481169116145b15620001b457620001af838383620002c1565b505050565b60075442908103620002095760405162461bcd60e51b815260206004820152601760248201527f4e6f2062757973206174206c61756e636820626c6f636b000000000000000000604482015260640162000119565b603c6007546200021a91906200080c565b811080156200025557506008548262000247856001600160a01b03165f9081526020819052604090205490565b6200025391906200080c565b115b15620002ae5760405162461bcd60e51b815260206004820152602160248201527f4d61782032252077616c6c6574206c696d697420647572696e67206c61756e636044820152600d60fb1b606482015260840162000119565b620002bb848484620002c1565b50505050565b6001600160a01b038316620002ef578060025f828254620002e391906200080c565b90915550620003619050565b6001600160a01b0383165f9081526020819052604090205481811015620003435760405163391434e360e21b81526001600160a01b0385166004820152602481018290526044810183905260640162000119565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b0382166200037f576002805482900390556200039d565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051620003e391815260200190565b60405180910390a3505050565b634e487b7160e01b5f52604160045260245ffd5b5f82601f83011262000414575f80fd5b81516001600160401b0380821115620004315762000431620003f0565b604051601f8301601f19908116603f011681019082821181831017156200045c576200045c620003f0565b816040528381526020925086602085880101111562000479575f80fd5b5f91505b838210156200049c57858201830151818301840152908201906200047d565b5f602085830101528094505050505092915050565b80516001600160a01b0381168114620004c8575f80fd5b919050565b5f805f8060808587031215620004e1575f80fd5b84516001600160401b0380821115620004f8575f80fd5b620005068883890162000404565b955060208701519150808211156200051c575f80fd5b506200052b8782880162000404565b9350506200053c60408601620004b1565b91506200054c60608601620004b1565b905092959194509250565b600181811c908216806200056c57607f821691505b6020821081036200058b57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f821115620001af57805f5260205f20601f840160051c81016020851015620005b85750805b601f840160051c820191505b81811015620005d9575f8155600101620005c4565b5050505050565b81516001600160401b03811115620005fc57620005fc620003f0565b62000614816200060d845462000557565b8462000591565b602080601f8311600181146200064a575f8415620006325750858301515b5f19600386901b1c1916600185901b178555620006a4565b5f85815260208120601f198616915b828110156200067a5788860151825594840194600190910190840162000659565b50858210156200069857878501515f19600388901b60f8161c191681555b505060018460011b0185555b505050505050565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156200070057815f1904821115620006e457620006e4620006ac565b80851615620006f257918102915b93841c9390800290620006c5565b509250929050565b5f826200071857506001620007b5565b816200072657505f620007b5565b81600181146200073f57600281146200074a576200076a565b6001915050620007b5565b60ff8411156200075e576200075e620006ac565b50506001821b620007b5565b5060208310610133831016604e8410600b84101617156200078f575081810a620007b5565b6200079b8383620006c0565b805f1904821115620007b157620007b1620006ac565b0290505b92915050565b5f620007cb60ff84168362000708565b9392505050565b8082028115828204841417620007b557620007b5620006ac565b5f826200080757634e487b7160e01b5f52601260045260245ffd5b500490565b80820180821115620007b557620007b5620006ac565b6109ad80620008305f395ff3fe608060405234801561000f575f80fd5b50600436106100e5575f3560e01c806342966c681161008857806379cc67901161006357806379cc6790146101dd57806395d89b41146101f0578063a9059cbb146101f8578063dd62ed3e1461020b575f80fd5b806342966c681461018d5780634bde38c8146101a257806370a08231146101b5575f80fd5b806318160ddd116100c357806318160ddd1461015157806323b872dd146101635780632f4237c014610176578063313ce5671461017e575f80fd5b806302d05d3f146100e957806306fdde0314610119578063095ea7b31461012e575b5f80fd5b6006546100fc906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b610121610243565b60405161011091906107f0565b61014161013c366004610857565b6102d3565b6040519015158152602001610110565b6002545b604051908152602001610110565b61014161017136600461087f565b6102ec565b61014161030f565b60405160128152602001610110565b6101a061019b3660046108b8565b610326565b005b6005546100fc906001600160a01b031681565b6101556101c33660046108cf565b6001600160a01b03165f9081526020819052604090205490565b6101a06101eb366004610857565b610333565b61012161034c565b610141610206366004610857565b61035b565b6101556102193660046108ef565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b60606003805461025290610920565b80601f016020809104026020016040519081016040528092919081815260200182805461027e90610920565b80156102c95780601f106102a0576101008083540402835291602001916102c9565b820191905f5260205f20905b8154815290600101906020018083116102ac57829003601f168201915b5050505050905090565b5f336102e0818585610368565b60019150505b92915050565b5f336102f985828561037a565b6103048585856103fb565b506001949350505050565b5f603c60075461031f9190610958565b4210905090565b6103303382610458565b50565b61033e82338361037a565b6103488282610458565b5050565b60606004805461025290610920565b5f336102e08185856103fb565b610375838383600161048c565b505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f198110156103f557818110156103e757604051637dc7a0d960e11b81526001600160a01b038416600482015260248101829052604481018390526064015b60405180910390fd5b6103f584848484035f61048c565b50505050565b6001600160a01b03831661042457604051634b637e8f60e11b81525f60048201526024016103de565b6001600160a01b03821661044d5760405163ec442f0560e01b81525f60048201526024016103de565b61037583838361055e565b6001600160a01b03821661048157604051634b637e8f60e11b81525f60048201526024016103de565b610348825f8361055e565b6001600160a01b0384166104b55760405163e602df0560e01b81525f60048201526024016103de565b6001600160a01b0383166104de57604051634a1406b160e11b81525f60048201526024016103de565b6001600160a01b038085165f90815260016020908152604080832093871683529290522082905580156103f557826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258460405161055091815260200190565b60405180910390a350505050565b6001600160a01b038316158061057b57506001600160a01b038216155b8061059357506006546001600160a01b038381169116145b806105ab57506005546001600160a01b038381169116145b806105c357506005546001600160a01b038481169116145b156105d3576103758383836106ca565b600754429081036106265760405162461bcd60e51b815260206004820152601760248201527f4e6f2062757973206174206c61756e636820626c6f636b00000000000000000060448201526064016103de565b603c6007546106359190610958565b8110801561066c575060085482610660856001600160a01b03165f9081526020819052604090205490565b61066a9190610958565b115b156106c35760405162461bcd60e51b815260206004820152602160248201527f4d61782032252077616c6c6574206c696d697420647572696e67206c61756e636044820152600d60fb1b60648201526084016103de565b6103f58484845b6001600160a01b0383166106f4578060025f8282546106e99190610958565b909155506107649050565b6001600160a01b0383165f90815260208190526040902054818110156107465760405163391434e360e21b81526001600160a01b038516600482015260248101829052604481018390526064016103de565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b0382166107805760028054829003905561079e565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516107e391815260200190565b60405180910390a3505050565b5f602080835283518060208501525f5b8181101561081c57858101830151858201604001528201610800565b505f604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610852575f80fd5b919050565b5f8060408385031215610868575f80fd5b6108718361083c565b946020939093013593505050565b5f805f60608486031215610891575f80fd5b61089a8461083c565b92506108a86020850161083c565b9150604084013590509250925092565b5f602082840312156108c8575f80fd5b5035919050565b5f602082840312156108df575f80fd5b6108e88261083c565b9392505050565b5f8060408385031215610900575f80fd5b6109098361083c565b91506109176020840161083c565b90509250929050565b600181811c9082168061093457607f821691505b60208210810361095257634e487b7160e01b5f52602260045260245ffd5b50919050565b808201808211156102e657634e487b7160e01b5f52601160045260245ffdfea264697066735822122069dc1eb441152a81907d2620f15ca4cb3e69b766dd97115bd700015d772cc62e64736f6c63430008180033000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000c000000000000000000000000019c89c76270fd64b64ff6fff8edb62ce9407511a000000000000000000000000f3f94d4339437befacc1a703239fa706d9a5deff0000000000000000000000000000000000000000000000000000000000000009537570657247726f6b00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000009535550455247524f4b0000000000000000000000000000000000000000000000

Deployed Bytecode

0x608060405234801561000f575f80fd5b50600436106100e5575f3560e01c806342966c681161008857806379cc67901161006357806379cc6790146101dd57806395d89b41146101f0578063a9059cbb146101f8578063dd62ed3e1461020b575f80fd5b806342966c681461018d5780634bde38c8146101a257806370a08231146101b5575f80fd5b806318160ddd116100c357806318160ddd1461015157806323b872dd146101635780632f4237c014610176578063313ce5671461017e575f80fd5b806302d05d3f146100e957806306fdde0314610119578063095ea7b31461012e575b5f80fd5b6006546100fc906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b610121610243565b60405161011091906107f0565b61014161013c366004610857565b6102d3565b6040519015158152602001610110565b6002545b604051908152602001610110565b61014161017136600461087f565b6102ec565b61014161030f565b60405160128152602001610110565b6101a061019b3660046108b8565b610326565b005b6005546100fc906001600160a01b031681565b6101556101c33660046108cf565b6001600160a01b03165f9081526020819052604090205490565b6101a06101eb366004610857565b610333565b61012161034c565b610141610206366004610857565b61035b565b6101556102193660046108ef565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b60606003805461025290610920565b80601f016020809104026020016040519081016040528092919081815260200182805461027e90610920565b80156102c95780601f106102a0576101008083540402835291602001916102c9565b820191905f5260205f20905b8154815290600101906020018083116102ac57829003601f168201915b5050505050905090565b5f336102e0818585610368565b60019150505b92915050565b5f336102f985828561037a565b6103048585856103fb565b506001949350505050565b5f603c60075461031f9190610958565b4210905090565b6103303382610458565b50565b61033e82338361037a565b6103488282610458565b5050565b60606004805461025290610920565b5f336102e08185856103fb565b610375838383600161048c565b505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f198110156103f557818110156103e757604051637dc7a0d960e11b81526001600160a01b038416600482015260248101829052604481018390526064015b60405180910390fd5b6103f584848484035f61048c565b50505050565b6001600160a01b03831661042457604051634b637e8f60e11b81525f60048201526024016103de565b6001600160a01b03821661044d5760405163ec442f0560e01b81525f60048201526024016103de565b61037583838361055e565b6001600160a01b03821661048157604051634b637e8f60e11b81525f60048201526024016103de565b610348825f8361055e565b6001600160a01b0384166104b55760405163e602df0560e01b81525f60048201526024016103de565b6001600160a01b0383166104de57604051634a1406b160e11b81525f60048201526024016103de565b6001600160a01b038085165f90815260016020908152604080832093871683529290522082905580156103f557826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258460405161055091815260200190565b60405180910390a350505050565b6001600160a01b038316158061057b57506001600160a01b038216155b8061059357506006546001600160a01b038381169116145b806105ab57506005546001600160a01b038381169116145b806105c357506005546001600160a01b038481169116145b156105d3576103758383836106ca565b600754429081036106265760405162461bcd60e51b815260206004820152601760248201527f4e6f2062757973206174206c61756e636820626c6f636b00000000000000000060448201526064016103de565b603c6007546106359190610958565b8110801561066c575060085482610660856001600160a01b03165f9081526020819052604090205490565b61066a9190610958565b115b156106c35760405162461bcd60e51b815260206004820152602160248201527f4d61782032252077616c6c6574206c696d697420647572696e67206c61756e636044820152600d60fb1b60648201526084016103de565b6103f58484845b6001600160a01b0383166106f4578060025f8282546106e99190610958565b909155506107649050565b6001600160a01b0383165f90815260208190526040902054818110156107465760405163391434e360e21b81526001600160a01b038516600482015260248101829052604481018390526064016103de565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b0382166107805760028054829003905561079e565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516107e391815260200190565b60405180910390a3505050565b5f602080835283518060208501525f5b8181101561081c57858101830151858201604001528201610800565b505f604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610852575f80fd5b919050565b5f8060408385031215610868575f80fd5b6108718361083c565b946020939093013593505050565b5f805f60608486031215610891575f80fd5b61089a8461083c565b92506108a86020850161083c565b9150604084013590509250925092565b5f602082840312156108c8575f80fd5b5035919050565b5f602082840312156108df575f80fd5b6108e88261083c565b9392505050565b5f8060408385031215610900575f80fd5b6109098361083c565b91506109176020840161083c565b90509250929050565b600181811c9082168061093457607f821691505b60208210810361095257634e487b7160e01b5f52602260045260245ffd5b50919050565b808201808211156102e657634e487b7160e01b5f52601160045260245ffdfea264697066735822122069dc1eb441152a81907d2620f15ca4cb3e69b766dd97115bd700015d772cc62e64736f6c63430008180033

Deployed Bytecode Sourcemap

27160:1626:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27236:22;;;;;-1:-1:-1;;;;;27236:22:0;;;;;;-1:-1:-1;;;;;178:32:1;;;160:51;;148:2;133:18;27236:22:0;;;;;;;;22697:91;;;:::i;:::-;;;;;;;:::i;23589:215::-;;;;;;:::i;:::-;;:::i;:::-;;;1377:14:1;;1370:22;1352:41;;1340:2;1325:18;23589:215:0;1212:187:1;22991:99:0;23070:12;;22991:99;;;1550:25:1;;;1538:2;1523:18;22991:99:0;1404:177:1;23812:283:0;;;;;;:::i;:::-;;:::i;28651:132::-;;;:::i;22899:84::-;;;22973:2;2061:36:1;;2049:2;2034:18;22899:84:0;1919:184:1;26895:89:0;;;;;;:::i;:::-;;:::i;:::-;;27206:23;;;;;-1:-1:-1;;;;;27206:23:0;;;23098:118;;;;;;:::i;:::-;-1:-1:-1;;;;;23190:18:0;23163:7;23190:18;;;;;;;;;;;;23098:118;26992:161;;;;;;:::i;:::-;;:::i;22796:95::-;;;:::i;23224:182::-;;;;;;:::i;:::-;;:::i;23414:167::-;;;;;;:::i;:::-;-1:-1:-1;;;;;23546:18:0;;;23519:7;23546:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;23414:167;22697:91;22742:13;22775:5;22768:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22697:91;:::o;23589:215::-;23687:4;22033:10;23743:31;22033:10;23759:7;23768:5;23743:8;:31::i;:::-;23792:4;23785:11;;;23589:215;;;;;:::o;23812:283::-;23933:4;22033:10;23991:37;24007:4;22033:10;24022:5;23991:15;:37::i;:::-;24039:26;24049:4;24055:2;24059:5;24039:9;:26::i;:::-;-1:-1:-1;24083:4:0;;23812:283;-1:-1:-1;;;;23812:283:0:o;28651:132::-;28704:4;27376:2;28746:10;;:29;;;;:::i;:::-;28728:15;:47;28721:54;;28651:132;:::o;26895:89::-;26950:26;22033:10;26970:5;26950;:26::i;:::-;26895:89;:::o;26992:161::-;27068:45;27084:7;22033:10;27107:5;27068:15;:45::i;:::-;27124:21;27130:7;27139:5;27124;:21::i;:::-;26992:161;;:::o;22796:95::-;22843:13;22876:7;22869:14;;;;;:::i;23224:182::-;23293:4;22033:10;23349:27;22033:10;23366:2;23370:5;23349:9;:27::i;25597:130::-;25682:37;25691:5;25698:7;25707:5;25714:4;25682:8;:37::i;:::-;25597:130;;;:::o;26229:602::-;-1:-1:-1;;;;;23546:18:0;;;26363:24;23546:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;-1:-1:-1;;26430:36:0;;26426:398;;;26506:5;26487:16;:24;26483:214;;;26539:142;;-1:-1:-1;;;26539:142:0;;-1:-1:-1;;;;;3581:32:1;;26539:142:0;;;3563:51:1;3630:18;;;3623:34;;;3673:18;;;3666:34;;;3536:18;;26539:142:0;;;;;;;;26483:214;26740:57;26749:5;26756:7;26784:5;26765:16;:24;26791:5;26740:8;:57::i;:::-;26352:479;26229:602;;;:::o;24103:308::-;-1:-1:-1;;;;;24187:18:0;;24183:88;;24229:30;;-1:-1:-1;;;24229:30:0;;24256:1;24229:30;;;160:51:1;133:18;;24229:30:0;14:203:1;24183:88:0;-1:-1:-1;;;;;24285:16:0;;24281:88;;24325:32;;-1:-1:-1;;;24325:32:0;;24354:1;24325:32;;;160:51:1;133:18;;24325:32:0;14:203:1;24281:88:0;24379:24;24387:4;24393:2;24397:5;24379:7;:24::i;25378:211::-;-1:-1:-1;;;;;25449:21:0;;25445:91;;25494:30;;-1:-1:-1;;;25494:30:0;;25521:1;25494:30;;;160:51:1;133:18;;25494:30:0;14:203:1;25445:91:0;25546:35;25554:7;25571:1;25575:5;25546:7;:35::i;25735:486::-;-1:-1:-1;;;;;25891:19:0;;25887:91;;25934:32;;-1:-1:-1;;;25934:32:0;;25963:1;25934:32;;;160:51:1;133:18;;25934:32:0;14:203:1;25887:91:0;-1:-1:-1;;;;;25992:21:0;;25988:92;;26037:31;;-1:-1:-1;;;26037:31:0;;26065:1;26037:31;;;160:51:1;133:18;;26037:31:0;14:203:1;25988:92:0;-1:-1:-1;;;;;26090:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;:35;;;26136:78;;;;26187:7;-1:-1:-1;;;;;26171:31:0;26180:5;-1:-1:-1;;;;;26171:31:0;;26196:5;26171:31;;;;1550:25:1;;1538:2;1523:18;;1404:177;26171:31:0;;;;;;;;25735:486;;;;:::o;27885:758::-;-1:-1:-1;;;;;28024:18:0;;;;:51;;-1:-1:-1;;;;;;28059:16:0;;;28024:51;:81;;;-1:-1:-1;28098:7:0;;-1:-1:-1;;;;;28092:13:0;;;28098:7;;28092:13;28024:81;:112;;;-1:-1:-1;28128:8:0;;-1:-1:-1;;;;;28122:14:0;;;28128:8;;28122:14;28024:112;:145;;;-1:-1:-1;28161:8:0;;-1:-1:-1;;;;;28153:16:0;;;28161:8;;28153:16;28024:145;28006:253;;;28196:30;28210:4;28216:2;28220:5;28196:13;:30::i;28006:253::-;28340:10;;28293:15;;28325:25;;28321:64;;28352:33;;-1:-1:-1;;;28352:33:0;;3913:2:1;28352:33:0;;;3895:21:1;3952:2;3932:18;;;3925:30;3991:25;3971:18;;;3964:53;4034:18;;28352:33:0;3711:347:1;28321:64:0;27376:2;28430:10;;:29;;;;:::i;:::-;28416:11;:43;:95;;;;;28500:11;;28492:5;28476:13;28486:2;-1:-1:-1;;;;;23190:18:0;23163:7;23190:18;;;;;;;;;;;;23098:118;28476:13;:21;;;;:::i;:::-;:35;28416:95;28398:195;;;28538:43;;-1:-1:-1;;;28538:43:0;;4265:2:1;28538:43:0;;;4247:21:1;4304:2;4284:18;;;4277:30;4343:34;4323:18;;;4316:62;-1:-1:-1;;;4394:18:1;;;4387:31;4435:19;;28538:43:0;4063:397:1;28398:195:0;28605:30;28619:4;28625:2;28629:5;24419:730;-1:-1:-1;;;;;24509:18:0;;24505:369;;24560:5;24544:12;;:21;;;;;;;:::i;:::-;;;;-1:-1:-1;24505:369:0;;-1:-1:-1;24505:369:0;;-1:-1:-1;;;;;24620:15:0;;24598:19;24620:15;;;;;;;;;;;24654:19;;;24650:117;;;24701:50;;-1:-1:-1;;;24701:50:0;;-1:-1:-1;;;;;3581:32:1;;24701:50:0;;;3563:51:1;3630:18;;;3623:34;;;3673:18;;;3666:34;;;3536:18;;24701:50:0;3361:345:1;24650:117:0;-1:-1:-1;;;;;24810:15:0;;:9;:15;;;;;;;;;;24828:19;;;;24810:37;;24505:369;-1:-1:-1;;;;;24890:16:0;;24886:213;;24952:12;:21;;;;;;;24886:213;;;-1:-1:-1;;;;;25050:13:0;;:9;:13;;;;;;;;;;:22;;;;;;24886:213;25131:2;-1:-1:-1;;;;;25116:25:0;25125:4;-1:-1:-1;;;;;25116:25:0;;25135:5;25116:25;;;;1550::1;;1538:2;1523:18;;1404:177;25116:25:0;;;;;;;;24419:730;;;:::o;222:548:1:-;334:4;363:2;392;381:9;374:21;424:6;418:13;467:6;462:2;451:9;447:18;440:34;492:1;502:140;516:6;513:1;510:13;502:140;;;611:14;;;607:23;;601:30;577:17;;;596:2;573:26;566:66;531:10;;502:140;;;506:3;691:1;686:2;677:6;666:9;662:22;658:31;651:42;761:2;754;750:7;745:2;737:6;733:15;729:29;718:9;714:45;710:54;702:62;;;;222:548;;;;:::o;775:173::-;843:20;;-1:-1:-1;;;;;892:31:1;;882:42;;872:70;;938:1;935;928:12;872:70;775:173;;;:::o;953:254::-;1021:6;1029;1082:2;1070:9;1061:7;1057:23;1053:32;1050:52;;;1098:1;1095;1088:12;1050:52;1121:29;1140:9;1121:29;:::i;:::-;1111:39;1197:2;1182:18;;;;1169:32;;-1:-1:-1;;;953:254:1:o;1586:328::-;1663:6;1671;1679;1732:2;1720:9;1711:7;1707:23;1703:32;1700:52;;;1748:1;1745;1738:12;1700:52;1771:29;1790:9;1771:29;:::i;:::-;1761:39;;1819:38;1853:2;1842:9;1838:18;1819:38;:::i;:::-;1809:48;;1904:2;1893:9;1889:18;1876:32;1866:42;;1586:328;;;;;:::o;2108:180::-;2167:6;2220:2;2208:9;2199:7;2195:23;2191:32;2188:52;;;2236:1;2233;2226:12;2188:52;-1:-1:-1;2259:23:1;;2108:180;-1:-1:-1;2108:180:1:o;2293:186::-;2352:6;2405:2;2393:9;2384:7;2380:23;2376:32;2373:52;;;2421:1;2418;2411:12;2373:52;2444:29;2463:9;2444:29;:::i;:::-;2434:39;2293:186;-1:-1:-1;;;2293:186:1:o;2484:260::-;2552:6;2560;2613:2;2601:9;2592:7;2588:23;2584:32;2581:52;;;2629:1;2626;2619:12;2581:52;2652:29;2671:9;2652:29;:::i;:::-;2642:39;;2700:38;2734:2;2723:9;2719:18;2700:38;:::i;:::-;2690:48;;2484:260;;;;;:::o;2749:380::-;2828:1;2824:12;;;;2871;;;2892:61;;2946:4;2938:6;2934:17;2924:27;;2892:61;2999:2;2991:6;2988:14;2968:18;2965:38;2962:161;;3045:10;3040:3;3036:20;3033:1;3026:31;3080:4;3077:1;3070:15;3108:4;3105:1;3098:15;2962:161;;2749:380;;;:::o;3134:222::-;3199:9;;;3220:10;;;3217:133;;;3272:10;3267:3;3263:20;3260:1;3253:31;3307:4;3304:1;3297:15;3335:4;3332:1;3325:15

Swarm Source

ipfs://69dc1eb441152a81907d2620f15ca4cb3e69b766dd97115bd700015d772cc62e
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.