More Info
Private Name Tags
ContractCreator
Latest 25 from a total of 1,768 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
Value | ||||
---|---|---|---|---|---|---|---|---|---|
Exit | 11559558 | 1280 days ago | IN | 0 ETH | 0.01431681 | ||||
Exit | 11520993 | 1286 days ago | IN | 0 ETH | 0.0101842 | ||||
Exit | 11498462 | 1290 days ago | IN | 0 ETH | 0.00520611 | ||||
Exit | 11495646 | 1290 days ago | IN | 0 ETH | 0.00483609 | ||||
Exit | 11467254 | 1294 days ago | IN | 0 ETH | 0.0194722 | ||||
Stake | 11467251 | 1294 days ago | IN | 0 ETH | 0.0117088 | ||||
Exit | 11459221 | 1296 days ago | IN | 0 ETH | 0.00331027 | ||||
Exit | 11457211 | 1296 days ago | IN | 0 ETH | 0.00932596 | ||||
Claim Reward | 11456939 | 1296 days ago | IN | 0 ETH | 0.00133262 | ||||
Exit | 11456939 | 1296 days ago | IN | 0 ETH | 0.0053201 | ||||
Exit | 11454259 | 1296 days ago | IN | 0 ETH | 0.00615738 | ||||
Exit | 11449755 | 1297 days ago | IN | 0 ETH | 0.00331027 | ||||
Exit | 11446766 | 1297 days ago | IN | 0 ETH | 0.00699213 | ||||
Exit | 11445915 | 1298 days ago | IN | 0 ETH | 0.00321291 | ||||
Exit | 11445172 | 1298 days ago | IN | 0 ETH | 0.0038847 | ||||
Exit | 11443623 | 1298 days ago | IN | 0 ETH | 0.00280902 | ||||
Exit | 11443063 | 1298 days ago | IN | 0 ETH | 0.00280902 | ||||
Exit | 11442834 | 1298 days ago | IN | 0 ETH | 0.00192774 | ||||
Exit | 11440390 | 1298 days ago | IN | 0 ETH | 0.00438409 | ||||
Exit | 11440041 | 1298 days ago | IN | 0 ETH | 0.00331027 | ||||
Exit | 11439447 | 1299 days ago | IN | 0 ETH | 0.00301819 | ||||
Exit | 11438767 | 1299 days ago | IN | 0 ETH | 0.0046581 | ||||
Exit | 11436710 | 1299 days ago | IN | 0 ETH | 0.00194722 | ||||
Exit | 11436428 | 1299 days ago | IN | 0 ETH | 0.00321291 | ||||
Exit | 11436181 | 1299 days ago | IN | 0 ETH | 0.00340763 |
View more zero value Internal Transactions in Advanced View mode
Advanced mode:
Loading...
Loading
Contract Name:
Boardroom
Compiler Version
v0.6.12+commit.27d51765
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2020-12-07 */ // File: @openzeppelin/contracts/token/ERC20/IERC20.sol pragma solidity ^0.6.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/SafeMath.sol pragma solidity ^0.6.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, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, 'SafeMath: addition overflow'); return c; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { return sub(a, b, 'SafeMath: subtraction overflow'); } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { require(b <= a, errorMessage); uint256 c = a - b; return c; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522 if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, 'SafeMath: multiplication overflow'); return c; } /** * @dev Returns the integer division of two unsigned integers. Reverts on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { return div(a, b, 'SafeMath: division by zero'); } /** * @dev Returns the integer division of two unsigned integers. Reverts with custom message on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { require(b > 0, errorMessage); uint256 c = a / b; // assert(a == b * c + a % b); // There is no case in which this doesn't hold return c; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { return mod(a, b, 'SafeMath: modulo by zero'); } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts with custom message when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { require(b != 0, errorMessage); return a % b; } } // File: @openzeppelin/contracts/utils/Address.sol pragma solidity ^0.6.2; /** * @dev Collection of functions related to the address type */ library Address { /** * @dev Returns true if `account` is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, `isContract` will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * ==== */ function isContract(address account) internal view returns (bool) { // This method relies in 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' ); return _functionCallWithValue(target, data, value, errorMessage); } function _functionCallWithValue( address target, bytes memory data, uint256 weiValue, string memory errorMessage ) private returns (bytes memory) { require(isContract(target), 'Address: call to non-contract'); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.call{value: weiValue}( data ); 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/SafeERC20.sol pragma solidity ^0.6.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/lib/Safe112.sol pragma solidity ^0.6.0; library Safe112 { function add(uint112 a, uint112 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, 'Safe112: addition overflow'); return c; } function sub(uint112 a, uint112 b) internal pure returns (uint256) { return sub(a, b, 'Safe112: subtraction overflow'); } function sub( uint112 a, uint112 b, string memory errorMessage ) internal pure returns (uint112) { require(b <= a, errorMessage); uint112 c = a - b; return c; } function mul(uint112 a, uint112 b) internal pure returns (uint256) { if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, 'Safe112: multiplication overflow'); return c; } function div(uint112 a, uint112 b) internal pure returns (uint256) { return div(a, b, 'Safe112: division by zero'); } function div( uint112 a, uint112 b, string memory errorMessage ) internal pure returns (uint112) { // Solidity only automatically asserts when dividing by 0 require(b > 0, errorMessage); uint112 c = a / b; return c; } function mod(uint112 a, uint112 b) internal pure returns (uint256) { return mod(a, b, 'Safe112: modulo by zero'); } function mod( uint112 a, uint112 b, string memory errorMessage ) internal pure returns (uint112) { require(b != 0, errorMessage); return a % b; } } // File: @openzeppelin/contracts/GSN/Context.sol pragma solidity ^0.6.0; /* * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with GSN meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal virtual view returns (address payable) { return msg.sender; } function _msgData() internal virtual view returns (bytes memory) { this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691 return msg.data; } } // File: @openzeppelin/contracts/access/Ownable.sol pragma solidity ^0.6.0; /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ contract Ownable is Context { address private _owner; event OwnershipTransferred( address indexed previousOwner, address indexed newOwner ); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() internal { address msgSender = _msgSender(); _owner = msgSender; emit OwnershipTransferred(address(0), msgSender); } /** * @dev Returns the address of the current owner. */ function owner() public view returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(_owner == _msgSender(), 'Ownable: caller is not the owner'); _; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { emit OwnershipTransferred(_owner, address(0)); _owner = address(0); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { require( newOwner != address(0), 'Ownable: new owner is the zero address' ); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } } // File: contracts/owner/Operator.sol pragma solidity ^0.6.0; contract Operator is Context, Ownable { address private _operator; event OperatorTransferred( address indexed previousOperator, address indexed newOperator ); constructor() internal { _operator = _msgSender(); emit OperatorTransferred(address(0), _operator); } function operator() public view returns (address) { return _operator; } modifier onlyOperator() { require( _operator == msg.sender, 'operator: caller is not the operator' ); _; } function isOperator() public view returns (bool) { return _msgSender() == _operator; } function transferOperator(address newOperator_) public onlyOwner { _transferOperator(newOperator_); } function _transferOperator(address newOperator_) internal { require( newOperator_ != address(0), 'operator: zero address given for new operator' ); emit OperatorTransferred(address(0), newOperator_); _operator = newOperator_; } } // 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); } // File: contracts/Boardroom.sol pragma solidity ^0.6.0; //pragma experimental ABIEncoderV2; 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 directorShare = _balances[msg.sender]; require( directorShare >= amount, 'Boardroom: withdraw request greater than staked amount' ); _totalSupply = _totalSupply.sub(amount); _balances[msg.sender] = directorShare.sub(amount); share.safeTransfer(msg.sender, amount); } } contract Boardroom is ShareWrapper, ContractGuard, Operator { using SafeERC20 for IERC20; using Address for address; using SafeMath for uint256; using Safe112 for uint112; /* ========== DATA STRUCTURES ========== */ struct Boardseat { uint256 lastSnapshotIndex; uint256 rewardEarned; } struct BoardSnapshot { uint256 timestamp; uint256 rewardReceived; uint256 rewardPerShare; } /* ========== STATE VARIABLES ========== */ IERC20 private cash; mapping(address => Boardseat) private directors; BoardSnapshot[] private boardHistory; /* ========== CONSTRUCTOR ========== */ constructor(IERC20 _cash, IERC20 _share) public { cash = _cash; share = _share; BoardSnapshot memory genesisSnapshot = BoardSnapshot(now, 0, 0); boardHistory.push(genesisSnapshot); } /* ========== Modifiers =============== */ modifier directorExists { require( balanceOf(msg.sender) > 0, 'Boardroom: The director does not exist' ); _; } modifier updateReward(address director) { uint256 currentIndex = latestSnapshotIndex(); if (director != address(0)) { Boardseat memory seat = directors[director]; seat.rewardEarned = earned(director); seat.lastSnapshotIndex = currentIndex; directors[director] = seat; } _; } /* ========== VIEW FUNCTIONS ========== */ // =========== Snapshot getters function latestSnapshotIndex() public view returns (uint256) { return boardHistory.length.sub(1); } function getLatestSnapshot() internal view returns (BoardSnapshot memory) { return boardHistory[latestSnapshotIndex()]; } function getLastSnapshotIndexOf(address director) public view returns (uint256) { return directors[director].lastSnapshotIndex; } function getLastSnapshotOf(address director) internal view returns (BoardSnapshot memory) { return boardHistory[getLastSnapshotIndexOf(director)]; } // =========== Director getters function rewardPerShare() public view returns (uint256) { return getLatestSnapshot().rewardPerShare; } function earned(address director) public view returns (uint256) { uint256 latestRPS = getLatestSnapshot().rewardPerShare; uint256 storedRPS = getLastSnapshotOf(director).rewardPerShare; return balanceOf(director).mul(latestRPS.sub(storedRPS)).add( directors[director].rewardEarned ); } /* ========== MUTATIVE FUNCTIONS ========== */ function stake(uint256 amount) public override onlyOneBlock updateReward(msg.sender) { require(amount > 0, 'Boardroom: Cannot stake 0'); super.stake(amount); emit Staked(msg.sender, amount); } function withdraw(uint256 amount) public override onlyOneBlock directorExists updateReward(msg.sender) { require(amount > 0, 'Boardroom: Cannot withdraw 0'); super.withdraw(amount); emit Withdrawn(msg.sender, amount); } function exit() external { withdraw(balanceOf(msg.sender)); claimReward(); } function claimReward() public updateReward(msg.sender) { uint256 reward = directors[msg.sender].rewardEarned; if (reward > 0) { directors[msg.sender].rewardEarned = 0; cash.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.div(totalSupply())); BoardSnapshot memory newSnapshot = BoardSnapshot({ timestamp: now, rewardReceived: amount, rewardPerShare: nextRPS }); boardHistory.push(newSnapshot); cash.safeTransferFrom(msg.sender, address(this), amount); emit RewardAdded(msg.sender, amount); } /* ========== EVENTS ========== */ 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); }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"contract IERC20","name":"_cash","type":"address"},{"internalType":"contract IERC20","name":"_share","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOperator","type":"address"},{"indexed":true,"internalType":"address","name":"newOperator","type":"address"}],"name":"OperatorTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":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":[],"name":"claimReward","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"director","type":"address"}],"name":"earned","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"exit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"director","type":"address"}],"name":"getLastSnapshotIndexOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isOperator","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"latestSnapshotIndex","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":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"rewardPerShare","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","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":[{"internalType":"address","name":"newOperator_","type":"address"}],"name":"transferOperator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
608060405234801561001057600080fd5b506040516119bb3803806119bb8339818101604052604081101561003357600080fd5b50805160209091015160006100466101c8565b600480546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35061009c6101c8565b600580546001600160a01b0319166001600160a01b0392831617908190556040519116906000907f74da04524d50c64947f5dd5381ef1a4dca5cba8ed1d816243f9e48aa0b5617ed908290a3600680546001600160a01b038085166001600160a01b03199283161790925560008054928416929091169190911790556101206101cc565b50506040805160608101825242815260006020820181815292820181815260088054600181018255925291517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee360039092029182015591517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee4830155517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee590910155506101ed565b3390565b60405180606001604052806000815260200160008152602001600081525090565b6117bf806101fc6000396000f3fe608060405234801561001057600080fd5b50600436106101155760003560e01c8063714b4658116100a2578063a694fc3a11610071578063a694fc3a14610268578063a8d5fd6514610285578063b88a802f1461028d578063e9fad8ee14610295578063f2fde38b1461029d57610115565b8063714b465814610215578063715018a61461023b5780638da5cb5b1461024357806397ffe1d71461024b57610115565b80633f9e3f04116100e95780633f9e3f041461019f5780634456eda2146101a7578063446a2ec8146101c3578063570ca735146101cb57806370a08231146101ef57610115565b80628cc2621461011a57806318160ddd1461015257806329605e771461015a5780632e1a7d4d14610182575b600080fd5b6101406004803603602081101561013057600080fd5b50356001600160a01b03166102c3565b60408051918252519081900360200190f35b610140610332565b6101806004803603602081101561017057600080fd5b50356001600160a01b0316610338565b005b6101806004803603602081101561019857600080fd5b50356103ae565b6101406105de565b6101af6105f4565b604080519115158252519081900360200190f35b61014061061a565b6101d361062d565b604080516001600160a01b039092168252519081900360200190f35b6101406004803603602081101561020557600080fd5b50356001600160a01b031661063c565b6101406004803603602081101561022b57600080fd5b50356001600160a01b0316610657565b610180610672565b6101d3610726565b6101806004803603602081101561026157600080fd5b5035610735565b6101806004803603602081101561027e57600080fd5b5035610a0e565b6101d3610bf7565b610180610c06565b610180610d14565b610180600480360360208110156102b357600080fd5b50356001600160a01b0316610d2f565b6000806102ce610e3a565b60400151905060006102df84610e92565b6040908101516001600160a01b03861660009081526007602052919091206001015490915061032a906103246103158585610eed565b61031e8861063c565b90610f38565b90610f91565b949350505050565b60015490565b610340610feb565b6004546001600160a01b039081169116146103a2576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6103ab81610fef565b50565b6103b661108c565b156103f25760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b6103fa6110ad565b156104365760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b60006104413361063c565b1161047d5760405162461bcd60e51b81526004018080602001828103825260268152602001806116de6026913960400191505060405180910390fd5b3360006104886105de565b90506001600160a01b0382161561050a576104a16115da565b506001600160a01b03821660009081526007602090815260409182902082518084019093528054835260010154908201526104db836102c3565b60208083019182528383526001600160a01b038516600090815260079091526040902091518255516001909101555b6000831161055f576040805162461bcd60e51b815260206004820152601c60248201527f426f617264726f6f6d3a2043616e6e6f74207769746864726177203000000000604482015290519081900360640190fd5b610568836110ce565b60408051848152905133917f7084f5476618d8e60b11ef0d7d3f06914655adb8793e28ff7f018d4c76d505d5919081900360200190a250504360009081526003602090815260408083203284529091528082208054600160ff199182168117909255338452919092208054909116909117905550565b6008546000906105ef906001610eed565b905090565b6005546000906001600160a01b031661060b610feb565b6001600160a01b031614905090565b6000610624610e3a565b60400151905090565b6005546001600160a01b031690565b6001600160a01b031660009081526002602052604090205490565b6001600160a01b031660009081526007602052604090205490565b61067a610feb565b6004546001600160a01b039081169116146106dc576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6004546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600480546001600160a01b0319169055565b6004546001600160a01b031690565b61073d61108c565b156107795760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b6107816110ad565b156107bd5760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b6005546001600160a01b031633146108065760405162461bcd60e51b81526004018080602001828103825260248152602001806116ba6024913960400191505060405180910390fd5b6000811161085b576040805162461bcd60e51b815260206004820152601c60248201527f426f617264726f6f6d3a2043616e6e6f7420616c6c6f63617465203000000000604482015290519081900360640190fd5b6000610865610332565b116108a15760405162461bcd60e51b81526004018080602001828103825260308152602001806116696030913960400191505060405180910390fd5b60006108ab610e3a565b60400151905060006108cf6108c86108c1610332565b8590611166565b8390610f91565b90506108d96115f4565b5060408051606081018252428152602081018581529181018381526008805460018101825560009190915282517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee360039092029182015592517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee4840155517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee590920191909155600654610997906001600160a01b03163330876111a8565b60408051858152905133917fac24935fd910bc682b5ccb1a07b718cadf8cf2f6d1404c4f3ddc3662dae40e29919081900360200190a250504360009081526003602090815260408083203284529091528082208054600160ff19918216811790925533845291909220805490911690911790555050565b610a1661108c565b15610a525760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b610a5a6110ad565b15610a965760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b336000610aa16105de565b90506001600160a01b03821615610b2357610aba6115da565b506001600160a01b0382166000908152600760209081526040918290208251808401909352805483526001015490820152610af4836102c3565b60208083019182528383526001600160a01b038516600090815260079091526040902091518255516001909101555b60008311610b78576040805162461bcd60e51b815260206004820152601960248201527f426f617264726f6f6d3a2043616e6e6f74207374616b65203000000000000000604482015290519081900360640190fd5b610b8183611208565b60408051848152905133917f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d919081900360200190a250504360009081526003602090815260408083203284529091528082208054600160ff199182168117909255338452919092208054909116909117905550565b6000546001600160a01b031681565b336000610c116105de565b90506001600160a01b03821615610c9357610c2a6115da565b506001600160a01b0382166000908152600760209081526040918290208251808401909352805483526001015490820152610c64836102c3565b60208083019182528383526001600160a01b038516600090815260079091526040902091518255516001909101555b336000908152600760205260409020600101548015610d0f5733600081815260076020526040812060010155600654610cd8916001600160a01b03909116908361125e565b60408051828152905133917fe2403640ba68fed3a2f88b7557551d1993f84b99bb10ff833f0cf8db0c5e0486919081900360200190a25b505050565b610d25610d203361063c565b6103ae565b610d2d610c06565b565b610d37610feb565b6004546001600160a01b03908116911614610d99576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6001600160a01b038116610dde5760405162461bcd60e51b81526004018080602001828103825260268152602001806116166026913960400191505060405180910390fd5b6004546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600480546001600160a01b0319166001600160a01b0392909216919091179055565b610e426115f4565b6008610e4c6105de565b81548110610e5657fe5b90600052602060002090600302016040518060600160405290816000820154815260200160018201548152602001600282015481525050905090565b610e9a6115f4565b6008610ea583610657565b81548110610eaf57fe5b906000526020600020906003020160405180606001604052908160008201548152602001600182015481526020016002820154815250509050919050565b6000610f2f83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506112b0565b90505b92915050565b600082610f4757506000610f32565b82820282848281610f5457fe5b0414610f2f5760405162461bcd60e51b81526004018080602001828103825260218152602001806116996021913960400191505060405180910390fd5b600082820183811015610f2f576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b3390565b6001600160a01b0381166110345760405162461bcd60e51b815260040180806020018281038252602d81526020018061163c602d913960400191505060405180910390fd5b6040516001600160a01b038216906000907f74da04524d50c64947f5dd5381ef1a4dca5cba8ed1d816243f9e48aa0b5617ed908290a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b43600090815260036020908152604080832032845290915290205460ff1690565b43600090815260036020908152604080832033845290915290205460ff1690565b336000908152600260205260409020548181101561111d5760405162461bcd60e51b81526004018080602001828103825260368152602001806117546036913960400191505060405180910390fd5b60015461112a9083610eed565b6001556111378183610eed565b336000818152600260205260408120929092559054611162916001600160a01b03909116908461125e565b5050565b6000610f2f83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611347565b604080516001600160a01b0380861660248301528416604482015260648082018490528251808303909101815260849091019091526020810180516001600160e01b03166323b872dd60e01b1790526112029085906113ac565b50505050565b6001546112159082610f91565b600155336000908152600260205260409020546112329082610f91565b3360008181526002602052604081209290925590546103ab916001600160a01b039091169030846111a8565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610d0f9084906113ac565b6000818484111561133f5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156113045781810151838201526020016112ec565b50505050905090810190601f1680156113315780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b600081836113965760405162461bcd60e51b81526020600482018181528351602484015283519092839260449091019190850190808383600083156113045781810151838201526020016112ec565b5060008385816113a257fe5b0495945050505050565b6060611401826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661145d9092919063ffffffff16565b805190915015610d0f5780806020019051602081101561142057600080fd5b5051610d0f5760405162461bcd60e51b815260040180806020018281038252602a815260200180611704602a913960400191505060405180910390fd5b606061032a84846000856060611472856115d4565b6114c3576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b602083106115025780518252601f1990920191602091820191016114e3565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114611564576040519150601f19603f3d011682016040523d82523d6000602084013e611569565b606091505b5091509150811561157d57915061032a9050565b80511561158d5780518082602001fd5b60405162461bcd60e51b81526020600482018181528651602484015286518793919283926044019190850190808383600083156113045781810151838201526020016112ec565b3b151590565b604051806040016040528060008152602001600081525090565b6040518060600160405280600081526020016000815260200160008152509056fe4f776e61626c653a206e6577206f776e657220697320746865207a65726f20616464726573736f70657261746f723a207a65726f206164647265737320676976656e20666f72206e6577206f70657261746f72426f617264726f6f6d3a2043616e6e6f7420616c6c6f63617465207768656e20746f74616c537570706c792069732030536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f776f70657261746f723a2063616c6c6572206973206e6f7420746865206f70657261746f72426f617264726f6f6d3a20546865206469726563746f7220646f6573206e6f742065786973745361666545524332303a204552433230206f7065726174696f6e20646964206e6f742073756363656564436f6e747261637447756172643a206f6e6520626c6f636b2c206f6e652066756e6374696f6e426f617264726f6f6d3a20776974686472617720726571756573742067726561746572207468616e207374616b656420616d6f756e74a2646970667358221220495693a7069736a26e001d8800215368484b0347d9cf5a89c0f8e5e34e83860d64736f6c634300060c00330000000000000000000000003449fc1cd036255ba1eb19d65ff4ba2b8903a69a000000000000000000000000a7ed29b253d8b4e3109ce07c80fc570f81b63696
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106101155760003560e01c8063714b4658116100a2578063a694fc3a11610071578063a694fc3a14610268578063a8d5fd6514610285578063b88a802f1461028d578063e9fad8ee14610295578063f2fde38b1461029d57610115565b8063714b465814610215578063715018a61461023b5780638da5cb5b1461024357806397ffe1d71461024b57610115565b80633f9e3f04116100e95780633f9e3f041461019f5780634456eda2146101a7578063446a2ec8146101c3578063570ca735146101cb57806370a08231146101ef57610115565b80628cc2621461011a57806318160ddd1461015257806329605e771461015a5780632e1a7d4d14610182575b600080fd5b6101406004803603602081101561013057600080fd5b50356001600160a01b03166102c3565b60408051918252519081900360200190f35b610140610332565b6101806004803603602081101561017057600080fd5b50356001600160a01b0316610338565b005b6101806004803603602081101561019857600080fd5b50356103ae565b6101406105de565b6101af6105f4565b604080519115158252519081900360200190f35b61014061061a565b6101d361062d565b604080516001600160a01b039092168252519081900360200190f35b6101406004803603602081101561020557600080fd5b50356001600160a01b031661063c565b6101406004803603602081101561022b57600080fd5b50356001600160a01b0316610657565b610180610672565b6101d3610726565b6101806004803603602081101561026157600080fd5b5035610735565b6101806004803603602081101561027e57600080fd5b5035610a0e565b6101d3610bf7565b610180610c06565b610180610d14565b610180600480360360208110156102b357600080fd5b50356001600160a01b0316610d2f565b6000806102ce610e3a565b60400151905060006102df84610e92565b6040908101516001600160a01b03861660009081526007602052919091206001015490915061032a906103246103158585610eed565b61031e8861063c565b90610f38565b90610f91565b949350505050565b60015490565b610340610feb565b6004546001600160a01b039081169116146103a2576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6103ab81610fef565b50565b6103b661108c565b156103f25760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b6103fa6110ad565b156104365760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b60006104413361063c565b1161047d5760405162461bcd60e51b81526004018080602001828103825260268152602001806116de6026913960400191505060405180910390fd5b3360006104886105de565b90506001600160a01b0382161561050a576104a16115da565b506001600160a01b03821660009081526007602090815260409182902082518084019093528054835260010154908201526104db836102c3565b60208083019182528383526001600160a01b038516600090815260079091526040902091518255516001909101555b6000831161055f576040805162461bcd60e51b815260206004820152601c60248201527f426f617264726f6f6d3a2043616e6e6f74207769746864726177203000000000604482015290519081900360640190fd5b610568836110ce565b60408051848152905133917f7084f5476618d8e60b11ef0d7d3f06914655adb8793e28ff7f018d4c76d505d5919081900360200190a250504360009081526003602090815260408083203284529091528082208054600160ff199182168117909255338452919092208054909116909117905550565b6008546000906105ef906001610eed565b905090565b6005546000906001600160a01b031661060b610feb565b6001600160a01b031614905090565b6000610624610e3a565b60400151905090565b6005546001600160a01b031690565b6001600160a01b031660009081526002602052604090205490565b6001600160a01b031660009081526007602052604090205490565b61067a610feb565b6004546001600160a01b039081169116146106dc576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6004546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600480546001600160a01b0319169055565b6004546001600160a01b031690565b61073d61108c565b156107795760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b6107816110ad565b156107bd5760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b6005546001600160a01b031633146108065760405162461bcd60e51b81526004018080602001828103825260248152602001806116ba6024913960400191505060405180910390fd5b6000811161085b576040805162461bcd60e51b815260206004820152601c60248201527f426f617264726f6f6d3a2043616e6e6f7420616c6c6f63617465203000000000604482015290519081900360640190fd5b6000610865610332565b116108a15760405162461bcd60e51b81526004018080602001828103825260308152602001806116696030913960400191505060405180910390fd5b60006108ab610e3a565b60400151905060006108cf6108c86108c1610332565b8590611166565b8390610f91565b90506108d96115f4565b5060408051606081018252428152602081018581529181018381526008805460018101825560009190915282517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee360039092029182015592517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee4840155517ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee590920191909155600654610997906001600160a01b03163330876111a8565b60408051858152905133917fac24935fd910bc682b5ccb1a07b718cadf8cf2f6d1404c4f3ddc3662dae40e29919081900360200190a250504360009081526003602090815260408083203284529091528082208054600160ff19918216811790925533845291909220805490911690911790555050565b610a1661108c565b15610a525760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b610a5a6110ad565b15610a965760405162461bcd60e51b815260040180806020018281038252602681526020018061172e6026913960400191505060405180910390fd5b336000610aa16105de565b90506001600160a01b03821615610b2357610aba6115da565b506001600160a01b0382166000908152600760209081526040918290208251808401909352805483526001015490820152610af4836102c3565b60208083019182528383526001600160a01b038516600090815260079091526040902091518255516001909101555b60008311610b78576040805162461bcd60e51b815260206004820152601960248201527f426f617264726f6f6d3a2043616e6e6f74207374616b65203000000000000000604482015290519081900360640190fd5b610b8183611208565b60408051848152905133917f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d919081900360200190a250504360009081526003602090815260408083203284529091528082208054600160ff199182168117909255338452919092208054909116909117905550565b6000546001600160a01b031681565b336000610c116105de565b90506001600160a01b03821615610c9357610c2a6115da565b506001600160a01b0382166000908152600760209081526040918290208251808401909352805483526001015490820152610c64836102c3565b60208083019182528383526001600160a01b038516600090815260079091526040902091518255516001909101555b336000908152600760205260409020600101548015610d0f5733600081815260076020526040812060010155600654610cd8916001600160a01b03909116908361125e565b60408051828152905133917fe2403640ba68fed3a2f88b7557551d1993f84b99bb10ff833f0cf8db0c5e0486919081900360200190a25b505050565b610d25610d203361063c565b6103ae565b610d2d610c06565b565b610d37610feb565b6004546001600160a01b03908116911614610d99576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6001600160a01b038116610dde5760405162461bcd60e51b81526004018080602001828103825260268152602001806116166026913960400191505060405180910390fd5b6004546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600480546001600160a01b0319166001600160a01b0392909216919091179055565b610e426115f4565b6008610e4c6105de565b81548110610e5657fe5b90600052602060002090600302016040518060600160405290816000820154815260200160018201548152602001600282015481525050905090565b610e9a6115f4565b6008610ea583610657565b81548110610eaf57fe5b906000526020600020906003020160405180606001604052908160008201548152602001600182015481526020016002820154815250509050919050565b6000610f2f83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506112b0565b90505b92915050565b600082610f4757506000610f32565b82820282848281610f5457fe5b0414610f2f5760405162461bcd60e51b81526004018080602001828103825260218152602001806116996021913960400191505060405180910390fd5b600082820183811015610f2f576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b3390565b6001600160a01b0381166110345760405162461bcd60e51b815260040180806020018281038252602d81526020018061163c602d913960400191505060405180910390fd5b6040516001600160a01b038216906000907f74da04524d50c64947f5dd5381ef1a4dca5cba8ed1d816243f9e48aa0b5617ed908290a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b43600090815260036020908152604080832032845290915290205460ff1690565b43600090815260036020908152604080832033845290915290205460ff1690565b336000908152600260205260409020548181101561111d5760405162461bcd60e51b81526004018080602001828103825260368152602001806117546036913960400191505060405180910390fd5b60015461112a9083610eed565b6001556111378183610eed565b336000818152600260205260408120929092559054611162916001600160a01b03909116908461125e565b5050565b6000610f2f83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611347565b604080516001600160a01b0380861660248301528416604482015260648082018490528251808303909101815260849091019091526020810180516001600160e01b03166323b872dd60e01b1790526112029085906113ac565b50505050565b6001546112159082610f91565b600155336000908152600260205260409020546112329082610f91565b3360008181526002602052604081209290925590546103ab916001600160a01b039091169030846111a8565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610d0f9084906113ac565b6000818484111561133f5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156113045781810151838201526020016112ec565b50505050905090810190601f1680156113315780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b600081836113965760405162461bcd60e51b81526020600482018181528351602484015283519092839260449091019190850190808383600083156113045781810151838201526020016112ec565b5060008385816113a257fe5b0495945050505050565b6060611401826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661145d9092919063ffffffff16565b805190915015610d0f5780806020019051602081101561142057600080fd5b5051610d0f5760405162461bcd60e51b815260040180806020018281038252602a815260200180611704602a913960400191505060405180910390fd5b606061032a84846000856060611472856115d4565b6114c3576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b602083106115025780518252601f1990920191602091820191016114e3565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114611564576040519150601f19603f3d011682016040523d82523d6000602084013e611569565b606091505b5091509150811561157d57915061032a9050565b80511561158d5780518082602001fd5b60405162461bcd60e51b81526020600482018181528651602484015286518793919283926044019190850190808383600083156113045781810151838201526020016112ec565b3b151590565b604051806040016040528060008152602001600081525090565b6040518060600160405280600081526020016000815260200160008152509056fe4f776e61626c653a206e6577206f776e657220697320746865207a65726f20616464726573736f70657261746f723a207a65726f206164647265737320676976656e20666f72206e6577206f70657261746f72426f617264726f6f6d3a2043616e6e6f7420616c6c6f63617465207768656e20746f74616c537570706c792069732030536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f776f70657261746f723a2063616c6c6572206973206e6f7420746865206f70657261746f72426f617264726f6f6d3a20546865206469726563746f7220646f6573206e6f742065786973745361666545524332303a204552433230206f7065726174696f6e20646964206e6f742073756363656564436f6e747261637447756172643a206f6e6520626c6f636b2c206f6e652066756e6374696f6e426f617264726f6f6d3a20776974686472617720726571756573742067726561746572207468616e207374616b656420616d6f756e74a2646970667358221220495693a7069736a26e001d8800215368484b0347d9cf5a89c0f8e5e34e83860d64736f6c634300060c0033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
0000000000000000000000003449fc1cd036255ba1eb19d65ff4ba2b8903a69a000000000000000000000000a7ed29b253d8b4e3109ce07c80fc570f81b63696
-----Decoded View---------------
Arg [0] : _cash (address): 0x3449FC1Cd036255BA1EB19d65fF4BA2b8903A69a
Arg [1] : _share (address): 0xa7ED29B253D8B4E3109ce07c80fc570f81B63696
-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 0000000000000000000000003449fc1cd036255ba1eb19d65ff4ba2b8903a69a
Arg [1] : 000000000000000000000000a7ed29b253d8b4e3109ce07c80fc570f81b63696
Deployed Bytecode Sourcemap
27932:4978:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30371:362;;;;;;;;;;;;;;;;-1:-1:-1;30371:362:0;-1:-1:-1;;;;;30371:362:0;;:::i;:::-;;;;;;;;;;;;;;;;27050:91;;;:::i;25047:115::-;;;;;;;;;;;;;;;;-1:-1:-1;25047:115:0;-1:-1:-1;;;;;25047:115:0;;:::i;:::-;;31068:301;;;;;;;;;;;;;;;;-1:-1:-1;31068:301:0;;:::i;29559:113::-;;;:::i;24939:100::-;;;:::i;:::-;;;;;;;;;;;;;;;;;;30247:116;;;:::i;24674:85::-;;;:::i;:::-;;;;-1:-1:-1;;;;;24674:85:0;;;;;;;;;;;;;;27149:110;;;;;;;;;;;;;;;;-1:-1:-1;27149:110:0;-1:-1:-1;;;;;27149:110:0;;:::i;29823:175::-;;;;;;;;;;;;;;;;-1:-1:-1;29823:175:0;-1:-1:-1;;;;;29823:175:0;;:::i;23682:148::-;;;:::i;23040:79::-;;;:::i;31810:813::-;;;;;;;;;;;;;;;;-1:-1:-1;31810:813:0;;:::i;30795:265::-;;;;;;;;;;;;;;;;-1:-1:-1;30795:265:0;;:::i;26933:19::-;;;:::i;31484:318::-;;;:::i;31377:99::-;;;:::i;23985:281::-;;;;;;;;;;;;;;;;-1:-1:-1;23985:281:0;-1:-1:-1;;;;;23985:281:0;;:::i;30371:362::-;30426:7;30446:17;30466:19;:17;:19::i;:::-;:34;;;30446:54;;30511:17;30531:27;30549:8;30531:17;:27::i;:::-;:42;;;;;-1:-1:-1;;;;;30678:19:0;;;;;;:9;:19;;;;;;:32;;;30531:42;;-1:-1:-1;30606:119:0;;:49;30630:24;:9;30531:42;30630:13;:24::i;:::-;30606:19;30616:8;30606:9;:19::i;:::-;:23;;:49::i;:::-;:53;;:119::i;:::-;30586:139;30371:362;-1:-1:-1;;;;30371:362:0:o;27050:91::-;27121:12;;27050:91;:::o;25047:115::-;23262:12;:10;:12::i;:::-;23252:6;;-1:-1:-1;;;;;23252:6:0;;;:22;;;23244:67;;;;;-1:-1:-1;;;23244:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25123:31:::1;25141:12;25123:17;:31::i;:::-;25047:115:::0;:::o;31068:301::-;25969:28;:26;:28::i;:::-;25968:29;25946:117;;;;-1:-1:-1;;;25946:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26097:28;:26;:28::i;:::-;26096:29;26074:117;;;;-1:-1:-1;;;26074:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29000:1:::1;28976:21;28986:10;28976:9;:21::i;:::-;:25;28954:113;;;;-1:-1:-1::0;;;28954:113:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31204:10:::2;29146:20;29169:21;:19;:21::i;:::-;29146:44:::0;-1:-1:-1;;;;;;29205:22:0;::::2;::::0;29201:242:::2;;29244:21;;:::i;:::-;-1:-1:-1::0;;;;;;29268:19:0;::::2;;::::0;;;:9:::2;:19;::::0;;;;;;;;29244:43;;;;::::2;::::0;;;;;;;::::2;;::::0;;;::::2;::::0;29322:16:::2;29278:8:::0;29322:6:::2;:16::i;:::-;29302:17;::::0;;::::2;:36:::0;;;29353:37;;;-1:-1:-1;;;;;29405:19:0;::::2;29353:22;29405:19:::0;;;:9:::2;:19:::0;;;;;;:26;;;;;::::2;::::0;;::::2;::::0;29201:242:::2;31249:1:::3;31240:6;:10;31232:51;;;::::0;;-1:-1:-1;;;31232:51:0;;::::3;;::::0;::::3;::::0;::::3;::::0;;;;::::3;::::0;;;;;;;;;;;;;::::3;;31294:22;31309:6;31294:14;:22::i;:::-;31332:29;::::0;;;;;;;31342:10:::3;::::0;31332:29:::3;::::0;;;;;::::3;::::0;;::::3;-1:-1:-1::0;;26226:12:0;26218:21;;;;:7;:21;;;;;;;;26240:9;26218:32;;;;;;;;:39;;26253:4;-1:-1:-1;;26218:39:0;;;;;;;;26290:10;26268:33;;;;;;:40;;;;;;;;;;-1:-1:-1;31068:301:0:o;29559:113::-;29638:12;:19;29611:7;;29638:26;;29662:1;29638:23;:26::i;:::-;29631:33;;29559:113;:::o;24939:100::-;25022:9;;24982:4;;-1:-1:-1;;;;;25022:9:0;25006:12;:10;:12::i;:::-;-1:-1:-1;;;;;25006:25:0;;24999:32;;24939:100;:::o;30247:116::-;30294:7;30321:19;:17;:19::i;:::-;:34;;;30314:41;;30247:116;:::o;24674:85::-;24742:9;;-1:-1:-1;;;;;24742:9:0;24674:85;:::o;27149:110::-;-1:-1:-1;;;;;27233:18:0;27206:7;27233:18;;;:9;:18;;;;;;;27149:110::o;29823:175::-;-1:-1:-1;;;;;29953:19:0;29921:7;29953:19;;;:9;:19;;;;;:37;;29823:175::o;23682:148::-;23262:12;:10;:12::i;:::-;23252:6;;-1:-1:-1;;;;;23252:6:0;;;:22;;;23244:67;;;;;-1:-1:-1;;;23244:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23773:6:::1;::::0;23752:40:::1;::::0;23789:1:::1;::::0;-1:-1:-1;;;;;23773:6:0::1;::::0;23752:40:::1;::::0;23789:1;;23752:40:::1;23803:6;:19:::0;;-1:-1:-1;;;;;;23803:19:0::1;::::0;;23682:148::o;23040:79::-;23105:6;;-1:-1:-1;;;;;23105:6:0;23040:79;:::o;31810:813::-;25969:28;:26;:28::i;:::-;25968:29;25946:117;;;;-1:-1:-1;;;25946:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26097:28;:26;:28::i;:::-;26096:29;26074:117;;;;-1:-1:-1;;;26074:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;24824:9:::1;::::0;-1:-1:-1;;;;;24824:9:0::1;24837:10;24824:23;24802:109;;;;-1:-1:-1::0;;;24802:109:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31950:1:::2;31941:6;:10;31933:51;;;::::0;;-1:-1:-1;;;31933:51:0;;::::2;;::::0;::::2;::::0;::::2;::::0;;;;::::2;::::0;;;;;;;;;;;;;::::2;;32033:1;32017:13;:11;:13::i;:::-;:17;31995:115;;;;-1:-1:-1::0;;;31995:115:0::2;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32161:15;32179:19;:17;:19::i;:::-;:34;;;32161:52;;32224:15;32242:38;32254:25;32265:13;:11;:13::i;:::-;32254:6:::0;;:10:::2;:25::i;:::-;32242:7:::0;;:11:::2;:38::i;:::-;32224:56;;32293:32;;:::i;:::-;-1:-1:-1::0;32328:130:0::2;::::0;;::::2;::::0;::::2;::::0;;32368:3:::2;32328:130:::0;;::::2;::::0;::::2;::::0;;;;;;;;;32469:12:::2;:30:::0;;::::2;::::0;::::2;::::0;;-1:-1:-1;32469:30:0;;;;;;;::::2;::::0;;::::2;::::0;;::::2;::::0;;;;;;;;;;;;;;;;32512:4:::2;::::0;:56:::2;::::0;-1:-1:-1;;;;;32512:4:0::2;32534:10;32554:4;32328:130:::0;32512:21:::2;:56::i;:::-;32584:31;::::0;;;;;;;32596:10:::2;::::0;32584:31:::2;::::0;;;;;::::2;::::0;;::::2;-1:-1:-1::0;;26226:12:0;26218:21;;;;:7;:21;;;;;;;;26240:9;26218:32;;;;;;;;:39;;26253:4;-1:-1:-1;;26218:39:0;;;;;;;;26290:10;26268:33;;;;;;:40;;;;;;;;;;-1:-1:-1;;31810:813:0:o;30795:265::-;25969:28;:26;:28::i;:::-;25968:29;25946:117;;;;-1:-1:-1;;;25946:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26097:28;:26;:28::i;:::-;26096:29;26074:117;;;;-1:-1:-1;;;26074:117:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30904:10:::1;29146:20;29169:21;:19;:21::i;:::-;29146:44:::0;-1:-1:-1;;;;;;29205:22:0;::::1;::::0;29201:242:::1;;29244:21;;:::i;:::-;-1:-1:-1::0;;;;;;29268:19:0;::::1;;::::0;;;:9:::1;:19;::::0;;;;;;;;29244:43;;;;::::1;::::0;;;;;;;::::1;;::::0;;;::::1;::::0;29322:16:::1;29278:8:::0;29322:6:::1;:16::i;:::-;29302:17;::::0;;::::1;:36:::0;;;29353:37;;;-1:-1:-1;;;;;29405:19:0;::::1;29353:22;29405:19:::0;;;:9:::1;:19:::0;;;;;;:26;;;;;::::1;::::0;;::::1;::::0;29201:242:::1;30949:1:::2;30940:6;:10;30932:48;;;::::0;;-1:-1:-1;;;30932:48:0;;::::2;;::::0;::::2;::::0;::::2;::::0;;;;::::2;::::0;;;;;;;;;;;;;::::2;;30991:19;31003:6;30991:11;:19::i;:::-;31026:26;::::0;;;;;;;31033:10:::2;::::0;31026:26:::2;::::0;;;;;::::2;::::0;;::::2;-1:-1:-1::0;;26226:12:0;26218:21;;;;:7;:21;;;;;;;;26240:9;26218:32;;;;;;;;:39;;26253:4;-1:-1:-1;;26218:39:0;;;;;;;;26290:10;26268:33;;;;;;:40;;;;;;;;;;-1:-1:-1;30795:265:0:o;26933:19::-;;;-1:-1:-1;;;;;26933:19:0;;:::o;31484:318::-;31527:10;29146:20;29169:21;:19;:21::i;:::-;29146:44;-1:-1:-1;;;;;;29205:22:0;;;29201:242;;29244:21;;:::i;:::-;-1:-1:-1;;;;;;29268:19:0;;;;;;:9;:19;;;;;;;;;29244:43;;;;;;;;;;;;;;;;;;;29322:16;29278:8;29322:6;:16::i;:::-;29302:17;;;;:36;;;29353:37;;;-1:-1:-1;;;;;29405:19:0;;29353:22;29405:19;;;:9;:19;;;;;;:26;;;;;;;;;;29201:242;31577:10:::1;31550:14;31567:21:::0;;;:9:::1;:21;::::0;;;;:34:::1;;::::0;31616:10;;31612:183:::1;;31653:10;31680:1;31643:21:::0;;;:9:::1;:21;::::0;;;;:34:::1;;:38:::0;31696:4:::1;::::0;:37:::1;::::0;-1:-1:-1;;;;;31696:4:0;;::::1;::::0;31726:6;31696:17:::1;:37::i;:::-;31753:30;::::0;;;;;;;31764:10:::1;::::0;31753:30:::1;::::0;;;;;::::1;::::0;;::::1;31612:183;29453:1;31484:318:::0;;:::o;31377:99::-;31413:31;31422:21;31432:10;31422:9;:21::i;:::-;31413:8;:31::i;:::-;31455:13;:11;:13::i;:::-;31377:99::o;23985:281::-;23262:12;:10;:12::i;:::-;23252:6;;-1:-1:-1;;;;;23252:6:0;;;:22;;;23244:67;;;;;-1:-1:-1;;;23244:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;24088:22:0;::::1;24066:110;;;;-1:-1:-1::0;;;24066:110:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;24213:6;::::0;24192:38:::1;::::0;-1:-1:-1;;;;;24192:38:0;;::::1;::::0;24213:6:::1;::::0;24192:38:::1;::::0;24213:6:::1;::::0;24192:38:::1;24241:6;:17:::0;;-1:-1:-1;;;;;;24241:17:0::1;-1:-1:-1::0;;;;;24241:17:0;;;::::1;::::0;;;::::1;::::0;;23985:281::o;29680:135::-;29732:20;;:::i;:::-;29772:12;29785:21;:19;:21::i;:::-;29772:35;;;;;;;;;;;;;;;;;;29765:42;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29680:135;:::o;30006:194::-;30101:20;;:::i;:::-;30146:12;30159:32;30182:8;30159:22;:32::i;:::-;30146:46;;;;;;;;;;;;;;;;;;30139:53;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30006:194;;;:::o;4297:136::-;4355:7;4382:43;4386:1;4389;4382:43;;;;;;;;;;;;;;;;;:3;:43::i;:::-;4375:50;;4297:136;;;;;:::o;5221:471::-;5279:7;5524:6;5520:47;;-1:-1:-1;5554:1:0;5547:8;;5520:47;5591:5;;;5595:1;5591;:5;:1;5615:5;;;;;:10;5607:56;;;;-1:-1:-1;;;5607:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3833:181;3891:7;3923:5;;;3947:6;;;;3939:46;;;;;-1:-1:-1;;;3939:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;21572:106;21660:10;21572:106;:::o;25170:294::-;-1:-1:-1;;;;;25261:26:0;;25239:121;;;;-1:-1:-1;;;25239:121:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25376:45;;-1:-1:-1;;;;;25376:45:0;;;25404:1;;25376:45;;25404:1;;25376:45;25432:9;:24;;-1:-1:-1;;;;;;25432:24:0;-1:-1:-1;;;;;25432:24:0;;;;;;;;;;25170:294::o;25644:125::-;25737:12;25705:4;25729:21;;;:7;:21;;;;;;;;25751:9;25729:32;;;;;;;;;;25644:125;:::o;25777:126::-;25870:12;25838:4;25862:21;;;:7;:21;;;;;;;;25884:10;25862:33;;;;;;;;;;25777:126;:::o;27515:410::-;27609:10;27575:21;27599;;;:9;:21;;;;;;27653:23;;;;27631:127;;;;-1:-1:-1;;;27631:127:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27784:12;;:24;;27801:6;27784:16;:24::i;:::-;27769:12;:39;27843:25;:13;27861:6;27843:17;:25::i;:::-;27829:10;27819:21;;;;:9;:21;;;;;:49;;;;27879:5;;:38;;-1:-1:-1;;;;;27879:5:0;;;;27910:6;27879:18;:38::i;:::-;27515:410;;:::o;6168:132::-;6226:7;6253:39;6257:1;6260;6253:39;;;;;;;;;;;;;;;;;:3;:39::i;15770:285::-;15968:68;;;-1:-1:-1;;;;;15968:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;15968:68:0;-1:-1:-1;;;15968:68:0;;;15914:133;;15948:5;;15914:19;:133::i;:::-;15770:285;;;;:::o;27267:240::-;27339:12;;:24;;27356:6;27339:16;:24::i;:::-;27324:12;:39;27408:10;27398:21;;;;:9;:21;;;;;;:33;;27424:6;27398:25;:33::i;:::-;27384:10;27374:21;;;;:9;:21;;;;;:57;;;;27442:5;;:57;;-1:-1:-1;;;;;27442:5:0;;;;27485:4;27492:6;27442:22;:57::i;15514:248::-;15685:58;;;-1:-1:-1;;;;;15685:58:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;15685:58:0;-1:-1:-1;;;15685:58:0;;;15631:123;;15665:5;;15631:19;:123::i;4736:226::-;4856:7;4892:12;4884:6;;;;4876:29;;;;-1:-1:-1;;;4876:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;4928:5:0;;;4736:226::o;6796:312::-;6916:7;6951:12;6944:5;6936:28;;;;-1:-1:-1;;;6936:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6975:9;6991:1;6987;:5;;;;;;;6796:312;-1:-1:-1;;;;;6796:312:0:o;18390:860::-;18814:23;18840:106;18882:4;18840:106;;;;;;;;;;;;;;;;;18848:5;-1:-1:-1;;;;;18840:27:0;;;:106;;;;;:::i;:::-;18961:17;;18814:132;;-1:-1:-1;18961:21:0;18957:286;;19134:10;19123:30;;;;;;;;;;;;;;;-1:-1:-1;19123:30:0;19097:134;;;;-1:-1:-1;;;19097:134:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12194:230;12331:12;12363:53;12386:6;12394:4;12400:1;12403:12;13988;14021:18;14032:6;14021:10;:18::i;:::-;14013:60;;;;;-1:-1:-1;;;14013:60:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;14147:12;14161:23;14188:6;-1:-1:-1;;;;;14188:11:0;14207:8;14231:4;14188:58;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;14188:58:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14146:100;;;;14261:7;14257:595;;;14292:10;-1:-1:-1;14285:17:0;;-1:-1:-1;14285:17:0;14257:595;14406:17;;:21;14402:439;;14669:10;14663:17;14730:15;14717:10;14713:2;14709:19;14702:44;14617:148;14805:20;;-1:-1:-1;;;14805:20:0;;;;;;;;;;;;;;;;;14812:12;;14805:20;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9157:444;9537:20;9585:8;;;9157:444::o;-1:-1:-1:-;;;;;;;;;;;;;;;;;;;:::o;:::-;;;;;;;;;;;;;;;;;;;;;;;;:::o
Swarm Source
ipfs://495693a7069736a26e001d8800215368484b0347d9cf5a89c0f8e5e34e83860d
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 26 Chains
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.