Address Contract Partially Verified
Address
0xADfafBf05d3D74aF537bDEC348Ce4e536d99fb95
Balance
0 ETH
Nonce
1
Code Size
5662 bytes
Creator
0x7790a6DA...54d4 at tx 0xdd11b8de...705b8a
Indexed Transactions
0
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