Address Contract Partially Verified
Address
0xDB99B0477574Ac0B2d9c8cec56B42277DA3fdb82
Balance
0 ETH
Nonce
1
Code Size
1698 bytes
Creator
0xd16831dc...99Ae at tx 0x530cf532...3f2bb3
Last Active
Indexed Transactions
2 (24,255,680 → 24,292,954)
Gas Used (indexed)
71,238
Contract Bytecode
1698 bytes
0x608060405234801561000f575f80fd5b5060043610610081575f3560e01c806306fdde0314610085578063095ea7b3146100a357806318160ddd146100c657806323b872dd146100d8578063313ce567146100eb57806370a08231146100fa57806395d89b4114610122578063a9059cbb1461012a578063dd62ed3e1461013d575b5f80fd5b61008d610150565b60405161009a91906104dd565b60405180910390f35b6100b66100b136600461052d565b6101e0565b604051901515815260200161009a565b6002545b60405190815260200161009a565b6100b66100e6366004610555565b6101f9565b6040516012815260200161009a565b6100ca61010836600461058f565b6001600160a01b03165f9081526020819052604090205490565b61008d61021c565b6100b661013836600461052d565b61022b565b6100ca61014b3660046105af565b610238565b60606003805461015f906105e0565b80601f016020809104026020016040519081016040528092919081815260200182805461018b906105e0565b80156101d65780601f106101ad576101008083540402835291602001916101d6565b820191905f5260205f20905b8154815290600101906020018083116101b957829003601f168201915b5050505050905090565b5f336101ed818585610262565b60019150505b92915050565b5f33610206858285610274565b6102118585856102cd565b506001949350505050565b60606004805461015f906105e0565b5f336101ed8185856102cd565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b61026f838383600161032a565b505050565b5f61027f8484610238565b90505f1981146102c757818110156102b957828183604051637dc7a0d960e11b81526004016102b093929190610618565b60405180910390fd5b6102c784848484035f61032a565b50505050565b6001600160a01b0383166102f6575f604051634b637e8f60e11b81526004016102b09190610639565b6001600160a01b03821661031f575f60405163ec442f0560e01b81526004016102b09190610639565b61026f8383836103fc565b6001600160a01b038416610353575f60405163e602df0560e01b81526004016102b09190610639565b6001600160a01b03831661037c575f604051634a1406b160e11b81526004016102b09190610639565b6001600160a01b038085165f90815260016020908152604080832093871683529290522082905580156102c757826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925846040516103ee91815260200190565b60405180910390a350505050565b6001600160a01b038316610426578060025f82825461041b919061064d565b909155506104839050565b6001600160a01b0383165f90815260208190526040902054818110156104655783818360405163391434e360e21b81526004016102b093929190610618565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b038281165f8181526020818152604091829020805486019055905184815291928616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3505050565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b80356001600160a01b0381168114610528575f80fd5b919050565b5f806040838503121561053e575f80fd5b61054783610512565b946020939093013593505050565b5f805f60608486031215610567575f80fd5b61057084610512565b925061057e60208501610512565b929592945050506040919091013590565b5f6020828403121561059f575f80fd5b6105a882610512565b9392505050565b5f80604083850312156105c0575f80fd5b6105c983610512565b91506105d760208401610512565b90509250929050565b600181811c908216806105f457607f821691505b60208210810361061257634e487b7160e01b5f52602260045260245ffd5b50919050565b6001600160a01b039390931683526020830191909152604082015260600190565b6001600160a01b0391909116815260200190565b808201808211156101f357634e487b7160e01b5f52601160045260245ffdfea2646970667358221220805b69d121afebd3ee0381115d70155aeca206def3398e7a4a1c7d1b6f60912c64736f6c634300081a0033
Verified Source Code Partial Match
Compiler: v0.8.26+commit.8a97fa7a
EVM: cancun
Optimization: Yes (1 runs)
DECToken.sol 231 lines
// SPDX-License-Identifier: MIT
/**
* @title DEC Token - ERC20 Smart Contract
* @dev Developed by the DEC Developers team.
* Special thanks to OpenZeppelin for their reliable ERC20 libraries.
*/
pragma solidity ^0.8.26;
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);
}
interface IERC20Metadata is IERC20 {
function name() external view returns (string memory);
function symbol() external view returns (string memory);
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;
}
}
interface IERC20Errors {
error ERC20InsufficientBalance(
address sender,
uint256 balance,
uint256 needed
);
error ERC20InvalidSender(address sender);
error ERC20InvalidReceiver(address receiver);
error ERC20InsufficientAllowance(
address spender,
uint256 allowance,
uint256 needed
);
error ERC20InvalidApprover(address approver);
error ERC20InvalidSpender(address spender);
}
abstract contract ERC20 is Context, IERC20, IERC20Metadata, IERC20Errors {
mapping(address => uint256) private _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 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 = _msgSender();
_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 = _msgSender();
_approve(owner, spender, value);
return true;
}
function transferFrom(
address from,
address to,
uint256 value
) public virtual returns (bool) {
address spender = _msgSender();
_spendAllowance(from, spender, value);
_transfer(from, to, value);
return true;
}
function _transfer(
address from,
address to,
uint256 value
) internal {
if (from == address(0)) {
revert ERC20InvalidSender(address(0));
}
if (to == address(0)) {
revert ERC20InvalidReceiver(address(0));
}
_update(from, to, value);
}
function _update(
address from,
address to,
uint256 value
) internal virtual {
if (from == address(0)) {
_totalSupply += value;
} else {
uint256 fromBalance = _balances[from];
if (fromBalance < value) {
revert ERC20InsufficientBalance(from, fromBalance, value);
}
unchecked {
_balances[from] = fromBalance - value;
}
}
unchecked {
_balances[to] += value;
}
emit Transfer(from, to, 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 ERC20InvalidApprover(address(0));
}
if (spender == address(0)) {
revert ERC20InvalidSpender(address(0));
}
_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 ERC20InsufficientAllowance(
spender,
currentAllowance,
value
);
}
unchecked {
_approve(owner, spender, currentAllowance - value, false);
}
}
}
}
contract DECToken is ERC20 {
constructor() ERC20("DEC Token", "DECT") {
_update(address(0), msg.sender, 1000000000 * 10**decimals());
}
}
Read Contract
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
Write Contract 3 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
Top Interactions
| Address | Txns | Sent | Received |
|---|---|---|---|
| 0xBd5DBD13...85D8 | 1 | 1 | |
| 0x826a6413...e850 | 1 | 1 |
Recent Transactions
|
| Hash | Block | Age | From/To | Value | |
|---|---|---|---|---|---|
| 0x68812948...3741f7 Fail | 24,292,954 | IN | 0x826a6413...e850 | 0 ETH | |
| 0xea9e6e2f...7b51b6 | 24,255,680 | IN | 0xBd5DBD13...85D8 | 0 ETH |