Overview
POL Balance
0 POL
POL Value
$0.00More Info
Private Name Tags
ContractCreator
Latest 1 from a total of 1 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Transfer Ownersh... | 29079706 | 919 days ago | IN | 0 POL | 0.00096981 |
Loading...
Loading
Contract Name:
AssetRouter
Compiler Version
v0.8.10+commit.fc410830
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: MIT pragma solidity 0.8.10; import {Ownable} from "@openzeppelin/contracts/access/Ownable.sol"; import {IERC20} from "@openzeppelin/contracts/token/ERC20/IERC20.sol"; import {SafeCast} from "@openzeppelin/contracts/utils/math/SafeCast.sol"; import {Errors} from "../utils/Errors.sol"; import {IAssetRegistry} from "./interfaces/IAssetRegistry.sol"; import {IAssetOracle} from "./interfaces/IAssetOracle.sol"; import {IAssetRouter} from "./interfaces/IAssetRouter.sol"; import {IAssetResolver} from "./interfaces/IAssetResolver.sol"; /// @title Asset router contract contract AssetRouter is IAssetRouter, Ownable { using SafeCast for uint256; IAssetOracle public oracle; IAssetRegistry public registry; constructor(address oracle_, address registry_) Ownable() { oracle = IAssetOracle(oracle_); registry = IAssetRegistry(registry_); } /// @notice Set the oracle of router. function setOracle(address oracle_) external onlyOwner { oracle = IAssetOracle(oracle_); } /// @notice Set the registry of router. function setRegistry(address registry_) external onlyOwner { registry = IAssetRegistry(registry_); } /// @notice Calculate assets total value. /// @param assets_ The asset array. /// @param amounts_ The amount array of assets. /// @param quote_ The address of the quote token. /// @return The total value of assets in quote token. function calcAssetsTotalValue( address[] calldata assets_, uint256[] calldata amounts_, address quote_ ) external view returns (uint256) { Errors._require( assets_.length == amounts_.length, Errors.Code.ASSET_ROUTER_ASSETS_AND_AMOUNTS_LENGTH_INCONSISTENT ); int256 totalValue; for (uint256 i = 0; i < assets_.length; ++i) { totalValue += calcAssetValue(assets_[i], amounts_[i], quote_); } Errors._require(totalValue >= 0, Errors.Code.ASSET_ROUTER_NEGATIVE_VALUE); return uint256(totalValue); } /// @param asset_ The asset address. /// @param amount_ The amount of asset. /// @param quote_ The address of the quote token. /// @return The value of asset in quote token. function calcAssetValue( address asset_, uint256 amount_, address quote_ ) public view returns (int256) { // avoid redundant calculation if (asset_ == quote_) { return amount_.toInt256(); } // return zero value directly if (amount_ == 0) { return 0; } IAssetResolver resolver = IAssetResolver(registry.resolvers(asset_)); return resolver.calcAssetValue(asset_, amount_, quote_); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (access/Ownable.sol) pragma solidity ^0.8.0; import "../utils/Context.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 Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() { _transferOwnership(_msgSender()); } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(owner() == _msgSender(), "Ownable: caller is not the owner"); _; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _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); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/IERC20.sol) pragma solidity ^0.8.0; /** * @dev Interface of the ERC20 standard as defined in the EIP. */ interface IERC20 { /** * @dev Returns the amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the amount of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves `amount` tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 amount) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance(address owner, address spender) external view returns (uint256); /** * @dev Sets `amount` as the allowance of `spender` over the caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 amount) external returns (bool); /** * @dev Moves `amount` tokens from `from` to `to` using the * allowance mechanism. `amount` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom( address from, address to, uint256 amount ) external returns (bool); /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/Context.sol) pragma solidity ^0.8.0; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/math/SafeCast.sol) pragma solidity ^0.8.0; /** * @dev Wrappers over Solidity's uintXX/intXX casting operators with added overflow * checks. * * Downcasting from uint256/int256 in Solidity does not revert on overflow. This can * easily result in undesired exploitation or bugs, since developers usually * assume that overflows raise errors. `SafeCast` restores this intuition by * reverting the transaction when such 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. * * Can be combined with {SafeMath} and {SignedSafeMath} to extend it to smaller types, by performing * all math on `uint256` and `int256` and then downcasting. */ library SafeCast { /** * @dev Returns the downcasted uint224 from uint256, reverting on * overflow (when the input is greater than largest uint224). * * Counterpart to Solidity's `uint224` operator. * * Requirements: * * - input must fit into 224 bits */ function toUint224(uint256 value) internal pure returns (uint224) { require(value <= type(uint224).max, "SafeCast: value doesn't fit in 224 bits"); return uint224(value); } /** * @dev Returns the downcasted uint128 from uint256, reverting on * overflow (when the input is greater than largest uint128). * * Counterpart to Solidity's `uint128` operator. * * Requirements: * * - input must fit into 128 bits */ function toUint128(uint256 value) internal pure returns (uint128) { require(value <= type(uint128).max, "SafeCast: value doesn't fit in 128 bits"); return uint128(value); } /** * @dev Returns the downcasted uint96 from uint256, reverting on * overflow (when the input is greater than largest uint96). * * Counterpart to Solidity's `uint96` operator. * * Requirements: * * - input must fit into 96 bits */ function toUint96(uint256 value) internal pure returns (uint96) { require(value <= type(uint96).max, "SafeCast: value doesn't fit in 96 bits"); return uint96(value); } /** * @dev Returns the downcasted uint64 from uint256, reverting on * overflow (when the input is greater than largest uint64). * * Counterpart to Solidity's `uint64` operator. * * Requirements: * * - input must fit into 64 bits */ function toUint64(uint256 value) internal pure returns (uint64) { require(value <= type(uint64).max, "SafeCast: value doesn't fit in 64 bits"); return uint64(value); } /** * @dev Returns the downcasted uint32 from uint256, reverting on * overflow (when the input is greater than largest uint32). * * Counterpart to Solidity's `uint32` operator. * * Requirements: * * - input must fit into 32 bits */ function toUint32(uint256 value) internal pure returns (uint32) { require(value <= type(uint32).max, "SafeCast: value doesn't fit in 32 bits"); return uint32(value); } /** * @dev Returns the downcasted uint16 from uint256, reverting on * overflow (when the input is greater than largest uint16). * * Counterpart to Solidity's `uint16` operator. * * Requirements: * * - input must fit into 16 bits */ function toUint16(uint256 value) internal pure returns (uint16) { require(value <= type(uint16).max, "SafeCast: value doesn't fit in 16 bits"); return uint16(value); } /** * @dev Returns the downcasted uint8 from uint256, reverting on * overflow (when the input is greater than largest uint8). * * Counterpart to Solidity's `uint8` operator. * * Requirements: * * - input must fit into 8 bits. */ function toUint8(uint256 value) internal pure returns (uint8) { require(value <= type(uint8).max, "SafeCast: value doesn't fit in 8 bits"); return uint8(value); } /** * @dev Converts a signed int256 into an unsigned uint256. * * Requirements: * * - input must be greater than or equal to 0. */ function toUint256(int256 value) internal pure returns (uint256) { require(value >= 0, "SafeCast: value must be positive"); return uint256(value); } /** * @dev Returns the downcasted int128 from int256, reverting on * overflow (when the input is less than smallest int128 or * greater than largest int128). * * Counterpart to Solidity's `int128` operator. * * Requirements: * * - input must fit into 128 bits * * _Available since v3.1._ */ function toInt128(int256 value) internal pure returns (int128) { require(value >= type(int128).min && value <= type(int128).max, "SafeCast: value doesn't fit in 128 bits"); return int128(value); } /** * @dev Returns the downcasted int64 from int256, reverting on * overflow (when the input is less than smallest int64 or * greater than largest int64). * * Counterpart to Solidity's `int64` operator. * * Requirements: * * - input must fit into 64 bits * * _Available since v3.1._ */ function toInt64(int256 value) internal pure returns (int64) { require(value >= type(int64).min && value <= type(int64).max, "SafeCast: value doesn't fit in 64 bits"); return int64(value); } /** * @dev Returns the downcasted int32 from int256, reverting on * overflow (when the input is less than smallest int32 or * greater than largest int32). * * Counterpart to Solidity's `int32` operator. * * Requirements: * * - input must fit into 32 bits * * _Available since v3.1._ */ function toInt32(int256 value) internal pure returns (int32) { require(value >= type(int32).min && value <= type(int32).max, "SafeCast: value doesn't fit in 32 bits"); return int32(value); } /** * @dev Returns the downcasted int16 from int256, reverting on * overflow (when the input is less than smallest int16 or * greater than largest int16). * * Counterpart to Solidity's `int16` operator. * * Requirements: * * - input must fit into 16 bits * * _Available since v3.1._ */ function toInt16(int256 value) internal pure returns (int16) { require(value >= type(int16).min && value <= type(int16).max, "SafeCast: value doesn't fit in 16 bits"); return int16(value); } /** * @dev Returns the downcasted int8 from int256, reverting on * overflow (when the input is less than smallest int8 or * greater than largest int8). * * Counterpart to Solidity's `int8` operator. * * Requirements: * * - input must fit into 8 bits. * * _Available since v3.1._ */ function toInt8(int256 value) internal pure returns (int8) { require(value >= type(int8).min && value <= type(int8).max, "SafeCast: value doesn't fit in 8 bits"); return int8(value); } /** * @dev Converts an unsigned uint256 into a signed int256. * * Requirements: * * - input must be less than or equal to maxInt256. */ function toInt256(uint256 value) internal pure returns (int256) { // Note: Unsafe cast below is okay because `type(int256).max` is guaranteed to be positive require(value <= uint256(type(int256).max), "SafeCast: value doesn't fit in an int256"); return int256(value); } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; interface IAssetOracle { function calcConversionAmount( address base_, uint256 baseAmount_, address quote_ ) external view returns (uint256); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; interface IAssetRegistry { function bannedResolvers(address) external view returns (bool); function register(address asset_, address resolver_) external; function unregister(address asset_) external; function banResolver(address resolver_) external; function unbanResolver(address resolver_) external; function resolvers(address asset_) external view returns (address); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; interface IAssetResolver { function calcAssetValue( address, uint256, address ) external view returns (int256); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; import {IAssetRegistry} from "./IAssetRegistry.sol"; import {IAssetOracle} from "./IAssetOracle.sol"; interface IAssetRouter { function oracle() external view returns (IAssetOracle); function registry() external view returns (IAssetRegistry); function setOracle(address oracle_) external; function setRegistry(address registry_) external; function calcAssetsTotalValue( address[] calldata bases_, uint256[] calldata amounts_, address quote_ ) external view returns (uint256); function calcAssetValue( address asset_, uint256 amount_, address quote_ ) external view returns (int256); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; library Errors { error RevertCode(Code errorCode); enum Code { COMPTROLLER_HALTED, // 0: "Halted" COMPTROLLER_BANNED, // 1: "Banned" COMPTROLLER_ZERO_ADDRESS, // 2: "Zero address" COMPTROLLER_TOS_AND_SIGS_LENGTH_INCONSISTENT, // 3: "tos and sigs length are inconsistent" COMPTROLLER_BEACON_IS_INITIALIZED, // 4: "Beacon is initialized" COMPTROLLER_DENOMINATIONS_AND_DUSTS_LENGTH_INCONSISTENT, // 5: "denominations and dusts length are inconsistent" IMPLEMENTATION_ASSET_LIST_NOT_EMPTY, // 6: "assetList is not empty" IMPLEMENTATION_INVALID_DENOMINATION, // 7: "Invalid denomination" IMPLEMENTATION_INVALID_MORTGAGE_TIER, // 8: "Mortgage tier not set in comptroller" IMPLEMENTATION_PENDING_SHARE_NOT_RESOLVABLE, // 9: "pending share is not resolvable" IMPLEMENTATION_PENDING_NOT_START, // 10: "Pending does not start" IMPLEMENTATION_PENDING_NOT_EXPIRE, // 11: "Pending does not expire" IMPLEMENTATION_INVALID_ASSET, // 12: "Invalid asset" IMPLEMENTATION_INSUFFICIENT_TOTAL_VALUE_FOR_EXECUTION, // 13: "Insufficient total value for execution" FUND_PROXY_FACTORY_INVALID_CREATOR, // 14: "Invalid creator" FUND_PROXY_FACTORY_INVALID_DENOMINATION, // 15: "Invalid denomination" FUND_PROXY_FACTORY_INVALID_MORTGAGE_TIER, // 16: "Mortgage tier not set in comptroller" FUND_PROXY_STORAGE_UTILS_INVALID_DENOMINATION, // 17: "Invalid denomination" FUND_PROXY_STORAGE_UTILS_UNKNOWN_OWNER, // 18: "Unknown owner" FUND_PROXY_STORAGE_UTILS_WRONG_ALLOWANCE, // 19: "Wrong allowance" FUND_PROXY_STORAGE_UTILS_IS_NOT_ZERO, // 20: "Is not zero value or address " FUND_PROXY_STORAGE_UTILS_IS_ZERO, // 21: "Is zero value or address" MORTGAGE_VAULT_FUND_MORTGAGED, // 22: "Fund mortgaged" SHARE_TOKEN_INVALID_FROM, // 23: "Invalid from" SHARE_TOKEN_INVALID_TO, // 24: "Invalid to" TASK_EXECUTOR_TOS_AND_DATAS_LENGTH_INCONSISTENT, // 25: "tos and datas length inconsistent" TASK_EXECUTOR_TOS_AND_CONFIGS_LENGTH_INCONSISTENT, // 26: "tos and configs length inconsistent" TASK_EXECUTOR_INVALID_COMPTROLLER_DELEGATE_CALL, // 27: "Invalid comptroller delegate call" TASK_EXECUTOR_INVALID_COMPTROLLER_CONTRACT_CALL, // 28: "Invalid comptroller contract call" TASK_EXECUTOR_INVALID_DEALING_ASSET, // 29: "Invalid dealing asset" TASK_EXECUTOR_REFERENCE_TO_OUT_OF_LOCALSTACK, // 30: "Reference to out of localStack" TASK_EXECUTOR_RETURN_NUM_AND_PARSED_RETURN_NUM_NOT_MATCHED, // 31: "Return num and parsed return num not matched" TASK_EXECUTOR_ILLEGAL_LENGTH_FOR_PARSE, // 32: "Illegal length for _parse" TASK_EXECUTOR_STACK_OVERFLOW, // 33: "Stack overflow" TASK_EXECUTOR_INVALID_INITIAL_ASSET, // 34: "Invalid initial asset" TASK_EXECUTOR_NON_ZERO_QUOTA, // 35: "Quota is not zero" AFURUCOMBO_DUPLICATED_TOKENSOUT, // 36: "Duplicated tokensOut" AFURUCOMBO_REMAINING_TOKENS, // 37: "Furucombo has remaining tokens" AFURUCOMBO_TOKENS_AND_AMOUNTS_LENGTH_INCONSISTENT, // 38: "Token length != amounts length" AFURUCOMBO_INVALID_COMPTROLLER_HANDLER_CALL, // 39: "Invalid comptroller handler call" CHAINLINK_ASSETS_AND_AGGREGATORS_INCONSISTENT, // 40: "assets.length == aggregators.length" CHAINLINK_ZERO_ADDRESS, // 41: "Zero address" CHAINLINK_EXISTING_ASSET, // 42: "Existing asset" CHAINLINK_NON_EXISTENT_ASSET, // 43: "Non-existent asset" CHAINLINK_INVALID_PRICE, // 44: "Invalid price" CHAINLINK_STALE_PRICE, // 45: "Stale price" ASSET_REGISTRY_UNREGISTERED, // 46: "Unregistered" ASSET_REGISTRY_BANNED_RESOLVER, // 47: "Resolver has been banned" ASSET_REGISTRY_ZERO_RESOLVER_ADDRESS, // 48: "Resolver zero address" ASSET_REGISTRY_ZERO_ASSET_ADDRESS, // 49: "Asset zero address" ASSET_REGISTRY_REGISTERED_RESOLVER, // 50: "Resolver is registered" ASSET_REGISTRY_NON_REGISTERED_RESOLVER, // 51: "Asset not registered" ASSET_REGISTRY_NON_BANNED_RESOLVER, // 52: "Resolver is not banned" ASSET_ROUTER_ASSETS_AND_AMOUNTS_LENGTH_INCONSISTENT, // 53: "assets length != amounts length" ASSET_ROUTER_NEGATIVE_VALUE, // 54: "Negative value" RESOLVER_ASSET_VALUE_NEGATIVE, // 55: "Resolver's asset value < 0" RESOLVER_ASSET_VALUE_POSITIVE, // 56: "Resolver's asset value > 0" RCURVE_STABLE_ZERO_ASSET_ADDRESS, // 57: "Zero asset address" RCURVE_STABLE_ZERO_POOL_ADDRESS, // 58: "Zero pool address" RCURVE_STABLE_ZERO_VALUED_ASSET_ADDRESS, // 59: "Zero valued asset address" RCURVE_STABLE_VALUED_ASSET_DECIMAL_NOT_MATCH_VALUED_ASSET, // 60: "Valued asset decimal not match valued asset" RCURVE_STABLE_POOL_INFO_IS_NOT_SET, // 61: "Pool info is not set" ASSET_MODULE_DIFFERENT_ASSET_REMAINING, // 62: "Different asset remaining" ASSET_MODULE_FULL_ASSET_CAPACITY, // 63: "Full Asset Capacity" MANAGEMENT_FEE_MODULE_FEE_RATE_SHOULD_BE_LESS_THAN_FUND_BASE, // 64: "Fee rate should be less than 100%" PERFORMANCE_FEE_MODULE_CAN_NOT_CRYSTALLIZED_YET, // 65: "Can not crystallized yet" PERFORMANCE_FEE_MODULE_TIME_BEFORE_START, // 66: "Time before start" PERFORMANCE_FEE_MODULE_FEE_RATE_SHOULD_BE_LESS_THAN_BASE, // 67: "Fee rate should be less than 100%" PERFORMANCE_FEE_MODULE_CRYSTALLIZATION_PERIOD_TOO_SHORT, // 68: "Crystallization period too short" SHARE_MODULE_SHARE_AMOUNT_TOO_LARGE, // 69: "The requesting share amount is greater than total share amount" SHARE_MODULE_PURCHASE_ZERO_BALANCE, // 70: "The purchased balance is zero" SHARE_MODULE_PURCHASE_ZERO_SHARE, // 71: "The share purchased need to greater than zero" SHARE_MODULE_REDEEM_ZERO_SHARE, // 72: "The redeem share is zero" SHARE_MODULE_INSUFFICIENT_SHARE, // 73: "Insufficient share amount" SHARE_MODULE_REDEEM_IN_PENDING_WITHOUT_PERMISSION, // 74: "Redeem in pending without permission" SHARE_MODULE_PENDING_ROUND_INCONSISTENT, // 75: "user pending round and current pending round are inconsistent" SHARE_MODULE_PENDING_REDEMPTION_NOT_CLAIMABLE // 76: "Pending redemption is not claimable" } function _require(bool condition_, Code errorCode_) internal pure { if (!condition_) revert RevertCode(errorCode_); } function _revertMsg(string memory functionName_, string memory reason_) internal pure { revert(string(abi.encodePacked(functionName_, ": ", reason_))); } function _revertMsg(string memory functionName_) internal pure { _revertMsg(functionName_, "Unspecified"); } }
{ "evmVersion": "london", "libraries": {}, "metadata": { "bytecodeHash": "ipfs", "useLiteralContent": true }, "optimizer": { "enabled": true, "runs": 200 }, "remappings": [], "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"address","name":"oracle_","type":"address"},{"internalType":"address","name":"registry_","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"enum Errors.Code","name":"errorCode","type":"uint8"}],"name":"RevertCode","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"inputs":[{"internalType":"address","name":"asset_","type":"address"},{"internalType":"uint256","name":"amount_","type":"uint256"},{"internalType":"address","name":"quote_","type":"address"}],"name":"calcAssetValue","outputs":[{"internalType":"int256","name":"","type":"int256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"assets_","type":"address[]"},{"internalType":"uint256[]","name":"amounts_","type":"uint256[]"},{"internalType":"address","name":"quote_","type":"address"}],"name":"calcAssetsTotalValue","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"oracle","outputs":[{"internalType":"contract IAssetOracle","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"registry","outputs":[{"internalType":"contract IAssetRegistry","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"oracle_","type":"address"}],"name":"setOracle","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"registry_","type":"address"}],"name":"setRegistry","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
608060405234801561001057600080fd5b5060405161092d38038061092d83398101604081905261002f916100d5565b61003833610069565b600180546001600160a01b039384166001600160a01b03199182161790915560028054929093169116179055610108565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b80516001600160a01b03811681146100d057600080fd5b919050565b600080604083850312156100e857600080fd5b6100f1836100b9565b91506100ff602084016100b9565b90509250929050565b610816806101176000396000f3fe608060405234801561001057600080fd5b50600436106100935760003560e01c80637dc0d1d0116100665780637dc0d1d0146101065780638da5cb5b14610119578063a91ee0dc1461012a578063dedcf6751461013d578063f2fde38b1461015057600080fd5b80631485a16214610098578063715018a6146100be5780637adbf973146100c85780637b103999146100db575b600080fd5b6100ab6100a63660046105e2565b610163565b6040519081526020015b60405180910390f35b6100c66101fd565b005b6100c66100d6366004610666565b61023c565b6002546100ee906001600160a01b031681565b6040516001600160a01b0390911681526020016100b5565b6001546100ee906001600160a01b031681565b6000546001600160a01b03166100ee565b6100c6610138366004610666565b610288565b6100ab61014b366004610683565b6102d4565b6100c661015e366004610666565b610404565b6000610172858414603561049f565b6000805b868110156101e3576101c7888883818110610193576101936106c5565b90506020020160208101906101a89190610666565b8787848181106101ba576101ba6106c5565b90506020020135866102d4565b6101d190836106f1565b91506101dc81610732565b9050610176565b506101f36000821215603661049f565b9695505050505050565b6000546001600160a01b031633146102305760405162461bcd60e51b81526004016102279061074d565b60405180910390fd5b61023a60006104c3565b565b6000546001600160a01b031633146102665760405162461bcd60e51b81526004016102279061074d565b600180546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146102b25760405162461bcd60e51b81526004016102279061074d565b600280546001600160a01b0319166001600160a01b0392909216919091179055565b6000816001600160a01b0316846001600160a01b03161415610300576102f983610513565b90506103fd565b8261030d575060006103fd565b60025460405163b93793e960e01b81526001600160a01b038681166004830152600092169063b93793e990602401602060405180830381865afa158015610358573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061037c9190610782565b60405163dedcf67560e01b81526001600160a01b0387811660048301526024820187905285811660448301529192509082169063dedcf67590606401602060405180830381865afa1580156103d5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103f9919061079f565b9150505b9392505050565b6000546001600160a01b0316331461042e5760405162461bcd60e51b81526004016102279061074d565b6001600160a01b0381166104935760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610227565b61049c816104c3565b50565b816104bf578060405163193106d160e21b815260040161022791906107b8565b5050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006001600160ff1b0382111561057d5760405162461bcd60e51b815260206004820152602860248201527f53616665436173743a2076616c756520646f65736e27742066697420696e2061604482015267371034b73a191a9b60c11b6064820152608401610227565b5090565b60008083601f84011261059357600080fd5b50813567ffffffffffffffff8111156105ab57600080fd5b6020830191508360208260051b85010111156105c657600080fd5b9250929050565b6001600160a01b038116811461049c57600080fd5b6000806000806000606086880312156105fa57600080fd5b853567ffffffffffffffff8082111561061257600080fd5b61061e89838a01610581565b9097509550602088013591508082111561063757600080fd5b5061064488828901610581565b9094509250506040860135610658816105cd565b809150509295509295909350565b60006020828403121561067857600080fd5b81356103fd816105cd565b60008060006060848603121561069857600080fd5b83356106a3816105cd565b92506020840135915060408401356106ba816105cd565b809150509250925092565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600080821280156001600160ff1b0384900385131615610713576107136106db565b600160ff1b839003841281161561072c5761072c6106db565b50500190565b6000600019821415610746576107466106db565b5060010190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60006020828403121561079457600080fd5b81516103fd816105cd565b6000602082840312156107b157600080fd5b5051919050565b60208101604d83106107da57634e487b7160e01b600052602160045260246000fd5b9190529056fea264697066735822122017a4855198263660539d17fe73a7849a7926f4ae0233df7c745b32159fa1445964736f6c634300080a0033000000000000000000000000d652ab89e48622744050c3cbeb4084bc58430fc6000000000000000000000000e9a65da3ac8599fda56ec7e5c39467401078753b
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106100935760003560e01c80637dc0d1d0116100665780637dc0d1d0146101065780638da5cb5b14610119578063a91ee0dc1461012a578063dedcf6751461013d578063f2fde38b1461015057600080fd5b80631485a16214610098578063715018a6146100be5780637adbf973146100c85780637b103999146100db575b600080fd5b6100ab6100a63660046105e2565b610163565b6040519081526020015b60405180910390f35b6100c66101fd565b005b6100c66100d6366004610666565b61023c565b6002546100ee906001600160a01b031681565b6040516001600160a01b0390911681526020016100b5565b6001546100ee906001600160a01b031681565b6000546001600160a01b03166100ee565b6100c6610138366004610666565b610288565b6100ab61014b366004610683565b6102d4565b6100c661015e366004610666565b610404565b6000610172858414603561049f565b6000805b868110156101e3576101c7888883818110610193576101936106c5565b90506020020160208101906101a89190610666565b8787848181106101ba576101ba6106c5565b90506020020135866102d4565b6101d190836106f1565b91506101dc81610732565b9050610176565b506101f36000821215603661049f565b9695505050505050565b6000546001600160a01b031633146102305760405162461bcd60e51b81526004016102279061074d565b60405180910390fd5b61023a60006104c3565b565b6000546001600160a01b031633146102665760405162461bcd60e51b81526004016102279061074d565b600180546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146102b25760405162461bcd60e51b81526004016102279061074d565b600280546001600160a01b0319166001600160a01b0392909216919091179055565b6000816001600160a01b0316846001600160a01b03161415610300576102f983610513565b90506103fd565b8261030d575060006103fd565b60025460405163b93793e960e01b81526001600160a01b038681166004830152600092169063b93793e990602401602060405180830381865afa158015610358573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061037c9190610782565b60405163dedcf67560e01b81526001600160a01b0387811660048301526024820187905285811660448301529192509082169063dedcf67590606401602060405180830381865afa1580156103d5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103f9919061079f565b9150505b9392505050565b6000546001600160a01b0316331461042e5760405162461bcd60e51b81526004016102279061074d565b6001600160a01b0381166104935760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610227565b61049c816104c3565b50565b816104bf578060405163193106d160e21b815260040161022791906107b8565b5050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006001600160ff1b0382111561057d5760405162461bcd60e51b815260206004820152602860248201527f53616665436173743a2076616c756520646f65736e27742066697420696e2061604482015267371034b73a191a9b60c11b6064820152608401610227565b5090565b60008083601f84011261059357600080fd5b50813567ffffffffffffffff8111156105ab57600080fd5b6020830191508360208260051b85010111156105c657600080fd5b9250929050565b6001600160a01b038116811461049c57600080fd5b6000806000806000606086880312156105fa57600080fd5b853567ffffffffffffffff8082111561061257600080fd5b61061e89838a01610581565b9097509550602088013591508082111561063757600080fd5b5061064488828901610581565b9094509250506040860135610658816105cd565b809150509295509295909350565b60006020828403121561067857600080fd5b81356103fd816105cd565b60008060006060848603121561069857600080fd5b83356106a3816105cd565b92506020840135915060408401356106ba816105cd565b809150509250925092565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600080821280156001600160ff1b0384900385131615610713576107136106db565b600160ff1b839003841281161561072c5761072c6106db565b50500190565b6000600019821415610746576107466106db565b5060010190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60006020828403121561079457600080fd5b81516103fd816105cd565b6000602082840312156107b157600080fd5b5051919050565b60208101604d83106107da57634e487b7160e01b600052602160045260246000fd5b9190529056fea264697066735822122017a4855198263660539d17fe73a7849a7926f4ae0233df7c745b32159fa1445964736f6c634300080a0033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
000000000000000000000000d652ab89e48622744050c3cbeb4084bc58430fc6000000000000000000000000e9a65da3ac8599fda56ec7e5c39467401078753b
-----Decoded View---------------
Arg [0] : oracle_ (address): 0xd652aB89E48622744050c3cbeB4084BC58430Fc6
Arg [1] : registry_ (address): 0xE9a65dA3ac8599fda56Ec7e5c39467401078753b
-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 000000000000000000000000d652ab89e48622744050c3cbeb4084bc58430fc6
Arg [1] : 000000000000000000000000e9a65da3ac8599fda56ec7e5c39467401078753b
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 30 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
[ 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.