Feature Tip: Add private address tag to any address under My Name Tag !
Overview
ETH Balance
0 ETH
Eth Value
$0.00More Info
Private Name Tags
ContractCreator
View more zero value Internal Transactions in Advanced View mode
Advanced mode:
Loading...
Loading
Contract Name:
GoldfinchConfig
Compiler Version
v0.6.12+commit.27d51765
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; pragma experimental ABIEncoderV2; import {BaseUpgradeablePausable} from "./BaseUpgradeablePausable.sol"; import {IGoldfinchConfig} from "../../interfaces/IGoldfinchConfig.sol"; import {ConfigOptions} from "./ConfigOptions.sol"; /** * @title GoldfinchConfig * @notice This contract stores mappings of useful "protocol config state", giving a central place * for all other contracts to access it. For example, the TransactionLimit, or the PoolAddress. These config vars * are enumerated in the `ConfigOptions` library, and can only be changed by admins of the protocol. * @author Goldfinch */ contract GoldfinchConfig is BaseUpgradeablePausable, IGoldfinchConfig { bytes32 public constant GO_LISTER_ROLE = keccak256("GO_LISTER_ROLE"); mapping(uint256 => address) public addresses; mapping(uint256 => uint256) public numbers; mapping(address => bool) public goList; event AddressUpdated(address owner, uint256 index, address oldValue, address newValue); event NumberUpdated(address owner, uint256 index, uint256 oldValue, uint256 newValue); event GoListed(address indexed member); event NoListed(address indexed member); bool public valuesInitialized; function initialize(address owner) public initializer { require(owner != address(0), "Owner address cannot be empty"); __BaseUpgradeablePausable__init(owner); _setupRole(GO_LISTER_ROLE, owner); _setRoleAdmin(GO_LISTER_ROLE, OWNER_ROLE); } /// @inheritdoc IGoldfinchConfig function setAddress(uint256 addressIndex, address newAddress) public override onlyAdmin { require(addresses[addressIndex] == address(0), "Address has already been initialized"); emit AddressUpdated(msg.sender, addressIndex, addresses[addressIndex], newAddress); addresses[addressIndex] = newAddress; } /// @inheritdoc IGoldfinchConfig function setNumber(uint256 index, uint256 newNumber) public override onlyAdmin { emit NumberUpdated(msg.sender, index, numbers[index], newNumber); numbers[index] = newNumber; } function setTreasuryReserve(address newTreasuryReserve) public onlyAdmin { uint256 key = uint256(ConfigOptions.Addresses.TreasuryReserve); emit AddressUpdated(msg.sender, key, addresses[key], newTreasuryReserve); addresses[key] = newTreasuryReserve; } function setSeniorPoolStrategy(address newStrategy) public onlyAdmin { uint256 key = uint256(ConfigOptions.Addresses.SeniorPoolStrategy); emit AddressUpdated(msg.sender, key, addresses[key], newStrategy); addresses[key] = newStrategy; } function setCreditLineImplementation(address newAddress) public onlyAdmin { uint256 key = uint256(ConfigOptions.Addresses.CreditLineImplementation); emit AddressUpdated(msg.sender, key, addresses[key], newAddress); addresses[key] = newAddress; } function setTranchedPoolImplementation(address newAddress) public onlyAdmin { uint256 key = uint256(ConfigOptions.Addresses.TranchedPoolImplementation); emit AddressUpdated(msg.sender, key, addresses[key], newAddress); addresses[key] = newAddress; } function setBorrowerImplementation(address newAddress) public onlyAdmin { uint256 key = uint256(ConfigOptions.Addresses.BorrowerImplementation); emit AddressUpdated(msg.sender, key, addresses[key], newAddress); addresses[key] = newAddress; } function setGoldfinchConfig(address newAddress) public onlyAdmin { uint256 key = uint256(ConfigOptions.Addresses.GoldfinchConfig); emit AddressUpdated(msg.sender, key, addresses[key], newAddress); addresses[key] = newAddress; } function setMonthlyScheduleRepo(address newAddress) public onlyAdmin { uint256 key = uint256(ConfigOptions.Addresses.MonthlyScheduleRepo); emit AddressUpdated(msg.sender, key, addresses[key], newAddress); addresses[key] = newAddress; } function initializeFromOtherConfig( address _initialConfig, uint256 numbersLength, uint256 addressesLength ) public onlyAdmin { require(!valuesInitialized, "Already initialized values"); IGoldfinchConfig initialConfig = IGoldfinchConfig(_initialConfig); for (uint256 i = 0; i < numbersLength; i++) { setNumber(i, initialConfig.getNumber(i)); } for (uint256 i = 0; i < addressesLength; i++) { if (getAddress(i) == address(0)) { setAddress(i, initialConfig.getAddress(i)); } } valuesInitialized = true; } /// @inheritdoc IGoldfinchConfig function addToGoList(address _member) public override onlyGoListerRole { goList[_member] = true; emit GoListed(_member); } /// @inheritdoc IGoldfinchConfig function removeFromGoList(address _member) public override onlyGoListerRole { goList[_member] = false; emit NoListed(_member); } /// @inheritdoc IGoldfinchConfig function bulkAddToGoList(address[] calldata _members) external override onlyGoListerRole { for (uint256 i = 0; i < _members.length; i++) { addToGoList(_members[i]); } } /// @inheritdoc IGoldfinchConfig function bulkRemoveFromGoList(address[] calldata _members) external override onlyGoListerRole { for (uint256 i = 0; i < _members.length; i++) { removeFromGoList(_members[i]); } } /// @inheritdoc IGoldfinchConfig function getAddress(uint256 index) public view override returns (address) { return addresses[index]; } function getNumber(uint256 index) public view override returns (uint256) { return numbers[index]; } modifier onlyGoListerRole() { require( hasRole(GO_LISTER_ROLE, _msgSender()), "Must have go-lister role to perform this action" ); _; } }
pragma solidity ^0.6.0; import "../Initializable.sol"; /* * @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. */ contract ContextUpgradeSafe is Initializable { // Empty internal constructor, to prevent people from mistakenly deploying // an instance of this contract, which should be used via inheritance. function __Context_init() internal initializer { __Context_init_unchained(); } function __Context_init_unchained() internal initializer { } 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; } uint256[50] private __gap; }
pragma solidity >=0.4.24 <0.7.0; /** * @title Initializable * * @dev Helper contract to support initializer functions. To use it, replace * the constructor with a function that has the `initializer` modifier. * WARNING: Unlike constructors, initializer functions must be manually * invoked. This applies both to deploying an Initializable contract, as well * as extending an Initializable contract via inheritance. * WARNING: When used with inheritance, manual care must be taken to not invoke * a parent initializer twice, or ensure that all initializers are idempotent, * because this is not dealt with automatically as with constructors. */ contract Initializable { /** * @dev Indicates that the contract has been initialized. */ bool private initialized; /** * @dev Indicates that the contract is in the process of being initialized. */ bool private initializing; /** * @dev Modifier to use in the initializer function of a contract. */ modifier initializer() { require(initializing || isConstructor() || !initialized, "Contract instance has already been initialized"); bool isTopLevelCall = !initializing; if (isTopLevelCall) { initializing = true; initialized = true; } _; if (isTopLevelCall) { initializing = false; } } /// @dev Returns true if and only if the function is running in the constructor function isConstructor() private view returns (bool) { // extcodesize checks the size of the code stored in an address, and // address returns the current address. Since the code is still not // deployed when running a constructor, any checks on its code size will // yield zero, making it an effective way to detect if a contract is // under construction or not. address self = address(this); uint256 cs; assembly { cs := extcodesize(self) } return cs == 0; } // Reserved storage space to allow for layout changes in the future. uint256[50] private ______gap; }
pragma solidity ^0.6.0; import "../utils/EnumerableSet.sol"; import "../utils/Address.sol"; import "../GSN/Context.sol"; import "../Initializable.sol"; /** * @dev Contract module that allows children to implement role-based access * control mechanisms. * * Roles are referred to by their `bytes32` identifier. These should be exposed * in the external API and be unique. The best way to achieve this is by * using `public constant` hash digests: * * ``` * bytes32 public constant MY_ROLE = keccak256("MY_ROLE"); * ``` * * Roles can be used to represent a set of permissions. To restrict access to a * function call, use {hasRole}: * * ``` * function foo() public { * require(hasRole(MY_ROLE, _msgSender())); * ... * } * ``` * * Roles can be granted and revoked dynamically via the {grantRole} and * {revokeRole} functions. Each role has an associated admin role, and only * accounts that have a role's admin role can call {grantRole} and {revokeRole}. * * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means * that only accounts with this role will be able to grant or revoke other * roles. More complex role relationships can be created by using * {_setRoleAdmin}. */ abstract contract AccessControlUpgradeSafe is Initializable, ContextUpgradeSafe { function __AccessControl_init() internal initializer { __Context_init_unchained(); __AccessControl_init_unchained(); } function __AccessControl_init_unchained() internal initializer { } using EnumerableSet for EnumerableSet.AddressSet; using Address for address; struct RoleData { EnumerableSet.AddressSet members; bytes32 adminRole; } mapping (bytes32 => RoleData) private _roles; bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00; /** * @dev Emitted when `account` is granted `role`. * * `sender` is the account that originated the contract call, an admin role * bearer except when using {_setupRole}. */ event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender); /** * @dev Emitted when `account` is revoked `role`. * * `sender` is the account that originated the contract call: * - if using `revokeRole`, it is the admin role bearer * - if using `renounceRole`, it is the role bearer (i.e. `account`) */ event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender); /** * @dev Returns `true` if `account` has been granted `role`. */ function hasRole(bytes32 role, address account) public view returns (bool) { return _roles[role].members.contains(account); } /** * @dev Returns the number of accounts that have `role`. Can be used * together with {getRoleMember} to enumerate all bearers of a role. */ function getRoleMemberCount(bytes32 role) public view returns (uint256) { return _roles[role].members.length(); } /** * @dev Returns one of the accounts that have `role`. `index` must be a * value between 0 and {getRoleMemberCount}, non-inclusive. * * Role bearers are not sorted in any particular way, and their ordering may * change at any point. * * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure * you perform all queries on the same block. See the following * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post] * for more information. */ function getRoleMember(bytes32 role, uint256 index) public view returns (address) { return _roles[role].members.at(index); } /** * @dev Returns the admin role that controls `role`. See {grantRole} and * {revokeRole}. * * To change a role's admin, use {_setRoleAdmin}. */ function getRoleAdmin(bytes32 role) public view returns (bytes32) { return _roles[role].adminRole; } /** * @dev Grants `role` to `account`. * * If `account` had not been already granted `role`, emits a {RoleGranted} * event. * * Requirements: * * - the caller must have ``role``'s admin role. */ function grantRole(bytes32 role, address account) public virtual { require(hasRole(_roles[role].adminRole, _msgSender()), "AccessControl: sender must be an admin to grant"); _grantRole(role, account); } /** * @dev Revokes `role` from `account`. * * If `account` had been granted `role`, emits a {RoleRevoked} event. * * Requirements: * * - the caller must have ``role``'s admin role. */ function revokeRole(bytes32 role, address account) public virtual { require(hasRole(_roles[role].adminRole, _msgSender()), "AccessControl: sender must be an admin to revoke"); _revokeRole(role, account); } /** * @dev Revokes `role` from the calling account. * * Roles are often managed via {grantRole} and {revokeRole}: this function's * purpose is to provide a mechanism for accounts to lose their privileges * if they are compromised (such as when a trusted device is misplaced). * * If the calling account had been granted `role`, emits a {RoleRevoked} * event. * * Requirements: * * - the caller must be `account`. */ function renounceRole(bytes32 role, address account) public virtual { require(account == _msgSender(), "AccessControl: can only renounce roles for self"); _revokeRole(role, account); } /** * @dev Grants `role` to `account`. * * If `account` had not been already granted `role`, emits a {RoleGranted} * event. Note that unlike {grantRole}, this function doesn't perform any * checks on the calling account. * * [WARNING] * ==== * This function should only be called from the constructor when setting * up the initial roles for the system. * * Using this function in any other way is effectively circumventing the admin * system imposed by {AccessControl}. * ==== */ function _setupRole(bytes32 role, address account) internal virtual { _grantRole(role, account); } /** * @dev Sets `adminRole` as ``role``'s admin role. */ function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual { _roles[role].adminRole = adminRole; } function _grantRole(bytes32 role, address account) private { if (_roles[role].members.add(account)) { emit RoleGranted(role, account, _msgSender()); } } function _revokeRole(bytes32 role, address account) private { if (_roles[role].members.remove(account)) { emit RoleRevoked(role, account, _msgSender()); } } uint256[49] private __gap; }
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) { // Solidity only automatically asserts when dividing by 0 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; } }
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"); } }
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)); } }
pragma solidity ^0.6.0; import "../GSN/Context.sol"; import "../Initializable.sol"; /** * @dev Contract module which allows children to implement an emergency stop * mechanism that can be triggered by an authorized account. * * This module is used through inheritance. It will make available the * modifiers `whenNotPaused` and `whenPaused`, which can be applied to * the functions of your contract. Note that they will not be pausable by * simply including this module, only once the modifiers are put in place. */ contract PausableUpgradeSafe is Initializable, ContextUpgradeSafe { /** * @dev Emitted when the pause is triggered by `account`. */ event Paused(address account); /** * @dev Emitted when the pause is lifted by `account`. */ event Unpaused(address account); bool private _paused; /** * @dev Initializes the contract in unpaused state. */ function __Pausable_init() internal initializer { __Context_init_unchained(); __Pausable_init_unchained(); } function __Pausable_init_unchained() internal initializer { _paused = false; } /** * @dev Returns true if the contract is paused, and false otherwise. */ function paused() public view returns (bool) { return _paused; } /** * @dev Modifier to make a function callable only when the contract is not paused. */ modifier whenNotPaused() { require(!_paused, "Pausable: paused"); _; } /** * @dev Modifier to make a function callable only when the contract is paused. */ modifier whenPaused() { require(_paused, "Pausable: not paused"); _; } /** * @dev Triggers stopped state. */ function _pause() internal virtual whenNotPaused { _paused = true; emit Paused(_msgSender()); } /** * @dev Returns to normal state. */ function _unpause() internal virtual whenPaused { _paused = false; emit Unpaused(_msgSender()); } uint256[49] private __gap; }
pragma solidity ^0.6.0; import "../Initializable.sol"; /** * @dev Contract module that helps prevent reentrant calls to a function. * * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier * available, which can be applied to functions to make sure there are no nested * (reentrant) calls to them. * * Note that because there is a single `nonReentrant` guard, functions marked as * `nonReentrant` may not call one another. This can be worked around by making * those functions `private`, and then adding `external` `nonReentrant` entry * points to them. * * TIP: If you would like to learn more about reentrancy and alternative ways * to protect against it, check out our blog post * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul]. */ contract ReentrancyGuardUpgradeSafe is Initializable { bool private _notEntered; function __ReentrancyGuard_init() internal initializer { __ReentrancyGuard_init_unchained(); } function __ReentrancyGuard_init_unchained() internal initializer { // Storing an initial non-zero value makes deployment a bit more // expensive, but in exchange the refund on every call to nonReentrant // will be lower in amount. Since refunds are capped to a percetange of // the total transaction's gas, it is best to keep them low in cases // like this one, to increase the likelihood of the full refund coming // into effect. _notEntered = true; } /** * @dev Prevents a contract from calling itself, directly or indirectly. * Calling a `nonReentrant` function from another `nonReentrant` * function is not supported. It is possible to prevent this from happening * by making the `nonReentrant` function external, and make it call a * `private` function that does the actual work. */ modifier nonReentrant() { // On the first call to nonReentrant, _notEntered will be true require(_notEntered, "ReentrancyGuard: reentrant call"); // Any calls to nonReentrant after this point will fail _notEntered = false; _; // By storing the original value once again, a refund is triggered (see // https://eips.ethereum.org/EIPS/eip-2200) _notEntered = true; } uint256[49] private __gap; }
// SPDX-License-Identifier: MIT pragma solidity >=0.6.12; pragma experimental ABIEncoderV2; interface IGoldfinchConfig { /** * @dev Adds a user to go-list * @param _member address to add to go-list */ function addToGoList(address _member) external; /** * @dev removes a user from go-list * @param _member address to remove from go-list */ function removeFromGoList(address _member) external; /** * @dev adds many users to go-list at once * @param _members addresses to ad to go-list */ function bulkAddToGoList(address[] calldata _members) external; /** * @dev removes many users from go-list at once * @param _members addresses to remove from go-list */ function bulkRemoveFromGoList(address[] calldata _members) external; function getNumber(uint256 index) external view returns (uint256); /* Using custom getters in case we want to change underlying implementation later, or add checks or validations later on. */ function getAddress(uint256 index) external view returns (address); function setAddress(uint256 index, address newAddress) external; function setNumber(uint256 index, uint256 newNumber) external; }
pragma solidity >=0.6.12; // NOTE: this file exists only to remove the extremely long error messages in safe math. import {SafeMath as OzSafeMath} from "@openzeppelin/contracts-ethereum-package/contracts/math/SafeMath.sol"; /** * @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); 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 OzSafeMath.sub(a, b, ""); } /** * @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) { return OzSafeMath.sub(a, b, errorMessage); } /// @notice Do a - b. If that would result in overflow then return 0 function saturatingSub(uint256 a, uint256 b) internal pure returns (uint256) { return b > a ? 0 : a - b; } 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); 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 OzSafeMath.div(a, b, ""); } /** * @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) { return OzSafeMath.div(a, b, errorMessage); } /** * @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 OzSafeMath.mod(a, b, ""); } function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { return OzSafeMath.mod(a, b, errorMessage); } }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; pragma experimental ABIEncoderV2; import {AccessControlUpgradeSafe} from "@openzeppelin/contracts-ethereum-package/contracts/access/AccessControl.sol"; import {ReentrancyGuardUpgradeSafe} from "@openzeppelin/contracts-ethereum-package/contracts/utils/ReentrancyGuard.sol"; import {Initializable} from "@openzeppelin/contracts-ethereum-package/contracts/Initializable.sol"; import {SafeMath} from "../../library/SafeMath.sol"; import {PauserPausable} from "./PauserPausable.sol"; /** * @title BaseUpgradeablePausable contract * @notice This is our Base contract that most other contracts inherit from. It includes many standard * useful abilities like upgradeability, pausability, access control, and re-entrancy guards. * @author Goldfinch */ contract BaseUpgradeablePausable is Initializable, AccessControlUpgradeSafe, PauserPausable, ReentrancyGuardUpgradeSafe { bytes32 public constant OWNER_ROLE = keccak256("OWNER_ROLE"); using SafeMath for uint256; // Pre-reserving a few slots in the base contract in case we need to add things in the future. // This does not actually take up gas cost or storage cost, but it does reserve the storage slots. // See OpenZeppelin's use of this pattern here: // https://github.com/OpenZeppelin/openzeppelin-contracts-ethereum-package/blob/master/contracts/GSN/Context.sol#L37 uint256[50] private __gap1; uint256[50] private __gap2; uint256[50] private __gap3; uint256[50] private __gap4; // solhint-disable-next-line func-name-mixedcase function __BaseUpgradeablePausable__init(address owner) public initializer { require(owner != address(0), "Owner cannot be the zero address"); __AccessControl_init_unchained(); __Pausable_init_unchained(); __ReentrancyGuard_init_unchained(); _setupRole(OWNER_ROLE, owner); _setupRole(PAUSER_ROLE, owner); _setRoleAdmin(PAUSER_ROLE, OWNER_ROLE); _setRoleAdmin(OWNER_ROLE, OWNER_ROLE); } function isAdmin() public view returns (bool) { return hasRole(OWNER_ROLE, _msgSender()); } modifier onlyAdmin() { require(isAdmin(), "Must have admin role to perform this action"); _; } }
// SPDX-License-Identifier: MIT pragma solidity >=0.6.12; pragma experimental ABIEncoderV2; /** * @title ConfigOptions * @notice A central place for enumerating the configurable options of our GoldfinchConfig contract * @author Goldfinch */ library ConfigOptions { // NEVER EVER CHANGE THE ORDER OF THESE! // You can rename or append. But NEVER change the order. enum Numbers { TransactionLimit, /// @dev: TotalFundsLimit used to represent a total cap on senior pool deposits /// but is now deprecated TotalFundsLimit, MaxUnderwriterLimit, ReserveDenominator, WithdrawFeeDenominator, LatenessGracePeriodInDays, LatenessMaxDays, DrawdownPeriodInSeconds, TransferRestrictionPeriodInDays, LeverageRatio, /// A number in the range [0, 10000] representing basis points of FIDU taken as a fee /// when a withdrawal request is canceled. SeniorPoolWithdrawalCancelationFeeInBps } /// @dev TrustedForwarder is deprecated because we no longer use GSN. CreditDesk /// and Pool are deprecated because they are no longer used in the protocol. enum Addresses { Pool, // deprecated CreditLineImplementation, GoldfinchFactory, CreditDesk, // deprecated Fidu, USDC, TreasuryReserve, ProtocolAdmin, OneInch, TrustedForwarder, // deprecated CUSDCContract, GoldfinchConfig, PoolTokens, TranchedPoolImplementation, // deprecated SeniorPool, SeniorPoolStrategy, MigratedTranchedPoolImplementation, BorrowerImplementation, GFI, Go, BackerRewards, StakingRewards, FiduUSDCCurveLP, TranchedPoolImplementationRepository, WithdrawalRequestToken, MonthlyScheduleRepo, CallableLoanImplementationRepository } }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; pragma experimental ABIEncoderV2; import "@openzeppelin/contracts-ethereum-package/contracts/utils/Pausable.sol"; import "@openzeppelin/contracts-ethereum-package/contracts/access/AccessControl.sol"; /** * @title PauserPausable * @notice Inheriting from OpenZeppelin's Pausable contract, this does small * augmentations to make it work with a PAUSER_ROLE, leveraging the AccessControl contract. * It is meant to be inherited. * @author Goldfinch */ contract PauserPausable is AccessControlUpgradeSafe, PausableUpgradeSafe { bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE"); // solhint-disable-next-line func-name-mixedcase function __PauserPausable__init() public initializer { __Pausable_init_unchained(); } /** * @dev Pauses all functions guarded by Pause * * See {Pausable-_pause}. * * Requirements: * * - the caller must have the PAUSER_ROLE. */ function pause() public onlyPauserRole { _pause(); } /** * @dev Unpauses the contract * * See {Pausable-_unpause}. * * Requirements: * * - the caller must have the Pauser role */ function unpause() public onlyPauserRole { _unpause(); } modifier onlyPauserRole() { /// @dev NA: not authorized require(hasRole(PAUSER_ROLE, _msgSender()), "NA"); _; } }
{ "evmVersion": "istanbul", "libraries": {}, "metadata": { "bytecodeHash": "ipfs", "useLiteralContent": true }, "optimizer": { "enabled": true, "runs": 100 }, "remappings": [], "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"owner","type":"address"},{"indexed":false,"internalType":"uint256","name":"index","type":"uint256"},{"indexed":false,"internalType":"address","name":"oldValue","type":"address"},{"indexed":false,"internalType":"address","name":"newValue","type":"address"}],"name":"AddressUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"member","type":"address"}],"name":"GoListed","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"member","type":"address"}],"name":"NoListed","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"owner","type":"address"},{"indexed":false,"internalType":"uint256","name":"index","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"oldValue","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"newValue","type":"uint256"}],"name":"NumberUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleGranted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleRevoked","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"inputs":[],"name":"DEFAULT_ADMIN_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"GO_LISTER_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"OWNER_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PAUSER_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"__BaseUpgradeablePausable__init","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"__PauserPausable__init","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_member","type":"address"}],"name":"addToGoList","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"addresses","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"_members","type":"address[]"}],"name":"bulkAddToGoList","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"_members","type":"address[]"}],"name":"bulkRemoveFromGoList","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"getAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"getNumber","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"}],"name":"getRoleAdmin","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"uint256","name":"index","type":"uint256"}],"name":"getRoleMember","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"}],"name":"getRoleMemberCount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"goList","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"grantRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"hasRole","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"initialize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_initialConfig","type":"address"},{"internalType":"uint256","name":"numbersLength","type":"uint256"},{"internalType":"uint256","name":"addressesLength","type":"uint256"}],"name":"initializeFromOtherConfig","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"isAdmin","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"numbers","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_member","type":"address"}],"name":"removeFromGoList","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"renounceRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"revokeRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"addressIndex","type":"uint256"},{"internalType":"address","name":"newAddress","type":"address"}],"name":"setAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newAddress","type":"address"}],"name":"setBorrowerImplementation","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newAddress","type":"address"}],"name":"setCreditLineImplementation","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newAddress","type":"address"}],"name":"setGoldfinchConfig","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newAddress","type":"address"}],"name":"setMonthlyScheduleRepo","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"index","type":"uint256"},{"internalType":"uint256","name":"newNumber","type":"uint256"}],"name":"setNumber","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newStrategy","type":"address"}],"name":"setSeniorPoolStrategy","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newAddress","type":"address"}],"name":"setTranchedPoolImplementation","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newTreasuryReserve","type":"address"}],"name":"setTreasuryReserve","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unpause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"valuesInitialized","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"}]
Contract Creation Code
608060405234801561001057600080fd5b50611b8b806100206000396000f3fe608060405234801561001057600080fd5b50600436106102125760003560e01c8063a217fddf11610120578063d39fa233116100b8578063e861e9561161007c578063e861e9561461044e578063edf26d9b14610461578063f6b205e514610474578063fc56365814610487578063fdf4a2ea1461049a57610212565b8063d39fa23314610405578063d547741f14610418578063d9abc9f41461042b578063e58378bb1461043e578063e63ab1e91461044657610212565b8063a217fddf1461037b578063ac4ce2c614610383578063ad5a35e314610396578063b6db75a0146103a9578063b93f9b0a146103b1578063bc9d1764146103c4578063c4d66de8146103d7578063ca15c873146103ea578063d2133c8f146103fd57610212565b806357337adb116101ae5780636b19e8c7116101725780636b19e8c71461031a57806377134cdf1461032d5780638456cb59146103405780639010d07c1461034857806391d148541461036857610212565b806357337adb146102c45780635b51277b146102d75780635c949057146102df5780635c975abb146102f25780635f7c0e5d1461030757610212565b8063097616a314610217578063178a99ae1461022c5780631e7213cf1461023f578063248a9ca314610252578063249e25431461027b5780632f2ff15d1461028e57806336568abe146102a15780633f4ba83a146102b4578063526d81f6146102bc575b600080fd5b61022a610225366004611592565b6104ad565b005b61022a61023a366004611605565b6105e6565b61022a61024d366004611592565b610658565b610265610260366004611674565b61070a565b6040516102729190611764565b60405180910390f35b61022a6102893660046115d1565b61071f565b61022a61029c36600461168c565b6108be565b61022a6102af36600461168c565b610902565b61022a610944565b61022a610984565b61022a6102d2366004611592565b610a0f565b610265610a3c565b61022a6102ed366004611592565b610a4e565b6102fa610ace565b6040516102729190611759565b61022a610315366004611592565b610ad7565b61022a6103283660046116bb565b610b5a565b61022a61033b366004611605565b610bde565b61022a610c4b565b61035b6103563660046116bb565b610c89565b60405161027291906116f4565b6102fa61037636600461168c565b610caa565b610265610cc2565b61022a61039136600461168c565b610cc7565b6102fa6103a4366004611592565b610da9565b6102fa610dbf565b61035b6103bf366004611674565b610de0565b61022a6103d2366004611592565b610dfc565b61022a6103e5366004611592565b610e29565b6102656103f8366004611674565b610f04565b6102fa610f1b565b610265610413366004611674565b610f25565b61022a61042636600461168c565b610f38565b61022a610439366004611592565b610f72565b610265610f9f565b610265610fb1565b61022a61045c366004611592565b610fc3565b61035b61046f366004611674565b610ff0565b61022a610482366004611592565b61100c565b610265610495366004611674565b611039565b61022a6104a8366004611592565b61104c565b600054610100900460ff16806104c657506104c6611079565b806104d4575060005460ff16155b6104f95760405162461bcd60e51b81526004016104f090611998565b60405180910390fd5b600054610100900460ff16158015610524576000805460ff1961ff0019909116610100171660011790555b6001600160a01b03821661054a5760405162461bcd60e51b81526004016104f0906118dd565b61055261107f565b61055a611100565b61056261118c565b61057a600080516020611af6833981519152836108f8565b610592600080516020611b16833981519152836108f8565b6105b8600080516020611b16833981519152600080516020611af683398151915261121b565b6105d0600080516020611af68339815191528061121b565b80156105e2576000805461ff00191690555b5050565b610600600080516020611b36833981519152610376611230565b61061c5760405162461bcd60e51b81526004016104f090611949565b60005b818110156106535761064b83838381811061063657fe5b90506020020160208101906103159190611592565b60010161061f565b505050565b610660610dbf565b61067c5760405162461bcd60e51b81526004016104f090611a46565b600060015b60008181526101c36020526040908190205490519192507faebfad0d8db62d5b2e540f64d7c2be34ded04171b48ed6655286c392a879bf6c916106d391339185916001600160a01b0316908790611708565b60405180910390a160009081526101c36020526040902080546001600160a01b0319166001600160a01b0392909216919091179055565b60009081526065602052604090206002015490565b610727610dbf565b6107435760405162461bcd60e51b81526004016104f090611a46565b6101c65460ff16156107675760405162461bcd60e51b81526004016104f090611912565b8260005b838110156107fb576107f381836001600160a01b031663fc563658846040518263ffffffff1660e01b81526004016107a39190611764565b60206040518083038186803b1580156107bb57600080fd5b505afa1580156107cf573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061032891906116dc565b60010161076b565b5060005b828110156108a957600061081282610de0565b6001600160a01b031614156108a1576108a181836001600160a01b031663b93f9b0a846040518263ffffffff1660e01b81526004016108519190611764565b60206040518083038186803b15801561086957600080fd5b505afa15801561087d573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061039191906115b5565b6001016107ff565b50506101c6805460ff19166001179055505050565b6000828152606560205260409020600201546108dc90610376611230565b6108f85760405162461bcd60e51b81526004016104f0906117af565b6105e28282611234565b61090a611230565b6001600160a01b0316816001600160a01b03161461093a5760405162461bcd60e51b81526004016104f090611a91565b6105e2828261129d565b61095e600080516020611b16833981519152610376611230565b61097a5760405162461bcd60e51b81526004016104f0906119e6565b610982611306565b565b600054610100900460ff168061099d575061099d611079565b806109ab575060005460ff16155b6109c75760405162461bcd60e51b81526004016104f090611998565b600054610100900460ff161580156109f2576000805460ff1961ff0019909116610100171660011790555b6109fa611100565b8015610a0c576000805461ff00191690555b50565b610a17610dbf565b610a335760405162461bcd60e51b81526004016104f090611a46565b60006006610681565b600080516020611b3683398151915281565b610a68600080516020611b36833981519152610376611230565b610a845760405162461bcd60e51b81526004016104f090611949565b6001600160a01b03811660008181526101c56020526040808220805460ff19169055517f8975df3325e4d0a8fdefaff900160c197e34acf82b6db814c02509bdf218cf609190a250565b60975460ff1690565b610af1600080516020611b36833981519152610376611230565b610b0d5760405162461bcd60e51b81526004016104f090611949565b6001600160a01b03811660008181526101c56020526040808220805460ff19166001179055517f6ea07fa01118ee7113c6c1f1cfc6778df228949052175f938d8154739d5e897c9190a250565b610b62610dbf565b610b7e5760405162461bcd60e51b81526004016104f090611a46565b60008281526101c46020526040908190205490517f6b54a1d7321bc1699c15f7f585030864b02ca971590f31de4acbb60eff0758c091610bc391339186918690611733565b60405180910390a160009182526101c4602052604090912055565b610bf8600080516020611b36833981519152610376611230565b610c145760405162461bcd60e51b81526004016104f090611949565b60005b8181101561065357610c43838383818110610c2e57fe5b90506020020160208101906102ed9190611592565b600101610c17565b610c65600080516020611b16833981519152610376611230565b610c815760405162461bcd60e51b81526004016104f0906119e6565b610982611372565b6000828152606560205260408120610ca190836113cb565b90505b92915050565b6000828152606560205260408120610ca190836113d7565b600081565b610ccf610dbf565b610ceb5760405162461bcd60e51b81526004016104f090611a46565b60008281526101c360205260409020546001600160a01b031615610d215760405162461bcd60e51b81526004016104f090611a02565b60008281526101c36020526040908190205490517faebfad0d8db62d5b2e540f64d7c2be34ded04171b48ed6655286c392a879bf6c91610d7291339186916001600160a01b03909116908690611708565b60405180910390a160009182526101c3602052604090912080546001600160a01b0319166001600160a01b03909216919091179055565b6101c56020526000908152604090205460ff1681565b6000610ddb600080516020611af6833981519152610376611230565b905090565b60009081526101c360205260409020546001600160a01b031690565b610e04610dbf565b610e205760405162461bcd60e51b81526004016104f090611a46565b6000600b610681565b600054610100900460ff1680610e425750610e42611079565b80610e50575060005460ff16155b610e6c5760405162461bcd60e51b81526004016104f090611998565b600054610100900460ff16158015610e97576000805460ff1961ff0019909116610100171660011790555b6001600160a01b038216610ebd5760405162461bcd60e51b81526004016104f09061182c565b610ec6826104ad565b610ede600080516020611b36833981519152836108f8565b6105d0600080516020611b36833981519152600080516020611af683398151915261121b565b6000818152606560205260408120610ca4906113ec565b6101c65460ff1681565b6101c46020526000908152604090205481565b600082815260656020526040902060020154610f5690610376611230565b61093a5760405162461bcd60e51b81526004016104f090611863565b610f7a610dbf565b610f965760405162461bcd60e51b81526004016104f090611a46565b60006019610681565b600080516020611af683398151915281565b600080516020611b1683398151915281565b610fcb610dbf565b610fe75760405162461bcd60e51b81526004016104f090611a46565b60006011610681565b6101c3602052600090815260409020546001600160a01b031681565b611014610dbf565b6110305760405162461bcd60e51b81526004016104f090611a46565b6000600f610681565b60009081526101c4602052604090205490565b611054610dbf565b6110705760405162461bcd60e51b81526004016104f090611a46565b6000600d610681565b303b1590565b600054610100900460ff16806110985750611098611079565b806110a6575060005460ff16155b6110c25760405162461bcd60e51b81526004016104f090611998565b600054610100900460ff161580156109fa576000805460ff1961ff0019909116610100171660011790558015610a0c576000805461ff001916905550565b600054610100900460ff16806111195750611119611079565b80611127575060005460ff16155b6111435760405162461bcd60e51b81526004016104f090611998565b600054610100900460ff1615801561116e576000805460ff1961ff0019909116610100171660011790555b6097805460ff191690558015610a0c576000805461ff001916905550565b600054610100900460ff16806111a557506111a5611079565b806111b3575060005460ff16155b6111cf5760405162461bcd60e51b81526004016104f090611998565b600054610100900460ff161580156111fa576000805460ff1961ff0019909116610100171660011790555b60c9805460ff191660011790558015610a0c576000805461ff001916905550565b60009182526065602052604090912060020155565b3390565b600082815260656020526040902061124c90826113f7565b156105e257611259611230565b6001600160a01b0316816001600160a01b0316837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45050565b60008281526065602052604090206112b5908261140c565b156105e2576112c2611230565b6001600160a01b0316816001600160a01b0316837ff6391f5c32d9c69d2a47ea670b442974b53935d1edc7fd64eb21e047a839171b60405160405180910390a45050565b60975460ff166113285760405162461bcd60e51b81526004016104f0906117fe565b6097805460ff191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa61135b611230565b60405161136891906116f4565b60405180910390a1565b60975460ff16156113955760405162461bcd60e51b81526004016104f0906118b3565b6097805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a25861135b611230565b6000610ca18383611421565b6000610ca1836001600160a01b038416611466565b6000610ca48261147e565b6000610ca1836001600160a01b038416611482565b6000610ca1836001600160a01b0384166114cc565b815460009082106114445760405162461bcd60e51b81526004016104f09061176d565b82600001828154811061145357fe5b9060005260206000200154905092915050565b60009081526001919091016020526040902054151590565b5490565b600061148e8383611466565b6114c457508154600181810184556000848152602080822090930184905584548482528286019093526040902091909155610ca4565b506000610ca4565b6000818152600183016020526040812054801561158857835460001980830191908101906000908790839081106114ff57fe5b906000526020600020015490508087600001848154811061151c57fe5b60009182526020808320909101929092558281526001898101909252604090209084019055865487908061154c57fe5b60019003818190600052602060002001600090559055866001016000878152602001908152602001600020600090556001945050505050610ca4565b6000915050610ca4565b6000602082840312156115a3578081fd5b81356115ae81611ae0565b9392505050565b6000602082840312156115c6578081fd5b81516115ae81611ae0565b6000806000606084860312156115e5578182fd5b83356115f081611ae0565b95602085013595506040909401359392505050565b60008060208385031215611617578182fd5b823567ffffffffffffffff8082111561162e578384fd5b818501915085601f830112611641578384fd5b81358181111561164f578485fd5b8660208083028501011115611662578485fd5b60209290920196919550909350505050565b600060208284031215611685578081fd5b5035919050565b6000806040838503121561169e578182fd5b8235915060208301356116b081611ae0565b809150509250929050565b600080604083850312156116cd578182fd5b50508035926020909101359150565b6000602082840312156116ed578081fd5b5051919050565b6001600160a01b0391909116815260200190565b6001600160a01b03948516815260208101939093529083166040830152909116606082015260800190565b6001600160a01b0394909416845260208401929092526040830152606082015260800190565b901515815260200190565b90815260200190565b60208082526022908201527f456e756d657261626c655365743a20696e646578206f7574206f6620626f756e604082015261647360f01b606082015260800190565b6020808252602f908201527f416363657373436f6e74726f6c3a2073656e646572206d75737420626520616e60408201526e0818591b5a5b881d1bc819dc985b9d608a1b606082015260800190565b60208082526014908201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b604082015260600190565b6020808252601d908201527f4f776e657220616464726573732063616e6e6f7420626520656d707479000000604082015260600190565b60208082526030908201527f416363657373436f6e74726f6c3a2073656e646572206d75737420626520616e60408201526f2061646d696e20746f207265766f6b6560801b606082015260800190565b60208082526010908201526f14185d5cd8589b194e881c185d5cd95960821b604082015260600190565b6020808252818101527f4f776e65722063616e6e6f7420626520746865207a65726f2061646472657373604082015260600190565b6020808252601a908201527f416c726561647920696e697469616c697a65642076616c756573000000000000604082015260600190565b6020808252602f908201527f4d757374206861766520676f2d6c697374657220726f6c6520746f207065726660408201526e37b936903a3434b99030b1ba34b7b760891b606082015260800190565b6020808252602e908201527f436f6e747261637420696e7374616e63652068617320616c726561647920626560408201526d195b881a5b9a5d1a585b1a5e995960921b606082015260800190565b6020808252600290820152614e4160f01b604082015260600190565b60208082526024908201527f416464726573732068617320616c7265616479206265656e20696e697469616c6040820152631a5e995960e21b606082015260800190565b6020808252602b908201527f4d75737420686176652061646d696e20726f6c6520746f20706572666f726d2060408201526a3a3434b99030b1ba34b7b760a91b606082015260800190565b6020808252602f908201527f416363657373436f6e74726f6c3a2063616e206f6e6c792072656e6f756e636560408201526e103937b632b9903337b91039b2b63360891b606082015260800190565b6001600160a01b0381168114610a0c57600080fdfeb19546dff01e856fb3f010c267a7b1c60363cf8a4664e21cc89c26224620214e65d7a28e3265b37a6474929f336521b332c1681b933f6cb9f3376673440d862a4261c544cc1a84a4828404bd710bd4900df04736488a0f1af6a07d8ba25ece98a26469706673582212203aeaa1f7f1480aa1b0d3acc03185e738c07437a860f2288a2f16b4bc1a15425f64736f6c634300060c0033
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106102125760003560e01c8063a217fddf11610120578063d39fa233116100b8578063e861e9561161007c578063e861e9561461044e578063edf26d9b14610461578063f6b205e514610474578063fc56365814610487578063fdf4a2ea1461049a57610212565b8063d39fa23314610405578063d547741f14610418578063d9abc9f41461042b578063e58378bb1461043e578063e63ab1e91461044657610212565b8063a217fddf1461037b578063ac4ce2c614610383578063ad5a35e314610396578063b6db75a0146103a9578063b93f9b0a146103b1578063bc9d1764146103c4578063c4d66de8146103d7578063ca15c873146103ea578063d2133c8f146103fd57610212565b806357337adb116101ae5780636b19e8c7116101725780636b19e8c71461031a57806377134cdf1461032d5780638456cb59146103405780639010d07c1461034857806391d148541461036857610212565b806357337adb146102c45780635b51277b146102d75780635c949057146102df5780635c975abb146102f25780635f7c0e5d1461030757610212565b8063097616a314610217578063178a99ae1461022c5780631e7213cf1461023f578063248a9ca314610252578063249e25431461027b5780632f2ff15d1461028e57806336568abe146102a15780633f4ba83a146102b4578063526d81f6146102bc575b600080fd5b61022a610225366004611592565b6104ad565b005b61022a61023a366004611605565b6105e6565b61022a61024d366004611592565b610658565b610265610260366004611674565b61070a565b6040516102729190611764565b60405180910390f35b61022a6102893660046115d1565b61071f565b61022a61029c36600461168c565b6108be565b61022a6102af36600461168c565b610902565b61022a610944565b61022a610984565b61022a6102d2366004611592565b610a0f565b610265610a3c565b61022a6102ed366004611592565b610a4e565b6102fa610ace565b6040516102729190611759565b61022a610315366004611592565b610ad7565b61022a6103283660046116bb565b610b5a565b61022a61033b366004611605565b610bde565b61022a610c4b565b61035b6103563660046116bb565b610c89565b60405161027291906116f4565b6102fa61037636600461168c565b610caa565b610265610cc2565b61022a61039136600461168c565b610cc7565b6102fa6103a4366004611592565b610da9565b6102fa610dbf565b61035b6103bf366004611674565b610de0565b61022a6103d2366004611592565b610dfc565b61022a6103e5366004611592565b610e29565b6102656103f8366004611674565b610f04565b6102fa610f1b565b610265610413366004611674565b610f25565b61022a61042636600461168c565b610f38565b61022a610439366004611592565b610f72565b610265610f9f565b610265610fb1565b61022a61045c366004611592565b610fc3565b61035b61046f366004611674565b610ff0565b61022a610482366004611592565b61100c565b610265610495366004611674565b611039565b61022a6104a8366004611592565b61104c565b600054610100900460ff16806104c657506104c6611079565b806104d4575060005460ff16155b6104f95760405162461bcd60e51b81526004016104f090611998565b60405180910390fd5b600054610100900460ff16158015610524576000805460ff1961ff0019909116610100171660011790555b6001600160a01b03821661054a5760405162461bcd60e51b81526004016104f0906118dd565b61055261107f565b61055a611100565b61056261118c565b61057a600080516020611af6833981519152836108f8565b610592600080516020611b16833981519152836108f8565b6105b8600080516020611b16833981519152600080516020611af683398151915261121b565b6105d0600080516020611af68339815191528061121b565b80156105e2576000805461ff00191690555b5050565b610600600080516020611b36833981519152610376611230565b61061c5760405162461bcd60e51b81526004016104f090611949565b60005b818110156106535761064b83838381811061063657fe5b90506020020160208101906103159190611592565b60010161061f565b505050565b610660610dbf565b61067c5760405162461bcd60e51b81526004016104f090611a46565b600060015b60008181526101c36020526040908190205490519192507faebfad0d8db62d5b2e540f64d7c2be34ded04171b48ed6655286c392a879bf6c916106d391339185916001600160a01b0316908790611708565b60405180910390a160009081526101c36020526040902080546001600160a01b0319166001600160a01b0392909216919091179055565b60009081526065602052604090206002015490565b610727610dbf565b6107435760405162461bcd60e51b81526004016104f090611a46565b6101c65460ff16156107675760405162461bcd60e51b81526004016104f090611912565b8260005b838110156107fb576107f381836001600160a01b031663fc563658846040518263ffffffff1660e01b81526004016107a39190611764565b60206040518083038186803b1580156107bb57600080fd5b505afa1580156107cf573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061032891906116dc565b60010161076b565b5060005b828110156108a957600061081282610de0565b6001600160a01b031614156108a1576108a181836001600160a01b031663b93f9b0a846040518263ffffffff1660e01b81526004016108519190611764565b60206040518083038186803b15801561086957600080fd5b505afa15801561087d573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061039191906115b5565b6001016107ff565b50506101c6805460ff19166001179055505050565b6000828152606560205260409020600201546108dc90610376611230565b6108f85760405162461bcd60e51b81526004016104f0906117af565b6105e28282611234565b61090a611230565b6001600160a01b0316816001600160a01b03161461093a5760405162461bcd60e51b81526004016104f090611a91565b6105e2828261129d565b61095e600080516020611b16833981519152610376611230565b61097a5760405162461bcd60e51b81526004016104f0906119e6565b610982611306565b565b600054610100900460ff168061099d575061099d611079565b806109ab575060005460ff16155b6109c75760405162461bcd60e51b81526004016104f090611998565b600054610100900460ff161580156109f2576000805460ff1961ff0019909116610100171660011790555b6109fa611100565b8015610a0c576000805461ff00191690555b50565b610a17610dbf565b610a335760405162461bcd60e51b81526004016104f090611a46565b60006006610681565b600080516020611b3683398151915281565b610a68600080516020611b36833981519152610376611230565b610a845760405162461bcd60e51b81526004016104f090611949565b6001600160a01b03811660008181526101c56020526040808220805460ff19169055517f8975df3325e4d0a8fdefaff900160c197e34acf82b6db814c02509bdf218cf609190a250565b60975460ff1690565b610af1600080516020611b36833981519152610376611230565b610b0d5760405162461bcd60e51b81526004016104f090611949565b6001600160a01b03811660008181526101c56020526040808220805460ff19166001179055517f6ea07fa01118ee7113c6c1f1cfc6778df228949052175f938d8154739d5e897c9190a250565b610b62610dbf565b610b7e5760405162461bcd60e51b81526004016104f090611a46565b60008281526101c46020526040908190205490517f6b54a1d7321bc1699c15f7f585030864b02ca971590f31de4acbb60eff0758c091610bc391339186918690611733565b60405180910390a160009182526101c4602052604090912055565b610bf8600080516020611b36833981519152610376611230565b610c145760405162461bcd60e51b81526004016104f090611949565b60005b8181101561065357610c43838383818110610c2e57fe5b90506020020160208101906102ed9190611592565b600101610c17565b610c65600080516020611b16833981519152610376611230565b610c815760405162461bcd60e51b81526004016104f0906119e6565b610982611372565b6000828152606560205260408120610ca190836113cb565b90505b92915050565b6000828152606560205260408120610ca190836113d7565b600081565b610ccf610dbf565b610ceb5760405162461bcd60e51b81526004016104f090611a46565b60008281526101c360205260409020546001600160a01b031615610d215760405162461bcd60e51b81526004016104f090611a02565b60008281526101c36020526040908190205490517faebfad0d8db62d5b2e540f64d7c2be34ded04171b48ed6655286c392a879bf6c91610d7291339186916001600160a01b03909116908690611708565b60405180910390a160009182526101c3602052604090912080546001600160a01b0319166001600160a01b03909216919091179055565b6101c56020526000908152604090205460ff1681565b6000610ddb600080516020611af6833981519152610376611230565b905090565b60009081526101c360205260409020546001600160a01b031690565b610e04610dbf565b610e205760405162461bcd60e51b81526004016104f090611a46565b6000600b610681565b600054610100900460ff1680610e425750610e42611079565b80610e50575060005460ff16155b610e6c5760405162461bcd60e51b81526004016104f090611998565b600054610100900460ff16158015610e97576000805460ff1961ff0019909116610100171660011790555b6001600160a01b038216610ebd5760405162461bcd60e51b81526004016104f09061182c565b610ec6826104ad565b610ede600080516020611b36833981519152836108f8565b6105d0600080516020611b36833981519152600080516020611af683398151915261121b565b6000818152606560205260408120610ca4906113ec565b6101c65460ff1681565b6101c46020526000908152604090205481565b600082815260656020526040902060020154610f5690610376611230565b61093a5760405162461bcd60e51b81526004016104f090611863565b610f7a610dbf565b610f965760405162461bcd60e51b81526004016104f090611a46565b60006019610681565b600080516020611af683398151915281565b600080516020611b1683398151915281565b610fcb610dbf565b610fe75760405162461bcd60e51b81526004016104f090611a46565b60006011610681565b6101c3602052600090815260409020546001600160a01b031681565b611014610dbf565b6110305760405162461bcd60e51b81526004016104f090611a46565b6000600f610681565b60009081526101c4602052604090205490565b611054610dbf565b6110705760405162461bcd60e51b81526004016104f090611a46565b6000600d610681565b303b1590565b600054610100900460ff16806110985750611098611079565b806110a6575060005460ff16155b6110c25760405162461bcd60e51b81526004016104f090611998565b600054610100900460ff161580156109fa576000805460ff1961ff0019909116610100171660011790558015610a0c576000805461ff001916905550565b600054610100900460ff16806111195750611119611079565b80611127575060005460ff16155b6111435760405162461bcd60e51b81526004016104f090611998565b600054610100900460ff1615801561116e576000805460ff1961ff0019909116610100171660011790555b6097805460ff191690558015610a0c576000805461ff001916905550565b600054610100900460ff16806111a557506111a5611079565b806111b3575060005460ff16155b6111cf5760405162461bcd60e51b81526004016104f090611998565b600054610100900460ff161580156111fa576000805460ff1961ff0019909116610100171660011790555b60c9805460ff191660011790558015610a0c576000805461ff001916905550565b60009182526065602052604090912060020155565b3390565b600082815260656020526040902061124c90826113f7565b156105e257611259611230565b6001600160a01b0316816001600160a01b0316837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45050565b60008281526065602052604090206112b5908261140c565b156105e2576112c2611230565b6001600160a01b0316816001600160a01b0316837ff6391f5c32d9c69d2a47ea670b442974b53935d1edc7fd64eb21e047a839171b60405160405180910390a45050565b60975460ff166113285760405162461bcd60e51b81526004016104f0906117fe565b6097805460ff191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa61135b611230565b60405161136891906116f4565b60405180910390a1565b60975460ff16156113955760405162461bcd60e51b81526004016104f0906118b3565b6097805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a25861135b611230565b6000610ca18383611421565b6000610ca1836001600160a01b038416611466565b6000610ca48261147e565b6000610ca1836001600160a01b038416611482565b6000610ca1836001600160a01b0384166114cc565b815460009082106114445760405162461bcd60e51b81526004016104f09061176d565b82600001828154811061145357fe5b9060005260206000200154905092915050565b60009081526001919091016020526040902054151590565b5490565b600061148e8383611466565b6114c457508154600181810184556000848152602080822090930184905584548482528286019093526040902091909155610ca4565b506000610ca4565b6000818152600183016020526040812054801561158857835460001980830191908101906000908790839081106114ff57fe5b906000526020600020015490508087600001848154811061151c57fe5b60009182526020808320909101929092558281526001898101909252604090209084019055865487908061154c57fe5b60019003818190600052602060002001600090559055866001016000878152602001908152602001600020600090556001945050505050610ca4565b6000915050610ca4565b6000602082840312156115a3578081fd5b81356115ae81611ae0565b9392505050565b6000602082840312156115c6578081fd5b81516115ae81611ae0565b6000806000606084860312156115e5578182fd5b83356115f081611ae0565b95602085013595506040909401359392505050565b60008060208385031215611617578182fd5b823567ffffffffffffffff8082111561162e578384fd5b818501915085601f830112611641578384fd5b81358181111561164f578485fd5b8660208083028501011115611662578485fd5b60209290920196919550909350505050565b600060208284031215611685578081fd5b5035919050565b6000806040838503121561169e578182fd5b8235915060208301356116b081611ae0565b809150509250929050565b600080604083850312156116cd578182fd5b50508035926020909101359150565b6000602082840312156116ed578081fd5b5051919050565b6001600160a01b0391909116815260200190565b6001600160a01b03948516815260208101939093529083166040830152909116606082015260800190565b6001600160a01b0394909416845260208401929092526040830152606082015260800190565b901515815260200190565b90815260200190565b60208082526022908201527f456e756d657261626c655365743a20696e646578206f7574206f6620626f756e604082015261647360f01b606082015260800190565b6020808252602f908201527f416363657373436f6e74726f6c3a2073656e646572206d75737420626520616e60408201526e0818591b5a5b881d1bc819dc985b9d608a1b606082015260800190565b60208082526014908201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b604082015260600190565b6020808252601d908201527f4f776e657220616464726573732063616e6e6f7420626520656d707479000000604082015260600190565b60208082526030908201527f416363657373436f6e74726f6c3a2073656e646572206d75737420626520616e60408201526f2061646d696e20746f207265766f6b6560801b606082015260800190565b60208082526010908201526f14185d5cd8589b194e881c185d5cd95960821b604082015260600190565b6020808252818101527f4f776e65722063616e6e6f7420626520746865207a65726f2061646472657373604082015260600190565b6020808252601a908201527f416c726561647920696e697469616c697a65642076616c756573000000000000604082015260600190565b6020808252602f908201527f4d757374206861766520676f2d6c697374657220726f6c6520746f207065726660408201526e37b936903a3434b99030b1ba34b7b760891b606082015260800190565b6020808252602e908201527f436f6e747261637420696e7374616e63652068617320616c726561647920626560408201526d195b881a5b9a5d1a585b1a5e995960921b606082015260800190565b6020808252600290820152614e4160f01b604082015260600190565b60208082526024908201527f416464726573732068617320616c7265616479206265656e20696e697469616c6040820152631a5e995960e21b606082015260800190565b6020808252602b908201527f4d75737420686176652061646d696e20726f6c6520746f20706572666f726d2060408201526a3a3434b99030b1ba34b7b760a91b606082015260800190565b6020808252602f908201527f416363657373436f6e74726f6c3a2063616e206f6e6c792072656e6f756e636560408201526e103937b632b9903337b91039b2b63360891b606082015260800190565b6001600160a01b0381168114610a0c57600080fdfeb19546dff01e856fb3f010c267a7b1c60363cf8a4664e21cc89c26224620214e65d7a28e3265b37a6474929f336521b332c1681b933f6cb9f3376673440d862a4261c544cc1a84a4828404bd710bd4900df04736488a0f1af6a07d8ba25ece98a26469706673582212203aeaa1f7f1480aa1b0d3acc03185e738c07437a860f2288a2f16b4bc1a15425f64736f6c634300060c0033
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 30 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
Loading...
Loading
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.