Contract 0x077F9e86B53Ac32187f479A096Af0362825eD651 2

 

Contract Overview

Balance:
0 BNB

BNB Value:
$0.00

Token:
 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0xb8f982bd7888df383cfe3df2cc5cb139bc0ba9b4b95f0d289f1517faea885b69Withdraw145014872022-01-19 12:38:399 hrs 23 mins ago0xb4bb114b1b3bd8fa89d7a74f2d8a5a4239c88807 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00059597
0x805ae4aabafa660ef1747ae4b9d9da318c2b9a1ddda2a687d8ad1b391e9e0958Deposit145014712022-01-19 12:37:519 hrs 23 mins ago0xb4bb114b1b3bd8fa89d7a74f2d8a5a4239c88807 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00080741
0x4a1ffc5824acf798c033221f9c0981842c511201153c47f8be28cf327b9725bcDeposit144775052022-01-18 16:37:251 day 5 hrs ago0x82d78b962ad2a921b6b843333b414641edd27d64 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.000749325
0x137b0397d51586da195e5b4a93dbe8623500baccbaa758f7ace58d69bfc81b95Deposit142755642022-01-11 15:26:028 days 6 hrs ago0x80ed43b18cc73084334628c9810436cda29982cf IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00076895
0xc1029b8f277c2d7378e28962c5e7c2c4a413d70934c5b9770f12ec73137f5b91Withdraw142644892022-01-11 6:09:578 days 15 hrs ago0x86132419153dc0856c4af81aa1a7e72c35cc96e0 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00067084
0x5e5cb36ef6b9f9a6b94246b476434cdc9520083c1854eaead9d7a09138d7b5dbDeposit142641032022-01-11 5:50:398 days 16 hrs ago0x86132419153dc0856c4af81aa1a7e72c35cc96e0 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00076907
0x5f0d9a5deb4959f06d6ed3cd11dac33e985e12e57f98f1660545076211a0fa34Withdraw142640472022-01-11 5:47:518 days 16 hrs ago0xcfa602875cc7e4381989bbf31124fefaa96136a1 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00052072
0x693c0e8abe9beff2d6a922a097a6d651ea6ad5c8ae694bf6172c36ac926c71adDeposit142639512022-01-11 5:43:038 days 16 hrs ago0xcfa602875cc7e4381989bbf31124fefaa96136a1 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.000866185
0xd3d704dc81f13d4c5e6a5c05f5aaf880c828bb16ae6bdf8e1cd4d755b99feb0dDeposit142639372022-01-11 5:42:218 days 16 hrs ago0xcfa602875cc7e4381989bbf31124fefaa96136a1 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00084389
0xec26b8638e61818003cffe69bd7d4df4da6b1b592d82d3eafea61f7fd4ac96edWithdraw142496832022-01-10 17:45:559 days 4 hrs ago0xa61254ae264e5b32d70c84427f2936fd4bf9df3c IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00059584
0xf387db63a4bed457133ffb6993b933ef1503be7f8e3750e9d62ad743fb38b6ccDeposit142496632022-01-10 17:44:559 days 4 hrs ago0xa61254ae264e5b32d70c84427f2936fd4bf9df3c IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00055619
0xca621e4dbcd717343e1d8080744a1df5e410f2cf673707ee844016a283b7d640Deposit141541862022-01-07 10:06:4312 days 11 hrs ago0xa61254ae264e5b32d70c84427f2936fd4bf9df3c IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00076907
0x3cc0c0157a326b94362f6a4e182bc7afd3b3c46bc79018b9242f7c94abb26927Deposit141541262022-01-07 10:03:4312 days 11 hrs ago0xa61254ae264e5b32d70c84427f2936fd4bf9df3c IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.000437745
0xbb88afdc674b9ee0d25e3732159972f93efcb6ad3658d270c7cfcf6b3d433968Withdraw141540692022-01-07 10:00:5212 days 12 hrs ago0xa61254ae264e5b32d70c84427f2936fd4bf9df3c IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00059584
0x37f45a8da1fe31d3275b263c61e6ab292f68e12838897ffe3aabb53a7ee89a5fDeposit141540632022-01-07 10:00:3412 days 12 hrs ago0xa61254ae264e5b32d70c84427f2936fd4bf9df3c IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00063119
0x6e4a1338c78a5ebf61a62c7c5169eb8ed91af61c0c3af6cc977623098c3caf13Withdraw141529192022-01-07 9:03:2212 days 12 hrs ago0x028bedbad29f5a585ea99d2a648c6c634f93ffe0 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00067097
0xbb4ae9fb3e455a93f9b95b0fbf94c9867ffa962aef3ba6d27f6f893390ee0c28Deposit141528392022-01-07 8:59:2212 days 13 hrs ago0x028bedbad29f5a585ea99d2a648c6c634f93ffe0 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00080741
0x27bbe49bbf67e4789ffa86064f90e5cc9478280f6c1abc8f94ee155123988b69Deposit141462842022-01-07 3:28:5112 days 18 hrs ago0xa61254ae264e5b32d70c84427f2936fd4bf9df3c IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00076907
0x5569b6751f26b8c783c91eb3ae0c983d36628c78095aa0470bf888ab1ae544b9Withdraw140786502022-01-04 18:58:4115 days 3 hrs ago0x8c5e8da3864ae813c69b05dfef8d0cb1c233720a IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00059597
0x6c5fda56c499be468ce94b507b90e75a2860ea8fb5b610380ca0a2b15a280e43Deposit140786372022-01-04 18:58:0215 days 3 hrs ago0x8c5e8da3864ae813c69b05dfef8d0cb1c233720a IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00063122
0xf3a9da5e2da0c3ed921db08f1e0e547707d746a78728c69cf49961c8e1cab299Withdraw139924822022-01-01 19:02:4318 days 2 hrs ago0x599cb2b0a0e1e96aa31d187127a783f4d6b566ec IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00067066
0x32c752b539816bab2ba74949a8d88ab2a1e7a509c33fc4e0e42788ab47baf63cWithdraw139922902022-01-01 18:53:0718 days 3 hrs ago0xc48b968ca83cba03735d46f3fc8c2f3192db40a9 IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00067103
0xc19aa6037ad785764641a9ae2b380a404347462719cd0cbdcb1a5450f3cf76aeDeposit139921362022-01-01 18:45:2518 days 3 hrs ago0x599cb2b0a0e1e96aa31d187127a783f4d6b566ec IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00076889
0x78e031405173d9d52fbb0f096af464cc5b2706d65801a797a855fe6819c737ecWithdraw139840182022-01-01 11:58:3118 days 10 hrs ago0x079cdf0a3b6711e908b9d3a46abe603dcb538fdb IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00059584
0xb8b3114fcdf8e7c17da90387b83769d6b751d9353061badefae43e0db665a432Deposit139840122022-01-01 11:58:1318 days 10 hrs ago0x079cdf0a3b6711e908b9d3a46abe603dcb538fdb IN  0x077f9e86b53ac32187f479a096af0362825ed6510 BNB0.00063119
[ Download CSV Export 
Parent Txn Hash Block From To Value
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
MasterChefV2

Compiler Version
v0.6.12+commit.27d51765

Optimization Enabled:
Yes with 200 runs

Other Settings:
istanbul EvmVersion, MIT license

Contract Source Code (Solidity Multiple files format)

File 1 of 3: MasterChefV2.sol
/**
 * Code updated by Taylor for Pepper Finance
*/

// SPDX-License-Identifier: MIT

pragma solidity 0.6.12;

// import "@openzeppelin/contracts/math/SafeMath.sol";
// import "./libs/IERC20.sol";
// import "./libs/SafeBEP20.sol";
// import "@openzeppelin/contracts/access/Ownable.sol";
import "./ReentrancyGuard.sol";

import "./PEPRToken.sol";

// MasterChef is the master of Pepper. He can make Pepper and he is a fair guy.
//
// Note that it's ownable and the owner wields tremendous power. The ownership
// will be transferred to a governance smart contract once PEPR is sufficiently
// distributed and the community can show to govern itself.
//
// Have fun reading it. Hopefully it's bug-free. God bless.
contract MasterChefV2 is Ownable, ReentrancyGuard {
    using SafeMath for uint256;
    // using ERC20 for IERC20;

    // Info of each user.
    struct UserInfo {
        uint256 amount;         // How many LP tokens the user has provided.
        uint256 rewardDebt;     // Reward debt. See explanation below.
        //
        // We do some fancy math here. Basically, any point in time, the amount of PEPRs
        // entitled to a user but is pending to be distributed is:
        //
        //   pending reward = (user.amount * pool.accPeprPerShare) - user.rewardDebt
        //
        // Whenever a user deposits or withdraws LP tokens to a pool. Here's what happens:
        //   1. The pool's `accPeprPerShare` (and `lastRewardBlock`) gets updated.
        //   2. User receives the pending reward sent to his/her address.
        //   3. User's `amount` gets updated.
        //   4. User's `rewardDebt` gets updated.
    }

    // Info of each pool.
    struct PoolInfo {
        IERC20 lpToken;           // Address of LP token contract.
        uint256 allocPoint;       // How many allocation points assigned to this pool. PEPRs to distribute per block.
        uint256 lastRewardBlock;  // Last block number that PEPRs distribution occurs.
        uint256 accPeprPerShare;   // Accumulated PEPRs per share, times 1e12. See below.
        uint16 depositFeeBP;      // Deposit fee in basis points
    }

    // The PEPR TOKEN!
    PEPRToken public pepr;
    // Dev address.
    address public devaddr;
    // PEPR tokens created per block.
    uint256 public peprPerBlock;
    // Bonus muliplier for early pepr makers.
    uint256 public constant BONUS_MULTIPLIER = 1;
    // Deposit Fee address
    address public feeAddress;

    // Info of each pool.
    PoolInfo[] public poolInfo;
    // Info of each user that stakes LP tokens.
    mapping(uint256 => mapping(address => UserInfo)) public userInfo;
    // Total allocation points. Must be the sum of all allocation points in all pools.
    uint256 public totalAllocPoint = 0;
    // The block number when PEPR mining starts.
    uint256 public startBlock;

    event Deposit(address indexed user, uint256 indexed pid, uint256 amount);
    event Withdraw(address indexed user, uint256 indexed pid, uint256 amount);
    event EmergencyWithdraw(address indexed user, uint256 indexed pid, uint256 amount);
    event SetFeeAddress(address indexed user, address indexed newAddress);
    event SetDevAddress(address indexed user, address indexed newAddress);
    event UpdateEmissionRate(address indexed user, uint256 goosePerBlock);

    constructor(
        PEPRToken _pepr,
        address _devaddr,
        address _feeAddress,
        uint256 _peprPerBlock,
        uint256 _startBlock
    ) public {
        pepr = _pepr;
        devaddr = _devaddr;
        feeAddress = _feeAddress;
        peprPerBlock = _peprPerBlock;
        startBlock = _startBlock;
    }

    function poolLength() external view returns (uint256) {
        return poolInfo.length;
    }

    mapping(IERC20 => bool) public poolExistence;
    modifier nonDuplicated(IERC20 _lpToken) {
        require(poolExistence[_lpToken] == false, "nonDuplicated: duplicated");
        _;
    }

    // Add a new lp to the pool. Can only be called by the owner.
    function add(uint256 _allocPoint, IERC20 _lpToken, uint16 _depositFeeBP, bool _withUpdate) public onlyOwner nonDuplicated(_lpToken) {
        require(_depositFeeBP <= 10000, "add: invalid deposit fee basis points");
        if (_withUpdate) {
            massUpdatePools();
        }
        uint256 lastRewardBlock = block.number > startBlock ? block.number : startBlock;
        totalAllocPoint = totalAllocPoint.add(_allocPoint);
        poolExistence[_lpToken] = true;
        poolInfo.push(PoolInfo({
        lpToken : _lpToken,
        allocPoint : _allocPoint,
        lastRewardBlock : lastRewardBlock,
        accPeprPerShare : 0,
        depositFeeBP : _depositFeeBP
        }));
    }

    // Update the given pool's PEPR allocation point and deposit fee. Can only be called by the owner.
    function set(uint256 _pid, uint256 _allocPoint, uint16 _depositFeeBP, bool _withUpdate) public onlyOwner {
        require(_depositFeeBP <= 10000, "set: invalid deposit fee basis points");
        if (_withUpdate) {
            massUpdatePools();
        }
        totalAllocPoint = totalAllocPoint.sub(poolInfo[_pid].allocPoint).add(_allocPoint);
        poolInfo[_pid].allocPoint = _allocPoint;
        poolInfo[_pid].depositFeeBP = _depositFeeBP;
    }

    // Return reward multiplier over the given _from to _to block.
    function getMultiplier(uint256 _from, uint256 _to) public view returns (uint256) {
        return _to.sub(_from).mul(BONUS_MULTIPLIER);
    }

    // View function to see pending PEPRs on frontend.
    function pendingPepr(uint256 _pid, address _user) external view returns (uint256) {
        PoolInfo storage pool = poolInfo[_pid];
        UserInfo storage user = userInfo[_pid][_user];
        uint256 accPeprPerShare = pool.accPeprPerShare;
        uint256 lpSupply = pool.lpToken.balanceOf(address(this));
        if (block.number > pool.lastRewardBlock && lpSupply != 0) {
            uint256 multiplier = getMultiplier(pool.lastRewardBlock, block.number);
            uint256 peprReward = multiplier.mul(peprPerBlock).mul(pool.allocPoint).div(totalAllocPoint);
            accPeprPerShare = accPeprPerShare.add(peprReward.mul(1e12).div(lpSupply));
        }
        return user.amount.mul(accPeprPerShare).div(1e12).sub(user.rewardDebt);
    }

    // Update reward variables for all pools. Be careful of gas spending!
    function massUpdatePools() public {
        uint256 length = poolInfo.length;
        for (uint256 pid = 0; pid < length; ++pid) {
            updatePool(pid);
        }
    }

    // Update reward variables of the given pool to be up-to-date.
    function updatePool(uint256 _pid) public {
        PoolInfo storage pool = poolInfo[_pid];
        if (block.number <= pool.lastRewardBlock) {
            return;
        }
        uint256 lpSupply = pool.lpToken.balanceOf(address(this));
        if (lpSupply == 0 || pool.allocPoint == 0) {
            pool.lastRewardBlock = block.number;
            return;
        }
        uint256 multiplier = getMultiplier(pool.lastRewardBlock, block.number);
        uint256 peprReward = multiplier.mul(peprPerBlock).mul(pool.allocPoint).div(totalAllocPoint);
        pepr.mint(devaddr, peprReward.div(25));
        pepr.mint(address(this), peprReward);
        pool.accPeprPerShare = pool.accPeprPerShare.add(peprReward.mul(1e12).div(lpSupply));
        pool.lastRewardBlock = block.number;
    }

    // Deposit LP tokens to MasterChef for PEPR allocation.
    function deposit(uint256 _pid, uint256 _amount) public nonReentrant {
        PoolInfo storage pool = poolInfo[_pid];
        UserInfo storage user = userInfo[_pid][msg.sender];
        updatePool(_pid);
        if (user.amount > 0) {
            uint256 pending = user.amount.mul(pool.accPeprPerShare).div(1e12).sub(user.rewardDebt);
            if (pending > 0) {
                safePeprTransfer(msg.sender, pending);
            }
        }
        if (_amount > 0) {
            pool.lpToken.transferFrom(address(msg.sender), address(this), _amount);
            if (pool.depositFeeBP > 0) {
                uint256 depositFee = _amount.mul(pool.depositFeeBP).div(10000);
                pool.lpToken.transfer(feeAddress, depositFee);
                user.amount = user.amount.add(_amount).sub(depositFee);
            } else {
                user.amount = user.amount.add(_amount);
            }
        }
        user.rewardDebt = user.amount.mul(pool.accPeprPerShare).div(1e12);
        emit Deposit(msg.sender, _pid, _amount);
    }

    // Withdraw LP tokens from MasterChef.
    function withdraw(uint256 _pid, uint256 _amount) public nonReentrant {
        PoolInfo storage pool = poolInfo[_pid];
        UserInfo storage user = userInfo[_pid][msg.sender];
        require(user.amount >= _amount, "withdraw: not good");
        updatePool(_pid);
        uint256 pending = user.amount.mul(pool.accPeprPerShare).div(1e12).sub(user.rewardDebt);
        if (pending > 0) {
            safePeprTransfer(msg.sender, pending);
        }
        if (_amount > 0) {
            user.amount = user.amount.sub(_amount);
            pool.lpToken.transfer(address(msg.sender), _amount);
        }
        user.rewardDebt = user.amount.mul(pool.accPeprPerShare).div(1e12);
        emit Withdraw(msg.sender, _pid, _amount);
    }

    // Withdraw without caring about rewards. EMERGENCY ONLY.
    function emergencyWithdraw(uint256 _pid) public nonReentrant {
        PoolInfo storage pool = poolInfo[_pid];
        UserInfo storage user = userInfo[_pid][msg.sender];
        uint256 amount = user.amount;
        user.amount = 0;
        user.rewardDebt = 0;
        pool.lpToken.transfer(address(msg.sender), amount);
        emit EmergencyWithdraw(msg.sender, _pid, amount);
    }

    // Safe pepr transfer function, just in case if rounding error causes pool to not have enough PEPRs.
    function safePeprTransfer(address _to, uint256 _amount) internal {
        uint256 peprBal = pepr.balanceOf(address(this));
        bool transferSuccess = false;
        if (_amount > peprBal) {
            transferSuccess = pepr.transfer(_to, peprBal);
        } else {
            transferSuccess = pepr.transfer(_to, _amount);
        }
        require(transferSuccess, "safePeprTransfer: transfer failed");
    }

    // Update dev address by the previous dev.
    function dev(address _devaddr) public {
        require(msg.sender == devaddr, "dev: wut?");
        devaddr = _devaddr;
        emit SetDevAddress(msg.sender, _devaddr);
    }

    function setFeeAddress(address _feeAddress) public {
        require(msg.sender == feeAddress, "setFeeAddress: FORBIDDEN");
        feeAddress = _feeAddress;
        emit SetFeeAddress(msg.sender, _feeAddress);
    }

    //Pancake has to add hidden dummy pools inorder to alter the emission, here we make it simple and transparent to all.
    function updateEmissionRate(uint256 _peprPerBlock) public onlyOwner {
        massUpdatePools();
        peprPerBlock = _peprPerBlock;
        emit UpdateEmissionRate(msg.sender, _peprPerBlock);
    }
}

File 2 of 3: PEPRToken.sol
/**
 * Code updated by Taylor for Pepper Finance
*/

// SPDX-License-Identifier: MIT

pragma solidity ^0.6.12;

// import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/ERC20.sol";
abstract contract Context {
    function _msgSender() internal view virtual returns (address payable) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes memory) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

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;
    }
}

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
    );
}

contract ERC20 is Context, IERC20 {
    using SafeMath for uint256;

    mapping(address => uint256) private _balances;

    mapping(address => mapping(address => uint256)) private _allowances;

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;
    uint8 private _decimals;

    /**
     * @dev Sets the values for {name} and {symbol}, initializes {decimals} with
     * a default value of 18.
     *
     * To select a different value for {decimals}, use {_setupDecimals}.
     *
     * All three of these values are immutable: they can only be set once during
     * construction.
     */
    constructor(string memory name_, string memory symbol_) public {
        _name = name_;
        _symbol = symbol_;
        _decimals = 18;
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5,05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless {_setupDecimals} is
     * called.
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view returns (uint8) {
        return _decimals;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view override returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account) public view override returns (uint256) {
        return _balances[account];
    }

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount)
        public
        virtual
        override
        returns (bool)
    {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender)
        public
        view
        virtual
        override
        returns (uint256)
    {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount)
        public
        virtual
        override
        returns (bool)
    {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(
            sender,
            _msgSender(),
            _allowances[sender][_msgSender()].sub(
                amount,
                "ERC20: transfer amount exceeds allowance"
            )
        );
        return true;
    }

    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue)
        public
        virtual
        returns (bool)
    {
        _approve(
            _msgSender(),
            spender,
            _allowances[_msgSender()][spender].add(addedValue)
        );
        return true;
    }

    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue)
        public
        virtual
        returns (bool)
    {
        _approve(
            _msgSender(),
            spender,
            _allowances[_msgSender()][spender].sub(
                subtractedValue,
                "ERC20: decreased allowance below zero"
            )
        );
        return true;
    }

    /**
     * @dev Moves tokens `amount` from `sender` to `recipient`.
     *
     * This is internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        _beforeTokenTransfer(sender, recipient, amount);

        _balances[sender] = _balances[sender].sub(
            amount,
            "ERC20: transfer amount exceeds balance"
        );
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
    }

    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

        _beforeTokenTransfer(address(0), account, amount);

        _totalSupply = _totalSupply.add(amount);
        _balances[account] = _balances[account].add(amount);
        emit Transfer(address(0), account, amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, reducing the
     * total supply.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     * - `account` must have at least `amount` tokens.
     */
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        _balances[account] = _balances[account].sub(
            amount,
            "ERC20: burn amount exceeds balance"
        );
        _totalSupply = _totalSupply.sub(amount);
        emit Transfer(account, address(0), amount);
    }

    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    /**
     * @dev Sets {decimals} to a value other than the default one of 18.
     *
     * WARNING: This function should only be called from the constructor. Most
     * applications that interact with token contracts will not expect
     * {decimals} to ever change, and may work incorrectly if it does.
     */
    function _setupDecimals(uint8 decimals_) internal {
        _decimals = decimals_;
    }

    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be to transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

// import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/access/Ownable.sol";
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.
     */
    constructor() internal {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(
            newOwner != address(0),
            "Ownable: new owner is the zero address"
        );
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}


contract PEPRToken is ERC20("Pepper Token", "PEPR"), Ownable {
    uint256 private _maxTotalSupply = 7777777e18; // Maximum Total PEPR supply: 7,777,777 Tokens

    function mint(address _to, uint256 _amount) public onlyOwner {
        _mint(_to, _amount);
    }
        /**
     * @dev See {ERC20-_beforeTokenTransfer}.
     *
     * Requirements:
     *
     * - minted tokens must not cause the total supply to go over the cap.
     */
    function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual override {
        super._beforeTokenTransfer(from, to, amount);
        if (from == address(0)) { // When minting tokens
            require(totalSupply().add(amount) <= _maxTotalSupply, "Maxium Pepr Supply 7,777,777 Token: Supply Exceeded");
        }
    }
}

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

pragma solidity >=0.6.0 <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
    // 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;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"contract PEPRToken","name":"_pepr","type":"address"},{"internalType":"address","name":"_devaddr","type":"address"},{"internalType":"address","name":"_feeAddress","type":"address"},{"internalType":"uint256","name":"_peprPerBlock","type":"uint256"},{"internalType":"uint256","name":"_startBlock","type":"uint256"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Deposit","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"EmergencyWithdraw","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"address","name":"newAddress","type":"address"}],"name":"SetDevAddress","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"address","name":"newAddress","type":"address"}],"name":"SetFeeAddress","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"goosePerBlock","type":"uint256"}],"name":"UpdateEmissionRate","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Withdraw","type":"event"},{"inputs":[],"name":"BONUS_MULTIPLIER","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_allocPoint","type":"uint256"},{"internalType":"contract IERC20","name":"_lpToken","type":"address"},{"internalType":"uint16","name":"_depositFeeBP","type":"uint16"},{"internalType":"bool","name":"_withUpdate","type":"bool"}],"name":"add","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"deposit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_devaddr","type":"address"}],"name":"dev","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"devaddr","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"}],"name":"emergencyWithdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"feeAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_from","type":"uint256"},{"internalType":"uint256","name":"_to","type":"uint256"}],"name":"getMultiplier","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"massUpdatePools","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"address","name":"_user","type":"address"}],"name":"pendingPepr","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pepr","outputs":[{"internalType":"contract PEPRToken","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"peprPerBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"name":"poolExistence","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"poolInfo","outputs":[{"internalType":"contract IERC20","name":"lpToken","type":"address"},{"internalType":"uint256","name":"allocPoint","type":"uint256"},{"internalType":"uint256","name":"lastRewardBlock","type":"uint256"},{"internalType":"uint256","name":"accPeprPerShare","type":"uint256"},{"internalType":"uint16","name":"depositFeeBP","type":"uint16"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"poolLength","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"uint256","name":"_allocPoint","type":"uint256"},{"internalType":"uint16","name":"_depositFeeBP","type":"uint16"},{"internalType":"bool","name":"_withUpdate","type":"bool"}],"name":"set","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_feeAddress","type":"address"}],"name":"setFeeAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalAllocPoint","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_peprPerBlock","type":"uint256"}],"name":"updateEmissionRate","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"}],"name":"updatePool","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"address","name":"","type":"address"}],"name":"userInfo","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"rewardDebt","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"}]

6080604052600060085534801561001557600080fd5b50604051611d2c380380611d2c833981810160405260a081101561003857600080fd5b5080516020820151604083015160608401516080909401519293919290919060006100616100fb565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35060018055600280546001600160a01b03199081166001600160a01b0397881617909155600380548216958716959095179094556005805490941692909416919091179091556004556009556100ff565b3390565b611c1e8061010e6000396000f3fe608060405234801561001057600080fd5b506004361061018e5760003560e01c80638705fcd4116100de578063b5ceeb9d11610097578063d963842211610071578063d963842214610417578063e095a0941461044c578063e2bbb15814610478578063f2fde38b1461049b5761018e565b8063b5ceeb9d146103cd578063cbd258b5146103d5578063d49e77cd1461040f5761018e565b80638705fcd4146103095780638aa285501461032f5780638d88a90e146103375780638da5cb5b1461035d5780638dbb1e3a1461036557806393f1a40b146103885761018e565b8063441a3e701161014b5780635312ea8e116101255780635312ea8e1461029e578063630b5ba1146102bb578063715018a6146102c357806384e82a33146102cb5761018e565b8063441a3e701461025657806348cd4cb11461027957806351eb05a6146102815761018e565b8063081e3eda146101935780630ba84cd2146101ad5780631526fe27146101cc57806317caf6f1146102225780632dc714cf1461022a578063412753581461024e575b600080fd5b61019b6104c1565b60408051918252519081900360200190f35b6101ca600480360360208110156101c357600080fd5b50356104c7565b005b6101e9600480360360208110156101e257600080fd5b5035610565565b604080516001600160a01b039096168652602086019490945284840192909252606084015261ffff166080830152519081900360a00190f35b61019b6105b1565b6102326105b7565b604080516001600160a01b039092168252519081900360200190f35b6102326105c6565b6101ca6004803603604081101561026c57600080fd5b50803590602001356105d5565b61019b610802565b6101ca6004803603602081101561029757600080fd5b5035610808565b6101ca600480360360208110156102b457600080fd5b5035610a3e565b6101ca610ba6565b6101ca610bc9565b6101ca600480360360808110156102e157600080fd5b508035906001600160a01b036020820135169061ffff60408201351690606001351515610c6b565b6101ca6004803603602081101561031f57600080fd5b50356001600160a01b0316610ef7565b61019b610fa2565b6101ca6004803603602081101561034d57600080fd5b50356001600160a01b0316610fa7565b61023261103e565b61019b6004803603604081101561037b57600080fd5b508035906020013561104d565b6103b46004803603604081101561039e57600080fd5b50803590602001356001600160a01b0316611067565b6040805192835260208301919091528051918290030190f35b61019b61108b565b6103fb600480360360208110156103eb57600080fd5b50356001600160a01b0316611091565b604080519115158252519081900360200190f35b6102326110a6565b6101ca6004803603608081101561042d57600080fd5b5080359060208101359061ffff604082013516906060013515156110b5565b61019b6004803603604081101561046257600080fd5b50803590602001356001600160a01b0316611205565b6101ca6004803603604081101561048e57600080fd5b5080359060200135611363565b6101ca600480360360208110156104b157600080fd5b50356001600160a01b0316611614565b60065490565b6104cf61170c565b6000546001600160a01b0390811691161461051f576040805162461bcd60e51b81526020600482018190526024820152600080516020611ba8833981519152604482015290519081900360640190fd5b610527610ba6565b600481905560408051828152905133917fe2492e003bbe8afa53088b406f0c1cb5d9e280370fc72a74cf116ffd343c4053919081900360200190a250565b6006818154811061057257fe5b6000918252602090912060059091020180546001820154600283015460038401546004909401546001600160a01b0390931694509092909161ffff1685565b60085481565b6002546001600160a01b031681565b6005546001600160a01b031681565b6002600154141561062d576040805162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015290519081900360640190fd5b600260018190555060006006838154811061064457fe5b6000918252602080832086845260078252604080852033865290925292208054600590920290920192508311156106b7576040805162461bcd60e51b81526020600482015260126024820152711dda5d1a191c985dce881b9bdd0819dbdbd960721b604482015290519081900360640190fd5b6106c084610808565b60006106fa82600101546106f464e8d4a510006106ee8760030154876000015461171090919063ffffffff16565b90611769565b906117ab565b9050801561070c5761070c33826117ed565b83156107a057815461071e90856117ab565b825582546040805163a9059cbb60e01b81523360048201526024810187905290516001600160a01b039092169163a9059cbb916044808201926020929091908290030181600087803b15801561077357600080fd5b505af1158015610787573d6000803e3d6000fd5b505050506040513d602081101561079d57600080fd5b50505b600383015482546107bb9164e8d4a51000916106ee91611710565b6001830155604080518581529051869133917ff279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b5689181900360200190a3505060018055505050565b60095481565b60006006828154811061081757fe5b90600052602060002090600502019050806002015443116108385750610a3b565b8054604080516370a0823160e01b815230600482015290516000926001600160a01b0316916370a08231916024808301926020929190829003018186803b15801561088257600080fd5b505afa158015610896573d6000803e3d6000fd5b505050506040513d60208110156108ac57600080fd5b505190508015806108bf57506001820154155b156108d1575043600290910155610a3b565b60006108e183600201544361104d565b9050600061090e6008546106ee86600101546109086004548761171090919063ffffffff16565b90611710565b6002546003549192506001600160a01b03908116916340c10f199116610935846019611769565b6040518363ffffffff1660e01b815260040180836001600160a01b0316815260200182815260200192505050600060405180830381600087803b15801561097b57600080fd5b505af115801561098f573d6000803e3d6000fd5b5050600254604080516340c10f1960e01b81523060048201526024810186905290516001600160a01b0390921693506340c10f19925060448082019260009290919082900301818387803b1580156109e657600080fd5b505af11580156109fa573d6000803e3d6000fd5b50505050610a28610a1d846106ee64e8d4a510008561171090919063ffffffff16565b6003860154906119c0565b6003850155505043600290920191909155505b50565b60026001541415610a96576040805162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015290519081900360640190fd5b6002600181905550600060068281548110610aad57fe5b600091825260208083208584526007825260408085203380875290845281862080548782556001820188905560059096029093018054835163a9059cbb60e01b8152600481019390935260248301879052925190975092956001600160a01b03929092169363a9059cbb9360448084019492939192918390030190829087803b158015610b3957600080fd5b505af1158015610b4d573d6000803e3d6000fd5b505050506040513d6020811015610b6357600080fd5b5050604080518281529051859133917fbb757047c2b5f3974fe26b7c10f732e7bce710b0952a71082702781e62ae05959181900360200190a35050600180555050565b60065460005b81811015610bc557610bbd81610808565b600101610bac565b5050565b610bd161170c565b6000546001600160a01b03908116911614610c21576040805162461bcd60e51b81526020600482018190526024820152600080516020611ba8833981519152604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b610c7361170c565b6000546001600160a01b03908116911614610cc3576040805162461bcd60e51b81526020600482018190526024820152600080516020611ba8833981519152604482015290519081900360640190fd5b6001600160a01b0383166000908152600a6020526040902054839060ff1615610d33576040805162461bcd60e51b815260206004820152601960248201527f6e6f6e4475706c6963617465643a206475706c69636174656400000000000000604482015290519081900360640190fd5b6127108361ffff161115610d785760405162461bcd60e51b8152600401808060200182810382526025815260200180611b176025913960400191505060405180910390fd5b8115610d8657610d86610ba6565b60006009544311610d9957600954610d9b565b435b600854909150610dab90876119c0565b6008556001600160a01b039485166000818152600a602090815260408083208054600160ff199091168117909155815160a081018352948552918401998a5283019384526060830182815261ffff9788166080850190815260068054938401815590935292517ff652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f600590920291820180546001600160a01b031916919099161790975596517ff652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d4087015590517ff652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d41860155517ff652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d42850155505091517ff652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d43909101805461ffff191691909216179055565b6005546001600160a01b03163314610f56576040805162461bcd60e51b815260206004820152601860248201527f736574466565416464726573733a20464f5242494444454e0000000000000000604482015290519081900360640190fd5b600580546001600160a01b0319166001600160a01b03831690811790915560405133907fd44190acf9d04bdb5d3a1aafff7e6dee8b40b93dfb8c5d3f0eea4b9f4539c3f790600090a350565b600181565b6003546001600160a01b03163314610ff2576040805162461bcd60e51b81526020600482015260096024820152686465763a207775743f60b81b604482015290519081900360640190fd5b600380546001600160a01b0319166001600160a01b03831690811790915560405133907f618c54559e94f1499a808aad71ee8729f8e74e8c48e979616328ce493a1a52e790600090a350565b6000546001600160a01b031690565b600061105e600161090884866117ab565b90505b92915050565b60076020908152600092835260408084209091529082529020805460019091015482565b60045481565b600a6020526000908152604090205460ff1681565b6003546001600160a01b031681565b6110bd61170c565b6000546001600160a01b0390811691161461110d576040805162461bcd60e51b81526020600482018190526024820152600080516020611ba8833981519152604482015290519081900360640190fd5b6127108261ffff1611156111525760405162461bcd60e51b8152600401808060200182810382526025815260200180611b836025913960400191505060405180910390fd5b801561116057611160610ba6565b61119d836111976006878154811061117457fe5b9060005260206000209060050201600101546008546117ab90919063ffffffff16565b906119c0565b60088190555082600685815481106111b157fe5b90600052602060002090600502016001018190555081600685815481106111d457fe5b906000526020600020906005020160040160006101000a81548161ffff021916908361ffff16021790555050505050565b6000806006848154811061121557fe5b600091825260208083208784526007825260408085206001600160a01b0389811687529084528186206005959095029092016003810154815483516370a0823160e01b815230600482015293519298509596909590949316926370a082319260248082019391829003018186803b15801561128f57600080fd5b505afa1580156112a3573d6000803e3d6000fd5b505050506040513d60208110156112b957600080fd5b50516002850154909150431180156112d057508015155b156113305760006112e585600201544361104d565b9050600061130c6008546106ee88600101546109086004548761171090919063ffffffff16565b905061132b611324846106ee8464e8d4a51000611710565b85906119c0565b935050505b61135883600101546106f464e8d4a510006106ee86886000015461171090919063ffffffff16565b979650505050505050565b600260015414156113bb576040805162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015290519081900360640190fd5b60026001819055506000600683815481106113d257fe5b6000918252602080832086845260078252604080852033865290925292206005909102909101915061140384610808565b80541561144c57600061143882600101546106f464e8d4a510006106ee8760030154876000015461171090919063ffffffff16565b9050801561144a5761144a33826117ed565b505b82156115b3578154604080516323b872dd60e01b81523360048201523060248201526044810186905290516001600160a01b03909216916323b872dd916064808201926020929091908290030181600087803b1580156114ab57600080fd5b505af11580156114bf573d6000803e3d6000fd5b505050506040513d60208110156114d557600080fd5b5050600482015461ffff16156115a457600482015460009061150490612710906106ee90879061ffff16611710565b83546005546040805163a9059cbb60e01b81526001600160a01b03928316600482015260248101859052905193945091169163a9059cbb916044808201926020929091908290030181600087803b15801561155e57600080fd5b505af1158015611572573d6000803e3d6000fd5b505050506040513d602081101561158857600080fd5b5050815461159c9082906106f490876119c0565b8255506115b3565b80546115b090846119c0565b81555b600382015481546115ce9164e8d4a51000916106ee91611710565b6001820155604080518481529051859133917f90890809c654f11d6e72a28fa60149770a0d11ec6c92319d6ceb2bb0a4ea1a159181900360200190a35050600180555050565b61161c61170c565b6000546001600160a01b0390811691161461166c576040805162461bcd60e51b81526020600482018190526024820152600080516020611ba8833981519152604482015290519081900360640190fd5b6001600160a01b0381166116b15760405162461bcd60e51b8152600401808060200182810382526026815260200180611b3c6026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b3390565b60008261171f57506000611061565b8282028284828161172c57fe5b041461105e5760405162461bcd60e51b8152600401808060200182810382526021815260200180611b626021913960400191505060405180910390fd5b600061105e83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611a1a565b600061105e83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611abc565b600254604080516370a0823160e01b815230600482015290516000926001600160a01b0316916370a08231916024808301926020929190829003018186803b15801561183857600080fd5b505afa15801561184c573d6000803e3d6000fd5b505050506040513d602081101561186257600080fd5b505190506000818311156118f9576002546040805163a9059cbb60e01b81526001600160a01b038781166004830152602482018690529151919092169163a9059cbb9160448083019260209291908290030181600087803b1580156118c657600080fd5b505af11580156118da573d6000803e3d6000fd5b505050506040513d60208110156118f057600080fd5b5051905061197e565b6002546040805163a9059cbb60e01b81526001600160a01b038781166004830152602482018790529151919092169163a9059cbb9160448083019260209291908290030181600087803b15801561194f57600080fd5b505af1158015611963573d6000803e3d6000fd5b505050506040513d602081101561197957600080fd5b505190505b806119ba5760405162461bcd60e51b8152600401808060200182810382526021815260200180611bc86021913960400191505060405180910390fd5b50505050565b60008282018381101561105e576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b60008183611aa65760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611a6b578181015183820152602001611a53565b50505050905090810190601f168015611a985780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b506000838581611ab257fe5b0495945050505050565b60008184841115611b0e5760405162461bcd60e51b8152602060048201818152835160248401528351909283926044909101919085019080838360008315611a6b578181015183820152602001611a53565b50505090039056fe6164643a20696e76616c6964206465706f7369742066656520626173697320706f696e74734f776e61626c653a206e6577206f776e657220697320746865207a65726f2061646472657373536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f777365743a20696e76616c6964206465706f7369742066656520626173697320706f696e74734f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657273616665506570725472616e736665723a207472616e73666572206661696c6564a2646970667358221220be25859eafb44ccc75b0c56c6753d2c089e16a019dc1413d5df7662ca348df8f64736f6c634300060c003300000000000000000000000067ed0a0b32f239a3fcd1b8c21bef7d86578f106b000000000000000000000000c4310932da9d8970424514638f04ab5e5d3703d40000000000000000000000001827f7b5383a62b2b1a450ec876082f4e63a513b000000000000000000000000000000000000000000000000016345785d8a00000000000000000000000000000000000000000000000000000000000000680100

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

00000000000000000000000067ed0a0b32f239a3fcd1b8c21bef7d86578f106b000000000000000000000000c4310932da9d8970424514638f04ab5e5d3703d40000000000000000000000001827f7b5383a62b2b1a450ec876082f4e63a513b000000000000000000000000000000000000000000000000016345785d8a00000000000000000000000000000000000000000000000000000000000000680100

-----Decoded View---------------
Arg [0] : _pepr (address): 0x67ed0a0b32f239a3fcd1b8c21bef7d86578f106b
Arg [1] : _devaddr (address): 0xc4310932da9d8970424514638f04ab5e5d3703d4
Arg [2] : _feeAddress (address): 0x1827f7b5383a62b2b1a450ec876082f4e63a513b
Arg [3] : _peprPerBlock (uint256): 100000000000000000
Arg [4] : _startBlock (uint256): 6816000

-----Encoded View---------------
5 Constructor Arguments found :
Arg [0] : 00000000000000000000000067ed0a0b32f239a3fcd1b8c21bef7d86578f106b
Arg [1] : 000000000000000000000000c4310932da9d8970424514638f04ab5e5d3703d4
Arg [2] : 0000000000000000000000001827f7b5383a62b2b1a450ec876082f4e63a513b
Arg [3] : 000000000000000000000000000000000000000000000000016345785d8a0000
Arg [4] : 0000000000000000000000000000000000000000000000000000000000680100


Deployed ByteCode Sourcemap

735:10590:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3742:95;;;:::i;:::-;;;;;;;;;;;;;;;;11118:204;;;;;;;;;;;;;;;;-1:-1:-1;11118:204:0;;:::i;:::-;;2550:26;;;;;;;;;;;;;;;;-1:-1:-1;2550:26:0;;:::i;:::-;;;;-1:-1:-1;;;;;2550:26:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2791:34;;;:::i;2212:21::-;;;:::i;:::-;;;;-1:-1:-1;;;;;2212:21:0;;;;;;;;;;;;;;2489:25;;;:::i;8768:751::-;;;;;;;;;;;;;;;;-1:-1:-1;8768:751:0;;;;;;;:::i;2882:25::-;;;:::i;6778:805::-;;;;;;;;;;;;;;;;-1:-1:-1;6778:805:0;;:::i;9590:394::-;;;;;;;;;;;;;;;;-1:-1:-1;9590:394:0;;:::i;6522:180::-;;;:::i;19670:148:1:-;;;:::i;4112:710:0:-;;;;;;;;;;;;;;;;-1:-1:-1;4112:710:0;;;-1:-1:-1;;;;;4112:710:0;;;;;;;;;;;;;;;;;;;:::i;10767:220::-;;;;;;;;;;;;;;;;-1:-1:-1;10767:220:0;-1:-1:-1;;;;;10767:220:0;;:::i;2410:44::-;;;:::i;10579:180::-;;;;;;;;;;;;;;;;-1:-1:-1;10579:180:0;-1:-1:-1;;;;;10579:180:0;;:::i;19028:79:1:-;;;:::i;5473:143:0:-;;;;;;;;;;;;;;;;-1:-1:-1;5473:143:0;;;;;;;:::i;2632:64::-;;;;;;;;;;;;;;;;-1:-1:-1;2632:64:0;;;;;;-1:-1:-1;;;;;2632:64:0;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;2329:27;;;:::i;3845:44::-;;;;;;;;;;;;;;;;-1:-1:-1;3845:44:0;-1:-1:-1;;;;;3845:44:0;;:::i;:::-;;;;;;;;;;;;;;;;;;2261:22;;;:::i;4934:463::-;;;;;;;;;;;;;;;;-1:-1:-1;4934:463:0;;;;;;;;;;;;;;;;;;;;;:::i;5680:759::-;;;;;;;;;;;;;;;;-1:-1:-1;5680:759:0;;;;;;-1:-1:-1;;;;;5680:759:0;;:::i;7652:1064::-;;;;;;;;;;;;;;;;-1:-1:-1;7652:1064:0;;;;;;;:::i;19973:281:1:-;;;;;;;;;;;;;;;;-1:-1:-1;19973:281:1;-1:-1:-1;;;;;19973:281:1;;:::i;3742:95:0:-;3814:8;:15;3742:95;:::o;11118:204::-;19250:12:1;:10;:12::i;:::-;19240:6;;-1:-1:-1;;;;;19240:6:1;;;:22;;;19232:67;;;;;-1:-1:-1;;;19232:67:1;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;19232:67:1;;;;;;;;;;;;;;;11197:17:0::1;:15;:17::i;:::-;11225:12;:28:::0;;;11269:45:::1;::::0;;;;;;;11288:10:::1;::::0;11269:45:::1;::::0;;;;;::::1;::::0;;::::1;11118:204:::0;:::o;2550:26::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;2550:26:0;;;;-1:-1:-1;2550:26:0;;;;;;;:::o;2791:34::-;;;;:::o;2212:21::-;;;-1:-1:-1;;;;;2212:21:0;;:::o;2489:25::-;;;-1:-1:-1;;;;;2489:25:0;;:::o;8768:751::-;1721:1:2;2327:7;;:19;;2319:63;;;;;-1:-1:-1;;;2319:63:2;;;;;;;;;;;;;;;;;;;;;;;;;;;;1721:1;2460:7;:18;;;;8848:21:0::1;8872:8;8881:4;8872:14;;;;;;;;;::::0;;;::::1;::::0;;;8921;;;:8:::1;:14:::0;;;;;;8936:10:::1;8921:26:::0;;;;;;;8966:11;;8872:14:::1;::::0;;::::1;::::0;;::::1;::::0;-1:-1:-1;8966:22:0;-1:-1:-1;8966:22:0::1;8958:53;;;::::0;;-1:-1:-1;;;8958:53:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;-1:-1:-1;;;8958:53:0;;;;;;;;;;;;;::::1;;9022:16;9033:4;9022:10;:16::i;:::-;9049:15;9067:68;9119:4;:15;;;9067:47;9109:4;9067:37;9083:4;:20;;;9067:4;:11;;;:15;;:37;;;;:::i;:::-;:41:::0;::::1;:47::i;:::-;:51:::0;::::1;:68::i;:::-;9049:86:::0;-1:-1:-1;9150:11:0;;9146:81:::1;;9178:37;9195:10;9207:7;9178:16;:37::i;:::-;9241:11:::0;;9237:148:::1;;9283:11:::0;;:24:::1;::::0;9299:7;9283:15:::1;:24::i;:::-;9269:38:::0;;9322:12;;:51:::1;::::0;;-1:-1:-1;;;9322:51:0;;9352:10:::1;9322:51;::::0;::::1;::::0;;;;;;;;;-1:-1:-1;;;;;9322:12:0;;::::1;::::0;:21:::1;::::0;:51;;;;;::::1;::::0;;;;;;;;;9269:11:::1;9322:12:::0;:51;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;;9237:148:0::1;9429:20;::::0;::::1;::::0;9413:11;;:47:::1;::::0;9455:4:::1;::::0;9413:37:::1;::::0;:15:::1;:37::i;:47::-;9395:15;::::0;::::1;:65:::0;9476:35:::1;::::0;;;;;;;9497:4;;9485:10:::1;::::0;9476:35:::1;::::0;;;;::::1;::::0;;::::1;-1:-1:-1::0;;1677:1:2;2639:22;;-1:-1:-1;;;8768:751:0:o;2882:25::-;;;;:::o;6778:805::-;6830:21;6854:8;6863:4;6854:14;;;;;;;;;;;;;;;;;;6830:38;;6899:4;:20;;;6883:12;:36;6879:75;;6936:7;;;6879:75;6983:12;;:37;;;-1:-1:-1;;;6983:37:0;;7014:4;6983:37;;;;;;6964:16;;-1:-1:-1;;;;;6983:12:0;;:22;;:37;;;;;;;;;;;;;;:12;:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;6983:37:0;;-1:-1:-1;7035:13:0;;;:37;;-1:-1:-1;7052:15:0;;;;:20;7035:37;7031:126;;;-1:-1:-1;7112:12:0;7089:20;;;;:35;7139:7;;7031:126;7167:18;7188:49;7202:4;:20;;;7224:12;7188:13;:49::i;:::-;7167:70;;7248:18;7269:70;7323:15;;7269:49;7302:4;:15;;;7269:28;7284:12;;7269:10;:14;;:28;;;;:::i;:::-;:32;;:49::i;:70::-;7350:4;;7360:7;;7248:91;;-1:-1:-1;;;;;;7350:4:0;;;;:9;;7360:7;7369:18;7248:91;7384:2;7369:14;:18::i;:::-;7350:38;;;;;;;;;;;;;-1:-1:-1;;;;;7350:38:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;7399:4:0;;:36;;;-1:-1:-1;;;7399:36:0;;7417:4;7399:36;;;;;;;;;;;;-1:-1:-1;;;;;7399:4:0;;;;-1:-1:-1;7399:9:0;;-1:-1:-1;7399:36:0;;;;;:4;;:36;;;;;;;;:4;;:36;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7469:60;7494:34;7519:8;7494:20;7509:4;7494:10;:14;;:20;;;;:::i;:34::-;7469:20;;;;;:24;:60::i;:::-;7446:20;;;:83;-1:-1:-1;;7563:12:0;7540:20;;;;:35;;;;-1:-1:-1;6778:805:0;;:::o;9590:394::-;1721:1:2;2327:7;;:19;;2319:63;;;;;-1:-1:-1;;;2319:63:2;;;;;;;;;;;;;;;;;;;;;;;;;;;;1721:1;2460:7;:18;;;;9662:21:0::1;9686:8;9695:4;9686:14;;;;;;;;;::::0;;;::::1;::::0;;;9735;;;:8:::1;:14:::0;;;;;;9750:10:::1;9735:26:::0;;;;;;;;;9789:11;;9811:15;;;-1:-1:-1;9837:15:0;::::1;:19:::0;;;9686:14:::1;::::0;;::::1;::::0;;::::1;9867:12:::0;;:50;;-1:-1:-1;;;9867:50:0;;::::1;::::0;::::1;::::0;;;;;;;;;;;;9686:14;;-1:-1:-1;9735:26:0;;-1:-1:-1;;;;;9867:12:0;;;::::1;::::0;:21:::1;::::0;:50;;;;;9686:14;;9867:50;;;;;;;;;;:12;:50;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;;9933:43:0::1;::::0;;;;;;;9963:4;;9951:10:::1;::::0;9933:43:::1;::::0;;;;9867:50:::1;9933:43:::0;;::::1;-1:-1:-1::0;;1677:1:2;2639:22;;-1:-1:-1;;9590:394:0:o;6522:180::-;6584:8;:15;6567:14;6610:85;6638:6;6632:3;:12;6610:85;;;6668:15;6679:3;6668:10;:15::i;:::-;6646:5;;6610:85;;;;6522:180;:::o;19670:148:1:-;19250:12;:10;:12::i;:::-;19240:6;;-1:-1:-1;;;;;19240:6:1;;;:22;;;19232:67;;;;;-1:-1:-1;;;19232:67:1;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;19232:67:1;;;;;;;;;;;;;;;19777:1:::1;19761:6:::0;;19740:40:::1;::::0;-1:-1:-1;;;;;19761:6:1;;::::1;::::0;19740:40:::1;::::0;19777:1;;19740:40:::1;19808:1;19791:19:::0;;-1:-1:-1;;;;;;19791:19:1::1;::::0;;19670:148::o;4112:710:0:-;19250:12:1;:10;:12::i;:::-;19240:6;;-1:-1:-1;;;;;19240:6:1;;;:22;;;19232:67;;;;;-1:-1:-1;;;19232:67:1;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;19232:67:1;;;;;;;;;;;;;;;-1:-1:-1;;;;;3955:23:0;::::1;;::::0;;;:13:::1;:23;::::0;;;;;4234:8;;3955:23:::1;;:32;3947:70;;;::::0;;-1:-1:-1;;;3947:70:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;::::1;::::0;;;;;;;;;;;;;::::1;;4280:5:::2;4263:13;:22;;;;4255:72;;;;-1:-1:-1::0;;;4255:72:0::2;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4342:11;4338:61;;;4370:17;:15;:17::i;:::-;4409:23;4450:10;;4435:12;:25;:53;;4478:10;;4435:53;;;4463:12;4435:53;4517:15;::::0;4409:79;;-1:-1:-1;4517:32:0::2;::::0;4537:11;4517:19:::2;:32::i;:::-;4499:15;:50:::0;-1:-1:-1;;;;;4560:23:0;;::::2;;::::0;;;:13:::2;:23;::::0;;;;;;;:30;;4586:4:::2;-1:-1:-1::0;;4560:30:0;;::::2;::::0;::::2;::::0;;;4615:198;;::::2;::::0;::::2;::::0;;;;;;;::::2;::::0;;;;;;;;;;;;;;::::2;::::0;;::::2;::::0;;;;;;4601:8:::2;:213:::0;;;;::::2;::::0;;;;;;;;::::2;::::0;;::::2;::::0;;::::2;::::0;;-1:-1:-1;;;;;;4601:213:0::2;::::0;;;::::2;;::::0;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;4601:213:0;;;;;;;;-1:-1:-1;;4601:213:0::2;::::0;;;::::2;;::::0;;4112:710::o;10767:220::-;10851:10;;-1:-1:-1;;;;;10851:10:0;10837;:24;10829:61;;;;;-1:-1:-1;;;10829:61:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;10901:10;:24;;-1:-1:-1;;;;;;10901:24:0;-1:-1:-1;;;;;10901:24:0;;;;;;;;10941:38;;10955:10;;10941:38;;-1:-1:-1;;10941:38:0;10767:220;:::o;2410:44::-;2453:1;2410:44;:::o;10579:180::-;10650:7;;-1:-1:-1;;;;;10650:7:0;10636:10;:21;10628:43;;;;;-1:-1:-1;;;10628:43:0;;;;;;;;;;;;-1:-1:-1;;;10628:43:0;;;;;;;;;;;;;;;10682:7;:18;;-1:-1:-1;;;;;;10682:18:0;-1:-1:-1;;;;;10682:18:0;;;;;;;;10716:35;;10730:10;;10716:35;;-1:-1:-1;;10716:35:0;10579:180;:::o;19028:79:1:-;19066:7;19093:6;-1:-1:-1;;;;;19093:6:1;19028:79;:::o;5473:143:0:-;5545:7;5572:36;2453:1;5572:14;:3;5580:5;5572:7;:14::i;:36::-;5565:43;;5473:143;;;;;:::o;2632:64::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;2329:27::-;;;;:::o;3845:44::-;;;;;;;;;;;;;;;:::o;2261:22::-;;;-1:-1:-1;;;;;2261:22:0;;:::o;4934:463::-;19250:12:1;:10;:12::i;:::-;19240:6;;-1:-1:-1;;;;;19240:6:1;;;:22;;;19232:67;;;;;-1:-1:-1;;;19232:67:1;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;19232:67:1;;;;;;;;;;;;;;;5075:5:0::1;5058:13;:22;;;;5050:72;;;;-1:-1:-1::0;;;5050:72:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5137:11;5133:61;;;5165:17;:15;:17::i;:::-;5222:63;5273:11;5222:46;5242:8;5251:4;5242:14;;;;;;;;;;;;;;;;;;:25;;;5222:15;;:19;;:46;;;;:::i;:::-;:50:::0;::::1;:63::i;:::-;5204:15;:81;;;;5324:11;5296:8;5305:4;5296:14;;;;;;;;;;;;;;;;;;:25;;:39;;;;5376:13;5346:8;5355:4;5346:14;;;;;;;;;;;;;;;;;;:27;;;:43;;;;;;;;;;;;;;;;;;4934:463:::0;;;;:::o;5680:759::-;5753:7;5773:21;5797:8;5806:4;5797:14;;;;;;;;;;;;;;;;5846;;;:8;:14;;;;;;-1:-1:-1;;;;;5846:21:0;;;;;;;;;;;5797:14;;;;;;;;5904:20;;;;5954:12;;:37;;-1:-1:-1;;;5954:37:0;;5985:4;5954:37;;;;;;5797:14;;-1:-1:-1;5846:21:0;;5904:20;;5797:14;;5954:12;;;:22;;:37;;;;;;;;;;;:12;:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;5954:37:0;6021:20;;;;5954:37;;-1:-1:-1;6006:12:0;:35;:52;;;;-1:-1:-1;6045:13:0;;;6006:52;6002:349;;;6075:18;6096:49;6110:4;:20;;;6132:12;6096:13;:49::i;:::-;6075:70;;6160:18;6181:70;6235:15;;6181:49;6214:4;:15;;;6181:28;6196:12;;6181:10;:14;;:28;;;;:::i;:70::-;6160:91;-1:-1:-1;6284:55:0;6304:34;6329:8;6304:20;6160:91;6319:4;6304:14;:20::i;:34::-;6284:15;;:19;:55::i;:::-;6266:73;;6002:349;;;6368:63;6415:4;:15;;;6368:42;6405:4;6368:32;6384:15;6368:4;:11;;;:15;;:32;;;;:::i;:63::-;6361:70;5680:759;-1:-1:-1;;;;;;;5680:759:0:o;7652:1064::-;1721:1:2;2327:7;;:19;;2319:63;;;;;-1:-1:-1;;;2319:63:2;;;;;;;;;;;;;;;;;;;;;;;;;;;;1721:1;2460:7;:18;;;;7731:21:0::1;7755:8;7764:4;7755:14;;;;;;;;;::::0;;;::::1;::::0;;;7804;;;:8:::1;:14:::0;;;;;;7819:10:::1;7804:26:::0;;;;;;;7755:14:::1;::::0;;::::1;::::0;;::::1;::::0;-1:-1:-1;7841:16:0::1;7813:4:::0;7841:10:::1;:16::i;:::-;7872:11:::0;;:15;7868:237:::1;;7904:15;7922:68;7974:4;:15;;;7922:47;7964:4;7922:37;7938:4;:20;;;7922:4;:11;;;:15;;:37;;;;:::i;:68::-;7904:86:::0;-1:-1:-1;8009:11:0;;8005:89:::1;;8041:37;8058:10;8070:7;8041:16;:37::i;:::-;7868:237;;8119:11:::0;;8115:468:::1;;8147:12:::0;;:70:::1;::::0;;-1:-1:-1;;;8147:70:0;;8181:10:::1;8147:70;::::0;::::1;::::0;8202:4:::1;8147:70:::0;;;;;;;;;;;;-1:-1:-1;;;;;8147:12:0;;::::1;::::0;:25:::1;::::0;:70;;;;;::::1;::::0;;;;;;;;;:12:::1;::::0;:70;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;;8236:17:0::1;::::0;::::1;::::0;::::1;;:21:::0;8232:340:::1;;8311:17;::::0;::::1;::::0;8278:18:::1;::::0;8299:41:::1;::::0;8334:5:::1;::::0;8299:30:::1;::::0;:7;;8311:17:::1;;8299:11;:30::i;:41::-;8359:12:::0;;8381:10:::1;::::0;8359:45:::1;::::0;;-1:-1:-1;;;8359:45:0;;-1:-1:-1;;;;;8381:10:0;;::::1;8359:45;::::0;::::1;::::0;;;;;;;;;8278:62;;-1:-1:-1;8359:12:0;::::1;::::0;:21:::1;::::0;:45;;;;;::::1;::::0;;;;;;;;;:12:::1;::::0;:45;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;;8437:11:0;;:40:::1;::::0;8466:10;;8437:24:::1;::::0;8453:7;8437:15:::1;:24::i;:40::-;8423:54:::0;;-1:-1:-1;8232:340:0::1;;;8532:11:::0;;:24:::1;::::0;8548:7;8532:15:::1;:24::i;:::-;8518:38:::0;;8232:340:::1;8627:20;::::0;::::1;::::0;8611:11;;:47:::1;::::0;8653:4:::1;::::0;8611:37:::1;::::0;:15:::1;:37::i;:47::-;8593:15;::::0;::::1;:65:::0;8674:34:::1;::::0;;;;;;;8694:4;;8682:10:::1;::::0;8674:34:::1;::::0;;;;::::1;::::0;;::::1;-1:-1:-1::0;;1677:1:2;2639:22;;-1:-1:-1;;7652:1064:0:o;19973:281:1:-;19250:12;:10;:12::i;:::-;19240:6;;-1:-1:-1;;;;;19240:6:1;;;:22;;;19232:67;;;;;-1:-1:-1;;;19232:67:1;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;19232:67:1;;;;;;;;;;;;;;;-1:-1:-1;;;;;20076:22:1;::::1;20054:110;;;;-1:-1:-1::0;;;20054:110:1::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20201:6;::::0;;20180:38:::1;::::0;-1:-1:-1;;;;;20180:38:1;;::::1;::::0;20201:6;::::1;::::0;20180:38:::1;::::0;::::1;20229:6;:17:::0;;-1:-1:-1;;;;;;20229:17:1::1;-1:-1:-1::0;;;;;20229:17:1;;;::::1;::::0;;;::::1;::::0;;19973:281::o;266:106::-;354:10;266:106;:::o;2271:471::-;2329:7;2574:6;2570:47;;-1:-1:-1;2604:1:1;2597:8;;2570:47;2641:5;;;2645:1;2641;:5;:1;2665:5;;;;;:10;2657:56;;;;-1:-1:-1;;;2657:56:1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3218:132;3276:7;3303:39;3307:1;3310;3303:39;;;;;;;;;;;;;;;;;:3;:39::i;1347:136::-;1405:7;1432:43;1436:1;1439;1432:43;;;;;;;;;;;;;;;;;:3;:43::i;10098:425:0:-;10192:4;;:29;;;-1:-1:-1;;;10192:29:0;;10215:4;10192:29;;;;;;10174:15;;-1:-1:-1;;;;;10192:4:0;;:14;;:29;;;;;;;;;;;;;;:4;:29;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;10192:29:0;;-1:-1:-1;10232:20:0;10275:17;;;10271:173;;;10327:4;;:27;;;-1:-1:-1;;;10327:27:0;;-1:-1:-1;;;;;10327:27:0;;;;;;;;;;;;;;;:4;;;;;:13;;:27;;;;;;;;;;;;;;:4;;:27;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;10327:27:0;;-1:-1:-1;10271:173:0;;;10405:4;;:27;;;-1:-1:-1;;;10405:27:0;;-1:-1:-1;;;;;10405:27:0;;;;;;;;;;;;;;;:4;;;;;:13;;:27;;;;;;;;;;;;;;:4;;:27;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;10405:27:0;;-1:-1:-1;10271:173:0;10462:15;10454:61;;;;-1:-1:-1;;;10454:61:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10098:425;;;;:::o;883:181:1:-;941:7;973:5;;;997:6;;;;989:46;;;;;-1:-1:-1;;;989:46:1;;;;;;;;;;;;;;;;;;;;;;;;;;;3846:312;3966:7;4001:12;3994:5;3986:28;;;;-1:-1:-1;;;3986:28:1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4025:9;4041:1;4037;:5;;;;;;;3846:312;-1:-1:-1;;;;;3846:312:1:o;1786:226::-;1906:7;1942:12;1934:6;;;;1926:29;;;;-1:-1:-1;;;1926:29:1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;1978:5:1;;;1786:226::o

Swarm Source

ipfs://be25859eafb44ccc75b0c56c6753d2c089e16a019dc1413d5df7662ca348df8f
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.