Overview
ETH Balance
0 ETH
Eth Value
$0.00More Info
Private Name Tags
ContractCreator
Latest 1 from a total of 1 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
0x60806040 | 18780883 | 216 days ago | IN | Create: AddressProvider | 0 ETH | 0.03269042 |
View more zero value Internal Transactions in Advanced View mode
Advanced mode:
Loading...
Loading
Contract Name:
AddressProvider
Compiler Version
v0.8.17+commit.8df45f5f
Optimization Enabled:
Yes with 200 runs
Other Settings:
default evmVersion
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: MIT pragma solidity 0.8.17; import {OwnableUpgradeable} from '@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.sol'; import {IAddressProvider} from '../interfaces/IAddressProvider.sol'; contract AddressProvider is OwnableUpgradeable, IAddressProvider { bytes32 private constant TREASURY = 'TREASURY'; bytes32 private constant SHEZMU = 'SHEZMU'; bytes32 private constant GUARDIAN = 'GUARDIAN'; bytes32 private constant PRICE_ORACLE_AGGREGATOR = 'PRICE_ORACLE_AGGREGATOR'; bytes32 private constant BOND = 'BOND'; /// @notice address storage mapping(bytes32 => address) private _addresses; bytes32 private constant OBELISK = 'OBELISK'; bytes32 private constant OPTION_SHEZMU = 'OPTION_SHEZMU'; bytes32 private constant FARMING = 'FARMING'; /* ======== ERRORS ======== */ error ZERO_ADDRESS(); /* ======== INITIALIZATION ======== */ /// @custom:oz-upgrades-unsafe-allow constructor constructor() { _disableInitializers(); } function initialize() external initializer { // init __Ownable_init(); } /* ======== POLICY FUNCTIONS ======== */ function setTreasury(address treasury) external onlyOwner { if (treasury == address(0)) revert ZERO_ADDRESS(); _addresses[TREASURY] = treasury; } function setShezmu(address shezmu) external onlyOwner { if (shezmu == address(0)) revert ZERO_ADDRESS(); _addresses[SHEZMU] = shezmu; } function setGuardian(address guardian) external onlyOwner { if (guardian == address(0)) revert ZERO_ADDRESS(); _addresses[GUARDIAN] = guardian; } function setPriceOracleAggregator( address priceOracleAggregator ) external onlyOwner { if (priceOracleAggregator == address(0)) revert ZERO_ADDRESS(); _addresses[PRICE_ORACLE_AGGREGATOR] = priceOracleAggregator; } function setBond(address bond) external onlyOwner { if (bond == address(0)) revert ZERO_ADDRESS(); _addresses[BOND] = bond; } function setObelisk(address obelisk) external onlyOwner { if (obelisk == address(0)) revert ZERO_ADDRESS(); _addresses[OBELISK] = obelisk; } function setOptionShezmu(address optionShezmu) external onlyOwner { if (optionShezmu == address(0)) revert ZERO_ADDRESS(); _addresses[OPTION_SHEZMU] = optionShezmu; } function setFarming(address farming) external onlyOwner { if (farming == address(0)) revert ZERO_ADDRESS(); _addresses[FARMING] = farming; } /* ======== VIEW FUNCTIONS ======== */ function getTreasury() external view returns (address) { return _addresses[TREASURY]; } function getShezmu() external view returns (address) { return _addresses[SHEZMU]; } function getGuardian() external view returns (address) { return _addresses[GUARDIAN]; } function getPriceOracleAggregator() external view returns (address) { return _addresses[PRICE_ORACLE_AGGREGATOR]; } function getBond() external view returns (address) { return _addresses[BOND]; } function getObelisk() external view returns (address) { return _addresses[OBELISK]; } function getOptionShezmu() external view returns (address) { return _addresses[OPTION_SHEZMU]; } function getFarming() external view returns (address) { return _addresses[FARMING]; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (access/Ownable.sol) pragma solidity ^0.8.0; import "../utils/ContextUpgradeable.sol"; import "../proxy/utils/Initializable.sol"; /** * @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. */ abstract contract OwnableUpgradeable is Initializable, ContextUpgradeable { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ function __Ownable_init() internal onlyInitializing { __Ownable_init_unchained(); } function __Ownable_init_unchained() internal onlyInitializing { _transferOwnership(_msgSender()); } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { _checkOwner(); _; } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if the sender is not the owner. */ function _checkOwner() internal view virtual { require(owner() == _msgSender(), "Ownable: caller is not the owner"); } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby disabling any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _transferOwnership(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"); _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Internal function without access restriction. */ function _transferOwnership(address newOwner) internal virtual { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } /** * @dev This empty reserved space is put in place to allow future versions to add new * variables without shifting down storage in the inheritance chain. * See https://docs.openzeppelin.com/contracts/4.x/upgradeable#storage_gaps */ uint256[49] private __gap; }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (proxy/utils/Initializable.sol) pragma solidity ^0.8.2; import "../../utils/AddressUpgradeable.sol"; /** * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect. * * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be * reused. This mechanism prevents re-execution of each "step" but allows the creation of new initialization steps in * case an upgrade adds a module that needs to be initialized. * * For example: * * [.hljs-theme-light.nopadding] * ```solidity * contract MyToken is ERC20Upgradeable { * function initialize() initializer public { * __ERC20_init("MyToken", "MTK"); * } * } * * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable { * function initializeV2() reinitializer(2) public { * __ERC20Permit_init("MyToken"); * } * } * ``` * * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}. * * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity. * * [CAUTION] * ==== * Avoid leaving a contract uninitialized. * * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed: * * [.hljs-theme-light.nopadding] * ``` * /// @custom:oz-upgrades-unsafe-allow constructor * constructor() { * _disableInitializers(); * } * ``` * ==== */ abstract contract Initializable { /** * @dev Indicates that the contract has been initialized. * @custom:oz-retyped-from bool */ uint8 private _initialized; /** * @dev Indicates that the contract is in the process of being initialized. */ bool private _initializing; /** * @dev Triggered when the contract has been initialized or reinitialized. */ event Initialized(uint8 version); /** * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope, * `onlyInitializing` functions can be used to initialize parent contracts. * * Similar to `reinitializer(1)`, except that functions marked with `initializer` can be nested in the context of a * constructor. * * Emits an {Initialized} event. */ modifier initializer() { bool isTopLevelCall = !_initializing; require( (isTopLevelCall && _initialized < 1) || (!AddressUpgradeable.isContract(address(this)) && _initialized == 1), "Initializable: contract is already initialized" ); _initialized = 1; if (isTopLevelCall) { _initializing = true; } _; if (isTopLevelCall) { _initializing = false; emit Initialized(1); } } /** * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be * used to initialize parent contracts. * * A reinitializer may be used after the original initialization step. This is essential to configure modules that * are added through upgrades and that require initialization. * * When `version` is 1, this modifier is similar to `initializer`, except that functions marked with `reinitializer` * cannot be nested. If one is invoked in the context of another, execution will revert. * * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in * a contract, executing them in the right order is up to the developer or operator. * * WARNING: setting the version to 255 will prevent any future reinitialization. * * Emits an {Initialized} event. */ modifier reinitializer(uint8 version) { require(!_initializing && _initialized < version, "Initializable: contract is already initialized"); _initialized = version; _initializing = true; _; _initializing = false; emit Initialized(version); } /** * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the * {initializer} and {reinitializer} modifiers, directly or indirectly. */ modifier onlyInitializing() { require(_initializing, "Initializable: contract is not initializing"); _; } /** * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call. * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized * to any version. It is recommended to use this to lock implementation contracts that are designed to be called * through proxies. * * Emits an {Initialized} event the first time it is successfully executed. */ function _disableInitializers() internal virtual { require(!_initializing, "Initializable: contract is initializing"); if (_initialized != type(uint8).max) { _initialized = type(uint8).max; emit Initialized(type(uint8).max); } } /** * @dev Returns the highest version that has been initialized. See {reinitializer}. */ function _getInitializedVersion() internal view returns (uint8) { return _initialized; } /** * @dev Returns `true` if the contract is currently initializing. See {onlyInitializing}. */ function _isInitializing() internal view returns (bool) { return _initializing; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.9.0) (utils/Address.sol) pragma solidity ^0.8.1; /** * @dev Collection of functions related to the address type */ library AddressUpgradeable { /** * @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 * * Furthermore, `isContract` will also return true if the target contract within * the same transaction is already scheduled for destruction by `SELFDESTRUCT`, * which only has an effect at the end of a transaction. * ==== * * [IMPORTANT] * ==== * You shouldn't rely on `isContract` to protect against flash loan attacks! * * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract * constructor. * ==== */ function isContract(address account) internal view returns (bool) { // This method relies on extcodesize/address.code.length, which returns 0 // for contracts in construction, since the code is only stored at the end // of the constructor execution. return account.code.length > 0; } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://consensys.net/diligence/blog/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.8.0/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Address: insufficient balance"); (bool success, ) = recipient.call{value: amount}(""); require(success, "Address: unable to send value, recipient may have reverted"); } /** * @dev Performs a Solidity function call using a low level `call`. A * plain `call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCallWithValue(target, data, 0, "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"); (bool success, bytes memory returndata) = target.call{value: value}(data); return verifyCallResultFromTarget(target, success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) { return functionStaticCall(target, data, "Address: low-level static call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall( address target, bytes memory data, string memory errorMessage ) internal view returns (bytes memory) { (bool success, bytes memory returndata) = target.staticcall(data); return verifyCallResultFromTarget(target, success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) { return functionDelegateCall(target, data, "Address: low-level delegate call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall( address target, bytes memory data, string memory errorMessage ) internal returns (bytes memory) { (bool success, bytes memory returndata) = target.delegatecall(data); return verifyCallResultFromTarget(target, success, returndata, errorMessage); } /** * @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling * the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract. * * _Available since v4.8._ */ function verifyCallResultFromTarget( address target, bool success, bytes memory returndata, string memory errorMessage ) internal view returns (bytes memory) { if (success) { if (returndata.length == 0) { // only check isContract if the call was successful and the return data is empty // otherwise we already know that it was a contract require(isContract(target), "Address: call to non-contract"); } return returndata; } else { _revert(returndata, errorMessage); } } /** * @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the * revert reason or using the provided one. * * _Available since v4.3._ */ function verifyCallResult( bool success, bytes memory returndata, string memory errorMessage ) internal pure returns (bytes memory) { if (success) { return returndata; } else { _revert(returndata, errorMessage); } } function _revert(bytes memory returndata, string memory errorMessage) private pure { // 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 /// @solidity memory-safe-assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/Context.sol) pragma solidity ^0.8.0; import "../proxy/utils/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 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 ContextUpgradeable is Initializable { function __Context_init() internal onlyInitializing { } function __Context_init_unchained() internal onlyInitializing { } function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } /** * @dev This empty reserved space is put in place to allow future versions to add new * variables without shifting down storage in the inheritance chain. * See https://docs.openzeppelin.com/contracts/4.x/upgradeable#storage_gaps */ uint256[50] private __gap; }
// SPDX-License-Identifier: MIT pragma solidity 0.8.17; interface IAddressProvider { function getTreasury() external view returns (address); function getShezmu() external view returns (address); function getGuardian() external view returns (address); function getPriceOracleAggregator() external view returns (address); function getBond() external view returns (address); function getObelisk() external view returns (address); function getOptionShezmu() external view returns (address); function getFarming() external view returns (address); }
{ "optimizer": { "enabled": true, "runs": 200 }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "metadata": { "useLiteralContent": true }, "libraries": {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"ZERO_ADDRESS","type":"error"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint8","name":"version","type":"uint8"}],"name":"Initialized","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"},{"inputs":[],"name":"getBond","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getFarming","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getGuardian","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getObelisk","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getOptionShezmu","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getPriceOracleAggregator","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getShezmu","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getTreasury","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"initialize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"bond","type":"address"}],"name":"setBond","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"farming","type":"address"}],"name":"setFarming","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"guardian","type":"address"}],"name":"setGuardian","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"obelisk","type":"address"}],"name":"setObelisk","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"optionShezmu","type":"address"}],"name":"setOptionShezmu","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"priceOracleAggregator","type":"address"}],"name":"setPriceOracleAggregator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"shezmu","type":"address"}],"name":"setShezmu","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"treasury","type":"address"}],"name":"setTreasury","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
608060405234801561001057600080fd5b5061001961001e565b6100dd565b600054610100900460ff161561008a5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff908116146100db576000805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b610bc6806100ec6000396000f3fe608060405234801561001057600080fd5b506004361061012c5760003560e01c8063a75b87d2116100ad578063de2ae16711610071578063de2ae167146103b5578063ef7063b0146103c8578063f0f442601461040a578063f2fde38b1461041d578063f3f9ebf31461043057600080fd5b8063a75b87d2146102c2578063ac98247214610306578063b4a6589c14610346578063c937cfa414610359578063d959fb2e146103a257600080fd5b8063715018a6116100f4578063715018a61461027b5780638129fc1c146102835780638a0dac4a1461028b5780638da5cb5b1461029e578063a124a640146102af57600080fd5b80632d729142146101315780632ea451be146101465780633b19e84a146101b157806345813eb0146101f557806369576d8914610238575b600080fd5b61014461013f366004610b15565b610443565b005b76282924a1a2afa7a920a1a622afa0a3a3a922a3a0aa27a960491b60005260656020527fe110409edc9a0b90e9d21aab5059d379cbdfd2a769ad5b408d5ae263a2569796546001600160a01b03165b6040516001600160a01b03909116815260200160405180910390f35b67545245415355525960c01b60005260656020527f273af53ceec744447a7738adbc443776ff6daf084d4d3ca9047b8232c65cc0da546001600160a01b0316610195565b664641524d494e4760c81b60005260656020527f3ac420333c7fa008764194937bf26a064cd1e73cefe43ca3e59e9f72b8faa2fd546001600160a01b0316610195565b664f42454c49534b60c81b60005260656020527f688a30b83ea6da8c04c45fecf52937319f015b25d5dbd85409ae70da32dbf97c546001600160a01b0316610195565b6101446104d6565b6101446104ea565b610144610299366004610b15565b610600565b6033546001600160a01b0316610195565b6101446102bd366004610b15565b610684565b6723aaa0a92224a0a760c11b60005260656020527f77e34a3b4834e435146247fa65afcf7ea37e9131390e51b0e0f63714ee067bf6546001600160a01b0316610195565b631093d39160e21b60005260656020527fda5f286e3abf3f1aba5271b23124cb42ab0b794b0dabf0c0589b1717e61d400f546001600160a01b0316610195565b610144610354366004610b15565b610707565b6c4f5054494f4e5f5348455a4d5560981b60005260656020527ff967d0fdc819cca7d64b33f6b0a226b9d1d6598d34aeaa3c9b608e5c75e311ec546001600160a01b0316610195565b6101446103b0366004610b15565b61078a565b6101446103c3366004610b15565b61080a565b655348455a4d5560d01b60005260656020527f586b8f0a8ced7191e893a49d03ca1e79e020f10ef286d0d3c3311d28e9288ab5546001600160a01b0316610195565b610144610418366004610b15565b610893565b61014461042b366004610b15565b610917565b61014461043e366004610b15565b61098d565b61044b610a0f565b6001600160a01b0381166104725760405163538ba4f960e01b815260040160405180910390fd5b76282924a1a2afa7a920a1a622afa0a3a3a922a3a0aa27a960491b60005260656020527fe110409edc9a0b90e9d21aab5059d379cbdfd2a769ad5b408d5ae263a256979680546001600160a01b0319166001600160a01b0392909216919091179055565b6104de610a0f565b6104e86000610a69565b565b600054610100900460ff161580801561050a5750600054600160ff909116105b806105245750303b158015610524575060005460ff166001145b61058c5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b6000805460ff1916600117905580156105af576000805461ff0019166101001790555b6105b7610abb565b80156105fd576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50565b610608610a0f565b6001600160a01b03811661062f5760405163538ba4f960e01b815260040160405180910390fd5b6723aaa0a92224a0a760c11b60005260656020527f77e34a3b4834e435146247fa65afcf7ea37e9131390e51b0e0f63714ee067bf680546001600160a01b0319166001600160a01b0392909216919091179055565b61068c610a0f565b6001600160a01b0381166106b35760405163538ba4f960e01b815260040160405180910390fd5b664641524d494e4760c81b60005260656020527f3ac420333c7fa008764194937bf26a064cd1e73cefe43ca3e59e9f72b8faa2fd80546001600160a01b0319166001600160a01b0392909216919091179055565b61070f610a0f565b6001600160a01b0381166107365760405163538ba4f960e01b815260040160405180910390fd5b664f42454c49534b60c81b60005260656020527f688a30b83ea6da8c04c45fecf52937319f015b25d5dbd85409ae70da32dbf97c80546001600160a01b0319166001600160a01b0392909216919091179055565b610792610a0f565b6001600160a01b0381166107b95760405163538ba4f960e01b815260040160405180910390fd5b631093d39160e21b60005260656020527fda5f286e3abf3f1aba5271b23124cb42ab0b794b0dabf0c0589b1717e61d400f80546001600160a01b0319166001600160a01b0392909216919091179055565b610812610a0f565b6001600160a01b0381166108395760405163538ba4f960e01b815260040160405180910390fd5b6c4f5054494f4e5f5348455a4d5560981b60005260656020527ff967d0fdc819cca7d64b33f6b0a226b9d1d6598d34aeaa3c9b608e5c75e311ec80546001600160a01b0319166001600160a01b0392909216919091179055565b61089b610a0f565b6001600160a01b0381166108c25760405163538ba4f960e01b815260040160405180910390fd5b67545245415355525960c01b60005260656020527f273af53ceec744447a7738adbc443776ff6daf084d4d3ca9047b8232c65cc0da80546001600160a01b0319166001600160a01b0392909216919091179055565b61091f610a0f565b6001600160a01b0381166109845760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610583565b6105fd81610a69565b610995610a0f565b6001600160a01b0381166109bc5760405163538ba4f960e01b815260040160405180910390fd5b655348455a4d5560d01b60005260656020527f586b8f0a8ced7191e893a49d03ca1e79e020f10ef286d0d3c3311d28e9288ab580546001600160a01b0319166001600160a01b0392909216919091179055565b6033546001600160a01b031633146104e85760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610583565b603380546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b600054610100900460ff16610ae25760405162461bcd60e51b815260040161058390610b45565b6104e8600054610100900460ff16610b0c5760405162461bcd60e51b815260040161058390610b45565b6104e833610a69565b600060208284031215610b2757600080fd5b81356001600160a01b0381168114610b3e57600080fd5b9392505050565b6020808252602b908201527f496e697469616c697a61626c653a20636f6e7472616374206973206e6f74206960408201526a6e697469616c697a696e6760a81b60608201526080019056fea2646970667358221220dc0748db8beedd494e85b1b6da0b908bf5429382ad83a251efbab39e3c03112264736f6c63430008110033
Deployed Bytecode
0x608060405234801561001057600080fd5b506004361061012c5760003560e01c8063a75b87d2116100ad578063de2ae16711610071578063de2ae167146103b5578063ef7063b0146103c8578063f0f442601461040a578063f2fde38b1461041d578063f3f9ebf31461043057600080fd5b8063a75b87d2146102c2578063ac98247214610306578063b4a6589c14610346578063c937cfa414610359578063d959fb2e146103a257600080fd5b8063715018a6116100f4578063715018a61461027b5780638129fc1c146102835780638a0dac4a1461028b5780638da5cb5b1461029e578063a124a640146102af57600080fd5b80632d729142146101315780632ea451be146101465780633b19e84a146101b157806345813eb0146101f557806369576d8914610238575b600080fd5b61014461013f366004610b15565b610443565b005b76282924a1a2afa7a920a1a622afa0a3a3a922a3a0aa27a960491b60005260656020527fe110409edc9a0b90e9d21aab5059d379cbdfd2a769ad5b408d5ae263a2569796546001600160a01b03165b6040516001600160a01b03909116815260200160405180910390f35b67545245415355525960c01b60005260656020527f273af53ceec744447a7738adbc443776ff6daf084d4d3ca9047b8232c65cc0da546001600160a01b0316610195565b664641524d494e4760c81b60005260656020527f3ac420333c7fa008764194937bf26a064cd1e73cefe43ca3e59e9f72b8faa2fd546001600160a01b0316610195565b664f42454c49534b60c81b60005260656020527f688a30b83ea6da8c04c45fecf52937319f015b25d5dbd85409ae70da32dbf97c546001600160a01b0316610195565b6101446104d6565b6101446104ea565b610144610299366004610b15565b610600565b6033546001600160a01b0316610195565b6101446102bd366004610b15565b610684565b6723aaa0a92224a0a760c11b60005260656020527f77e34a3b4834e435146247fa65afcf7ea37e9131390e51b0e0f63714ee067bf6546001600160a01b0316610195565b631093d39160e21b60005260656020527fda5f286e3abf3f1aba5271b23124cb42ab0b794b0dabf0c0589b1717e61d400f546001600160a01b0316610195565b610144610354366004610b15565b610707565b6c4f5054494f4e5f5348455a4d5560981b60005260656020527ff967d0fdc819cca7d64b33f6b0a226b9d1d6598d34aeaa3c9b608e5c75e311ec546001600160a01b0316610195565b6101446103b0366004610b15565b61078a565b6101446103c3366004610b15565b61080a565b655348455a4d5560d01b60005260656020527f586b8f0a8ced7191e893a49d03ca1e79e020f10ef286d0d3c3311d28e9288ab5546001600160a01b0316610195565b610144610418366004610b15565b610893565b61014461042b366004610b15565b610917565b61014461043e366004610b15565b61098d565b61044b610a0f565b6001600160a01b0381166104725760405163538ba4f960e01b815260040160405180910390fd5b76282924a1a2afa7a920a1a622afa0a3a3a922a3a0aa27a960491b60005260656020527fe110409edc9a0b90e9d21aab5059d379cbdfd2a769ad5b408d5ae263a256979680546001600160a01b0319166001600160a01b0392909216919091179055565b6104de610a0f565b6104e86000610a69565b565b600054610100900460ff161580801561050a5750600054600160ff909116105b806105245750303b158015610524575060005460ff166001145b61058c5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b6000805460ff1916600117905580156105af576000805461ff0019166101001790555b6105b7610abb565b80156105fd576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50565b610608610a0f565b6001600160a01b03811661062f5760405163538ba4f960e01b815260040160405180910390fd5b6723aaa0a92224a0a760c11b60005260656020527f77e34a3b4834e435146247fa65afcf7ea37e9131390e51b0e0f63714ee067bf680546001600160a01b0319166001600160a01b0392909216919091179055565b61068c610a0f565b6001600160a01b0381166106b35760405163538ba4f960e01b815260040160405180910390fd5b664641524d494e4760c81b60005260656020527f3ac420333c7fa008764194937bf26a064cd1e73cefe43ca3e59e9f72b8faa2fd80546001600160a01b0319166001600160a01b0392909216919091179055565b61070f610a0f565b6001600160a01b0381166107365760405163538ba4f960e01b815260040160405180910390fd5b664f42454c49534b60c81b60005260656020527f688a30b83ea6da8c04c45fecf52937319f015b25d5dbd85409ae70da32dbf97c80546001600160a01b0319166001600160a01b0392909216919091179055565b610792610a0f565b6001600160a01b0381166107b95760405163538ba4f960e01b815260040160405180910390fd5b631093d39160e21b60005260656020527fda5f286e3abf3f1aba5271b23124cb42ab0b794b0dabf0c0589b1717e61d400f80546001600160a01b0319166001600160a01b0392909216919091179055565b610812610a0f565b6001600160a01b0381166108395760405163538ba4f960e01b815260040160405180910390fd5b6c4f5054494f4e5f5348455a4d5560981b60005260656020527ff967d0fdc819cca7d64b33f6b0a226b9d1d6598d34aeaa3c9b608e5c75e311ec80546001600160a01b0319166001600160a01b0392909216919091179055565b61089b610a0f565b6001600160a01b0381166108c25760405163538ba4f960e01b815260040160405180910390fd5b67545245415355525960c01b60005260656020527f273af53ceec744447a7738adbc443776ff6daf084d4d3ca9047b8232c65cc0da80546001600160a01b0319166001600160a01b0392909216919091179055565b61091f610a0f565b6001600160a01b0381166109845760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610583565b6105fd81610a69565b610995610a0f565b6001600160a01b0381166109bc5760405163538ba4f960e01b815260040160405180910390fd5b655348455a4d5560d01b60005260656020527f586b8f0a8ced7191e893a49d03ca1e79e020f10ef286d0d3c3311d28e9288ab580546001600160a01b0319166001600160a01b0392909216919091179055565b6033546001600160a01b031633146104e85760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610583565b603380546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b600054610100900460ff16610ae25760405162461bcd60e51b815260040161058390610b45565b6104e8600054610100900460ff16610b0c5760405162461bcd60e51b815260040161058390610b45565b6104e833610a69565b600060208284031215610b2757600080fd5b81356001600160a01b0381168114610b3e57600080fd5b9392505050565b6020808252602b908201527f496e697469616c697a61626c653a20636f6e7472616374206973206e6f74206960408201526a6e697469616c697a696e6760a81b60608201526080019056fea2646970667358221220dc0748db8beedd494e85b1b6da0b908bf5429382ad83a251efbab39e3c03112264736f6c63430008110033
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 26 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
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.