Feature Tip: Add private address tag to any address under My Name Tag !
More Info
Private Name Tags
ContractCreator
Latest 25 from a total of 65 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Release | 19796755 | 297 days ago | IN | 0 ETH | 0.00032217 | ||||
Release | 18859101 | 428 days ago | IN | 0 ETH | 0.0007485 | ||||
Release | 16975900 | 693 days ago | IN | 0 ETH | 0.00140201 | ||||
Release | 16912901 | 701 days ago | IN | 0 ETH | 0.00136009 | ||||
Release | 16830051 | 713 days ago | IN | 0 ETH | 0.00101332 | ||||
Release | 16807223 | 716 days ago | IN | 0 ETH | 0.00267072 | ||||
Release | 16807222 | 716 days ago | IN | 0 ETH | 0.0027828 | ||||
Release | 16666501 | 736 days ago | IN | 0 ETH | 0.00093705 | ||||
Release | 16607690 | 744 days ago | IN | 0 ETH | 0.00071549 | ||||
Release | 16607685 | 744 days ago | IN | 0 ETH | 0.00076847 | ||||
Release | 16600172 | 745 days ago | IN | 0 ETH | 0.00112437 | ||||
Release | 16347347 | 781 days ago | IN | 0 ETH | 0.00073058 | ||||
Release | 16342689 | 781 days ago | IN | 0 ETH | 0.00121453 | ||||
Release | 16342687 | 781 days ago | IN | 0 ETH | 0.00114448 | ||||
Release | 16325792 | 784 days ago | IN | 0 ETH | 0.0007118 | ||||
Release | 16243689 | 795 days ago | IN | 0 ETH | 0.0006095 | ||||
Release | 16174712 | 805 days ago | IN | 0 ETH | 0.00104027 | ||||
Release | 16098475 | 815 days ago | IN | 0 ETH | 0.00061695 | ||||
Release | 16098466 | 815 days ago | IN | 0 ETH | 0.00061136 | ||||
Release | 16083661 | 817 days ago | IN | 0 ETH | 0.00065227 | ||||
Release | 16028012 | 825 days ago | IN | 0 ETH | 0.00092509 | ||||
Release | 16019776 | 826 days ago | IN | 0 ETH | 0.00127875 | ||||
Release | 15968740 | 834 days ago | IN | 0 ETH | 0.00142235 | ||||
Release | 15928530 | 839 days ago | IN | 0 ETH | 0.00116848 | ||||
Release | 15921342 | 840 days ago | IN | 0 ETH | 0.00070765 |
Latest 25 internal transactions (View All)
Advanced mode:
Parent Transaction Hash | Block |
From
|
To
|
|||
---|---|---|---|---|---|---|
21712901 | 29 days ago | 0.00027 ETH | ||||
21514568 | 57 days ago | 0.0003 ETH | ||||
21298251 | 87 days ago | 0.00002493 ETH | ||||
21198994 | 101 days ago | 0.00252 ETH | ||||
21160983 | 106 days ago | 0.00075175 ETH | ||||
21103387 | 114 days ago | 0.000039 ETH | ||||
21051919 | 121 days ago | 0.0003 ETH | ||||
21051919 | 121 days ago | 0.0003 ETH | ||||
21051844 | 121 days ago | 0.0003 ETH | ||||
20917410 | 140 days ago | 0.00004 ETH | ||||
20917395 | 140 days ago | 0.0003 ETH | ||||
20838599 | 151 days ago | 0.00004 ETH | ||||
20838434 | 151 days ago | 0.0003225 ETH | ||||
20654626 | 177 days ago | 0.0002475 ETH | ||||
20654624 | 177 days ago | 0.000255 ETH | ||||
20519045 | 196 days ago | 0.0004965 ETH | ||||
20512642 | 197 days ago | 0.0002475 ETH | ||||
20307514 | 225 days ago | 0.000031 ETH | ||||
19796755 | 297 days ago | 0.00004677 ETH | ||||
19446133 | 346 days ago | 0.0000245 ETH | ||||
19317078 | 364 days ago | 0.000015 ETH | ||||
19266598 | 371 days ago | 0.00045 ETH | ||||
19240194 | 375 days ago | 0.00014 ETH | ||||
19153211 | 387 days ago | 0.000015 ETH | ||||
19117828 | 392 days ago | 0.001323 ETH |
Loading...
Loading
Contract Source Code Verified (Exact Match)
Contract Name:
LumensSplitter
Compiler Version
v0.8.4+commit.c7e474f2
Optimization Enabled:
No with 200 runs
Other Settings:
default evmVersion
Contract Source Code (Solidity Standard Json-Input format)
//SPDX-License-Identifier: MIT pragma solidity ^0.8.4; import "@openzeppelin/contracts/finance/PaymentSplitter.sol"; contract LumensSplitter is PaymentSplitter { //The below addresses are for example purposes only. Please modify them. address[] private payees = [ 0xDbD10Ff27EA8c4d8ea6795397996361862091410, 0x38198ee928400Cd81ED4B72Aa0c550eF1c9ebE28, 0x78F2268fEe6dd5ab3e30Ef1F040C62777b5DF42e, 0x8c540BFb73D39CcCb59A2d48907091C19F191F55, 0x2f508BE8Ac24d694b796411B35330aaB7c40E913, 0xa16231D4DA9d49968D2191328102F6731Ef78FCA, 0x30d6B3497e967B72013e921aAf5d5ee9915B1010, 0x2B11D45ea9f7d133B7b3deDd5fd884cF6385CA7B ]; //The below percentages are for example purposes only. Please modify them. uint256[] private payeesShares = [100, 100, 100, 100, 10, 10, 15, 565]; constructor() PaymentSplitter(payees, payeesShares) {} function pendingPayment(address account) public view returns (uint256) { return ((address(this).balance + totalReleased()) * shares(account)) / totalShares() - released(account); } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; import "../utils/Address.sol"; import "../utils/Context.sol"; import "../utils/math/SafeMath.sol"; /** * @title PaymentSplitter * @dev This contract allows to split Ether payments among a group of accounts. The sender does not need to be aware * that the Ether will be split in this way, since it is handled transparently by the contract. * * The split can be in equal parts or in any other arbitrary proportion. The way this is specified is by assigning each * account to a number of shares. Of all the Ether that this contract receives, each account will then be able to claim * an amount proportional to the percentage of total shares they were assigned. * * `PaymentSplitter` follows a _pull payment_ model. This means that payments are not automatically forwarded to the * accounts but kept in this contract, and the actual transfer is triggered as a separate step by calling the {release} * function. */ contract PaymentSplitter is Context { event PayeeAdded(address account, uint256 shares); event PaymentReleased(address to, uint256 amount); event PaymentReceived(address from, uint256 amount); uint256 private _totalShares; uint256 private _totalReleased; mapping(address => uint256) private _shares; mapping(address => uint256) private _released; address[] private _payees; /** * @dev Creates an instance of `PaymentSplitter` where each account in `payees` is assigned the number of shares at * the matching position in the `shares` array. * * All addresses in `payees` must be non-zero. Both arrays must have the same non-zero length, and there must be no * duplicates in `payees`. */ constructor(address[] memory payees, uint256[] memory shares_) payable { require(payees.length == shares_.length, "PaymentSplitter: payees and shares length mismatch"); require(payees.length > 0, "PaymentSplitter: no payees"); for (uint256 i = 0; i < payees.length; i++) { _addPayee(payees[i], shares_[i]); } } /** * @dev The Ether received will be logged with {PaymentReceived} events. Note that these events are not fully * reliable: it's possible for a contract to receive Ether without triggering this function. This only affects the * reliability of the events, and not the actual splitting of Ether. * * To learn more about this see the Solidity documentation for * https://solidity.readthedocs.io/en/latest/contracts.html#fallback-function[fallback * functions]. */ receive() external payable virtual { emit PaymentReceived(_msgSender(), msg.value); } /** * @dev Getter for the total shares held by payees. */ function totalShares() public view returns (uint256) { return _totalShares; } /** * @dev Getter for the total amount of Ether already released. */ function totalReleased() public view returns (uint256) { return _totalReleased; } /** * @dev Getter for the amount of shares held by an account. */ function shares(address account) public view returns (uint256) { return _shares[account]; } /** * @dev Getter for the amount of Ether already released to a payee. */ function released(address account) public view returns (uint256) { return _released[account]; } /** * @dev Getter for the address of the payee number `index`. */ function payee(uint256 index) public view returns (address) { return _payees[index]; } /** * @dev Triggers a transfer to `account` of the amount of Ether they are owed, according to their percentage of the * total shares and their previous withdrawals. */ function release(address payable account) public virtual { require(_shares[account] > 0, "PaymentSplitter: account has no shares"); uint256 totalReceived = address(this).balance + _totalReleased; uint256 payment = (totalReceived * _shares[account]) / _totalShares - _released[account]; require(payment != 0, "PaymentSplitter: account is not due payment"); _released[account] = _released[account] + payment; _totalReleased = _totalReleased + payment; Address.sendValue(account, payment); emit PaymentReleased(account, payment); } /** * @dev Add a new payee to the contract. * @param account The address of the payee to add. * @param shares_ The number of shares owned by the payee. */ function _addPayee(address account, uint256 shares_) private { require(account != address(0), "PaymentSplitter: account is the zero address"); require(shares_ > 0, "PaymentSplitter: shares are 0"); require(_shares[account] == 0, "PaymentSplitter: account already has shares"); _payees.push(account); _shares[account] = shares_; _totalShares = _totalShares + shares_; emit PayeeAdded(account, shares_); } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; /** * @dev Collection of functions related to the address type */ library Address { /** * @dev Returns true if `account` is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, `isContract` will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * ==== */ function isContract(address account) internal view returns (bool) { // This method relies on extcodesize, which returns 0 for contracts in // construction, since the code is only stored at the end of the // constructor execution. uint256 size; assembly { size := extcodesize(account) } return size > 0; } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Address: insufficient balance"); (bool success, ) = recipient.call{value: amount}(""); require(success, "Address: unable to send value, recipient may have reverted"); } /** * @dev Performs a Solidity function call using a low level `call`. A * plain `call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCall(target, data, "Address: low-level call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with * `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCall( address target, bytes memory data, string memory errorMessage ) internal returns (bytes memory) { return functionCallWithValue(target, data, 0, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but also transferring `value` wei to `target`. * * Requirements: * * - the calling contract must have an ETH balance of at least `value`. * - the called Solidity function must be `payable`. * * _Available since v3.1._ */ function functionCallWithValue( address target, bytes memory data, uint256 value ) internal returns (bytes memory) { return functionCallWithValue(target, data, value, "Address: low-level call with value failed"); } /** * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but * with `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCallWithValue( address target, bytes memory data, uint256 value, string memory errorMessage ) internal returns (bytes memory) { require(address(this).balance >= value, "Address: insufficient balance for call"); require(isContract(target), "Address: call to non-contract"); (bool success, bytes memory returndata) = target.call{value: value}(data); return verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) { return functionStaticCall(target, data, "Address: low-level static call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall( address target, bytes memory data, string memory errorMessage ) internal view returns (bytes memory) { require(isContract(target), "Address: static call to non-contract"); (bool success, bytes memory returndata) = target.staticcall(data); return verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) { return functionDelegateCall(target, data, "Address: low-level delegate call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall( address target, bytes memory data, string memory errorMessage ) internal returns (bytes memory) { require(isContract(target), "Address: delegate call to non-contract"); (bool success, bytes memory returndata) = target.delegatecall(data); return verifyCallResult(success, returndata, errorMessage); } /** * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the * revert reason using the provided one. * * _Available since v4.3._ */ function verifyCallResult( bool success, bytes memory returndata, string memory errorMessage ) internal pure returns (bytes memory) { if (success) { return returndata; } else { // Look for revert reason and bubble it up if present if (returndata.length > 0) { // The easiest way to bubble the revert reason is using memory via assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; // CAUTION // This version of SafeMath should only be used with Solidity 0.8 or later, // because it relies on the compiler's built in overflow checks. /** * @dev Wrappers over Solidity's arithmetic operations. * * NOTE: `SafeMath` is no longer needed starting with Solidity 0.8. The compiler * now has built in overflow checking. */ 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) { unchecked { 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) { unchecked { 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) { unchecked { // 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) { unchecked { 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) { unchecked { 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) { return a + b; } /** * @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 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) { return a * b; } /** * @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. * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { 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) { 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) { unchecked { 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. * * 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) { unchecked { 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) { unchecked { require(b > 0, errorMessage); return a % b; } } }
{ "optimizer": { "enabled": false, "runs": 200 }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "metadata": { "useLiteralContent": true }, "libraries": {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"shares","type":"uint256"}],"name":"PayeeAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"PaymentReceived","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"PaymentReleased","type":"event"},{"inputs":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"payee","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"pendingPayment","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address payable","name":"account","type":"address"}],"name":"release","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"released","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"shares","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalReleased","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalShares","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
608060405260405180610100016040528073dbd10ff27ea8c4d8ea679539799636186209141073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020017338198ee928400cd81ed4b72aa0c550ef1c9ebe2873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020017378f2268fee6dd5ab3e30ef1f040c62777b5df42e73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001738c540bfb73d39cccb59a2d48907091c19f191f5573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001732f508be8ac24d694b796411b35330aab7c40e91373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200173a16231d4da9d49968d2191328102f6731ef78fca73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020017330d6b3497e967b72013e921aaf5d5ee9915b101073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001732b11d45ea9f7d133b7b3dedd5fd884cf6385ca7b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681525060059060086200025092919062000739565b50604051806101000160405280606461ffff168152602001606461ffff168152602001606461ffff168152602001606461ffff168152602001600a61ffff168152602001600a61ffff168152602001600f61ffff16815260200161023561ffff168152506006906008620002c6929190620007c8565b50348015620002d457600080fd5b5060058054806020026020016040519081016040528092919081815260200182805480156200035957602002820191906000526020600020905b8160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190600101908083116200030e575b50505050506006805480602002602001604051908101604052809291908181526020018280548015620003ac57602002820191906000526020600020905b81548152602001906001019080831162000397575b50505050508051825114620003f8576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401620003ef9062000973565b60405180910390fd5b60008251116200043f576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016200043690620009b7565b60405180910390fd5b60005b8251811015620004f657620004e08382815181106200048a577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b6020026020010151838381518110620004cc577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b6020026020010151620004ff60201b60201c565b8080620004ed9062000aa7565b91505062000442565b50505062000c63565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16141562000572576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401620005699062000951565b60405180910390fd5b60008111620005b8576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401620005af90620009d9565b60405180910390fd5b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054146200063d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401620006349062000995565b60405180910390fd5b6004829080600181540180825580915050600190039060005260206000200160009091909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555080600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555080600054620006f4919062000a0c565b6000819055507f40c340f65e17194d14ddddb073d3c9f888e3cb52b5aae0c6c7706b4fbc905fac82826040516200072d92919062000924565b60405180910390a15050565b828054828255906000526020600020908101928215620007b5579160200282015b82811115620007b45782518260006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550916020019190600101906200075a565b5b509050620007c4919062000820565b5090565b8280548282559060005260206000209081019282156200080d579160200282015b828111156200080c578251829061ffff16905591602001919060010190620007e9565b5b5090506200081c919062000820565b5090565b5b808211156200083b57600081600090555060010162000821565b5090565b6200084a8162000a69565b82525050565b60006200085f602c83620009fb565b91506200086c8262000b24565b604082019050919050565b600062000886603283620009fb565b9150620008938262000b73565b604082019050919050565b6000620008ad602b83620009fb565b9150620008ba8262000bc2565b604082019050919050565b6000620008d4601a83620009fb565b9150620008e18262000c11565b602082019050919050565b6000620008fb601d83620009fb565b9150620009088262000c3a565b602082019050919050565b6200091e8162000a9d565b82525050565b60006040820190506200093b60008301856200083f565b6200094a602083018462000913565b9392505050565b600060208201905081810360008301526200096c8162000850565b9050919050565b600060208201905081810360008301526200098e8162000877565b9050919050565b60006020820190508181036000830152620009b0816200089e565b9050919050565b60006020820190508181036000830152620009d281620008c5565b9050919050565b60006020820190508181036000830152620009f481620008ec565b9050919050565b600082825260208201905092915050565b600062000a198262000a9d565b915062000a268362000a9d565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0382111562000a5e5762000a5d62000af5565b5b828201905092915050565b600062000a768262000a7d565b9050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b600062000ab48262000a9d565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82141562000aea5762000ae962000af5565b5b600182019050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f5061796d656e7453706c69747465723a206163636f756e74206973207468652060008201527f7a65726f20616464726573730000000000000000000000000000000000000000602082015250565b7f5061796d656e7453706c69747465723a2070617965657320616e64207368617260008201527f6573206c656e677468206d69736d617463680000000000000000000000000000602082015250565b7f5061796d656e7453706c69747465723a206163636f756e7420616c726561647960008201527f2068617320736861726573000000000000000000000000000000000000000000602082015250565b7f5061796d656e7453706c69747465723a206e6f20706179656573000000000000600082015250565b7f5061796d656e7453706c69747465723a20736861726573206172652030000000600082015250565b610d588062000c736000396000f3fe6080604052600436106100745760003560e01c80639852595c1161004e5780639852595c14610151578063aeae177c1461018e578063ce7c2ac2146101cb578063e33b7de314610208576100bb565b806319165587146100c05780633a98ef39146100e95780638b83209b14610114576100bb565b366100bb577f6ef95f06320e7a25a04a175ca677b7052bdd97131872c2192525a629f51be7706100a2610233565b346040516100b19291906108ed565b60405180910390a1005b600080fd5b3480156100cc57600080fd5b506100e760048036038101906100e29190610766565b61023b565b005b3480156100f557600080fd5b506100fe6104a3565b60405161010b9190610996565b60405180910390f35b34801561012057600080fd5b5061013b6004803603810190610136919061078f565b6104ac565b60405161014891906108a9565b60405180910390f35b34801561015d57600080fd5b506101786004803603810190610173919061073d565b61051a565b6040516101859190610996565b60405180910390f35b34801561019a57600080fd5b506101b560048036038101906101b0919061073d565b610563565b6040516101c29190610996565b60405180910390f35b3480156101d757600080fd5b506101f260048036038101906101ed919061073d565b6105b7565b6040516101ff9190610996565b60405180910390f35b34801561021457600080fd5b5061021d610600565b60405161022a9190610996565b60405180910390f35b600033905090565b6000600260008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054116102bd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016102b490610916565b60405180910390fd5b6000600154476102cd91906109cd565b90506000600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054600054600260008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020548461035f9190610a54565b6103699190610a23565b6103739190610aae565b905060008114156103b9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016103b090610976565b60405180910390fd5b80600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461040491906109cd565b600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508060015461045591906109cd565b600181905550610465838261060a565b7fdf20fd1e76bc69d672e4814fafb2c449bba3a5369d8359adf9e05e6fde87b05683826040516104969291906108c4565b60405180910390a1505050565b60008054905090565b6000600482815481106104e8577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b9060005260206000200160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000600360008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b600061056e8261051a565b6105766104a3565b61057f846105b7565b610587610600565b4761059291906109cd565b61059c9190610a54565b6105a69190610a23565b6105b09190610aae565b9050919050565b6000600260008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6000600154905090565b8047101561064d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161064490610956565b60405180910390fd5b60008273ffffffffffffffffffffffffffffffffffffffff168260405161067390610894565b60006040518083038185875af1925050503d80600081146106b0576040519150601f19603f3d011682016040523d82523d6000602084013e6106b5565b606091505b50509050806106f9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106f090610936565b60405180910390fd5b505050565b60008135905061070d81610cdd565b92915050565b60008135905061072281610cf4565b92915050565b60008135905061073781610d0b565b92915050565b60006020828403121561074f57600080fd5b600061075d848285016106fe565b91505092915050565b60006020828403121561077857600080fd5b600061078684828501610713565b91505092915050565b6000602082840312156107a157600080fd5b60006107af84828501610728565b91505092915050565b6107c181610b30565b82525050565b6107d081610ae2565b82525050565b60006107e36026836109bc565b91506107ee82610bc4565b604082019050919050565b6000610806603a836109bc565b915061081182610c13565b604082019050919050565b6000610829601d836109bc565b915061083482610c62565b602082019050919050565b600061084c602b836109bc565b915061085782610c8b565b604082019050919050565b600061086f6000836109b1565b915061087a82610cda565b600082019050919050565b61088e81610b26565b82525050565b600061089f82610862565b9150819050919050565b60006020820190506108be60008301846107c7565b92915050565b60006040820190506108d960008301856107b8565b6108e66020830184610885565b9392505050565b600060408201905061090260008301856107c7565b61090f6020830184610885565b9392505050565b6000602082019050818103600083015261092f816107d6565b9050919050565b6000602082019050818103600083015261094f816107f9565b9050919050565b6000602082019050818103600083015261096f8161081c565b9050919050565b6000602082019050818103600083015261098f8161083f565b9050919050565b60006020820190506109ab6000830184610885565b92915050565b600081905092915050565b600082825260208201905092915050565b60006109d882610b26565b91506109e383610b26565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff03821115610a1857610a17610b66565b5b828201905092915050565b6000610a2e82610b26565b9150610a3983610b26565b925082610a4957610a48610b95565b5b828204905092915050565b6000610a5f82610b26565b9150610a6a83610b26565b9250817fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0483118215151615610aa357610aa2610b66565b5b828202905092915050565b6000610ab982610b26565b9150610ac483610b26565b925082821015610ad757610ad6610b66565b5b828203905092915050565b6000610aed82610b06565b9050919050565b6000610aff82610b06565b9050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b6000610b3b82610b42565b9050919050565b6000610b4d82610b54565b9050919050565b6000610b5f82610b06565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b7f5061796d656e7453706c69747465723a206163636f756e7420686173206e6f2060008201527f7368617265730000000000000000000000000000000000000000000000000000602082015250565b7f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260008201527f6563697069656e74206d61792068617665207265766572746564000000000000602082015250565b7f416464726573733a20696e73756666696369656e742062616c616e6365000000600082015250565b7f5061796d656e7453706c69747465723a206163636f756e74206973206e6f742060008201527f647565207061796d656e74000000000000000000000000000000000000000000602082015250565b50565b610ce681610ae2565b8114610cf157600080fd5b50565b610cfd81610af4565b8114610d0857600080fd5b50565b610d1481610b26565b8114610d1f57600080fd5b5056fea2646970667358221220d6e0298fc244d2632b965b265cd4c938c6697f19fbc998c8a29666bdb198a26064736f6c63430008040033
Deployed Bytecode
0x6080604052600436106100745760003560e01c80639852595c1161004e5780639852595c14610151578063aeae177c1461018e578063ce7c2ac2146101cb578063e33b7de314610208576100bb565b806319165587146100c05780633a98ef39146100e95780638b83209b14610114576100bb565b366100bb577f6ef95f06320e7a25a04a175ca677b7052bdd97131872c2192525a629f51be7706100a2610233565b346040516100b19291906108ed565b60405180910390a1005b600080fd5b3480156100cc57600080fd5b506100e760048036038101906100e29190610766565b61023b565b005b3480156100f557600080fd5b506100fe6104a3565b60405161010b9190610996565b60405180910390f35b34801561012057600080fd5b5061013b6004803603810190610136919061078f565b6104ac565b60405161014891906108a9565b60405180910390f35b34801561015d57600080fd5b506101786004803603810190610173919061073d565b61051a565b6040516101859190610996565b60405180910390f35b34801561019a57600080fd5b506101b560048036038101906101b0919061073d565b610563565b6040516101c29190610996565b60405180910390f35b3480156101d757600080fd5b506101f260048036038101906101ed919061073d565b6105b7565b6040516101ff9190610996565b60405180910390f35b34801561021457600080fd5b5061021d610600565b60405161022a9190610996565b60405180910390f35b600033905090565b6000600260008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054116102bd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016102b490610916565b60405180910390fd5b6000600154476102cd91906109cd565b90506000600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054600054600260008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020548461035f9190610a54565b6103699190610a23565b6103739190610aae565b905060008114156103b9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016103b090610976565b60405180910390fd5b80600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461040491906109cd565b600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508060015461045591906109cd565b600181905550610465838261060a565b7fdf20fd1e76bc69d672e4814fafb2c449bba3a5369d8359adf9e05e6fde87b05683826040516104969291906108c4565b60405180910390a1505050565b60008054905090565b6000600482815481106104e8577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b9060005260206000200160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000600360008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b600061056e8261051a565b6105766104a3565b61057f846105b7565b610587610600565b4761059291906109cd565b61059c9190610a54565b6105a69190610a23565b6105b09190610aae565b9050919050565b6000600260008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6000600154905090565b8047101561064d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161064490610956565b60405180910390fd5b60008273ffffffffffffffffffffffffffffffffffffffff168260405161067390610894565b60006040518083038185875af1925050503d80600081146106b0576040519150601f19603f3d011682016040523d82523d6000602084013e6106b5565b606091505b50509050806106f9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106f090610936565b60405180910390fd5b505050565b60008135905061070d81610cdd565b92915050565b60008135905061072281610cf4565b92915050565b60008135905061073781610d0b565b92915050565b60006020828403121561074f57600080fd5b600061075d848285016106fe565b91505092915050565b60006020828403121561077857600080fd5b600061078684828501610713565b91505092915050565b6000602082840312156107a157600080fd5b60006107af84828501610728565b91505092915050565b6107c181610b30565b82525050565b6107d081610ae2565b82525050565b60006107e36026836109bc565b91506107ee82610bc4565b604082019050919050565b6000610806603a836109bc565b915061081182610c13565b604082019050919050565b6000610829601d836109bc565b915061083482610c62565b602082019050919050565b600061084c602b836109bc565b915061085782610c8b565b604082019050919050565b600061086f6000836109b1565b915061087a82610cda565b600082019050919050565b61088e81610b26565b82525050565b600061089f82610862565b9150819050919050565b60006020820190506108be60008301846107c7565b92915050565b60006040820190506108d960008301856107b8565b6108e66020830184610885565b9392505050565b600060408201905061090260008301856107c7565b61090f6020830184610885565b9392505050565b6000602082019050818103600083015261092f816107d6565b9050919050565b6000602082019050818103600083015261094f816107f9565b9050919050565b6000602082019050818103600083015261096f8161081c565b9050919050565b6000602082019050818103600083015261098f8161083f565b9050919050565b60006020820190506109ab6000830184610885565b92915050565b600081905092915050565b600082825260208201905092915050565b60006109d882610b26565b91506109e383610b26565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff03821115610a1857610a17610b66565b5b828201905092915050565b6000610a2e82610b26565b9150610a3983610b26565b925082610a4957610a48610b95565b5b828204905092915050565b6000610a5f82610b26565b9150610a6a83610b26565b9250817fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0483118215151615610aa357610aa2610b66565b5b828202905092915050565b6000610ab982610b26565b9150610ac483610b26565b925082821015610ad757610ad6610b66565b5b828203905092915050565b6000610aed82610b06565b9050919050565b6000610aff82610b06565b9050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b6000610b3b82610b42565b9050919050565b6000610b4d82610b54565b9050919050565b6000610b5f82610b06565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b7f5061796d656e7453706c69747465723a206163636f756e7420686173206e6f2060008201527f7368617265730000000000000000000000000000000000000000000000000000602082015250565b7f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260008201527f6563697069656e74206d61792068617665207265766572746564000000000000602082015250565b7f416464726573733a20696e73756666696369656e742062616c616e6365000000600082015250565b7f5061796d656e7453706c69747465723a206163636f756e74206973206e6f742060008201527f647565207061796d656e74000000000000000000000000000000000000000000602082015250565b50565b610ce681610ae2565b8114610cf157600080fd5b50565b610cfd81610af4565b8114610d0857600080fd5b50565b610d1481610b26565b8114610d1f57600080fd5b5056fea2646970667358221220d6e0298fc244d2632b965b265cd4c938c6697f19fbc998c8a29666bdb198a26064736f6c63430008040033
Loading...
Loading
Loading...
Loading
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.