Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xADfafBf05d3D74aF537bDEC348Ce4e536d99fb95
Balance 0 ETH
Nonce 1
Code Size 5662 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

5662 bytes
0x608060405234801561001057600080fd5b506004361061014d5760003560e01c80638da5cb5b116100c3578063d29dad831161007c578063d29dad83146102b4578063d8fb9337146102c7578063dd62ed3e146102fd578063de6baccb14610336578063e20bc67b14610349578063f2fde38b1461035c57600080fd5b80638da5cb5b1461023057806395d89b411461024b578063a457c2d714610253578063a9059cbb14610266578063b2520a7c14610279578063d1c46916146102a157600080fd5b8063395093511161011557806339509351146101c757806342966c68146101da57806370a08231146101ef578063715018a61461020257806379cc67901461020a5780637eee288d1461021d57600080fd5b806306fdde0314610152578063095ea7b31461017057806318160ddd1461019357806323b872dd146101a5578063313ce567146101b8575b600080fd5b61015a61036f565b6040516101679190611329565b60405180910390f35b61018361017e366004611393565b610401565b6040519015158152602001610167565b6002545b604051908152602001610167565b6101836101b33660046113bd565b610418565b60405160128152602001610167565b6101836101d5366004611393565b6104c0565b6101ed6101e83660046113f9565b6104fc565b005b6101976101fd366004611412565b610509565b6101ed6105b1565b6101ed610218366004611393565b610625565b61018361022b366004611393565b61069f565b6005546040516001600160a01b039091168152602001610167565b61015a610747565b610183610261366004611393565b610756565b610183610274366004611393565b6107d7565b61028c610287366004611393565b610862565b60408051928352602083019190915201610167565b6101836102af366004611412565b6108c9565b6101976102c2366004611412565b6109a2565b61028c6102d5366004611412565b6001600160a01b03166000908152600760209081526040808320546006909252909120549091565b61019761030b366004611434565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b610183610344366004611467565b6109c0565b610183610357366004611412565b610a21565b6101ed61036a366004611412565b610aa8565b60606003805461037e9061149a565b80601f01602080910402602001604051908101604052809291908181526020018280546103aa9061149a565b80156103f75780601f106103cc576101008083540402835291602001916103f7565b820191906000526020600020905b8154815290600101906020018083116103da57829003601f168201915b5050505050905090565b600061040e338484610b84565b5060015b92915050565b6001600160a01b0383166000908152600660205260408120548490839080156104465761044483610a21565b505b6001600160a01b03831660009081526007602052604090205461046a9083906114ea565b6001600160a01b03841660009081526020819052604090205410156104aa5760405162461bcd60e51b81526004016104a1906114fd565b60405180910390fd5b6104b5878787610c92565b979650505050505050565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161040e9185906104f79086906114ea565b610b84565b6105063382610d2a565b50565b6001600160a01b038116600090815260208181526040808320546007835281842054600690935290832054909183918184101561054557600080fd5b80156105925760005b81811015610590576000806105638984610862565b9150915042821161057b5761057881876114ea565b95505b5050808061058890611542565b91505061054e565b505b8261059d838661155b565b6105a791906114ea565b9695505050505050565b6005546001600160a01b031633146105db5760405162461bcd60e51b81526004016104a19061156e565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6000610631833361030b565b9050818110156106835760405162461bcd60e51b815260206004820152601d60248201527f4275726e20616d6f756e74206578636565647320616c6c6f77616e636500000060448201526064016104a1565b6106908333848403610b84565b61069a8383610d2a565b505050565b6005546000906001600160a01b031633146106cc5760405162461bcd60e51b81526004016104a19061156e565b6001600160a01b03831660009081526006602052604090205482106107335760405162461bcd60e51b815260206004820152601d60248201527f5468657265206973206e6f206c6f636b20696e666f726d6174696f6e2e00000060448201526064016104a1565b61073d8383610e5b565b5060019392505050565b60606004805461037e9061149a565b3360009081526001602090815260408083206001600160a01b0386168452909152812054828110156107ca5760405162461bcd60e51b815260206004820152601e60248201527f44656372656173656420616c6c6f77616e63652062656c6f77207a65726f000060448201526064016104a1565b61073d3385858403610b84565b33600081815260066020526040812054909190839080156107fd576107fb83610a21565b505b6001600160a01b0383166000908152600760205260409020546108219083906114ea565b6001600160a01b03841660009081526020819052604090205410156108585760405162461bcd60e51b81526004016104a1906114fd565b6105a78686611016565b6001600160a01b038216600090815260066020526040812080548291829185908110610890576108906115a5565b60009182526020918290206040805180820190915260029092020180548083526001909101549190920181905290969095509350505050565b6005546000906001600160a01b031633146108f65760405162461bcd60e51b81526004016104a19061156e565b6001600160a01b03821660009081526006602052604090205461095b5760405162461bcd60e51b815260206004820152601d60248201527f5468657265206973206e6f206c6f636b20696e666f726d6174696f6e2e00000060448201526064016104a1565b6001600160a01b0382166000908152600660205260409020545b801561040e5761098f8361098a60018461155b565b610e5b565b508061099a816115bb565b915050610975565b6001600160a01b038116600090815260208190526040812054610412565b6005546000906001600160a01b031633146109ed5760405162461bcd60e51b81526004016104a19061156e565b6001600160a01b038416610a0057600080fd5b610a0b33858561101f565b610a168484846111c5565b506001949350505050565b6000805b6001600160a01b03831660009081526006602052604090205481101561040e576001600160a01b0383166000908152600660205260409020805442919083908110610a7257610a726115a5565b9060005260206000209060020201600001541015610a9657610a948382610e5b565b505b80610aa081611542565b915050610a25565b6005546001600160a01b03163314610ad25760405162461bcd60e51b81526004016104a19061156e565b6001600160a01b038116610b285760405162461bcd60e51b815260206004820152601d60248201527f4e6577206f776e657220697320746865207a65726f206164647265737300000060448201526064016104a1565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610bda5760405162461bcd60e51b815260206004820152601d60248201527f417070726f76652066726f6d20746865207a65726f206164647265737300000060448201526064016104a1565b6001600160a01b038216610c305760405162461bcd60e51b815260206004820152601b60248201527f417070726f766520746f20746865207a65726f2061646472657373000000000060448201526064016104a1565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6000610c9f84848461101f565b6001600160a01b038416600090815260016020908152604080832033845290915290205482811015610d1d5760405162461bcd60e51b815260206004820152602160248201527f5472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636044820152606560f81b60648201526084016104a1565b610a168533858403610b84565b6001600160a01b038216610d805760405162461bcd60e51b815260206004820152601a60248201527f4275726e2066726f6d20746865207a65726f206164647265737300000000000060448201526064016104a1565b6001600160a01b03821660009081526020819052604090205481811015610de95760405162461bcd60e51b815260206004820152601b60248201527f4275726e20616d6f756e7420657863656564732062616c616e6365000000000060448201526064016104a1565b6001600160a01b0383166000908152602081905260408120838303905560028054849290610e1890849061155b565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90602001610c85565b6001600160a01b0382166000908152600660205260408120805482919084908110610e8857610e886115a5565b90600052602060002090600202019050806001015460076000866001600160a01b03166001600160a01b0316815260200190815260200160002054610ecd919061155b565b6001600160a01b03851660008181526007602052604090819020929092556001830154915190917f6381d9813cabeb57471b5a7e05078e64845ccdb563146a6911d536f24ce960f191610f2291815260200190565b60405180910390a26001600160a01b03841660009081526006602052604090208054610f509060019061155b565b81548110610f6057610f606115a5565b906000526020600020906002020160066000866001600160a01b03166001600160a01b031681526020019081526020016000208481548110610fa457610fa46115a5565b60009182526020808320845460029093020191825560019384015493909101929092556001600160a01b0386168152600690915260409020805480610feb57610feb6115d2565b6000828152602081206002600019909301928302018181556001908101919091559155949350505050565b600061040e3384845b6001600160a01b0383166110755760405162461bcd60e51b815260206004820152601e60248201527f5472616e736665722066726f6d20746865207a65726f2061646472657373000060448201526064016104a1565b6001600160a01b0382166110cb5760405162461bcd60e51b815260206004820152601c60248201527f5472616e7366657220746f20746865207a65726f20616464726573730000000060448201526064016104a1565b6001600160a01b038316600090815260208190526040902054818110156111345760405162461bcd60e51b815260206004820152601f60248201527f5472616e7366657220616d6f756e7420657863656564732062616c616e63650060448201526064016104a1565b6001600160a01b0380851660009081526020819052604080822085850390559185168152908120805484929061116b9084906114ea565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516111b791815260200190565b60405180910390a350505050565b6001600160a01b0383166000908152600760205260408120546111e890846114ea565b6001600160a01b03851660009081526020819052604090205410156112635760405162461bcd60e51b815260206004820152602b60248201527f4c6f636b656420746f74616c2073686f756c6420626520736d616c6c6572207460448201526a68616e2062616c616e636560a81b60648201526084016104a1565b6001600160a01b0384166000908152600760205260409020546112879084906114ea565b6001600160a01b0385166000818152600760209081526040808320949094556006815283822084518086018652878152808301898152825460018181018555938652939094209051600290930201918255915191015590517f49eaf4942f1237055eb4cfa5f31c9dfe50d5b4ade01e021f7de8be2fbbde557b906113179086908690918252602082015260400190565b60405180910390a25060019392505050565b600060208083528351808285015260005b818110156113565785810183015185820160400152820161133a565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b038116811461138e57600080fd5b919050565b600080604083850312156113a657600080fd5b6113af83611377565b946020939093013593505050565b6000806000606084860312156113d257600080fd5b6113db84611377565b92506113e960208501611377565b9150604084013590509250925092565b60006020828403121561140b57600080fd5b5035919050565b60006020828403121561142457600080fd5b61142d82611377565b9392505050565b6000806040838503121561144757600080fd5b61145083611377565b915061145e60208401611377565b90509250929050565b60008060006060848603121561147c57600080fd5b61148584611377565b95602085013595506040909401359392505050565b600181811c908216806114ae57607f821691505b6020821081036114ce57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b80820180821115610412576104126114d4565b60208082526025908201527f43616e6e6f742073656e64206d6f7265207468616e20756e6c6f636b656420616040820152641b5bdd5b9d60da1b606082015260800190565b600060018201611554576115546114d4565b5060010190565b81810381811115610412576104126114d4565b60208082526017908201527f43616c6c6572206973206e6f7420746865206f776e6572000000000000000000604082015260600190565b634e487b7160e01b600052603260045260246000fd5b6000816115ca576115ca6114d4565b506000190190565b634e487b7160e01b600052603160045260246000fdfea2646970667358221220b62ff07eea54b1b2f1e79f785159ce2e2dbfbf150b9ab26c7bd7d4e0b255c22b64736f6c63430008110033

Verified Source Code Partial Match

Compiler: v0.8.17+commit.8df45f5f EVM: london Optimization: Yes (200 runs)
Xmile.sol 353 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.8.17;

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

    function _msgData() internal view virtual returns (bytes calldata) {
        this;
        return msg.data;
    }
}

abstract contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

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

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

    modifier onlyOwner() {
        require(owner() == _msgSender(), "Caller is not the owner");
        _;
    }

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

    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "New owner is the zero address");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

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

interface IERC20Metadata is IERC20 {
    function name() external view returns (string memory);
    function symbol() external view returns (string memory);
    function decimals() external view returns (uint8);
}

contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping(address => uint256) internal _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 override returns (string memory) {
        return _name;
    }

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

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

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

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

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

    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(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);

        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(currentAllowance >= amount, "Transfer amount exceeds allowance");
    unchecked {
        _approve(sender, _msgSender(), currentAllowance - amount);
    }

        return true;
    }

    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
        return true;
    }

    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "Decreased allowance below zero");
    unchecked {
        _approve(_msgSender(), spender, currentAllowance - subtractedValue);
    }

        return true;
    }

    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "Transfer from the zero address");
        require(recipient != address(0), "Transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

        uint256 senderBalance = _balances[sender];
        require(senderBalance >= amount, "Transfer amount exceeds balance");
    unchecked {
        _balances[sender] = senderBalance - amount;
    }
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);
    }

    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "Mint to the zero address");

        _beforeTokenTransfer(address(0), account, amount);

        _totalSupply += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);
    }

    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "Burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "Burn amount exceeds balance");
    unchecked {
        _balances[account] = accountBalance - amount;
    }
        _totalSupply -= amount;

        emit Transfer(account, address(0), amount);
    }

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

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

    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

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

    function burnFrom(address account, uint256 amount) public virtual {
        uint256 currentAllowance = allowance(account, _msgSender());
        require(currentAllowance >= amount, "Burn amount exceeds allowance");
    unchecked {
        _approve(account, _msgSender(), currentAllowance - amount);
    }
        _burn(account, amount);
    }
}

abstract contract ERC20Lockable is ERC20, Ownable {
    struct LockInfo {
        uint256 _releaseTime;
        uint256 _amount;
    }

    mapping(address => LockInfo[]) internal _locks;
    mapping(address => uint256) internal _totalLocked;

    event Lock(address indexed from, uint256 amount, uint256 releaseTime);
    event Unlock(address indexed from, uint256 amount);

    modifier checkLock(address from, uint256 amount) {
        uint256 length = _locks[from].length;
        if (length > 0) {
            autoUnlock(from);
        }
        require(_balances[from] >= _totalLocked[from] + amount, "Cannot send more than unlocked amount");
        _;
    }

    function _lock(address from, uint256 amount, uint256 releaseTime) internal returns (bool success)
    {
        require(
            _balances[from] >= amount + _totalLocked[from],
            "Locked total should be smaller than balance"
        );
        _totalLocked[from] = _totalLocked[from] + amount;
        _locks[from].push(LockInfo(releaseTime, amount));
        emit Lock(from, amount, releaseTime);
        success = true;
    }

    function _unlock(address from, uint256 index) internal returns (bool success) {
        LockInfo storage info = _locks[from][index];
        _totalLocked[from] = _totalLocked[from] - info._amount;
        emit Unlock(from, info._amount);
        _locks[from][index] = _locks[from][_locks[from].length - 1];
        _locks[from].pop();
        success = true;
    }

    function autoUnlock(address from) public returns (bool success) {
        for (uint256 i = 0; i < _locks[from].length; i++) {
            if (_locks[from][i]._releaseTime < block.timestamp) {
                _unlock(from, i);
            }
        }
        success = true;
    }

    function unlock(address from, uint256 idx) public onlyOwner returns (bool success) {
        require(_locks[from].length > idx, "There is no lock information.");
        _unlock(from, idx);
        success = true;
    }

    function releaseLock(address from) external onlyOwner returns (bool success){
        require(_locks[from].length > 0, "There is no lock information.");
        for (uint256 i = _locks[from].length; i > 0; i--) {
            _unlock(from, i - 1);
        }
        success = true;
    }

    function transferWithLock(address recipient, uint256 amount, uint256 releaseTime) external onlyOwner returns (bool success)
    {
        require(recipient != address(0));
        _transfer(msg.sender, recipient, amount);
        _lock(recipient, amount, releaseTime);
        success = true;
    }

    function lockInfo(address locked, uint256 index) public view returns (uint256 releaseTime, uint256 amount)
    {
        LockInfo memory info = _locks[locked][index];
        releaseTime = info._releaseTime;
        amount = info._amount;
    }

    function totalLocked(address locked) public view returns (uint256 amount, uint256 length){
        amount = _totalLocked[locked];
        length = _locks[locked].length;
    }
}

contract Xmile is ERC20, ERC20Burnable, ERC20Lockable {

    constructor() ERC20("Xmile", "XML") {
        _mint(msg.sender, 2000000000 * (10 ** decimals()));
    }

    function transfer(address to, uint256 amount) public checkLock(msg.sender, amount) override returns (bool) {
        return super.transfer(to, amount);
    }

    function transferFrom(address from, address to, uint256 amount) public checkLock(from, amount) override returns (bool) {
        return super.transferFrom(from, to, amount);
    }

    function balanceOf(address holder) public view override returns (uint256 balance) {
        uint256 totalBalance = super.balanceOf(holder);
        uint256 avaliableBalance = 0;
        (uint256 lockedBalance, uint256 lockedLength) = totalLocked(holder);
        require(totalBalance >= lockedBalance);

        if (lockedLength > 0) {
            for (uint i = 0; i < lockedLength; i++) {
                (uint256 releaseTime, uint256 amount) = lockInfo(holder, i);
                if (releaseTime <= block.timestamp) {
                    avaliableBalance += amount;
                }
            }
        }

        balance = totalBalance - lockedBalance + avaliableBalance;
    }

    function balanceOfTotal(address holder) public view returns (uint256 balance) {
        balance = super.balanceOf(holder);
    }

    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    )
        internal override {
        super._beforeTokenTransfer(from, to, amount);
    }

}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
balanceOfTotal 0xd29dad83 → uint256
decimals 0x313ce567 → uint8
lockInfo 0xb2520a7c → uint256, uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalLocked 0xd8fb9337 → uint256, uint256
totalSupply 0x18160ddd → uint256

Write Contract 13 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
autoUnlock 0xe20bc67b
address from
returns: bool
burn 0x42966c68
uint256 amount
burnFrom 0x79cc6790
address account
uint256 amount
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
releaseLock 0xd1c46916
address from
returns: bool
renounceOwnership 0x715018a6
No parameters
transfer 0xa9059cbb
address to
uint256 amount
returns: bool
transferFrom 0x23b872dd
address from
address to
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
transferWithLock 0xde6baccb
address recipient
uint256 amount
uint256 releaseTime
returns: bool
unlock 0x7eee288d
address from
uint256 idx
returns: bool

Recent Transactions

No transactions found for this address