Overview
S Balance
S Value
$0.00More Info
Private Name Tags
ContractCreator
Loading...
Loading
This contract may be a proxy contract. Click on More Options and select Is this a proxy? to confirm and enable the "Read as Proxy" & "Write as Proxy" tabs.
Contract Name:
Boardroom
Compiler Version
v0.6.12+commit.27d51765
Contract Source Code (Solidity)
/** *Submitted for verification at SonicScan.org on 2025-02-18 */ // SPDX-License-Identifier: MIT pragma solidity >=0.6.0 <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 @openzeppelin/contracts/math/[email protected] pragma solidity >=0.6.0 <0.8.0; /** * @dev Wrappers over Solidity's arithmetic operations with added overflow * checks. * * Arithmetic operations in Solidity wrap on overflow. This can easily result * in bugs, because programmers usually assume that an overflow raises an * error, which is the standard behavior in high level programming languages. * `SafeMath` restores this intuition by reverting the transaction when an * operation overflows. * * Using this library instead of the unchecked operations eliminates an entire * class of bugs, so it's recommended to use it always. */ library SafeMath { /** * @dev Returns the addition of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) { uint256 c = a + b; if (c < a) return (false, 0); return (true, c); } /** * @dev Returns the substraction of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b > a) return (false, 0); return (true, a - b); } /** * @dev Returns the multiplication of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522 if (a == 0) return (true, 0); uint256 c = a * b; if (c / a != b) return (false, 0); return (true, c); } /** * @dev Returns the division of two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b == 0) return (false, 0); return (true, a / b); } /** * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b == 0) return (false, 0); return (true, a % b); } /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { require(b <= a, "SafeMath: subtraction overflow"); return a - b; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { if (a == 0) return 0; uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } /** * @dev Returns the integer division of two unsigned integers, reverting on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { require(b > 0, "SafeMath: division by zero"); return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { require(b > 0, "SafeMath: modulo by zero"); return a % b; } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {trySub}. * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b <= a, errorMessage); return a - b; } /** * @dev Returns the integer division of two unsigned integers, reverting with custom message on * division by zero. The result is rounded towards zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryDiv}. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting with custom message when dividing by zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryMod}. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); return a % b; } } // File @openzeppelin/contracts/utils/[email protected] pragma solidity >=0.6.2 <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; // solhint-disable-next-line no-inline-assembly assembly { size := extcodesize(account) } return size > 0; } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Address: insufficient balance"); // solhint-disable-next-line avoid-low-level-calls, avoid-call-value (bool success, ) = recipient.call{ value: amount }(""); require(success, "Address: unable to send value, recipient may have reverted"); } /** * @dev Performs a Solidity function call using a low level `call`. A * plain`call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCall(target, data, "Address: low-level call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with * `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) { return functionCallWithValue(target, data, 0, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but also transferring `value` wei to `target`. * * Requirements: * * - the calling contract must have an ETH balance of at least `value`. * - the called Solidity function must be `payable`. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) { return functionCallWithValue(target, data, value, "Address: low-level call with value failed"); } /** * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but * with `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) { require(address(this).balance >= value, "Address: insufficient balance for call"); require(isContract(target), "Address: call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.call{ value: value }(data); return _verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) { return functionStaticCall(target, data, "Address: low-level static call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data, string memory errorMessage) internal view returns (bytes memory) { require(isContract(target), "Address: static call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.staticcall(data); return _verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a delegate call. * * _Available since v3.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"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.delegatecall(data); return _verifyCallResult(success, returndata, errorMessage); } function _verifyCallResult(bool success, bytes memory returndata, string memory errorMessage) private pure returns(bytes memory) { if (success) { return returndata; } else { // Look for revert reason and bubble it up if present if (returndata.length > 0) { // The easiest way to bubble the revert reason is using memory via assembly // solhint-disable-next-line no-inline-assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } } } // File @openzeppelin/contracts/token/ERC20/[email protected] pragma solidity >=0.6.0 <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 SafeMath for uint256; using Address for address; function safeTransfer(IERC20 token, address to, uint256 value) internal { _callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value)); } function safeTransferFrom(IERC20 token, address from, address to, uint256 value) internal { _callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value)); } /** * @dev Deprecated. This function has issues similar to the ones found in * {IERC20-approve}, and its usage is discouraged. * * Whenever possible, use {safeIncreaseAllowance} and * {safeDecreaseAllowance} instead. */ function safeApprove(IERC20 token, address spender, uint256 value) internal { // safeApprove should only be called when setting an initial allowance, // or when resetting it to zero. To increase and decrease it, use // 'safeIncreaseAllowance' and 'safeDecreaseAllowance' // solhint-disable-next-line max-line-length require((value == 0) || (token.allowance(address(this), spender) == 0), "SafeERC20: approve from non-zero to non-zero allowance" ); _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value)); } function safeIncreaseAllowance(IERC20 token, address spender, uint256 value) internal { uint256 newAllowance = token.allowance(address(this), spender).add(value); _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance)); } function safeDecreaseAllowance(IERC20 token, address spender, uint256 value) internal { uint256 newAllowance = token.allowance(address(this), spender).sub(value, "SafeERC20: decreased allowance below zero"); _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance)); } /** * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement * on the return value: the return value is optional (but if data is returned, it must not be false). * @param token The token targeted by the call. * @param data The call data (encoded using abi.encode or one of its variants). */ function _callOptionalReturn(IERC20 token, bytes memory data) private { // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since // we're implementing it ourselves. We use {Address.functionCall} to perform this call, which verifies that // the target address contains contract code and also asserts for success in the low-level call. bytes memory returndata = address(token).functionCall(data, "SafeERC20: low-level call failed"); if (returndata.length > 0) { // Return data is optional // solhint-disable-next-line max-line-length require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed"); } } } // File contracts/utils/ContractGuard.sol pragma solidity 0.6.12; contract ContractGuard { mapping(uint256 => mapping(address => bool)) private _status; function checkSameOriginReentranted() internal view returns (bool) { return _status[block.number][tx.origin]; } function checkSameSenderReentranted() internal view returns (bool) { return _status[block.number][msg.sender]; } modifier onlyOneBlock() { require(!checkSameOriginReentranted(), "ContractGuard: one block, one function"); require(!checkSameSenderReentranted(), "ContractGuard: one block, one function"); _; _status[block.number][tx.origin] = true; _status[block.number][msg.sender] = true; } } // File contracts/interfaces/IBasisAsset.sol pragma solidity ^0.6.0; interface IBasisAsset { function mint(address recipient, uint256 amount) external returns (bool); function burn(uint256 amount) external; function burnFrom(address from, uint256 amount) external; function isOperator() external returns (bool); function operator() external view returns (address); function transferOperator(address newOperator_) external; } // File contracts/interfaces/ITreasury.sol pragma solidity 0.6.12; interface ITreasury { function epoch() external view returns (uint256); function nextEpochPoint() external view returns (uint256); function getGhostPrice() external view returns (uint256); function buyBonds(uint256 amount, uint256 targetPrice) external; function redeemBonds(uint256 amount, uint256 targetPrice) external; } // File contracts/Boardroom.sol pragma solidity 0.6.12; contract ShareWrapper { using SafeMath for uint256; using SafeERC20 for IERC20; IERC20 public share; uint256 private _totalSupply; mapping(address => uint256) private _balances; function totalSupply() public view returns (uint256) { return _totalSupply; } function balanceOf(address account) public view returns (uint256) { return _balances[account]; } function stake(uint256 amount) public virtual { _totalSupply = _totalSupply.add(amount); _balances[msg.sender] = _balances[msg.sender].add(amount); share.safeTransferFrom(msg.sender, address(this), amount); } function withdraw(uint256 amount) public virtual { uint256 memberShare = _balances[msg.sender]; require(memberShare >= amount, "Boardroom: withdraw request greater than staked amount"); _totalSupply = _totalSupply.sub(amount); _balances[msg.sender] = memberShare.sub(amount); share.safeTransfer(msg.sender, amount); } } contract Boardroom is ShareWrapper, ContractGuard { using SafeERC20 for IERC20; using Address for address; using SafeMath for uint256; /* ========== DATA STRUCTURES ========== */ struct Memberseat { uint256 lastSnapshotIndex; uint256 rewardEarned; uint256 epochTimerStart; } struct BoardroomSnapshot { uint256 time; uint256 rewardReceived; uint256 rewardPerShare; } /* ========== STATE VARIABLES ========== */ // governance address public operator; // flags bool public initialized = false; IERC20 public ghost; ITreasury public treasury; mapping(address => Memberseat) public members; BoardroomSnapshot[] public boardroomHistory; uint256 public withdrawLockupEpochs; uint256 public rewardLockupEpochs; /* ========== EVENTS ========== */ event Initialized(address indexed executor, uint256 at); event Staked(address indexed user, uint256 amount); event Withdrawn(address indexed user, uint256 amount); event RewardPaid(address indexed user, uint256 reward); event RewardAdded(address indexed user, uint256 reward); /* ========== Modifiers =============== */ modifier onlyOperator() { require(operator == msg.sender, "Boardroom: caller is not the operator"); _; } modifier memberExists() { require(balanceOf(msg.sender) > 0, "Boardroom: The member does not exist"); _; } modifier updateReward(address member) { if (member != address(0)) { Memberseat memory seat = members[member]; seat.rewardEarned = earned(member); seat.lastSnapshotIndex = latestSnapshotIndex(); members[member] = seat; } _; } modifier notInitialized() { require(!initialized, "Boardroom: already initialized"); _; } /* ========== GOVERNANCE ========== */ function initialize( IERC20 _ghost, IERC20 _share, ITreasury _treasury ) public notInitialized { ghost = _ghost; share = _share; treasury = _treasury; BoardroomSnapshot memory genesisSnapshot = BoardroomSnapshot({time: block.number, rewardReceived: 0, rewardPerShare: 0}); boardroomHistory.push(genesisSnapshot); withdrawLockupEpochs = 4; // Lock for 4 epochs (24h) before release withdraw rewardLockupEpochs = 2; // Lock for 2 epochs (12h) before release claimReward initialized = true; operator = msg.sender; emit Initialized(msg.sender, block.number); } function setOperator(address _operator) external onlyOperator { operator = _operator; } function setLockUp(uint256 _withdrawLockupEpochs, uint256 _rewardLockupEpochs) external onlyOperator { require(_withdrawLockupEpochs >= _rewardLockupEpochs && _withdrawLockupEpochs <= 56, "_withdrawLockupEpochs: out of range"); // <= 2 week withdrawLockupEpochs = _withdrawLockupEpochs; rewardLockupEpochs = _rewardLockupEpochs; } /* ========== VIEW FUNCTIONS ========== */ // =========== Snapshot getters function latestSnapshotIndex() public view returns (uint256) { return boardroomHistory.length.sub(1); } function getLatestSnapshot() internal view returns (BoardroomSnapshot memory) { return boardroomHistory[latestSnapshotIndex()]; } function getLastSnapshotIndexOf(address member) public view returns (uint256) { return members[member].lastSnapshotIndex; } function getLastSnapshotOf(address member) internal view returns (BoardroomSnapshot memory) { return boardroomHistory[getLastSnapshotIndexOf(member)]; } function canWithdraw(address member) external view returns (bool) { return members[member].epochTimerStart.add(withdrawLockupEpochs) <= treasury.epoch(); } function canClaimReward(address member) external view returns (bool) { return members[member].epochTimerStart.add(rewardLockupEpochs) <= treasury.epoch(); } function epoch() external view returns (uint256) { return treasury.epoch(); } function nextEpochPoint() external view returns (uint256) { return treasury.nextEpochPoint(); } function getGhostPrice() external view returns (uint256) { return treasury.getGhostPrice(); } // =========== Member getters function rewardPerShare() public view returns (uint256) { return getLatestSnapshot().rewardPerShare; } function earned(address member) public view returns (uint256) { uint256 latestRPS = getLatestSnapshot().rewardPerShare; uint256 storedRPS = getLastSnapshotOf(member).rewardPerShare; return balanceOf(member).mul(latestRPS.sub(storedRPS)).div(1e18).add(members[member].rewardEarned); } /* ========== MUTATIVE FUNCTIONS ========== */ function stake(uint256 amount) public override onlyOneBlock updateReward(msg.sender) { require(amount > 0, "Boardroom: Cannot stake 0"); super.stake(amount); members[msg.sender].epochTimerStart = treasury.epoch(); // reset timer emit Staked(msg.sender, amount); } function withdraw(uint256 amount) public override onlyOneBlock memberExists updateReward(msg.sender) { require(amount > 0, "Boardroom: Cannot withdraw 0"); require(members[msg.sender].epochTimerStart.add(withdrawLockupEpochs) <= treasury.epoch(), "Boardroom: still in withdraw lockup"); claimReward(); super.withdraw(amount); emit Withdrawn(msg.sender, amount); } function exit() external { withdraw(balanceOf(msg.sender)); } function claimReward() public updateReward(msg.sender) { uint256 reward = members[msg.sender].rewardEarned; if (reward > 0) { require(members[msg.sender].epochTimerStart.add(rewardLockupEpochs) <= treasury.epoch(), "Boardroom: still in reward lockup"); members[msg.sender].epochTimerStart = treasury.epoch(); // reset timer members[msg.sender].rewardEarned = 0; ghost.safeTransfer(msg.sender, reward); emit RewardPaid(msg.sender, reward); } } function allocateSeigniorage(uint256 amount) external onlyOneBlock onlyOperator { require(amount > 0, "Boardroom: Cannot allocate 0"); require(totalSupply() > 0, "Boardroom: Cannot allocate when totalSupply is 0"); // Create & add new snapshot uint256 prevRPS = getLatestSnapshot().rewardPerShare; uint256 nextRPS = prevRPS.add(amount.mul(1e18).div(totalSupply())); BoardroomSnapshot memory newSnapshot = BoardroomSnapshot({time: block.number, rewardReceived: amount, rewardPerShare: nextRPS}); boardroomHistory.push(newSnapshot); ghost.safeTransferFrom(msg.sender, address(this), amount); emit RewardAdded(msg.sender, amount); } function governanceRecoverUnsupported( IERC20 _token, uint256 _amount, address _to ) external onlyOperator { // do not allow to drain core tokens require(address(_token) != address(ghost), "ghost"); require(address(_token) != address(share), "share"); _token.safeTransfer(_to, _amount); } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"executor","type":"address"},{"indexed":false,"internalType":"uint256","name":"at","type":"uint256"}],"name":"Initialized","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"reward","type":"uint256"}],"name":"RewardAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"reward","type":"uint256"}],"name":"RewardPaid","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Staked","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Withdrawn","type":"event"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"allocateSeigniorage","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"boardroomHistory","outputs":[{"internalType":"uint256","name":"time","type":"uint256"},{"internalType":"uint256","name":"rewardReceived","type":"uint256"},{"internalType":"uint256","name":"rewardPerShare","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"member","type":"address"}],"name":"canClaimReward","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"member","type":"address"}],"name":"canWithdraw","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"claimReward","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"member","type":"address"}],"name":"earned","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"epoch","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"exit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getGhostPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"member","type":"address"}],"name":"getLastSnapshotIndexOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"ghost","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"_token","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"address","name":"_to","type":"address"}],"name":"governanceRecoverUnsupported","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"_ghost","type":"address"},{"internalType":"contract IERC20","name":"_share","type":"address"},{"internalType":"contract ITreasury","name":"_treasury","type":"address"}],"name":"initialize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"initialized","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"latestSnapshotIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"members","outputs":[{"internalType":"uint256","name":"lastSnapshotIndex","type":"uint256"},{"internalType":"uint256","name":"rewardEarned","type":"uint256"},{"internalType":"uint256","name":"epochTimerStart","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"nextEpochPoint","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"operator","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rewardLockupEpochs","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rewardPerShare","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_withdrawLockupEpochs","type":"uint256"},{"internalType":"uint256","name":"_rewardLockupEpochs","type":"uint256"}],"name":"setLockUp","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_operator","type":"address"}],"name":"setOperator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"share","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"stake","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"treasury","outputs":[{"internalType":"contract ITreasury","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawLockupEpochs","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"}]
Contract Creation Code
60806040526004805460ff60a01b1916905534801561001d57600080fd5b50611fbb8061002d6000396000f3fe608060405234801561001057600080fd5b50600436106101ce5760003560e01c8063570ca73511610104578063a694fc3a116100a2578063c0c53b8b11610071578063c0c53b8b14610457578063c58e38431461048f578063c5967c26146104ac578063e9fad8ee146104b4576101ce565b8063a694fc3a14610404578063a8d5fd6514610421578063b3ab15fb14610429578063b88a802f1461044f576101ce565b8063714b4658116100de578063714b4658146103b1578063900cf0cf146103d757806397ffe1d7146103df578063a3ab9049146103fc576101ce565b8063570ca7351461037b57806361d027b31461038357806370a082311461038b576101ce565b80631e85cd65116101715780633f9e3f041161014b5780633f9e3f0414610311578063446a2ec81461031957806351dc71891461032157806354575af414610345576101ce565b80631e85cd65146102c75780632e1a7d4d146102cf5780632ffaaa09146102ee576101ce565b806308ae4b0c116101ad57806308ae4b0c1461024d578063158ef93e1461029157806318160ddd1461029957806319262d30146102a1576101ce565b80628cc262146101d3578063022ba18d1461020b578063046335d014610213575b600080fd5b6101f9600480360360208110156101e957600080fd5b50356001600160a01b03166104bc565b60408051918252519081900360200190f35b6101f961053d565b6102396004803603602081101561022957600080fd5b50356001600160a01b0316610543565b604080519115158252519081900360200190f35b6102736004803603602081101561026357600080fd5b50356001600160a01b03166105e4565b60408051938452602084019290925282820152519081900360600190f35b610239610605565b6101f9610615565b610239600480360360208110156102b757600080fd5b50356001600160a01b031661061b565b6101f96106b4565b6102ec600480360360208110156102e557600080fd5b50356106ba565b005b6102ec6004803603604081101561030457600080fd5b50803590602001356109d4565b6101f9610a74565b6101f9610a8a565b610329610a9d565b604080516001600160a01b039092168252519081900360200190f35b6102ec6004803603606081101561035b57600080fd5b506001600160a01b03813581169160208101359160409091013516610aac565b610329610ba4565b610329610bb3565b6101f9600480360360208110156103a157600080fd5b50356001600160a01b0316610bc2565b6101f9600480360360208110156103c757600080fd5b50356001600160a01b0316610bdd565b6101f9610bf8565b6102ec600480360360208110156103f557600080fd5b5035610c6e565b6101f9610f52565b6102ec6004803603602081101561041a57600080fd5b5035610f97565b61032961121c565b6102ec6004803603602081101561043f57600080fd5b50356001600160a01b031661122b565b6102ec611296565b6102ec6004803603606081101561046d57600080fd5b506001600160a01b03813581169160208101358216916040909101351661150d565b610273600480360360208110156104a557600080fd5b50356116c1565b6101f96116f1565b6102ec611736565b6000806104c7611749565b60400151905060006104d8846117a1565b6040908101516001600160a01b0386166000908152600760205291909120600101549091506105359061052f670de0b6b3a764000061052961051a87876117fc565b6105238a610bc2565b9061185e565b906118be565b90611925565b949350505050565b600a5481565b6006546040805163900cf0cf60e01b815290516000926001600160a01b03169163900cf0cf916004808301926020929190829003018186803b15801561058857600080fd5b505afa15801561059c573d6000803e3d6000fd5b505050506040513d60208110156105b257600080fd5b5051600a546001600160a01b0384166000908152600760205260409020600201546105dc91611925565b111592915050565b60076020526000908152604090208054600182015460029092015490919083565b600454600160a01b900460ff1681565b60015490565b6006546040805163900cf0cf60e01b815290516000926001600160a01b03169163900cf0cf916004808301926020929190829003018186803b15801561066057600080fd5b505afa158015610674573d6000803e3d6000fd5b505050506040513d602081101561068a57600080fd5b50516009546001600160a01b0384166000908152600760205260409020600201546105dc91611925565b60095481565b6106c261197f565b156106fe5760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b6107066119a0565b156107425760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b600061074d33610bc2565b116107895760405162461bcd60e51b8152600401808060200182810382526024815260200180611dff6024913960400191505060405180910390fd5b33801561082357610798611ddd565b506001600160a01b03811660009081526007602090815260409182902082516060810184528154815260018201549281019290925260020154918101919091526107e1826104bc565b60208201526107ee610a74565b81526001600160a01b038216600090815260076020908152604091829020835181559083015160018201559101516002909101555b60008211610878576040805162461bcd60e51b815260206004820152601c60248201527f426f617264726f6f6d3a2043616e6e6f74207769746864726177203000000000604482015290519081900360640190fd5b600660009054906101000a90046001600160a01b03166001600160a01b031663900cf0cf6040518163ffffffff1660e01b815260040160206040518083038186803b1580156108c657600080fd5b505afa1580156108da573d6000803e3d6000fd5b505050506040513d60208110156108f057600080fd5b50516009543360009081526007602052604090206002015461091191611925565b111561094e5760405162461bcd60e51b8152600401808060200182810382526023815260200180611edd6023913960400191505060405180910390fd5b610956611296565b61095f826119c1565b60408051838152905133917f7084f5476618d8e60b11ef0d7d3f06914655adb8793e28ff7f018d4c76d505d5919081900360200190a250504360009081526003602090815260408083203284529091528082208054600160ff1991821681179092553384529190922080549091169091179055565b6004546001600160a01b03163314610a1d5760405162461bcd60e51b8152600401808060200182810382526025815260200180611eb86025913960400191505060405180910390fd5b808210158015610a2e575060388211155b610a695760405162461bcd60e51b8152600401808060200182810382526023815260200180611e956023913960400191505060405180910390fd5b600991909155600a55565b600854600090610a859060016117fc565b905090565b6000610a94611749565b60400151905090565b6005546001600160a01b031681565b6004546001600160a01b03163314610af55760405162461bcd60e51b8152600401808060200182810382526025815260200180611eb86025913960400191505060405180910390fd5b6005546001600160a01b0384811691161415610b40576040805162461bcd60e51b815260206004820152600560248201526419da1bdcdd60da1b604482015290519081900360640190fd5b6000546001600160a01b0384811691161415610b8b576040805162461bcd60e51b8152602060048201526005602482015264736861726560d81b604482015290519081900360640190fd5b610b9f6001600160a01b0384168284611a51565b505050565b6004546001600160a01b031681565b6006546001600160a01b031681565b6001600160a01b031660009081526002602052604090205490565b6001600160a01b031660009081526007602052604090205490565b6006546040805163900cf0cf60e01b815290516000926001600160a01b03169163900cf0cf916004808301926020929190829003018186803b158015610c3d57600080fd5b505afa158015610c51573d6000803e3d6000fd5b505050506040513d6020811015610c6757600080fd5b5051905090565b610c7661197f565b15610cb25760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b610cba6119a0565b15610cf65760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b6004546001600160a01b03163314610d3f5760405162461bcd60e51b8152600401808060200182810382526025815260200180611eb86025913960400191505060405180910390fd5b60008111610d94576040805162461bcd60e51b815260206004820152601c60248201527f426f617264726f6f6d3a2043616e6e6f7420616c6c6f63617465203000000000604482015290519081900360640190fd5b6000610d9e610615565b11610dda5760405162461bcd60e51b8152600401808060200182810382526030815260200180611e236030913960400191505060405180910390fd5b6000610de4611749565b6040015190506000610e13610e0c610dfa610615565b61052986670de0b6b3a764000061185e565b8390611925565b9050610e1d611ddd565b5060408051606081018252438152602081018581529181018381526008805460018101825560009190915282517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee360039092029182015592517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee4840155517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee590920191909155600554610edb906001600160a01b0316333087611aa3565b60408051858152905133917fac24935fd910bc682b5ccb1a07b718cadf8cf2f6d1404c4f3ddc3662dae40e29919081900360200190a250504360009081526003602090815260408083203284529091528082208054600160ff19918216811790925533845291909220805490911690911790555050565b6006546040805163a3ab904960e01b815290516000926001600160a01b03169163a3ab9049916004808301926020929190829003018186803b158015610c3d57600080fd5b610f9f61197f565b15610fdb5760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b610fe36119a0565b1561101f5760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b3380156110b95761102e611ddd565b506001600160a01b0381166000908152600760209081526040918290208251606081018452815481526001820154928101929092526002015491810191909152611077826104bc565b6020820152611084610a74565b81526001600160a01b038216600090815260076020908152604091829020835181559083015160018201559101516002909101555b6000821161110e576040805162461bcd60e51b815260206004820152601960248201527f426f617264726f6f6d3a2043616e6e6f74207374616b65203000000000000000604482015290519081900360640190fd5b61111782611b03565b600660009054906101000a90046001600160a01b03166001600160a01b031663900cf0cf6040518163ffffffff1660e01b815260040160206040518083038186803b15801561116557600080fd5b505afa158015611179573d6000803e3d6000fd5b505050506040513d602081101561118f57600080fd5b505133600081815260076020908152604091829020600201939093558051858152905191927f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d92918290030190a250504360009081526003602090815260408083203284529091528082208054600160ff1991821681179092553384529190922080549091169091179055565b6000546001600160a01b031681565b6004546001600160a01b031633146112745760405162461bcd60e51b8152600401808060200182810382526025815260200180611eb86025913960400191505060405180910390fd5b600480546001600160a01b0319166001600160a01b0392909216919091179055565b338015611330576112a5611ddd565b506001600160a01b03811660009081526007602090815260409182902082516060810184528154815260018201549281019290925260020154918101919091526112ee826104bc565b60208201526112fb610a74565b81526001600160a01b038216600090815260076020908152604091829020835181559083015160018201559101516002909101555b33600090815260076020526040902060010154801561150957600660009054906101000a90046001600160a01b03166001600160a01b031663900cf0cf6040518163ffffffff1660e01b815260040160206040518083038186803b15801561139757600080fd5b505afa1580156113ab573d6000803e3d6000fd5b505050506040513d60208110156113c157600080fd5b5051600a54336000908152600760205260409020600201546113e291611925565b111561141f5760405162461bcd60e51b8152600401808060200182810382526021815260200180611e746021913960400191505060405180910390fd5b600660009054906101000a90046001600160a01b03166001600160a01b031663900cf0cf6040518163ffffffff1660e01b815260040160206040518083038186803b15801561146d57600080fd5b505afa158015611481573d6000803e3d6000fd5b505050506040513d602081101561149757600080fd5b505133600081815260076020526040812060028101939093556001909201919091556005546114d2916001600160a01b039091169083611a51565b60408051828152905133917fe2403640ba68fed3a2f88b7557551d1993f84b99bb10ff833f0cf8db0c5e0486919081900360200190a25b5050565b600454600160a01b900460ff161561156c576040805162461bcd60e51b815260206004820152601e60248201527f426f617264726f6f6d3a20616c726561647920696e697469616c697a65640000604482015290519081900360640190fd5b600580546001600160a01b038086166001600160a01b0319928316179092556000805485841690831617905560068054928416929091169190911790556115b1611ddd565b50604080516060810182524380825260006020808401828152848601838152600880546001810182559452855160039094027ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee381019490945590517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee4840155517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee590920191909155600460098190556002600a5580546001600160a01b031960ff60a01b19909116600160a01b171633908117909155845192835293519293927f25ff68dd81b34665b5ba7e553ee5511bf6812e12adb4a7e2c0d9e26b3099ce799281900390910190a250505050565b600881815481106116ce57fe5b600091825260209091206003909102018054600182015460029092015490925083565b600654604080516362cb3e1360e11b815290516000926001600160a01b03169163c5967c26916004808301926020929190829003018186803b158015610c3d57600080fd5b61174761174233610bc2565b6106ba565b565b611751611ddd565b600861175b610a74565b8154811061176557fe5b90600052602060002090600302016040518060600160405290816000820154815260200160018201548152602001600282015481525050905090565b6117a9611ddd565b60086117b483610bdd565b815481106117be57fe5b906000526020600020906003020160405180606001604052908160008201548152602001600182015481526020016002820154815250509050919050565b600082821115611853576040805162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015290519081900360640190fd5b508082035b92915050565b60008261186d57506000611858565b8282028284828161187a57fe5b04146118b75760405162461bcd60e51b8152600401808060200182810382526021815260200180611e536021913960400191505060405180910390fd5b9392505050565b6000808211611914576040805162461bcd60e51b815260206004820152601a60248201527f536166654d6174683a206469766973696f6e206279207a65726f000000000000604482015290519081900360640190fd5b81838161191d57fe5b049392505050565b6000828201838110156118b7576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b43600090815260036020908152604080832032845290915290205460ff1690565b43600090815260036020908152604080832033845290915290205460ff1690565b3360009081526002602052604090205481811015611a105760405162461bcd60e51b8152600401808060200182810382526036815260200180611f506036913960400191505060405180910390fd5b600154611a1d90836117fc565b600155611a2a81836117fc565b336000818152600260205260408120929092559054611509916001600160a01b0390911690845b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610b9f908490611b5c565b604080516001600160a01b0380861660248301528416604482015260648082018490528251808303909101815260849091019091526020810180516001600160e01b03166323b872dd60e01b179052611afd908590611b5c565b50505050565b600154611b109082611925565b60015533600090815260026020526040902054611b2d9082611925565b336000818152600260205260408120929092559054611b59916001600160a01b03909116903084611aa3565b50565b6060611bb1826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b0316611c0d9092919063ffffffff16565b805190915015610b9f57808060200190516020811015611bd057600080fd5b5051610b9f5760405162461bcd60e51b815260040180806020018281038252602a815260200180611f00602a913960400191505060405180910390fd5b6060610535848460008585611c2185611d33565b611c72576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b60208310611cb15780518252601f199092019160209182019101611c92565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114611d13576040519150601f19603f3d011682016040523d82523d6000602084013e611d18565b606091505b5091509150611d28828286611d39565b979650505050505050565b3b151590565b60608315611d485750816118b7565b825115611d585782518084602001fd5b8160405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611da2578181015183820152602001611d8a565b50505050905090810190601f168015611dcf5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b6040518060600160405280600081526020016000815260200160008152509056fe426f617264726f6f6d3a20546865206d656d62657220646f6573206e6f74206578697374426f617264726f6f6d3a2043616e6e6f7420616c6c6f63617465207768656e20746f74616c537570706c792069732030536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f77426f617264726f6f6d3a207374696c6c20696e20726577617264206c6f636b75705f77697468647261774c6f636b757045706f6368733a206f7574206f662072616e6765426f617264726f6f6d3a2063616c6c6572206973206e6f7420746865206f70657261746f72426f617264726f6f6d3a207374696c6c20696e207769746864726177206c6f636b75705361666545524332303a204552433230206f7065726174696f6e20646964206e6f742073756363656564436f6e747261637447756172643a206f6e6520626c6f636b2c206f6e652066756e6374696f6e426f617264726f6f6d3a20776974686472617720726571756573742067726561746572207468616e207374616b656420616d6f756e74a264697066735822122014a28f02350f26fc809bfd1574910ec31cdd402316b822a08f573d6e13e5357064736f6c634300060c0033
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106101ce5760003560e01c8063570ca73511610104578063a694fc3a116100a2578063c0c53b8b11610071578063c0c53b8b14610457578063c58e38431461048f578063c5967c26146104ac578063e9fad8ee146104b4576101ce565b8063a694fc3a14610404578063a8d5fd6514610421578063b3ab15fb14610429578063b88a802f1461044f576101ce565b8063714b4658116100de578063714b4658146103b1578063900cf0cf146103d757806397ffe1d7146103df578063a3ab9049146103fc576101ce565b8063570ca7351461037b57806361d027b31461038357806370a082311461038b576101ce565b80631e85cd65116101715780633f9e3f041161014b5780633f9e3f0414610311578063446a2ec81461031957806351dc71891461032157806354575af414610345576101ce565b80631e85cd65146102c75780632e1a7d4d146102cf5780632ffaaa09146102ee576101ce565b806308ae4b0c116101ad57806308ae4b0c1461024d578063158ef93e1461029157806318160ddd1461029957806319262d30146102a1576101ce565b80628cc262146101d3578063022ba18d1461020b578063046335d014610213575b600080fd5b6101f9600480360360208110156101e957600080fd5b50356001600160a01b03166104bc565b60408051918252519081900360200190f35b6101f961053d565b6102396004803603602081101561022957600080fd5b50356001600160a01b0316610543565b604080519115158252519081900360200190f35b6102736004803603602081101561026357600080fd5b50356001600160a01b03166105e4565b60408051938452602084019290925282820152519081900360600190f35b610239610605565b6101f9610615565b610239600480360360208110156102b757600080fd5b50356001600160a01b031661061b565b6101f96106b4565b6102ec600480360360208110156102e557600080fd5b50356106ba565b005b6102ec6004803603604081101561030457600080fd5b50803590602001356109d4565b6101f9610a74565b6101f9610a8a565b610329610a9d565b604080516001600160a01b039092168252519081900360200190f35b6102ec6004803603606081101561035b57600080fd5b506001600160a01b03813581169160208101359160409091013516610aac565b610329610ba4565b610329610bb3565b6101f9600480360360208110156103a157600080fd5b50356001600160a01b0316610bc2565b6101f9600480360360208110156103c757600080fd5b50356001600160a01b0316610bdd565b6101f9610bf8565b6102ec600480360360208110156103f557600080fd5b5035610c6e565b6101f9610f52565b6102ec6004803603602081101561041a57600080fd5b5035610f97565b61032961121c565b6102ec6004803603602081101561043f57600080fd5b50356001600160a01b031661122b565b6102ec611296565b6102ec6004803603606081101561046d57600080fd5b506001600160a01b03813581169160208101358216916040909101351661150d565b610273600480360360208110156104a557600080fd5b50356116c1565b6101f96116f1565b6102ec611736565b6000806104c7611749565b60400151905060006104d8846117a1565b6040908101516001600160a01b0386166000908152600760205291909120600101549091506105359061052f670de0b6b3a764000061052961051a87876117fc565b6105238a610bc2565b9061185e565b906118be565b90611925565b949350505050565b600a5481565b6006546040805163900cf0cf60e01b815290516000926001600160a01b03169163900cf0cf916004808301926020929190829003018186803b15801561058857600080fd5b505afa15801561059c573d6000803e3d6000fd5b505050506040513d60208110156105b257600080fd5b5051600a546001600160a01b0384166000908152600760205260409020600201546105dc91611925565b111592915050565b60076020526000908152604090208054600182015460029092015490919083565b600454600160a01b900460ff1681565b60015490565b6006546040805163900cf0cf60e01b815290516000926001600160a01b03169163900cf0cf916004808301926020929190829003018186803b15801561066057600080fd5b505afa158015610674573d6000803e3d6000fd5b505050506040513d602081101561068a57600080fd5b50516009546001600160a01b0384166000908152600760205260409020600201546105dc91611925565b60095481565b6106c261197f565b156106fe5760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b6107066119a0565b156107425760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b600061074d33610bc2565b116107895760405162461bcd60e51b8152600401808060200182810382526024815260200180611dff6024913960400191505060405180910390fd5b33801561082357610798611ddd565b506001600160a01b03811660009081526007602090815260409182902082516060810184528154815260018201549281019290925260020154918101919091526107e1826104bc565b60208201526107ee610a74565b81526001600160a01b038216600090815260076020908152604091829020835181559083015160018201559101516002909101555b60008211610878576040805162461bcd60e51b815260206004820152601c60248201527f426f617264726f6f6d3a2043616e6e6f74207769746864726177203000000000604482015290519081900360640190fd5b600660009054906101000a90046001600160a01b03166001600160a01b031663900cf0cf6040518163ffffffff1660e01b815260040160206040518083038186803b1580156108c657600080fd5b505afa1580156108da573d6000803e3d6000fd5b505050506040513d60208110156108f057600080fd5b50516009543360009081526007602052604090206002015461091191611925565b111561094e5760405162461bcd60e51b8152600401808060200182810382526023815260200180611edd6023913960400191505060405180910390fd5b610956611296565b61095f826119c1565b60408051838152905133917f7084f5476618d8e60b11ef0d7d3f06914655adb8793e28ff7f018d4c76d505d5919081900360200190a250504360009081526003602090815260408083203284529091528082208054600160ff1991821681179092553384529190922080549091169091179055565b6004546001600160a01b03163314610a1d5760405162461bcd60e51b8152600401808060200182810382526025815260200180611eb86025913960400191505060405180910390fd5b808210158015610a2e575060388211155b610a695760405162461bcd60e51b8152600401808060200182810382526023815260200180611e956023913960400191505060405180910390fd5b600991909155600a55565b600854600090610a859060016117fc565b905090565b6000610a94611749565b60400151905090565b6005546001600160a01b031681565b6004546001600160a01b03163314610af55760405162461bcd60e51b8152600401808060200182810382526025815260200180611eb86025913960400191505060405180910390fd5b6005546001600160a01b0384811691161415610b40576040805162461bcd60e51b815260206004820152600560248201526419da1bdcdd60da1b604482015290519081900360640190fd5b6000546001600160a01b0384811691161415610b8b576040805162461bcd60e51b8152602060048201526005602482015264736861726560d81b604482015290519081900360640190fd5b610b9f6001600160a01b0384168284611a51565b505050565b6004546001600160a01b031681565b6006546001600160a01b031681565b6001600160a01b031660009081526002602052604090205490565b6001600160a01b031660009081526007602052604090205490565b6006546040805163900cf0cf60e01b815290516000926001600160a01b03169163900cf0cf916004808301926020929190829003018186803b158015610c3d57600080fd5b505afa158015610c51573d6000803e3d6000fd5b505050506040513d6020811015610c6757600080fd5b5051905090565b610c7661197f565b15610cb25760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b610cba6119a0565b15610cf65760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b6004546001600160a01b03163314610d3f5760405162461bcd60e51b8152600401808060200182810382526025815260200180611eb86025913960400191505060405180910390fd5b60008111610d94576040805162461bcd60e51b815260206004820152601c60248201527f426f617264726f6f6d3a2043616e6e6f7420616c6c6f63617465203000000000604482015290519081900360640190fd5b6000610d9e610615565b11610dda5760405162461bcd60e51b8152600401808060200182810382526030815260200180611e236030913960400191505060405180910390fd5b6000610de4611749565b6040015190506000610e13610e0c610dfa610615565b61052986670de0b6b3a764000061185e565b8390611925565b9050610e1d611ddd565b5060408051606081018252438152602081018581529181018381526008805460018101825560009190915282517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee360039092029182015592517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee4840155517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee590920191909155600554610edb906001600160a01b0316333087611aa3565b60408051858152905133917fac24935fd910bc682b5ccb1a07b718cadf8cf2f6d1404c4f3ddc3662dae40e29919081900360200190a250504360009081526003602090815260408083203284529091528082208054600160ff19918216811790925533845291909220805490911690911790555050565b6006546040805163a3ab904960e01b815290516000926001600160a01b03169163a3ab9049916004808301926020929190829003018186803b158015610c3d57600080fd5b610f9f61197f565b15610fdb5760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b610fe36119a0565b1561101f5760405162461bcd60e51b8152600401808060200182810382526026815260200180611f2a6026913960400191505060405180910390fd5b3380156110b95761102e611ddd565b506001600160a01b0381166000908152600760209081526040918290208251606081018452815481526001820154928101929092526002015491810191909152611077826104bc565b6020820152611084610a74565b81526001600160a01b038216600090815260076020908152604091829020835181559083015160018201559101516002909101555b6000821161110e576040805162461bcd60e51b815260206004820152601960248201527f426f617264726f6f6d3a2043616e6e6f74207374616b65203000000000000000604482015290519081900360640190fd5b61111782611b03565b600660009054906101000a90046001600160a01b03166001600160a01b031663900cf0cf6040518163ffffffff1660e01b815260040160206040518083038186803b15801561116557600080fd5b505afa158015611179573d6000803e3d6000fd5b505050506040513d602081101561118f57600080fd5b505133600081815260076020908152604091829020600201939093558051858152905191927f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d92918290030190a250504360009081526003602090815260408083203284529091528082208054600160ff1991821681179092553384529190922080549091169091179055565b6000546001600160a01b031681565b6004546001600160a01b031633146112745760405162461bcd60e51b8152600401808060200182810382526025815260200180611eb86025913960400191505060405180910390fd5b600480546001600160a01b0319166001600160a01b0392909216919091179055565b338015611330576112a5611ddd565b506001600160a01b03811660009081526007602090815260409182902082516060810184528154815260018201549281019290925260020154918101919091526112ee826104bc565b60208201526112fb610a74565b81526001600160a01b038216600090815260076020908152604091829020835181559083015160018201559101516002909101555b33600090815260076020526040902060010154801561150957600660009054906101000a90046001600160a01b03166001600160a01b031663900cf0cf6040518163ffffffff1660e01b815260040160206040518083038186803b15801561139757600080fd5b505afa1580156113ab573d6000803e3d6000fd5b505050506040513d60208110156113c157600080fd5b5051600a54336000908152600760205260409020600201546113e291611925565b111561141f5760405162461bcd60e51b8152600401808060200182810382526021815260200180611e746021913960400191505060405180910390fd5b600660009054906101000a90046001600160a01b03166001600160a01b031663900cf0cf6040518163ffffffff1660e01b815260040160206040518083038186803b15801561146d57600080fd5b505afa158015611481573d6000803e3d6000fd5b505050506040513d602081101561149757600080fd5b505133600081815260076020526040812060028101939093556001909201919091556005546114d2916001600160a01b039091169083611a51565b60408051828152905133917fe2403640ba68fed3a2f88b7557551d1993f84b99bb10ff833f0cf8db0c5e0486919081900360200190a25b5050565b600454600160a01b900460ff161561156c576040805162461bcd60e51b815260206004820152601e60248201527f426f617264726f6f6d3a20616c726561647920696e697469616c697a65640000604482015290519081900360640190fd5b600580546001600160a01b038086166001600160a01b0319928316179092556000805485841690831617905560068054928416929091169190911790556115b1611ddd565b50604080516060810182524380825260006020808401828152848601838152600880546001810182559452855160039094027ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee381019490945590517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee4840155517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee590920191909155600460098190556002600a5580546001600160a01b031960ff60a01b19909116600160a01b171633908117909155845192835293519293927f25ff68dd81b34665b5ba7e553ee5511bf6812e12adb4a7e2c0d9e26b3099ce799281900390910190a250505050565b600881815481106116ce57fe5b600091825260209091206003909102018054600182015460029092015490925083565b600654604080516362cb3e1360e11b815290516000926001600160a01b03169163c5967c26916004808301926020929190829003018186803b158015610c3d57600080fd5b61174761174233610bc2565b6106ba565b565b611751611ddd565b600861175b610a74565b8154811061176557fe5b90600052602060002090600302016040518060600160405290816000820154815260200160018201548152602001600282015481525050905090565b6117a9611ddd565b60086117b483610bdd565b815481106117be57fe5b906000526020600020906003020160405180606001604052908160008201548152602001600182015481526020016002820154815250509050919050565b600082821115611853576040805162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015290519081900360640190fd5b508082035b92915050565b60008261186d57506000611858565b8282028284828161187a57fe5b04146118b75760405162461bcd60e51b8152600401808060200182810382526021815260200180611e536021913960400191505060405180910390fd5b9392505050565b6000808211611914576040805162461bcd60e51b815260206004820152601a60248201527f536166654d6174683a206469766973696f6e206279207a65726f000000000000604482015290519081900360640190fd5b81838161191d57fe5b049392505050565b6000828201838110156118b7576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b43600090815260036020908152604080832032845290915290205460ff1690565b43600090815260036020908152604080832033845290915290205460ff1690565b3360009081526002602052604090205481811015611a105760405162461bcd60e51b8152600401808060200182810382526036815260200180611f506036913960400191505060405180910390fd5b600154611a1d90836117fc565b600155611a2a81836117fc565b336000818152600260205260408120929092559054611509916001600160a01b0390911690845b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610b9f908490611b5c565b604080516001600160a01b0380861660248301528416604482015260648082018490528251808303909101815260849091019091526020810180516001600160e01b03166323b872dd60e01b179052611afd908590611b5c565b50505050565b600154611b109082611925565b60015533600090815260026020526040902054611b2d9082611925565b336000818152600260205260408120929092559054611b59916001600160a01b03909116903084611aa3565b50565b6060611bb1826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b0316611c0d9092919063ffffffff16565b805190915015610b9f57808060200190516020811015611bd057600080fd5b5051610b9f5760405162461bcd60e51b815260040180806020018281038252602a815260200180611f00602a913960400191505060405180910390fd5b6060610535848460008585611c2185611d33565b611c72576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b60208310611cb15780518252601f199092019160209182019101611c92565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114611d13576040519150601f19603f3d011682016040523d82523d6000602084013e611d18565b606091505b5091509150611d28828286611d39565b979650505050505050565b3b151590565b60608315611d485750816118b7565b825115611d585782518084602001fd5b8160405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611da2578181015183820152602001611d8a565b50505050905090810190601f168015611dcf5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b6040518060600160405280600081526020016000815260200160008152509056fe426f617264726f6f6d3a20546865206d656d62657220646f6573206e6f74206578697374426f617264726f6f6d3a2043616e6e6f7420616c6c6f63617465207768656e20746f74616c537570706c792069732030536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f77426f617264726f6f6d3a207374696c6c20696e20726577617264206c6f636b75705f77697468647261774c6f636b757045706f6368733a206f7574206f662072616e6765426f617264726f6f6d3a2063616c6c6572206973206e6f7420746865206f70657261746f72426f617264726f6f6d3a207374696c6c20696e207769746864726177206c6f636b75705361666545524332303a204552433230206f7065726174696f6e20646964206e6f742073756363656564436f6e747261637447756172643a206f6e6520626c6f636b2c206f6e652066756e6374696f6e426f617264726f6f6d3a20776974686472617720726571756573742067726561746572207468616e207374616b656420616d6f756e74a264697066735822122014a28f02350f26fc809bfd1574910ec31cdd402316b822a08f573d6e13e5357064736f6c634300060c0033
Deployed Bytecode Sourcemap
24873:7569:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29607:317;;;;;;;;;;;;;;;;-1:-1:-1;29607:317:0;-1:-1:-1;;;;;29607:317:0;;:::i;:::-;;;;;;;;;;;;;;;;25708:33;;;:::i;28937:170::-;;;;;;;;;;;;;;;;-1:-1:-1;28937:170:0;-1:-1:-1;;;;;28937:170:0;;:::i;:::-;;;;;;;;;;;;;;;;;;25562:45;;;;;;;;;;;;;;;;-1:-1:-1;25562:45:0;-1:-1:-1;;;;;25562:45:0;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;25462:31;;;:::i;24032:91::-;;;:::i;28760:169::-;;;;;;;;;;;;;;;;-1:-1:-1;28760:169:0;-1:-1:-1;;;;;28760:169:0;;:::i;25666:35::-;;;:::i;30298:413::-;;;;;;;;;;;;;;;;-1:-1:-1;30298:413:0;;:::i;:::-;;27706:362;;;;;;;;;;;;;;;;-1:-1:-1;27706:362:0;;;;;;;:::i;28165:117::-;;;:::i;29483:116::-;;;:::i;25502:19::-;;;:::i;:::-;;;;-1:-1:-1;;;;;25502:19:0;;;;;;;;;;;;;;32078:361;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;32078:361:0;;;;;;;;;;;;;;;;;:::i;25416:23::-;;;:::i;25528:25::-;;;:::i;24131:110::-;;;;;;;;;;;;;;;;-1:-1:-1;24131:110:0;-1:-1:-1;;;;;24131:110:0;;:::i;28441:137::-;;;;;;;;;;;;;;;;-1:-1:-1;28441:137:0;-1:-1:-1;;;;;28441:137:0;;:::i;29115:91::-;;;:::i;31349:721::-;;;;;;;;;;;;;;;;-1:-1:-1;31349:721:0;;:::i;29331:107::-;;;:::i;29986:304::-;;;;;;;;;;;;;;;;-1:-1:-1;29986:304:0;;:::i;23915:19::-;;;:::i;27597:101::-;;;;;;;;;;;;;;;;-1:-1:-1;27597:101:0;-1:-1:-1;;;;;27597:101:0;;:::i;30802:539::-;;;:::i;26900:689::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;26900:689:0;;;;;;;;;;;;;;;;;;;:::i;25614:43::-;;;;;;;;;;;;;;;;-1:-1:-1;25614:43:0;;:::i;29214:109::-;;;:::i;30719:75::-;;;:::i;29607:317::-;29660:7;29680:17;29700:19;:17;:19::i;:::-;:34;;;29680:54;;29745:17;29765:25;29783:6;29765:17;:25::i;:::-;:40;;;;;-1:-1:-1;;;;;29887:15:0;;;;;;:7;:15;;;;;;:28;;;29765:40;;-1:-1:-1;29825:91:0;;:57;29877:4;29825:47;29847:24;:9;29765:40;29847:13;:24::i;:::-;29825:17;29835:6;29825:9;:17::i;:::-;:21;;:47::i;:::-;:51;;:57::i;:::-;:61;;:91::i;:::-;29818:98;29607:317;-1:-1:-1;;;;29607:317:0:o;25708:33::-;;;;:::o;28937:170::-;29083:8;;:16;;;-1:-1:-1;;;29083:16:0;;;;29000:4;;-1:-1:-1;;;;;29083:8:0;;:14;;:16;;;;;;;;;;;;;;:8;:16;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;29083:16:0;29060:18;;-1:-1:-1;;;;;29024:15:0;;;;;;:7;29083:16;29024:15;;;;:31;;;:55;;:35;:55::i;:::-;:75;;;28937:170;-1:-1:-1;;28937:170:0:o;25562:45::-;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;25462:31::-;;;-1:-1:-1;;;25462:31:0;;;;;:::o;24032:91::-;24103:12;;24032:91;:::o;28760:169::-;28905:8;;:16;;;-1:-1:-1;;;28905:16:0;;;;28820:4;;-1:-1:-1;;;;;28905:8:0;;:14;;:16;;;;;;;;;;;;;;:8;:16;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;28905:16:0;28880:20;;-1:-1:-1;;;;;28844:15:0;;;;;;:7;28905:16;28844:15;;;;:31;;;:57;;:35;:57::i;25666:35::-;;;;:::o;30298:413::-;22529:28;:26;:28::i;:::-;22528:29;22520:80;;;;-1:-1:-1;;;22520:80:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22620:28;:26;:28::i;:::-;22619:29;22611:80;;;;-1:-1:-1;;;22611:80:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26348:1:::1;26324:21;26334:10;26324:9;:21::i;:::-;:25;26316:74;;;;-1:-1:-1::0;;;26316:74:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30387:10:::2;26471:20:::0;;26467:240:::2;;26508:22;;:::i;:::-;-1:-1:-1::0;;;;;;26533:15:0;::::2;;::::0;;;:7:::2;:15;::::0;;;;;;;;26508:40;;::::2;::::0;::::2;::::0;;;;;;::::2;::::0;::::2;::::0;;;::::2;::::0;;;;::::2;;::::0;;;;;;;;26583:14:::2;26541:6:::0;26583::::2;:14::i;:::-;26563:17;::::0;::::2;:34:::0;26637:21:::2;:19;:21::i;:::-;26612:46:::0;;-1:-1:-1;;;;;26673:15:0;::::2;26612:22;26673:15:::0;;;:7:::2;:15;::::0;;;;;;;;:22;;;;;;::::2;::::0;::::2;::::0;::::2;::::0;;::::2;::::0;::::2;::::0;;::::2;::::0;26467:240:::2;30427:1:::3;30418:6;:10;30410:51;;;::::0;;-1:-1:-1;;;30410:51:0;;::::3;;::::0;::::3;::::0;::::3;::::0;;;;::::3;::::0;;;;;;;;;;;;;::::3;;30545:8;;;;;;;;;-1:-1:-1::0;;;;;30545:8:0::3;-1:-1:-1::0;;;;;30545:14:0::3;;:16;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::3;;;;;;;;;;;;::::0;::::3;;;;;;;;;;;;;;;;;;;::::0;::::3;;-1:-1:-1::0;30545:16:0;30520:20:::3;::::0;30488:10:::3;30480:19;::::0;;;:7:::3;30545:16;30480:19:::0;;;;:35:::3;;::::0;:61:::3;::::0;:39:::3;:61::i;:::-;:81;;30472:129;;;;-1:-1:-1::0;;;30472:129:0::3;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30612:13;:11;:13::i;:::-;30636:22;30651:6;30636:14;:22::i;:::-;30674:29;::::0;;;;;;;30684:10:::3;::::0;30674:29:::3;::::0;;;;;::::3;::::0;;::::3;-1:-1:-1::0;;22726:12:0;22718:21;;;;:7;:21;;;;;;;;22740:9;22718:32;;;;;;;;:39;;22753:4;-1:-1:-1;;22718:39:0;;;;;;;;22790:10;22768:33;;;;;;:40;;;;;;;;;;30298:413::o;27706:362::-;26189:8;;-1:-1:-1;;;;;26189:8:0;26201:10;26189:22;26181:72;;;;-1:-1:-1;;;26181:72:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27851:19:::1;27826:21;:44;;:75;;;;;27899:2;27874:21;:27;;27826:75;27818:123;;;;-1:-1:-1::0;;;27818:123:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27965:20;:44:::0;;;;28020:18:::1;:40:::0;27706:362::o;28165:117::-;28244:16;:23;28217:7;;28244:30;;28272:1;28244:27;:30::i;:::-;28237:37;;28165:117;:::o;29483:116::-;29530:7;29557:19;:17;:19::i;:::-;:34;;;29550:41;;29483:116;:::o;25502:19::-;;;-1:-1:-1;;;;;25502:19:0;;:::o;32078:361::-;26189:8;;-1:-1:-1;;;;;26189:8:0;26201:10;26189:22;26181:72;;;;-1:-1:-1;;;26181:72:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32309:5:::1;::::0;-1:-1:-1;;;;;32282:33:0;;::::1;32309:5:::0;::::1;32282:33;;32274:51;;;::::0;;-1:-1:-1;;;32274:51:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;-1:-1:-1;;;32274:51:0;;;;;;;;;;;;;::::1;;32371:5;::::0;-1:-1:-1;;;;;32344:33:0;;::::1;32371:5:::0;::::1;32344:33;;32336:51;;;::::0;;-1:-1:-1;;;32336:51:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;-1:-1:-1;;;32336:51:0;;;;;;;;;;;;;::::1;;32398:33;-1:-1:-1::0;;;;;32398:19:0;::::1;32418:3:::0;32423:7;32398:19:::1;:33::i;:::-;32078:361:::0;;;:::o;25416:23::-;;;-1:-1:-1;;;;;25416:23:0;;:::o;25528:25::-;;;-1:-1:-1;;;;;25528:25:0;;:::o;24131:110::-;-1:-1:-1;;;;;24215:18:0;24188:7;24215:18;;;:9;:18;;;;;;;24131:110::o;28441:137::-;-1:-1:-1;;;;;28537:15:0;28510:7;28537:15;;;:7;:15;;;;;:33;;28441:137::o;29115:91::-;29182:8;;:16;;;-1:-1:-1;;;29182:16:0;;;;29155:7;;-1:-1:-1;;;;;29182:8:0;;:14;;:16;;;;;;;;;;;;;;:8;:16;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;29182:16:0;;-1:-1:-1;29115:91:0;:::o;31349:721::-;22529:28;:26;:28::i;:::-;22528:29;22520:80;;;;-1:-1:-1;;;22520:80:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22620:28;:26;:28::i;:::-;22619:29;22611:80;;;;-1:-1:-1;;;22611:80:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26189:8:::1;::::0;-1:-1:-1;;;;;26189:8:0::1;26201:10;26189:22;26181:72;;;;-1:-1:-1::0;;;26181:72:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31457:1:::2;31448:6;:10;31440:51;;;::::0;;-1:-1:-1;;;31440:51:0;;::::2;;::::0;::::2;::::0;::::2;::::0;;;;::::2;::::0;;;;;;;;;;;;;::::2;;31526:1;31510:13;:11;:13::i;:::-;:17;31502:78;;;;-1:-1:-1::0;;;31502:78:0::2;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31631:15;31649:19;:17;:19::i;:::-;:34;;;31631:52;;31694:15;31712:48;31724:35;31745:13;:11;:13::i;:::-;31724:16;:6:::0;31735:4:::2;31724:10;:16::i;:35::-;31712:7:::0;;:11:::2;:48::i;:::-;31694:66;;31773:36;;:::i;:::-;-1:-1:-1::0;31812:88:0::2;::::0;;::::2;::::0;::::2;::::0;;31837:12:::2;31812:88:::0;;::::2;::::0;::::2;::::0;;;;;;;;;31911:16:::2;:34:::0;;::::2;::::0;::::2;::::0;;-1:-1:-1;31911:34:0;;;;;;;::::2;::::0;;::::2;::::0;;::::2;::::0;;;;;;;;;;;;;;;;31958:5:::2;::::0;:57:::2;::::0;-1:-1:-1;;;;;31958:5:0::2;31981:10;32001:4;31812:88:::0;31958:22:::2;:57::i;:::-;32031:31;::::0;;;;;;;32043:10:::2;::::0;32031:31:::2;::::0;;;;;::::2;::::0;;::::2;-1:-1:-1::0;;22726:12:0;22718:21;;;;:7;:21;;;;;;;;22740:9;22718:32;;;;;;;;:39;;22753:4;-1:-1:-1;;22718:39:0;;;;;;;;22790:10;22768:33;;;;;;:40;;;;;;;;;;-1:-1:-1;;31349:721:0:o;29331:107::-;29406:8;;:24;;;-1:-1:-1;;;29406:24:0;;;;29379:7;;-1:-1:-1;;;;;29406:8:0;;:22;;:24;;;;;;;;;;;;;;:8;:24;;;;;;;;;;29986:304;22529:28;:26;:28::i;:::-;22528:29;22520:80;;;;-1:-1:-1;;;22520:80:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22620:28;:26;:28::i;:::-;22619:29;22611:80;;;;-1:-1:-1;;;22611:80:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30059:10:::1;26471:20:::0;;26467:240:::1;;26508:22;;:::i;:::-;-1:-1:-1::0;;;;;;26533:15:0;::::1;;::::0;;;:7:::1;:15;::::0;;;;;;;;26508:40;;::::1;::::0;::::1;::::0;;;;;;::::1;::::0;::::1;::::0;;;::::1;::::0;;;;::::1;;::::0;;;;;;;;26583:14:::1;26541:6:::0;26583::::1;:14::i;:::-;26563:17;::::0;::::1;:34:::0;26637:21:::1;:19;:21::i;:::-;26612:46:::0;;-1:-1:-1;;;;;26673:15:0;::::1;26612:22;26673:15:::0;;;:7:::1;:15;::::0;;;;;;;;:22;;;;;;::::1;::::0;::::1;::::0;::::1;::::0;;::::1;::::0;::::1;::::0;;::::1;::::0;26467:240:::1;30099:1:::2;30090:6;:10;30082:48;;;::::0;;-1:-1:-1;;;30082:48:0;;::::2;;::::0;::::2;::::0;::::2;::::0;;;;::::2;::::0;;;;;;;;;;;;;::::2;;30141:19;30153:6;30141:11;:19::i;:::-;30209:8;;;;;;;;;-1:-1:-1::0;;;;;30209:8:0::2;-1:-1:-1::0;;;;;30209:14:0::2;;:16;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::2;;;;;;;;;;;;::::0;::::2;;;;;;;;;;;;;;;;;;;::::0;::::2;;-1:-1:-1::0;30209:16:0;30179:10:::2;30171:19;::::0;;;:7:::2;30209:16;30171:19:::0;;;;;;;;:35:::2;;:54:::0;;;;30256:26;;;;;;;30179:10;;30256:26:::2;::::0;;;;;;;::::2;-1:-1:-1::0;;22726:12:0;22718:21;;;;:7;:21;;;;;;;;22740:9;22718:32;;;;;;;;:39;;22753:4;-1:-1:-1;;22718:39:0;;;;;;;;22790:10;22768:33;;;;;;:40;;;;;;;;;;29986:304::o;23915:19::-;;;-1:-1:-1;;;;;23915:19:0;;:::o;27597:101::-;26189:8;;-1:-1:-1;;;;;26189:8:0;26201:10;26189:22;26181:72;;;;-1:-1:-1;;;26181:72:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27670:8:::1;:20:::0;;-1:-1:-1;;;;;;27670:20:0::1;-1:-1:-1::0;;;;;27670:20:0;;;::::1;::::0;;;::::1;::::0;;27597:101::o;30802:539::-;30845:10;26471:20;;26467:240;;26508:22;;:::i;:::-;-1:-1:-1;;;;;;26533:15:0;;;;;;:7;:15;;;;;;;;;26508:40;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26583:14;26541:6;26583;:14::i;:::-;26563:17;;;:34;26637:21;:19;:21::i;:::-;26612:46;;-1:-1:-1;;;;;26673:15:0;;26612:22;26673:15;;;:7;:15;;;;;;;;;:22;;;;;;;;;;;;;;;;;;;;26467:240;30893:10:::1;30868:14;30885:19:::0;;;:7:::1;:19;::::0;;;;:32:::1;;::::0;30932:10;;30928:406:::1;;31030:8;;;;;;;;;-1:-1:-1::0;;;;;31030:8:0::1;-1:-1:-1::0;;;;;31030:14:0::1;;:16;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;31030:16:0;31007:18:::1;::::0;30975:10:::1;30967:19;::::0;;;:7:::1;31030:16;30967:19:::0;;;;:35:::1;;::::0;:59:::1;::::0;:39:::1;:59::i;:::-;:79;;30959:125;;;;-1:-1:-1::0;;;30959:125:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31137:8;;;;;;;;;-1:-1:-1::0;;;;;31137:8:0::1;-1:-1:-1::0;;;;;31137:14:0::1;;:16;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;31137:16:0;31107:10:::1;31099:19;::::0;;;:7:::1;31137:16;31099:19:::0;;;;:35:::1;::::0;::::1;:54:::0;;;;31183:32:::1;::::0;;::::1;:36:::0;;;;31234:5:::1;::::0;:38:::1;::::0;-1:-1:-1;;;;;31234:5:0;;::::1;::::0;31265:6;31234:18:::1;:38::i;:::-;31292:30;::::0;;;;;;;31303:10:::1;::::0;31292:30:::1;::::0;;;;;::::1;::::0;;::::1;30928:406;26717:1;30802:539:::0;:::o;26900:689::-;26780:11;;-1:-1:-1;;;26780:11:0;;;;26779:12;26771:55;;;;;-1:-1:-1;;;26771:55:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;27038:5:::1;:14:::0;;-1:-1:-1;;;;;27038:14:0;;::::1;-1:-1:-1::0;;;;;;27038:14:0;;::::1;;::::0;;;:5:::1;27063:14:::0;;;;::::1;::::0;;::::1;;::::0;;27088:8:::1;:20:::0;;;;::::1;::::0;;;::::1;::::0;;;::::1;::::0;;27121:40:::1;;:::i;:::-;-1:-1:-1::0;27164:77:0::1;::::0;;::::1;::::0;::::1;::::0;;27189:12:::1;27164:77:::0;;;-1:-1:-1;27164:77:0::1;::::0;;::::1;::::0;;;;;;;;;27252:16:::1;:38:::0;;::::1;::::0;::::1;::::0;;;;;;::::1;::::0;;::::1;::::0;;::::1;::::0;;;;;;;;;;;;;;;;;;;27326:1:::1;27303:20;:24:::0;;;27252:38:::1;27389:18;:22:::0;27478:18;;-1:-1:-1;;;;;;;;;;27478:18:0;;::::1;-1:-1:-1::0;;;27478:18:0::1;27507:21;27518:10;27507:21:::0;;::::1;::::0;;;27544:37;;;;;;;27164:77;;27518:10;27544:37:::1;::::0;;;;;;;;::::1;26837:1;26900:689:::0;;;:::o;25614:43::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;25614:43:0;:::o;29214:109::-;29290:8;;:25;;;-1:-1:-1;;;29290:25:0;;;;29263:7;;-1:-1:-1;;;;;29290:8:0;;:23;;:25;;;;;;;;;;;;;;:8;:25;;;;;;;;;;30719:75;30755:31;30764:21;30774:10;30764:9;:21::i;:::-;30755:8;:31::i;:::-;30719:75::o;28290:143::-;28342:24;;:::i;:::-;28386:16;28403:21;:19;:21::i;:::-;28386:39;;;;;;;;;;;;;;;;;;28379:46;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28290:143;:::o;28586:166::-;28652:24;;:::i;:::-;28696:16;28713:30;28736:6;28713:22;:30::i;:::-;28696:48;;;;;;;;;;;;;;;;;;28689:55;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28586:166;;;:::o;6050:158::-;6108:7;6141:1;6136;:6;;6128:49;;;;;-1:-1:-1;;;6128:49:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;6195:5:0;;;6050:158;;;;;:::o;6467:220::-;6525:7;6549:6;6545:20;;-1:-1:-1;6564:1:0;6557:8;;6545:20;6588:5;;;6592:1;6588;:5;:1;6612:5;;;;;:10;6604:56;;;;-1:-1:-1;;;6604:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6678:1;6467:220;-1:-1:-1;;;6467:220:0:o;7165:153::-;7223:7;7255:1;7251;:5;7243:44;;;;;-1:-1:-1;;;7243:44:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;7309:1;7305;:5;;;;;;;7165:153;-1:-1:-1;;;7165:153:0:o;5588:179::-;5646:7;5678:5;;;5702:6;;;;5694:46;;;;;-1:-1:-1;;;5694:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;22218:125;22311:12;22279:4;22303:21;;;:7;:21;;;;;;;;22325:9;22303:32;;;;;;;;;;22218:125;:::o;22351:126::-;22444:12;22412:4;22436:21;;;:7;:21;;;;;;;;22458:10;22436:33;;;;;;;;;;22351:126;:::o;24497:367::-;24589:10;24557:19;24579:21;;;:9;:21;;;;;;24619;;;;24611:88;;;;-1:-1:-1;;;24611:88:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;24725:12;;:24;;24742:6;24725:16;:24::i;:::-;24710:12;:39;24784:23;:11;24800:6;24784:15;:23::i;:::-;24770:10;24760:21;;;;:9;:21;;;;;:47;;;;24818:5;;:38;;-1:-1:-1;;;;;24818:5:0;;;;24849:6;18968:177;19078:58;;;-1:-1:-1;;;;;19078:58:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;19078:58:0;-1:-1:-1;;;19078:58:0;;;19051:86;;19071:5;;19051:19;:86::i;19153:205::-;19281:68;;;-1:-1:-1;;;;;19281:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;19281:68:0;-1:-1:-1;;;19281:68:0;;;19254:96;;19274:5;;19254:19;:96::i;:::-;19153:205;;;;:::o;24249:240::-;24321:12;;:24;;24338:6;24321:16;:24::i;:::-;24306:12;:39;24390:10;24380:21;;;;:9;:21;;;;;;:33;;24406:6;24380:25;:33::i;:::-;24366:10;24356:21;;;;:9;:21;;;;;:57;;;;24424:5;;:57;;-1:-1:-1;;;;;24424:5:0;;;;24467:4;24474:6;24424:22;:57::i;:::-;24249:240;:::o;21273:761::-;21697:23;21723:69;21751:4;21723:69;;;;;;;;;;;;;;;;;21731:5;-1:-1:-1;;;;;21723:27:0;;;:69;;;;;:::i;:::-;21807:17;;21697:95;;-1:-1:-1;21807:21:0;21803:224;;21949:10;21938:30;;;;;;;;;;;;;;;-1:-1:-1;21938:30:0;21930:85;;;;-1:-1:-1;;;21930:85:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13955:195;14058:12;14090:52;14112:6;14120:4;14126:1;14129:12;14058;15259:18;15270:6;15259:10;:18::i;:::-;15251:60;;;;;-1:-1:-1;;;15251:60:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;15385:12;15399:23;15426:6;-1:-1:-1;;;;;15426:11:0;15446:5;15454:4;15426:33;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;15426:33:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15384:75;;;;15477:52;15495:7;15504:10;15516:12;15477:17;:52::i;:::-;15470:59;15007:530;-1:-1:-1;;;;;;;15007:530:0:o;11037:422::-;11404:20;11443:8;;;11037:422::o;17547:742::-;17662:12;17691:7;17687:595;;;-1:-1:-1;17722:10:0;17715:17;;17687:595;17836:17;;:21;17832:439;;18099:10;18093:17;18160:15;18147:10;18143:2;18139:19;18132:44;18047:148;18242:12;18235:20;;-1:-1:-1;;;18235:20:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;;;;;;;;;;;;;;:::o
Swarm Source
ipfs://14a28f02350f26fc809bfd1574910ec31cdd402316b822a08f573d6e13e53570
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 31 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
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.