Address Contract Verified
Address
0x4965b3b90f3a63Fc72F74e53322f66b2a174a98F
Balance
0 ETH
Nonce
1
Code Size
4078 bytes
Creator
0x979DB181...1D70 at tx 0x35db5a57...65798d
Indexed Transactions
0
Contract Bytecode
4078 bytes
0x608060405234801561001057600080fd5b50600436106101375760003560e01c806379cc6790116100b8578063ad38bf221161007c578063ad38bf2214610283578063bd10243014610296578063dd62ed3e146102a9578063f2fde38b146102bc578063f9f92be4146102cf578063fe575a87146102e257600080fd5b806379cc67901461021d5780638da5cb5b1461023057806395d89b4114610255578063a457c2d71461025d578063a9059cbb1461027057600080fd5b8063313ce567116100ff578063313ce567146101b757806339509351146101c657806342966c68146101d957806370a08231146101ec578063715018a61461021557600080fd5b806306fdde031461013c578063095ea7b31461015a57806318160ddd1461017d5780631a8952661461018f57806323b872dd146101a4575b600080fd5b61014461030e565b6040516101519190610d85565b60405180910390f35b61016d610168366004610def565b6103a0565b6040519015158152602001610151565b6002545b604051908152602001610151565b6101a261019d366004610e19565b6103ba565b005b61016d6101b2366004610e3b565b61044b565b60405160128152602001610151565b61016d6101d4366004610def565b61046f565b6101a26101e7366004610e77565b610491565b6101816101fa366004610e19565b6001600160a01b031660009081526020819052604090205490565b6101a261049e565b6101a261022b366004610def565b6104b2565b6005546001600160a01b03165b6040516001600160a01b039091168152602001610151565b6101446104cb565b61016d61026b366004610def565b6104da565b61016d61027e366004610def565b610555565b6101a2610291366004610e19565b610563565b60065461023d906001600160a01b031681565b6101816102b7366004610e90565b610626565b6101a26102ca366004610e19565b610651565b6101a26102dd366004610e19565b6106c7565b61016d6102f0366004610e19565b6001600160a01b031660009081526007602052604090205460ff1690565b60606003805461031d90610ec3565b80601f016020809104026020016040519081016040528092919081815260200182805461034990610ec3565b80156103965780601f1061036b57610100808354040283529160200191610396565b820191906000526020600020905b81548152906001019060200180831161037957829003601f168201915b5050505050905090565b6000336103ae818585610752565b60019150505b92915050565b6006546001600160a01b03163314806103dd57506005546001600160a01b031633145b6104025760405162461bcd60e51b81526004016103f990610efd565b60405180910390fd5b6001600160a01b038116600081815260076020526040808220805460ff19169055517f117e3210bb9aa7d9baff172026820255c6f6c30ba8999d1c2fd88e2848137c4e9190a250565b6000336104598582856107da565b610464858585610854565b506001949350505050565b6000336103ae8185856104828383610626565b61048c9190610f52565b610752565b61049b3382610a03565b50565b6104a6610b42565b6104b06000610b9c565b565b6104bd8233836107da565b6104c78282610a03565b5050565b60606004805461031d90610ec3565b600033816104e88286610626565b9050838110156105485760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016103f9565b6104648286868403610752565b6000336103ae818585610854565b61056b610b42565b6001600160a01b0381166105dc5760405162461bcd60e51b815260206004820152603260248201527f426c61636b6c69737461626c653a206e657720626c61636b6c697374657220696044820152717320746865207a65726f206164647265737360701b60648201526084016103f9565b600680546001600160a01b0319166001600160a01b0383169081179091556040517fc67398012c111ce95ecb7429b933096c977380ee6c421175a71a4a4c6c88c06e90600090a250565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b610659610b42565b6001600160a01b0381166106be5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016103f9565b61049b81610b9c565b6006546001600160a01b03163314806106ea57506005546001600160a01b031633145b6107065760405162461bcd60e51b81526004016103f990610efd565b6001600160a01b038116600081815260076020526040808220805460ff19166001179055517fffa4e6181777692565cf28528fc88fd1516ea86b56da075235fa575af6a4b8559190a250565b6001600160a01b038316600090815260076020526040902054839060ff161561078d5760405162461bcd60e51b81526004016103f990610f73565b6001600160a01b038316600090815260076020526040902054839060ff16156107c85760405162461bcd60e51b81526004016103f990610f73565b6107d3858585610bee565b5050505050565b60006107e68484610626565b9050600019811461084e57818110156108415760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e636500000060448201526064016103f9565b61084e8484848403610752565b50505050565b6001600160a01b0383166108b85760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103f9565b6001600160a01b03821661091a5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103f9565b610925838383610d0a565b6001600160a01b0383166000908152602081905260409020548181101561099d5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016103f9565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a361084e565b6001600160a01b038216610a635760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b60648201526084016103f9565b610a6f82600083610d0a565b6001600160a01b03821660009081526020819052604090205481811015610ae35760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b60648201526084016103f9565b6001600160a01b0383166000818152602081815260408083208686039055600280548790039055518581529192917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91015b60405180910390a3505050565b6005546001600160a01b031633146104b05760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016103f9565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038316610c505760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103f9565b6001600160a01b038216610cb15760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103f9565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259101610b35565b6001600160a01b038316600090815260076020526040902054839060ff1615610d455760405162461bcd60e51b81526004016103f990610f73565b6001600160a01b038316600090815260076020526040902054839060ff1615610d805760405162461bcd60e51b81526004016103f990610f73565b6107d3565b600060208083528351808285015260005b81811015610db257858101830151858201604001528201610d96565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610dea57600080fd5b919050565b60008060408385031215610e0257600080fd5b610e0b83610dd3565b946020939093013593505050565b600060208284031215610e2b57600080fd5b610e3482610dd3565b9392505050565b600080600060608486031215610e5057600080fd5b610e5984610dd3565b9250610e6760208501610dd3565b9150604084013590509250925092565b600060208284031215610e8957600080fd5b5035919050565b60008060408385031215610ea357600080fd5b610eac83610dd3565b9150610eba60208401610dd3565b90509250929050565b600181811c90821680610ed757607f821691505b602082108103610ef757634e487b7160e01b600052602260045260246000fd5b50919050565b60208082526035908201527f426c61636b6c69737461626c653a2063616c6c6572206973206e6f742074686560408201527410313630b1b5b634b9ba32b91037b91037bbb732b960591b606082015260800190565b808201808211156103b457634e487b7160e01b600052601160045260246000fd5b60208082526025908201527f426c61636b6c69737461626c653a206163636f756e7420697320626c61636b6c6040820152641a5cdd195960da1b60608201526080019056fea2646970667358221220f176445958804d8c08484e6ea77860c4ae0587f00d1e5135693d87f9dce9a38364736f6c63430008130033
Verified Source Code Full Match
Compiler: v0.8.19+commit.7dd6d404
EVM: paris
Optimization: Yes (200 runs)
ShibieToken.sol 307 lines
// SPDX-License-Identifier: None
pragma solidity ^0.8.19;
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);
}
}
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 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 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) 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 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 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;
}
function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
address owner = _msgSender();
_approve(owner, spender, allowance(owner, spender) + addedValue);
return true;
}
function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
address owner = _msgSender();
uint256 currentAllowance = allowance(owner, spender);
require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
unchecked {
_approve(owner, spender, currentAllowance - subtractedValue);
}
return true;
}
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");
_beforeTokenTransfer(from, to, amount);
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 _mint(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: mint to the zero address");
_beforeTokenTransfer(address(0), account, amount);
_totalSupply += amount;
unchecked {
_balances[account] += amount;
}
emit Transfer(address(0), account, amount);
_afterTokenTransfer(address(0), account, amount);
}
function _burn(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: burn from the zero address");
_beforeTokenTransfer(account, address(0), amount);
uint256 accountBalance = _balances[account];
require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
unchecked {
_balances[account] = accountBalance - amount;
_totalSupply -= amount;
}
emit Transfer(account, address(0), amount);
_afterTokenTransfer(account, address(0), amount);
}
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 _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 _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual {}
function _afterTokenTransfer(address from, address to, uint256 amount) internal virtual {}
}
abstract contract ERC20Burnable is Context, ERC20 {
function burn(uint256 amount) public virtual {
_burn(_msgSender(), amount);
}
function burnFrom(address account, uint256 amount) public virtual {
_spendAllowance(account, _msgSender(), amount);
_burn(account, amount);
}
}
contract Blacklistable is Ownable {
address public blacklister;
mapping(address => bool) internal blacklisted;
event Blacklisted(address indexed _account);
event UnBlacklisted(address indexed _account);
event BlacklisterChanged(address indexed newBlacklister);
modifier onlyBlacklister() {
require(
msg.sender == blacklister || msg.sender == owner(),
"Blacklistable: caller is not the blacklister or owner"
);
_;
}
modifier notBlacklisted(address _account) {
require(
!blacklisted[_account],
"Blacklistable: account is blacklisted"
);
_;
}
function isBlacklisted(address _account) external view returns (bool) {
return blacklisted[_account];
}
function blacklist(address _account) external onlyBlacklister {
blacklisted[_account] = true;
emit Blacklisted(_account);
}
function unBlacklist(address _account) external onlyBlacklister {
blacklisted[_account] = false;
emit UnBlacklisted(_account);
}
function updateBlacklister(address _newBlacklister) external onlyOwner {
require(
_newBlacklister != address(0),
"Blacklistable: new blacklister is the zero address"
);
blacklister = _newBlacklister;
emit BlacklisterChanged(blacklister);
}
}
contract ShibieToken is ERC20, ERC20Burnable, Ownable, Blacklistable {
constructor(uint256 _totalSupply) ERC20("SHIBIE", "SHIBIE") {
blacklister = msg.sender;
_mint(msg.sender, _totalSupply);
}
function _approve(address owner, address spender, uint256 amount)
internal
notBlacklisted(owner)
notBlacklisted(spender)
override
{
super._approve(owner, spender, amount);
}
function _beforeTokenTransfer(address from, address to, uint256 amount)
internal
notBlacklisted(from)
notBlacklisted(to)
override
{
super._beforeTokenTransfer(from, to, amount);
}
}
Read Contract
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
blacklister 0xbd102430 → address
decimals 0x313ce567 → uint8
isBlacklisted 0xfe575a87 → bool
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
Write Contract 12 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
blacklist 0xf9f92be4
address _account
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
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
unBlacklist 0x1a895266
address _account
updateBlacklister 0xad38bf22
address _newBlacklister
Recent Transactions
No transactions found for this address