ETH Price: $3,994.31 (+2.64%)

Contract

0x8C211EE553668222307BC1B7c698eDF0B29173e9
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

Token Holdings

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Claim186598282023-11-27 1:52:23376 days ago1701049943IN
handle.fi: Team
0 ETH0.0020236723.18659207
Claim176478252023-07-08 8:21:23517 days ago1688804483IN
handle.fi: Team
0 ETH0.0014830520.58085231
Claim176392992023-07-07 3:36:47519 days ago1688701007IN
handle.fi: Team
0 ETH0.0011731621.3457647
Claim172000992023-05-06 7:34:47580 days ago1683358487IN
handle.fi: Team
0 ETH0.00621835113.14326339
Claim169894722023-04-06 12:08:47610 days ago1680782927IN
handle.fi: Team
0 ETH0.0014174925.79138871
Claim169436442023-03-31 0:33:11617 days ago1680222791IN
handle.fi: Team
0 ETH0.001298123.61910051
Claim168619092023-03-19 12:57:11628 days ago1679230631IN
handle.fi: Team
0 ETH0.0008602315.65202166
Claim167666362023-03-06 3:26:11642 days ago1678073171IN
handle.fi: Team
0 ETH0.0024712928.31198987
Claim166831162023-02-22 9:31:35653 days ago1677058295IN
handle.fi: Team
0 ETH0.0015867328.8707913
Claim165594552023-02-05 1:59:47671 days ago1675562387IN
handle.fi: Team
0 ETH0.0009588617.44658251
Claim163669702023-01-09 4:51:59698 days ago1673239919IN
handle.fi: Team
0 ETH0.0015263117.48591829
Claim163534142023-01-07 7:27:59699 days ago1673076479IN
handle.fi: Team
0 ETH0.000711412.94409516
Claim162154882022-12-19 1:34:59719 days ago1671413699IN
handle.fi: Team
0 ETH0.0006978212.69699632
Claim160525032022-11-26 6:54:59741 days ago1669445699IN
handle.fi: Team
0 ETH0.0007491810.39664626
Claim159205302022-11-07 20:27:23760 days ago1667852843IN
handle.fi: Team
0 ETH0.0011491120.90829475
Claim157138262022-10-09 23:29:35789 days ago1665358175IN
handle.fi: Team
0 ETH0.0014193425.82503301
Claim154946032022-09-08 4:50:03821 days ago1662612603IN
handle.fi: Team
0 ETH0.000549279.99401659
Claim154714162022-09-04 11:37:37824 days ago1662291457IN
handle.fi: Team
0 ETH0.000185425.51759643
Claim154714162022-09-04 11:37:37824 days ago1662291457IN
handle.fi: Team
0 ETH0.000185425.51759643
Claim154713982022-09-04 11:33:12824 days ago1662291192IN
handle.fi: Team
0 ETH0.00021286.33221653
Claim153351342022-08-13 19:00:49846 days ago1660417249IN
handle.fi: Team
0 ETH0.000655911.93414218
Claim152466842022-07-30 23:09:27860 days ago1659222567IN
handle.fi: Team
0 ETH0.000545939.9333773
Claim150252252022-06-25 19:36:54895 days ago1656185814IN
handle.fi: Team
0 ETH0.0024922945.34749905
Claim148568672022-05-27 23:05:37924 days ago1653692737IN
handle.fi: Team
0 ETH0.0032789745.50340486
Claim147540342022-05-11 9:25:03940 days ago1652261103IN
handle.fi: Team
0 ETH0.0042954378.15561578
View all transactions

View more zero value Internal Transactions in Advanced View mode

Advanced mode:
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
ForexVesting

Compiler Version
v0.8.0+commit.c7dfd78e

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion
File 1 of 6 : ForexVesting.sol
// SPDX-License-Identifier: MIT
pragma solidity 0.8.0;

import "@openzeppelin/contracts/access/Ownable.sol";
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
import "@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol";

/*                                                *\
 *                ,.-"""-.,                       *
 *               /   ===   \                      *
 *              /  =======  \                     *
 *           __|  (o)   (0)  |__                  *
 *          / _|    .---.    |_ \                 *
 *         | /.----/ O O \----.\ |                *
 *          \/     |     |     \/                 *
 *          |                   |                 *
 *          |                   |                 *
 *          |                   |                 *
 *          _\   -.,_____,.-   /_                 *
 *      ,.-"  "-.,_________,.-"  "-.,             *
 *     /          |       |  ╭-╮     \            *
 *    |           l.     .l  ┃ ┃      |           *
 *    |            |     |   ┃ ╰━━╮   |           *
 *    l.           |     |   ┃ ╭╮ ┃  .l           *
 *     |           l.   .l   ┃ ┃┃ ┃  | \,         *
 *     l.           |   |    ╰-╯╰-╯ .l   \,       *
 *      |           |   |           |      \,     *
 *      l.          |   |          .l        |    *
 *       |          |   |          |         |    *
 *       |          |---|          |         |    *
 *       |          |   |          |         |    *
 *       /"-.,__,.-"\   /"-.,__,.-"\"-.,_,.-"\    *
 *      |            \ /            |         |   *
 *      |             |             |         |   *
 *       \__|__|__|__/ \__|__|__|__/ \_|__|__/    *
\*                                                 */

contract ForexVesting is Ownable {
    using SafeERC20 for IERC20;

    /** @dev Canonical FOREX token address */
    address public immutable FOREX;
    /** @dev The vesting period in seconds at which the FOREX supply for each
             participant is accrued as claimable each second according to their
             vested value */
    uint256 public immutable vestingPeriod;
    /** @dev Minimum delay (in seconds) between user claims. */
    uint256 public immutable minimumClaimDelay;
    /** @dev Date from which participants can claim their immediate value, and
             from which the vested value starts accruing as claimable */
    uint256 public claimStartDate;
    /** @dev Mapping of (participant address => participant vesting data) */
    mapping(address => Participant) public participants;
    /** @dev Total funds required by contract. Used for asserting the contract
             has been correctly funded after deployment */
    uint256 public immutable forexSupply;

    /** @dev Vesting data for participant */
    struct Participant {
        /* Amount initially claimable at any time from the claimStartDate */
        uint256 claimable;
        /* Total vested amount released in equal amounts throughout the
                 vesting period. */
        uint256 vestedValue;
        /* Date at which the participant last claimed FOREX */
        uint256 lastClaimDate;
    }

    event ParticipantAddressChanged(
        address indexed previous,
        address indexed current
    );

    constructor(
        address _FOREX,
        uint256 _vestingPeriod,
        uint256 _minimumClaimDelay,
        address[] memory participantAddresses,
        uint256[] memory initiallyClaimable,
        uint256[] memory vestedValues
    ) {
        // Assert that the minimum claim delay is greater than zero seconds.
        assert(_minimumClaimDelay > 0);
        // Assert that the vesting period is a multiple of the minimum delay.
        assert(_vestingPeriod % _minimumClaimDelay == 0);
        // Assert all array lengths match.
        uint256 length = participantAddresses.length;
        assert(length == initiallyClaimable.length);
        assert(length == vestedValues.length);
        // Initialise immutable variables.
        FOREX = _FOREX;
        vestingPeriod = _vestingPeriod;
        minimumClaimDelay = _minimumClaimDelay;
        uint256 _forexSupply = 0;
        // Initialise participants mapping.
        for (uint256 i = 0; i < length; i++) {
            participants[participantAddresses[i]] = Participant({
                claimable: initiallyClaimable[i],
                vestedValue: vestedValues[i],
                lastClaimDate: 0
            });
            _forexSupply += initiallyClaimable[i] + vestedValues[i];
        }
        forexSupply = _forexSupply;
    }

    /**
     * @dev Transfers claimable FOREX to participant.
     */
    function claim() external {
        require(isClaimable(), "Funds not yet claimable");
        Participant storage participant = participants[msg.sender];
        require(
            block.timestamp >= participant.lastClaimDate + minimumClaimDelay,
            "Must wait before next claim"
        );
        uint256 cutoffTime = getLastCutoffTime(msg.sender);
        uint256 claimable = _balanceOf(msg.sender, cutoffTime);
        if (claimable == 0) return;
        // Reset vesting period for accruing new FOREX.
        // This starts at the claim date and then is incremented in
        // a value multiple of minimumClaimDelay.
        participant.lastClaimDate = cutoffTime;
        // Clear initial claimable amount if claiming for the first time.
        if (participant.claimable > 0) participant.claimable = 0;
        // Transfer tokens.
        IERC20(FOREX).safeTransfer(msg.sender, claimable);
    }

    /**
     * @dev Returns the last valid claim date for a participant.
     *      The difference between this value and the participant's
     *      last claim date is the actual claimable amount that
     *      can be transferred so that the minimum delay also enforces
     *      a minimum FOREX claim granularity.
     * @param account The participant account to fetch the cutoff time for.
     */
    function getLastCutoffTime(address account) public view returns (uint256) {
        Participant storage participant = participants[account];
        uint256 lastClaimDate = getParticipantLastClaimDate(participant);
        uint256 elapsed = block.timestamp - lastClaimDate;
        uint256 remainder = elapsed % minimumClaimDelay;
        if (elapsed > remainder) {
            // At least one cutoff time has passed.
            return lastClaimDate + elapsed - remainder;
        } else {
            // Next cutoff time not yet reached.
            return lastClaimDate;
        }
    }

    /**
     * @dev Returns the parsed last claim date for a participant.
     *      Instead of returning the default date of zero, it returns
     *      the claim start date.
     * @param participant The storage pointer to a participant.
     */
    function getParticipantLastClaimDate(Participant storage participant)
        private
        view
        returns (uint256)
    {
        return
            participant.lastClaimDate > claimStartDate
                ? participant.lastClaimDate
                : claimStartDate;
    }

    /**
     * @dev Returns the accrued FOREX balance for an participant.
     *      This amount may not be fully claimable yet.
     * @param account The participant to fetch the balance for.
     */
    function balanceOf(address account) public view returns (uint256) {
        return _balanceOf(account, block.timestamp);
    }

    /**
     * @dev Returns the claimable FOREX balance for an participant.
     * @param account The participant to fetch the balance for.
     * @param cutoffTime The time to fetch the balance from.
     */
    function _balanceOf(address account, uint256 cutoffTime)
        public
        view
        returns (uint256)
    {
        if (!isClaimable()) return 0;
        Participant storage participant = participants[account];
        uint256 lastClaimed = getParticipantLastClaimDate(participant);
        uint256 vestingCompleteDate = claimStartDate + vestingPeriod;
        // Prevent elapsed from passing the vestingPeriod value.
        uint256 elapsed = cutoffTime > vestingCompleteDate
            ? vestingCompleteDate - lastClaimed
            : cutoffTime - lastClaimed;
        uint256 accrued = (participant.vestedValue * elapsed) / vestingPeriod;
        return participant.claimable + accrued;
    }

    /**
     * @dev Withdraws FOREX for the contract owner.
     * @param amount The amount of FOREX to withdraw.
     */
    function withdrawForex(uint256 amount) external onlyOwner {
        IERC20(FOREX).safeTransfer(msg.sender, amount);
    }

    /**
     * @dev Changes the address for a participant. The new address
     *      will be eligible to claim the currently claimable funds
     *      from the previous address, plus all the accrued funds
     *      until the end of the vesting period.
     * @param previous The previous participant address to be changed.
     * @param current The current participant address to be eligible for claims.
     */
    function changeParticipantAddress(address previous, address current)
        external
        onlyOwner
    {
        require(current != address(0), "Current address cannot be zero");
        require(previous != current, "Addresses are the same");
        Participant storage previousParticipant = participants[previous];
        require(
            doesParticipantExist(previousParticipant),
            "Previous participant does not exist"
        );
        Participant storage currentParticipant = participants[current];
        require(
            !doesParticipantExist(currentParticipant),
            "Next participant already exists"
        );
        currentParticipant.claimable = previousParticipant.claimable;
        currentParticipant.vestedValue = previousParticipant.vestedValue;
        currentParticipant.lastClaimDate = previousParticipant.lastClaimDate;
        delete participants[previous];
        emit ParticipantAddressChanged(previous, current);
    }

    /**
     * @dev Returns whether the participant exists.
     * @param participant Pointer to the participant object.
     */
    function doesParticipantExist(Participant storage participant)
        private
        view
        returns (bool)
    {
        return participant.claimable > 0 || participant.vestedValue > 0;
    }

    /**
     * @dev Enables FOREX claiming from the next block.
     *      Can only be called once.
     */
    function enableForexClaims() public onlyOwner {
        assert(claimStartDate == 0);
        claimStartDate = block.timestamp + 1;
    }

    /**
     * Returns whether the contract is currently claimable.
     */
    function isClaimable() private view returns (bool) {
        return claimStartDate != 0 && block.timestamp >= claimStartDate;
    }
}

File 2 of 6 : Ownable.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "../utils/Context.sol";

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

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _setOwner(_msgSender());
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual 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 {
        _setOwner(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");
        _setOwner(newOwner);
    }

    function _setOwner(address newOwner) private {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

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

pragma solidity ^0.8.0;

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

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

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

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

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

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

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);
}

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

pragma solidity ^0.8.0;

import "../IERC20.sol";
import "../../../utils/Address.sol";

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

    function safeTransfer(
        IERC20 token,
        address to,
        uint256 value
    ) internal {
        _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 5 of 6 : Context.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

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

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

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

pragma solidity ^0.8.0;

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

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

        (bool success, ) = recipient.call{value: amount}("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

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

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

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

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

        (bool success, bytes memory returndata) = target.call{value: value}(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

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

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

        (bool success, bytes memory returndata) = target.staticcall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.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) {
        require(isContract(target), "Address: delegate call to non-contract");

        (bool success, bytes memory returndata) = target.delegatecall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the
     * revert reason 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 {
            // 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

                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

Settings
{
  "optimizer": {
    "enabled": false,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "abi"
      ]
    }
  },
  "libraries": {}
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_FOREX","type":"address"},{"internalType":"uint256","name":"_vestingPeriod","type":"uint256"},{"internalType":"uint256","name":"_minimumClaimDelay","type":"uint256"},{"internalType":"address[]","name":"participantAddresses","type":"address[]"},{"internalType":"uint256[]","name":"initiallyClaimable","type":"uint256[]"},{"internalType":"uint256[]","name":"vestedValues","type":"uint256[]"}],"stateMutability":"nonpayable","type":"constructor"},{"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":"previous","type":"address"},{"indexed":true,"internalType":"address","name":"current","type":"address"}],"name":"ParticipantAddressChanged","type":"event"},{"inputs":[],"name":"FOREX","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"cutoffTime","type":"uint256"}],"name":"_balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"previous","type":"address"},{"internalType":"address","name":"current","type":"address"}],"name":"changeParticipantAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"claim","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"claimStartDate","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"enableForexClaims","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"forexSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getLastCutoffTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minimumClaimDelay","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"participants","outputs":[{"internalType":"uint256","name":"claimable","type":"uint256"},{"internalType":"uint256","name":"vestedValue","type":"uint256"},{"internalType":"uint256","name":"lastClaimDate","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"vestingPeriod","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"withdrawForex","outputs":[],"stateMutability":"nonpayable","type":"function"}]

6101006040523480156200001257600080fd5b50604051620025b0380380620025b08339818101604052810190620000389190620005e8565b620000586200004c620003aa60201b60201c565b620003b260201b60201c565b6000841162000090577f4e487b7100000000000000000000000000000000000000000000000000000000600052600160045260246000fd5b60008486620000a0919062000844565b14620000d5577f4e487b7100000000000000000000000000000000000000000000000000000000600052600160045260246000fd5b6000835190508251811462000113577f4e487b7100000000000000000000000000000000000000000000000000000000600052600160045260246000fd5b815181146200014b577f4e487b7100000000000000000000000000000000000000000000000000000000600052600160045260246000fd5b8673ffffffffffffffffffffffffffffffffffffffff1660808173ffffffffffffffffffffffffffffffffffffffff1660601b815250508560a081815250508460c081815250506000805b8281101562000393576040518060600160405280868381518110620001e4577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b602002602001015181526020018583815181106200022b577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b602002602001015181526020016000815250600260008884815181106200027b577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008201518160000155602082015181600101556040820151816002015590505083818151811062000318577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b60200260200101518582815181106200035a577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b60200260200101516200036e91906200075b565b826200037b91906200075b565b915080806200038a90620007f6565b91505062000196565b508060e0818152505050505050505050506200093d565b600033905090565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050816000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b60006200048d6200048784620006fd565b620006c9565b90508083825260208201905082856020860282011115620004ad57600080fd5b60005b85811015620004e15781620004c6888262000560565b845260208401935060208301925050600181019050620004b0565b5050509392505050565b600062000502620004fc846200072c565b620006c9565b905080838252602082019050828560208602820111156200052257600080fd5b60005b858110156200055657816200053b8882620005d1565b84526020840193506020830192505060018101905062000525565b5050509392505050565b600081519050620005718162000909565b92915050565b600082601f8301126200058957600080fd5b81516200059b84826020860162000476565b91505092915050565b600082601f830112620005b657600080fd5b8151620005c8848260208601620004eb565b91505092915050565b600081519050620005e28162000923565b92915050565b60008060008060008060c087890312156200060257600080fd5b60006200061289828a0162000560565b96505060206200062589828a01620005d1565b95505060406200063889828a01620005d1565b945050606087015167ffffffffffffffff8111156200065657600080fd5b6200066489828a0162000577565b935050608087015167ffffffffffffffff8111156200068257600080fd5b6200069089828a01620005a4565b92505060a087015167ffffffffffffffff811115620006ae57600080fd5b620006bc89828a01620005a4565b9150509295509295509295565b6000604051905081810181811067ffffffffffffffff82111715620006f357620006f2620008da565b5b8060405250919050565b600067ffffffffffffffff8211156200071b576200071a620008da565b5b602082029050602081019050919050565b600067ffffffffffffffff8211156200074a5762000749620008da565b5b602082029050602081019050919050565b60006200076882620007ec565b91506200077583620007ec565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff03821115620007ad57620007ac6200087c565b5b828201905092915050565b6000620007c582620007cc565b9050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b60006200080382620007ec565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8214156200083957620008386200087c565b5b600182019050919050565b60006200085182620007ec565b91506200085e83620007ec565b925082620008715762000870620008ab565b5b828206905092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6200091481620007b8565b81146200092057600080fd5b50565b6200092e81620007ec565b81146200093a57600080fd5b50565b60805160601c60a05160c05160e051611c0c620009a46000396000610ba501526000818161037c0152818161046b0152610daf01526000818161061c015281816106a9015261070401526000818161052f01528181610b5c0152610c930152611c0c6000f3fe608060405234801561001057600080fd5b50600436106101005760003560e01c80637d9de14311610097578063b78d821311610066578063b78d82131461028b578063c705b99714610295578063f2fde38b146102b3578063fdbba469146102cf57610100565b80637d9de143146102175780638da5cb5b146102335780638fd0637914610251578063986e2fb11461026d57610100565b806370a08231116100d357806370a082311461018f578063715018a6146101bf5780637313ee5a146101c9578063787d2f30146101e757610100565b806309e69ede1461010557806343a52776146101375780634e71d92d146101675780635f03b6b214610171575b600080fd5b61011f600480360381019061011a919061122d565b6102ed565b60405161012e939291906118f8565b60405180910390f35b610151600480360381019061014c919061122d565b610317565b60405161015e91906118dd565b60405180910390f35b61016f6103df565b005b610179610579565b60405161018691906118dd565b60405180910390f35b6101a960048036038101906101a4919061122d565b61057f565b6040516101b691906118dd565b60405180910390f35b6101c7610592565b005b6101d161061a565b6040516101de91906118dd565b60405180910390f35b61020160048036038101906101fc9190611292565b61063e565b60405161020e91906118dd565b60405180910390f35b610231600480360381019061022c9190611256565b61075d565b005b61023b610ab0565b6040516102489190611717565b60405180910390f35b61026b600480360381019061026691906112f7565b610ad9565b005b610275610ba3565b60405161028291906118dd565b60405180910390f35b610293610bc7565b005b61029d610c91565b6040516102aa9190611717565b60405180910390f35b6102cd60048036038101906102c8919061122d565b610cb5565b005b6102d7610dad565b6040516102e491906118dd565b60405180910390f35b60026020528060005260406000206000915090508060000154908060010154908060020154905083565b600080600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000209050600061036682610dd1565b9050600081426103769190611a42565b905060007f0000000000000000000000000000000000000000000000000000000000000000826103a69190611af1565b9050808211156103d2578082846103bd9190611961565b6103c79190611a42565b9450505050506103da565b829450505050505b919050565b6103e7610df5565b610426576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161041d9061181d565b60405180910390fd5b6000600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090507f000000000000000000000000000000000000000000000000000000000000000081600201546104999190611961565b4210156104db576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016104d29061187d565b60405180910390fd5b60006104e633610317565b905060006104f4338361063e565b9050600081141561050757505050610577565b81836002018190555060008360000154111561052857600083600001819055505b61057333827f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff16610e109092919063ffffffff16565b5050505b565b60015481565b600061058b824261063e565b9050919050565b61059a610e96565b73ffffffffffffffffffffffffffffffffffffffff166105b8610ab0565b73ffffffffffffffffffffffffffffffffffffffff161461060e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106059061185d565b60405180910390fd5b6106186000610e9e565b565b7f000000000000000000000000000000000000000000000000000000000000000081565b6000610648610df5565b6106555760009050610757565b6000600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905060006106a382610dd1565b905060007f00000000000000000000000000000000000000000000000000000000000000006001546106d59190611961565b905060008186116106f15782866106ec9190611a42565b6106fe565b82826106fd9190611a42565b5b905060007f000000000000000000000000000000000000000000000000000000000000000082866001015461073391906119e8565b61073d91906119b7565b905080856000015461074f9190611961565b955050505050505b92915050565b610765610e96565b73ffffffffffffffffffffffffffffffffffffffff16610783610ab0565b73ffffffffffffffffffffffffffffffffffffffff16146107d9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107d09061185d565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610849576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610840906117dd565b60405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156108b8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108af9061183d565b60405180910390fd5b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905061090481610f62565b610943576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161093a9061179d565b60405180910390fd5b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905061098f81610f62565b156109cf576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016109c69061177d565b60405180910390fd5b816000015481600001819055508160010154816001018190555081600201548160020181905550600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000808201600090556001820160009055600282016000905550508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167f79c2af83e125c7d8a9c7279d001069b807c1844617f6e5c826ba067226a3b05360405160405180910390a350505050565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b610ae1610e96565b73ffffffffffffffffffffffffffffffffffffffff16610aff610ab0565b73ffffffffffffffffffffffffffffffffffffffff1614610b55576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b4c9061185d565b60405180910390fd5b610ba033827f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff16610e109092919063ffffffff16565b50565b7f000000000000000000000000000000000000000000000000000000000000000081565b610bcf610e96565b73ffffffffffffffffffffffffffffffffffffffff16610bed610ab0565b73ffffffffffffffffffffffffffffffffffffffff1614610c43576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c3a9061185d565b60405180910390fd5b600060015414610c7c577f4e487b7100000000000000000000000000000000000000000000000000000000600052600160045260246000fd5b600142610c899190611961565b600181905550565b7f000000000000000000000000000000000000000000000000000000000000000081565b610cbd610e96565b73ffffffffffffffffffffffffffffffffffffffff16610cdb610ab0565b73ffffffffffffffffffffffffffffffffffffffff1614610d31576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d289061185d565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610da1576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d98906117bd565b60405180910390fd5b610daa81610e9e565b50565b7f000000000000000000000000000000000000000000000000000000000000000081565b6000600154826002015411610de857600154610dee565b81600201545b9050919050565b60008060015414158015610e0b57506001544210155b905090565b610e918363a9059cbb60e01b8484604051602401610e2f929190611732565b604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050610f81565b505050565b600033905090565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050816000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b60008082600001541180610f7a575060008260010154115b9050919050565b6000610fe3826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c65648152508573ffffffffffffffffffffffffffffffffffffffff166110489092919063ffffffff16565b9050600081511115611043578080602001905181019061100391906112ce565b611042576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611039906118bd565b60405180910390fd5b5b505050565b60606110578484600085611060565b90509392505050565b6060824710156110a5576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161109c906117fd565b60405180910390fd5b6110ae85611174565b6110ed576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110e49061189d565b60405180910390fd5b6000808673ffffffffffffffffffffffffffffffffffffffff1685876040516111169190611700565b60006040518083038185875af1925050503d8060008114611153576040519150601f19603f3d011682016040523d82523d6000602084013e611158565b606091505b5091509150611168828286611187565b92505050949350505050565b600080823b905060008111915050919050565b60608315611197578290506111e7565b6000835111156111aa5782518084602001fd5b816040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111de919061175b565b60405180910390fd5b9392505050565b6000813590506111fd81611b91565b92915050565b60008151905061121281611ba8565b92915050565b60008135905061122781611bbf565b92915050565b60006020828403121561123f57600080fd5b600061124d848285016111ee565b91505092915050565b6000806040838503121561126957600080fd5b6000611277858286016111ee565b9250506020611288858286016111ee565b9150509250929050565b600080604083850312156112a557600080fd5b60006112b3858286016111ee565b92505060206112c485828601611218565b9150509250929050565b6000602082840312156112e057600080fd5b60006112ee84828501611203565b91505092915050565b60006020828403121561130957600080fd5b600061131784828501611218565b91505092915050565b61132981611a76565b82525050565b600061133a8261192f565b6113448185611945565b9350611354818560208601611abe565b80840191505092915050565b600061136b8261193a565b6113758185611950565b9350611385818560208601611abe565b61138e81611b80565b840191505092915050565b60006113a6601f83611950565b91507f4e657874207061727469636970616e7420616c726561647920657869737473006000830152602082019050919050565b60006113e6602383611950565b91507f50726576696f7573207061727469636970616e7420646f6573206e6f7420657860008301527f69737400000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b600061144c602683611950565b91507f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008301527f64647265737300000000000000000000000000000000000000000000000000006020830152604082019050919050565b60006114b2601e83611950565b91507f43757272656e7420616464726573732063616e6e6f74206265207a65726f00006000830152602082019050919050565b60006114f2602683611950565b91507f416464726573733a20696e73756666696369656e742062616c616e636520666f60008301527f722063616c6c00000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000611558601783611950565b91507f46756e6473206e6f742079657420636c61696d61626c650000000000000000006000830152602082019050919050565b6000611598601683611950565b91507f41646472657373657320617265207468652073616d65000000000000000000006000830152602082019050919050565b60006115d8602083611950565b91507f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726000830152602082019050919050565b6000611618601b83611950565b91507f4d7573742077616974206265666f7265206e65787420636c61696d00000000006000830152602082019050919050565b6000611658601d83611950565b91507f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006000830152602082019050919050565b6000611698602a83611950565b91507f5361666545524332303a204552433230206f7065726174696f6e20646964206e60008301527f6f742073756363656564000000000000000000000000000000000000000000006020830152604082019050919050565b6116fa81611ab4565b82525050565b600061170c828461132f565b915081905092915050565b600060208201905061172c6000830184611320565b92915050565b60006040820190506117476000830185611320565b61175460208301846116f1565b9392505050565b600060208201905081810360008301526117758184611360565b905092915050565b6000602082019050818103600083015261179681611399565b9050919050565b600060208201905081810360008301526117b6816113d9565b9050919050565b600060208201905081810360008301526117d68161143f565b9050919050565b600060208201905081810360008301526117f6816114a5565b9050919050565b60006020820190508181036000830152611816816114e5565b9050919050565b600060208201905081810360008301526118368161154b565b9050919050565b600060208201905081810360008301526118568161158b565b9050919050565b60006020820190508181036000830152611876816115cb565b9050919050565b600060208201905081810360008301526118968161160b565b9050919050565b600060208201905081810360008301526118b68161164b565b9050919050565b600060208201905081810360008301526118d68161168b565b9050919050565b60006020820190506118f260008301846116f1565b92915050565b600060608201905061190d60008301866116f1565b61191a60208301856116f1565b61192760408301846116f1565b949350505050565b600081519050919050565b600081519050919050565b600081905092915050565b600082825260208201905092915050565b600061196c82611ab4565b915061197783611ab4565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff038211156119ac576119ab611b22565b5b828201905092915050565b60006119c282611ab4565b91506119cd83611ab4565b9250826119dd576119dc611b51565b5b828204905092915050565b60006119f382611ab4565b91506119fe83611ab4565b9250817fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0483118215151615611a3757611a36611b22565b5b828202905092915050565b6000611a4d82611ab4565b9150611a5883611ab4565b925082821015611a6b57611a6a611b22565b5b828203905092915050565b6000611a8182611a94565b9050919050565b60008115159050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b60005b83811015611adc578082015181840152602081019050611ac1565b83811115611aeb576000848401525b50505050565b6000611afc82611ab4565b9150611b0783611ab4565b925082611b1757611b16611b51565b5b828206905092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b6000601f19601f8301169050919050565b611b9a81611a76565b8114611ba557600080fd5b50565b611bb181611a88565b8114611bbc57600080fd5b50565b611bc881611ab4565b8114611bd357600080fd5b5056fea2646970667358221220dd3bffeb98b069bd10da372ace382863211874c14b20b1e580a086095e476ef064736f6c63430008000033000000000000000000000000db298285fe4c5410b05390ca80e8fbe9de1f259b0000000000000000000000000000000000000000000000000000000002c7ea000000000000000000000000000000000000000000000000000000000000278d0000000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000030000000000000000000000000000000000000000000000000000000000000005400000000000000000000000000000000000000000000000000000000000000011000000000000000000000000b80d80c0745f976a8beb96fc2a4d934842fd52b6000000000000000000000000fd88eb2104604bba4222877a7232a588d4ed7c4300000000000000000000000053ce118c794d567922cb30b41397681a7528bf160000000000000000000000005029425723173130e47b3d0c715e018f6cb601080000000000000000000000001880c138b8c3d8cb4eadf9e105d05d75e4a0fac80000000000000000000000002de2d1402adce82ddc8248c754f4f43b5ca3488b0000000000000000000000009a85c9c497c006cd6ef33196e98a586e0f5482b3000000000000000000000000f11ad7917d815e67b03201464f0c0a18177cfa3e0000000000000000000000002ca78b53fd1f80ea9e4516e26efbc5ced04b738e000000000000000000000000619a1ccb9f8a7560773f869bdb7869ef780381eb000000000000000000000000a08436d4e74e6ba4d1b736e2e65e0f14b4bb05e5000000000000000000000000471903799a45c6da3ec2a3a6ffaba20aaec9e97300000000000000000000000078c5fa233eb07486333b91aca0a6cfa198b2445900000000000000000000000087a89626be393803e4235ff3e0ffe2d55af7b2a00000000000000000000000002239012fee70096b424a25d5d9ce5c7abde1c2aa000000000000000000000000ed51e6550f085a46ef4a47f3f65f025a98c3e940000000000000000000000000403097babb6a5e2a2b0a7aa40b216dac887b89300000000000000000000000000000000000000000000000000000000000000011000000000000000000000000000000000000000000010ad0bca349e3bb8000000000000000000000000000000000000000000000000163c0fb846284fa000000000000000000000000000000000000000000000000010ad0bca349e3bb8000000000000000000000000000000000000000000000000058f03ee118a13e8000000000000000000000000000000000000000000000000085685e51a4f1ddc0000000000000000000000000000000000000000000000000b1e07dc231427d00000000000000000000000000000000000000000000000000de589d32bd931c4000000000000000000000000000000000000000000000000058f03ee118a13e80000000000000000000000000000000000000000000000000b1e07dc231427d000000000000000000000000000000000000000000000000002c781f708c509f400000000000000000000000000000000000000000000000002c781f708c509f400000000000000000000000000000000000000000000000002c781f708c509f400000000000000000000000000000000000000000000000000d573ca1c3b1c96000000000000000000000000000000000000000000000000005ede20f01a45980000000000000000000000000000000000000000000000000017b7883c069166000000000000000000000000000000000000000000000000011c9a62d04ed0c800000000000000000000000000000000000000000000000000639c6f6281fc46000000000000000000000000000000000000000000000000000000000000000000011000000000000000000000000000000000000000000096156a1bd9901978000000000000000000000000000000000000000000000000c81c8d7a776acca000000000000000000000000000000000000000000000000096156a1bd99019780000000000000000000000000000000000000000000000003207235e9ddab3280000000000000000000000000000000000000000000000004b0ab50decc80cbc000000000000000000000000000000000000000000000000640e46bd3bb566500000000000000000000000000000000000000000000000007d11d86c8aa2bfe40000000000000000000000000000000000000000000000003207235e9ddab328000000000000000000000000000000000000000000000000640e46bd3bb56650000000000000000000000000000000000000000000000000190391af4eed5994000000000000000000000000000000000000000000000000190391af4eed5994000000000000000000000000000000000000000000000000190391af4eed59940000000000000000000000000000000000000000000000000781121afe1401460000000000000000000000000000000000000000000000000355cf2870ec725800000000000000000000000000000000000000000000000000d573ca1c3b1c960000000000000000000000000000000000000000000000000a016d7952c5570800000000000000000000000000000000000000000000000003807fea7691de7600000

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101005760003560e01c80637d9de14311610097578063b78d821311610066578063b78d82131461028b578063c705b99714610295578063f2fde38b146102b3578063fdbba469146102cf57610100565b80637d9de143146102175780638da5cb5b146102335780638fd0637914610251578063986e2fb11461026d57610100565b806370a08231116100d357806370a082311461018f578063715018a6146101bf5780637313ee5a146101c9578063787d2f30146101e757610100565b806309e69ede1461010557806343a52776146101375780634e71d92d146101675780635f03b6b214610171575b600080fd5b61011f600480360381019061011a919061122d565b6102ed565b60405161012e939291906118f8565b60405180910390f35b610151600480360381019061014c919061122d565b610317565b60405161015e91906118dd565b60405180910390f35b61016f6103df565b005b610179610579565b60405161018691906118dd565b60405180910390f35b6101a960048036038101906101a4919061122d565b61057f565b6040516101b691906118dd565b60405180910390f35b6101c7610592565b005b6101d161061a565b6040516101de91906118dd565b60405180910390f35b61020160048036038101906101fc9190611292565b61063e565b60405161020e91906118dd565b60405180910390f35b610231600480360381019061022c9190611256565b61075d565b005b61023b610ab0565b6040516102489190611717565b60405180910390f35b61026b600480360381019061026691906112f7565b610ad9565b005b610275610ba3565b60405161028291906118dd565b60405180910390f35b610293610bc7565b005b61029d610c91565b6040516102aa9190611717565b60405180910390f35b6102cd60048036038101906102c8919061122d565b610cb5565b005b6102d7610dad565b6040516102e491906118dd565b60405180910390f35b60026020528060005260406000206000915090508060000154908060010154908060020154905083565b600080600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000209050600061036682610dd1565b9050600081426103769190611a42565b905060007f0000000000000000000000000000000000000000000000000000000000278d00826103a69190611af1565b9050808211156103d2578082846103bd9190611961565b6103c79190611a42565b9450505050506103da565b829450505050505b919050565b6103e7610df5565b610426576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161041d9061181d565b60405180910390fd5b6000600260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090507f0000000000000000000000000000000000000000000000000000000000278d0081600201546104999190611961565b4210156104db576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016104d29061187d565b60405180910390fd5b60006104e633610317565b905060006104f4338361063e565b9050600081141561050757505050610577565b81836002018190555060008360000154111561052857600083600001819055505b61057333827f000000000000000000000000db298285fe4c5410b05390ca80e8fbe9de1f259b73ffffffffffffffffffffffffffffffffffffffff16610e109092919063ffffffff16565b5050505b565b60015481565b600061058b824261063e565b9050919050565b61059a610e96565b73ffffffffffffffffffffffffffffffffffffffff166105b8610ab0565b73ffffffffffffffffffffffffffffffffffffffff161461060e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106059061185d565b60405180910390fd5b6106186000610e9e565b565b7f0000000000000000000000000000000000000000000000000000000002c7ea0081565b6000610648610df5565b6106555760009050610757565b6000600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905060006106a382610dd1565b905060007f0000000000000000000000000000000000000000000000000000000002c7ea006001546106d59190611961565b905060008186116106f15782866106ec9190611a42565b6106fe565b82826106fd9190611a42565b5b905060007f0000000000000000000000000000000000000000000000000000000002c7ea0082866001015461073391906119e8565b61073d91906119b7565b905080856000015461074f9190611961565b955050505050505b92915050565b610765610e96565b73ffffffffffffffffffffffffffffffffffffffff16610783610ab0565b73ffffffffffffffffffffffffffffffffffffffff16146107d9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107d09061185d565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610849576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610840906117dd565b60405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156108b8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108af9061183d565b60405180910390fd5b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905061090481610f62565b610943576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161093a9061179d565b60405180910390fd5b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905061098f81610f62565b156109cf576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016109c69061177d565b60405180910390fd5b816000015481600001819055508160010154816001018190555081600201548160020181905550600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000808201600090556001820160009055600282016000905550508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167f79c2af83e125c7d8a9c7279d001069b807c1844617f6e5c826ba067226a3b05360405160405180910390a350505050565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b610ae1610e96565b73ffffffffffffffffffffffffffffffffffffffff16610aff610ab0565b73ffffffffffffffffffffffffffffffffffffffff1614610b55576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b4c9061185d565b60405180910390fd5b610ba033827f000000000000000000000000db298285fe4c5410b05390ca80e8fbe9de1f259b73ffffffffffffffffffffffffffffffffffffffff16610e109092919063ffffffff16565b50565b7f0000000000000000000000000000000000000000004c716cfa78ab63e2c0000081565b610bcf610e96565b73ffffffffffffffffffffffffffffffffffffffff16610bed610ab0565b73ffffffffffffffffffffffffffffffffffffffff1614610c43576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c3a9061185d565b60405180910390fd5b600060015414610c7c577f4e487b7100000000000000000000000000000000000000000000000000000000600052600160045260246000fd5b600142610c899190611961565b600181905550565b7f000000000000000000000000db298285fe4c5410b05390ca80e8fbe9de1f259b81565b610cbd610e96565b73ffffffffffffffffffffffffffffffffffffffff16610cdb610ab0565b73ffffffffffffffffffffffffffffffffffffffff1614610d31576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d289061185d565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610da1576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d98906117bd565b60405180910390fd5b610daa81610e9e565b50565b7f0000000000000000000000000000000000000000000000000000000000278d0081565b6000600154826002015411610de857600154610dee565b81600201545b9050919050565b60008060015414158015610e0b57506001544210155b905090565b610e918363a9059cbb60e01b8484604051602401610e2f929190611732565b604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050610f81565b505050565b600033905090565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050816000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b60008082600001541180610f7a575060008260010154115b9050919050565b6000610fe3826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c65648152508573ffffffffffffffffffffffffffffffffffffffff166110489092919063ffffffff16565b9050600081511115611043578080602001905181019061100391906112ce565b611042576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611039906118bd565b60405180910390fd5b5b505050565b60606110578484600085611060565b90509392505050565b6060824710156110a5576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161109c906117fd565b60405180910390fd5b6110ae85611174565b6110ed576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110e49061189d565b60405180910390fd5b6000808673ffffffffffffffffffffffffffffffffffffffff1685876040516111169190611700565b60006040518083038185875af1925050503d8060008114611153576040519150601f19603f3d011682016040523d82523d6000602084013e611158565b606091505b5091509150611168828286611187565b92505050949350505050565b600080823b905060008111915050919050565b60608315611197578290506111e7565b6000835111156111aa5782518084602001fd5b816040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111de919061175b565b60405180910390fd5b9392505050565b6000813590506111fd81611b91565b92915050565b60008151905061121281611ba8565b92915050565b60008135905061122781611bbf565b92915050565b60006020828403121561123f57600080fd5b600061124d848285016111ee565b91505092915050565b6000806040838503121561126957600080fd5b6000611277858286016111ee565b9250506020611288858286016111ee565b9150509250929050565b600080604083850312156112a557600080fd5b60006112b3858286016111ee565b92505060206112c485828601611218565b9150509250929050565b6000602082840312156112e057600080fd5b60006112ee84828501611203565b91505092915050565b60006020828403121561130957600080fd5b600061131784828501611218565b91505092915050565b61132981611a76565b82525050565b600061133a8261192f565b6113448185611945565b9350611354818560208601611abe565b80840191505092915050565b600061136b8261193a565b6113758185611950565b9350611385818560208601611abe565b61138e81611b80565b840191505092915050565b60006113a6601f83611950565b91507f4e657874207061727469636970616e7420616c726561647920657869737473006000830152602082019050919050565b60006113e6602383611950565b91507f50726576696f7573207061727469636970616e7420646f6573206e6f7420657860008301527f69737400000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b600061144c602683611950565b91507f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008301527f64647265737300000000000000000000000000000000000000000000000000006020830152604082019050919050565b60006114b2601e83611950565b91507f43757272656e7420616464726573732063616e6e6f74206265207a65726f00006000830152602082019050919050565b60006114f2602683611950565b91507f416464726573733a20696e73756666696369656e742062616c616e636520666f60008301527f722063616c6c00000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000611558601783611950565b91507f46756e6473206e6f742079657420636c61696d61626c650000000000000000006000830152602082019050919050565b6000611598601683611950565b91507f41646472657373657320617265207468652073616d65000000000000000000006000830152602082019050919050565b60006115d8602083611950565b91507f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726000830152602082019050919050565b6000611618601b83611950565b91507f4d7573742077616974206265666f7265206e65787420636c61696d00000000006000830152602082019050919050565b6000611658601d83611950565b91507f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006000830152602082019050919050565b6000611698602a83611950565b91507f5361666545524332303a204552433230206f7065726174696f6e20646964206e60008301527f6f742073756363656564000000000000000000000000000000000000000000006020830152604082019050919050565b6116fa81611ab4565b82525050565b600061170c828461132f565b915081905092915050565b600060208201905061172c6000830184611320565b92915050565b60006040820190506117476000830185611320565b61175460208301846116f1565b9392505050565b600060208201905081810360008301526117758184611360565b905092915050565b6000602082019050818103600083015261179681611399565b9050919050565b600060208201905081810360008301526117b6816113d9565b9050919050565b600060208201905081810360008301526117d68161143f565b9050919050565b600060208201905081810360008301526117f6816114a5565b9050919050565b60006020820190508181036000830152611816816114e5565b9050919050565b600060208201905081810360008301526118368161154b565b9050919050565b600060208201905081810360008301526118568161158b565b9050919050565b60006020820190508181036000830152611876816115cb565b9050919050565b600060208201905081810360008301526118968161160b565b9050919050565b600060208201905081810360008301526118b68161164b565b9050919050565b600060208201905081810360008301526118d68161168b565b9050919050565b60006020820190506118f260008301846116f1565b92915050565b600060608201905061190d60008301866116f1565b61191a60208301856116f1565b61192760408301846116f1565b949350505050565b600081519050919050565b600081519050919050565b600081905092915050565b600082825260208201905092915050565b600061196c82611ab4565b915061197783611ab4565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff038211156119ac576119ab611b22565b5b828201905092915050565b60006119c282611ab4565b91506119cd83611ab4565b9250826119dd576119dc611b51565b5b828204905092915050565b60006119f382611ab4565b91506119fe83611ab4565b9250817fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0483118215151615611a3757611a36611b22565b5b828202905092915050565b6000611a4d82611ab4565b9150611a5883611ab4565b925082821015611a6b57611a6a611b22565b5b828203905092915050565b6000611a8182611a94565b9050919050565b60008115159050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b60005b83811015611adc578082015181840152602081019050611ac1565b83811115611aeb576000848401525b50505050565b6000611afc82611ab4565b9150611b0783611ab4565b925082611b1757611b16611b51565b5b828206905092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b6000601f19601f8301169050919050565b611b9a81611a76565b8114611ba557600080fd5b50565b611bb181611a88565b8114611bbc57600080fd5b50565b611bc881611ab4565b8114611bd357600080fd5b5056fea2646970667358221220dd3bffeb98b069bd10da372ace382863211874c14b20b1e580a086095e476ef064736f6c63430008000033

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

000000000000000000000000db298285fe4c5410b05390ca80e8fbe9de1f259b0000000000000000000000000000000000000000000000000000000002c7ea000000000000000000000000000000000000000000000000000000000000278d0000000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000030000000000000000000000000000000000000000000000000000000000000005400000000000000000000000000000000000000000000000000000000000000011000000000000000000000000b80d80c0745f976a8beb96fc2a4d934842fd52b6000000000000000000000000fd88eb2104604bba4222877a7232a588d4ed7c4300000000000000000000000053ce118c794d567922cb30b41397681a7528bf160000000000000000000000005029425723173130e47b3d0c715e018f6cb601080000000000000000000000001880c138b8c3d8cb4eadf9e105d05d75e4a0fac80000000000000000000000002de2d1402adce82ddc8248c754f4f43b5ca3488b0000000000000000000000009a85c9c497c006cd6ef33196e98a586e0f5482b3000000000000000000000000f11ad7917d815e67b03201464f0c0a18177cfa3e0000000000000000000000002ca78b53fd1f80ea9e4516e26efbc5ced04b738e000000000000000000000000619a1ccb9f8a7560773f869bdb7869ef780381eb000000000000000000000000a08436d4e74e6ba4d1b736e2e65e0f14b4bb05e5000000000000000000000000471903799a45c6da3ec2a3a6ffaba20aaec9e97300000000000000000000000078c5fa233eb07486333b91aca0a6cfa198b2445900000000000000000000000087a89626be393803e4235ff3e0ffe2d55af7b2a00000000000000000000000002239012fee70096b424a25d5d9ce5c7abde1c2aa000000000000000000000000ed51e6550f085a46ef4a47f3f65f025a98c3e940000000000000000000000000403097babb6a5e2a2b0a7aa40b216dac887b89300000000000000000000000000000000000000000000000000000000000000011000000000000000000000000000000000000000000010ad0bca349e3bb8000000000000000000000000000000000000000000000000163c0fb846284fa000000000000000000000000000000000000000000000000010ad0bca349e3bb8000000000000000000000000000000000000000000000000058f03ee118a13e8000000000000000000000000000000000000000000000000085685e51a4f1ddc0000000000000000000000000000000000000000000000000b1e07dc231427d00000000000000000000000000000000000000000000000000de589d32bd931c4000000000000000000000000000000000000000000000000058f03ee118a13e80000000000000000000000000000000000000000000000000b1e07dc231427d000000000000000000000000000000000000000000000000002c781f708c509f400000000000000000000000000000000000000000000000002c781f708c509f400000000000000000000000000000000000000000000000002c781f708c509f400000000000000000000000000000000000000000000000000d573ca1c3b1c96000000000000000000000000000000000000000000000000005ede20f01a45980000000000000000000000000000000000000000000000000017b7883c069166000000000000000000000000000000000000000000000000011c9a62d04ed0c800000000000000000000000000000000000000000000000000639c6f6281fc46000000000000000000000000000000000000000000000000000000000000000000011000000000000000000000000000000000000000000096156a1bd9901978000000000000000000000000000000000000000000000000c81c8d7a776acca000000000000000000000000000000000000000000000000096156a1bd99019780000000000000000000000000000000000000000000000003207235e9ddab3280000000000000000000000000000000000000000000000004b0ab50decc80cbc000000000000000000000000000000000000000000000000640e46bd3bb566500000000000000000000000000000000000000000000000007d11d86c8aa2bfe40000000000000000000000000000000000000000000000003207235e9ddab328000000000000000000000000000000000000000000000000640e46bd3bb56650000000000000000000000000000000000000000000000000190391af4eed5994000000000000000000000000000000000000000000000000190391af4eed5994000000000000000000000000000000000000000000000000190391af4eed59940000000000000000000000000000000000000000000000000781121afe1401460000000000000000000000000000000000000000000000000355cf2870ec725800000000000000000000000000000000000000000000000000d573ca1c3b1c960000000000000000000000000000000000000000000000000a016d7952c5570800000000000000000000000000000000000000000000000003807fea7691de7600000

-----Decoded View---------------
Arg [0] : _FOREX (address): 0xDb298285FE4C5410B05390cA80e8Fbe9DE1F259B
Arg [1] : _vestingPeriod (uint256): 46656000
Arg [2] : _minimumClaimDelay (uint256): 2592000
Arg [3] : participantAddresses (address[]): 0xB80d80C0745F976A8bEb96fC2A4D934842FD52b6,0xfD88eB2104604bBa4222877A7232a588d4Ed7c43,0x53ce118C794D567922cb30b41397681A7528bF16,0x5029425723173130e47B3d0c715e018F6cb60108,0x1880c138B8C3D8cB4EadF9E105d05D75e4a0fAc8,0x2dE2d1402ADCe82DDc8248c754F4f43b5CA3488B,0x9a85C9C497c006Cd6Ef33196E98A586e0F5482B3,0xf11Ad7917D815e67B03201464f0C0A18177cFa3E,0x2Ca78B53FD1F80EA9e4516E26eFBC5CeD04b738e,0x619a1CcB9F8a7560773f869bDB7869ef780381eB,0xA08436D4e74e6ba4d1b736E2E65E0f14B4Bb05E5,0x471903799A45c6da3eC2a3a6fFAbA20AAeC9e973,0x78C5Fa233Eb07486333B91aCA0A6CFa198B24459,0x87a89626be393803e4235FF3E0ffe2d55af7B2a0,0x2239012FEe70096B424A25d5d9Ce5c7abDe1C2aa,0xeD51E6550f085A46EF4a47f3f65F025a98C3E940,0x403097bABb6A5e2A2b0A7AA40b216Dac887b8930
Arg [4] : initiallyClaimable (uint256[]): 1260000000000000000000000,1680000000000000000000000,1260000000000000000000000,420000000000000000000000,630000000000000000000000,840000000000000000000000,1050000000000000000000000,420000000000000000000000,840000000000000000000000,210000000000000000000000,210000000000000000000000,210000000000000000000000,63000000000000000000000,28000000000000000000000,7000000000000000000000,84000000000000000000000,29400000000000000000000
Arg [5] : vestedValues (uint256[]): 11340000000000000000000000,15120000000000000000000000,11340000000000000000000000,3780000000000000000000000,5670000000000000000000000,7560000000000000000000000,9450000000000000000000000,3780000000000000000000000,7560000000000000000000000,1890000000000000000000000,1890000000000000000000000,1890000000000000000000000,567000000000000000000000,252000000000000000000000,63000000000000000000000,756000000000000000000000,264600000000000000000000

-----Encoded View---------------
60 Constructor Arguments found :
Arg [0] : 000000000000000000000000db298285fe4c5410b05390ca80e8fbe9de1f259b
Arg [1] : 0000000000000000000000000000000000000000000000000000000002c7ea00
Arg [2] : 0000000000000000000000000000000000000000000000000000000000278d00
Arg [3] : 00000000000000000000000000000000000000000000000000000000000000c0
Arg [4] : 0000000000000000000000000000000000000000000000000000000000000300
Arg [5] : 0000000000000000000000000000000000000000000000000000000000000540
Arg [6] : 0000000000000000000000000000000000000000000000000000000000000011
Arg [7] : 000000000000000000000000b80d80c0745f976a8beb96fc2a4d934842fd52b6
Arg [8] : 000000000000000000000000fd88eb2104604bba4222877a7232a588d4ed7c43
Arg [9] : 00000000000000000000000053ce118c794d567922cb30b41397681a7528bf16
Arg [10] : 0000000000000000000000005029425723173130e47b3d0c715e018f6cb60108
Arg [11] : 0000000000000000000000001880c138b8c3d8cb4eadf9e105d05d75e4a0fac8
Arg [12] : 0000000000000000000000002de2d1402adce82ddc8248c754f4f43b5ca3488b
Arg [13] : 0000000000000000000000009a85c9c497c006cd6ef33196e98a586e0f5482b3
Arg [14] : 000000000000000000000000f11ad7917d815e67b03201464f0c0a18177cfa3e
Arg [15] : 0000000000000000000000002ca78b53fd1f80ea9e4516e26efbc5ced04b738e
Arg [16] : 000000000000000000000000619a1ccb9f8a7560773f869bdb7869ef780381eb
Arg [17] : 000000000000000000000000a08436d4e74e6ba4d1b736e2e65e0f14b4bb05e5
Arg [18] : 000000000000000000000000471903799a45c6da3ec2a3a6ffaba20aaec9e973
Arg [19] : 00000000000000000000000078c5fa233eb07486333b91aca0a6cfa198b24459
Arg [20] : 00000000000000000000000087a89626be393803e4235ff3e0ffe2d55af7b2a0
Arg [21] : 0000000000000000000000002239012fee70096b424a25d5d9ce5c7abde1c2aa
Arg [22] : 000000000000000000000000ed51e6550f085a46ef4a47f3f65f025a98c3e940
Arg [23] : 000000000000000000000000403097babb6a5e2a2b0a7aa40b216dac887b8930
Arg [24] : 0000000000000000000000000000000000000000000000000000000000000011
Arg [25] : 000000000000000000000000000000000000000000010ad0bca349e3bb800000
Arg [26] : 0000000000000000000000000000000000000000000163c0fb846284fa000000
Arg [27] : 000000000000000000000000000000000000000000010ad0bca349e3bb800000
Arg [28] : 0000000000000000000000000000000000000000000058f03ee118a13e800000
Arg [29] : 0000000000000000000000000000000000000000000085685e51a4f1ddc00000
Arg [30] : 00000000000000000000000000000000000000000000b1e07dc231427d000000
Arg [31] : 00000000000000000000000000000000000000000000de589d32bd931c400000
Arg [32] : 0000000000000000000000000000000000000000000058f03ee118a13e800000
Arg [33] : 00000000000000000000000000000000000000000000b1e07dc231427d000000
Arg [34] : 000000000000000000000000000000000000000000002c781f708c509f400000
Arg [35] : 000000000000000000000000000000000000000000002c781f708c509f400000
Arg [36] : 000000000000000000000000000000000000000000002c781f708c509f400000
Arg [37] : 000000000000000000000000000000000000000000000d573ca1c3b1c9600000
Arg [38] : 0000000000000000000000000000000000000000000005ede20f01a459800000
Arg [39] : 00000000000000000000000000000000000000000000017b7883c06916600000
Arg [40] : 0000000000000000000000000000000000000000000011c9a62d04ed0c800000
Arg [41] : 000000000000000000000000000000000000000000000639c6f6281fc4600000
Arg [42] : 0000000000000000000000000000000000000000000000000000000000000011
Arg [43] : 000000000000000000000000000000000000000000096156a1bd990197800000
Arg [44] : 0000000000000000000000000000000000000000000c81c8d7a776acca000000
Arg [45] : 000000000000000000000000000000000000000000096156a1bd990197800000
Arg [46] : 00000000000000000000000000000000000000000003207235e9ddab32800000
Arg [47] : 00000000000000000000000000000000000000000004b0ab50decc80cbc00000
Arg [48] : 0000000000000000000000000000000000000000000640e46bd3bb5665000000
Arg [49] : 00000000000000000000000000000000000000000007d11d86c8aa2bfe400000
Arg [50] : 00000000000000000000000000000000000000000003207235e9ddab32800000
Arg [51] : 0000000000000000000000000000000000000000000640e46bd3bb5665000000
Arg [52] : 0000000000000000000000000000000000000000000190391af4eed599400000
Arg [53] : 0000000000000000000000000000000000000000000190391af4eed599400000
Arg [54] : 0000000000000000000000000000000000000000000190391af4eed599400000
Arg [55] : 00000000000000000000000000000000000000000000781121afe14014600000
Arg [56] : 00000000000000000000000000000000000000000000355cf2870ec725800000
Arg [57] : 000000000000000000000000000000000000000000000d573ca1c3b1c9600000
Arg [58] : 00000000000000000000000000000000000000000000a016d7952c5570800000
Arg [59] : 000000000000000000000000000000000000000000003807fea7691de7600000


Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
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  ]

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.