S Price: $0.459814 (-1.73%)
    /

    Contract

    0x6706Adb93117C0a7235dCBe639E12ed13fa5752f

    Overview

    S Balance

    Sonic LogoSonic LogoSonic Logo0 S

    S Value

    $0.00

    Multichain Info

    No addresses found
    Transaction Hash
    Method
    Block
    Age
    From
    To
    Amount
    Approve179588832025-04-03 18:08:491 min ago1743703729IN
    0x6706Adb9...13fa5752f
    0 S0.0026814655.01
    Approve179588422025-04-03 18:08:321 min ago1743703712IN
    0x6706Adb9...13fa5752f
    0 S0.003860679.2
    Transfer179587692025-04-03 18:08:052 mins ago1743703685IN
    0x6706Adb9...13fa5752f
    0 S0.001486350
    Approve179587032025-04-03 18:07:402 mins ago1743703660IN
    0x6706Adb9...13fa5752f
    0 S0.0019397763
    Approve179585302025-04-03 18:06:373 mins ago1743703597IN
    0x6706Adb9...13fa5752f
    0 S0.0026807455.01
    Approve179584272025-04-03 18:06:024 mins ago1743703562IN
    0x6706Adb9...13fa5752f
    0 S0.0026807455.01
    Transfer179583902025-04-03 18:05:494 mins ago1743703549IN
    0x6706Adb9...13fa5752f
    0 S0.0019898966.94113603
    Approve179580332025-04-03 18:03:376 mins ago1743703417IN
    0x6706Adb9...13fa5752f
    0 S0.0026814655.01
    Transfer179580262025-04-03 18:03:346 mins ago1743703414IN
    0x6706Adb9...13fa5752f
    0 S0.001486350.00000666
    Approve179578512025-04-03 18:02:307 mins ago1743703350IN
    0x6706Adb9...13fa5752f
    0 S0.0026800855.01
    Transfer179576612025-04-03 18:01:189 mins ago1743703278IN
    0x6706Adb9...13fa5752f
    0 S0.001486350.000105
    Approve179576402025-04-03 18:01:109 mins ago1743703270IN
    0x6706Adb9...13fa5752f
    0 S0.001536450
    Approve179575882025-04-03 18:00:529 mins ago1743703252IN
    0x6706Adb9...13fa5752f
    0 S0.0026814655.01
    Approve179575712025-04-03 18:00:459 mins ago1743703245IN
    0x6706Adb9...13fa5752f
    0 S0.0026814655.01
    Transfer179573242025-04-03 17:59:0211 mins ago1743703142IN
    0x6706Adb9...13fa5752f
    0 S0.001486350
    Transfer179569842025-04-03 17:56:4613 mins ago1743703006IN
    0x6706Adb9...13fa5752f
    0 S0.001486350
    Transfer179566332025-04-03 17:54:3015 mins ago1743702870IN
    0x6706Adb9...13fa5752f
    0 S0.001486350
    Approve179565462025-04-03 17:54:0116 mins ago1743702841IN
    0x6706Adb9...13fa5752f
    0 S0.0026807455.01
    Approve179563282025-04-03 17:52:3017 mins ago1743702750IN
    0x6706Adb9...13fa5752f
    0 S0.0029734461
    Transfer179562902025-04-03 17:52:1518 mins ago1743702735IN
    0x6706Adb9...13fa5752f
    0 S0.001486350
    Approve179561932025-04-03 17:51:3118 mins ago1743702691IN
    0x6706Adb9...13fa5752f
    0 S0.0026802655
    Approve179561182025-04-03 17:51:0219 mins ago1743702662IN
    0x6706Adb9...13fa5752f
    0 S0.001536450
    Transfer179559582025-04-03 17:49:5920 mins ago1743702599IN
    0x6706Adb9...13fa5752f
    0 S0.0016423655.25
    Approve179559452025-04-03 17:49:5420 mins ago1743702594IN
    0x6706Adb9...13fa5752f
    0 S0.0026805755.02
    Approve179558702025-04-03 17:49:2320 mins ago1743702563IN
    0x6706Adb9...13fa5752f
    0 S0.0026807455.01
    View all transactions

    Parent Transaction Hash Block Age From To Amount
    View All Internal Transactions
    Loading...
    Loading

    Contract Source Code Verified (Exact Match)

    Contract Name:
    SHIELD

    Compiler Version
    v0.8.20+commit.a1b79de6

    Optimization Enabled:
    Yes with 200 runs

    Other Settings:
    paris EvmVersion
    File 1 of 10 : SHIELD.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    pragma solidity ^0.8.20;
    import "@openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol";
    import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
    import "./owner/Operator.sol";
    import "./libraries/SafeMath.sol";
    contract SHIELD is ERC20Burnable, Operator {
    using SafeMath for uint256;
    uint256 public constant INITIAL_DAOFUND_DISTRIBUTION = 1000 ether; // 1000 SHIELD
    uint256 public constant GENESIS_DISTRIBUTION = 577500 ether; // 577500 SHIELD
    bool public rewardsDistributed = false;
    /**
    * @notice Constructs the SHIELD ERC-20 contract.
    */
    constructor() ERC20("SHIELD", "SHIELD") {
    // Mints 25 SHIELD to contract creator for initial pool setup
    _mint(msg.sender, 25 ether);
    }
    /**
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 2 of 10 : SafeMath.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    pragma solidity ^0.8.20;
    library SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
    return a + b;
    }
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
    return a - b;
    }
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
    require(b <= a, errorMessage);
    return a - b;
    }
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
    return a * b;
    }
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
    return a / b;
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 3 of 10 : Ownable.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.0.0) (access/Ownable.sol)
    pragma solidity ^0.8.20;
    import {Context} from "../utils/Context.sol";
    /**
    * @dev Contract module which provides a basic access control mechanism, where
    * there is an account (an owner) that can be granted exclusive access to
    * specific functions.
    *
    * The initial owner is set to the address provided by the deployer. This can
    * later be changed with {transferOwnership}.
    *
    * This module is used through inheritance. It will make available the modifier
    * `onlyOwner`, which can be applied to your functions to restrict their use to
    * the owner.
    */
    abstract contract Ownable is Context {
    address private _owner;
    /**
    * @dev The caller account is not authorized to perform an operation.
    */
    error OwnableUnauthorizedAccount(address account);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 4 of 10 : draft-IERC6093.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.1.0) (interfaces/draft-IERC6093.sol)
    pragma solidity ^0.8.20;
    /**
    * @dev Standard ERC-20 Errors
    * Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC-20 tokens.
    */
    interface IERC20Errors {
    /**
    * @dev Indicates an error related to the current `balance` of a `sender`. Used in transfers.
    * @param sender Address whose tokens are being transferred.
    * @param balance Current balance for the interacting account.
    * @param needed Minimum amount required to perform a transfer.
    */
    error ERC20InsufficientBalance(address sender, uint256 balance, uint256 needed);
    /**
    * @dev Indicates a failure with the token `sender`. Used in transfers.
    * @param sender Address whose tokens are being transferred.
    */
    error ERC20InvalidSender(address sender);
    /**
    * @dev Indicates a failure with the token `receiver`. Used in transfers.
    * @param receiver Address to which tokens are being transferred.
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 5 of 10 : ERC20.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.2.0) (token/ERC20/ERC20.sol)
    pragma solidity ^0.8.20;
    import {IERC20} from "./IERC20.sol";
    import {IERC20Metadata} from "./extensions/IERC20Metadata.sol";
    import {Context} from "../../utils/Context.sol";
    import {IERC20Errors} from "../../interfaces/draft-IERC6093.sol";
    /**
    * @dev Implementation of the {IERC20} interface.
    *
    * This implementation is agnostic to the way tokens are created. This means
    * that a supply mechanism has to be added in a derived contract using {_mint}.
    *
    * TIP: For a detailed writeup see our guide
    * https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How
    * to implement supply mechanisms].
    *
    * The default value of {decimals} is 18. To change this, you should override
    * this function so it returns a different value.
    *
    * We have followed general OpenZeppelin Contracts guidelines: functions revert
    * instead returning `false` on failure. This behavior is nonetheless
    * conventional and does not conflict with the expectations of ERC-20
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 6 of 10 : IERC20.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.1.0) (token/ERC20/IERC20.sol)
    pragma solidity ^0.8.20;
    /**
    * @dev Interface of the ERC-20 standard as defined in the ERC.
    */
    interface IERC20 {
    /**
    * @dev Emitted when `value` tokens are moved from one account (`from`) to
    * another (`to`).
    *
    * Note that `value` may be zero.
    */
    event Transfer(address indexed from, address indexed to, uint256 value);
    /**
    * @dev Emitted when the allowance of a `spender` for an `owner` is set by
    * a call to {approve}. `value` is the new allowance.
    */
    event Approval(address indexed owner, address indexed spender, uint256 value);
    /**
    * @dev Returns the value of tokens in existence.
    */
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 7 of 10 : ERC20Burnable.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/extensions/ERC20Burnable.sol)
    pragma solidity ^0.8.20;
    import {ERC20} from "../ERC20.sol";
    import {Context} from "../../../utils/Context.sol";
    /**
    * @dev Extension of {ERC20} that allows token holders to destroy both their own
    * tokens and those that they have an allowance for, in a way that can be
    * recognized off-chain (via event analysis).
    */
    abstract contract ERC20Burnable is Context, ERC20 {
    /**
    * @dev Destroys a `value` amount of tokens from the caller.
    *
    * See {ERC20-_burn}.
    */
    function burn(uint256 value) public virtual {
    _burn(_msgSender(), value);
    }
    /**
    * @dev Destroys a `value` amount of tokens from `account`, deducting from
    * the caller's allowance.
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 8 of 10 : IERC20Metadata.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.1.0) (token/ERC20/extensions/IERC20Metadata.sol)
    pragma solidity ^0.8.20;
    import {IERC20} from "../IERC20.sol";
    /**
    * @dev Interface for the optional metadata functions from the ERC-20 standard.
    */
    interface IERC20Metadata is IERC20 {
    /**
    * @dev Returns the name of the token.
    */
    function name() external view returns (string memory);
    /**
    * @dev Returns the symbol of the token.
    */
    function symbol() external view returns (string memory);
    /**
    * @dev Returns the decimals places of the token.
    */
    function decimals() external view returns (uint8);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 9 of 10 : Context.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v5.0.1) (utils/Context.sol)
    pragma solidity ^0.8.20;
    /**
    * @dev Provides information about the current execution context, including the
    * sender of the transaction and its data. While these are generally available
    * via msg.sender and msg.data, they should not be accessed in such a direct
    * manner, since when dealing with meta-transactions the account sending and
    * paying for execution may not be the actual sender (as far as an application
    * is concerned).
    *
    * This contract is only required for intermediate, library-like contracts.
    */
    abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
    return msg.sender;
    }
    function _msgData() internal view virtual returns (bytes calldata) {
    return msg.data;
    }
    function _contextSuffixLength() internal view virtual returns (uint256) {
    return 0;
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 10 of 10 : Operator.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    pragma solidity ^0.8.20;
    import "@openzeppelin/contracts/access/Ownable.sol";
    contract Operator is Ownable {
    address private _operator;
    event OperatorTransferred(address indexed previousOperator, address indexed newOperator);
    constructor() Ownable(msg.sender)
    {
    _operator = msg.sender;
    emit OperatorTransferred(address(0), _operator);
    }
    function operator() public view returns (address) {
    return _operator;
    }
    modifier onlyOperator() {
    require(_operator == msg.sender, "operator: caller is not the operator");
    _;
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Settings
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    {
    "optimizer": {
    "enabled": true,
    "runs": 200
    },
    "viaIR": false,
    "outputSelection": {
    "*": {
    "*": [
    "evm.bytecode",
    "evm.deployedBytecode",
    "devdoc",
    "userdoc",
    "metadata",
    "abi"
    ]
    }
    },
    "remappings": [
    "@=node_modules/@"
    ],
    "evmVersion": "paris"
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Contract Security Audit

    Contract ABI

    API
    [{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"allowance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientAllowance","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"uint256","name":"balance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientBalance","type":"error"},{"inputs":[{"internalType":"address","name":"approver","type":"address"}],"name":"ERC20InvalidApprover","type":"error"},{"inputs":[{"internalType":"address","name":"receiver","type":"address"}],"name":"ERC20InvalidReceiver","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"}],"name":"ERC20InvalidSender","type":"error"},{"inputs":[{"internalType":"address","name":"spender","type":"address"}],"name":"ERC20InvalidSpender","type":"error"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"OwnableInvalidOwner","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"OwnableUnauthorizedAccount","type":"error"},{"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":"previousOperator","type":"address"},{"indexed":true,"internalType":"address","name":"newOperator","type":"address"}],"name":"OperatorTransferred","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":[],"name":"GENESIS_DISTRIBUTION","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"INITIAL_DAOFUND_DISTRIBUTION","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"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":"value","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":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burnFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_daoFund","type":"address"},{"internalType":"address","name":"_genesis","type":"address"}],"name":"distributeReward","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"_token","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"address","name":"_to","type":"address"}],"name":"governanceRecoverUnsupported","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"recipient_","type":"address"},{"internalType":"uint256","name":"amount_","type":"uint256"}],"name":"mint","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":"operator","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rewardsDistributed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"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":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOperator_","type":"address"}],"name":"transferOperator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]

    60806040526006805460ff60a01b191690553480156200001e57600080fd5b5060408051808201825260068082526514d21251531160d21b6020808401829052845180860190955291845290830152339160036200005e83826200036f565b5060046200006d82826200036f565b5050506001600160a01b038116620000a057604051631e4fbdf760e01b8152600060048201526024015b60405180910390fd5b620000ab8162000107565b50600680546001600160a01b031916339081179091556040516000907f74da04524d50c64947f5dd5381ef1a4dca5cba8ed1d816243f9e48aa0b5617ed908290a3620001013368015af1d78b58c4000062000159565b62000463565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038216620001855760405163ec442f0560e01b81526000600482015260240162000097565b620001936000838362000197565b5050565b6001600160a01b038316620001c6578060026000828254620001ba91906200043b565b909155506200023a9050565b6001600160a01b038316600090815260208190526040902054818110156200021b5760405163391434e360e21b81526001600160a01b0385166004820152602481018290526044810183905260640162000097565b6001600160a01b03841660009081526020819052604090209082900390555b6001600160a01b038216620002585760028054829003905562000277565b6001600160a01b03821660009081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051620002bd91815260200190565b60405180910390a3505050565b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620002f557607f821691505b6020821081036200031657634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200036a57600081815260208120601f850160051c81016020861015620003455750805b601f850160051c820191505b81811015620003665782815560010162000351565b5050505b505050565b81516001600160401b038111156200038b576200038b620002ca565b620003a3816200039c8454620002e0565b846200031c565b602080601f831160018114620003db5760008415620003c25750858301515b600019600386901b1c1916600185901b17855562000366565b600085815260208120601f198616915b828110156200040c57888601518255948401946001909101908401620003eb565b50858210156200042b5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b808201808211156200045d57634e487b7160e01b600052601160045260246000fd5b92915050565b610f5080620004736000396000f3fe608060405234801561001057600080fd5b50600436106101425760003560e01c8063570ca735116100b857806395d89b411161007c57806395d89b41146102a55780639c1454d4146102ad578063a9059cbb146102c1578063dd62ed3e146102d4578063f2fde38b1461030d578063f4fd47cf1461032057600080fd5b8063570ca7351461022b57806370a0823114610250578063715018a61461027957806379cc6790146102815780638da5cb5b1461029457600080fd5b8063313ce5671161010a578063313ce567146101c257806331bdc35e146101d157806340c10f19146101e257806342966c68146101f557806350c5bd721461020857806354575af41461021857600080fd5b806306fdde0314610147578063095ea7b31461016557806318160ddd1461018857806323b872dd1461019a57806329605e77146101ad575b600080fd5b61014f610333565b60405161015c9190610c8e565b60405180910390f35b610178610173366004610cf1565b6103c5565b604051901515815260200161015c565b6002545b60405190815260200161015c565b6101786101a8366004610d1d565b6103df565b6101c06101bb366004610d5e565b61042e565b005b6040516012815260200161015c565b61018c697a4a567581ddb5f0000081565b6101786101f0366004610cf1565b610442565b6101c0610203366004610d82565b6104c0565b61018c683635c9adc5dea0000081565b6101c0610226366004610d9b565b6104c9565b6006546001600160a01b03165b6040516001600160a01b03909116815260200161015c565b61018c61025e366004610d5e565b6001600160a01b031660009081526020819052604090205490565b6101c061056c565b6101c061028f366004610cf1565b6105c7565b6005546001600160a01b0316610238565b61014f6105ff565b60065461017890600160a01b900460ff1681565b6101786102cf366004610cf1565b61060e565b61018c6102e2366004610ddd565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6101c061031b366004610d5e565b61061c565b6101c061032e366004610ddd565b610657565b60606003805461034290610e16565b80601f016020809104026020016040519081016040528092919081815260200182805461036e90610e16565b80156103bb5780601f10610390576101008083540402835291602001916103bb565b820191906000526020600020905b81548152906001019060200180831161039e57829003601f168201915b5050505050905090565b6000336103d381858561079a565b60019150505b92915050565b60006103ec8484846107ac565b610424843361041f85604051806060016040528060288152602001610ef3602891396104188a336102e2565b919061080b565b61079a565b5060019392505050565b610436610842565b61043f81610871565b50565b6006546000906001600160a01b031633146104785760405162461bcd60e51b815260040161046f90610e50565b60405180910390fd5b6001600160a01b03831660009081526020819052604090205461049b8484610939565b6001600160a01b03841660009081526020819052604081205491909111949350505050565b61043f8161096f565b6006546001600160a01b031633146104f35760405162461bcd60e51b815260040161046f90610e50565b60405163a9059cbb60e01b81526001600160a01b0382811660048301526024820184905284169063a9059cbb906044016020604051808303816000875af1158015610542573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906105669190610e94565b50505050565b610574610842565b60405162461bcd60e51b815260206004820152602260248201527f4f70657261746f72206d75737420616c77617973206861766520616e206f776e60448201526132b960f11b606482015260840161046f565b6006546001600160a01b031633146105f15760405162461bcd60e51b815260040161046f90610e50565b6105fb8282610979565b5050565b60606004805461034290610e16565b6000336103d38185856107ac565b610624610842565b6001600160a01b03811661064e57604051631e4fbdf760e01b81526000600482015260240161046f565b61043f8161098e565b6006546001600160a01b031633146106815760405162461bcd60e51b815260040161046f90610e50565b6001600160a01b0382166106c45760405162461bcd60e51b815260206004820152600a602482015269215f747265617375727960b01b604482015260640161046f565b6001600160a01b0381166107065760405162461bcd60e51b8152602060048201526009602482015268215f67656e6573697360b81b604482015260640161046f565b600654600160a01b900460ff16156107605760405162461bcd60e51b815260206004820152601860248201527f6f6e6c792063616e2064697374726962757465206f6e63650000000000000000604482015260640161046f565b6006805460ff60a01b1916600160a01b17905561078682683635c9adc5dea00000610939565b6105fb81697a4a567581ddb5f00000610939565b6107a783838360016109e0565b505050565b6001600160a01b0383166107d657604051634b637e8f60e11b81526000600482015260240161046f565b6001600160a01b0382166108005760405163ec442f0560e01b81526000600482015260240161046f565b6107a7838383610ab5565b6000818484111561082f5760405162461bcd60e51b815260040161046f9190610c8e565b5061083a8385610ecc565b949350505050565b6005546001600160a01b0316331461086f5760405163118cdaa760e01b815233600482015260240161046f565b565b6001600160a01b0381166108dd5760405162461bcd60e51b815260206004820152602d60248201527f6f70657261746f723a207a65726f206164647265737320676976656e20666f7260448201526c103732bb9037b832b930ba37b960991b606482015260840161046f565b6006546040516001600160a01b038084169216907f74da04524d50c64947f5dd5381ef1a4dca5cba8ed1d816243f9e48aa0b5617ed90600090a3600680546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0382166109635760405163ec442f0560e01b81526000600482015260240161046f565b6105fb60008383610ab5565b61043f3382610bdf565b610984823383610c15565b6105fb8282610bdf565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038416610a0a5760405163e602df0560e01b81526000600482015260240161046f565b6001600160a01b038316610a3457604051634a1406b160e11b81526000600482015260240161046f565b6001600160a01b038085166000908152600160209081526040808320938716835292905220829055801561056657826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92584604051610aa791815260200190565b60405180910390a350505050565b6001600160a01b038316610ae0578060026000828254610ad59190610edf565b90915550610b529050565b6001600160a01b03831660009081526020819052604090205481811015610b335760405163391434e360e21b81526001600160a01b0385166004820152602481018290526044810183905260640161046f565b6001600160a01b03841660009081526020819052604090209082900390555b6001600160a01b038216610b6e57600280548290039055610b8d565b6001600160a01b03821660009081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610bd291815260200190565b60405180910390a3505050565b6001600160a01b038216610c0957604051634b637e8f60e11b81526000600482015260240161046f565b6105fb82600083610ab5565b6001600160a01b038381166000908152600160209081526040808320938616835292905220546000198110156105665781811015610c7f57604051637dc7a0d960e11b81526001600160a01b0384166004820152602481018290526044810183905260640161046f565b610566848484840360006109e0565b600060208083528351808285015260005b81811015610cbb57858101830151858201604001528201610c9f565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461043f57600080fd5b60008060408385031215610d0457600080fd5b8235610d0f81610cdc565b946020939093013593505050565b600080600060608486031215610d3257600080fd5b8335610d3d81610cdc565b92506020840135610d4d81610cdc565b929592945050506040919091013590565b600060208284031215610d7057600080fd5b8135610d7b81610cdc565b9392505050565b600060208284031215610d9457600080fd5b5035919050565b600080600060608486031215610db057600080fd5b8335610dbb81610cdc565b9250602084013591506040840135610dd281610cdc565b809150509250925092565b60008060408385031215610df057600080fd5b8235610dfb81610cdc565b91506020830135610e0b81610cdc565b809150509250929050565b600181811c90821680610e2a57607f821691505b602082108103610e4a57634e487b7160e01b600052602260045260246000fd5b50919050565b60208082526024908201527f6f70657261746f723a2063616c6c6572206973206e6f7420746865206f70657260408201526330ba37b960e11b606082015260800190565b600060208284031215610ea657600080fd5b81518015158114610d7b57600080fd5b634e487b7160e01b600052601160045260246000fd5b818103818111156103d9576103d9610eb6565b808201808211156103d9576103d9610eb656fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122038359259a3ee4929f838fd5edb4460074633622c6108febd7d8b02d9d8d3998564736f6c63430008140033

    Deployed Bytecode

    0x608060405234801561001057600080fd5b50600436106101425760003560e01c8063570ca735116100b857806395d89b411161007c57806395d89b41146102a55780639c1454d4146102ad578063a9059cbb146102c1578063dd62ed3e146102d4578063f2fde38b1461030d578063f4fd47cf1461032057600080fd5b8063570ca7351461022b57806370a0823114610250578063715018a61461027957806379cc6790146102815780638da5cb5b1461029457600080fd5b8063313ce5671161010a578063313ce567146101c257806331bdc35e146101d157806340c10f19146101e257806342966c68146101f557806350c5bd721461020857806354575af41461021857600080fd5b806306fdde0314610147578063095ea7b31461016557806318160ddd1461018857806323b872dd1461019a57806329605e77146101ad575b600080fd5b61014f610333565b60405161015c9190610c8e565b60405180910390f35b610178610173366004610cf1565b6103c5565b604051901515815260200161015c565b6002545b60405190815260200161015c565b6101786101a8366004610d1d565b6103df565b6101c06101bb366004610d5e565b61042e565b005b6040516012815260200161015c565b61018c697a4a567581ddb5f0000081565b6101786101f0366004610cf1565b610442565b6101c0610203366004610d82565b6104c0565b61018c683635c9adc5dea0000081565b6101c0610226366004610d9b565b6104c9565b6006546001600160a01b03165b6040516001600160a01b03909116815260200161015c565b61018c61025e366004610d5e565b6001600160a01b031660009081526020819052604090205490565b6101c061056c565b6101c061028f366004610cf1565b6105c7565b6005546001600160a01b0316610238565b61014f6105ff565b60065461017890600160a01b900460ff1681565b6101786102cf366004610cf1565b61060e565b61018c6102e2366004610ddd565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6101c061031b366004610d5e565b61061c565b6101c061032e366004610ddd565b610657565b60606003805461034290610e16565b80601f016020809104026020016040519081016040528092919081815260200182805461036e90610e16565b80156103bb5780601f10610390576101008083540402835291602001916103bb565b820191906000526020600020905b81548152906001019060200180831161039e57829003601f168201915b5050505050905090565b6000336103d381858561079a565b60019150505b92915050565b60006103ec8484846107ac565b610424843361041f85604051806060016040528060288152602001610ef3602891396104188a336102e2565b919061080b565b61079a565b5060019392505050565b610436610842565b61043f81610871565b50565b6006546000906001600160a01b031633146104785760405162461bcd60e51b815260040161046f90610e50565b60405180910390fd5b6001600160a01b03831660009081526020819052604090205461049b8484610939565b6001600160a01b03841660009081526020819052604081205491909111949350505050565b61043f8161096f565b6006546001600160a01b031633146104f35760405162461bcd60e51b815260040161046f90610e50565b60405163a9059cbb60e01b81526001600160a01b0382811660048301526024820184905284169063a9059cbb906044016020604051808303816000875af1158015610542573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906105669190610e94565b50505050565b610574610842565b60405162461bcd60e51b815260206004820152602260248201527f4f70657261746f72206d75737420616c77617973206861766520616e206f776e60448201526132b960f11b606482015260840161046f565b6006546001600160a01b031633146105f15760405162461bcd60e51b815260040161046f90610e50565b6105fb8282610979565b5050565b60606004805461034290610e16565b6000336103d38185856107ac565b610624610842565b6001600160a01b03811661064e57604051631e4fbdf760e01b81526000600482015260240161046f565b61043f8161098e565b6006546001600160a01b031633146106815760405162461bcd60e51b815260040161046f90610e50565b6001600160a01b0382166106c45760405162461bcd60e51b815260206004820152600a602482015269215f747265617375727960b01b604482015260640161046f565b6001600160a01b0381166107065760405162461bcd60e51b8152602060048201526009602482015268215f67656e6573697360b81b604482015260640161046f565b600654600160a01b900460ff16156107605760405162461bcd60e51b815260206004820152601860248201527f6f6e6c792063616e2064697374726962757465206f6e63650000000000000000604482015260640161046f565b6006805460ff60a01b1916600160a01b17905561078682683635c9adc5dea00000610939565b6105fb81697a4a567581ddb5f00000610939565b6107a783838360016109e0565b505050565b6001600160a01b0383166107d657604051634b637e8f60e11b81526000600482015260240161046f565b6001600160a01b0382166108005760405163ec442f0560e01b81526000600482015260240161046f565b6107a7838383610ab5565b6000818484111561082f5760405162461bcd60e51b815260040161046f9190610c8e565b5061083a8385610ecc565b949350505050565b6005546001600160a01b0316331461086f5760405163118cdaa760e01b815233600482015260240161046f565b565b6001600160a01b0381166108dd5760405162461bcd60e51b815260206004820152602d60248201527f6f70657261746f723a207a65726f206164647265737320676976656e20666f7260448201526c103732bb9037b832b930ba37b960991b606482015260840161046f565b6006546040516001600160a01b038084169216907f74da04524d50c64947f5dd5381ef1a4dca5cba8ed1d816243f9e48aa0b5617ed90600090a3600680546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0382166109635760405163ec442f0560e01b81526000600482015260240161046f565b6105fb60008383610ab5565b61043f3382610bdf565b610984823383610c15565b6105fb8282610bdf565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b038416610a0a5760405163e602df0560e01b81526000600482015260240161046f565b6001600160a01b038316610a3457604051634a1406b160e11b81526000600482015260240161046f565b6001600160a01b038085166000908152600160209081526040808320938716835292905220829055801561056657826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92584604051610aa791815260200190565b60405180910390a350505050565b6001600160a01b038316610ae0578060026000828254610ad59190610edf565b90915550610b529050565b6001600160a01b03831660009081526020819052604090205481811015610b335760405163391434e360e21b81526001600160a01b0385166004820152602481018290526044810183905260640161046f565b6001600160a01b03841660009081526020819052604090209082900390555b6001600160a01b038216610b6e57600280548290039055610b8d565b6001600160a01b03821660009081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610bd291815260200190565b60405180910390a3505050565b6001600160a01b038216610c0957604051634b637e8f60e11b81526000600482015260240161046f565b6105fb82600083610ab5565b6001600160a01b038381166000908152600160209081526040808320938616835292905220546000198110156105665781811015610c7f57604051637dc7a0d960e11b81526001600160a01b0384166004820152602481018290526044810183905260640161046f565b610566848484840360006109e0565b600060208083528351808285015260005b81811015610cbb57858101830151858201604001528201610c9f565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461043f57600080fd5b60008060408385031215610d0457600080fd5b8235610d0f81610cdc565b946020939093013593505050565b600080600060608486031215610d3257600080fd5b8335610d3d81610cdc565b92506020840135610d4d81610cdc565b929592945050506040919091013590565b600060208284031215610d7057600080fd5b8135610d7b81610cdc565b9392505050565b600060208284031215610d9457600080fd5b5035919050565b600080600060608486031215610db057600080fd5b8335610dbb81610cdc565b9250602084013591506040840135610dd281610cdc565b809150509250925092565b60008060408385031215610df057600080fd5b8235610dfb81610cdc565b91506020830135610e0b81610cdc565b809150509250929050565b600181811c90821680610e2a57607f821691505b602082108103610e4a57634e487b7160e01b600052602260045260246000fd5b50919050565b60208082526024908201527f6f70657261746f723a2063616c6c6572206973206e6f7420746865206f70657260408201526330ba37b960e11b606082015260800190565b600060208284031215610ea657600080fd5b81518015158114610d7b57600080fd5b634e487b7160e01b600052601160045260246000fd5b818103818111156103d9576103d9610eb6565b808201808211156103d9576103d9610eb656fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122038359259a3ee4929f838fd5edb4460074633622c6108febd7d8b02d9d8d3998564736f6c63430008140033

    Block Age Transaction Gas Used Reward
    view all blocks ##produced##

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

    Validator Index Block Age Amount
    View All Withdrawals

    Transaction Hash Block Age Value Eth2 PubKey Valid
    View All Deposits
    [ 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.