ETH Price: $1,970.91 (+1.08%)

Contract

0x1b1Eb8CCC251deb3abD971B12bD8f34ac2A9a608
Transaction Hash
Block
From
To
Deposit4273922362026-02-01 5:20:4211 days ago1769923242IN
Poison Finance: Master Castle
0 ETH0.000002310.02001
Deposit4273921212026-02-01 5:20:1311 days ago1769923213IN
Poison Finance: Master Castle
0 ETH0.000002650.02002
Emergency Withdr...4268824092026-01-30 18:04:4712 days ago1769796287IN
Poison Finance: Master Castle
0 ETH0.000000950.020024
Deposit4263898032026-01-29 8:01:2713 days ago1769673687IN
Poison Finance: Master Castle
0 ETH0.000002910.020014
Deposit4263796742026-01-29 7:19:1714 days ago1769671157IN
Poison Finance: Master Castle
0 ETH0.00000240.02
Deposit4263791042026-01-29 7:16:5514 days ago1769671015IN
Poison Finance: Master Castle
0 ETH0.000002310.020046
Deposit4263787182026-01-29 7:15:1914 days ago1769670919IN
Poison Finance: Master Castle
0 ETH0.000002320.020114
Deposit4263783492026-01-29 7:13:4614 days ago1769670826IN
Poison Finance: Master Castle
0 ETH0.000002310.020004
Deposit4263779552026-01-29 7:12:0914 days ago1769670729IN
Poison Finance: Master Castle
0 ETH0.000002330.020236
Deposit4263777772026-01-29 7:11:2414 days ago1769670684IN
Poison Finance: Master Castle
0 ETH0.000002310.020002
Deposit4263776042026-01-29 7:10:4114 days ago1769670641IN
Poison Finance: Master Castle
0 ETH0.000002320.020092
Emergency Withdr...4250385312026-01-25 10:22:4617 days ago1769336566IN
Poison Finance: Master Castle
0 ETH0.000001260.02003
Deposit4250382562026-01-25 10:21:3717 days ago1769336497IN
Poison Finance: Master Castle
0 ETH0.000002650.020024
Deposit4219423112026-01-16 11:14:3726 days ago1768562077IN
Poison Finance: Master Castle
0 ETH0.00000240.020052
Deposit4219422532026-01-16 11:14:2226 days ago1768562062IN
Poison Finance: Master Castle
0 ETH0.00000240.020064
Deposit4219421992026-01-16 11:14:0826 days ago1768562048IN
Poison Finance: Master Castle
0 ETH0.00000240.020078
Deposit4219421462026-01-16 11:13:5526 days ago1768562035IN
Poison Finance: Master Castle
0 ETH0.000002390.020012
Deposit4206617152026-01-12 18:19:4630 days ago1768241986IN
Poison Finance: Master Castle
0 ETH0.000002410.020118
Deposit4206613662026-01-12 18:18:1930 days ago1768241899IN
Poison Finance: Master Castle
0 ETH0.000002310.02001
Deposit4206612492026-01-12 18:17:5230 days ago1768241872IN
Poison Finance: Master Castle
0 ETH0.000002310.02
Deposit4206607412026-01-12 18:15:4530 days ago1768241745IN
Poison Finance: Master Castle
0 ETH0.000002330.020216
Deposit4206605722026-01-12 18:15:0230 days ago1768241702IN
Poison Finance: Master Castle
0 ETH0.000002310.02007
Deposit4206603532026-01-12 18:14:0730 days ago1768241647IN
Poison Finance: Master Castle
0 ETH0.000002330.020214
Deposit4206600052026-01-12 18:12:4030 days ago1768241560IN
Poison Finance: Master Castle
0 ETH0.000002330.020166
Deposit4198330762026-01-10 8:44:2032 days ago1768034660IN
Poison Finance: Master Castle
0 ETH0.000002390.020004
View all transactions

Latest 25 internal transactions (View All)

Parent Transaction Hash Block From To
720792542023-03-21 9:48:101058 days ago1679392090
Poison Finance: Master Castle
0 ETH
720792542023-03-21 9:48:101058 days ago1679392090
Poison Finance: Master Castle
0 ETH
720792542023-03-21 9:48:101058 days ago1679392090
Poison Finance: Master Castle
0 ETH
720792542023-03-21 9:48:101058 days ago1679392090
Poison Finance: Master Castle
0 ETH
720792542023-03-21 9:48:101058 days ago1679392090
Poison Finance: Master Castle
0 ETH
720710422023-03-21 9:14:221058 days ago1679390062
Poison Finance: Master Castle
0 ETH
720710422023-03-21 9:14:221058 days ago1679390062
Poison Finance: Master Castle
0 ETH
720710422023-03-21 9:14:221058 days ago1679390062
Poison Finance: Master Castle
0 ETH
720710422023-03-21 9:14:221058 days ago1679390062
Poison Finance: Master Castle
0 ETH
720496212023-03-21 7:46:421058 days ago1679384802
Poison Finance: Master Castle
0 ETH
720496212023-03-21 7:46:421058 days ago1679384802
Poison Finance: Master Castle
0 ETH
720496212023-03-21 7:46:421058 days ago1679384802
Poison Finance: Master Castle
0 ETH
720496212023-03-21 7:46:421058 days ago1679384802
Poison Finance: Master Castle
0 ETH
720460252023-03-21 7:31:531059 days ago1679383913
Poison Finance: Master Castle
0 ETH
720460252023-03-21 7:31:531059 days ago1679383913
Poison Finance: Master Castle
0 ETH
720460252023-03-21 7:31:531059 days ago1679383913
Poison Finance: Master Castle
0 ETH
720460252023-03-21 7:31:531059 days ago1679383913
Poison Finance: Master Castle
0 ETH
720219612023-03-21 5:53:091059 days ago1679377989
Poison Finance: Master Castle
0 ETH
720219612023-03-21 5:53:091059 days ago1679377989
Poison Finance: Master Castle
0 ETH
720219612023-03-21 5:53:091059 days ago1679377989
Poison Finance: Master Castle
0 ETH
720219612023-03-21 5:53:091059 days ago1679377989
Poison Finance: Master Castle
0 ETH
720106142023-03-21 5:06:161059 days ago1679375176
Poison Finance: Master Castle
0 ETH
720106142023-03-21 5:06:161059 days ago1679375176
Poison Finance: Master Castle
0 ETH
720106142023-03-21 5:06:161059 days ago1679375176
Poison Finance: Master Castle
0 ETH
720106142023-03-21 5:06:161059 days ago1679375176
Poison Finance: Master Castle
0 ETH
View All Internal Transactions

Cross-Chain Transactions
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
MasterCastle

Compiler Version
v0.8.7+commit.e28d00a7

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Arbiscan.io on 2023-01-01
*/

// @@@@@@@    @@@@@@   @@@   @@@@@@    @@@@@@   @@@  @@@  
// @@@@@@@@  @@@@@@@@  @@@  @@@@@@@   @@@@@@@@  @@@@ @@@  
// @@!  @@@  @@!  @@@  @@!  !@@       @@!  @@@  @@!@!@@@  
// !@!  @!@  !@!  @!@  !@!  !@!       !@!  @!@  !@!!@!@!  
// @!@@!@!   @!@  !@!  !!@  !!@@!!    @!@  !@!  @!@ !!@!  
// !!@!!!    !@!  !!!  !!!   !!@!!!   !@!  !!!  !@!  !!!  
// !!:       !!:  !!!  !!:       !:!  !!:  !!!  !!:  !!!  
// :!:       :!:  !:!  :!:      !:!   :!:  !:!  :!:  !:!  
//  ::       ::::: ::   ::  :::: ::   ::::: ::   ::   ::  
//  :         : :  :   :    :: : :     : :  :   ::    :   
//                      https://Poison.Finance    

pragma solidity ^0.8.0;

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

    function balanceOf(address account) external view returns (uint256);

    function transfer(address recipient, uint256 amount)
        external
        returns (bool);

    function allowance(address owner, address spender)
        external
        view
        returns (uint256);

    function approve(address spender, uint256 amount) external returns (bool);

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    event Transfer(address indexed from, address indexed to, uint256 value);

    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
}

interface PoisonToken is IERC20 {
    function mint(address _to, uint256 _amount) external;
}

// File: @openzeppelin/contracts/utils/Address.sol

// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)

pragma solidity ^0.8.1;

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     *
     * [IMPORTANT]
     * ====
     * You shouldn't rely on `isContract` to protect against flash loan attacks!
     *
     * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets
     * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract
     * constructor.
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize/address.code.length, which returns 0
        // for contracts in construction, since the code is only stored at the end
        // of the constructor execution.

        return account.code.length > 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"
        );

        (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
            functionCallWithValue(
                target,
                data,
                0,
                "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"
        );
        (bool success, bytes memory returndata) = target.call{value: value}(
            data
        );
        return
            verifyCallResultFromTarget(
                target,
                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) {
        (bool success, bytes memory returndata) = target.staticcall(data);
        return
            verifyCallResultFromTarget(
                target,
                success,
                returndata,
                errorMessage
            );
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    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.4._
     */
    function functionDelegateCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return
            verifyCallResultFromTarget(
                target,
                success,
                returndata,
                errorMessage
            );
    }

    /**
     * @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling
     * the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract.
     *
     * _Available since v4.8._
     */
    function verifyCallResultFromTarget(
        address target,
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        if (success) {
            if (returndata.length == 0) {
                // only check isContract if the call was successful and the return data is empty
                // otherwise we already know that it was a contract
                require(isContract(target), "Address: call to non-contract");
            }
            return returndata;
        } else {
            _revert(returndata, errorMessage);
        }
    }

    /**
     * @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the
     * revert reason or using the provided one.
     *
     * _Available since v4.3._
     */
    function verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal pure returns (bytes memory) {
        if (success) {
            return returndata;
        } else {
            _revert(returndata, errorMessage);
        }
    }

    function _revert(bytes memory returndata, string memory errorMessage)
        private
        pure
    {
        // 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
            /// @solidity memory-safe-assembly
            assembly {
                let returndata_size := mload(returndata)
                revert(add(32, returndata), returndata_size)
            }
        } else {
            revert(errorMessage);
        }
    }
}

pragma solidity ^0.8.0;

/**
 * @title SafeERC20
 * @dev Wrappers around ERC20 operations that throw on failure (when the token
 * contract returns false). Tokens that return no value (and instead revert or
 * throw on failure) are also supported, non-reverting calls are assumed to be
 * successful.
 * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
library SafeERC20 {
    using Address for address;

    function safeTransfer(
        IERC20 token,
        address to,
        uint256 value
    ) internal {
        _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'
        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) + value;
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(
                token.approve.selector,
                spender,
                newAllowance
            )
        );
    }

    function safeDecreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        unchecked {
            uint256 oldAllowance = token.allowance(address(this), spender);
            require(
                oldAllowance >= value,
                "SafeERC20: decreased allowance below zero"
            );
            uint256 newAllowance = oldAllowance - value;
            _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
            require(
                abi.decode(returndata, (bool)),
                "SafeERC20: ERC20 operation did not succeed"
            );
        }
    }
}

// File: @openzeppelin/contracts/GSN/Context.sol

pragma solidity ^0.8.0;

/*
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with GSN meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address payable) {
        return payable(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;
    }
}

// File: @openzeppelin/contracts/access/Ownable.sol

pragma solidity ^0.8.0;

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(
        address indexed previousOwner,
        address indexed newOwner
    );

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        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;
    }
}

// File: @openzeppelin/contracts/token/ERC20/ERC20.sol

pragma solidity ^0.8.4;

// MasterGarden is the master of Peaches.

// Ownership will be transferred to a governance smart contract once Peaches is sufficiently
// distributed and the community can show to govern itself.

pragma solidity ^0.8.4;

// MasterCastle is the master of Poison.

contract MasterCastle is Ownable {
    using SafeERC20 for IERC20;
    using SafeERC20 for PoisonToken;

    // Info of each user.
    struct UserInfo {
        uint256 amount; // How many LP tokens the user has provided.
        uint256 rewardDebt; // Reward debt. See explanation below.
    }

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

    // The Poison TOKEN!
    PoisonToken public Poison;

    address public collector;
    // Block number when bonus Poison period ends.
    uint256 public bonusEndBlock;
    // Poison tokens created per block.
    uint256 public PoisonPerBlock;
    // Bonus muliplier for early Poison makers.
    uint256 public constant BONUS_MULTIPLIER = 3;
    uint256 public constant POISON_CAP = 4203333333333333333333333;
    uint256 public poisonMinted;
    uint256 public totalBoxes = 0;

    // Info of each pool.
    PoolInfo[] public poolInfo;
    // Info of each Lockbox.

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

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

    constructor(
        PoisonToken _Poison,
        uint256 _PoisonPerBlock,
        uint256 _bonusEndBlock
    ) {
        Poison = _Poison;
        PoisonPerBlock = _PoisonPerBlock;
        bonusEndBlock = _bonusEndBlock;
        startBlock = block.number;
        startTime = block.timestamp;
    }

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

    // Add a new lp to the pool. Can only be called by the owner.
    // DO NOT add the same LP token more than once. Rewards will be messed up if you do.
    function addPool(
        uint256 _allocPoint,
        IERC20 _lpToken,
        bool _withUpdate
    ) external onlyOwner {
        if (_withUpdate) {
            massUpdatePools();
        }

        totalAllocPoint = totalAllocPoint + _allocPoint;
        poolInfo.push(
            PoolInfo({
                lpToken: _lpToken,
                allocPoint: _allocPoint,
                lastRewardBlock: block.number,
                accPoisonPerShare: 0
            })
        );
    }

    // Update the given pool's Poison allocation point. Can only be called by the owner.
    function setPool(
        uint256 _pid,
        uint256 _allocPoint,
        bool _withUpdate
    ) external onlyOwner {
        if (_withUpdate) {
            massUpdatePools();
        }
        totalAllocPoint =
            totalAllocPoint -
            poolInfo[_pid].allocPoint +
            _allocPoint;
        poolInfo[_pid].allocPoint = _allocPoint;
    }

    // Return reward multiplier over the given _from to _to block.
    function getMultiplier(uint256 _from, uint256 _to)
        public
        view
        returns (uint256)
    {
        if (_to <= bonusEndBlock) {
            return (_to - _from) * BONUS_MULTIPLIER;
        } else if (_from >= bonusEndBlock) {
            return _to - _from;
        } else {
            return
                (bonusEndBlock - _from) *
                BONUS_MULTIPLIER +
                (_to - bonusEndBlock);
        }
    }

    // Update reward vairables 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.lastRewardBlock = block.number;
            return;
        }

        uint256 PoisonReward = (getMultiplier(
            pool.lastRewardBlock,
            block.number
        ) *
            PoisonPerBlock *
            pool.allocPoint) / totalAllocPoint;

        pool.accPoisonPerShare =
            pool.accPoisonPerShare +
            ((PoisonReward * 1e12) / lpSupply);
        pool.lastRewardBlock = block.number;

        if (poisonMinted <= POISON_CAP) {
            poisonMinted = poisonMinted + PoisonReward;
            Poison.mint(address(this), PoisonReward);
        }
    }

    // Deposit LP tokens to MasterCastle for Poison allocation.
    function deposit(uint256 _pid, uint256 _amount) external {
        PoolInfo storage pool = poolInfo[_pid];
        UserInfo storage user = userInfo[_pid][msg.sender];

        require(
            _amount <= pool.lpToken.allowance(msg.sender, address(this)),
            "Allowance not high enough"
        );
        pool.lpToken.safeTransferFrom(msg.sender, address(this), _amount);

        updatePool(_pid);

        uint256 pending = (user.amount * pool.accPoisonPerShare) /
            1e12 -
            user.rewardDebt;
        user.amount = user.amount + _amount;

        if (block.timestamp > (startTime + 40 days) && pending > 0) {
            user.rewardDebt = (user.amount * pool.accPoisonPerShare) / 1e12;
            Poison.safeTransfer(msg.sender, pending);
        } else {
            user.rewardDebt =
                (user.amount * pool.accPoisonPerShare) /
                1e12 -
                pending;
        }

        emit Deposit(msg.sender, _pid, _amount);
    }

    // Withdraw LP tokens from MasterCastle.
    function withdraw(uint256 _pid, uint256 _amount) external {
        require(block.timestamp > (startTime + 40 days), "Too early");

        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 * pool.accPoisonPerShare) /
            1e12 -
            user.rewardDebt;

        user.amount = user.amount - _amount;
        user.rewardDebt = (user.amount * pool.accPoisonPerShare) / 1e12;

        Poison.safeTransfer(msg.sender, pending);
        pool.lpToken.safeTransfer(msg.sender, _amount);

        emit Withdraw(msg.sender, _pid, _amount);
    }

    // Withdraw without caring about rewards. EMERGENCY ONLY.
    function emergencyWithdraw(uint256 _pid) external {
        PoolInfo storage pool = poolInfo[_pid];
        UserInfo storage user = userInfo[_pid][msg.sender];

        uint256 amount = user.amount;
        uint256 reward = user.rewardDebt;

        user.amount = 0;
        user.rewardDebt = 0;

        pool.lpToken.safeTransfer(msg.sender, amount);
        emit EmergencyWithdraw(msg.sender, _pid, reward);
    }
}

Contract Security Audit

Contract ABI

API
[{"inputs":[{"internalType":"contract PoisonToken","name":"_Poison","type":"address"},{"internalType":"uint256","name":"_PoisonPerBlock","type":"uint256"},{"internalType":"uint256","name":"_bonusEndBlock","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":"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":[],"name":"POISON_CAP","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"Poison","outputs":[{"internalType":"contract PoisonToken","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PoisonPerBlock","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":"bool","name":"_withUpdate","type":"bool"}],"name":"addPool","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"bonusEndBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"collector","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"deposit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"}],"name":"emergencyWithdraw","outputs":[],"stateMutability":"nonpayable","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":[],"name":"poisonMinted","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":"accPoisonPerShare","type":"uint256"}],"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":"bool","name":"_withUpdate","type":"bool"}],"name":"setPool","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"startTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalAllocPoint","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalBoxes","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":"_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"}]

6080604052600060065560006009553480156200001b57600080fd5b50604051620027863803806200278683398181016040528101906200004191906200018d565b6000620000536200015760201b60201c565b9050806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508073ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35082600160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550816004819055508060038190555043600a8190555042600b8190555050505062000274565b600033905090565b600081519050620001708162000240565b92915050565b60008151905062000187816200025a565b92915050565b600080600060608486031215620001a957620001a86200023b565b5b6000620001b9868287016200015f565b9350506020620001cc8682870162000176565b9250506040620001df8682870162000176565b9150509250925092565b6000620001f68262000211565b9050919050565b60006200020a82620001e9565b9050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b600080fd5b6200024b81620001fd565b81146200025757600080fd5b50565b620002658162000231565b81146200027157600080fd5b50565b61250280620002846000396000f3fe608060405234801561001057600080fd5b50600436106101735760003560e01c8063630b5ba1116100de5780638da5cb5b1161009757806393f1a40b1161007157806393f1a40b146103e3578063abdc107314610414578063e2bbb15814610432578063f2fde38b1461044e57610173565b80638da5cb5b146103775780638dbb1e3a14610395578063913e77ad146103c557610173565b8063630b5ba1146102ed578063715018a6146102f757806378e97925146103015780637abceffd1461031f57806388ef74ec1461033b5780638aa285501461035957610173565b806346ca6bea1161013057806346ca6bea1461023f57806348cd4cb11461025b57806351eb05a6146102795780635312ea8e1461029557806353469aac146102b157806357e78adc146102cf57610173565b80630757d32714610178578063081e3eda146101965780631526fe27146101b457806317caf6f1146101e75780631aed655314610205578063441a3e7014610223575b600080fd5b61018061046a565b60405161018d9190611f6a565b60405180910390f35b61019e610470565b6040516101ab9190611f6a565b60405180910390f35b6101ce60048036038101906101c991906119ef565b61047d565b6040516101de9493929190611de8565b60405180910390f35b6101ef6104dd565b6040516101fc9190611f6a565b60405180910390f35b61020d6104e3565b60405161021a9190611f6a565b60405180910390f35b61023d60048036038101906102389190611adc565b6104e9565b005b61025960048036038101906102549190611b1c565b610772565b005b610263610889565b6040516102709190611f6a565b60405180910390f35b610293600480360381019061028e91906119ef565b61088f565b005b6102af60048036038101906102aa91906119ef565b610ac6565b005b6102b9610c0b565b6040516102c69190611f6a565b60405180910390f35b6102d7610c11565b6040516102e49190611f6a565b60405180910390f35b6102f5610c17565b005b6102ff610c4a565b005b610309610d9d565b6040516103169190611f6a565b60405180910390f35b61033960048036038101906103349190611a89565b610da3565b005b610343610f2a565b6040516103509190611e2d565b60405180910390f35b610361610f50565b60405161036e9190611f6a565b60405180910390f35b61037f610f55565b60405161038c9190611d44565b60405180910390f35b6103af60048036038101906103aa9190611adc565b610f7e565b6040516103bc9190611f6a565b60405180910390f35b6103cd610fff565b6040516103da9190611d44565b60405180910390f35b6103fd60048036038101906103f89190611a49565b611025565b60405161040b929190611f85565b60405180910390f35b61041c611056565b6040516104299190611f6a565b60405180910390f35b61044c60048036038101906104479190611adc565b611065565b005b61046860048036038101906104639190611995565b6113a9565b005b60045481565b6000600780549050905090565b6007818154811061048d57600080fd5b90600052602060002090600402016000915090508060000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16908060010154908060020154908060030154905084565b60095481565b60035481565b6234bc00600b546104fa9190611fe0565b421161053b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161053290611eea565b60405180910390fd5b60006007838154811061055157610550612271565b5b9060005260206000209060040201905060006008600085815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905082816000015410156105fc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016105f390611f2a565b60405180910390fd5b6106058461088f565b6000816001015464e8d4a51000846003015484600001546106269190612067565b6106309190612036565b61063a91906120c1565b905083826000015461064c91906120c1565b826000018190555064e8d4a510008360030154836000015461066e9190612067565b6106789190612036565b82600101819055506106cd3382600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661156b9092919063ffffffff16565b61071c33858560000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661156b9092919063ffffffff16565b843373ffffffffffffffffffffffffffffffffffffffff167ff279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b568866040516107639190611f6a565b60405180910390a35050505050565b61077a6115f1565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610807576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107fe90611eca565b60405180910390fd5b801561081657610815610c17565b5b816007848154811061082b5761082a612271565b5b90600052602060002090600402016001015460095461084a91906120c1565b6108549190611fe0565b600981905550816007848154811061086f5761086e612271565b5b906000526020600020906004020160010181905550505050565b600a5481565b6000600782815481106108a5576108a4612271565b5b90600052602060002090600402019050806002015443116108c65750610ac3565b60008160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b81526004016109259190611d44565b60206040518083038186803b15801561093d57600080fd5b505afa158015610951573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109759190611a1c565b90506000811415610990574382600201819055505050610ac3565b600060095483600101546004546109ab866002015443610f7e565b6109b59190612067565b6109bf9190612067565b6109c99190612036565b90508164e8d4a51000826109dd9190612067565b6109e79190612036565b83600301546109f69190611fe0565b83600301819055504383600201819055506a037a172815e4355715555560055411610abf5780600554610a299190611fe0565b600581905550600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166340c10f1930836040518363ffffffff1660e01b8152600401610a8c929190611dbf565b600060405180830381600087803b158015610aa657600080fd5b505af1158015610aba573d6000803e3d6000fd5b505050505b5050505b50565b600060078281548110610adc57610adb612271565b5b9060005260206000209060040201905060006008600084815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090506000816000015490506000826001015490506000836000018190555060008360010181905550610bb533838660000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661156b9092919063ffffffff16565b843373ffffffffffffffffffffffffffffffffffffffff167fbb757047c2b5f3974fe26b7c10f732e7bce710b0952a71082702781e62ae059583604051610bfc9190611f6a565b60405180910390a35050505050565b60055481565b60065481565b6000600780549050905060005b81811015610c4657610c358161088f565b80610c3f906121ca565b9050610c24565b5050565b610c526115f1565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610cdf576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cd690611eca565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b600b5481565b610dab6115f1565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610e38576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e2f90611eca565b60405180910390fd5b8015610e4757610e46610c17565b5b82600954610e559190611fe0565b600981905550600760405180608001604052808473ffffffffffffffffffffffffffffffffffffffff1681526020018581526020014381526020016000815250908060018154018082558091505060019003906000526020600020906004020160009091909190915060008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506020820151816001015560408201518160020155606082015181600301555050505050565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600381565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60006003548211610fa85760038383610f9791906120c1565b610fa19190612067565b9050610ff9565b6003548310610fc4578282610fbd91906120c1565b9050610ff9565b60035482610fd291906120c1565b600384600354610fe291906120c1565b610fec9190612067565b610ff69190611fe0565b90505b92915050565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6008602052816000526040600020602052806000526040600020600091509150508060000154908060010154905082565b6a037a172815e4355715555581565b60006007838154811061107b5761107a612271565b5b9060005260206000209060040201905060006008600085815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090508160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663dd62ed3e33306040518363ffffffff1660e01b815260040161113e929190611d5f565b60206040518083038186803b15801561115657600080fd5b505afa15801561116a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061118e9190611a1c565b8311156111d0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111c790611e8a565b60405180910390fd5b6112213330858560000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166115f9909392919063ffffffff16565b61122a8461088f565b6000816001015464e8d4a510008460030154846000015461124b9190612067565b6112559190612036565b61125f91906120c1565b90508382600001546112719190611fe0565b82600001819055506234bc00600b5461128a9190611fe0565b421180156112985750600081115b1561131b5764e8d4a51000836003015483600001546112b79190612067565b6112c19190612036565b82600101819055506113163382600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661156b9092919063ffffffff16565b611353565b8064e8d4a51000846003015484600001546113369190612067565b6113409190612036565b61134a91906120c1565b82600101819055505b843373ffffffffffffffffffffffffffffffffffffffff167f90890809c654f11d6e72a28fa60149770a0d11ec6c92319d6ceb2bb0a4ea1a158660405161139a9190611f6a565b60405180910390a35050505050565b6113b16115f1565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461143e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161143590611eca565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614156114ae576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114a590611e6a565b60405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a3806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b6115ec8363a9059cbb60e01b848460405160240161158a929190611dbf565b604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050611682565b505050565b600033905090565b61167c846323b872dd60e01b85858560405160240161161a93929190611d88565b604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050611682565b50505050565b60006116e4826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c65648152508573ffffffffffffffffffffffffffffffffffffffff166117499092919063ffffffff16565b9050600081511115611744578080602001905181019061170491906119c2565b611743576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161173a90611f4a565b60405180910390fd5b5b505050565b60606117588484600085611761565b90509392505050565b6060824710156117a6576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161179d90611eaa565b60405180910390fd5b6000808673ffffffffffffffffffffffffffffffffffffffff1685876040516117cf9190611d2d565b60006040518083038185875af1925050503d806000811461180c576040519150601f19603f3d011682016040523d82523d6000602084013e611811565b606091505b50915091506118228783838761182e565b92505050949350505050565b606083156118915760008351141561188957611849856118a4565b611888576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161187f90611f0a565b60405180910390fd5b5b82905061189c565b61189b83836118c7565b5b949350505050565b6000808273ffffffffffffffffffffffffffffffffffffffff163b119050919050565b6000825111156118da5781518083602001fd5b806040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161190e9190611e48565b60405180910390fd5b60008135905061192681612470565b92915050565b60008135905061193b81612487565b92915050565b60008151905061195081612487565b92915050565b6000813590506119658161249e565b92915050565b60008135905061197a816124b5565b92915050565b60008151905061198f816124b5565b92915050565b6000602082840312156119ab576119aa6122a0565b5b60006119b984828501611917565b91505092915050565b6000602082840312156119d8576119d76122a0565b5b60006119e684828501611941565b91505092915050565b600060208284031215611a0557611a046122a0565b5b6000611a138482850161196b565b91505092915050565b600060208284031215611a3257611a316122a0565b5b6000611a4084828501611980565b91505092915050565b60008060408385031215611a6057611a5f6122a0565b5b6000611a6e8582860161196b565b9250506020611a7f85828601611917565b9150509250929050565b600080600060608486031215611aa257611aa16122a0565b5b6000611ab08682870161196b565b9350506020611ac186828701611956565b9250506040611ad28682870161192c565b9150509250925092565b60008060408385031215611af357611af26122a0565b5b6000611b018582860161196b565b9250506020611b128582860161196b565b9150509250929050565b600080600060608486031215611b3557611b346122a0565b5b6000611b438682870161196b565b9350506020611b548682870161196b565b9250506040611b658682870161192c565b9150509250925092565b611b78816120f5565b82525050565b6000611b8982611fae565b611b938185611fc4565b9350611ba3818560208601612197565b80840191505092915050565b611bb88161214f565b82525050565b611bc781612161565b82525050565b6000611bd882611fb9565b611be28185611fcf565b9350611bf2818560208601612197565b611bfb816122a5565b840191505092915050565b6000611c13602683611fcf565b9150611c1e826122b6565b604082019050919050565b6000611c36601983611fcf565b9150611c4182612305565b602082019050919050565b6000611c59602683611fcf565b9150611c648261232e565b604082019050919050565b6000611c7c602083611fcf565b9150611c878261237d565b602082019050919050565b6000611c9f600983611fcf565b9150611caa826123a6565b602082019050919050565b6000611cc2601d83611fcf565b9150611ccd826123cf565b602082019050919050565b6000611ce5601283611fcf565b9150611cf0826123f8565b602082019050919050565b6000611d08602a83611fcf565b9150611d1382612421565b604082019050919050565b611d2781612145565b82525050565b6000611d398284611b7e565b915081905092915050565b6000602082019050611d596000830184611b6f565b92915050565b6000604082019050611d746000830185611b6f565b611d816020830184611b6f565b9392505050565b6000606082019050611d9d6000830186611b6f565b611daa6020830185611b6f565b611db76040830184611d1e565b949350505050565b6000604082019050611dd46000830185611b6f565b611de16020830184611d1e565b9392505050565b6000608082019050611dfd6000830187611baf565b611e0a6020830186611d1e565b611e176040830185611d1e565b611e246060830184611d1e565b95945050505050565b6000602082019050611e426000830184611bbe565b92915050565b60006020820190508181036000830152611e628184611bcd565b905092915050565b60006020820190508181036000830152611e8381611c06565b9050919050565b60006020820190508181036000830152611ea381611c29565b9050919050565b60006020820190508181036000830152611ec381611c4c565b9050919050565b60006020820190508181036000830152611ee381611c6f565b9050919050565b60006020820190508181036000830152611f0381611c92565b9050919050565b60006020820190508181036000830152611f2381611cb5565b9050919050565b60006020820190508181036000830152611f4381611cd8565b9050919050565b60006020820190508181036000830152611f6381611cfb565b9050919050565b6000602082019050611f7f6000830184611d1e565b92915050565b6000604082019050611f9a6000830185611d1e565b611fa76020830184611d1e565b9392505050565b600081519050919050565b600081519050919050565b600081905092915050565b600082825260208201905092915050565b6000611feb82612145565b9150611ff683612145565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0382111561202b5761202a612213565b5b828201905092915050565b600061204182612145565b915061204c83612145565b92508261205c5761205b612242565b5b828204905092915050565b600061207282612145565b915061207d83612145565b9250817fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff04831182151516156120b6576120b5612213565b5b828202905092915050565b60006120cc82612145565b91506120d783612145565b9250828210156120ea576120e9612213565b5b828203905092915050565b600061210082612125565b9050919050565b60008115159050919050565b600061211e826120f5565b9050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b600061215a82612173565b9050919050565b600061216c82612173565b9050919050565b600061217e82612185565b9050919050565b600061219082612125565b9050919050565b60005b838110156121b557808201518184015260208101905061219a565b838111156121c4576000848401525b50505050565b60006121d582612145565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82141561220857612207612213565b5b600182019050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b600080fd5b6000601f19601f8301169050919050565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b7f416c6c6f77616e6365206e6f74206869676820656e6f75676800000000000000600082015250565b7f416464726573733a20696e73756666696369656e742062616c616e636520666f60008201527f722063616c6c0000000000000000000000000000000000000000000000000000602082015250565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b7f546f6f206561726c790000000000000000000000000000000000000000000000600082015250565b7f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000600082015250565b7f77697468647261773a206e6f7420676f6f640000000000000000000000000000600082015250565b7f5361666545524332303a204552433230206f7065726174696f6e20646964206e60008201527f6f74207375636365656400000000000000000000000000000000000000000000602082015250565b612479816120f5565b811461248457600080fd5b50565b61249081612107565b811461249b57600080fd5b50565b6124a781612113565b81146124b257600080fd5b50565b6124be81612145565b81146124c957600080fd5b5056fea264697066735822122042de472ff6110815e2a1a96a0b5536781a4fb8beecbce971d48769a702ccff9164736f6c6343000807003300000000000000000000000031c91d8fb96bff40955dd2dbc909b36e8b104dde00000000000000000000000000000000000000000000000004a03ce68d2155550000000000000000000000000000000000000000000000000000000000fc2182

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101735760003560e01c8063630b5ba1116100de5780638da5cb5b1161009757806393f1a40b1161007157806393f1a40b146103e3578063abdc107314610414578063e2bbb15814610432578063f2fde38b1461044e57610173565b80638da5cb5b146103775780638dbb1e3a14610395578063913e77ad146103c557610173565b8063630b5ba1146102ed578063715018a6146102f757806378e97925146103015780637abceffd1461031f57806388ef74ec1461033b5780638aa285501461035957610173565b806346ca6bea1161013057806346ca6bea1461023f57806348cd4cb11461025b57806351eb05a6146102795780635312ea8e1461029557806353469aac146102b157806357e78adc146102cf57610173565b80630757d32714610178578063081e3eda146101965780631526fe27146101b457806317caf6f1146101e75780631aed655314610205578063441a3e7014610223575b600080fd5b61018061046a565b60405161018d9190611f6a565b60405180910390f35b61019e610470565b6040516101ab9190611f6a565b60405180910390f35b6101ce60048036038101906101c991906119ef565b61047d565b6040516101de9493929190611de8565b60405180910390f35b6101ef6104dd565b6040516101fc9190611f6a565b60405180910390f35b61020d6104e3565b60405161021a9190611f6a565b60405180910390f35b61023d60048036038101906102389190611adc565b6104e9565b005b61025960048036038101906102549190611b1c565b610772565b005b610263610889565b6040516102709190611f6a565b60405180910390f35b610293600480360381019061028e91906119ef565b61088f565b005b6102af60048036038101906102aa91906119ef565b610ac6565b005b6102b9610c0b565b6040516102c69190611f6a565b60405180910390f35b6102d7610c11565b6040516102e49190611f6a565b60405180910390f35b6102f5610c17565b005b6102ff610c4a565b005b610309610d9d565b6040516103169190611f6a565b60405180910390f35b61033960048036038101906103349190611a89565b610da3565b005b610343610f2a565b6040516103509190611e2d565b60405180910390f35b610361610f50565b60405161036e9190611f6a565b60405180910390f35b61037f610f55565b60405161038c9190611d44565b60405180910390f35b6103af60048036038101906103aa9190611adc565b610f7e565b6040516103bc9190611f6a565b60405180910390f35b6103cd610fff565b6040516103da9190611d44565b60405180910390f35b6103fd60048036038101906103f89190611a49565b611025565b60405161040b929190611f85565b60405180910390f35b61041c611056565b6040516104299190611f6a565b60405180910390f35b61044c60048036038101906104479190611adc565b611065565b005b61046860048036038101906104639190611995565b6113a9565b005b60045481565b6000600780549050905090565b6007818154811061048d57600080fd5b90600052602060002090600402016000915090508060000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16908060010154908060020154908060030154905084565b60095481565b60035481565b6234bc00600b546104fa9190611fe0565b421161053b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161053290611eea565b60405180910390fd5b60006007838154811061055157610550612271565b5b9060005260206000209060040201905060006008600085815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905082816000015410156105fc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016105f390611f2a565b60405180910390fd5b6106058461088f565b6000816001015464e8d4a51000846003015484600001546106269190612067565b6106309190612036565b61063a91906120c1565b905083826000015461064c91906120c1565b826000018190555064e8d4a510008360030154836000015461066e9190612067565b6106789190612036565b82600101819055506106cd3382600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661156b9092919063ffffffff16565b61071c33858560000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661156b9092919063ffffffff16565b843373ffffffffffffffffffffffffffffffffffffffff167ff279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b568866040516107639190611f6a565b60405180910390a35050505050565b61077a6115f1565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610807576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107fe90611eca565b60405180910390fd5b801561081657610815610c17565b5b816007848154811061082b5761082a612271565b5b90600052602060002090600402016001015460095461084a91906120c1565b6108549190611fe0565b600981905550816007848154811061086f5761086e612271565b5b906000526020600020906004020160010181905550505050565b600a5481565b6000600782815481106108a5576108a4612271565b5b90600052602060002090600402019050806002015443116108c65750610ac3565b60008160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b81526004016109259190611d44565b60206040518083038186803b15801561093d57600080fd5b505afa158015610951573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109759190611a1c565b90506000811415610990574382600201819055505050610ac3565b600060095483600101546004546109ab866002015443610f7e565b6109b59190612067565b6109bf9190612067565b6109c99190612036565b90508164e8d4a51000826109dd9190612067565b6109e79190612036565b83600301546109f69190611fe0565b83600301819055504383600201819055506a037a172815e4355715555560055411610abf5780600554610a299190611fe0565b600581905550600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166340c10f1930836040518363ffffffff1660e01b8152600401610a8c929190611dbf565b600060405180830381600087803b158015610aa657600080fd5b505af1158015610aba573d6000803e3d6000fd5b505050505b5050505b50565b600060078281548110610adc57610adb612271565b5b9060005260206000209060040201905060006008600084815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090506000816000015490506000826001015490506000836000018190555060008360010181905550610bb533838660000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661156b9092919063ffffffff16565b843373ffffffffffffffffffffffffffffffffffffffff167fbb757047c2b5f3974fe26b7c10f732e7bce710b0952a71082702781e62ae059583604051610bfc9190611f6a565b60405180910390a35050505050565b60055481565b60065481565b6000600780549050905060005b81811015610c4657610c358161088f565b80610c3f906121ca565b9050610c24565b5050565b610c526115f1565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610cdf576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cd690611eca565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b600b5481565b610dab6115f1565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610e38576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e2f90611eca565b60405180910390fd5b8015610e4757610e46610c17565b5b82600954610e559190611fe0565b600981905550600760405180608001604052808473ffffffffffffffffffffffffffffffffffffffff1681526020018581526020014381526020016000815250908060018154018082558091505060019003906000526020600020906004020160009091909190915060008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506020820151816001015560408201518160020155606082015181600301555050505050565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600381565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60006003548211610fa85760038383610f9791906120c1565b610fa19190612067565b9050610ff9565b6003548310610fc4578282610fbd91906120c1565b9050610ff9565b60035482610fd291906120c1565b600384600354610fe291906120c1565b610fec9190612067565b610ff69190611fe0565b90505b92915050565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6008602052816000526040600020602052806000526040600020600091509150508060000154908060010154905082565b6a037a172815e4355715555581565b60006007838154811061107b5761107a612271565b5b9060005260206000209060040201905060006008600085815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090508160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663dd62ed3e33306040518363ffffffff1660e01b815260040161113e929190611d5f565b60206040518083038186803b15801561115657600080fd5b505afa15801561116a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061118e9190611a1c565b8311156111d0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111c790611e8a565b60405180910390fd5b6112213330858560000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166115f9909392919063ffffffff16565b61122a8461088f565b6000816001015464e8d4a510008460030154846000015461124b9190612067565b6112559190612036565b61125f91906120c1565b90508382600001546112719190611fe0565b82600001819055506234bc00600b5461128a9190611fe0565b421180156112985750600081115b1561131b5764e8d4a51000836003015483600001546112b79190612067565b6112c19190612036565b82600101819055506113163382600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661156b9092919063ffffffff16565b611353565b8064e8d4a51000846003015484600001546113369190612067565b6113409190612036565b61134a91906120c1565b82600101819055505b843373ffffffffffffffffffffffffffffffffffffffff167f90890809c654f11d6e72a28fa60149770a0d11ec6c92319d6ceb2bb0a4ea1a158660405161139a9190611f6a565b60405180910390a35050505050565b6113b16115f1565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461143e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161143590611eca565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614156114ae576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114a590611e6a565b60405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a3806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b6115ec8363a9059cbb60e01b848460405160240161158a929190611dbf565b604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050611682565b505050565b600033905090565b61167c846323b872dd60e01b85858560405160240161161a93929190611d88565b604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050611682565b50505050565b60006116e4826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c65648152508573ffffffffffffffffffffffffffffffffffffffff166117499092919063ffffffff16565b9050600081511115611744578080602001905181019061170491906119c2565b611743576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161173a90611f4a565b60405180910390fd5b5b505050565b60606117588484600085611761565b90509392505050565b6060824710156117a6576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161179d90611eaa565b60405180910390fd5b6000808673ffffffffffffffffffffffffffffffffffffffff1685876040516117cf9190611d2d565b60006040518083038185875af1925050503d806000811461180c576040519150601f19603f3d011682016040523d82523d6000602084013e611811565b606091505b50915091506118228783838761182e565b92505050949350505050565b606083156118915760008351141561188957611849856118a4565b611888576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161187f90611f0a565b60405180910390fd5b5b82905061189c565b61189b83836118c7565b5b949350505050565b6000808273ffffffffffffffffffffffffffffffffffffffff163b119050919050565b6000825111156118da5781518083602001fd5b806040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161190e9190611e48565b60405180910390fd5b60008135905061192681612470565b92915050565b60008135905061193b81612487565b92915050565b60008151905061195081612487565b92915050565b6000813590506119658161249e565b92915050565b60008135905061197a816124b5565b92915050565b60008151905061198f816124b5565b92915050565b6000602082840312156119ab576119aa6122a0565b5b60006119b984828501611917565b91505092915050565b6000602082840312156119d8576119d76122a0565b5b60006119e684828501611941565b91505092915050565b600060208284031215611a0557611a046122a0565b5b6000611a138482850161196b565b91505092915050565b600060208284031215611a3257611a316122a0565b5b6000611a4084828501611980565b91505092915050565b60008060408385031215611a6057611a5f6122a0565b5b6000611a6e8582860161196b565b9250506020611a7f85828601611917565b9150509250929050565b600080600060608486031215611aa257611aa16122a0565b5b6000611ab08682870161196b565b9350506020611ac186828701611956565b9250506040611ad28682870161192c565b9150509250925092565b60008060408385031215611af357611af26122a0565b5b6000611b018582860161196b565b9250506020611b128582860161196b565b9150509250929050565b600080600060608486031215611b3557611b346122a0565b5b6000611b438682870161196b565b9350506020611b548682870161196b565b9250506040611b658682870161192c565b9150509250925092565b611b78816120f5565b82525050565b6000611b8982611fae565b611b938185611fc4565b9350611ba3818560208601612197565b80840191505092915050565b611bb88161214f565b82525050565b611bc781612161565b82525050565b6000611bd882611fb9565b611be28185611fcf565b9350611bf2818560208601612197565b611bfb816122a5565b840191505092915050565b6000611c13602683611fcf565b9150611c1e826122b6565b604082019050919050565b6000611c36601983611fcf565b9150611c4182612305565b602082019050919050565b6000611c59602683611fcf565b9150611c648261232e565b604082019050919050565b6000611c7c602083611fcf565b9150611c878261237d565b602082019050919050565b6000611c9f600983611fcf565b9150611caa826123a6565b602082019050919050565b6000611cc2601d83611fcf565b9150611ccd826123cf565b602082019050919050565b6000611ce5601283611fcf565b9150611cf0826123f8565b602082019050919050565b6000611d08602a83611fcf565b9150611d1382612421565b604082019050919050565b611d2781612145565b82525050565b6000611d398284611b7e565b915081905092915050565b6000602082019050611d596000830184611b6f565b92915050565b6000604082019050611d746000830185611b6f565b611d816020830184611b6f565b9392505050565b6000606082019050611d9d6000830186611b6f565b611daa6020830185611b6f565b611db76040830184611d1e565b949350505050565b6000604082019050611dd46000830185611b6f565b611de16020830184611d1e565b9392505050565b6000608082019050611dfd6000830187611baf565b611e0a6020830186611d1e565b611e176040830185611d1e565b611e246060830184611d1e565b95945050505050565b6000602082019050611e426000830184611bbe565b92915050565b60006020820190508181036000830152611e628184611bcd565b905092915050565b60006020820190508181036000830152611e8381611c06565b9050919050565b60006020820190508181036000830152611ea381611c29565b9050919050565b60006020820190508181036000830152611ec381611c4c565b9050919050565b60006020820190508181036000830152611ee381611c6f565b9050919050565b60006020820190508181036000830152611f0381611c92565b9050919050565b60006020820190508181036000830152611f2381611cb5565b9050919050565b60006020820190508181036000830152611f4381611cd8565b9050919050565b60006020820190508181036000830152611f6381611cfb565b9050919050565b6000602082019050611f7f6000830184611d1e565b92915050565b6000604082019050611f9a6000830185611d1e565b611fa76020830184611d1e565b9392505050565b600081519050919050565b600081519050919050565b600081905092915050565b600082825260208201905092915050565b6000611feb82612145565b9150611ff683612145565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0382111561202b5761202a612213565b5b828201905092915050565b600061204182612145565b915061204c83612145565b92508261205c5761205b612242565b5b828204905092915050565b600061207282612145565b915061207d83612145565b9250817fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff04831182151516156120b6576120b5612213565b5b828202905092915050565b60006120cc82612145565b91506120d783612145565b9250828210156120ea576120e9612213565b5b828203905092915050565b600061210082612125565b9050919050565b60008115159050919050565b600061211e826120f5565b9050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b600061215a82612173565b9050919050565b600061216c82612173565b9050919050565b600061217e82612185565b9050919050565b600061219082612125565b9050919050565b60005b838110156121b557808201518184015260208101905061219a565b838111156121c4576000848401525b50505050565b60006121d582612145565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82141561220857612207612213565b5b600182019050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b600080fd5b6000601f19601f8301169050919050565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b7f416c6c6f77616e6365206e6f74206869676820656e6f75676800000000000000600082015250565b7f416464726573733a20696e73756666696369656e742062616c616e636520666f60008201527f722063616c6c0000000000000000000000000000000000000000000000000000602082015250565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b7f546f6f206561726c790000000000000000000000000000000000000000000000600082015250565b7f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000600082015250565b7f77697468647261773a206e6f7420676f6f640000000000000000000000000000600082015250565b7f5361666545524332303a204552433230206f7065726174696f6e20646964206e60008201527f6f74207375636365656400000000000000000000000000000000000000000000602082015250565b612479816120f5565b811461248457600080fd5b50565b61249081612107565b811461249b57600080fd5b50565b6124a781612113565b81146124b257600080fd5b50565b6124be81612145565b81146124c957600080fd5b5056fea264697066735822122042de472ff6110815e2a1a96a0b5536781a4fb8beecbce971d48769a702ccff9164736f6c63430008070033

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

00000000000000000000000031c91d8fb96bff40955dd2dbc909b36e8b104dde00000000000000000000000000000000000000000000000004a03ce68d2155550000000000000000000000000000000000000000000000000000000000fc2182

-----Decoded View---------------
Arg [0] : _Poison (address): 0x31C91D8Fb96BfF40955DD2dbc909B36E8b104Dde
Arg [1] : _PoisonPerBlock (uint256): 333333333333333333
Arg [2] : _bonusEndBlock (uint256): 16523650

-----Encoded View---------------
3 Constructor Arguments found :
Arg [0] : 00000000000000000000000031c91d8fb96bff40955dd2dbc909b36e8b104dde
Arg [1] : 00000000000000000000000000000000000000000000000004a03ce68d215555
Arg [2] : 0000000000000000000000000000000000000000000000000000000000fc2182


Deployed Bytecode Sourcemap

20010:7692:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20950:29;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;22286:95;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;21254:26;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;;;;:::i;:::-;;;;;;;;21527:34;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;20874:28;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;26451:750;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;23149:377;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;21620:25;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;24400:904;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;27272:427;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;21155:27;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;21189:29;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;24144:180;;;:::i;:::-;;19061:148;;;:::i;:::-;;21652:24;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;22546:505;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;20757:25;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;21035:44;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;18419:79;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;23602:459;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;20791:24;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;21368:64;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;;:::i;:::-;;;;;;;;21086:62;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;25377:1020;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;19364:281;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;20950:29;;;;:::o;22286:95::-;22331:7;22358:8;:15;;;;22351:22;;22286:95;:::o;21254:26::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;21527:34::-;;;;:::o;20874:28::-;;;;:::o;26451:750::-;26559:7;26547:9;;:19;;;;:::i;:::-;26528:15;:39;26520:61;;;;;;;;;;;;:::i;:::-;;;;;;;;;26594:21;26618:8;26627:4;26618:14;;;;;;;;:::i;:::-;;;;;;;;;;;;26594:38;;26643:21;26667:8;:14;26676:4;26667:14;;;;;;;;;;;:26;26682:10;26667:26;;;;;;;;;;;;;;;26643:50;;26729:7;26714:4;:11;;;:22;;26706:53;;;;;;;;;;;;:::i;:::-;;;;;;;;;26772:16;26783:4;26772:10;:16::i;:::-;26801:15;26893:4;:15;;;26873:4;26834;:22;;;26820:4;:11;;;:36;;;;:::i;:::-;26819:58;;;;:::i;:::-;:89;;;;:::i;:::-;26801:107;;26949:7;26935:4;:11;;;:21;;;;:::i;:::-;26921:4;:11;;:35;;;;27026:4;27000;:22;;;26986:4;:11;;;:36;;;;:::i;:::-;26985:45;;;;:::i;:::-;26967:4;:15;;:63;;;;27043:40;27063:10;27075:7;27043:6;;;;;;;;;;;:19;;;;:40;;;;;:::i;:::-;27094:46;27120:10;27132:7;27094:4;:12;;;;;;;;;;;;:25;;;;:46;;;;;:::i;:::-;27179:4;27167:10;27158:35;;;27185:7;27158:35;;;;;;:::i;:::-;;;;;;;;26509:692;;;26451:750;;:::o;23149:377::-;18641:12;:10;:12::i;:::-;18631:22;;:6;;;;;;;;;;:22;;;18623:67;;;;;;;;;;;;:::i;:::-;;;;;;;;;23287:11:::1;23283:61;;;23315:17;:15;:17::i;:::-;23283:61;23457:11;23416:8;23425:4;23416:14;;;;;;;;:::i;:::-;;;;;;;;;;;;:25;;;23385:15;;:56;;;;:::i;:::-;:83;;;;:::i;:::-;23354:15;:114;;;;23507:11;23479:8;23488:4;23479:14;;;;;;;;:::i;:::-;;;;;;;;;;;;:25;;:39;;;;23149:377:::0;;;:::o;21620:25::-;;;;:::o;24400:904::-;24452:21;24476:8;24485:4;24476:14;;;;;;;;:::i;:::-;;;;;;;;;;;;24452:38;;24521:4;:20;;;24505:12;:36;24501:75;;24558:7;;;24501:75;24588:16;24607:4;:12;;;;;;;;;;;;:22;;;24638:4;24607:37;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;24588:56;;24671:1;24659:8;:13;24655:102;;;24712:12;24689:4;:20;;:35;;;;24739:7;;;;24655:102;24769:20;24944:15;;24925:4;:15;;;24895:14;;24793:86;24821:4;:20;;;24856:12;24793:13;:86::i;:::-;:116;;;;:::i;:::-;:147;;;;:::i;:::-;24792:167;;;;:::i;:::-;24769:190;;25073:8;25065:4;25050:12;:19;;;;:::i;:::-;25049:32;;;;:::i;:::-;25010:4;:22;;;:72;;;;:::i;:::-;24972:4;:22;;:110;;;;25116:12;25093:4;:20;;:35;;;;21123:25;25145:12;;:26;25141:156;;25218:12;25203;;:27;;;;:::i;:::-;25188:12;:42;;;;25245:6;;;;;;;;;;;:11;;;25265:4;25272:12;25245:40;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25141:156;24441:863;;;24400:904;;:::o;27272:427::-;27333:21;27357:8;27366:4;27357:14;;;;;;;;:::i;:::-;;;;;;;;;;;;27333:38;;27382:21;27406:8;:14;27415:4;27406:14;;;;;;;;;;;:26;27421:10;27406:26;;;;;;;;;;;;;;;27382:50;;27445:14;27462:4;:11;;;27445:28;;27484:14;27501:4;:15;;;27484:32;;27543:1;27529:4;:11;;:15;;;;27573:1;27555:4;:15;;:19;;;;27587:45;27613:10;27625:6;27587:4;:12;;;;;;;;;;;;:25;;;;:45;;;;;:::i;:::-;27678:4;27666:10;27648:43;;;27684:6;27648:43;;;;;;:::i;:::-;;;;;;;;27322:377;;;;27272:427;:::o;21155:27::-;;;;:::o;21189:29::-;;;;:::o;24144:180::-;24189:14;24206:8;:15;;;;24189:32;;24237:11;24232:85;24260:6;24254:3;:12;24232:85;;;24290:15;24301:3;24290:10;:15::i;:::-;24268:5;;;;:::i;:::-;;;24232:85;;;;24178:146;24144:180::o;19061:148::-;18641:12;:10;:12::i;:::-;18631:22;;:6;;;;;;;;;;:22;;;18623:67;;;;;;;;;;;;:::i;:::-;;;;;;;;;19168:1:::1;19131:40;;19152:6;::::0;::::1;;;;;;;;19131:40;;;;;;;;;;;;19199:1;19182:6:::0;::::1;:19;;;;;;;;;;;;;;;;;;19061:148::o:0;21652:24::-;;;;:::o;22546:505::-;18641:12;:10;:12::i;:::-;18631:22;;:6;;;;;;;;;;:22;;;18623:67;;;;;;;;;;;;:::i;:::-;;;;;;;;;22687:11:::1;22683:61;;;22715:17;:15;:17::i;:::-;22683:61;22792:11;22774:15;;:29;;;;:::i;:::-;22756:15;:47;;;;22814:8;22842:190;;;;;;;;22879:8;22842:190;;;;;;22918:11;22842:190;;;;22965:12;22842:190;;;;23015:1;22842:190;;::::0;22814:229:::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22546:505:::0;;;:::o;20757:25::-;;;;;;;;;;;;;:::o;21035:44::-;21078:1;21035:44;:::o;18419:79::-;18457:7;18484:6;;;;;;;;;;;18477:13;;18419:79;:::o;23602:459::-;23701:7;23737:13;;23730:3;:20;23726:328;;21078:1;23781:5;23775:3;:11;;;;:::i;:::-;23774:32;;;;:::i;:::-;23767:39;;;;23726:328;23837:13;;23828:5;:22;23824:230;;23880:5;23874:3;:11;;;;:::i;:::-;23867:18;;;;23824:230;24028:13;;24022:3;:19;;;;:::i;:::-;21078:1;23959:5;23943:13;;:21;;;;:::i;:::-;23942:59;;;;:::i;:::-;:100;;;;:::i;:::-;23918:124;;23602:459;;;;;:::o;20791:24::-;;;;;;;;;;;;;:::o;21368:64::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;21086:62::-;21123:25;21086:62;:::o;25377:1020::-;25445:21;25469:8;25478:4;25469:14;;;;;;;;:::i;:::-;;;;;;;;;;;;25445:38;;25494:21;25518:8;:14;25527:4;25518:14;;;;;;;;;;;:26;25533:10;25518:26;;;;;;;;;;;;;;;25494:50;;25590:4;:12;;;;;;;;;;;;:22;;;25613:10;25633:4;25590:49;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;25579:7;:60;;25557:135;;;;;;;;;;;;:::i;:::-;;;;;;;;;25703:65;25733:10;25753:4;25760:7;25703:4;:12;;;;;;;;;;;;:29;;;;:65;;;;;;:::i;:::-;25781:16;25792:4;25781:10;:16::i;:::-;25810:15;25902:4;:15;;;25882:4;25843;:22;;;25829:4;:11;;;:36;;;;:::i;:::-;25828:58;;;;:::i;:::-;:89;;;;:::i;:::-;25810:107;;25956:7;25942:4;:11;;;:21;;;;:::i;:::-;25928:4;:11;;:35;;;;26011:7;25999:9;;:19;;;;:::i;:::-;25980:15;:39;:54;;;;;26033:1;26023:7;:11;25980:54;25976:362;;;26110:4;26084;:22;;;26070:4;:11;;;:36;;;;:::i;:::-;26069:45;;;;:::i;:::-;26051:4;:15;;:63;;;;26129:40;26149:10;26161:7;26129:6;;;;;;;;;;;:19;;;;:40;;;;;:::i;:::-;25976:362;;;26319:7;26295:4;26252;:22;;;26238:4;:11;;;:36;;;;:::i;:::-;26237:62;;;;:::i;:::-;:89;;;;:::i;:::-;26202:4;:15;;:124;;;;25976:362;26375:4;26363:10;26355:34;;;26381:7;26355:34;;;;;;:::i;:::-;;;;;;;;25434:963;;;25377:1020;;:::o;19364:281::-;18641:12;:10;:12::i;:::-;18631:22;;:6;;;;;;;;;;:22;;;18623:67;;;;;;;;;;;;:::i;:::-;;;;;;;;;19487:1:::1;19467:22;;:8;:22;;;;19445:110;;;;;;;;;;;;:::i;:::-;;;;;;;;;19600:8;19571:38;;19592:6;::::0;::::1;;;;;;;;19571:38;;;;;;;;;;;;19629:8;19620:6;::::0;:17:::1;;;;;;;;;;;;;;;;;;19364:281:::0;:::o;12544:248::-;12661:123;12695:5;12738:23;;;12763:2;12767:5;12715:58;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12661:19;:123::i;:::-;12544:248;;;:::o;16942:115::-;16995:15;17038:10;17023:26;;16942:115;:::o;12800:285::-;12944:133;12978:5;13021:27;;;13050:4;13056:2;13060:5;12998:68;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12944:19;:133::i;:::-;12800:285;;;;:::o;15511:802::-;15935:23;15961:106;16003:4;15961:106;;;;;;;;;;;;;;;;;15969:5;15961:27;;;;:106;;;;;:::i;:::-;15935:132;;16102:1;16082:10;:17;:21;16078:228;;;16197:10;16186:30;;;;;;;;;;;;:::i;:::-;16160:134;;;;;;;;;;;;:::i;:::-;;;;;;;;;16078:228;15581:732;15511:802;;:::o;5872:229::-;6009:12;6041:52;6063:6;6071:4;6077:1;6080:12;6041:21;:52::i;:::-;6034:59;;5872:229;;;;;:::o;7088:612::-;7258:12;7330:5;7305:21;:30;;7283:118;;;;;;;;;;;;:::i;:::-;;;;;;;;;7413:12;7427:23;7454:6;:11;;7473:5;7494:4;7454:55;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7412:97;;;;7540:152;7585:6;7610:7;7636:10;7665:12;7540:26;:152::i;:::-;7520:172;;;;7088:612;;;;;;:::o;10223:644::-;10408:12;10437:7;10433:427;;;10486:1;10465:10;:17;:22;10461:290;;;10683:18;10694:6;10683:10;:18::i;:::-;10675:60;;;;;;;;;;;;:::i;:::-;;;;;;;;;10461:290;10772:10;10765:17;;;;10433:427;10815:33;10823:10;10835:12;10815:7;:33::i;:::-;10223:644;;;;;;;:::o;2922:326::-;2982:4;3239:1;3217:7;:19;;;:23;3210:30;;2922:326;;;:::o;11409:575::-;11613:1;11593:10;:17;:21;11589:388;;;11825:10;11819:17;11882:15;11869:10;11865:2;11861:19;11854:44;11589:388;11952:12;11945:20;;;;;;;;;;;:::i;:::-;;;;;;;;7:139:1;53:5;91:6;78:20;69:29;;107:33;134:5;107:33;:::i;:::-;7:139;;;;:::o;152:133::-;195:5;233:6;220:20;211:29;;249:30;273:5;249:30;:::i;:::-;152:133;;;;:::o;291:137::-;345:5;376:6;370:13;361:22;;392:30;416:5;392:30;:::i;:::-;291:137;;;;:::o;434:165::-;493:5;531:6;518:20;509:29;;547:46;587:5;547:46;:::i;:::-;434:165;;;;:::o;605:139::-;651:5;689:6;676:20;667:29;;705:33;732:5;705:33;:::i;:::-;605:139;;;;:::o;750:143::-;807:5;838:6;832:13;823:22;;854:33;881:5;854:33;:::i;:::-;750:143;;;;:::o;899:329::-;958:6;1007:2;995:9;986:7;982:23;978:32;975:119;;;1013:79;;:::i;:::-;975:119;1133:1;1158:53;1203:7;1194:6;1183:9;1179:22;1158:53;:::i;:::-;1148:63;;1104:117;899:329;;;;:::o;1234:345::-;1301:6;1350:2;1338:9;1329:7;1325:23;1321:32;1318:119;;;1356:79;;:::i;:::-;1318:119;1476:1;1501:61;1554:7;1545:6;1534:9;1530:22;1501:61;:::i;:::-;1491:71;;1447:125;1234:345;;;;:::o;1585:329::-;1644:6;1693:2;1681:9;1672:7;1668:23;1664:32;1661:119;;;1699:79;;:::i;:::-;1661:119;1819:1;1844:53;1889:7;1880:6;1869:9;1865:22;1844:53;:::i;:::-;1834:63;;1790:117;1585:329;;;;:::o;1920:351::-;1990:6;2039:2;2027:9;2018:7;2014:23;2010:32;2007:119;;;2045:79;;:::i;:::-;2007:119;2165:1;2190:64;2246:7;2237:6;2226:9;2222:22;2190:64;:::i;:::-;2180:74;;2136:128;1920:351;;;;:::o;2277:474::-;2345:6;2353;2402:2;2390:9;2381:7;2377:23;2373:32;2370:119;;;2408:79;;:::i;:::-;2370:119;2528:1;2553:53;2598:7;2589:6;2578:9;2574:22;2553:53;:::i;:::-;2543:63;;2499:117;2655:2;2681:53;2726:7;2717:6;2706:9;2702:22;2681:53;:::i;:::-;2671:63;;2626:118;2277:474;;;;;:::o;2757:639::-;2844:6;2852;2860;2909:2;2897:9;2888:7;2884:23;2880:32;2877:119;;;2915:79;;:::i;:::-;2877:119;3035:1;3060:53;3105:7;3096:6;3085:9;3081:22;3060:53;:::i;:::-;3050:63;;3006:117;3162:2;3188:66;3246:7;3237:6;3226:9;3222:22;3188:66;:::i;:::-;3178:76;;3133:131;3303:2;3329:50;3371:7;3362:6;3351:9;3347:22;3329:50;:::i;:::-;3319:60;;3274:115;2757:639;;;;;:::o;3402:474::-;3470:6;3478;3527:2;3515:9;3506:7;3502:23;3498:32;3495:119;;;3533:79;;:::i;:::-;3495:119;3653:1;3678:53;3723:7;3714:6;3703:9;3699:22;3678:53;:::i;:::-;3668:63;;3624:117;3780:2;3806:53;3851:7;3842:6;3831:9;3827:22;3806:53;:::i;:::-;3796:63;;3751:118;3402:474;;;;;:::o;3882:613::-;3956:6;3964;3972;4021:2;4009:9;4000:7;3996:23;3992:32;3989:119;;;4027:79;;:::i;:::-;3989:119;4147:1;4172:53;4217:7;4208:6;4197:9;4193:22;4172:53;:::i;:::-;4162:63;;4118:117;4274:2;4300:53;4345:7;4336:6;4325:9;4321:22;4300:53;:::i;:::-;4290:63;;4245:118;4402:2;4428:50;4470:7;4461:6;4450:9;4446:22;4428:50;:::i;:::-;4418:60;;4373:115;3882:613;;;;;:::o;4501:118::-;4588:24;4606:5;4588:24;:::i;:::-;4583:3;4576:37;4501:118;;:::o;4625:373::-;4729:3;4757:38;4789:5;4757:38;:::i;:::-;4811:88;4892:6;4887:3;4811:88;:::i;:::-;4804:95;;4908:52;4953:6;4948:3;4941:4;4934:5;4930:16;4908:52;:::i;:::-;4985:6;4980:3;4976:16;4969:23;;4733:265;4625:373;;;;:::o;5004:157::-;5104:50;5148:5;5104:50;:::i;:::-;5099:3;5092:63;5004:157;;:::o;5167:167::-;5272:55;5321:5;5272:55;:::i;:::-;5267:3;5260:68;5167:167;;:::o;5340:364::-;5428:3;5456:39;5489:5;5456:39;:::i;:::-;5511:71;5575:6;5570:3;5511:71;:::i;:::-;5504:78;;5591:52;5636:6;5631:3;5624:4;5617:5;5613:16;5591:52;:::i;:::-;5668:29;5690:6;5668:29;:::i;:::-;5663:3;5659:39;5652:46;;5432:272;5340:364;;;;:::o;5710:366::-;5852:3;5873:67;5937:2;5932:3;5873:67;:::i;:::-;5866:74;;5949:93;6038:3;5949:93;:::i;:::-;6067:2;6062:3;6058:12;6051:19;;5710:366;;;:::o;6082:::-;6224:3;6245:67;6309:2;6304:3;6245:67;:::i;:::-;6238:74;;6321:93;6410:3;6321:93;:::i;:::-;6439:2;6434:3;6430:12;6423:19;;6082:366;;;:::o;6454:::-;6596:3;6617:67;6681:2;6676:3;6617:67;:::i;:::-;6610:74;;6693:93;6782:3;6693:93;:::i;:::-;6811:2;6806:3;6802:12;6795:19;;6454:366;;;:::o;6826:::-;6968:3;6989:67;7053:2;7048:3;6989:67;:::i;:::-;6982:74;;7065:93;7154:3;7065:93;:::i;:::-;7183:2;7178:3;7174:12;7167:19;;6826:366;;;:::o;7198:365::-;7340:3;7361:66;7425:1;7420:3;7361:66;:::i;:::-;7354:73;;7436:93;7525:3;7436:93;:::i;:::-;7554:2;7549:3;7545:12;7538:19;;7198:365;;;:::o;7569:366::-;7711:3;7732:67;7796:2;7791:3;7732:67;:::i;:::-;7725:74;;7808:93;7897:3;7808:93;:::i;:::-;7926:2;7921:3;7917:12;7910:19;;7569:366;;;:::o;7941:::-;8083:3;8104:67;8168:2;8163:3;8104:67;:::i;:::-;8097:74;;8180:93;8269:3;8180:93;:::i;:::-;8298:2;8293:3;8289:12;8282:19;;7941:366;;;:::o;8313:::-;8455:3;8476:67;8540:2;8535:3;8476:67;:::i;:::-;8469:74;;8552:93;8641:3;8552:93;:::i;:::-;8670:2;8665:3;8661:12;8654:19;;8313:366;;;:::o;8685:118::-;8772:24;8790:5;8772:24;:::i;:::-;8767:3;8760:37;8685:118;;:::o;8809:271::-;8939:3;8961:93;9050:3;9041:6;8961:93;:::i;:::-;8954:100;;9071:3;9064:10;;8809:271;;;;:::o;9086:222::-;9179:4;9217:2;9206:9;9202:18;9194:26;;9230:71;9298:1;9287:9;9283:17;9274:6;9230:71;:::i;:::-;9086:222;;;;:::o;9314:332::-;9435:4;9473:2;9462:9;9458:18;9450:26;;9486:71;9554:1;9543:9;9539:17;9530:6;9486:71;:::i;:::-;9567:72;9635:2;9624:9;9620:18;9611:6;9567:72;:::i;:::-;9314:332;;;;;:::o;9652:442::-;9801:4;9839:2;9828:9;9824:18;9816:26;;9852:71;9920:1;9909:9;9905:17;9896:6;9852:71;:::i;:::-;9933:72;10001:2;9990:9;9986:18;9977:6;9933:72;:::i;:::-;10015;10083:2;10072:9;10068:18;10059:6;10015:72;:::i;:::-;9652:442;;;;;;:::o;10100:332::-;10221:4;10259:2;10248:9;10244:18;10236:26;;10272:71;10340:1;10329:9;10325:17;10316:6;10272:71;:::i;:::-;10353:72;10421:2;10410:9;10406:18;10397:6;10353:72;:::i;:::-;10100:332;;;;;:::o;10438:579::-;10628:4;10666:3;10655:9;10651:19;10643:27;;10680:84;10761:1;10750:9;10746:17;10737:6;10680:84;:::i;:::-;10774:72;10842:2;10831:9;10827:18;10818:6;10774:72;:::i;:::-;10856;10924:2;10913:9;10909:18;10900:6;10856:72;:::i;:::-;10938;11006:2;10995:9;10991:18;10982:6;10938:72;:::i;:::-;10438:579;;;;;;;:::o;11023:258::-;11134:4;11172:2;11161:9;11157:18;11149:26;;11185:89;11271:1;11260:9;11256:17;11247:6;11185:89;:::i;:::-;11023:258;;;;:::o;11287:313::-;11400:4;11438:2;11427:9;11423:18;11415:26;;11487:9;11481:4;11477:20;11473:1;11462:9;11458:17;11451:47;11515:78;11588:4;11579:6;11515:78;:::i;:::-;11507:86;;11287:313;;;;:::o;11606:419::-;11772:4;11810:2;11799:9;11795:18;11787:26;;11859:9;11853:4;11849:20;11845:1;11834:9;11830:17;11823:47;11887:131;12013:4;11887:131;:::i;:::-;11879:139;;11606:419;;;:::o;12031:::-;12197:4;12235:2;12224:9;12220:18;12212:26;;12284:9;12278:4;12274:20;12270:1;12259:9;12255:17;12248:47;12312:131;12438:4;12312:131;:::i;:::-;12304:139;;12031:419;;;:::o;12456:::-;12622:4;12660:2;12649:9;12645:18;12637:26;;12709:9;12703:4;12699:20;12695:1;12684:9;12680:17;12673:47;12737:131;12863:4;12737:131;:::i;:::-;12729:139;;12456:419;;;:::o;12881:::-;13047:4;13085:2;13074:9;13070:18;13062:26;;13134:9;13128:4;13124:20;13120:1;13109:9;13105:17;13098:47;13162:131;13288:4;13162:131;:::i;:::-;13154:139;;12881:419;;;:::o;13306:::-;13472:4;13510:2;13499:9;13495:18;13487:26;;13559:9;13553:4;13549:20;13545:1;13534:9;13530:17;13523:47;13587:131;13713:4;13587:131;:::i;:::-;13579:139;;13306:419;;;:::o;13731:::-;13897:4;13935:2;13924:9;13920:18;13912:26;;13984:9;13978:4;13974:20;13970:1;13959:9;13955:17;13948:47;14012:131;14138:4;14012:131;:::i;:::-;14004:139;;13731:419;;;:::o;14156:::-;14322:4;14360:2;14349:9;14345:18;14337:26;;14409:9;14403:4;14399:20;14395:1;14384:9;14380:17;14373:47;14437:131;14563:4;14437:131;:::i;:::-;14429:139;;14156:419;;;:::o;14581:::-;14747:4;14785:2;14774:9;14770:18;14762:26;;14834:9;14828:4;14824:20;14820:1;14809:9;14805:17;14798:47;14862:131;14988:4;14862:131;:::i;:::-;14854:139;;14581:419;;;:::o;15006:222::-;15099:4;15137:2;15126:9;15122:18;15114:26;;15150:71;15218:1;15207:9;15203:17;15194:6;15150:71;:::i;:::-;15006:222;;;;:::o;15234:332::-;15355:4;15393:2;15382:9;15378:18;15370:26;;15406:71;15474:1;15463:9;15459:17;15450:6;15406:71;:::i;:::-;15487:72;15555:2;15544:9;15540:18;15531:6;15487:72;:::i;:::-;15234:332;;;;;:::o;15653:98::-;15704:6;15738:5;15732:12;15722:22;;15653:98;;;:::o;15757:99::-;15809:6;15843:5;15837:12;15827:22;;15757:99;;;:::o;15862:147::-;15963:11;16000:3;15985:18;;15862:147;;;;:::o;16015:169::-;16099:11;16133:6;16128:3;16121:19;16173:4;16168:3;16164:14;16149:29;;16015:169;;;;:::o;16190:305::-;16230:3;16249:20;16267:1;16249:20;:::i;:::-;16244:25;;16283:20;16301:1;16283:20;:::i;:::-;16278:25;;16437:1;16369:66;16365:74;16362:1;16359:81;16356:107;;;16443:18;;:::i;:::-;16356:107;16487:1;16484;16480:9;16473:16;;16190:305;;;;:::o;16501:185::-;16541:1;16558:20;16576:1;16558:20;:::i;:::-;16553:25;;16592:20;16610:1;16592:20;:::i;:::-;16587:25;;16631:1;16621:35;;16636:18;;:::i;:::-;16621:35;16678:1;16675;16671:9;16666:14;;16501:185;;;;:::o;16692:348::-;16732:7;16755:20;16773:1;16755:20;:::i;:::-;16750:25;;16789:20;16807:1;16789:20;:::i;:::-;16784:25;;16977:1;16909:66;16905:74;16902:1;16899:81;16894:1;16887:9;16880:17;16876:105;16873:131;;;16984:18;;:::i;:::-;16873:131;17032:1;17029;17025:9;17014:20;;16692:348;;;;:::o;17046:191::-;17086:4;17106:20;17124:1;17106:20;:::i;:::-;17101:25;;17140:20;17158:1;17140:20;:::i;:::-;17135:25;;17179:1;17176;17173:8;17170:34;;;17184:18;;:::i;:::-;17170:34;17229:1;17226;17222:9;17214:17;;17046:191;;;;:::o;17243:96::-;17280:7;17309:24;17327:5;17309:24;:::i;:::-;17298:35;;17243:96;;;:::o;17345:90::-;17379:7;17422:5;17415:13;17408:21;17397:32;;17345:90;;;:::o;17441:109::-;17491:7;17520:24;17538:5;17520:24;:::i;:::-;17509:35;;17441:109;;;:::o;17556:126::-;17593:7;17633:42;17626:5;17622:54;17611:65;;17556:126;;;:::o;17688:77::-;17725:7;17754:5;17743:16;;17688:77;;;:::o;17771:139::-;17834:9;17867:37;17898:5;17867:37;:::i;:::-;17854:50;;17771:139;;;:::o;17916:144::-;17984:9;18017:37;18048:5;18017:37;:::i;:::-;18004:50;;17916:144;;;:::o;18066:126::-;18116:9;18149:37;18180:5;18149:37;:::i;:::-;18136:50;;18066:126;;;:::o;18198:113::-;18248:9;18281:24;18299:5;18281:24;:::i;:::-;18268:37;;18198:113;;;:::o;18317:307::-;18385:1;18395:113;18409:6;18406:1;18403:13;18395:113;;;18494:1;18489:3;18485:11;18479:18;18475:1;18470:3;18466:11;18459:39;18431:2;18428:1;18424:10;18419:15;;18395:113;;;18526:6;18523:1;18520:13;18517:101;;;18606:1;18597:6;18592:3;18588:16;18581:27;18517:101;18366:258;18317:307;;;:::o;18630:233::-;18669:3;18692:24;18710:5;18692:24;:::i;:::-;18683:33;;18738:66;18731:5;18728:77;18725:103;;;18808:18;;:::i;:::-;18725:103;18855:1;18848:5;18844:13;18837:20;;18630:233;;;:::o;18869:180::-;18917:77;18914:1;18907:88;19014:4;19011:1;19004:15;19038:4;19035:1;19028:15;19055:180;19103:77;19100:1;19093:88;19200:4;19197:1;19190:15;19224:4;19221:1;19214:15;19241:180;19289:77;19286:1;19279:88;19386:4;19383:1;19376:15;19410:4;19407:1;19400:15;19550:117;19659:1;19656;19649:12;19673:102;19714:6;19765:2;19761:7;19756:2;19749:5;19745:14;19741:28;19731:38;;19673:102;;;:::o;19781:225::-;19921:34;19917:1;19909:6;19905:14;19898:58;19990:8;19985:2;19977:6;19973:15;19966:33;19781:225;:::o;20012:175::-;20152:27;20148:1;20140:6;20136:14;20129:51;20012:175;:::o;20193:225::-;20333:34;20329:1;20321:6;20317:14;20310:58;20402:8;20397:2;20389:6;20385:15;20378:33;20193:225;:::o;20424:182::-;20564:34;20560:1;20552:6;20548:14;20541:58;20424:182;:::o;20612:159::-;20752:11;20748:1;20740:6;20736:14;20729:35;20612:159;:::o;20777:179::-;20917:31;20913:1;20905:6;20901:14;20894:55;20777:179;:::o;20962:168::-;21102:20;21098:1;21090:6;21086:14;21079:44;20962:168;:::o;21136:229::-;21276:34;21272:1;21264:6;21260:14;21253:58;21345:12;21340:2;21332:6;21328:15;21321:37;21136:229;:::o;21371:122::-;21444:24;21462:5;21444:24;:::i;:::-;21437:5;21434:35;21424:63;;21483:1;21480;21473:12;21424:63;21371:122;:::o;21499:116::-;21569:21;21584:5;21569:21;:::i;:::-;21562:5;21559:32;21549:60;;21605:1;21602;21595:12;21549:60;21499:116;:::o;21621:148::-;21707:37;21738:5;21707:37;:::i;:::-;21700:5;21697:48;21687:76;;21759:1;21756;21749:12;21687:76;21621:148;:::o;21775:122::-;21848:24;21866:5;21848:24;:::i;:::-;21841:5;21838:35;21828:63;;21887:1;21884;21877:12;21828:63;21775:122;:::o

Swarm Source

ipfs://42de472ff6110815e2a1a96a0b5536781a4fb8beecbce971d48769a702ccff91

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

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

Validator Index Block Amount
View All Withdrawals

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

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