S Price: $0.807828 (-5.79%)
    /

    Contract

    0x487e54d9e5021F092EF33923CbB9424cfC561b9a

    Overview

    S Balance

    Sonic LogoSonic LogoSonic Logo0 S

    S Value

    $0.00

    Multichain Info

    No addresses found
    Transaction Hash
    Method
    Block
    Age
    From
    To
    Notify Reward Am...74366562025-02-11 19:04:1711 days ago1739300657IN
    0x487e54d9...cfC561b9a
    0 S0.0140606155.01
    Notify Reward Am...66899002025-02-05 19:45:4617 days ago1738784746IN
    0x487e54d9...cfC561b9a
    0 S0.0140606155.01
    Notify Reward Am...57913122025-01-29 15:52:3124 days ago1738165951IN
    0x487e54d9...cfC561b9a
    0 S0.017939255.01

    Latest 1 internal transaction

    Parent Transaction Hash Block Age From To Amount
    57041612025-01-28 18:48:5025 days ago1738090130
     Contract Creation
    0 S
    Loading...
    Loading

    Similar Match Source Code
    This contract matches the deployed Bytecode of the Source Code for Contract 0x959664AE...dcB9f8f4d
    The constructor portion of the code might be different and could alter the actual behaviour of the contract

    Contract Name:
    Bribe

    Compiler Version
    v0.8.13+commit.abaa5c0e

    Optimization Enabled:
    Yes with 200 runs

    Other Settings:
    default evmVersion
    File 1 of 13 : Bribes.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.11;
    import "./interfaces/IMinter.sol";
    import "./interfaces/IVoter.sol";
    import "./interfaces/IVotingEscrow.sol";
    import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
    import './libraries/Math.sol';
    import './libraries/Constants.sol';
    import "@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol";
    import "@openzeppelin/contracts/security/ReentrancyGuard.sol";
    import "@openzeppelin/contracts/access/Ownable.sol";
    contract Bribe is ReentrancyGuard {
    using SafeERC20 for IERC20;
    uint256 public firstBribeTimestamp;
    /* ========== STATE VARIABLES ========== */
    struct Reward {
    uint256 periodFinish;
    uint256 rewardsPerEpoch;
    uint256 lastUpdateTime;
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 2 of 13 : 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 v4.7.0) (access/Ownable.sol)
    pragma solidity ^0.8.0;
    import "../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.
    *
    * By default, the owner account will be the one that deploys the contract. 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;
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
    /**
    * @dev Initializes the contract setting the deployer as the initial owner.
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 3 of 13 : ReentrancyGuard.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 v4.8.0) (security/ReentrancyGuard.sol)
    pragma solidity ^0.8.0;
    /**
    * @dev Contract module that helps prevent reentrant calls to a function.
    *
    * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier
    * available, which can be applied to functions to make sure there are no nested
    * (reentrant) calls to them.
    *
    * Note that because there is a single `nonReentrant` guard, functions marked as
    * `nonReentrant` may not call one another. This can be worked around by making
    * those functions `private`, and then adding `external` `nonReentrant` entry
    * points to them.
    *
    * TIP: If you would like to learn more about reentrancy and alternative ways
    * to protect against it, check out our blog post
    * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].
    */
    abstract contract ReentrancyGuard {
    // Booleans are more expensive than uint256 or any type that takes up a full
    // word because each write operation emits an extra SLOAD to first read the
    // slot's contents, replace the bits taken up by the boolean, and then write
    // back. This is the compiler's defense against contract upgrades and
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 4 of 13 : draft-IERC20Permit.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 v4.4.1 (token/ERC20/extensions/draft-IERC20Permit.sol)
    pragma solidity ^0.8.0;
    /**
    * @dev Interface of the ERC20 Permit extension allowing approvals to be made via signatures, as defined in
    * https://eips.ethereum.org/EIPS/eip-2612[EIP-2612].
    *
    * Adds the {permit} method, which can be used to change an account's ERC20 allowance (see {IERC20-allowance}) by
    * presenting a message signed by the account. By not relying on {IERC20-approve}, the token holder account doesn't
    * need to send a transaction, and thus is not required to hold Ether at all.
    */
    interface IERC20Permit {
    /**
    * @dev Sets `value` as the allowance of `spender` over ``owner``'s tokens,
    * given ``owner``'s signed approval.
    *
    * IMPORTANT: The same issues {IERC20-approve} has related to transaction
    * ordering also apply here.
    *
    * Emits an {Approval} event.
    *
    * Requirements:
    *
    * - `spender` cannot be the zero address.
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 5 of 13 : 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 v4.6.0) (token/ERC20/IERC20.sol)
    pragma solidity ^0.8.0;
    /**
    * @dev Interface of the ERC20 standard as defined in the EIP.
    */
    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 amount of tokens in existence.
    */
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 6 of 13 : SafeERC20.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 v4.8.0) (token/ERC20/utils/SafeERC20.sol)
    pragma solidity ^0.8.0;
    import "../IERC20.sol";
    import "../extensions/draft-IERC20Permit.sol";
    import "../../../utils/Address.sol";
    /**
    * @title SafeERC20
    * @dev Wrappers around ERC20 operations that throw on failure (when the token
    * contract returns false). Tokens that return no value (and instead revert or
    * throw on failure) are also supported, non-reverting calls are assumed to be
    * successful.
    * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract,
    * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
    */
    library SafeERC20 {
    using Address for address;
    function safeTransfer(
    IERC20 token,
    address to,
    uint256 value
    ) internal {
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 7 of 13 : Address.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 v4.8.0) (utils/Address.sol)
    pragma solidity ^0.8.1;
    /**
    * @dev Collection of functions related to the address type
    */
    library Address {
    /**
    * @dev Returns true if `account` is a contract.
    *
    * [IMPORTANT]
    * ====
    * It is unsafe to assume that an address for which this function returns
    * false is an externally-owned account (EOA) and not a contract.
    *
    * Among others, `isContract` will return false for the following
    * types of addresses:
    *
    * - an externally-owned account
    * - a contract in construction
    * - an address where a contract will be created
    * - an address where a contract lived, but was destroyed
    * ====
    *
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 8 of 13 : 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
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts v4.4.1 (utils/Context.sol)
    pragma solidity ^0.8.0;
    /**
    * @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;
    }
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 9 of 13 : IMinter.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    // SPDX-License-Identifier: MIT
    pragma solidity 0.8.13;
    interface IMinter {
    function update_period() external returns (uint);
    function check() external view returns(bool);
    function period() external view returns(uint);
    function active_period() external view returns(uint);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 10 of 13 : IVoter.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
    // SPDX-License-Identifier: MIT
    pragma solidity 0.8.13;
    interface IVoter {
    function _ve() external view returns (address);
    function gauges(address _pair) external view returns (address);
    function isGauge(address _gauge) external view returns (bool);
    function poolForGauge(address _gauge) external view returns (address);
    function factory() external view returns (address);
    function minter() external view returns(address);
    function isWhitelisted(address token) external view returns (bool);
    function notifyRewardAmount(uint amount) external;
    function distributeAll() external;
    function distributeFees(address[] memory _gauges) external;
    function internal_bribes(address _gauge) external view returns (address);
    function external_bribes(address _gauge) external view returns (address);
    function usedWeights(uint id) external view returns(uint);
    function lastVoted(uint id) external view returns(uint);
    function poolVote(uint id, uint _index) external view returns(address _pair);
    function votes(uint id, address _pool) external view returns(uint votes);
    function poolVoteLength(uint tokenId) external view returns(uint);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 11 of 13 : IVotingEscrow.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.13;
    interface IVotingEscrow {
    struct Point {
    int128 bias;
    int128 slope; // # -dweight / dt
    uint256 ts;
    uint256 blk; // block
    }
    struct LockedBalance {
    int128 amount;
    uint start;
    uint end;
    }
    function create_lock_for(uint _value, uint _lock_duration, address _to) external returns (uint);
    function locked(uint id) external view returns(LockedBalance memory);
    function tokenOfOwnerByIndex(address _owner, uint _tokenIndex) external view returns (uint);
    function token() external view returns (address);
    function team() external returns (address);
    function epoch() external view returns (uint);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 12 of 13 : Constants.sol
    1
    2
    3
    4
    5
    6
    // SPDX-License-Identifier: MIT
    pragma solidity 0.8.13;
    library Constants {
    uint256 internal constant EPOCH_LENGTH = 7 days;
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 13 of 13 : Math.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.13;
    library Math {
    function max(uint a, uint b) internal pure returns (uint) {
    return a >= b ? a : b;
    }
    function min(uint a, uint b) internal pure returns (uint) {
    return a < b ? a : b;
    }
    function sqrt(uint y) internal pure returns (uint z) {
    if (y > 3) {
    z = y;
    uint x = y / 2 + 1;
    while (x < z) {
    z = x;
    x = (y / x + x) / 2;
    }
    } else if (y != 0) {
    z = 1;
    }
    }
    function cbrt(uint256 n) internal pure returns (uint256) { unchecked {
    uint256 x = 0;
    for (uint256 y = 1 << 255; y > 0; y >>= 3) {
    x <<= 1;
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Settings
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    {
    "optimizer": {
    "enabled": true,
    "runs": 200
    },
    "outputSelection": {
    "*": {
    "*": [
    "evm.bytecode",
    "evm.deployedBytecode",
    "devdoc",
    "userdoc",
    "metadata",
    "abi"
    ]
    }
    },
    "libraries": {}
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Contract Security Audit

    Contract ABI

    [{"inputs":[{"internalType":"address","name":"_owner","type":"address"},{"internalType":"address","name":"_voter","type":"address"},{"internalType":"address","name":"_bribeFactory","type":"address"},{"internalType":"string","name":"_type","type":"string"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"token","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Recovered","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"rewardToken","type":"address"},{"indexed":false,"internalType":"uint256","name":"reward","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"startTimestamp","type":"uint256"}],"name":"RewardAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"address","name":"rewardsToken","type":"address"},{"indexed":false,"internalType":"uint256","name":"reward","type":"uint256"}],"name":"RewardPaid","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"bribesAddress","type":"address"},{"indexed":true,"internalType":"address","name":"newRewardToken","type":"address"}],"name":"RewardTokenAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Staked","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Withdrawn","type":"event"},{"inputs":[],"name":"TYPE","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"_deposit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"_totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"_withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_rewardsToken","type":"address"}],"name":"addReward","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"_rewardsToken","type":"address[]"}],"name":"addRewards","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"uint256","name":"_timestamp","type":"uint256"}],"name":"balanceOfAt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"balanceOfOwner","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"},{"internalType":"uint256","name":"_timestamp","type":"uint256"}],"name":"balanceOfOwnerAt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"bribeFactory","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"},{"internalType":"address","name":"_rewardToken","type":"address"}],"name":"earned","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"address","name":"_rewardToken","type":"address"}],"name":"earned","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"tokenAddress","type":"address"},{"internalType":"uint256","name":"tokenAmount","type":"uint256"}],"name":"emergencyRecoverERC20","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"firstBribeTimestamp","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getEpochStart","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getNextEpochStart","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"tokens","type":"address[]"}],"name":"getReward","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"address[]","name":"tokens","type":"address[]"}],"name":"getReward","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"},{"internalType":"address[]","name":"tokens","type":"address[]"}],"name":"getRewardForAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"address[]","name":"tokens","type":"address[]"}],"name":"getRewardForOwner","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isRewardToken","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minter","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_rewardsToken","type":"address"},{"internalType":"uint256","name":"reward","type":"uint256"}],"name":"notifyRewardAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"tokenAddress","type":"address"},{"internalType":"uint256","name":"tokenAmount","type":"uint256"}],"name":"recoverERC20AndUpdateData","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"rewardData","outputs":[{"internalType":"uint256","name":"periodFinish","type":"uint256"},{"internalType":"uint256","name":"rewardsPerEpoch","type":"uint256"},{"internalType":"uint256","name":"lastUpdateTime","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_rewardsToken","type":"address"},{"internalType":"uint256","name":"_timestamp","type":"uint256"}],"name":"rewardPerToken","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"rewardTokens","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rewardsListLength","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_minter","type":"address"}],"name":"setMinter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"setOwner","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_Voter","type":"address"}],"name":"setVoter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_timestamp","type":"uint256"}],"name":"totalSupplyAt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"userRewardPerTokenPaid","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"userTimestamp","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"ve","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"voter","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"}]

    Deployed Bytecode

    0x608060405234801561001057600080fd5b506004361061023d5760003560e01c80638da5cb5b1161013b578063bb24fe8a116100b8578063e68863961161007c578063e688639614610597578063eb4a78e01461059f578063f3207723146105b2578063f5f8d365146105c5578063fca3b5aa146105d857600080fd5b8063bb24fe8a14610536578063c66130d71461054b578063c95bda701461055e578063db0ea98414610571578063e39c08fc1461058457600080fd5b8063a4a3e035116100ff578063a4a3e0351461049f578063a7852afa146104a7578063ae205536146104ba578063b5fd73f8146104f0578063b66503cf1461052357600080fd5b80638da5cb5b14610433578063981b24d0146104465780639c9b2e21146104665780639cc7f708146104795780639e2bf22c1461048c57600080fd5b806355288eea116101c95780637035ab981161018d5780637035ab98146103a4578063731b8f72146103cf5780637bb7bed1146103fa5780637fd7d0621461040d578063853c8aeb1461042057600080fd5b806355288eea1461034d57806357bc5614146103565780635977e82a14610369578063613ec9141461038957806365c5f94a1461039c57600080fd5b80631f850716116102105780631f850716146102b0578063211dc32d146102c357806338174862146102d657806346c96aac146103275780634bc2a6571461033a57600080fd5b80630125bb3214610242578063075461721461025757806313af40351461028757806318160ddd1461029a575b600080fd5b6102556102503660046122e4565b6105eb565b005b60075461026a906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b610255610295366004612310565b610707565b6102a261077b565b60405190815260200161027e565b60085461026a906001600160a01b031681565b6102a26102d136600461232d565b61079b565b61030c6102e43660046122e4565b6002602081815260009384526040808520909152918352912080546001820154919092015483565b6040805193845260208401929092529082015260600161027e565b60055461026a906001600160a01b031681565b610255610348366004612310565b6108bf565b6102a260015481565b6102a26103643660046122e4565b610933565b6102a2610377366004612366565b600d6020526000908152604090205481565b61025561039736600461242c565b6109cc565b6102a2610a4f565b6102a26103b236600461232d565b600b60209081526000928352604080842090915290825290205481565b6102a26103dd36600461232d565b600c60209081526000928352604080842090915290825290205481565b61026a610408366004612366565b610a6c565b61025561041b36600461242c565b610a96565b6102a261042e366004612461565b610b7d565b60095461026a906001600160a01b031681565b6102a2610454366004612366565b6000908152600d602052604090205490565b610255610474366004612310565b610c1b565b6102a2610487366004612366565b610c63565b61025561049a366004612461565b610d0d565b6102a2610f6b565b6102556104b5366004612483565b610fd9565b6102a26104c83660046122e4565b6001600160a01b03919091166000908152600e60209081526040808320938352929052205490565b6105136104fe366004612310565b60036020526000908152604090205460ff1681565b604051901515815260200161027e565b6102556105313660046122e4565b611145565b61053e61135c565b60405161027e91906124f6565b6102a2610559366004612310565b6113ea565b61025561056c3660046122e4565b611422565b61025561057f366004612529565b611634565b6102a2610592366004612563565b611720565b6004546102a2565b60065461026a906001600160a01b031681565b6102556105c0366004612461565b6118b7565b6102556105d3366004612483565b611ad6565b6102556105e6366004612310565b611c99565b6009546001600160a01b031633148061060e57506006546001600160a01b031633145b6106335760405162461bcd60e51b815260040161062a90612588565b60405180910390fd5b6040516370a0823160e01b81523060048201526001600160a01b038316906370a0823190602401602060405180830381865afa158015610677573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061069b91906125b7565b8111156106a757600080fd5b6009546106c1906001600160a01b03848116911683611d0d565b604080516001600160a01b0384168152602081018390527f8c1256b8896378cd5044f80c202f9772b9d77dc85c8a6eb51967210b09bfaa28910160405180910390a15050565b6009546001600160a01b031633148061072a57506006546001600160a01b031633145b6107465760405162461bcd60e51b815260040161062a90612588565b6001600160a01b03811661075957600080fd5b600980546001600160a01b0319166001600160a01b0392909216919091179055565b600080610786610a4f565b6000908152600d602052604090205492915050565b60075460408051631a2732c160e31b815290516000928392839283926001600160a01b03169163d13996089160048083019260209291908290030181865afa1580156107eb573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061080f91906125b7565b6001600160a01b038088166000908152600c60209081526040808320938a168352929052205490915080820361084c5760009450505050506108b9565b60015481101561086a5762093a8060015461086791906125e6565b90505b60328410156108b2578082146108b257610885878783611d75565b61088f90846125fd565b925061089e62093a80826125fd565b9050836108aa81612615565b94505061086a565b5090925050505b92915050565b6009546001600160a01b03163314806108e257506006546001600160a01b031633145b6108fe5760405162461bcd60e51b815260040161062a90612588565b6001600160a01b03811661091157600080fd5b600580546001600160a01b0319166001600160a01b0392909216919091179055565b6000818152600d6020526040812054810361097557506001600160a01b03821660009081526002602090815260408083208484529091529020600101546108b9565b6000828152600d60209081526040808320546001600160a01b038716845260028352818420868552909252909120600101546109bb9069d3c21bcecceda100000061262e565b6109c5919061264d565b9392505050565b6009546001600160a01b03163314806109ef57506006546001600160a01b031633145b610a0b5760405162461bcd60e51b815260040161062a90612588565b60005b8151811015610a4b57610a39828281518110610a2c57610a2c61266f565b6020026020010151611de5565b80610a4381612615565b915050610a0e565b5050565b600062093a80610a5d610f6b565b610a6791906125fd565b905090565b60048181548110610a7c57600080fd5b6000918252602090912001546001600160a01b0316905081565b610a9e611e92565b60008033815b8451811015610b6c576000858281518110610ac157610ac161266f565b60200260200101519050610ad58382611eeb565b955093508315610b2f57610af36001600160a01b0382168486611d0d565b806001600160a01b0316836001600160a01b031660008051602061274783398151915286604051610b2691815260200190565b60405180910390a35b6001600160a01b038084166000908152600c6020908152604080832094909316825292909252902084905580610b6481612615565b915050610aa4565b50505050610b7a6001600055565b50565b6008546040516331a9108f60e11b81526004810184905260009182916001600160a01b0390911690636352211e90602401602060405180830381865afa158015610bcb573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bef9190612685565b6001600160a01b03166000908152600e6020908152604080832086845290915290205491505092915050565b6009546001600160a01b0316331480610c3e57506006546001600160a01b031633145b610c5a5760405162461bcd60e51b815260040161062a90612588565b610b7a81611de5565b600080610c6e610a4f565b6008546040516331a9108f60e11b8152600481018690529192506000916001600160a01b0390911690636352211e90602401602060405180830381865afa158015610cbd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ce19190612685565b6001600160a01b03166000908152600e6020908152604080832094835293905291909120549392505050565b610d15611e92565b60008211610d595760405162461bcd60e51b8152602060048201526011602482015270043616e6e6f74207769746864726177203607c1b604482015260640161062a565b6005546001600160a01b03163314610d7057600080fd5b60075460408051631a2732c160e31b815290516000926001600160a01b03169163d13996089160048083019260209291908290030181865afa158015610dba573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610dde91906125b7565b905080600003610e005760405162461bcd60e51b815260040161062a906126a2565b6000610e0f62093a80836125fd565b6008546040516331a9108f60e11b8152600481018690529192506000916001600160a01b0390911690636352211e90602401602060405180830381865afa158015610e5e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e829190612685565b6001600160a01b0381166000908152600e602090815260408083208684529091529020549091508511610f5e576000828152600d60209081526040808320546001600160a01b0385168452600e835281842086855290925290912054610ee887836125e6565b6000858152600d6020526040902055610f0187826125e6565b6001600160a01b0384166000908152600e60209081526040808320888452825291829020929092555188815287917f0c875c8d391179c5cf7ad8303d268efd50b8beb78b671f85cd54bfb91eb8ef4091015b60405180910390a250505b505050610a4b6001600055565b60075460408051631a2732c160e31b815290516000926001600160a01b03169163d13996089160048083019260209291908290030181865afa158015610fb5573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a6791906125b7565b610fe1611e92565b6005546001600160a01b03163314610ff857600080fd5b6008546040516331a9108f60e11b815260048101849052600091829182916001600160a01b031690636352211e90602401602060405180830381865afa158015611046573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061106a9190612685565b905060005b845181101561113757600085828151811061108c5761108c61266f565b602002602001015190506110a08382611eeb565b9550935083156110fa576110be6001600160a01b0382168486611d0d565b806001600160a01b0316836001600160a01b0316600080516020612747833981519152866040516110f191815260200190565b60405180910390a35b6001600160a01b038084166000908152600c602090815260408083209490931682529290925290208490558061112f81612615565b91505061106f565b50505050610a4b6001600055565b61114d611e92565b6001600160a01b03821660009081526003602052604090205460ff166111b55760405162461bcd60e51b815260206004820152601960248201527f72657761726420746f6b656e206e6f7420766572696669656400000000000000604482015260640161062a565b6111ca6001600160a01b03831633308461201f565b60075460408051631a2732c160e31b815290516000926001600160a01b03169163d13996089160048083019260209291908290030181865afa158015611214573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061123891906125b7565b90508060000361125a5760405162461bcd60e51b815260040161062a906126a2565b600061126962093a80836125fd565b905060015460000361127b5760018190555b6001600160a01b03841660009081526002602090815260408083208484529091529020600101546112ac84826125fd565b6001600160a01b03861660009081526002602081815260408084208785529091529091206001810192909255429101556112e962093a80836125fd565b6001600160a01b03861660008181526002602090815260408083208784528252918290209390935580519182529181018690529081018390527f6a6f77044107a33658235d41bedbbaf2fe9ccdceb313143c947a5e76e1ec84749060600160405180910390a1505050610a4b6001600055565b600a8054611369906126ce565b80601f0160208091040260200160405190810160405280929190818152602001828054611395906126ce565b80156113e25780601f106113b7576101008083540402835291602001916113e2565b820191906000526020600020905b8154815290600101906020018083116113c557829003601f168201915b505050505081565b6000806113f5610a4f565b6001600160a01b039093166000908152600e60209081526040808320958352949052929092205492915050565b6009546001600160a01b031633148061144557506006546001600160a01b031633145b6114615760405162461bcd60e51b815260040161062a90612588565b6040516370a0823160e01b81523060048201526001600160a01b038316906370a0823190602401602060405180830381865afa1580156114a5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114c991906125b7565b8111156114d557600080fd5b60075460408051631a2732c160e31b815290516000926001600160a01b03169163d13996089160048083019260209291908290030181865afa15801561151f573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061154391906125b7565b9050806000036115655760405162461bcd60e51b815260040161062a906126a2565b600061157462093a80836125fd565b6001600160a01b03851660009081526002602090815260408083208484529091529020600101549091506115a884826125e6565b6001600160a01b0386811660008181526002602081815260408084208985529091529091206001810194909455429301929092556009546115eb92911686611d0d565b604080516001600160a01b0387168152602081018690527f8c1256b8896378cd5044f80c202f9772b9d77dc85c8a6eb51967210b09bfaa28910160405180910390a15050505050565b61163c611e92565b6005546001600160a01b0316331461165357600080fd5b600080805b8351811015610f5e5760008482815181106116755761167561266f565b602002602001015190506116898682611eeb565b9450925082156116e3576116a76001600160a01b0382168785611d0d565b806001600160a01b0316866001600160a01b0316600080516020612747833981519152856040516116da91815260200190565b60405180910390a35b6001600160a01b038087166000908152600c602090815260408083209490931682529290925290208390558061171881612615565b915050611658565b60075460408051631a2732c160e31b815290516000928392839283926001600160a01b03169163d13996089160048083019260209291908290030181865afa158015611770573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061179491906125b7565b6008546040516331a9108f60e11b8152600481018990529192506000916001600160a01b0390911690636352211e90602401602060405180830381865afa1580156117e3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906118079190612685565b6001600160a01b038082166000908152600c60209081526040808320938b1683529290522054909150808303611845576000955050505050506108b9565b6001548110156118635762093a8060015461186091906125e6565b90505b60328510156118ab578083146118ab5761187e828883611d75565b61188890856125fd565b935061189762093a80826125fd565b9050846118a381612615565b955050611863565b50919695505050505050565b6118bf611e92565b600082116119005760405162461bcd60e51b815260206004820152600e60248201526d043616e6e6f74207374616b6520360941b604482015260640161062a565b6005546001600160a01b0316331461191757600080fd5b60075460408051631a2732c160e31b815290516000926001600160a01b03169163d13996089160048083019260209291908290030181865afa158015611961573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061198591906125b7565b9050806000036119a75760405162461bcd60e51b815260040161062a906126a2565b60006119b662093a80836125fd565b6000818152600d60205260408082205460085491516331a9108f60e11b815260048101889052939450926001600160a01b0390911690636352211e90602401602060405180830381865afa158015611a12573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a369190612685565b6001600160a01b0381166000908152600e60209081526040808320878452909152902054909150611a6787846125fd565b6000858152600d6020526040902055611a8087826125fd565b6001600160a01b0383166000908152600e60209081526040808320888452825291829020929092555188815287917f925435fa7e37e5d9555bb18ce0d62bb9627d0846942e58e5291e9a2dded462ed9101610f53565b611ade611e92565b60085460405163430c208160e01b8152336004820152602481018490526001600160a01b039091169063430c208190604401602060405180830381865afa158015611b2d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611b519190612708565b611b5a57600080fd5b6008546040516331a9108f60e11b815260048101849052600091829182916001600160a01b031690636352211e90602401602060405180830381865afa158015611ba8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611bcc9190612685565b905060005b8451811015611137576000858281518110611bee57611bee61266f565b60200260200101519050611c028382611eeb565b955093508315611c5c57611c206001600160a01b0382168486611d0d565b806001600160a01b0316836001600160a01b031660008051602061274783398151915286604051611c5391815260200190565b60405180910390a35b6001600160a01b038084166000908152600c6020908152604080832094909316825292909252902084905580611c9181612615565b915050611bd1565b6009546001600160a01b0316331480611cbc57506006546001600160a01b031633145b611cd85760405162461bcd60e51b815260040161062a90612588565b6001600160a01b038116611ceb57600080fd5b600780546001600160a01b0319166001600160a01b0392909216919091179055565b6040516001600160a01b038316602482015260448101829052611d7090849063a9059cbb60e01b906064015b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b03199093169290921790915261205d565b505050565b6001600160a01b0383166000908152600e6020908152604080832084845290915281205480600003611dab5760009150506109c5565b6000611db78585610933565b9050600069d3c21bcecceda1000000611dd0848461262e565b611dda919061264d565b93506109c592505050565b6001600160a01b03811660009081526003602052604090205460ff16610b7a576001600160a01b038116600081815260036020526040808220805460ff1916600190811790915560048054918201815583527f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b0180546001600160a01b031916841790555130917f3344e0a0f48738979c56a1b9f2cd3425597f76766d53e83439cab3fc30b067c791a350565b600260005403611ee45760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015260640161062a565b6002600055565b6000806000806000600760009054906101000a90046001600160a01b03166001600160a01b031663d13996086040518163ffffffff1660e01b8152600401602060405180830381865afa158015611f46573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611f6a91906125b7565b6001600160a01b038089166000908152600c60209081526040808320938b1683529290522054909150808203611fa95760009550935061201892505050565b600154811015611fc75762093a80600154611fc491906125e6565b90505b603284101561200f5780821461200f57611fe2888883611d75565b611fec90846125fd565b9250611ffb62093a80826125fd565b90508361200781612615565b945050611fc7565b91945090925050505b9250929050565b6040516001600160a01b03808516602483015283166044820152606481018290526120579085906323b872dd60e01b90608401611d39565b50505050565b60006120b2826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661212f9092919063ffffffff16565b805190915015611d7057808060200190518101906120d09190612708565b611d705760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b606482015260840161062a565b606061213e8484600085612146565b949350505050565b6060824710156121a75760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b606482015260840161062a565b600080866001600160a01b031685876040516121c3919061272a565b60006040518083038185875af1925050503d8060008114612200576040519150601f19603f3d011682016040523d82523d6000602084013e612205565b606091505b509150915061221687838387612221565b979650505050505050565b60608315612290578251600003612289576001600160a01b0385163b6122895760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015260640161062a565b508161213e565b61213e83838151156122a55781518083602001fd5b8060405162461bcd60e51b815260040161062a91906124f6565b6001600160a01b0381168114610b7a57600080fd5b80356122df816122bf565b919050565b600080604083850312156122f757600080fd5b8235612302816122bf565b946020939093013593505050565b60006020828403121561232257600080fd5b81356109c5816122bf565b6000806040838503121561234057600080fd5b823561234b816122bf565b9150602083013561235b816122bf565b809150509250929050565b60006020828403121561237857600080fd5b5035919050565b634e487b7160e01b600052604160045260246000fd5b600082601f8301126123a657600080fd5b8135602067ffffffffffffffff808311156123c3576123c361237f565b8260051b604051601f19603f830116810181811084821117156123e8576123e861237f565b60405293845285810183019383810192508785111561240657600080fd5b83870191505b848210156122165761241d826122d4565b8352918301919083019061240c565b60006020828403121561243e57600080fd5b813567ffffffffffffffff81111561245557600080fd5b61213e84828501612395565b6000806040838503121561247457600080fd5b50508035926020909101359150565b6000806040838503121561249657600080fd5b82359150602083013567ffffffffffffffff8111156124b457600080fd5b6124c085828601612395565b9150509250929050565b60005b838110156124e55781810151838201526020016124cd565b838111156120575750506000910152565b60208152600082518060208401526125158160408501602087016124ca565b601f01601f19169190910160400192915050565b6000806040838503121561253c57600080fd5b8235612547816122bf565b9150602083013567ffffffffffffffff8111156124b457600080fd5b6000806040838503121561257657600080fd5b82359150602083013561235b816122bf565b6020808252601590820152747065726d697373696f6e2069732064656e6965642160581b604082015260600190565b6000602082840312156125c957600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b6000828210156125f8576125f86125d0565b500390565b60008219821115612610576126106125d0565b500190565b600060018201612627576126276125d0565b5060010190565b6000816000190483118215151615612648576126486125d0565b500290565b60008261266a57634e487b7160e01b600052601260045260246000fd5b500490565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561269757600080fd5b81516109c5816122bf565b6020808252601290820152714e6f7420737461727465642065706f63687360701b604082015260600190565b600181811c908216806126e257607f821691505b60208210810361270257634e487b7160e01b600052602260045260246000fd5b50919050565b60006020828403121561271a57600080fd5b815180151581146109c557600080fd5b6000825161273c8184602087016124ca565b919091019291505056fe540798df468d7b23d11f156fdb954cb19ad414d150722a7b6d55ba369dea792ea26469706673582212204e8c710ab75d5a2a215b1abcac0b8de67150067ef0baa0fc8da2806e8cf2ce8b64736f6c634300080d0033

    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  ]
    [ 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.