ETH Price: $2,869.49 (-9.76%)
Gas: 14 Gwei

Contract

0xB099Bc46cB69d64150cDBeA7138B5b96A0F836e1
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Value
Approve195476892024-03-30 15:34:5996 days ago1711812899IN
0xB099Bc46...6A0F836e1
0 ETH0.0007118929.35524762
Approve184689792023-10-31 8:40:11247 days ago1698741611IN
0xB099Bc46...6A0F836e1
0 ETH0.0008611218.50481317
Approve184154152023-10-23 20:40:59255 days ago1698093659IN
0xB099Bc46...6A0F836e1
0 ETH0.0008300434.22726667
Approve177879842023-07-28 0:29:35343 days ago1690504175IN
0xB099Bc46...6A0F836e1
0 ETH0.0010716323.02856981
Approve177874712023-07-27 22:46:47343 days ago1690498007IN
0xB099Bc46...6A0F836e1
0 ETH0.0013382228.72043766
Approve172948502023-05-19 16:54:35412 days ago1684515275IN
0xB099Bc46...6A0F836e1
0 ETH0.0020064343.11664542
Approve172897122023-05-18 23:30:59413 days ago1684452659IN
0xB099Bc46...6A0F836e1
0 ETH0.0021190145.53601899
Approve172824212023-05-17 22:53:59414 days ago1684364039IN
0xB099Bc46...6A0F836e1
0 ETH0.0022170347.58089556
Approve172653342023-05-15 12:59:47416 days ago1684155587IN
0xB099Bc46...6A0F836e1
0 ETH0.0020649644.60450391
Approve172560882023-05-14 5:35:11418 days ago1684042511IN
0xB099Bc46...6A0F836e1
0 ETH0.0017742238.34413801
Transfer172440002023-05-12 12:01:59419 days ago1683892919IN
0xB099Bc46...6A0F836e1
0 ETH0.0027229755.19476428
Approve172435302023-05-12 10:26:23419 days ago1683887183IN
0xB099Bc46...6A0F836e1
0 ETH0.0022704348.97929497
Approve172408892023-05-12 1:28:47420 days ago1683854927IN
0xB099Bc46...6A0F836e1
0 ETH0.0031978169.074695
Approve172402532023-05-11 23:18:59420 days ago1683847139IN
0xB099Bc46...6A0F836e1
0 ETH0.004275991.88570331
Approve172396422023-05-11 21:14:47420 days ago1683839687IN
0xB099Bc46...6A0F836e1
0 ETH0.00487918104.84973839
Approve172390402023-05-11 19:01:59420 days ago1683831719IN
0xB099Bc46...6A0F836e1
0 ETH0.00573975123.18396078
Approve172387922023-05-11 18:11:47420 days ago1683828707IN
0xB099Bc46...6A0F836e1
0 ETH0.00588754127.174518
Approve172385632023-05-11 17:24:11420 days ago1683825851IN
0xB099Bc46...6A0F836e1
0 ETH0.00675708145.20427538
Approve172384712023-05-11 17:04:59420 days ago1683824699IN
0xB099Bc46...6A0F836e1
0 ETH0.00552438118.56169407
Approve172384322023-05-11 16:56:59420 days ago1683824219IN
0xB099Bc46...6A0F836e1
0 ETH0.0046047498.95228863
Approve172382932023-05-11 16:28:47420 days ago1683822527IN
0xB099Bc46...6A0F836e1
0 ETH0.00590694127.62658467
Approve172382112023-05-11 16:12:23420 days ago1683821543IN
0xB099Bc46...6A0F836e1
0 ETH0.00794806171.68293307
Approve172381822023-05-11 16:06:35420 days ago1683821195IN
0xB099Bc46...6A0F836e1
0 ETH0.00639874138.21677009
Transfer172381802023-05-11 16:06:11420 days ago1683821171IN
0xB099Bc46...6A0F836e1
0 ETH0.00460756142.8878478
Approve172381502023-05-11 15:59:59420 days ago1683820799IN
0xB099Bc46...6A0F836e1
0 ETH0.00557868120.56552018
View all transactions

View more zero value Internal Transactions in Advanced View mode

Advanced mode:
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
KirbyToken

Compiler Version
v0.8.19+commit.7dd6d404

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-05-10
*/

//  Website: https://kirby.wtf
//  Telegram: https://t.me/kirby_token
//  Twitter: https://twitter.com/kirbytoken
//
//     ██╗  ██╗██╗██████╗ ██████╗ ██╗   ██╗
//     ██║ ██╔╝██║██╔══██╗██╔══██╗╚██╗ ██╔╝
//     █████╔╝ ██║██████╔╝██████╔╝ ╚████╔╝
//     ██╔═██╗ ██║██╔══██╗██╔══██╗  ╚██╔╝
//     ██║  ██╗██║██║  ██║██████╔╝   ██║
//     ╚═╝  ╚═╝╚═╝╚═╝  ╚═╝╚═════╝    ╚═╝
//
// SPDX-License-Identifier: MIT
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;
            // Overflow not possible: the sum of all balances is capped by totalSupply, and the sum is preserved by
            // decrementing then incrementing.
            _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 {
            // Overflow not possible: balance + amount is at most totalSupply + amount, which is checked above.
            _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;
            // Overflow not possible: amount <= accountBalance <= totalSupply.
            _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 {}
}

interface IDEXRouter {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
}

interface IDEXFactory {
    function createPair(
        address tokenA,
        address tokenB
    ) external returns (address pair);
}

/// @custom:security-contact [email protected]
contract KirbyToken is ERC20, Ownable {
    address public immutable pair;
    bool public tradingEnabled = false;

    IDEXRouter public router =
        IDEXRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

    constructor() ERC20("Kirby Token", "KIRBY") Ownable() {
        _mint(msg.sender, 69_000_000_000 * 10 ** decimals());

        pair = IDEXFactory(router.factory()).createPair(
            router.WETH(),
            address(this)
        );
    }

    function _beforeTokenTransfer(
        address from,
        address /* to */,
        uint256 /* amount */
    ) internal virtual override {
        if (from != owner() && msg.sender != owner() && tx.origin != owner()) {
            require(tradingEnabled == true, "Trading is not enabled yet.");
        }
    }

    function enableTrading() public onlyOwner {
        tradingEnabled = true;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"router","outputs":[{"internalType":"contract IDEXRouter","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]

60a06040526005805460ff60a01b19169055600680546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d1790553480156200004457600080fd5b506040518060400160405280600b81526020016a25b4b9313c902a37b5b2b760a91b815250604051806040016040528060058152602001644b4952425960d81b8152508160039081620000989190620004f1565b506004620000a78282620004f1565b505050620000c4620000be6200027560201b60201c565b62000279565b620000ee33620000d76012600a620006d2565b620000e890641010b87200620006ea565b620002cb565b600660009054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000142573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000168919062000704565b6001600160a01b031663c9c65396600660009054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015620001ca573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001f0919062000704565b6040516001600160e01b031960e084901b1681526001600160a01b0390911660048201523060248201526044016020604051808303816000875af11580156200023d573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000263919062000704565b6001600160a01b031660805262000745565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038216620003275760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064015b60405180910390fd5b6200033560008383620003a0565b80600260008282546200034991906200072f565b90915550506001600160a01b038216600081815260208181526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6005546001600160a01b03848116911614801590620003ca57506005546001600160a01b03163314155b8015620003e257506005546001600160a01b03163214155b156200044857600554600160a01b900460ff161515600114620004485760405162461bcd60e51b815260206004820152601b60248201527f54726164696e67206973206e6f7420656e61626c6564207965742e000000000060448201526064016200031e565b505050565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200047857607f821691505b6020821081036200049957634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200044857600081815260208120601f850160051c81016020861015620004c85750805b601f850160051c820191505b81811015620004e957828155600101620004d4565b505050505050565b81516001600160401b038111156200050d576200050d6200044d565b62000525816200051e845462000463565b846200049f565b602080601f8311600181146200055d5760008415620005445750858301515b600019600386901b1c1916600185901b178555620004e9565b600085815260208120601f198616915b828110156200058e578886015182559484019460019091019084016200056d565b5085821015620005ad5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b600052601160045260246000fd5b600181815b8085111562000614578160001904821115620005f857620005f8620005bd565b808516156200060657918102915b93841c9390800290620005d8565b509250929050565b6000826200062d57506001620006cc565b816200063c57506000620006cc565b8160018114620006555760028114620006605762000680565b6001915050620006cc565b60ff841115620006745762000674620005bd565b50506001821b620006cc565b5060208310610133831016604e8410600b8410161715620006a5575081810a620006cc565b620006b18383620005d3565b8060001904821115620006c857620006c8620005bd565b0290505b92915050565b6000620006e360ff8416836200061c565b9392505050565b8082028115828204841417620006cc57620006cc620005bd565b6000602082840312156200071757600080fd5b81516001600160a01b0381168114620006e357600080fd5b80820180821115620006cc57620006cc620005bd565b608051610b606200076160003960006102370152610b606000f3fe608060405234801561001057600080fd5b50600436106101165760003560e01c80638a8c523c116100a2578063a8aa1b3111610071578063a8aa1b3114610232578063a9059cbb14610259578063dd62ed3e1461026c578063f2fde38b1461027f578063f887ea401461029257600080fd5b80638a8c523c146101ea5780638da5cb5b146101f257806395d89b4114610217578063a457c2d71461021f57600080fd5b8063313ce567116100e9578063313ce5671461018157806339509351146101905780634ada218b146101a357806370a08231146101b7578063715018a6146101e057600080fd5b806306fdde031461011b578063095ea7b31461013957806318160ddd1461015c57806323b872dd1461016e575b600080fd5b6101236102a5565b60405161013091906109aa565b60405180910390f35b61014c610147366004610a14565b610337565b6040519015158152602001610130565b6002545b604051908152602001610130565b61014c61017c366004610a3e565b610351565b60405160128152602001610130565b61014c61019e366004610a14565b610375565b60055461014c90600160a01b900460ff1681565b6101606101c5366004610a7a565b6001600160a01b031660009081526020819052604090205490565b6101e8610397565b005b6101e86103ab565b6005546001600160a01b03165b6040516001600160a01b039091168152602001610130565b6101236103c8565b61014c61022d366004610a14565b6103d7565b6101ff7f000000000000000000000000000000000000000000000000000000000000000081565b61014c610267366004610a14565b610457565b61016061027a366004610a9c565b610465565b6101e861028d366004610a7a565b610490565b6006546101ff906001600160a01b031681565b6060600380546102b490610acf565b80601f01602080910402602001604051908101604052809291908181526020018280546102e090610acf565b801561032d5780601f106103025761010080835404028352916020019161032d565b820191906000526020600020905b81548152906001019060200180831161031057829003601f168201915b5050505050905090565b600033610345818585610509565b60019150505b92915050565b60003361035f85828561062d565b61036a8585856106a7565b506001949350505050565b6000336103458185856103888383610465565b6103929190610b09565b610509565b61039f610856565b6103a960006108b0565b565b6103b3610856565b6005805460ff60a01b1916600160a01b179055565b6060600480546102b490610acf565b600033816103e58286610465565b90508381101561044a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084015b60405180910390fd5b61036a8286868403610509565b6000336103458185856106a7565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b610498610856565b6001600160a01b0381166104fd5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610441565b610506816108b0565b50565b6001600160a01b03831661056b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610441565b6001600160a01b0382166105cc5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610441565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006106398484610465565b905060001981146106a157818110156106945760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610441565b6106a18484848403610509565b50505050565b6001600160a01b03831661070b5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610441565b6001600160a01b03821661076d5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610441565b610778838383610902565b6001600160a01b038316600090815260208190526040902054818110156107f05760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610441565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a36106a1565b6005546001600160a01b031633146103a95760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610441565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6005546001600160a01b0384811691161480159061092b57506005546001600160a01b03163314155b801561094257506005546001600160a01b03163214155b156109a557600554600160a01b900460ff1615156001146109a55760405162461bcd60e51b815260206004820152601b60248201527f54726164696e67206973206e6f7420656e61626c6564207965742e00000000006044820152606401610441565b505050565b600060208083528351808285015260005b818110156109d7578581018301518582016040015282016109bb565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610a0f57600080fd5b919050565b60008060408385031215610a2757600080fd5b610a30836109f8565b946020939093013593505050565b600080600060608486031215610a5357600080fd5b610a5c846109f8565b9250610a6a602085016109f8565b9150604084013590509250925092565b600060208284031215610a8c57600080fd5b610a95826109f8565b9392505050565b60008060408385031215610aaf57600080fd5b610ab8836109f8565b9150610ac6602084016109f8565b90509250929050565b600181811c90821680610ae357607f821691505b602082108103610b0357634e487b7160e01b600052602260045260246000fd5b50919050565b8082018082111561034b57634e487b7160e01b600052601160045260246000fdfea2646970667358221220e653b8229a0c463c8081529cf77adf8d92826607c78e6ac2e3f3e520d0ad717364736f6c63430008130033

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101165760003560e01c80638a8c523c116100a2578063a8aa1b3111610071578063a8aa1b3114610232578063a9059cbb14610259578063dd62ed3e1461026c578063f2fde38b1461027f578063f887ea401461029257600080fd5b80638a8c523c146101ea5780638da5cb5b146101f257806395d89b4114610217578063a457c2d71461021f57600080fd5b8063313ce567116100e9578063313ce5671461018157806339509351146101905780634ada218b146101a357806370a08231146101b7578063715018a6146101e057600080fd5b806306fdde031461011b578063095ea7b31461013957806318160ddd1461015c57806323b872dd1461016e575b600080fd5b6101236102a5565b60405161013091906109aa565b60405180910390f35b61014c610147366004610a14565b610337565b6040519015158152602001610130565b6002545b604051908152602001610130565b61014c61017c366004610a3e565b610351565b60405160128152602001610130565b61014c61019e366004610a14565b610375565b60055461014c90600160a01b900460ff1681565b6101606101c5366004610a7a565b6001600160a01b031660009081526020819052604090205490565b6101e8610397565b005b6101e86103ab565b6005546001600160a01b03165b6040516001600160a01b039091168152602001610130565b6101236103c8565b61014c61022d366004610a14565b6103d7565b6101ff7f000000000000000000000000053a5a45c749f418d9658aa2d7b5afdc5dcb812d81565b61014c610267366004610a14565b610457565b61016061027a366004610a9c565b610465565b6101e861028d366004610a7a565b610490565b6006546101ff906001600160a01b031681565b6060600380546102b490610acf565b80601f01602080910402602001604051908101604052809291908181526020018280546102e090610acf565b801561032d5780601f106103025761010080835404028352916020019161032d565b820191906000526020600020905b81548152906001019060200180831161031057829003601f168201915b5050505050905090565b600033610345818585610509565b60019150505b92915050565b60003361035f85828561062d565b61036a8585856106a7565b506001949350505050565b6000336103458185856103888383610465565b6103929190610b09565b610509565b61039f610856565b6103a960006108b0565b565b6103b3610856565b6005805460ff60a01b1916600160a01b179055565b6060600480546102b490610acf565b600033816103e58286610465565b90508381101561044a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084015b60405180910390fd5b61036a8286868403610509565b6000336103458185856106a7565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b610498610856565b6001600160a01b0381166104fd5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610441565b610506816108b0565b50565b6001600160a01b03831661056b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610441565b6001600160a01b0382166105cc5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610441565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006106398484610465565b905060001981146106a157818110156106945760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610441565b6106a18484848403610509565b50505050565b6001600160a01b03831661070b5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610441565b6001600160a01b03821661076d5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610441565b610778838383610902565b6001600160a01b038316600090815260208190526040902054818110156107f05760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610441565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a36106a1565b6005546001600160a01b031633146103a95760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610441565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6005546001600160a01b0384811691161480159061092b57506005546001600160a01b03163314155b801561094257506005546001600160a01b03163214155b156109a557600554600160a01b900460ff1615156001146109a55760405162461bcd60e51b815260206004820152601b60248201527f54726164696e67206973206e6f7420656e61626c6564207965742e00000000006044820152606401610441565b505050565b600060208083528351808285015260005b818110156109d7578581018301518582016040015282016109bb565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610a0f57600080fd5b919050565b60008060408385031215610a2757600080fd5b610a30836109f8565b946020939093013593505050565b600080600060608486031215610a5357600080fd5b610a5c846109f8565b9250610a6a602085016109f8565b9150604084013590509250925092565b600060208284031215610a8c57600080fd5b610a95826109f8565b9392505050565b60008060408385031215610aaf57600080fd5b610ab8836109f8565b9150610ac6602084016109f8565b90509250929050565b600181811c90821680610ae357607f821691505b602082108103610b0357634e487b7160e01b600052602260045260246000fd5b50919050565b8082018082111561034b57634e487b7160e01b600052601160045260246000fdfea2646970667358221220e653b8229a0c463c8081529cf77adf8d92826607c78e6ac2e3f3e520d0ad717364736f6c63430008130033

Deployed Bytecode Sourcemap

9107:897:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3439:100;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;4371:201;;;;;;:::i;:::-;;:::i;:::-;;;1169:14:1;;1162:22;1144:41;;1132:2;1117:18;4371:201:0;1004:187:1;3760:108:0;3848:12;;3760:108;;;1342:25:1;;;1330:2;1315:18;3760:108:0;1196:177:1;4580:295:0;;;;;;:::i;:::-;;:::i;3659:93::-;;;3742:2;1853:36:1;;1841:2;1826:18;3659:93:0;1711:184:1;4883:238:0;;;;;;:::i;:::-;;:::i;9188:34::-;;;;;-1:-1:-1;;;9188:34:0;;;;;;3876:127;;;;;;:::i;:::-;-1:-1:-1;;;;;3977:18:0;3950:7;3977:18;;;;;;;;;;;;3876:127;1597:103;;;:::i;:::-;;9919:82;;;:::i;1362:87::-;1435:6;;-1:-1:-1;;;;;1435:6:0;1362:87;;;-1:-1:-1;;;;;2255:32:1;;;2237:51;;2225:2;2210:18;1362:87:0;2091:203:1;3547:104:0;;;:::i;5129:436::-;;;;;;:::i;:::-;;:::i;9152:29::-;;;;;4011:193;;;;;;:::i;:::-;;:::i;4212:151::-;;;;;;:::i;:::-;;:::i;1708:201::-;;;;;;:::i;:::-;;:::i;9231:90::-;;;;;-1:-1:-1;;;;;9231:90:0;;;3439:100;3493:13;3526:5;3519:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3439:100;:::o;4371:201::-;4454:4;915:10;4510:32;915:10;4526:7;4535:6;4510:8;:32::i;:::-;4560:4;4553:11;;;4371:201;;;;;:::o;4580:295::-;4711:4;915:10;4769:38;4785:4;915:10;4800:6;4769:15;:38::i;:::-;4818:27;4828:4;4834:2;4838:6;4818:9;:27::i;:::-;-1:-1:-1;4863:4:0;;4580:295;-1:-1:-1;;;;4580:295:0:o;4883:238::-;4971:4;915:10;5027:64;915:10;5043:7;5080:10;5052:25;915:10;5043:7;5052:9;:25::i;:::-;:38;;;;:::i;:::-;5027:8;:64::i;1597:103::-;1321:13;:11;:13::i;:::-;1662:30:::1;1689:1;1662:18;:30::i;:::-;1597:103::o:0;9919:82::-;1321:13;:11;:13::i;:::-;9972:14:::1;:21:::0;;-1:-1:-1;;;;9972:21:0::1;-1:-1:-1::0;;;9972:21:0::1;::::0;;9919:82::o;3547:104::-;3603:13;3636:7;3629:14;;;;;:::i;5129:436::-;5222:4;915:10;5222:4;5305:25;915:10;5322:7;5305:9;:25::i;:::-;5278:52;;5369:15;5349:16;:35;;5341:85;;;;-1:-1:-1;;;5341:85:0;;3604:2:1;5341:85:0;;;3586:21:1;3643:2;3623:18;;;3616:30;3682:34;3662:18;;;3655:62;-1:-1:-1;;;3733:18:1;;;3726:35;3778:19;;5341:85:0;;;;;;;;;5462:60;5471:5;5478:7;5506:15;5487:16;:34;5462:8;:60::i;4011:193::-;4090:4;915:10;4146:28;915:10;4163:2;4167:6;4146:9;:28::i;4212:151::-;-1:-1:-1;;;;;4328:18:0;;;4301:7;4328:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;4212:151::o;1708:201::-;1321:13;:11;:13::i;:::-;-1:-1:-1;;;;;1797:22:0;::::1;1789:73;;;::::0;-1:-1:-1;;;1789:73:0;;4010:2:1;1789:73:0::1;::::0;::::1;3992:21:1::0;4049:2;4029:18;;;4022:30;4088:34;4068:18;;;4061:62;-1:-1:-1;;;4139:18:1;;;4132:36;4185:19;;1789:73:0::1;3808:402:1::0;1789:73:0::1;1873:28;1892:8;1873:18;:28::i;:::-;1708:201:::0;:::o;7660:380::-;-1:-1:-1;;;;;7796:19:0;;7788:68;;;;-1:-1:-1;;;7788:68:0;;4417:2:1;7788:68:0;;;4399:21:1;4456:2;4436:18;;;4429:30;4495:34;4475:18;;;4468:62;-1:-1:-1;;;4546:18:1;;;4539:34;4590:19;;7788:68:0;4215:400:1;7788:68:0;-1:-1:-1;;;;;7875:21:0;;7867:68;;;;-1:-1:-1;;;7867:68:0;;4822:2:1;7867:68:0;;;4804:21:1;4861:2;4841:18;;;4834:30;4900:34;4880:18;;;4873:62;-1:-1:-1;;;4951:18:1;;;4944:32;4993:19;;7867:68:0;4620:398:1;7867:68:0;-1:-1:-1;;;;;7948:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;8000:32;;1342:25:1;;;8000:32:0;;1315:18:1;8000:32:0;;;;;;;7660:380;;;:::o;8048:453::-;8183:24;8210:25;8220:5;8227:7;8210:9;:25::i;:::-;8183:52;;-1:-1:-1;;8250:16:0;:37;8246:248;;8332:6;8312:16;:26;;8304:68;;;;-1:-1:-1;;;8304:68:0;;5225:2:1;8304:68:0;;;5207:21:1;5264:2;5244:18;;;5237:30;5303:31;5283:18;;;5276:59;5352:18;;8304:68:0;5023:353:1;8304:68:0;8416:51;8425:5;8432:7;8460:6;8441:16;:25;8416:8;:51::i;:::-;8172:329;8048:453;;;:::o;5573:840::-;-1:-1:-1;;;;;5704:18:0;;5696:68;;;;-1:-1:-1;;;5696:68:0;;5583:2:1;5696:68:0;;;5565:21:1;5622:2;5602:18;;;5595:30;5661:34;5641:18;;;5634:62;-1:-1:-1;;;5712:18:1;;;5705:35;5757:19;;5696:68:0;5381:401:1;5696:68:0;-1:-1:-1;;;;;5783:16:0;;5775:64;;;;-1:-1:-1;;;5775:64:0;;5989:2:1;5775:64:0;;;5971:21:1;6028:2;6008:18;;;6001:30;6067:34;6047:18;;;6040:62;-1:-1:-1;;;6118:18:1;;;6111:33;6161:19;;5775:64:0;5787:399:1;5775:64:0;5852:38;5873:4;5879:2;5883:6;5852:20;:38::i;:::-;-1:-1:-1;;;;;5925:15:0;;5903:19;5925:15;;;;;;;;;;;5959:21;;;;5951:72;;;;-1:-1:-1;;;5951:72:0;;6393:2:1;5951:72:0;;;6375:21:1;6432:2;6412:18;;;6405:30;6471:34;6451:18;;;6444:62;-1:-1:-1;;;6522:18:1;;;6515:36;6568:19;;5951:72:0;6191:402:1;5951:72:0;-1:-1:-1;;;;;6059:15:0;;;:9;:15;;;;;;;;;;;6077:20;;;6059:38;;6277:13;;;;;;;;;;:23;;;;;;6329:26;;1342:25:1;;;6277:13:0;;6329:26;;1315:18:1;6329:26:0;;;;;;;6368:37;9590:321;1457:132;1435:6;;-1:-1:-1;;;;;1435:6:0;915:10;1521:23;1513:68;;;;-1:-1:-1;;;1513:68:0;;6800:2:1;1513:68:0;;;6782:21:1;;;6819:18;;;6812:30;6878:34;6858:18;;;6851:62;6930:18;;1513:68:0;6598:356:1;1917:191:0;2010:6;;;-1:-1:-1;;;;;2027:17:0;;;-1:-1:-1;;;;;;2027:17:0;;;;;;;2060:40;;2010:6;;;2027:17;2010:6;;2060:40;;1991:16;;2060:40;1980:128;1917:191;:::o;9590:321::-;1435:6;;-1:-1:-1;;;;;9749:15:0;;;1435:6;;9749:15;;;;:40;;-1:-1:-1;1435:6:0;;-1:-1:-1;;;;;1435:6:0;9768:10;:21;;9749:40;:64;;;;-1:-1:-1;1435:6:0;;-1:-1:-1;;;;;1435:6:0;9793:9;:20;;9749:64;9745:159;;;9838:14;;-1:-1:-1;;;9838:14:0;;;;:22;;9856:4;9838:22;9830:62;;;;-1:-1:-1;;;9830:62:0;;7161:2:1;9830:62:0;;;7143:21:1;7200:2;7180:18;;;7173:30;7239:29;7219:18;;;7212:57;7286:18;;9830:62:0;6959:351:1;9830:62:0;9590:321;;;:::o;14:548:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:173::-;635:20;;-1:-1:-1;;;;;684:31:1;;674:42;;664:70;;730:1;727;720:12;664:70;567:173;;;:::o;745:254::-;813:6;821;874:2;862:9;853:7;849:23;845:32;842:52;;;890:1;887;880:12;842:52;913:29;932:9;913:29;:::i;:::-;903:39;989:2;974:18;;;;961:32;;-1:-1:-1;;;745:254:1:o;1378:328::-;1455:6;1463;1471;1524:2;1512:9;1503:7;1499:23;1495:32;1492:52;;;1540:1;1537;1530:12;1492:52;1563:29;1582:9;1563:29;:::i;:::-;1553:39;;1611:38;1645:2;1634:9;1630:18;1611:38;:::i;:::-;1601:48;;1696:2;1685:9;1681:18;1668:32;1658:42;;1378:328;;;;;:::o;1900:186::-;1959:6;2012:2;2000:9;1991:7;1987:23;1983:32;1980:52;;;2028:1;2025;2018:12;1980:52;2051:29;2070:9;2051:29;:::i;:::-;2041:39;1900:186;-1:-1:-1;;;1900:186:1:o;2299:260::-;2367:6;2375;2428:2;2416:9;2407:7;2403:23;2399:32;2396:52;;;2444:1;2441;2434:12;2396:52;2467:29;2486:9;2467:29;:::i;:::-;2457:39;;2515:38;2549:2;2538:9;2534:18;2515:38;:::i;:::-;2505:48;;2299:260;;;;;:::o;2790:380::-;2869:1;2865:12;;;;2912;;;2933:61;;2987:4;2979:6;2975:17;2965:27;;2933:61;3040:2;3032:6;3029:14;3009:18;3006:38;3003:161;;3086:10;3081:3;3077:20;3074:1;3067:31;3121:4;3118:1;3111:15;3149:4;3146:1;3139:15;3003:161;;2790:380;;;:::o;3175:222::-;3240:9;;;3261:10;;;3258:133;;;3313:10;3308:3;3304:20;3301:1;3294:31;3348:4;3345:1;3338:15;3376:4;3373:1;3366:15

Swarm Source

ipfs://e653b8229a0c463c8081529cf77adf8d92826607c78e6ac2e3f3e520d0ad7173

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading
[ Download: CSV Export  ]

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.