Source Code
Latest 25 from a total of 481 transactions
| Transaction Hash |
Method
|
Block
|
From
|
|
To
|
||||
|---|---|---|---|---|---|---|---|---|---|
| Deposit | 11308041 | 1918 days ago | IN | 0 ETH | 0.00468176 | ||||
| Deposit | 11264805 | 1924 days ago | IN | 0 ETH | 0.00163854 | ||||
| Deposit | 11261617 | 1925 days ago | IN | 0 ETH | 0.00271341 | ||||
| Withdraw | 11067682 | 1954 days ago | IN | 0 ETH | 0.00661673 | ||||
| Withdraw | 11029898 | 1960 days ago | IN | 0 ETH | 0.00342687 | ||||
| Deposit | 11029893 | 1960 days ago | IN | 0 ETH | 0.00316482 | ||||
| Deposit | 11018791 | 1962 days ago | IN | 0 ETH | 0.00571007 | ||||
| Withdraw | 11014808 | 1963 days ago | IN | 0 ETH | 0.00189793 | ||||
| Deposit | 11014808 | 1963 days ago | IN | 0 ETH | 0.00422048 | ||||
| Deposit | 11013426 | 1963 days ago | IN | 0 ETH | 0.00598475 | ||||
| Deposit | 11012084 | 1963 days ago | IN | 0 ETH | 0.00602165 | ||||
| Deposit | 11012055 | 1963 days ago | IN | 0 ETH | 0.00371048 | ||||
| Deposit | 11009196 | 1964 days ago | IN | 0 ETH | 0.00994917 | ||||
| Withdraw | 10992216 | 1966 days ago | IN | 0 ETH | 0.0062629 | ||||
| Deposit | 10981824 | 1968 days ago | IN | 0 ETH | 0.00521354 | ||||
| Withdraw | 10980574 | 1968 days ago | IN | 0 ETH | 0.00567206 | ||||
| Deposit | 10979735 | 1968 days ago | IN | 0 ETH | 0.00534746 | ||||
| Deposit | 10979714 | 1968 days ago | IN | 0 ETH | 0.00534746 | ||||
| Deposit | 10977955 | 1968 days ago | IN | 0 ETH | 0.01228906 | ||||
| Deposit | 10974381 | 1969 days ago | IN | 0 ETH | 0.00469267 | ||||
| Deposit | 10971014 | 1969 days ago | IN | 0 ETH | 0.01036754 | ||||
| Deposit | 10969663 | 1970 days ago | IN | 0 ETH | 0.00581445 | ||||
| Deposit | 10969619 | 1970 days ago | IN | 0 ETH | 0.00912322 | ||||
| Deposit | 10969596 | 1970 days ago | IN | 0 ETH | 0.00682726 | ||||
| Withdraw | 10969491 | 1970 days ago | IN | 0 ETH | 0.0059078 |
View more zero value Internal Transactions in Advanced View mode
Advanced mode:
Loading...
Loading
Loading...
Loading
Cross-Chain Transactions
Loading...
Loading
Contract Name:
Unifier
Compiler Version
v0.6.12+commit.27d51765
Contract Source Code (Solidity)
/**
*Submitted for verification at Etherscan.io on 2020-09-26
*/
// SPDX-License-Identifier: MIT
// 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) {
// According to EIP-1052, 0x0 is the value returned for not-yet created accounts
// and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
// for accounts without code, i.e. `keccak256('')`
bytes32 codehash;
bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
// solhint-disable-next-line no-inline-assembly
assembly { codehash := extcodehash(account) }
return (codehash != accountHash && codehash != 0x0);
}
/**
* @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: @openzeppelin/contracts/utils/EnumerableSet.sol
pragma solidity ^0.6.0;
/**
* @dev Library for managing
* https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive
* types.
*
* Sets have the following properties:
*
* - Elements are added, removed, and checked for existence in constant time
* (O(1)).
* - Elements are enumerated in O(n). No guarantees are made on the ordering.
*
* ```
* contract Example {
* // Add the library methods
* using EnumerableSet for EnumerableSet.AddressSet;
*
* // Declare a set state variable
* EnumerableSet.AddressSet private mySet;
* }
* ```
*
* As of v3.0.0, only sets of type `address` (`AddressSet`) and `uint256`
* (`UintSet`) are supported.
*/
library EnumerableSet {
// To implement this library for multiple types with as little code
// repetition as possible, we write it in terms of a generic Set type with
// bytes32 values.
// The Set implementation uses private functions, and user-facing
// implementations (such as AddressSet) are just wrappers around the
// underlying Set.
// This means that we can only create new EnumerableSets for types that fit
// in bytes32.
struct Set {
// Storage of set values
bytes32[] _values;
// Position of the value in the `values` array, plus 1 because index 0
// means a value is not in the set.
mapping (bytes32 => uint256) _indexes;
}
/**
* @dev Add a value to a set. O(1).
*
* Returns true if the value was added to the set, that is if it was not
* already present.
*/
function _add(Set storage set, bytes32 value) private returns (bool) {
if (!_contains(set, value)) {
set._values.push(value);
// The value is stored at length-1, but we add 1 to all indexes
// and use 0 as a sentinel value
set._indexes[value] = set._values.length;
return true;
} else {
return false;
}
}
/**
* @dev Removes a value from a set. O(1).
*
* Returns true if the value was removed from the set, that is if it was
* present.
*/
function _remove(Set storage set, bytes32 value) private returns (bool) {
// We read and store the value's index to prevent multiple reads from the same storage slot
uint256 valueIndex = set._indexes[value];
if (valueIndex != 0) { // Equivalent to contains(set, value)
// To delete an element from the _values array in O(1), we swap the element to delete with the last one in
// the array, and then remove the last element (sometimes called as 'swap and pop').
// This modifies the order of the array, as noted in {at}.
uint256 toDeleteIndex = valueIndex - 1;
uint256 lastIndex = set._values.length - 1;
// When the value to delete is the last one, the swap operation is unnecessary. However, since this occurs
// so rarely, we still do the swap anyway to avoid the gas cost of adding an 'if' statement.
bytes32 lastvalue = set._values[lastIndex];
// Move the last value to the index where the value to delete is
set._values[toDeleteIndex] = lastvalue;
// Update the index for the moved value
set._indexes[lastvalue] = toDeleteIndex + 1; // All indexes are 1-based
// Delete the slot where the moved value was stored
set._values.pop();
// Delete the index for the deleted slot
delete set._indexes[value];
return true;
} else {
return false;
}
}
/**
* @dev Returns true if the value is in the set. O(1).
*/
function _contains(Set storage set, bytes32 value) private view returns (bool) {
return set._indexes[value] != 0;
}
/**
* @dev Returns the number of values on the set. O(1).
*/
function _length(Set storage set) private view returns (uint256) {
return set._values.length;
}
/**
* @dev Returns the value stored at position `index` in the set. O(1).
*
* Note that there are no guarantees on the ordering of values inside the
* array, and it may change when more values are added or removed.
*
* Requirements:
*
* - `index` must be strictly less than {length}.
*/
function _at(Set storage set, uint256 index) private view returns (bytes32) {
require(set._values.length > index, "EnumerableSet: index out of bounds");
return set._values[index];
}
// AddressSet
struct AddressSet {
Set _inner;
}
/**
* @dev Add a value to a set. O(1).
*
* Returns true if the value was added to the set, that is if it was not
* already present.
*/
function add(AddressSet storage set, address value) internal returns (bool) {
return _add(set._inner, bytes32(uint256(value)));
}
/**
* @dev Removes a value from a set. O(1).
*
* Returns true if the value was removed from the set, that is if it was
* present.
*/
function remove(AddressSet storage set, address value) internal returns (bool) {
return _remove(set._inner, bytes32(uint256(value)));
}
/**
* @dev Returns true if the value is in the set. O(1).
*/
function contains(AddressSet storage set, address value) internal view returns (bool) {
return _contains(set._inner, bytes32(uint256(value)));
}
/**
* @dev Returns the number of values in the set. O(1).
*/
function length(AddressSet storage set) internal view returns (uint256) {
return _length(set._inner);
}
/**
* @dev Returns the value stored at position `index` in the set. O(1).
*
* Note that there are no guarantees on the ordering of values inside the
* array, and it may change when more values are added or removed.
*
* Requirements:
*
* - `index` must be strictly less than {length}.
*/
function at(AddressSet storage set, uint256 index) internal view returns (address) {
return address(uint256(_at(set._inner, index)));
}
// UintSet
struct UintSet {
Set _inner;
}
/**
* @dev Add a value to a set. O(1).
*
* Returns true if the value was added to the set, that is if it was not
* already present.
*/
function add(UintSet storage set, uint256 value) internal returns (bool) {
return _add(set._inner, bytes32(value));
}
/**
* @dev Removes a value from a set. O(1).
*
* Returns true if the value was removed from the set, that is if it was
* present.
*/
function remove(UintSet storage set, uint256 value) internal returns (bool) {
return _remove(set._inner, bytes32(value));
}
/**
* @dev Returns true if the value is in the set. O(1).
*/
function contains(UintSet storage set, uint256 value) internal view returns (bool) {
return _contains(set._inner, bytes32(value));
}
/**
* @dev Returns the number of values on the set. O(1).
*/
function length(UintSet storage set) internal view returns (uint256) {
return _length(set._inner);
}
/**
* @dev Returns the value stored at position `index` in the set. O(1).
*
* Note that there are no guarantees on the ordering of values inside the
* array, and it may change when more values are added or removed.
*
* Requirements:
*
* - `index` must be strictly less than {length}.
*/
function at(UintSet storage set, uint256 index) internal view returns (uint256) {
return uint256(_at(set._inner, index));
}
}
// 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 view virtual returns (address payable) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes memory) {
this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
return msg.data;
}
}
// File: @openzeppelin/contracts/access/Ownable.sol
pragma solidity ^0.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: @openzeppelin/contracts/token/ERC20/ERC20.sol
pragma solidity ^0.6.0;
/**
* @dev Implementation of the {IERC20} interface.
*
* This implementation is agnostic to the way tokens are created. This means
* that a supply mechanism has to be added in a derived contract using {_mint}.
* For a generic mechanism see {ERC20PresetMinterPauser}.
*
* TIP: For a detailed writeup see our guide
* https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How
* to implement supply mechanisms].
*
* We have followed general OpenZeppelin guidelines: functions revert instead
* of returning `false` on failure. This behavior is nonetheless conventional
* and does not conflict with the expectations of ERC20 applications.
*
* Additionally, an {Approval} event is emitted on calls to {transferFrom}.
* This allows applications to reconstruct the allowance for all accounts just
* by listening to said events. Other implementations of the EIP may not emit
* these events, as it isn't required by the specification.
*
* Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
* functions have been added to mitigate the well-known issues around setting
* allowances. See {IERC20-approve}.
*/
contract ERC20 is Context, IERC20 {
using SafeMath for uint256;
using Address for address;
mapping (address => uint256) private _balances;
mapping (address => mapping (address => uint256)) private _allowances;
uint256 private _totalSupply;
string private _name;
string private _symbol;
uint8 private _decimals;
/**
* @dev Sets the values for {name} and {symbol}, initializes {decimals} with
* a default value of 18.
*
* To select a different value for {decimals}, use {_setupDecimals}.
*
* All three of these values are immutable: they can only be set once during
* construction.
*/
constructor (string memory name, string memory symbol) public {
_name = name;
_symbol = symbol;
_decimals = 18;
}
/**
* @dev Returns the name of the token.
*/
function name() public view returns (string memory) {
return _name;
}
/**
* @dev Returns the symbol of the token, usually a shorter version of the
* name.
*/
function symbol() public view returns (string memory) {
return _symbol;
}
/**
* @dev Returns the number of decimals used to get its user representation.
* For example, if `decimals` equals `2`, a balance of `505` tokens should
* be displayed to a user as `5,05` (`505 / 10 ** 2`).
*
* Tokens usually opt for a value of 18, imitating the relationship between
* Ether and Wei. This is the value {ERC20} uses, unless {_setupDecimals} is
* called.
*
* NOTE: This information is only used for _display_ purposes: it in
* no way affects any of the arithmetic of the contract, including
* {IERC20-balanceOf} and {IERC20-transfer}.
*/
function decimals() public view returns (uint8) {
return _decimals;
}
/**
* @dev See {IERC20-totalSupply}.
*/
function totalSupply() public view override returns (uint256) {
return _totalSupply;
}
/**
* @dev See {IERC20-balanceOf}.
*/
function balanceOf(address account) public view override returns (uint256) {
return _balances[account];
}
/**
* @dev See {IERC20-transfer}.
*
* Requirements:
*
* - `recipient` cannot be the zero address.
* - the caller must have a balance of at least `amount`.
*/
function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
/**
* @dev See {IERC20-allowance}.
*/
function allowance(address owner, address spender) public view virtual override returns (uint256) {
return _allowances[owner][spender];
}
/**
* @dev See {IERC20-approve}.
*
* Requirements:
*
* - `spender` cannot be the zero address.
*/
function approve(address spender, uint256 amount) public virtual override returns (bool) {
_approve(_msgSender(), spender, amount);
return true;
}
/**
* @dev See {IERC20-transferFrom}.
*
* Emits an {Approval} event indicating the updated allowance. This is not
* required by the EIP. See the note at the beginning of {ERC20};
*
* Requirements:
* - `sender` and `recipient` cannot be the zero address.
* - `sender` must have a balance of at least `amount`.
* - the caller must have allowance for ``sender``'s tokens of at least
* `amount`.
*/
function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {
_transfer(sender, recipient, amount);
_approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
return true;
}
/**
* @dev Atomically increases the allowance granted to `spender` by the caller.
*
* This is an alternative to {approve} that can be used as a mitigation for
* problems described in {IERC20-approve}.
*
* Emits an {Approval} event indicating the updated allowance.
*
* Requirements:
*
* - `spender` cannot be the zero address.
*/
function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
return true;
}
/**
* @dev Atomically decreases the allowance granted to `spender` by the caller.
*
* This is an alternative to {approve} that can be used as a mitigation for
* problems described in {IERC20-approve}.
*
* Emits an {Approval} event indicating the updated allowance.
*
* Requirements:
*
* - `spender` cannot be the zero address.
* - `spender` must have allowance for the caller of at least
* `subtractedValue`.
*/
function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
return true;
}
/**
* @dev Moves tokens `amount` from `sender` to `recipient`.
*
* This is internal function is equivalent to {transfer}, and can be used to
* e.g. implement automatic token fees, slashing mechanisms, etc.
*
* Emits a {Transfer} event.
*
* Requirements:
*
* - `sender` cannot be the zero address.
* - `recipient` cannot be the zero address.
* - `sender` must have a balance of at least `amount`.
*/
function _transfer(address sender, address recipient, uint256 amount) internal virtual {
require(sender != address(0), "ERC20: transfer from the zero address");
require(recipient != address(0), "ERC20: transfer to the zero address");
_beforeTokenTransfer(sender, recipient, amount);
_balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
_balances[recipient] = _balances[recipient].add(amount);
emit Transfer(sender, recipient, amount);
}
/** @dev Creates `amount` tokens and assigns them to `account`, increasing
* the total supply.
*
* Emits a {Transfer} event with `from` set to the zero address.
*
* Requirements
*
* - `to` cannot be the zero address.
*/
function _mint(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: mint to the zero address");
_beforeTokenTransfer(address(0), account, amount);
_totalSupply = _totalSupply.add(amount);
_balances[account] = _balances[account].add(amount);
emit Transfer(address(0), account, amount);
}
/**
* @dev Destroys `amount` tokens from `account`, reducing the
* total supply.
*
* Emits a {Transfer} event with `to` set to the zero address.
*
* Requirements
*
* - `account` cannot be the zero address.
* - `account` must have at least `amount` tokens.
*/
function _burn(address account, uint256 amount) internal virtual {
require(account != address(0), "ERC20: burn from the zero address");
_beforeTokenTransfer(account, address(0), amount);
_balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
_totalSupply = _totalSupply.sub(amount);
emit Transfer(account, address(0), amount);
}
/**
* @dev Sets `amount` as the allowance of `spender` over the `owner`s tokens.
*
* This is internal function is equivalent to `approve`, and can be used to
* e.g. set automatic allowances for certain subsystems, etc.
*
* Emits an {Approval} event.
*
* Requirements:
*
* - `owner` cannot be the zero address.
* - `spender` cannot be the zero address.
*/
function _approve(address owner, address spender, uint256 amount) internal virtual {
require(owner != address(0), "ERC20: approve from the zero address");
require(spender != address(0), "ERC20: approve to the zero address");
_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
/**
* @dev Sets {decimals} to a value other than the default one of 18.
*
* WARNING: This function should only be called from the constructor. Most
* applications that interact with token contracts will not expect
* {decimals} to ever change, and may work incorrectly if it does.
*/
function _setupDecimals(uint8 decimals_) internal {
_decimals = decimals_;
}
/**
* @dev Hook that is called before any transfer of tokens. This includes
* minting and burning.
*
* Calling conditions:
*
* - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
* will be to transferred to `to`.
* - when `from` is zero, `amount` tokens will be minted for `to`.
* - when `to` is zero, `amount` of ``from``'s tokens will be burned.
* - `from` and `to` are never both zero.
*
* To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
*/
function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual { }
}
// File: contracts/UniSushiToken.sol
pragma solidity 0.6.12;
contract UniSushiToken is ERC20("UniSushi", "UniSushi"), Ownable {
function mint(address _to, uint256 _amount) public onlyOwner {
_mint(_to, _amount);
_moveDelegates(address(0), _delegates[_to], _amount);
}
// Copied and modified from YAM and COMPOUND and SUSHI:
mapping (address => address) internal _delegates;
struct Checkpoint {
uint32 fromBlock;
uint256 votes;
}
/// @notice A record of votes checkpoints for each account, by index
mapping (address => mapping (uint32 => Checkpoint)) public checkpoints;
/// @notice The number of checkpoints for each account
mapping (address => uint32) public numCheckpoints;
/// @notice The EIP-712 typehash for the contract's domain
bytes32 public constant DOMAIN_TYPEHASH = keccak256("EIP712Domain(string name,uint256 chainId,address verifyingContract)");
/// @notice The EIP-712 typehash for the delegation struct used by the contract
bytes32 public constant DELEGATION_TYPEHASH = keccak256("Delegation(address delegatee,uint256 nonce,uint256 expiry)");
/// @notice A record of states for signing / validating signatures
mapping (address => uint) public nonces;
/// @notice An event thats emitted when an account changes its delegate
event DelegateChanged(address indexed delegator, address indexed fromDelegate, address indexed toDelegate);
/// @notice An event thats emitted when a delegate account's vote balance changes
event DelegateVotesChanged(address indexed delegate, uint previousBalance, uint newBalance);
/**
* @notice Delegate votes from `msg.sender` to `delegatee`
* @param delegator The address to get delegatee for
*/
function delegates(address delegator)
external
view
returns (address)
{
return _delegates[delegator];
}
/**
* @notice Delegate votes from `msg.sender` to `delegatee`
* @param delegatee The address to delegate votes to
*/
function delegate(address delegatee) external {
return _delegate(msg.sender, delegatee);
}
/**
* @notice Delegates votes from signatory to `delegatee`
* @param delegatee The address to delegate votes to
* @param nonce The contract state required to match the signature
* @param expiry The time at which to expire the signature
* @param v The recovery byte of the signature
* @param r Half of the ECDSA signature pair
* @param s Half of the ECDSA signature pair
*/
function delegateBySig(
address delegatee,
uint nonce,
uint expiry,
uint8 v,
bytes32 r,
bytes32 s
)
external
{
bytes32 domainSeparator = keccak256(
abi.encode(
DOMAIN_TYPEHASH,
keccak256(bytes(name())),
getChainId(),
address(this)
)
);
bytes32 structHash = keccak256(
abi.encode(
DELEGATION_TYPEHASH,
delegatee,
nonce,
expiry
)
);
bytes32 digest = keccak256(
abi.encodePacked(
"\x19\x01",
domainSeparator,
structHash
)
);
address signatory = ecrecover(digest, v, r, s);
require(signatory != address(0), "UniSushiToken::delegateBySig: invalid signature");
require(nonce == nonces[signatory]++, "UniSushiToken::delegateBySig: invalid nonce");
require(now <= expiry, "UniSushiToken::delegateBySig: signature expired");
return _delegate(signatory, delegatee);
}
/**
* @notice Gets the current votes balance for `account`
* @param account The address to get votes balance
* @return The number of current votes for `account`
*/
function getCurrentVotes(address account)
external
view
returns (uint256)
{
uint32 nCheckpoints = numCheckpoints[account];
return nCheckpoints > 0 ? checkpoints[account][nCheckpoints - 1].votes : 0;
}
/**
* @notice Determine the prior number of votes for an account as of a block number
* @dev Block number must be a finalized block or else this function will revert to prevent misinformation.
* @param account The address of the account to check
* @param blockNumber The block number to get the vote balance at
* @return The number of votes the account had as of the given block
*/
function getPriorVotes(address account, uint blockNumber)
external
view
returns (uint256)
{
require(blockNumber < block.number, "UniSushiToken::getPriorVotes: not yet determined");
uint32 nCheckpoints = numCheckpoints[account];
if (nCheckpoints == 0) {
return 0;
}
if (checkpoints[account][nCheckpoints - 1].fromBlock <= blockNumber) {
return checkpoints[account][nCheckpoints - 1].votes;
}
if (checkpoints[account][0].fromBlock > blockNumber) {
return 0;
}
uint32 lower = 0;
uint32 upper = nCheckpoints - 1;
while (upper > lower) {
uint32 center = upper - (upper - lower) / 2; // ceil, avoiding overflow
Checkpoint memory cp = checkpoints[account][center];
if (cp.fromBlock == blockNumber) {
return cp.votes;
} else if (cp.fromBlock < blockNumber) {
lower = center;
} else {
upper = center - 1;
}
}
return checkpoints[account][lower].votes;
}
function _delegate(address delegator, address delegatee)
internal
{
address currentDelegate = _delegates[delegator];
uint256 delegatorBalance = balanceOf(delegator); // balance of underlying UniSushiToken (not scaled);
_delegates[delegator] = delegatee;
emit DelegateChanged(delegator, currentDelegate, delegatee);
_moveDelegates(currentDelegate, delegatee, delegatorBalance);
}
function _moveDelegates(address srcRep, address dstRep, uint256 amount) internal {
if (srcRep != dstRep && amount > 0) {
if (srcRep != address(0)) {
// decrease old representative
uint32 srcRepNum = numCheckpoints[srcRep];
uint256 srcRepOld = srcRepNum > 0 ? checkpoints[srcRep][srcRepNum - 1].votes : 0;
uint256 srcRepNew = srcRepOld.sub(amount);
_writeCheckpoint(srcRep, srcRepNum, srcRepOld, srcRepNew);
}
if (dstRep != address(0)) {
// increase new representative
uint32 dstRepNum = numCheckpoints[dstRep];
uint256 dstRepOld = dstRepNum > 0 ? checkpoints[dstRep][dstRepNum - 1].votes : 0;
uint256 dstRepNew = dstRepOld.add(amount);
_writeCheckpoint(dstRep, dstRepNum, dstRepOld, dstRepNew);
}
}
}
function _writeCheckpoint(
address delegatee,
uint32 nCheckpoints,
uint256 oldVotes,
uint256 newVotes
)
internal
{
uint32 blockNumber = safe32(block.number, "UniSushi::_writeCheckpoint: block number exceeds 32 bits");
if (nCheckpoints > 0 && checkpoints[delegatee][nCheckpoints - 1].fromBlock == blockNumber) {
checkpoints[delegatee][nCheckpoints - 1].votes = newVotes;
} else {
checkpoints[delegatee][nCheckpoints] = Checkpoint(blockNumber, newVotes);
numCheckpoints[delegatee] = nCheckpoints + 1;
}
emit DelegateVotesChanged(delegatee, oldVotes, newVotes);
}
function safe32(uint n, string memory errorMessage) internal pure returns (uint32) {
require(n < 2**32, errorMessage);
return uint32(n);
}
function getChainId() internal pure returns (uint) {
uint256 chainId;
assembly { chainId := chainid() }
return chainId;
}
}
// File: contracts/Unifier.sol
pragma solidity 0.6.12;
interface IMigratorChef {
function migrate(IERC20 token) external returns (IERC20);
}
// Unifier is the master of UniSushiToken. He can make UniSushiToken and he is a fair peaceful guy.
// Note that it's ownable and the owner wields tremendous power. The ownership will be transferred to a governance smart contract once UniSushiToken is sufficiently distributed and the community can show to govern itself.
contract Unifier is Ownable {
using SafeMath for uint256;
using SafeERC20 for IERC20;
// Info of each user.
struct UserInfo {
uint256 amount; // How many LP tokens the user has provided.
uint256 rewardDebt; // Reward debt. See explanation below.
}
struct PoolInfo {
IERC20 lpToken; // Address of LP token contract.
uint256 allocPoint; // How many allocation points assigned to this pool. UniSushi to distribute per block.
uint256 lastRewardBlock; // Last block number that UniSushi distribution occurs.
uint256 accUniSushiPerShare; // Accumulated UniSushi per share, times 1e12. See below.
}
// The UniSushi TOKEN!
UniSushiToken public unisushi;
// Dev address.
address public devaddr;
// Block number when bonus UniSushi period ends.
uint256 public bonusEndBlock;
// unisushi tokens created per block.
uint256 public unisushiPerBlock;
// Bonus muliplier for early UniSushi makers.
uint256 public BONUS_MULTIPLIER = 3;
// The migrator contract. It has a lot of power. Can only be set through governance (owner).
IMigratorChef public migrator;
// Info of each pool.
PoolInfo[] public poolInfo;
// Info of each user that stakes LP tokens.
mapping (uint256 => mapping (address => UserInfo)) public userInfo;
// Total allocation poitns. Must be the sum of all allocation points in all pools.
uint256 public totalAllocPoint = 0;
// The block number when UniSushi mining starts.
uint256 public startBlock;
event Deposit(address indexed user, uint256 indexed pid, uint256 amount);
event Withdraw(address indexed user, uint256 indexed pid, uint256 amount);
event EmergencyWithdraw(address indexed user, uint256 indexed pid, uint256 amount);
constructor(
UniSushiToken _unisushi,
address _devaddr,
uint256 _startBlock,
uint256 _bonusEndBlock
) public {
unisushi = _unisushi;
devaddr = _devaddr;
unisushiPerBlock = 10000000000000000000; // 10unisushi /Block
bonusEndBlock = _bonusEndBlock;
startBlock = _startBlock;
}
function changeReward(uint256 _unisushiPerBlock) public onlyOwner {
unisushiPerBlock = _unisushiPerBlock;
}
function changeStartBlock(uint256 _startBlock) public onlyOwner {
startBlock = _startBlock;
}
function changeBonusEndBlock(uint256 _bonusEndBlock) public onlyOwner {
bonusEndBlock = _bonusEndBlock;
}
function changeBonusMultiplier(uint256 _bonusMultiplier) public onlyOwner {
BONUS_MULTIPLIER = _bonusMultiplier;
}
function poolLength() external view returns (uint256) {
return poolInfo.length;
}
function add(uint256 _allocPoint, IERC20 _lpToken, bool _withUpdate) public onlyOwner {
if (_withUpdate) {
massUpdatePools();
}
uint256 lastRewardBlock = block.number > startBlock ? block.number : startBlock;
totalAllocPoint = totalAllocPoint.add(_allocPoint);
poolInfo.push(PoolInfo({
lpToken: _lpToken,
allocPoint: _allocPoint,
lastRewardBlock: lastRewardBlock,
accUniSushiPerShare: 0
}));
}
function set(uint256 _pid, uint256 _allocPoint, bool _withUpdate) public onlyOwner {
if (_withUpdate) {
massUpdatePools();
}
totalAllocPoint = totalAllocPoint.sub(poolInfo[_pid].allocPoint).add(_allocPoint);
poolInfo[_pid].allocPoint = _allocPoint;
}
// Set the migrator contract. Can only be called by the owner.
function setMigrator(IMigratorChef _migrator) public onlyOwner {
migrator = _migrator;
}
// Migrate lp token to another lp contract. Can be called by anyone. We trust that migrator contract is good.
function migrate(uint256 _pid) public {
require(address(migrator) != address(0), "migrate: no migrator");
PoolInfo storage pool = poolInfo[_pid];
IERC20 lpToken = pool.lpToken;
uint256 bal = lpToken.balanceOf(address(this));
lpToken.safeApprove(address(migrator), bal);
IERC20 newLpToken = migrator.migrate(lpToken);
require(bal == newLpToken.balanceOf(address(this)), "migrate: bad");
pool.lpToken = newLpToken;
}
// Return reward multiplier over the given _from to _to block.
function getMultiplier(uint256 _from, uint256 _to) public view returns (uint256) {
if (_to <= bonusEndBlock) {
return _to.sub(_from).mul(BONUS_MULTIPLIER);
} else if (_from >= bonusEndBlock) {
return _to.sub(_from);
} else {
return bonusEndBlock.sub(_from).mul(BONUS_MULTIPLIER).add(
_to.sub(bonusEndBlock)
);
}
}
// View function to see pending UniSushi on frontend.
function pendingUniSushi(uint256 _pid, address _user) external view returns (uint256) {
PoolInfo storage pool = poolInfo[_pid];
UserInfo storage user = userInfo[_pid][_user];
uint256 accUniSushiPerShare = pool.accUniSushiPerShare;
uint256 lpSupply = pool.lpToken.balanceOf(address(this));
if (block.number > pool.lastRewardBlock && lpSupply != 0) {
uint256 multiplier = getMultiplier(pool.lastRewardBlock, block.number);
uint256 unisushiReward = multiplier.mul(unisushiPerBlock).mul(pool.allocPoint).div(totalAllocPoint);
accUniSushiPerShare = accUniSushiPerShare.add(unisushiReward.mul(1e12).div(lpSupply));
}
return user.amount.mul(accUniSushiPerShare).div(1e12).sub(user.rewardDebt);
}
// Update reward variables for all pools. Be careful of gas spending!
function massUpdatePools() public {
uint256 length = poolInfo.length;
for (uint256 pid = 0; pid < length; ++pid) {
updatePool(pid);
}
}
// Update reward variables of the given pool to be up-to-date.
function updatePool(uint256 _pid) public {
PoolInfo storage pool = poolInfo[_pid];
if (block.number <= pool.lastRewardBlock) {
return;
}
uint256 lpSupply = pool.lpToken.balanceOf(address(this));
if (lpSupply == 0) {
pool.lastRewardBlock = block.number;
return;
}
uint256 multiplier = getMultiplier(pool.lastRewardBlock, block.number);
uint256 unisushiReward = multiplier.mul(unisushiPerBlock).mul(pool.allocPoint).div(totalAllocPoint);
unisushi.mint(devaddr, unisushiReward.div(20));
unisushi.mint(address(this), unisushiReward);
pool.accUniSushiPerShare = pool.accUniSushiPerShare.add(unisushiReward.mul(1e12).div(lpSupply));
pool.lastRewardBlock = block.number;
}
function deposit(uint256 _pid, uint256 _amount) public {
PoolInfo storage pool = poolInfo[_pid];
UserInfo storage user = userInfo[_pid][msg.sender];
updatePool(_pid);
if (user.amount > 0) {
uint256 pending = user.amount.mul(pool.accUniSushiPerShare).div(1e12).sub(user.rewardDebt);
if(pending > 0) {
safeUniSushiTransfer(msg.sender, pending);
}
}
if(_amount > 0) {
pool.lpToken.safeTransferFrom(address(msg.sender), address(this), _amount);
user.amount = user.amount.add(_amount);
}
user.rewardDebt = user.amount.mul(pool.accUniSushiPerShare).div(1e12);
emit Deposit(msg.sender, _pid, _amount);
}
// Withdraw LP tokens from Unifier.
function withdraw(uint256 _pid, uint256 _amount) public {
PoolInfo storage pool = poolInfo[_pid];
UserInfo storage user = userInfo[_pid][msg.sender];
require(user.amount >= _amount, "withdraw: not good");
updatePool(_pid);
uint256 pending = user.amount.mul(pool.accUniSushiPerShare).div(1e12).sub(user.rewardDebt);
if(pending > 0) {
safeUniSushiTransfer(msg.sender, pending);
}
if(_amount > 0) {
user.amount = user.amount.sub(_amount);
pool.lpToken.safeTransfer(address(msg.sender), _amount);
}
user.rewardDebt = user.amount.mul(pool.accUniSushiPerShare).div(1e12);
emit Withdraw(msg.sender, _pid, _amount);
}
// Withdraw without caring about rewards. EMERGENCY ONLY.
function emergencyWithdraw(uint256 _pid) public {
PoolInfo storage pool = poolInfo[_pid];
UserInfo storage user = userInfo[_pid][msg.sender];
pool.lpToken.safeTransfer(address(msg.sender), user.amount);
emit EmergencyWithdraw(msg.sender, _pid, user.amount);
user.amount = 0;
user.rewardDebt = 0;
}
// Safe UniSushi transfer function, just in case if rounding error causes pool to not have enough unisushi.
function safeUniSushiTransfer(address _to, uint256 _amount) internal {
uint256 unisushiBal = unisushi.balanceOf(address(this));
if (_amount > unisushiBal) {
unisushi.transfer(_to, unisushiBal);
} else {
unisushi.transfer(_to, _amount);
}
}
// Update dev address by the previous dev.
function dev(address _devaddr) public {
require(msg.sender == devaddr, "dev: wut?");
devaddr = _devaddr;
}
}Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
Contract ABI
API[{"inputs":[{"internalType":"contract UniSushiToken","name":"_unisushi","type":"address"},{"internalType":"address","name":"_devaddr","type":"address"},{"internalType":"uint256","name":"_startBlock","type":"uint256"},{"internalType":"uint256","name":"_bonusEndBlock","type":"uint256"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Deposit","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"EmergencyWithdraw","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"uint256","name":"pid","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Withdraw","type":"event"},{"inputs":[],"name":"BONUS_MULTIPLIER","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_allocPoint","type":"uint256"},{"internalType":"contract IERC20","name":"_lpToken","type":"address"},{"internalType":"bool","name":"_withUpdate","type":"bool"}],"name":"add","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"bonusEndBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_bonusEndBlock","type":"uint256"}],"name":"changeBonusEndBlock","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_bonusMultiplier","type":"uint256"}],"name":"changeBonusMultiplier","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_unisushiPerBlock","type":"uint256"}],"name":"changeReward","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_startBlock","type":"uint256"}],"name":"changeStartBlock","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"deposit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_devaddr","type":"address"}],"name":"dev","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"devaddr","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"}],"name":"emergencyWithdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_from","type":"uint256"},{"internalType":"uint256","name":"_to","type":"uint256"}],"name":"getMultiplier","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"massUpdatePools","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"}],"name":"migrate","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"migrator","outputs":[{"internalType":"contract IMigratorChef","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"address","name":"_user","type":"address"}],"name":"pendingUniSushi","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"poolInfo","outputs":[{"internalType":"contract IERC20","name":"lpToken","type":"address"},{"internalType":"uint256","name":"allocPoint","type":"uint256"},{"internalType":"uint256","name":"lastRewardBlock","type":"uint256"},{"internalType":"uint256","name":"accUniSushiPerShare","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"poolLength","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"uint256","name":"_allocPoint","type":"uint256"},{"internalType":"bool","name":"_withUpdate","type":"bool"}],"name":"set","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"contract IMigratorChef","name":"_migrator","type":"address"}],"name":"setMigrator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalAllocPoint","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unisushi","outputs":[{"internalType":"contract UniSushiToken","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"unisushiPerBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"}],"name":"updatePool","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"address","name":"","type":"address"}],"name":"userInfo","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"rewardDebt","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_pid","type":"uint256"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"}]Contract Creation Code
6080604052600360055560006009553480156200001b57600080fd5b506040516200348238038062003482833981810160405260808110156200004157600080fd5b8101908080519060200190929190805190602001909291908051906020019092919080519060200190929190505050600062000082620001c960201b60201c565b9050806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508073ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35083600160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555082600260006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550678ac7230489e800006004819055508060038190555081600a8190555050505050620001d1565b600033905090565b6132a180620001e16000396000f3fe608060405234801561001057600080fd5b50600436106101da5760003560e01c806364482f791161010457806393f1a40b116100a2578063e2bbb15811610071578063e2bbb15814610749578063eabe261714610781578063f2fde38b146107b5578063fdafa3c5146107f9576101da565b806393f1a40b14610650578063cf5d57db146106b9578063d49e77cd146106e7578063e0a4c98b1461071b576101da565b80638aa28550116100de5780638aa285501461056e5780638d88a90e1461058c5780638da5cb5b146105d05780638dbb1e3a14610604576101da565b806364482f79146104ec578063715018a6146105305780637cd07e471461053a576101da565b8063441a3e701161017c57806351eb05a61161014b57806351eb05a6146104585780635312ea8e146104865780635437f098146104b4578063630b5ba1146104e2576101da565b8063441a3e7014610372578063454b0608146103aa578063457b8181146103d857806348cd4cb11461043a576101da565b80631aed6553116101b85780631aed6553146102885780631eaaa045146102a657806323cf3118146103005780632ef9b5a714610344576101da565b8063081e3eda146101df5780631526fe27146101fd57806317caf6f11461026a575b600080fd5b6101e7610817565b6040518082815260200191505060405180910390f35b6102296004803603602081101561021357600080fd5b8101908080359060200190929190505050610824565b604051808573ffffffffffffffffffffffffffffffffffffffff16815260200184815260200183815260200182815260200194505050505060405180910390f35b610272610881565b6040518082815260200191505060405180910390f35b610290610887565b6040518082815260200191505060405180910390f35b6102fe600480360360608110156102bc57600080fd5b8101908080359060200190929190803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080351515906020019092919050505061088d565b005b6103426004803603602081101561031657600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050610a66565b005b6103706004803603602081101561035a57600080fd5b8101908080359060200190929190505050610b72565b005b6103a86004803603604081101561038857600080fd5b810190808035906020019092919080359060200190929190505050610c44565b005b6103d6600480360360208110156103c057600080fd5b8101908080359060200190929190505050610ea2565b005b610424600480360360408110156103ee57600080fd5b8101908080359060200190929190803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506112cc565b6040518082815260200191505060405180910390f35b610442611512565b6040518082815260200191505060405180910390f35b6104846004803603602081101561046e57600080fd5b8101908080359060200190929190505050611518565b005b6104b26004803603602081101561049c57600080fd5b8101908080359060200190929190505050611864565b005b6104e0600480360360208110156104ca57600080fd5b8101908080359060200190929190505050611996565b005b6104ea611a68565b005b61052e6004803603606081101561050257600080fd5b810190808035906020019092919080359060200190929190803515159060200190929190505050611a95565b005b610538611bdf565b005b610542611d65565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b610576611d8b565b6040518082815260200191505060405180910390f35b6105ce600480360360208110156105a257600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611d91565b005b6105d8611e98565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b61063a6004803603604081101561061a57600080fd5b810190808035906020019092919080359060200190929190505050611ec1565b6040518082815260200191505060405180910390f35b61069c6004803603604081101561066657600080fd5b8101908080359060200190929190803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611f75565b604051808381526020018281526020019250505060405180910390f35b6106e5600480360360208110156106cf57600080fd5b8101908080359060200190929190505050611fa6565b005b6106ef612078565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6107476004803603602081101561073157600080fd5b810190808035906020019092919050505061209e565b005b61077f6004803603604081101561075f57600080fd5b810190808035906020019092919080359060200190929190505050612170565b005b610789612364565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6107f7600480360360208110156107cb57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919050505061238a565b005b610801612595565b6040518082815260200191505060405180910390f35b6000600780549050905090565b6007818154811061083157fe5b90600052602060002090600402016000915090508060000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16908060010154908060020154908060030154905084565b60095481565b60035481565b61089561259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610955576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b801561096457610963611a68565b5b6000600a54431161097757600a54610979565b435b9050610990846009546125a390919063ffffffff16565b600981905550600760405180608001604052808573ffffffffffffffffffffffffffffffffffffffff1681526020018681526020018381526020016000815250908060018154018082558091505060019003906000526020600020906004020160009091909190915060008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550602082015181600101556040820151816002015560608201518160030155505050505050565b610a6e61259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610b2e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b80600660006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b610b7a61259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610c3a576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b8060058190555050565b600060078381548110610c5357fe5b9060005260206000209060040201905060006008600085815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090508281600001541015610d31576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260128152602001807f77697468647261773a206e6f7420676f6f64000000000000000000000000000081525060200191505060405180910390fd5b610d3a84611518565b6000610d848260010154610d7664e8d4a51000610d688760030154876000015461262b90919063ffffffff16565b6126b190919063ffffffff16565b6126fb90919063ffffffff16565b90506000811115610d9a57610d993382612745565b5b6000841115610e1257610dba8483600001546126fb90919063ffffffff16565b8260000181905550610e1133858560000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166129be9092919063ffffffff16565b5b610e4464e8d4a51000610e368560030154856000015461262b90919063ffffffff16565b6126b190919063ffffffff16565b8260010181905550843373ffffffffffffffffffffffffffffffffffffffff167ff279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b568866040518082815260200191505060405180910390a35050505050565b600073ffffffffffffffffffffffffffffffffffffffff16600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161415610f67576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260148152602001807f6d6967726174653a206e6f206d69677261746f7200000000000000000000000081525060200191505060405180910390fd5b600060078281548110610f7657fe5b9060005260206000209060040201905060008160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905060008173ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b15801561101857600080fd5b505afa15801561102c573d6000803e3d6000fd5b505050506040513d602081101561104257600080fd5b810190808051906020019092919050505090506110a2600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16828473ffffffffffffffffffffffffffffffffffffffff16612a609092919063ffffffff16565b6000600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ce5494bb846040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff168152602001915050602060405180830381600087803b15801561112f57600080fd5b505af1158015611143573d6000803e3d6000fd5b505050506040513d602081101561115957600080fd5b810190808051906020019092919050505090508073ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b1580156111d357600080fd5b505afa1580156111e7573d6000803e3d6000fd5b505050506040513d60208110156111fd57600080fd5b81019080805190602001909291905050508214611282576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252600c8152602001807f6d6967726174653a20626164000000000000000000000000000000000000000081525060200191505060405180910390fd5b808460000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055505050505050565b600080600784815481106112dc57fe5b9060005260206000209060040201905060006008600086815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905060008260030154905060008360000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b1580156113d657600080fd5b505afa1580156113ea573d6000803e3d6000fd5b505050506040513d602081101561140057600080fd5b81019080805190602001909291905050509050836002015443118015611427575060008114155b156114c257600061143c856002015443611ec1565b9050600061147f60095461147188600101546114636004548761262b90919063ffffffff16565b61262b90919063ffffffff16565b6126b190919063ffffffff16565b90506114bd6114ae846114a064e8d4a510008561262b90919063ffffffff16565b6126b190919063ffffffff16565b856125a390919063ffffffff16565b935050505b61150683600101546114f864e8d4a510006114ea86886000015461262b90919063ffffffff16565b6126b190919063ffffffff16565b6126fb90919063ffffffff16565b94505050505092915050565b600a5481565b60006007828154811061152757fe5b90600052602060002090600402019050806002015443116115485750611861565b60008160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b1580156115d557600080fd5b505afa1580156115e9573d6000803e3d6000fd5b505050506040513d60208110156115ff57600080fd5b81019080805190602001909291905050509050600081141561162b574382600201819055505050611861565b600061163b836002015443611ec1565b9050600061167e60095461167086600101546116626004548761262b90919063ffffffff16565b61262b90919063ffffffff16565b6126b190919063ffffffff16565b9050600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166340c10f19600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff166116f56014856126b190919063ffffffff16565b6040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050600060405180830381600087803b15801561174857600080fd5b505af115801561175c573d6000803e3d6000fd5b50505050600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166340c10f1930836040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050600060405180830381600087803b1580156117f357600080fd5b505af1158015611807573d6000803e3d6000fd5b5050505061184b6118388461182a64e8d4a510008561262b90919063ffffffff16565b6126b190919063ffffffff16565b85600301546125a390919063ffffffff16565b8460030181905550438460020181905550505050505b50565b60006007828154811061187357fe5b9060005260206000209060040201905060006008600084815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905061192a3382600001548460000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166129be9092919063ffffffff16565b823373ffffffffffffffffffffffffffffffffffffffff167fbb757047c2b5f3974fe26b7c10f732e7bce710b0952a71082702781e62ae059583600001546040518082815260200191505060405180910390a36000816000018190555060008160010181905550505050565b61199e61259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611a5e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b80600a8190555050565b6000600780549050905060005b81811015611a9157611a8681611518565b806001019050611a75565b5050565b611a9d61259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611b5d576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b8015611b6c57611b6b611a68565b5b611bb182611ba360078681548110611b8057fe5b9060005260206000209060040201600101546009546126fb90919063ffffffff16565b6125a390919063ffffffff16565b6009819055508160078481548110611bc557fe5b906000526020600020906004020160010181905550505050565b611be761259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611ca7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b60055481565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614611e54576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260098152602001807f6465763a207775743f000000000000000000000000000000000000000000000081525060200191505060405180910390fd5b80600260006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60006003548211611efa57611ef3600554611ee585856126fb90919063ffffffff16565b61262b90919063ffffffff16565b9050611f6f565b6003548310611f1d57611f1683836126fb90919063ffffffff16565b9050611f6f565b611f6c611f35600354846126fb90919063ffffffff16565b611f5e600554611f50876003546126fb90919063ffffffff16565b61262b90919063ffffffff16565b6125a390919063ffffffff16565b90505b92915050565b6008602052816000526040600020602052806000526040600020600091509150508060000154908060010154905082565b611fae61259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461206e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b8060048190555050565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6120a661259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614612166576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b8060038190555050565b60006007838154811061217f57fe5b9060005260206000209060040201905060006008600085815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090506121ec84611518565b60008160000154111561225b576000612243826001015461223564e8d4a510006122278760030154876000015461262b90919063ffffffff16565b6126b190919063ffffffff16565b6126fb90919063ffffffff16565b90506000811115612259576122583382612745565b5b505b60008311156122d5576122b53330858560000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16612c25909392919063ffffffff16565b6122cc8382600001546125a390919063ffffffff16565b81600001819055505b61230764e8d4a510006122f98460030154846000015461262b90919063ffffffff16565b6126b190919063ffffffff16565b8160010181905550833373ffffffffffffffffffffffffffffffffffffffff167f90890809c654f11d6e72a28fa60149770a0d11ec6c92319d6ceb2bb0a4ea1a15856040518082815260200191505060405180910390a350505050565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b61239261259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614612452576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614156124d8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260268152602001806131c56026913960400191505060405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a3806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b60045481565b600033905090565b600080828401905083811015612621576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601b8152602001807f536166654d6174683a206164646974696f6e206f766572666c6f77000000000081525060200191505060405180910390fd5b8091505092915050565b60008083141561263e57600090506126ab565b600082840290508284828161264f57fe5b04146126a6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260218152602001806131eb6021913960400191505060405180910390fd5b809150505b92915050565b60006126f383836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612ce6565b905092915050565b600061273d83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250612dac565b905092915050565b6000600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b1580156127d057600080fd5b505afa1580156127e4573d6000803e3d6000fd5b505050506040513d60208110156127fa57600080fd5b81019080805190602001909291905050509050808211156128e957600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663a9059cbb84836040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050602060405180830381600087803b1580156128a857600080fd5b505af11580156128bc573d6000803e3d6000fd5b505050506040513d60208110156128d257600080fd5b8101908080519060200190929190505050506129b9565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663a9059cbb84846040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050602060405180830381600087803b15801561297c57600080fd5b505af1158015612990573d6000803e3d6000fd5b505050506040513d60208110156129a657600080fd5b8101908080519060200190929190505050505b505050565b612a5b8363a9059cbb60e01b8484604051602401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050612e6c565b505050565b6000811480612b2e575060008373ffffffffffffffffffffffffffffffffffffffff1663dd62ed3e30856040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff1681526020018273ffffffffffffffffffffffffffffffffffffffff1681526020019250505060206040518083038186803b158015612af157600080fd5b505afa158015612b05573d6000803e3d6000fd5b505050506040513d6020811015612b1b57600080fd5b8101908080519060200190929190505050145b612b83576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260368152602001806132366036913960400191505060405180910390fd5b612c208363095ea7b360e01b8484604051602401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050612e6c565b505050565b612ce0846323b872dd60e01b858585604051602401808473ffffffffffffffffffffffffffffffffffffffff1681526020018373ffffffffffffffffffffffffffffffffffffffff1681526020018281526020019350505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050612e6c565b50505050565b60008083118290612d92576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825283818151815260200191508051906020019080838360005b83811015612d57578082015181840152602081019050612d3c565b50505050905090810190601f168015612d845780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b506000838581612d9e57fe5b049050809150509392505050565b6000838311158290612e59576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825283818151815260200191508051906020019080838360005b83811015612e1e578082015181840152602081019050612e03565b50505050905090810190601f168015612e4b5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b5060008385039050809150509392505050565b6060612ece826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c65648152508573ffffffffffffffffffffffffffffffffffffffff16612f5b9092919063ffffffff16565b9050600081511115612f5657808060200190516020811015612eef57600080fd5b8101908080519060200190929190505050612f55576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602a81526020018061320c602a913960400191505060405180910390fd5b5b505050565b6060612f6a8484600085612f73565b90509392505050565b6060612f7e85613179565b612ff0576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601d8152602001807f416464726573733a2063616c6c20746f206e6f6e2d636f6e747261637400000081525060200191505060405180910390fd5b600060608673ffffffffffffffffffffffffffffffffffffffff1685876040518082805190602001908083835b60208310613040578051825260208201915060208101905060208303925061301d565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d80600081146130a2576040519150601f19603f3d011682016040523d82523d6000602084013e6130a7565b606091505b509150915081156130bc578092505050613171565b6000815111156130cf5780518082602001fd5b836040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561313657808201518184015260208101905061311b565b50505050905090810190601f1680156131635780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b949350505050565b60008060007fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a47060001b9050833f91508082141580156131bb57506000801b8214155b9250505091905056fe4f776e61626c653a206e6577206f776e657220697320746865207a65726f2061646472657373536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f775361666545524332303a204552433230206f7065726174696f6e20646964206e6f7420737563636565645361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f20746f206e6f6e2d7a65726f20616c6c6f77616e6365a26469706673582212204a56690cb8f6ff7ead552af04751f1cf5c6d8241a13e89397f4f228bc693bb1c64736f6c634300060c003300000000000000000000000050b379ec299e4585f2644ea6376d00b3c402c8cc000000000000000000000000accb75e6dc80e15f09cc378bb931c540d879a9890000000000000000000000000000000000000000000000000000000000a71b4c0000000000000000000000000000000000000000000000000000000000a7425c
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106101da5760003560e01c806364482f791161010457806393f1a40b116100a2578063e2bbb15811610071578063e2bbb15814610749578063eabe261714610781578063f2fde38b146107b5578063fdafa3c5146107f9576101da565b806393f1a40b14610650578063cf5d57db146106b9578063d49e77cd146106e7578063e0a4c98b1461071b576101da565b80638aa28550116100de5780638aa285501461056e5780638d88a90e1461058c5780638da5cb5b146105d05780638dbb1e3a14610604576101da565b806364482f79146104ec578063715018a6146105305780637cd07e471461053a576101da565b8063441a3e701161017c57806351eb05a61161014b57806351eb05a6146104585780635312ea8e146104865780635437f098146104b4578063630b5ba1146104e2576101da565b8063441a3e7014610372578063454b0608146103aa578063457b8181146103d857806348cd4cb11461043a576101da565b80631aed6553116101b85780631aed6553146102885780631eaaa045146102a657806323cf3118146103005780632ef9b5a714610344576101da565b8063081e3eda146101df5780631526fe27146101fd57806317caf6f11461026a575b600080fd5b6101e7610817565b6040518082815260200191505060405180910390f35b6102296004803603602081101561021357600080fd5b8101908080359060200190929190505050610824565b604051808573ffffffffffffffffffffffffffffffffffffffff16815260200184815260200183815260200182815260200194505050505060405180910390f35b610272610881565b6040518082815260200191505060405180910390f35b610290610887565b6040518082815260200191505060405180910390f35b6102fe600480360360608110156102bc57600080fd5b8101908080359060200190929190803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080351515906020019092919050505061088d565b005b6103426004803603602081101561031657600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050610a66565b005b6103706004803603602081101561035a57600080fd5b8101908080359060200190929190505050610b72565b005b6103a86004803603604081101561038857600080fd5b810190808035906020019092919080359060200190929190505050610c44565b005b6103d6600480360360208110156103c057600080fd5b8101908080359060200190929190505050610ea2565b005b610424600480360360408110156103ee57600080fd5b8101908080359060200190929190803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506112cc565b6040518082815260200191505060405180910390f35b610442611512565b6040518082815260200191505060405180910390f35b6104846004803603602081101561046e57600080fd5b8101908080359060200190929190505050611518565b005b6104b26004803603602081101561049c57600080fd5b8101908080359060200190929190505050611864565b005b6104e0600480360360208110156104ca57600080fd5b8101908080359060200190929190505050611996565b005b6104ea611a68565b005b61052e6004803603606081101561050257600080fd5b810190808035906020019092919080359060200190929190803515159060200190929190505050611a95565b005b610538611bdf565b005b610542611d65565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b610576611d8b565b6040518082815260200191505060405180910390f35b6105ce600480360360208110156105a257600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611d91565b005b6105d8611e98565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b61063a6004803603604081101561061a57600080fd5b810190808035906020019092919080359060200190929190505050611ec1565b6040518082815260200191505060405180910390f35b61069c6004803603604081101561066657600080fd5b8101908080359060200190929190803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611f75565b604051808381526020018281526020019250505060405180910390f35b6106e5600480360360208110156106cf57600080fd5b8101908080359060200190929190505050611fa6565b005b6106ef612078565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6107476004803603602081101561073157600080fd5b810190808035906020019092919050505061209e565b005b61077f6004803603604081101561075f57600080fd5b810190808035906020019092919080359060200190929190505050612170565b005b610789612364565b604051808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6107f7600480360360208110156107cb57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919050505061238a565b005b610801612595565b6040518082815260200191505060405180910390f35b6000600780549050905090565b6007818154811061083157fe5b90600052602060002090600402016000915090508060000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16908060010154908060020154908060030154905084565b60095481565b60035481565b61089561259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610955576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b801561096457610963611a68565b5b6000600a54431161097757600a54610979565b435b9050610990846009546125a390919063ffffffff16565b600981905550600760405180608001604052808573ffffffffffffffffffffffffffffffffffffffff1681526020018681526020018381526020016000815250908060018154018082558091505060019003906000526020600020906004020160009091909190915060008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550602082015181600101556040820151816002015560608201518160030155505050505050565b610a6e61259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610b2e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b80600660006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b610b7a61259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610c3a576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b8060058190555050565b600060078381548110610c5357fe5b9060005260206000209060040201905060006008600085815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090508281600001541015610d31576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260128152602001807f77697468647261773a206e6f7420676f6f64000000000000000000000000000081525060200191505060405180910390fd5b610d3a84611518565b6000610d848260010154610d7664e8d4a51000610d688760030154876000015461262b90919063ffffffff16565b6126b190919063ffffffff16565b6126fb90919063ffffffff16565b90506000811115610d9a57610d993382612745565b5b6000841115610e1257610dba8483600001546126fb90919063ffffffff16565b8260000181905550610e1133858560000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166129be9092919063ffffffff16565b5b610e4464e8d4a51000610e368560030154856000015461262b90919063ffffffff16565b6126b190919063ffffffff16565b8260010181905550843373ffffffffffffffffffffffffffffffffffffffff167ff279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b568866040518082815260200191505060405180910390a35050505050565b600073ffffffffffffffffffffffffffffffffffffffff16600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161415610f67576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260148152602001807f6d6967726174653a206e6f206d69677261746f7200000000000000000000000081525060200191505060405180910390fd5b600060078281548110610f7657fe5b9060005260206000209060040201905060008160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905060008173ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b15801561101857600080fd5b505afa15801561102c573d6000803e3d6000fd5b505050506040513d602081101561104257600080fd5b810190808051906020019092919050505090506110a2600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16828473ffffffffffffffffffffffffffffffffffffffff16612a609092919063ffffffff16565b6000600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ce5494bb846040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff168152602001915050602060405180830381600087803b15801561112f57600080fd5b505af1158015611143573d6000803e3d6000fd5b505050506040513d602081101561115957600080fd5b810190808051906020019092919050505090508073ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b1580156111d357600080fd5b505afa1580156111e7573d6000803e3d6000fd5b505050506040513d60208110156111fd57600080fd5b81019080805190602001909291905050508214611282576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252600c8152602001807f6d6967726174653a20626164000000000000000000000000000000000000000081525060200191505060405180910390fd5b808460000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055505050505050565b600080600784815481106112dc57fe5b9060005260206000209060040201905060006008600086815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905060008260030154905060008360000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b1580156113d657600080fd5b505afa1580156113ea573d6000803e3d6000fd5b505050506040513d602081101561140057600080fd5b81019080805190602001909291905050509050836002015443118015611427575060008114155b156114c257600061143c856002015443611ec1565b9050600061147f60095461147188600101546114636004548761262b90919063ffffffff16565b61262b90919063ffffffff16565b6126b190919063ffffffff16565b90506114bd6114ae846114a064e8d4a510008561262b90919063ffffffff16565b6126b190919063ffffffff16565b856125a390919063ffffffff16565b935050505b61150683600101546114f864e8d4a510006114ea86886000015461262b90919063ffffffff16565b6126b190919063ffffffff16565b6126fb90919063ffffffff16565b94505050505092915050565b600a5481565b60006007828154811061152757fe5b90600052602060002090600402019050806002015443116115485750611861565b60008160000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b1580156115d557600080fd5b505afa1580156115e9573d6000803e3d6000fd5b505050506040513d60208110156115ff57600080fd5b81019080805190602001909291905050509050600081141561162b574382600201819055505050611861565b600061163b836002015443611ec1565b9050600061167e60095461167086600101546116626004548761262b90919063ffffffff16565b61262b90919063ffffffff16565b6126b190919063ffffffff16565b9050600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166340c10f19600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff166116f56014856126b190919063ffffffff16565b6040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050600060405180830381600087803b15801561174857600080fd5b505af115801561175c573d6000803e3d6000fd5b50505050600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166340c10f1930836040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050600060405180830381600087803b1580156117f357600080fd5b505af1158015611807573d6000803e3d6000fd5b5050505061184b6118388461182a64e8d4a510008561262b90919063ffffffff16565b6126b190919063ffffffff16565b85600301546125a390919063ffffffff16565b8460030181905550438460020181905550505050505b50565b60006007828154811061187357fe5b9060005260206000209060040201905060006008600084815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020905061192a3382600001548460000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166129be9092919063ffffffff16565b823373ffffffffffffffffffffffffffffffffffffffff167fbb757047c2b5f3974fe26b7c10f732e7bce710b0952a71082702781e62ae059583600001546040518082815260200191505060405180910390a36000816000018190555060008160010181905550505050565b61199e61259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611a5e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b80600a8190555050565b6000600780549050905060005b81811015611a9157611a8681611518565b806001019050611a75565b5050565b611a9d61259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611b5d576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b8015611b6c57611b6b611a68565b5b611bb182611ba360078681548110611b8057fe5b9060005260206000209060040201600101546009546126fb90919063ffffffff16565b6125a390919063ffffffff16565b6009819055508160078481548110611bc557fe5b906000526020600020906004020160010181905550505050565b611be761259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611ca7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b60055481565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614611e54576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260098152602001807f6465763a207775743f000000000000000000000000000000000000000000000081525060200191505060405180910390fd5b80600260006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60006003548211611efa57611ef3600554611ee585856126fb90919063ffffffff16565b61262b90919063ffffffff16565b9050611f6f565b6003548310611f1d57611f1683836126fb90919063ffffffff16565b9050611f6f565b611f6c611f35600354846126fb90919063ffffffff16565b611f5e600554611f50876003546126fb90919063ffffffff16565b61262b90919063ffffffff16565b6125a390919063ffffffff16565b90505b92915050565b6008602052816000526040600020602052806000526040600020600091509150508060000154908060010154905082565b611fae61259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461206e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b8060048190555050565b600260009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6120a661259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614612166576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b8060038190555050565b60006007838154811061217f57fe5b9060005260206000209060040201905060006008600085815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002090506121ec84611518565b60008160000154111561225b576000612243826001015461223564e8d4a510006122278760030154876000015461262b90919063ffffffff16565b6126b190919063ffffffff16565b6126fb90919063ffffffff16565b90506000811115612259576122583382612745565b5b505b60008311156122d5576122b53330858560000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16612c25909392919063ffffffff16565b6122cc8382600001546125a390919063ffffffff16565b81600001819055505b61230764e8d4a510006122f98460030154846000015461262b90919063ffffffff16565b6126b190919063ffffffff16565b8160010181905550833373ffffffffffffffffffffffffffffffffffffffff167f90890809c654f11d6e72a28fa60149770a0d11ec6c92319d6ceb2bb0a4ea1a15856040518082815260200191505060405180910390a350505050565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b61239261259b565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614612452576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614156124d8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260268152602001806131c56026913960400191505060405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a3806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b60045481565b600033905090565b600080828401905083811015612621576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601b8152602001807f536166654d6174683a206164646974696f6e206f766572666c6f77000000000081525060200191505060405180910390fd5b8091505092915050565b60008083141561263e57600090506126ab565b600082840290508284828161264f57fe5b04146126a6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260218152602001806131eb6021913960400191505060405180910390fd5b809150505b92915050565b60006126f383836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612ce6565b905092915050565b600061273d83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250612dac565b905092915050565b6000600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b1580156127d057600080fd5b505afa1580156127e4573d6000803e3d6000fd5b505050506040513d60208110156127fa57600080fd5b81019080805190602001909291905050509050808211156128e957600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663a9059cbb84836040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050602060405180830381600087803b1580156128a857600080fd5b505af11580156128bc573d6000803e3d6000fd5b505050506040513d60208110156128d257600080fd5b8101908080519060200190929190505050506129b9565b600160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663a9059cbb84846040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050602060405180830381600087803b15801561297c57600080fd5b505af1158015612990573d6000803e3d6000fd5b505050506040513d60208110156129a657600080fd5b8101908080519060200190929190505050505b505050565b612a5b8363a9059cbb60e01b8484604051602401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050612e6c565b505050565b6000811480612b2e575060008373ffffffffffffffffffffffffffffffffffffffff1663dd62ed3e30856040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff1681526020018273ffffffffffffffffffffffffffffffffffffffff1681526020019250505060206040518083038186803b158015612af157600080fd5b505afa158015612b05573d6000803e3d6000fd5b505050506040513d6020811015612b1b57600080fd5b8101908080519060200190929190505050145b612b83576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260368152602001806132366036913960400191505060405180910390fd5b612c208363095ea7b360e01b8484604051602401808373ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050612e6c565b505050565b612ce0846323b872dd60e01b858585604051602401808473ffffffffffffffffffffffffffffffffffffffff1681526020018373ffffffffffffffffffffffffffffffffffffffff1681526020018281526020019350505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050612e6c565b50505050565b60008083118290612d92576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825283818151815260200191508051906020019080838360005b83811015612d57578082015181840152602081019050612d3c565b50505050905090810190601f168015612d845780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b506000838581612d9e57fe5b049050809150509392505050565b6000838311158290612e59576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825283818151815260200191508051906020019080838360005b83811015612e1e578082015181840152602081019050612e03565b50505050905090810190601f168015612e4b5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b5060008385039050809150509392505050565b6060612ece826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c65648152508573ffffffffffffffffffffffffffffffffffffffff16612f5b9092919063ffffffff16565b9050600081511115612f5657808060200190516020811015612eef57600080fd5b8101908080519060200190929190505050612f55576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602a81526020018061320c602a913960400191505060405180910390fd5b5b505050565b6060612f6a8484600085612f73565b90509392505050565b6060612f7e85613179565b612ff0576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601d8152602001807f416464726573733a2063616c6c20746f206e6f6e2d636f6e747261637400000081525060200191505060405180910390fd5b600060608673ffffffffffffffffffffffffffffffffffffffff1685876040518082805190602001908083835b60208310613040578051825260208201915060208101905060208303925061301d565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d80600081146130a2576040519150601f19603f3d011682016040523d82523d6000602084013e6130a7565b606091505b509150915081156130bc578092505050613171565b6000815111156130cf5780518082602001fd5b836040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561313657808201518184015260208101905061311b565b50505050905090810190601f1680156131635780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b949350505050565b60008060007fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a47060001b9050833f91508082141580156131bb57506000801b8214155b9250505091905056fe4f776e61626c653a206e6577206f776e657220697320746865207a65726f2061646472657373536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f775361666545524332303a204552433230206f7065726174696f6e20646964206e6f7420737563636565645361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f20746f206e6f6e2d7a65726f20616c6c6f77616e6365a26469706673582212204a56690cb8f6ff7ead552af04751f1cf5c6d8241a13e89397f4f228bc693bb1c64736f6c634300060c0033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
00000000000000000000000050b379ec299e4585f2644ea6376d00b3c402c8cc000000000000000000000000accb75e6dc80e15f09cc378bb931c540d879a9890000000000000000000000000000000000000000000000000000000000a71b4c0000000000000000000000000000000000000000000000000000000000a7425c
-----Decoded View---------------
Arg [0] : _unisushi (address): 0x50b379ec299E4585F2644EA6376D00b3C402c8cc
Arg [1] : _devaddr (address): 0xaCcb75e6DC80E15F09cC378BB931C540d879a989
Arg [2] : _startBlock (uint256): 10951500
Arg [3] : _bonusEndBlock (uint256): 10961500
-----Encoded View---------------
4 Constructor Arguments found :
Arg [0] : 00000000000000000000000050b379ec299e4585f2644ea6376d00b3c402c8cc
Arg [1] : 000000000000000000000000accb75e6dc80e15f09cc378bb931c540d879a989
Arg [2] : 0000000000000000000000000000000000000000000000000000000000a71b4c
Arg [3] : 0000000000000000000000000000000000000000000000000000000000a7425c
Deployed Bytecode Sourcemap
49292:9605:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;52041:95;;;:::i;:::-;;;;;;;;;;;;;;;;;;;50543:26;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;50786:34;;;:::i;:::-;;;;;;;;;;;;;;;;;;;50171:28;;;:::i;:::-;;;;;;;;;;;;;;;;;;;52144:517;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;53049:102;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;51905:128;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;57103:752;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;53274:491;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;54331:795;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;50881:25;;;:::i;:::-;;;;;;;;;;;;;;;;;;;55465:817;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;57926:356;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;51667:107;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;55209:180;;;:::i;:::-;;52669:304;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;28919:148;;;:::i;:::-;;50478:29;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;50338:35;;;:::i;:::-;;;;;;;;;;;;;;;;;;;58765:129;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;28277:79;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;53841:423;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;50625:66;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;51538:121;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;50088:22;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;51780:119;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;56290:764;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;50031:29;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;29222:244;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;50249:31;;;:::i;:::-;;;;;;;;;;;;;;;;;;;52041:95;52086:7;52113:8;:15;;;;52106:22;;52041:95;:::o;50543:26::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;50786:34::-;;;;:::o;50171:28::-;;;;:::o;52144:517::-;28499:12;:10;:12::i;:::-;28489:22;;:6;;;;;;;;;;:22;;;28481:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;52245:11:::1;52241:61;;;52273:17;:15;:17::i;:::-;52241:61;52312:23;52353:10;;52338:12;:25;:53;;52381:10;;52338:53;;;52366:12;52338:53;52312:79;;52420:32;52440:11;52420:15;;:19;;:32;;;;:::i;:::-;52402:15;:50;;;;52463:8;52477:175;;;;;;;;52510:8;52477:175;;;;;;52545:11;52477:175;;;;52588:15;52477:175;;;;52639:1;52477:175;;::::0;52463:190:::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28559:1;52144:517:::0;;;:::o;53049:102::-;28499:12;:10;:12::i;:::-;28489:22;;:6;;;;;;;;;;:22;;;28481:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53134:9:::1;53123:8;;:20;;;;;;;;;;;;;;;;;;53049:102:::0;:::o;51905:128::-;28499:12;:10;:12::i;:::-;28489:22;;:6;;;;;;;;;;:22;;;28481:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;52009:16:::1;51990;:35;;;;51905:128:::0;:::o;57103:752::-;57170:21;57194:8;57203:4;57194:14;;;;;;;;;;;;;;;;;;57170:38;;57219:21;57243:8;:14;57252:4;57243:14;;;;;;;;;;;:26;57258:10;57243:26;;;;;;;;;;;;;;;57219:50;;57303:7;57288:4;:11;;;:22;;57280:53;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;57344:16;57355:4;57344:10;:16::i;:::-;57371:15;57389:72;57445:4;:15;;;57389:51;57435:4;57389:41;57405:4;:24;;;57389:4;:11;;;:15;;:41;;;;:::i;:::-;:45;;:51;;;;:::i;:::-;:55;;:72;;;;:::i;:::-;57371:90;;57485:1;57475:7;:11;57472:84;;;57503:41;57524:10;57536:7;57503:20;:41::i;:::-;57472:84;57579:1;57569:7;:11;57566:151;;;57611:24;57627:7;57611:4;:11;;;:15;;:24;;;;:::i;:::-;57597:4;:11;;:38;;;;57650:55;57684:10;57697:7;57650:4;:12;;;;;;;;;;;;:25;;;;:55;;;;;:::i;:::-;57566:151;57745:51;57791:4;57745:41;57761:4;:24;;;57745:4;:11;;;:15;;:41;;;;:::i;:::-;:45;;:51;;;;:::i;:::-;57727:4;:15;;:69;;;;57833:4;57821:10;57812:35;;;57839:7;57812:35;;;;;;;;;;;;;;;;;;57103:752;;;;;:::o;53274:491::-;53360:1;53331:31;;53339:8;;;;;;;;;;;53331:31;;;;53323:64;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53398:21;53422:8;53431:4;53422:14;;;;;;;;;;;;;;;;;;53398:38;;53447:14;53464:4;:12;;;;;;;;;;;;53447:29;;53487:11;53501:7;:17;;;53527:4;53501:32;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53487:46;;53544:43;53572:8;;;;;;;;;;;53583:3;53544:7;:19;;;;:43;;;;;:::i;:::-;53598:17;53618:8;;;;;;;;;;;:16;;;53635:7;53618:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53598:45;;53669:10;:20;;;53698:4;53669:35;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53662:3;:42;53654:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53747:10;53732:4;:12;;;:25;;;;;;;;;;;;;;;;;;53274:491;;;;;:::o;54331:795::-;54408:7;54428:21;54452:8;54461:4;54452:14;;;;;;;;;;;;;;;;;;54428:38;;54477:21;54501:8;:14;54510:4;54501:14;;;;;;;;;;;:21;54516:5;54501:21;;;;;;;;;;;;;;;54477:45;;54533:27;54563:4;:24;;;54533:54;;54598:16;54617:4;:12;;;;;;;;;;;;:22;;;54648:4;54617:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;54598:56;;54684:4;:20;;;54669:12;:35;:52;;;;;54720:1;54708:8;:13;;54669:52;54665:369;;;54738:18;54759:49;54773:4;:20;;;54795:12;54759:13;:49::i;:::-;54738:70;;54823:22;54848:74;54906:15;;54848:53;54885:4;:15;;;54848:32;54863:16;;54848:10;:14;;:32;;;;:::i;:::-;:36;;:53;;;;:::i;:::-;:57;;:74;;;;:::i;:::-;54823:99;;54959:63;54983:38;55012:8;54983:24;55002:4;54983:14;:18;;:24;;;;:::i;:::-;:28;;:38;;;;:::i;:::-;54959:19;:23;;:63;;;;:::i;:::-;54937:85;;54665:369;;;55051:67;55102:4;:15;;;55051:46;55092:4;55051:36;55067:19;55051:4;:11;;;:15;;:36;;;;:::i;:::-;:40;;:46;;;;:::i;:::-;:50;;:67;;;;:::i;:::-;55044:74;;;;;;54331:795;;;;:::o;50881:25::-;;;;:::o;55465:817::-;55517:21;55541:8;55550:4;55541:14;;;;;;;;;;;;;;;;;;55517:38;;55586:4;:20;;;55570:12;:36;55566:75;;55623:7;;;55566:75;55651:16;55670:4;:12;;;;;;;;;;;;:22;;;55701:4;55670:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;55651:56;;55734:1;55722:8;:13;55718:102;;;55775:12;55752:4;:20;;:35;;;;55802:7;;;;55718:102;55830:18;55851:49;55865:4;:20;;;55887:12;55851:13;:49::i;:::-;55830:70;;55911:22;55936:74;55994:15;;55936:53;55973:4;:15;;;55936:32;55951:16;;55936:10;:14;;:32;;;;:::i;:::-;:36;;:53;;;;:::i;:::-;:57;;:74;;;;:::i;:::-;55911:99;;56021:8;;;;;;;;;;;:13;;;56035:7;;;;;;;;;;;56044:22;56063:2;56044:14;:18;;:22;;;;:::i;:::-;56021:46;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56078:8;;;;;;;;;;;:13;;;56100:4;56107:14;56078:44;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56160:68;56189:38;56218:8;56189:24;56208:4;56189:14;:18;;:24;;;;:::i;:::-;:28;;:38;;;;:::i;:::-;56160:4;:24;;;:28;;:68;;;;:::i;:::-;56133:4;:24;;:95;;;;56262:12;56239:4;:20;;:35;;;;55465:817;;;;;;:::o;57926:356::-;57985:21;58009:8;58018:4;58009:14;;;;;;;;;;;;;;;;;;57985:38;;58034:21;58058:8;:14;58067:4;58058:14;;;;;;;;;;;:26;58073:10;58058:26;;;;;;;;;;;;;;;58034:50;;58095:59;58129:10;58142:4;:11;;;58095:4;:12;;;;;;;;;;;;:25;;;;:59;;;;;:::i;:::-;58200:4;58188:10;58170:48;;;58206:4;:11;;;58170:48;;;;;;;;;;;;;;;;;;58243:1;58229:4;:11;;:15;;;;58273:1;58255:4;:15;;:19;;;;57926:356;;;:::o;51667:107::-;28499:12;:10;:12::i;:::-;28489:22;;:6;;;;;;;;;;:22;;;28481:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;51755:11:::1;51742:10;:24;;;;51667:107:::0;:::o;55209:180::-;55254:14;55271:8;:15;;;;55254:32;;55302:11;55297:85;55325:6;55319:3;:12;55297:85;;;55355:15;55366:3;55355:10;:15::i;:::-;55333:5;;;;;55297:85;;;;55209:180;:::o;52669:304::-;28499:12;:10;:12::i;:::-;28489:22;;:6;;;;;;;;;;:22;;;28481:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;52767:11:::1;52763:61;;;52795:17;:15;:17::i;:::-;52763:61;52852:63;52903:11;52852:46;52872:8;52881:4;52872:14;;;;;;;;;;;;;;;;;;:25;;;52852:15;;:19;;:46;;;;:::i;:::-;:50;;:63;;;;:::i;:::-;52834:15;:81;;;;52954:11;52926:8;52935:4;52926:14;;;;;;;;;;;;;;;;;;:25;;:39;;;;52669:304:::0;;;:::o;28919:148::-;28499:12;:10;:12::i;:::-;28489:22;;:6;;;;;;;;;;:22;;;28481:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29026:1:::1;28989:40;;29010:6;::::0;::::1;;;;;;;;28989:40;;;;;;;;;;;;29057:1;29040:6:::0;::::1;:19;;;;;;;;;;;;;;;;;;28919:148::o:0;50478:29::-;;;;;;;;;;;;;:::o;50338:35::-;;;;:::o;58765:129::-;58836:7;;;;;;;;;;;58822:21;;:10;:21;;;58814:43;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;58878:8;58868:7;;:18;;;;;;;;;;;;;;;;;;58765:129;:::o;28277:79::-;28315:7;28342:6;;;;;;;;;;;28335:13;;28277:79;:::o;53841:423::-;53913:7;53944:13;;53937:3;:20;53933:324;;53981:36;54000:16;;53981:14;53989:5;53981:3;:7;;:14;;;;:::i;:::-;:18;;:36;;;;:::i;:::-;53974:43;;;;53933:324;54048:13;;54039:5;:22;54035:222;;54085:14;54093:5;54085:3;:7;;:14;;;;:::i;:::-;54078:21;;;;54035:222;54139:106;54208:22;54216:13;;54208:3;:7;;:22;;;;:::i;:::-;54139:46;54168:16;;54139:24;54157:5;54139:13;;:17;;:24;;;;:::i;:::-;:28;;:46;;;;:::i;:::-;:50;;:106;;;;:::i;:::-;54132:113;;53841:423;;;;;:::o;50625:66::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;51538:121::-;28499:12;:10;:12::i;:::-;28489:22;;:6;;;;;;;;;;:22;;;28481:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;51634:17:::1;51615:16;:36;;;;51538:121:::0;:::o;50088:22::-;;;;;;;;;;;;;:::o;51780:119::-;28499:12;:10;:12::i;:::-;28489:22;;:6;;;;;;;;;;:22;;;28481:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;51877:14:::1;51861:13;:30;;;;51780:119:::0;:::o;56290:764::-;56356:21;56380:8;56389:4;56380:14;;;;;;;;;;;;;;;;;;56356:38;;56405:21;56429:8;:14;56438:4;56429:14;;;;;;;;;;;:26;56444:10;56429:26;;;;;;;;;;;;;;;56405:50;;56466:16;56477:4;56466:10;:16::i;:::-;56511:1;56497:4;:11;;;:15;56493:244;;;56529:15;56547:72;56603:4;:15;;;56547:51;56593:4;56547:41;56563:4;:24;;;56547:4;:11;;;:15;;:41;;;;:::i;:::-;:45;;:51;;;;:::i;:::-;:55;;:72;;;;:::i;:::-;56529:90;;56647:1;56637:7;:11;56634:92;;;56669:41;56690:10;56702:7;56669:20;:41::i;:::-;56634:92;56493:244;;56760:1;56750:7;:11;56747:170;;;56778:74;56816:10;56837:4;56844:7;56778:4;:12;;;;;;;;;;;;:29;;;;:74;;;;;;:::i;:::-;56881:24;56897:7;56881:4;:11;;;:15;;:24;;;;:::i;:::-;56867:4;:11;;:38;;;;56747:170;56945:51;56991:4;56945:41;56961:4;:24;;;56945:4;:11;;;:15;;:41;;;;:::i;:::-;:45;;:51;;;;:::i;:::-;56927:4;:15;;:69;;;;57032:4;57020:10;57012:34;;;57038:7;57012:34;;;;;;;;;;;;;;;;;;56290:764;;;;:::o;50031:29::-;;;;;;;;;;;;;:::o;29222:244::-;28499:12;:10;:12::i;:::-;28489:22;;:6;;;;;;;;;;:22;;;28481:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29331:1:::1;29311:22;;:8;:22;;;;29303:73;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29421:8;29392:38;;29413:6;::::0;::::1;;;;;;;;29392:38;;;;;;;;;;;;29450:8;29441:6;::::0;:17:::1;;;;;;;;;;;;;;;;;;29222:244:::0;:::o;50249:31::-;;;;:::o;26835:106::-;26888:15;26923:10;26916:17;;26835:106;:::o;3749:181::-;3807:7;3827:9;3843:1;3839;:5;3827:17;;3868:1;3863;:6;;3855:46;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3921:1;3914:8;;;3749:181;;;;:::o;5103:471::-;5161:7;5411:1;5406;:6;5402:47;;;5436:1;5429:8;;;;5402:47;5461:9;5477:1;5473;:5;5461:17;;5506:1;5501;5497;:5;;;;;;:10;5489:56;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5565:1;5558:8;;;5103:471;;;;;:::o;6050:132::-;6108:7;6135:39;6139:1;6142;6135:39;;;;;;;;;;;;;;;;;:3;:39::i;:::-;6128:46;;6050:132;;;;:::o;4213:136::-;4271:7;4298:43;4302:1;4305;4298:43;;;;;;;;;;;;;;;;;:3;:43::i;:::-;4291:50;;4213:136;;;;:::o;58403:306::-;58483:19;58505:8;;;;;;;;;;;:18;;;58532:4;58505:33;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;58483:55;;58563:11;58553:7;:21;58549:153;;;58591:8;;;;;;;;;;;:17;;;58609:3;58614:11;58591:35;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;58549:153;;;58659:8;;;;;;;;;;;:17;;;58677:3;58682:7;58659:31;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;58549:153;58403:306;;;:::o;15091:177::-;15174:86;15194:5;15224:23;;;15249:2;15253:5;15201:58;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15174:19;:86::i;:::-;15091:177;;;:::o;15750:622::-;16129:1;16120:5;:10;16119:62;;;;16179:1;16136:5;:15;;;16160:4;16167:7;16136:39;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:44;16119:62;16111:152;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16274:90;16294:5;16324:22;;;16348:7;16357:5;16301:62;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16274:19;:90::i;:::-;15750:622;;;:::o;15276:205::-;15377:96;15397:5;15427:27;;;15456:4;15462:2;15466:5;15404:68;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15377:19;:96::i;:::-;15276:205;;;;:::o;6678:278::-;6764:7;6796:1;6792;:5;6799:12;6784:28;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6823:9;6839:1;6835;:5;;;;;;6823:17;;6947:1;6940:8;;;6678:278;;;;;:::o;4652:192::-;4738:7;4771:1;4766;:6;;4774:12;4758:29;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4798:9;4814:1;4810;:5;4798:17;;4835:1;4828:8;;;4652:192;;;;;:::o;17396:761::-;17820:23;17846:69;17874:4;17846:69;;;;;;;;;;;;;;;;;17854:5;17846:27;;;;:69;;;;;:::i;:::-;17820:95;;17950:1;17930:10;:17;:21;17926:224;;;18072:10;18061:30;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18053:85;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17926:224;17396:761;;;:::o;12084:196::-;12187:12;12219:53;12242:6;12250:4;12256:1;12259:12;12219:22;:53::i;:::-;12212:60;;12084:196;;;;;:::o;13461:979::-;13591:12;13624:18;13635:6;13624:10;:18::i;:::-;13616:60;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13750:12;13764:23;13791:6;:11;;13811:8;13822:4;13791:36;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13749:78;;;;13842:7;13838:595;;;13873:10;13866:17;;;;;;13838:595;14007:1;13987:10;:17;:21;13983:439;;;14250:10;14244:17;14311:15;14298:10;14294:2;14290:19;14283:44;14198:148;14393:12;14386:20;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13461:979;;;;;;;:::o;8969:619::-;9029:4;9291:16;9318:19;9340:66;9318:88;;;;9509:7;9497:20;9485:32;;9549:11;9537:8;:23;;:42;;;;;9576:3;9564:15;;:8;:15;;9537:42;9529:51;;;;8969:619;;;:::o
Swarm Source
ipfs://4a56690cb8f6ff7ead552af04751f1cf5c6d8241a13e89397f4f228bc693bb1c
Loading...
Loading
Loading...
Loading
Net Worth in USD
$0.00
Net Worth in ETH
0
Multichain Portfolio | 34 Chains
| Chain | Token | Portfolio % | Price | Amount | Value |
|---|
Loading...
Loading
Loading...
Loading
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.