Contract 0xd2D1162512F927a7e282Ef43a362659E4F2a728F 14

Txn Hash Method
Block
From
To
Value [Txn Fee]
0x69f8c416cfb5cdedccd44f2aa7b731521fb2155aac7c3e1ea37624d2b334741dClaim357768792023-09-28 18:00:145 hrs 36 mins ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0x6005da94e0beb4fcac62da97e4def2dd388a511c969b5891e2df8782f7e08b67Claim357663462023-09-28 12:00:1511 hrs 36 mins ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0x424c4feca2b12056bc2b2d66da59273d1ccc8a25aea44692d4a53f2faf69be77Claim357560082023-09-28 6:00:1317 hrs 36 mins ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0xa79b679add809f82df6f18157d0ac5039f2e0f54879ba29dcdaa7291b78556a3Claim357454292023-09-28 0:00:1923 hrs 36 mins ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0xe569f793119464549abfec838fff7593adcd9e64a91178ab15d8859f19f94bc1Claim357347832023-09-27 18:00:231 day 5 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0xd75196e7dce83427ef786d2cc93eeaab498cc692794fc84806676d4143c1a419Claim357242112023-09-27 12:00:211 day 11 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0x690de9158623b113d5b0f4c97d055f7e47a62264f1aeb155b5a2fc41cc849527Claim353320442023-09-18 6:00:1810 days 17 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003799936536 29.854
0x85ae20c02e64e82cf4342c27db58639ee2cfe11306d1e09cf933de550582bd98Claim353214922023-09-18 0:00:1810 days 23 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003429158244 26.941
0x50d14cfea614134a1f815157927a2aea2c35a1810a943e2bb4e93d6407d42738Claim353109902023-09-17 18:00:1111 days 5 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003441377508 27.037
0xeb9e595ea4c8dee13bb1c70fb6bd6c928c2bb6268f441786c9dc80ea6097aefaClaim352898702023-09-17 6:00:1011 days 17 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003500564568 27.502
0x54bbdcdc25b96df7300c8f56b3addabe4a007bde06f54351310d7f87e41180e0Claim352795542023-09-17 0:00:1811 days 23 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0x58a6d2614b882f3e6a0b79eb4c4ee649643676016f03d9edf395bda6542d8c07Claim352691432023-09-16 18:00:2112 days 5 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003500564568 27.502
0xaf6dec058783835fb6a6f0989a2fcff67c06416f14325cec4b18cc7bd1648980Claim352584992023-09-16 12:00:1712 days 11 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0x10621ee8e08668e3bce2c4b673eecc7b9d5b2dd8e2545e86a1f24cd486045720Claim352478392023-09-16 6:00:1112 days 17 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0xd266fce4d82c067279d81067dd4b767acb62219809cc08b07aa703f3b17d4c35Claim352373602023-09-16 0:00:1912 days 23 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003429158244 26.941
0x0245e34830d1bce362e5edea5d1a2ed57e913e1c7aec9b98707861063413249fClaim352269402023-09-15 18:00:1813 days 5 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0x157565b1b8b611e84e007d4098dac3a6478f1e3655baf62bad2eefa0e78da0ccClaim352162962023-09-15 12:00:1413 days 11 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003500564568 27.502
0x96c772c394d3c3d7810a95e1f6c6d617ef53874559a03b646994f75033e7f12dClaim352056342023-09-15 6:00:1513 days 17 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003406883544 26.766
0xb107b4e5988a82a26eab66beae614df4cb56bd1dc75f1b2c6ccbcba05ce9ed66Claim351952492023-09-15 0:00:1613 days 23 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003429158244 26.941
0x6a60f55dbb10e3fbcca0cd58f5acc074f971cfb69e4da02cd2a5ca88b08e9048Claim351847782023-09-14 18:00:1114 days 5 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0x1043f30558029523398cd65e609e54b4e9ee22e0d5b7d88d6d224a927362c86bClaim351742202023-09-14 12:00:1914 days 11 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0x5e992f0b1d047dbc31e164b5a16d2759eaf3ed540bf7096e2fc7d0c0b9687cd4Claim351635482023-09-14 6:00:1114 days 17 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003436795284 27.001
0xedb9bd9ec55147f9acda97b0d84261dbf07a68f6d85e639bc2ba758e4c2c693eClaim351530372023-09-14 0:00:1914 days 23 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003373153284 26.501
0x07855d2f10671dac050cebf168adba6c3542966272c0dd90fa119e95dbad6331Claim351424852023-09-13 18:00:1915 days 5 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003030280368 27.502
0x776ea09a83f1bcc3a2e69bb0bbfbb9f1f33db8b40e09cbe0059b946b09f90b75Claim351318502023-09-13 12:00:1615 days 11 hrs ago0x3c8074982302d44d67a3fb25952525f05a7eabda IN  0xd2d1162512f927a7e282ef43a362659e4f2a728f0 AVAX0.003022016568 27.427
[ Download CSV Export 
Parent Txn Hash Block From To Value
Index Block
Loading

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

Contract Name:
RewardTracker

Compiler Version
v0.6.12+commit.27d51765

Optimization Enabled:
Yes with 1 runs

Other Settings:
default evmVersion
File 1 of 9 : RewardTracker.sol
// SPDX-License-Identifier: MIT

pragma solidity 0.6.12;

import "../libraries/math/SafeMath.sol";
import "../libraries/token/IERC20.sol";
import "../libraries/token/SafeERC20.sol";
import "../libraries/utils/ReentrancyGuard.sol";

import "./interfaces/IRewardDistributor.sol";
import "./interfaces/IRewardTracker.sol";
import "../access/Governable.sol";

contract RewardTracker is IERC20, ReentrancyGuard, IRewardTracker, Governable {
    using SafeMath for uint256;
    using SafeERC20 for IERC20;

    uint256 public constant BASIS_POINTS_DIVISOR = 10000;
    uint256 public constant PRECISION = 1e30;

    uint8 public constant decimals = 18;

    bool public isInitialized;

    string public name;
    string public symbol;

    address public distributor;
    mapping (address => bool) public isDepositToken;
    mapping (address => mapping (address => uint256)) public override depositBalances;
    mapping (address => uint256) public totalDepositSupply;

    uint256 public override totalSupply;
    mapping (address => uint256) public balances;
    mapping (address => mapping (address => uint256)) public allowances;

    uint256 public cumulativeRewardPerToken;
    mapping (address => uint256) public override stakedAmounts;
    mapping (address => uint256) public claimableReward;
    mapping (address => uint256) public previousCumulatedRewardPerToken;
    mapping (address => uint256) public override cumulativeRewards;
    mapping (address => uint256) public override averageStakedAmounts;

    bool public inPrivateTransferMode;
    bool public inPrivateStakingMode;
    bool public inPrivateClaimingMode;
    mapping (address => bool) public isHandler;

    event Claim(address receiver, uint256 amount);

    constructor(string memory _name, string memory _symbol) public {
        name = _name;
        symbol = _symbol;
    }

    function initialize(
        address[] memory _depositTokens,
        address _distributor
    ) external onlyGov {
        require(!isInitialized, "RewardTracker: already initialized");
        isInitialized = true;

        for (uint256 i = 0; i < _depositTokens.length; i++) {
            address depositToken = _depositTokens[i];
            isDepositToken[depositToken] = true;
        }

        distributor = _distributor;
    }

    function setDepositToken(address _depositToken, bool _isDepositToken) external onlyGov {
        isDepositToken[_depositToken] = _isDepositToken;
    }

    function setInPrivateTransferMode(bool _inPrivateTransferMode) external onlyGov {
        inPrivateTransferMode = _inPrivateTransferMode;
    }

    function setInPrivateStakingMode(bool _inPrivateStakingMode) external onlyGov {
        inPrivateStakingMode = _inPrivateStakingMode;
    }

    function setInPrivateClaimingMode(bool _inPrivateClaimingMode) external onlyGov {
        inPrivateClaimingMode = _inPrivateClaimingMode;
    }

    function setHandler(address _handler, bool _isActive) external onlyGov {
        isHandler[_handler] = _isActive;
    }

    // to help users who accidentally send their tokens to this contract
    function withdrawToken(address _token, address _account, uint256 _amount) external onlyGov {
        IERC20(_token).safeTransfer(_account, _amount);
    }

    function balanceOf(address _account) external view override returns (uint256) {
        return balances[_account];
    }

    function stake(address _depositToken, uint256 _amount) external override nonReentrant {
        if (inPrivateStakingMode) { revert("RewardTracker: action not enabled"); }
        _stake(msg.sender, msg.sender, _depositToken, _amount);
    }

    function stakeForAccount(address _fundingAccount, address _account, address _depositToken, uint256 _amount) external override nonReentrant {
        _validateHandler();
        _stake(_fundingAccount, _account, _depositToken, _amount);
    }

    function unstake(address _depositToken, uint256 _amount) external override nonReentrant {
        if (inPrivateStakingMode) { revert("RewardTracker: action not enabled"); }
        _unstake(msg.sender, _depositToken, _amount, msg.sender);
    }

    function unstakeForAccount(address _account, address _depositToken, uint256 _amount, address _receiver) external override nonReentrant {
        _validateHandler();
        _unstake(_account, _depositToken, _amount, _receiver);
    }

    function transfer(address _recipient, uint256 _amount) external override returns (bool) {
        _transfer(msg.sender, _recipient, _amount);
        return true;
    }

    function allowance(address _owner, address _spender) external view override returns (uint256) {
        return allowances[_owner][_spender];
    }

    function approve(address _spender, uint256 _amount) external override returns (bool) {
        _approve(msg.sender, _spender, _amount);
        return true;
    }

    function transferFrom(address _sender, address _recipient, uint256 _amount) external override returns (bool) {
        if (isHandler[msg.sender]) {
            _transfer(_sender, _recipient, _amount);
            return true;
        }

        uint256 nextAllowance = allowances[_sender][msg.sender].sub(_amount, "RewardTracker: transfer amount exceeds allowance");
        _approve(_sender, msg.sender, nextAllowance);
        _transfer(_sender, _recipient, _amount);
        return true;
    }

    function tokensPerInterval() external override view returns (uint256) {
        return IRewardDistributor(distributor).tokensPerInterval();
    }

    function updateRewards() external override nonReentrant {
        _updateRewards(address(0));
    }

    function claim(address _receiver) external override nonReentrant returns (uint256) {
        if (inPrivateClaimingMode) { revert("RewardTracker: action not enabled"); }
        return _claim(msg.sender, _receiver);
    }

    function claimForAccount(address _account, address _receiver) external override nonReentrant returns (uint256) {
        _validateHandler();
        return _claim(_account, _receiver);
    }

    function claimable(address _account) public override view returns (uint256) {
        uint256 stakedAmount = stakedAmounts[_account];
        if (stakedAmount == 0) {
            return claimableReward[_account];
        }
        uint256 supply = totalSupply;
        uint256 pendingRewards = IRewardDistributor(distributor).pendingRewards().mul(PRECISION);
        uint256 nextCumulativeRewardPerToken = cumulativeRewardPerToken.add(pendingRewards.div(supply));
        return claimableReward[_account].add(
            stakedAmount.mul(nextCumulativeRewardPerToken.sub(previousCumulatedRewardPerToken[_account])).div(PRECISION));
    }

    function rewardToken() public view returns (address) {
        return IRewardDistributor(distributor).rewardToken();
    }

    function _claim(address _account, address _receiver) private returns (uint256) {
        _updateRewards(_account);

        uint256 tokenAmount = claimableReward[_account];
        claimableReward[_account] = 0;

        if (tokenAmount > 0) {
            IERC20(rewardToken()).safeTransfer(_receiver, tokenAmount);
            emit Claim(_account, tokenAmount);
        }

        return tokenAmount;
    }

    function _mint(address _account, uint256 _amount) internal {
        require(_account != address(0), "RewardTracker: mint to the zero address");

        totalSupply = totalSupply.add(_amount);
        balances[_account] = balances[_account].add(_amount);

        emit Transfer(address(0), _account, _amount);
    }

    function _burn(address _account, uint256 _amount) internal {
        require(_account != address(0), "RewardTracker: burn from the zero address");

        balances[_account] = balances[_account].sub(_amount, "RewardTracker: burn amount exceeds balance");
        totalSupply = totalSupply.sub(_amount);

        emit Transfer(_account, address(0), _amount);
    }

    function _transfer(address _sender, address _recipient, uint256 _amount) private {
        require(_sender != address(0), "RewardTracker: transfer from the zero address");
        require(_recipient != address(0), "RewardTracker: transfer to the zero address");

        if (inPrivateTransferMode) { _validateHandler(); }

        balances[_sender] = balances[_sender].sub(_amount, "RewardTracker: transfer amount exceeds balance");
        balances[_recipient] = balances[_recipient].add(_amount);

        emit Transfer(_sender, _recipient,_amount);
    }

    function _approve(address _owner, address _spender, uint256 _amount) private {
        require(_owner != address(0), "RewardTracker: approve from the zero address");
        require(_spender != address(0), "RewardTracker: approve to the zero address");

        allowances[_owner][_spender] = _amount;

        emit Approval(_owner, _spender, _amount);
    }

    function _validateHandler() private view {
        require(isHandler[msg.sender], "RewardTracker: forbidden");
    }

    function _stake(address _fundingAccount, address _account, address _depositToken, uint256 _amount) private {
        require(_amount > 0, "RewardTracker: invalid _amount");
        require(isDepositToken[_depositToken], "RewardTracker: invalid _depositToken");

        IERC20(_depositToken).safeTransferFrom(_fundingAccount, address(this), _amount);

        _updateRewards(_account);

        stakedAmounts[_account] = stakedAmounts[_account].add(_amount);
        depositBalances[_account][_depositToken] = depositBalances[_account][_depositToken].add(_amount);
        totalDepositSupply[_depositToken] = totalDepositSupply[_depositToken].add(_amount);

        _mint(_account, _amount);
    }

    function _unstake(address _account, address _depositToken, uint256 _amount, address _receiver) private {
        require(_amount > 0, "RewardTracker: invalid _amount");
        require(isDepositToken[_depositToken], "RewardTracker: invalid _depositToken");

        _updateRewards(_account);

        uint256 stakedAmount = stakedAmounts[_account];
        require(stakedAmounts[_account] >= _amount, "RewardTracker: _amount exceeds stakedAmount");

        stakedAmounts[_account] = stakedAmount.sub(_amount);

        uint256 depositBalance = depositBalances[_account][_depositToken];
        require(depositBalance >= _amount, "RewardTracker: _amount exceeds depositBalance");
        depositBalances[_account][_depositToken] = depositBalance.sub(_amount);
        totalDepositSupply[_depositToken] = totalDepositSupply[_depositToken].sub(_amount);

        _burn(_account, _amount);
        IERC20(_depositToken).safeTransfer(_receiver, _amount);
    }

    function _updateRewards(address _account) private {
        uint256 blockReward = IRewardDistributor(distributor).distribute();

        uint256 supply = totalSupply;
        uint256 _cumulativeRewardPerToken = cumulativeRewardPerToken;
        if (supply > 0 && blockReward > 0) {
            _cumulativeRewardPerToken = _cumulativeRewardPerToken.add(blockReward.mul(PRECISION).div(supply));
            cumulativeRewardPerToken = _cumulativeRewardPerToken;
        }

        // cumulativeRewardPerToken can only increase
        // so if cumulativeRewardPerToken is zero, it means there are no rewards yet
        if (_cumulativeRewardPerToken == 0) {
            return;
        }

        if (_account != address(0)) {
            uint256 stakedAmount = stakedAmounts[_account];
            uint256 accountReward = stakedAmount.mul(_cumulativeRewardPerToken.sub(previousCumulatedRewardPerToken[_account])).div(PRECISION);
            uint256 _claimableReward = claimableReward[_account].add(accountReward);

            claimableReward[_account] = _claimableReward;
            previousCumulatedRewardPerToken[_account] = _cumulativeRewardPerToken;

            if (_claimableReward > 0 && stakedAmounts[_account] > 0) {
                uint256 nextCumulativeReward = cumulativeRewards[_account].add(accountReward);

                averageStakedAmounts[_account] = averageStakedAmounts[_account].mul(cumulativeRewards[_account]).div(nextCumulativeReward)
                    .add(stakedAmount.mul(accountReward).div(nextCumulativeReward));

                cumulativeRewards[_account] = nextCumulativeReward;
            }
        }
    }
}

File 2 of 9 : SafeMath.sol
// SPDX-License-Identifier: MIT

pragma solidity 0.6.12;

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");

        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

File 3 of 9 : IERC20.sol
// SPDX-License-Identifier: MIT

pragma solidity 0.6.12;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);

    /**
     * @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);
}

File 4 of 9 : SafeERC20.sol
// SPDX-License-Identifier: MIT

pragma solidity 0.6.12;

import "./IERC20.sol";
import "../math/SafeMath.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 SafeMath for uint256;
    using Address for address;

    function safeTransfer(IERC20 token, address to, uint256 value) internal {
        _callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value));
    }

    function safeTransferFrom(IERC20 token, address from, address to, uint256 value) internal {
        _callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value));
    }

    /**
     * @dev Deprecated. This function has issues similar to the ones found in
     * {IERC20-approve}, and its usage is discouraged.
     *
     * Whenever possible, use {safeIncreaseAllowance} and
     * {safeDecreaseAllowance} instead.
     */
    function safeApprove(IERC20 token, address spender, uint256 value) internal {
        // safeApprove should only be called when setting an initial allowance,
        // or when resetting it to zero. To increase and decrease it, use
        // 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
        // solhint-disable-next-line max-line-length
        require((value == 0) || (token.allowance(address(this), spender) == 0),
            "SafeERC20: approve from non-zero to non-zero allowance"
        );
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value));
    }

    function safeIncreaseAllowance(IERC20 token, address spender, uint256 value) internal {
        uint256 newAllowance = token.allowance(address(this), spender).add(value);
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance));
    }

    function safeDecreaseAllowance(IERC20 token, address spender, uint256 value) internal {
        uint256 newAllowance = token.allowance(address(this), spender).sub(value, "SafeERC20: decreased allowance below zero");
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance));
    }

    /**
     * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement
     * on the return value: the return value is optional (but if data is returned, it must not be false).
     * @param token The token targeted by the call.
     * @param data The call data (encoded using abi.encode or one of its variants).
     */
    function _callOptionalReturn(IERC20 token, bytes memory data) private {
        // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since
        // we're implementing it ourselves. We use {Address.functionCall} to perform this call, which verifies that
        // the target address contains contract code and also asserts for success in the low-level call.

        bytes memory returndata = address(token).functionCall(data, "SafeERC20: low-level call failed");
        if (returndata.length > 0) { // Return data is optional
            // solhint-disable-next-line max-line-length
            require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed");
        }
    }
}

File 5 of 9 : ReentrancyGuard.sol
// SPDX-License-Identifier: MIT

pragma solidity 0.6.12;

/**
 * @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].
 */
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
    // pointer aliasing, and it cannot be disabled.

    // The values being non-zero value makes deployment a bit more expensive,
    // but in exchange the refund on every call to nonReentrant will be lower in
    // amount. Since refunds are capped to a percentage of the total
    // transaction's gas, it is best to keep them low in cases like this one, to
    // increase the likelihood of the full refund coming into effect.
    uint256 private constant _NOT_ENTERED = 1;
    uint256 private constant _ENTERED = 2;

    uint256 private _status;

    constructor () internal {
        _status = _NOT_ENTERED;
    }

    /**
     * @dev Prevents a contract from calling itself, directly or indirectly.
     * Calling a `nonReentrant` function from another `nonReentrant`
     * function is not supported. It is possible to prevent this from happening
     * by making the `nonReentrant` function external, and make it call a
     * `private` function that does the actual work.
     */
    modifier nonReentrant() {
        // On the first call to nonReentrant, _notEntered will be true
        require(_status != _ENTERED, "ReentrancyGuard: reentrant call");

        // Any calls to nonReentrant after this point will fail
        _status = _ENTERED;

        _;

        // By storing the original value once again, a refund is triggered (see
        // https://eips.ethereum.org/EIPS/eip-2200)
        _status = _NOT_ENTERED;
    }
}

File 6 of 9 : IRewardDistributor.sol
// SPDX-License-Identifier: MIT

pragma solidity 0.6.12;

interface IRewardDistributor {
    function rewardToken() external view returns (address);
    function tokensPerInterval() external view returns (uint256);
    function pendingRewards() external view returns (uint256);
    function distribute() external returns (uint256);
}

File 7 of 9 : IRewardTracker.sol
// SPDX-License-Identifier: MIT

pragma solidity 0.6.12;

interface IRewardTracker {
    function depositBalances(address _account, address _depositToken) external view returns (uint256);
    function stakedAmounts(address _account) external view returns (uint256);
    function updateRewards() external;
    function stake(address _depositToken, uint256 _amount) external;
    function stakeForAccount(address _fundingAccount, address _account, address _depositToken, uint256 _amount) external;
    function unstake(address _depositToken, uint256 _amount) external;
    function unstakeForAccount(address _account, address _depositToken, uint256 _amount, address _receiver) external;
    function tokensPerInterval() external view returns (uint256);
    function claim(address _receiver) external returns (uint256);
    function claimForAccount(address _account, address _receiver) external returns (uint256);
    function claimable(address _account) external view returns (uint256);
    function averageStakedAmounts(address _account) external view returns (uint256);
    function cumulativeRewards(address _account) external view returns (uint256);
}

File 8 of 9 : Governable.sol
// SPDX-License-Identifier: MIT

pragma solidity 0.6.12;

contract Governable {
    address public gov;

    constructor() public {
        gov = msg.sender;
    }

    modifier onlyGov() {
        require(msg.sender == gov, "Governable: forbidden");
        _;
    }

    function setGov(address _gov) external onlyGov {
        gov = _gov;
    }
}

File 9 of 9 : Address.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.6.2;

/**
 * @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
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        // solhint-disable-next-line no-inline-assembly
        assembly { size := extcodesize(account) }
        return size > 0;
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success, ) = recipient.call{ value: amount }("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain`call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
      return functionCall(target, data, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        require(isContract(target), "Address: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{ value: value }(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
        return functionStaticCall(target, data, "Address: low-level static call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data, string memory errorMessage) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.staticcall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.3._
     */
    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionDelegateCall(target, data, "Address: low-level delegate call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.3._
     */
    function functionDelegateCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    function _verifyCallResult(bool success, bytes memory returndata, string memory errorMessage) private pure returns(bytes memory) {
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

Settings
{
  "optimizer": {
    "enabled": true,
    "runs": 1
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  },
  "libraries": {}
}

Contract ABI

[{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"}],"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":false,"internalType":"address","name":"receiver","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Claim","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":"BASIS_POINTS_DIVISOR","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PRECISION","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":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"allowances","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":"","type":"address"}],"name":"averageStakedAmounts","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"balances","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_receiver","type":"address"}],"name":"claim","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_account","type":"address"},{"internalType":"address","name":"_receiver","type":"address"}],"name":"claimForAccount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_account","type":"address"}],"name":"claimable","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"claimableReward","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"cumulativeRewardPerToken","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"cumulativeRewards","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":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"depositBalances","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"distributor","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"gov","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"inPrivateClaimingMode","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"inPrivateStakingMode","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"inPrivateTransferMode","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"_depositTokens","type":"address[]"},{"internalType":"address","name":"_distributor","type":"address"}],"name":"initialize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isDepositToken","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isHandler","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isInitialized","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"previousCumulatedRewardPerToken","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rewardToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_depositToken","type":"address"},{"internalType":"bool","name":"_isDepositToken","type":"bool"}],"name":"setDepositToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_gov","type":"address"}],"name":"setGov","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_handler","type":"address"},{"internalType":"bool","name":"_isActive","type":"bool"}],"name":"setHandler","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_inPrivateClaimingMode","type":"bool"}],"name":"setInPrivateClaimingMode","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_inPrivateStakingMode","type":"bool"}],"name":"setInPrivateStakingMode","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_inPrivateTransferMode","type":"bool"}],"name":"setInPrivateTransferMode","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_depositToken","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"stake","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_fundingAccount","type":"address"},{"internalType":"address","name":"_account","type":"address"},{"internalType":"address","name":"_depositToken","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"stakeForAccount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"stakedAmounts","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensPerInterval","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"totalDepositSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_recipient","type":"address"},{"internalType":"uint256","name":"_amount","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":"_depositToken","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"unstake","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_account","type":"address"},{"internalType":"address","name":"_depositToken","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"address","name":"_receiver","type":"address"}],"name":"unstakeForAccount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"updateRewards","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"},{"internalType":"address","name":"_account","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"withdrawToken","outputs":[],"stateMutability":"nonpayable","type":"function"}]

60806040523480156200001157600080fd5b5060405162002c2738038062002c27833981810160405260408110156200003757600080fd5b81019080805160405193929190846401000000008211156200005857600080fd5b9083019060208201858111156200006e57600080fd5b82516401000000008111828201881017156200008957600080fd5b82525081516020918201929091019080838360005b83811015620000b85781810151838201526020016200009e565b50505050905090810190601f168015620000e65780820380516001836020036101000a031916815260200191505b50604052602001805160405193929190846401000000008211156200010a57600080fd5b9083019060208201858111156200012057600080fd5b82516401000000008111828201881017156200013b57600080fd5b82525081516020918201929091019080838360005b838110156200016a57818101518382015260200162000150565b50505050905090810190601f168015620001985780820380516001836020036101000a031916815260200191505b5060405250506001600081905580546001600160a01b03191633179055508151620001cb906002906020850190620001ea565b508051620001e1906003906020840190620001ea565b50505062000286565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f106200022d57805160ff19168380011785556200025d565b828001600101855582156200025d579182015b828111156200025d57825182559160200191906001019062000240565b506200026b9291506200026f565b5090565b5b808211156200026b576000815560010162000270565b61299180620002966000396000f3fe608060405234801561001057600080fd5b50600436106102255760003560e01c806301e336671461022a57806306fdde0314610262578063095ea7b3146102df578063098bf59d1461031f57806310c1c1031461035b578063126082cf1461039357806312d43a511461039b57806313e82e7a146103bf57806318160ddd146103ed5780631d30d5bc146103f55780631e83409a1461041457806323b872dd1461043a57806327e235e314610470578063313ce567146104965780633792def3146104b4578063392e53cd146104da5780633cd7f700146104e25780633e158b0c14610501578063402914f51461050957806344a084111461052f578063462d0b2e1461055557806346ea87af14610601578063552ce1dc1461062757806355b6ed5c1461064d5780635a47a1a71461067b57806370a082311461069a578063790b5a6c146106c057806395d89b41146106fc5780639cb7de4b14610704578063a318021714610732578063a8d9362714610758578063a9059cbb14610760578063aaf5eb681461078c578063adc9772e14610794578063b89e45b3146107c0578063bfe10928146107e6578063c2a672e0146107ee578063c5fa27301461081a578063cfad57a214610822578063dd62ed3e14610848578063dfbaefb114610876578063e44b75581461087e578063e9503425146108ac578063f5d9d63e146108d2578063f5fc507614610900578063f76033d314610908578063f7c618c114610910575b600080fd5b6102606004803603606081101561024057600080fd5b506001600160a01b03813581169160208101359091169060400135610918565b005b61026a61097e565b6040805160208082528351818301528351919283929083019185019080838360005b838110156102a457818101518382015260200161028c565b50505050905090810190601f1680156102d15780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b61030b600480360360408110156102f557600080fd5b506001600160a01b038135169060200135610a09565b604080519115158252519081900360200190f35b6102606004803603608081101561033557600080fd5b506001600160a01b03813581169160208101358216916040820135916060013516610a20565b6103816004803603602081101561037157600080fd5b50356001600160a01b0316610a8a565b60408051918252519081900360200190f35b610381610a9c565b6103a3610aa2565b604080516001600160a01b039092168252519081900360200190f35b610381600480360360408110156103d557600080fd5b506001600160a01b0381358116916020013516610ab1565b610381610b1c565b6102606004803603602081101561040b57600080fd5b50351515610b22565b6103816004803603602081101561042a57600080fd5b50356001600160a01b0316610b89565b61030b6004803603606081101561045057600080fd5b506001600160a01b03813581169160208101359091169060400135610c33565b6103816004803603602081101561048657600080fd5b50356001600160a01b0316610ccd565b61049e610cdf565b6040805160ff9092168252519081900360200190f35b610381600480360360208110156104ca57600080fd5b50356001600160a01b0316610ce4565b61030b610cf6565b610260600480360360208110156104f857600080fd5b50351515610d06565b610260610d6f565b6103816004803603602081101561051f57600080fd5b50356001600160a01b0316610dcc565b6103816004803603602081101561054557600080fd5b50356001600160a01b0316610f2a565b6102606004803603604081101561056b57600080fd5b810190602081018135600160201b81111561058557600080fd5b82018360208201111561059757600080fd5b803590602001918460208302840111600160201b831117156105b857600080fd5b919080806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250929550505090356001600160a01b03169150610f3c9050565b61030b6004803603602081101561061757600080fd5b50356001600160a01b031661105f565b6103816004803603602081101561063d57600080fd5b50356001600160a01b0316611074565b6103816004803603604081101561066357600080fd5b506001600160a01b0381358116916020013516611086565b6102606004803603602081101561069157600080fd5b503515156110a3565b610381600480360360208110156106b057600080fd5b50356001600160a01b0316611103565b610260600480360360808110156106d657600080fd5b506001600160a01b0381358116916020810135821691604082013516906060013561111e565b61026a61117d565b6102606004803603604081101561071a57600080fd5b506001600160a01b03813516906020013515156111d8565b6103816004803603602081101561074857600080fd5b50356001600160a01b0316611250565b610381611262565b61030b6004803603604081101561077657600080fd5b506001600160a01b0381351690602001356112e3565b6103816112f0565b610260600480360360408110156107aa57600080fd5b506001600160a01b038135169060200135611300565b61030b600480360360208110156107d657600080fd5b50356001600160a01b03166113a7565b6103a36113bc565b6102606004803603604081101561080457600080fd5b506001600160a01b0381351690602001356113cb565b61030b611469565b6102606004803603602081101561083857600080fd5b50356001600160a01b0316611477565b6103816004803603604081101561085e57600080fd5b506001600160a01b03813581169160200135166114e6565b61030b611511565b6102606004803603604081101561089457600080fd5b506001600160a01b038135169060200135151561151a565b610381600480360360208110156108c257600080fd5b50356001600160a01b0316611592565b610381600480360360408110156108e857600080fd5b506001600160a01b03813581169160200135166115a4565b6103816115c1565b61030b6115c7565b6103a36115d6565b6001546001600160a01b03163314610965576040805162461bcd60e51b81526020600482015260156024820152600080516020612710833981519152604482015290519081900360640190fd5b6109796001600160a01b0384168383611626565b505050565b6002805460408051602060018416156101000260001901909316849004601f81018490048402820184019092528181529291830182828015610a015780601f106109d657610100808354040283529160200191610a01565b820191906000526020600020905b8154815290600101906020018083116109e457829003601f168201915b505050505081565b6000610a16338484611678565b5060015b92915050565b60026000541415610a66576040805162461bcd60e51b815260206004820152601f6024820152600080516020612670833981519152604482015290519081900360640190fd5b6002600055610a73611764565b610a7f848484846117c5565b505060016000555050565b600c6020526000908152604090205481565b61271081565b6001546001600160a01b031681565b600060026000541415610af9576040805162461bcd60e51b815260206004820152601f6024820152600080516020612670833981519152604482015290519081900360640190fd5b6002600055610b06611764565b610b1083836119c1565b60016000559392505050565b60085481565b6001546001600160a01b03163314610b6f576040805162461bcd60e51b81526020600482015260156024820152600080516020612710833981519152604482015290519081900360640190fd5b601180549115156101000261ff0019909216919091179055565b600060026000541415610bd1576040805162461bcd60e51b815260206004820152601f6024820152600080516020612670833981519152604482015290519081900360640190fd5b600260005560115462010000900460ff1615610c1e5760405162461bcd60e51b81526004018080602001828103825260218152602001806128e06021913960400191505060405180910390fd5b610c2833836119c1565b600160005592915050565b3360009081526012602052604081205460ff1615610c5e57610c56848484611a57565b506001610cc6565b6000610ca883604051806060016040528060308152602001612886603091396001600160a01b0388166000908152600a602090815260408083203384529091529020549190611baa565b9050610cb5853383611678565b610cc0858585611a57565b60019150505b9392505050565b60096020526000908152604090205481565b601281565b600f6020526000908152604090205481565b600154600160a01b900460ff1681565b6001546001600160a01b03163314610d53576040805162461bcd60e51b81526020600482015260156024820152600080516020612710833981519152604482015290519081900360640190fd5b60118054911515620100000262ff000019909216919091179055565b60026000541415610db5576040805162461bcd60e51b815260206004820152601f6024820152600080516020612670833981519152604482015290519081900360640190fd5b60026000908155610dc590611c41565b6001600055565b6001600160a01b0381166000908152600c602052604081205480610e0a5750506001600160a01b0381166000908152600d6020526040902054610f25565b60085460048054604080516376f69fed60e11b81529051600093610e979368327cb2734119d3b7a9601e1b936001600160a01b039091169263eded3fda92828101926020929190829003018186803b158015610e6557600080fd5b505afa158015610e79573d6000803e3d6000fd5b505050506040513d6020811015610e8f57600080fd5b505190611e91565b90506000610eb1610ea88385611eea565b600b5490611f29565b6001600160a01b0387166000908152600e6020526040902054909150610f1e90610eff9068327cb2734119d3b7a9601e1b90610ef990610ef2908690611f81565b8890611e91565b90611eea565b6001600160a01b0388166000908152600d602052604090205490611f29565b9450505050505b919050565b600e6020526000908152604090205481565b6001546001600160a01b03163314610f89576040805162461bcd60e51b81526020600482015260156024820152600080516020612710833981519152604482015290519081900360640190fd5b600154600160a01b900460ff1615610fd25760405162461bcd60e51b81526004018080602001828103825260228152602001806127f06022913960400191505060405180910390fd5b6001805460ff60a01b1916600160a01b17905560005b825181101561103b576000838281518110610fff57fe5b6020908102919091018101516001600160a01b03166000908152600590915260409020805460ff19166001908117909155919091019050610fe8565b50600480546001600160a01b0319166001600160a01b039290921691909117905550565b60126020526000908152604090205460ff1681565b60076020526000908152604090205481565b600a60209081526000928352604080842090915290825290205481565b6001546001600160a01b031633146110f0576040805162461bcd60e51b81526020600482015260156024820152600080516020612710833981519152604482015290519081900360640190fd5b6011805460ff1916911515919091179055565b6001600160a01b031660009081526009602052604090205490565b60026000541415611164576040805162461bcd60e51b815260206004820152601f6024820152600080516020612670833981519152604482015290519081900360640190fd5b6002600055611171611764565b610a7f84848484611fc3565b6003805460408051602060026001851615610100026000190190941693909304601f81018490048402820184019092528181529291830182828015610a015780601f106109d657610100808354040283529160200191610a01565b6001546001600160a01b03163314611225576040805162461bcd60e51b81526020600482015260156024820152600080516020612710833981519152604482015290519081900360640190fd5b6001600160a01b03919091166000908152601260205260409020805460ff1916911515919091179055565b60106020526000908152604090205481565b6000600460009054906101000a90046001600160a01b03166001600160a01b031663a8d936276040518163ffffffff1660e01b815260040160206040518083038186803b1580156112b257600080fd5b505afa1580156112c6573d6000803e3d6000fd5b505050506040513d60208110156112dc57600080fd5b5051905090565b6000610a16338484611a57565b68327cb2734119d3b7a9601e1b81565b60026000541415611346576040805162461bcd60e51b815260206004820152601f6024820152600080516020612670833981519152604482015290519081900360640190fd5b6002600055601154610100900460ff16156113925760405162461bcd60e51b81526004018080602001828103825260218152602001806128e06021913960400191505060405180910390fd5b61139e33338484611fc3565b50506001600055565b60056020526000908152604090205460ff1681565b6004546001600160a01b031681565b60026000541415611411576040805162461bcd60e51b815260206004820152601f6024820152600080516020612670833981519152604482015290519081900360640190fd5b6002600055601154610100900460ff161561145d5760405162461bcd60e51b81526004018080602001828103825260218152602001806128e06021913960400191505060405180910390fd5b61139e338383336117c5565b601154610100900460ff1681565b6001546001600160a01b031633146114c4576040805162461bcd60e51b81526020600482015260156024820152600080516020612710833981519152604482015290519081900360640190fd5b600180546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b039182166000908152600a6020908152604080832093909416825291909152205490565b60115460ff1681565b6001546001600160a01b03163314611567576040805162461bcd60e51b81526020600482015260156024820152600080516020612710833981519152604482015290519081900360640190fd5b6001600160a01b03919091166000908152600560205260409020805460ff1916911515919091179055565b600d6020526000908152604090205481565b600660209081526000928352604080842090915290825290205481565b600b5481565b60115462010000900460ff1681565b6000600460009054906101000a90046001600160a01b03166001600160a01b031663f7c618c16040518163ffffffff1660e01b815260040160206040518083038186803b1580156112b257600080fd5b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b17905261097990849061213a565b6001600160a01b0383166116bd5760405162461bcd60e51b815260040180806020018281038252602c8152602001806126bb602c913960400191505060405180910390fd5b6001600160a01b0382166117025760405162461bcd60e51b815260040180806020018281038252602a8152602001806127a5602a913960400191505060405180910390fd5b6001600160a01b038084166000818152600a6020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b3360009081526012602052604090205460ff166117c3576040805162461bcd60e51b81526020600482015260186024820152772932bbb0b9322a3930b1b5b2b91d103337b93134b23232b760411b604482015290519081900360640190fd5b565b60008211611808576040805162461bcd60e51b815260206004820152601e6024820152600080516020612626833981519152604482015290519081900360640190fd5b6001600160a01b03831660009081526005602052604090205460ff1661185f5760405162461bcd60e51b81526004018080602001828103825260248152602001806127816024913960400191505060405180910390fd5b61186884611c41565b6001600160a01b0384166000908152600c6020526040902054828110156118c05760405162461bcd60e51b815260040180806020018281038252602b815260200180612690602b913960400191505060405180910390fd5b6118ca8184611f81565b6001600160a01b038087166000908152600c60209081526040808320949094556006815283822092881682529190915220548381101561193b5760405162461bcd60e51b815260040180806020018281038252602d815260200180612901602d913960400191505060405180910390fd5b6119458185611f81565b6001600160a01b038088166000908152600660209081526040808320938a1683529281528282209390935560079092529020546119829085611f81565b6001600160a01b0386166000908152600760205260409020556119a586856121eb565b6119b96001600160a01b0386168486611626565b505050505050565b60006119cc83611c41565b6001600160a01b0383166000908152600d6020526040812080549190558015610cc657611a0c83826119fc6115d6565b6001600160a01b03169190611626565b604080516001600160a01b03861681526020810183905281517f47cee97cb7acd717b3c0aa1435d004cd5b3c8c57d70dbceb4e4458bbd60e39d4929181900390910190a19392505050565b6001600160a01b038316611a9c5760405162461bcd60e51b815260040180806020018281038252602d815260200180612812602d913960400191505060405180910390fd5b6001600160a01b038216611ae15760405162461bcd60e51b815260040180806020018281038252602b815260200180612730602b913960400191505060405180910390fd5b60115460ff1615611af457611af4611764565b611b31816040518060600160405280602e815260200161292e602e91396001600160a01b0386166000908152600960205260409020549190611baa565b6001600160a01b038085166000908152600960205260408082209390935590841681522054611b609082611f29565b6001600160a01b03808416600081815260096020908152604091829020949094558051858152905191939287169260008051602061286683398151915292918290030190a3505050565b60008184841115611c395760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611bfe578181015183820152602001611be6565b50505050905090810190601f168015611c2b5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6000600460009054906101000a90046001600160a01b03166001600160a01b031663e4fc6b6d6040518163ffffffff1660e01b8152600401602060405180830381600087803b158015611c9357600080fd5b505af1158015611ca7573d6000803e3d6000fd5b505050506040513d6020811015611cbd57600080fd5b5051600854600b54919250908115801590611cd85750600083115b15611d0957611d01611cfa83610ef98668327cb2734119d3b7a9601e1b611e91565b8290611f29565b600b81905590505b80611d1657505050611e8e565b6001600160a01b03841615611e8a576001600160a01b0384166000908152600c6020908152604080832054600e909252822054909190611d749068327cb2734119d3b7a9601e1b90610ef990611d6d908790611f81565b8590611e91565b6001600160a01b0387166000908152600d602052604081205491925090611d9b9083611f29565b6001600160a01b0388166000908152600d60209081526040808320849055600e909152902085905590508015801590611deb57506001600160a01b0387166000908152600c602052604090205415155b15611e86576001600160a01b0387166000908152600f6020526040812054611e139084611f29565b9050611e60611e2682610ef98787611e91565b6001600160a01b038a166000908152600f6020908152604080832054601090925290912054611e5a918591610ef991611e91565b90611f29565b6001600160a01b038916600090815260106020908152604080832093909355600f905220555b5050505b5050505b50565b600082611ea057506000610a1a565b82820282848281611ead57fe5b0414610cc65760405162461bcd60e51b81526004018080602001828103825260218152602001806127cf6021913960400191505060405180910390fd5b6000610cc683836040518060400160405280601a815260200179536166654d6174683a206469766973696f6e206279207a65726f60301b8152506122c9565b600082820183811015610cc6576040805162461bcd60e51b815260206004820152601b60248201527a536166654d6174683a206164646974696f6e206f766572666c6f7760281b604482015290519081900360640190fd5b6000610cc683836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611baa565b60008111612006576040805162461bcd60e51b815260206004820152601e6024820152600080516020612626833981519152604482015290519081900360640190fd5b6001600160a01b03821660009081526005602052604090205460ff1661205d5760405162461bcd60e51b81526004018080602001828103825260248152602001806127816024913960400191505060405180910390fd5b6120726001600160a01b03831685308461232e565b61207b83611c41565b6001600160a01b0383166000908152600c602052604090205461209e9082611f29565b6001600160a01b038085166000908152600c60209081526040808320949094556006815283822092861682529190915220546120da9082611f29565b6001600160a01b03808516600090815260066020908152604080832093871683529281528282209390935560079092529020546121179082611f29565b6001600160a01b038316600090815260076020526040902055611e8a8382612388565b606061218f826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166124469092919063ffffffff16565b805190915015610979578080602001905160208110156121ae57600080fd5b50516109795760405162461bcd60e51b815260040180806020018281038252602a8152602001806128b6602a913960400191505060405180910390fd5b6001600160a01b0382166122305760405162461bcd60e51b81526004018080602001828103825260298152602001806126e76029913960400191505060405180910390fd5b61226d816040518060600160405280602a8152602001612646602a91396001600160a01b0385166000908152600960205260409020549190611baa565b6001600160a01b0383166000908152600960205260409020556008546122939082611f81565b6008556040805182815290516000916001600160a01b038516916000805160206128668339815191529181900360200190a35050565b600081836123185760405162461bcd60e51b8152602060048201818152835160248401528351909283926044909101919085019080838360008315611bfe578181015183820152602001611be6565b50600083858161232457fe5b0495945050505050565b604080516001600160a01b0380861660248301528416604482015260648082018490528251808303909101815260849091019091526020810180516001600160e01b03166323b872dd60e01b179052611e8a90859061213a565b6001600160a01b0382166123cd5760405162461bcd60e51b815260040180806020018281038252602781526020018061283f6027913960400191505060405180910390fd5b6008546123da9082611f29565b6008556001600160a01b0382166000908152600960205260409020546124009082611f29565b6001600160a01b03831660008181526009602090815260408083209490945583518581529351929391926000805160206128668339815191529281900390910190a35050565b6060612455848460008561245d565b949350505050565b60608247101561249e5760405162461bcd60e51b815260040180806020018281038252602681526020018061275b6026913960400191505060405180910390fd5b6124a7856125b9565b6124f8576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b602083106125375780518252601f199092019160209182019101612518565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114612599576040519150601f19603f3d011682016040523d82523d6000602084013e61259e565b606091505b50915091506125ae8282866125bf565b979650505050505050565b3b151590565b606083156125ce575081610cc6565b8251156125de5782518084602001fd5b60405162461bcd60e51b8152602060048201818152845160248401528451859391928392604401919085019080838360008315611bfe578181015183820152602001611be656fe526577617264547261636b65723a20696e76616c6964205f616d6f756e740000526577617264547261636b65723a206275726e20616d6f756e7420657863656564732062616c616e63655265656e7472616e637947756172643a207265656e7472616e742063616c6c00526577617264547261636b65723a205f616d6f756e742065786365656473207374616b6564416d6f756e74526577617264547261636b65723a20617070726f76652066726f6d20746865207a65726f2061646472657373526577617264547261636b65723a206275726e2066726f6d20746865207a65726f2061646472657373476f7665726e61626c653a20666f7262696464656e0000000000000000000000526577617264547261636b65723a207472616e7366657220746f20746865207a65726f2061646472657373416464726573733a20696e73756666696369656e742062616c616e636520666f722063616c6c526577617264547261636b65723a20696e76616c6964205f6465706f736974546f6b656e526577617264547261636b65723a20617070726f766520746f20746865207a65726f2061646472657373536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f77526577617264547261636b65723a20616c726561647920696e697469616c697a6564526577617264547261636b65723a207472616e736665722066726f6d20746865207a65726f2061646472657373526577617264547261636b65723a206d696e7420746f20746865207a65726f2061646472657373ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef526577617264547261636b65723a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e63655361666545524332303a204552433230206f7065726174696f6e20646964206e6f742073756363656564526577617264547261636b65723a20616374696f6e206e6f7420656e61626c6564526577617264547261636b65723a205f616d6f756e742065786365656473206465706f73697442616c616e6365526577617264547261636b65723a207472616e7366657220616d6f756e7420657863656564732062616c616e6365a2646970667358221220a2a3a06705ce1314acbeee9e9c5ac4fc608c19a9384a2f6d662d636791ae414464736f6c634300060c003300000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000000a5374616b656420474d5800000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000473474d5800000000000000000000000000000000000000000000000000000000

Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.