Contract 0x70bbe4a294878a14cb3cdd9315f5eb490e346163 1

Contract Overview

Blizz: Lending Pool
Balance:
0 AVAX

AVAX Value:
$0.00

Token:
Txn Hash Method
Block
From
To
Value [Txn Fee]
0xfbc50089d2aa882f40ae7006de8b103abb4fbd808f0a5496ef29591a3494b291Borrow78751912021-12-06 8:36:0635 secs ago0xcba1a275e2d858ecffaf7a87f606f74b719a8a93 IN  Blizz: Lending Pool0 AVAX0.01580852525
0xa337f5feaa4e7e97b8da51e072ba53e17245cea515ff76d8918db4c557a38119Withdraw78751912021-12-06 8:36:0635 secs ago0x02e635ef7fd5ed146b81c30d7d443827b27b95eb IN  Blizz: Lending Pool0 AVAX0.00751757525
0xe872d23cbdf0794d6812134ee078a46f6d73d878621cc54fc79c2ad43c982b07Deposit78751742021-12-06 8:35:301 min ago0xcba1a275e2d858ecffaf7a87f606f74b719a8a93 IN  Blizz: Lending Pool0 AVAX0.00661777525
0xd7909b7f8b5af7fb7af0803a64ee175b1425b20365078c006c152697d2a2b3b3Deposit78751322021-12-06 8:34:062 mins ago0xcba1a275e2d858ecffaf7a87f606f74b719a8a93 IN  Blizz: Lending Pool0 AVAX0.00661837525
0xb30b5098007f99eccfab05a351c7a99d41d8559fbac34fdbbd3f4a54d51d76f3Withdraw78750602021-12-06 8:31:494 mins ago0xc232276308036e0b2be15fad63c09619b6ebe339 IN  Blizz: Lending Pool0 AVAX0.007516225
0xeb872723fb387163d2f7d0084f6ea7910805380af0c237f5ebac49c3df2b701bWithdraw78750072021-12-06 8:30:046 mins ago0x73eb7a4756ef34b903d8f0d320138fa4f2e4ec5b IN  Blizz: Lending Pool0 AVAX0.015167725
0x39db9d6a1370d973f2d0ca1284189c017dc69a8f4256ddf2673bdbf63545a415Repay78749812021-12-06 8:29:107 mins ago0x73eb7a4756ef34b903d8f0d320138fa4f2e4ec5b IN  Blizz: Lending Pool0 AVAX0.007735125
0x0fd93976cfdd89563a569fd6e9ad45e36f0302b17cfe3ebe0b422eb884b62ec9Withdraw78749802021-12-06 8:29:077 mins ago0xc232276308036e0b2be15fad63c09619b6ebe339 IN  Blizz: Lending Pool0 AVAX0.007516225
0x171c761d84a5eba7b898986a41cc5704fce0a0f07bec1f7c85867ab874255bcfWithdraw78749782021-12-06 8:29:057 mins ago0x7a38b009f9e176f07978c2e75bab2a5b657ca37a IN  Blizz: Lending Pool0 AVAX0.007088725
0x24f869d444a5a2fa670c72924f9f426040859035b00bbc877f424d9093fa8e79Withdraw78749552021-12-06 8:28:248 mins ago0xc232276308036e0b2be15fad63c09619b6ebe339 IN  Blizz: Lending Pool0 AVAX0.00751757525
0xc306503c590629133c396eedbd4d5433a94362ae026fb22041910089e3ddbdedRepay78749522021-12-06 8:28:178 mins ago0x7a38b009f9e176f07978c2e75bab2a5b657ca37a IN  Blizz: Lending Pool0 AVAX0.00787912525
0x4a9ed6f840846e2b30e55133ca2de0c502ce449d12abc9c83c8fbf2d92ee41f6Withdraw78749312021-12-06 8:27:369 mins ago0x7a38b009f9e176f07978c2e75bab2a5b657ca37a IN  Blizz: Lending Pool0 AVAX0.008958425
0x6b19445463d677fd8c291d5d73c69403581b589abb62cbfd48adb089475ef8daWithdraw78749272021-12-06 8:27:259 mins ago0xc232276308036e0b2be15fad63c09619b6ebe339 IN  Blizz: Lending Pool0 AVAX0.00751757525
0x404e67a88547277a82b538ed6e817ed229b7d14aafbf7f1a675cee9d0d9c4ae1Repay78749222021-12-06 8:27:119 mins ago0x7a38b009f9e176f07978c2e75bab2a5b657ca37a IN  Blizz: Lending Pool0 AVAX0.007735125
0xfc4146848346e488a50ff1e9f9c5d3653cc3f4ada431ff69e045b4b717f5746fWithdraw78749132021-12-06 8:26:539 mins ago0x1c53dbc699084d1ed944167886b142ff48c718e3 IN  Blizz: Lending Pool0 AVAX0.00751757525
0xa51b631b8ec7ff6ca86fb02071da402dbb1efddef588883c1528d1164378b1c0Withdraw78749072021-12-06 8:26:4110 mins ago0x1c53dbc699084d1ed944167886b142ff48c718e3 IN  Blizz: Lending Pool0 AVAX0.007516225
0xe8285c2476d10b1c37f281fc58d8a4fa64c17ea1a5062a34007acc61860bcfe2Withdraw78749042021-12-06 8:26:3510 mins ago0x7a38b009f9e176f07978c2e75bab2a5b657ca37a IN  Blizz: Lending Pool0 AVAX0.008958425
0xd47f0f6e0d123b927695f0158cf46f39cc98994f53463eee3c6aa6ea09b37227Withdraw78748982021-12-06 8:26:2110 mins ago0x1c53dbc699084d1ed944167886b142ff48c718e3 IN  Blizz: Lending Pool0 AVAX0.00751757525
0xa361134681471d612621f10e7223ea3057d689f4c2c7d28dac1c241d388af669Withdraw78748972021-12-06 8:26:2010 mins ago0xc232276308036e0b2be15fad63c09619b6ebe339 IN  Blizz: Lending Pool0 AVAX0.007088725
0xeecdce5f652e14aaf295492263c880485925e0ef21317469714f56c8e81df0b6Repay78748922021-12-06 8:26:0910 mins ago0x7a38b009f9e176f07978c2e75bab2a5b657ca37a IN  Blizz: Lending Pool0 AVAX0.007734825
0x94f812463bf538ac73763f910f951b338794e0077cca65a63ba8b69c414ea60cWithdraw78748772021-12-06 8:25:4111 mins ago0x7a38b009f9e176f07978c2e75bab2a5b657ca37a IN  Blizz: Lending Pool0 AVAX0.008958125
0x83aa5894304d3a02af85654b76029f0264a9a2f20107d19cda225d49fd3d2cc9Repay78748592021-12-06 8:25:0211 mins ago0x7a38b009f9e176f07978c2e75bab2a5b657ca37a IN  Blizz: Lending Pool0 AVAX0.007734825
0x83f804515a9c5cd86fd2c6c2c5c8217a5b89f2074ad73605de63743595a579acDeposit78748552021-12-06 8:24:5011 mins ago0xe0bce02c802233389c3c5309d279241c0638d90b IN  Blizz: Lending Pool0 AVAX0.0084732832
0x9f26f8ed2c99c828a7e70266e9587f74cad47ab73052d03670382208bb56319eWithdraw78748342021-12-06 8:24:0812 mins ago0x7a38b009f9e176f07978c2e75bab2a5b657ca37a IN  Blizz: Lending Pool0 AVAX0.009385625
0x381a67c5eab74bfae5e0051be7ce0c2af1376f7e61b36e4958da2f4b87a045a1Withdraw78748062021-12-06 8:23:1913 mins ago0x256b7fd4eff7cf86891c8db5e3b11c5acadafc21 IN  Blizz: Lending Pool0 AVAX0.007516225
[ Download CSV Export 
Latest 1 internal transaction
Parent Txn Hash Block From To Value
0x6564bf8984018da17aa6cff4a9328732d7a12d62fcfcf4ba1aff5353647a943366288612021-11-07 6:46:2729 days 1 hr ago Blizz: Lending Pool Address Provider  Contract Creation0 AVAX
[ Download CSV Export 
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
InitializableImmutableAdminUpgradeabilityProxy

Compiler Version
v0.7.6+commit.7338295f

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, GNU AGPLv3 license

Contract Source Code (Solidity)

/**
 *Submitted for verification at snowtrace.io on 2021-11-07
*/

/**
 *Submitted for verification at snowtrace.io on 2021-11-05
*/

/**
 *Submitted for verification at FtmScan.com on 2021-10-02
*/

// SPDX-License-Identifier: agpl-3.0

pragma solidity 0.7.6;



// Part: Address

/**
 * @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');
  }
}

// Part: Context

/*
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with GSN meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
  function _msgSender() internal view virtual returns (address payable) {
    return msg.sender;
  }

  function _msgData() internal view virtual returns (bytes memory) {
    this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
    return msg.data;
  }
}

// Part: ILendingPoolAddressesProvider

/**
 * @title LendingPoolAddressesProvider contract
 * @dev Main registry of addresses part of or connected to the protocol, including permissioned roles
 * - Acting also as factory of proxies and admin of those, so with right to change its implementations
 * - Owned by the Aave Governance
 * @author Aave
 **/
interface ILendingPoolAddressesProvider {
  event MarketIdSet(string newMarketId);
  event LendingPoolUpdated(address indexed newAddress);
  event ConfigurationAdminUpdated(address indexed newAddress);
  event EmergencyAdminUpdated(address indexed newAddress);
  event LendingPoolConfiguratorUpdated(address indexed newAddress);
  event LendingPoolCollateralManagerUpdated(address indexed newAddress);
  event PriceOracleUpdated(address indexed newAddress);
  event LendingRateOracleUpdated(address indexed newAddress);
  event ProxyCreated(bytes32 id, address indexed newAddress);
  event AddressSet(bytes32 id, address indexed newAddress, bool hasProxy);

  function getMarketId() external view returns (string memory);

  function setMarketId(string calldata marketId) external;

  function setAddress(bytes32 id, address newAddress) external;

  function setAddressAsProxy(bytes32 id, address impl) external;

  function getAddress(bytes32 id) external view returns (address);

  function getLendingPool() external view returns (address);

  function setLendingPoolImpl(address pool) external;

  function getLendingPoolConfigurator() external view returns (address);

  function setLendingPoolConfiguratorImpl(address configurator) external;

  function getLendingPoolCollateralManager() external view returns (address);

  function setLendingPoolCollateralManager(address manager) external;

  function getPoolAdmin() external view returns (address);

  function setPoolAdmin(address admin) external;

  function getEmergencyAdmin() external view returns (address);

  function setEmergencyAdmin(address admin) external;

  function getPriceOracle() external view returns (address);

  function setPriceOracle(address priceOracle) external;

  function getLendingRateOracle() external view returns (address);

  function setLendingRateOracle(address lendingRateOracle) external;
}

// Part: Proxy

/**
 * @title Proxy
 * @dev Implements delegation of calls to other contracts, with proper
 * forwarding of return values and bubbling of failures.
 * It defines a fallback function that delegates all calls to the address
 * returned by the abstract _implementation() internal function.
 */
abstract contract Proxy {
  /**
   * @dev Fallback function.
   * Implemented entirely in `_fallback`.
   */
  fallback() external payable {
    _fallback();
  }

  /**
   * @return The Address of the implementation.
   */
  function _implementation() internal view virtual returns (address);

  /**
   * @dev Delegates execution to an implementation contract.
   * This is a low level function that doesn't return to its internal call site.
   * It will return to the external caller whatever the implementation returns.
   * @param implementation Address to delegate.
   */
  function _delegate(address implementation) internal {
    //solium-disable-next-line
    assembly {
      // Copy msg.data. We take full control of memory in this inline assembly
      // block because it will not return to Solidity code. We overwrite the
      // Solidity scratch pad at memory position 0.
      calldatacopy(0, 0, calldatasize())

      // Call the implementation.
      // out and outsize are 0 because we don't know the size yet.
      let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)

      // Copy the returned data.
      returndatacopy(0, 0, returndatasize())

      switch result
        // delegatecall returns 0 on error.
        case 0 {
          revert(0, returndatasize())
        }
        default {
          return(0, returndatasize())
        }
    }
  }

  /**
   * @dev Function that is run as the first thing in the fallback function.
   * Can be redefined in derived contracts to add functionality.
   * Redefinitions must call super._willFallback().
   */
  function _willFallback() internal virtual {}

  /**
   * @dev fallback implementation.
   * Extracted to enable manual triggering.
   */
  function _fallback() internal {
    _willFallback();
    _delegate(_implementation());
  }
}

// Part: BaseUpgradeabilityProxy

/**
 * @title BaseUpgradeabilityProxy
 * @dev This contract implements a proxy that allows to change the
 * implementation address to which it will delegate.
 * Such a change is called an implementation upgrade.
 */
contract BaseUpgradeabilityProxy is Proxy {
  /**
   * @dev Emitted when the implementation is upgraded.
   * @param implementation Address of the new implementation.
   */
  event Upgraded(address indexed implementation);

  /**
   * @dev Storage slot with the address of the current implementation.
   * This is the keccak-256 hash of "eip1967.proxy.implementation" subtracted by 1, and is
   * validated in the constructor.
   */
  bytes32 internal constant IMPLEMENTATION_SLOT =
    0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;

  /**
   * @dev Returns the current implementation.
   * @return impl Address of the current implementation
   */
  function _implementation() internal view override returns (address impl) {
    bytes32 slot = IMPLEMENTATION_SLOT;
    //solium-disable-next-line
    assembly {
      impl := sload(slot)
    }
  }

  /**
   * @dev Upgrades the proxy to a new implementation.
   * @param newImplementation Address of the new implementation.
   */
  function _upgradeTo(address newImplementation) internal {
    _setImplementation(newImplementation);
    emit Upgraded(newImplementation);
  }

  /**
   * @dev Sets the implementation address of the proxy.
   * @param newImplementation Address of the new implementation.
   */
  function _setImplementation(address newImplementation) internal {
    require(
      Address.isContract(newImplementation),
      'Cannot set a proxy implementation to a non-contract address'
    );

    bytes32 slot = IMPLEMENTATION_SLOT;

    //solium-disable-next-line
    assembly {
      sstore(slot, newImplementation)
    }
  }
}

// Part: Ownable

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
contract Ownable is Context {
  address private _owner;

  event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

  /**
   * @dev Initializes the contract setting the deployer as the initial owner.
   */
  constructor() {
    address msgSender = _msgSender();
    _owner = msgSender;
    emit OwnershipTransferred(address(0), msgSender);
  }

  /**
   * @dev Returns the address of the current owner.
   */
  function owner() public view returns (address) {
    return _owner;
  }

  /**
   * @dev Throws if called by any account other than the owner.
   */
  modifier onlyOwner() {
    require(_owner == _msgSender(), 'Ownable: caller is not the owner');
    _;
  }

  /**
   * @dev Leaves the contract without owner. It will not be possible to call
   * `onlyOwner` functions anymore. Can only be called by the current owner.
   *
   * NOTE: Renouncing ownership will leave the contract without an owner,
   * thereby removing any functionality that is only available to the owner.
   */
  function renounceOwnership() public virtual onlyOwner {
    emit OwnershipTransferred(_owner, address(0));
    _owner = address(0);
  }

  /**
   * @dev Transfers ownership of the contract to a new account (`newOwner`).
   * Can only be called by the current owner.
   */
  function transferOwnership(address newOwner) public virtual onlyOwner {
    require(newOwner != address(0), 'Ownable: new owner is the zero address');
    emit OwnershipTransferred(_owner, newOwner);
    _owner = newOwner;
  }
}

// Part: BaseImmutableAdminUpgradeabilityProxy

/**
 * @title BaseImmutableAdminUpgradeabilityProxy
 * @author Aave, inspired by the OpenZeppelin upgradeability proxy pattern
 * @dev This contract combines an upgradeability proxy with an authorization
 * mechanism for administrative tasks. The admin role is stored in an immutable, which
 * helps saving transactions costs
 * All external functions in this contract must be guarded by the
 * `ifAdmin` modifier. See ethereum/solidity#3864 for a Solidity
 * feature proposal that would enable this to be done automatically.
 */
contract BaseImmutableAdminUpgradeabilityProxy is BaseUpgradeabilityProxy {
  address immutable ADMIN;

  constructor(address admin) {
    ADMIN = admin;
  }

  modifier ifAdmin() {
    if (msg.sender == ADMIN) {
      _;
    } else {
      _fallback();
    }
  }

  /**
   * @return The address of the proxy admin.
   */
  function admin() external ifAdmin returns (address) {
    return ADMIN;
  }

  /**
   * @return The address of the implementation.
   */
  function implementation() external ifAdmin returns (address) {
    return _implementation();
  }

  /**
   * @dev Upgrade the backing implementation of the proxy.
   * Only the admin can call this function.
   * @param newImplementation Address of the new implementation.
   */
  function upgradeTo(address newImplementation) external ifAdmin {
    _upgradeTo(newImplementation);
  }

  /**
   * @dev Upgrade the backing implementation of the proxy and call a function
   * on the new implementation.
   * This is useful to initialize the proxied contract.
   * @param newImplementation Address of the new implementation.
   * @param data Data to send as msg.data in the low level call.
   * It should include the signature and the parameters of the function to be called, as described in
   * https://solidity.readthedocs.io/en/v0.4.24/abi-spec.html#function-selector-and-argument-encoding.
   */
  function upgradeToAndCall(address newImplementation, bytes calldata data)
    external
    payable
    ifAdmin
  {
    _upgradeTo(newImplementation);
    (bool success, ) = newImplementation.delegatecall(data);
    require(success);
  }

  /**
   * @dev Only fall back when the sender is not the admin.
   */
  function _willFallback() internal virtual override {
    require(msg.sender != ADMIN, 'Cannot call fallback function from the proxy admin');
    super._willFallback();
  }
}

// Part: InitializableUpgradeabilityProxy

/**
 * @title InitializableUpgradeabilityProxy
 * @dev Extends BaseUpgradeabilityProxy with an initializer for initializing
 * implementation and init data.
 */
contract InitializableUpgradeabilityProxy is BaseUpgradeabilityProxy {
  /**
   * @dev Contract initializer.
   * @param _logic Address of the initial implementation.
   * @param _data Data to send as msg.data to the implementation to initialize the proxied contract.
   * It should include the signature and the parameters of the function to be called, as described in
   * https://solidity.readthedocs.io/en/v0.4.24/abi-spec.html#function-selector-and-argument-encoding.
   * This parameter is optional, if no data is given the initialization call to proxied contract will be skipped.
   */
  function initialize(address _logic, bytes memory _data) public payable {
    require(_implementation() == address(0));
    assert(IMPLEMENTATION_SLOT == bytes32(uint256(keccak256('eip1967.proxy.implementation')) - 1));
    _setImplementation(_logic);
    if (_data.length > 0) {
      (bool success, ) = _logic.delegatecall(_data);
      require(success);
    }
  }
}

// Part: InitializableImmutableAdminUpgradeabilityProxy

/**
 * @title InitializableAdminUpgradeabilityProxy
 * @dev Extends BaseAdminUpgradeabilityProxy with an initializer function
 */
contract InitializableImmutableAdminUpgradeabilityProxy is
  BaseImmutableAdminUpgradeabilityProxy,
  InitializableUpgradeabilityProxy
{
  constructor(address admin) BaseImmutableAdminUpgradeabilityProxy(admin) {}

  /**
   * @dev Only fall back when the sender is not the admin.
   */
  function _willFallback() internal override(BaseImmutableAdminUpgradeabilityProxy, Proxy) {
    BaseImmutableAdminUpgradeabilityProxy._willFallback();
  }
}

// File: LendingPoolAddressesProvider.sol

/**
 * @title LendingPoolAddressesProvider contract
 * @dev Main registry of addresses part of or connected to the protocol, including permissioned roles
 * - Acting also as factory of proxies and admin of those, so with right to change its implementations
 * - Owned by the Aave Governance
 * @author Aave
 **/
contract LendingPoolAddressesProvider is Ownable, ILendingPoolAddressesProvider {
  string private _marketId;
  mapping(bytes32 => address) private _addresses;

  bytes32 private constant LENDING_POOL = 'LENDING_POOL';
  bytes32 private constant LENDING_POOL_CONFIGURATOR = 'LENDING_POOL_CONFIGURATOR';
  bytes32 private constant POOL_ADMIN = 'POOL_ADMIN';
  bytes32 private constant EMERGENCY_ADMIN = 'EMERGENCY_ADMIN';
  bytes32 private constant LENDING_POOL_COLLATERAL_MANAGER = 'COLLATERAL_MANAGER';
  bytes32 private constant PRICE_ORACLE = 'PRICE_ORACLE';
  bytes32 private constant LENDING_RATE_ORACLE = 'LENDING_RATE_ORACLE';

  constructor(string memory marketId) {
    _setMarketId(marketId);
  }

  /**
   * @dev Returns the id of the Aave market to which this contracts points to
   * @return The market id
   **/
  function getMarketId() external view override returns (string memory) {
    return _marketId;
  }

  /**
   * @dev Allows to set the market which this LendingPoolAddressesProvider represents
   * @param marketId The market id
   */
  function setMarketId(string memory marketId) external override onlyOwner {
    _setMarketId(marketId);
  }

  /**
   * @dev General function to update the implementation of a proxy registered with
   * certain `id`. If there is no proxy registered, it will instantiate one and
   * set as implementation the `implementationAddress`
   * IMPORTANT Use this function carefully, only for ids that don't have an explicit
   * setter function, in order to avoid unexpected consequences
   * @param id The id
   * @param implementationAddress The address of the new implementation
   */
  function setAddressAsProxy(bytes32 id, address implementationAddress)
    external
    override
    onlyOwner
  {
    _updateImpl(id, implementationAddress);
    emit AddressSet(id, implementationAddress, true);
  }

  /**
   * @dev Sets an address for an id replacing the address saved in the addresses map
   * IMPORTANT Use this function carefully, as it will do a hard replacement
   * @param id The id
   * @param newAddress The address to set
   */
  function setAddress(bytes32 id, address newAddress) external override onlyOwner {
    _addresses[id] = newAddress;
    emit AddressSet(id, newAddress, false);
  }

  /**
   * @dev Returns an address by id
   * @return The address
   */
  function getAddress(bytes32 id) public view override returns (address) {
    return _addresses[id];
  }

  /**
   * @dev Returns the address of the LendingPool proxy
   * @return The LendingPool proxy address
   **/
  function getLendingPool() external view override returns (address) {
    return getAddress(LENDING_POOL);
  }

  /**
   * @dev Updates the implementation of the LendingPool, or creates the proxy
   * setting the new `pool` implementation on the first time calling it
   * @param pool The new LendingPool implementation
   **/
  function setLendingPoolImpl(address pool) external override onlyOwner {
    _updateImpl(LENDING_POOL, pool);
    emit LendingPoolUpdated(pool);
  }

  /**
   * @dev Returns the address of the LendingPoolConfigurator proxy
   * @return The LendingPoolConfigurator proxy address
   **/
  function getLendingPoolConfigurator() external view override returns (address) {
    return getAddress(LENDING_POOL_CONFIGURATOR);
  }

  /**
   * @dev Updates the implementation of the LendingPoolConfigurator, or creates the proxy
   * setting the new `configurator` implementation on the first time calling it
   * @param configurator The new LendingPoolConfigurator implementation
   **/
  function setLendingPoolConfiguratorImpl(address configurator) external override onlyOwner {
    _updateImpl(LENDING_POOL_CONFIGURATOR, configurator);
    emit LendingPoolConfiguratorUpdated(configurator);
  }

  /**
   * @dev Returns the address of the LendingPoolCollateralManager. Since the manager is used
   * through delegateCall within the LendingPool contract, the proxy contract pattern does not work properly hence
   * the addresses are changed directly
   * @return The address of the LendingPoolCollateralManager
   **/

  function getLendingPoolCollateralManager() external view override returns (address) {
    return getAddress(LENDING_POOL_COLLATERAL_MANAGER);
  }

  /**
   * @dev Updates the address of the LendingPoolCollateralManager
   * @param manager The new LendingPoolCollateralManager address
   **/
  function setLendingPoolCollateralManager(address manager) external override onlyOwner {
    _addresses[LENDING_POOL_COLLATERAL_MANAGER] = manager;
    emit LendingPoolCollateralManagerUpdated(manager);
  }

  /**
   * @dev The functions below are getters/setters of addresses that are outside the context
   * of the protocol hence the upgradable proxy pattern is not used
   **/

  function getPoolAdmin() external view override returns (address) {
    return getAddress(POOL_ADMIN);
  }

  function setPoolAdmin(address admin) external override onlyOwner {
    _addresses[POOL_ADMIN] = admin;
    emit ConfigurationAdminUpdated(admin);
  }

  function getEmergencyAdmin() external view override returns (address) {
    return getAddress(EMERGENCY_ADMIN);
  }

  function setEmergencyAdmin(address emergencyAdmin) external override onlyOwner {
    _addresses[EMERGENCY_ADMIN] = emergencyAdmin;
    emit EmergencyAdminUpdated(emergencyAdmin);
  }

  function getPriceOracle() external view override returns (address) {
    return getAddress(PRICE_ORACLE);
  }

  function setPriceOracle(address priceOracle) external override onlyOwner {
    _addresses[PRICE_ORACLE] = priceOracle;
    emit PriceOracleUpdated(priceOracle);
  }

  function getLendingRateOracle() external view override returns (address) {
    return getAddress(LENDING_RATE_ORACLE);
  }

  function setLendingRateOracle(address lendingRateOracle) external override onlyOwner {
    _addresses[LENDING_RATE_ORACLE] = lendingRateOracle;
    emit LendingRateOracleUpdated(lendingRateOracle);
  }

  /**
   * @dev Internal function to update the implementation of a specific proxied component of the protocol
   * - If there is no proxy registered in the given `id`, it creates the proxy setting `newAdress`
   *   as implementation and calls the initialize() function on the proxy
   * - If there is already a proxy registered, it just updates the implementation to `newAddress` and
   *   calls the initialize() function via upgradeToAndCall() in the proxy
   * @param id The id of the proxy to be updated
   * @param newAddress The address of the new implementation
   **/
  function _updateImpl(bytes32 id, address newAddress) internal {
    address payable proxyAddress = payable(_addresses[id]);

    InitializableImmutableAdminUpgradeabilityProxy proxy =
      InitializableImmutableAdminUpgradeabilityProxy(proxyAddress);
    bytes memory params = abi.encodeWithSignature('initialize(address)', address(this));

    if (proxyAddress == address(0)) {
      proxy = new InitializableImmutableAdminUpgradeabilityProxy(address(this));
      proxy.initialize(newAddress, params);
      _addresses[id] = address(proxy);
      emit ProxyCreated(id, address(proxy));
    } else {
      proxy.upgradeToAndCall(newAddress, params);
    }
  }

  function _setMarketId(string memory marketId) internal {
    _marketId = marketId;
    emit MarketIdSet(marketId);
  }
}

Contract ABI

[{"inputs":[{"internalType":"address","name":"admin","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"implementation","type":"address"}],"name":"Upgraded","type":"event"},{"stateMutability":"payable","type":"fallback"},{"inputs":[],"name":"admin","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"implementation","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_logic","type":"address"},{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"initialize","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"newImplementation","type":"address"}],"name":"upgradeTo","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newImplementation","type":"address"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"upgradeToAndCall","outputs":[],"stateMutability":"payable","type":"function"}]

60a060405234801561001057600080fd5b506040516107733803806107738339818101604052602081101561003357600080fd5b5051606081901b6001600160601b0319166080526001600160a01b03166106f36100806000398061022852806102725280610331528061045e528061048752806105af52506106f36000f3fe60806040526004361061004a5760003560e01c80633659cfe6146100545780634f1ef286146100875780635c60da1b14610107578063d1f5789414610138578063f851a440146101ee575b610052610203565b005b34801561006057600080fd5b506100526004803603602081101561007757600080fd5b50356001600160a01b031661021d565b6100526004803603604081101561009d57600080fd5b6001600160a01b0382351691908101906040810160208201356401000000008111156100c857600080fd5b8201836020820111156100da57600080fd5b803590602001918460018302840111640100000000831117156100fc57600080fd5b509092509050610267565b34801561011357600080fd5b5061011c610324565b604080516001600160a01b039092168252519081900360200190f35b6100526004803603604081101561014e57600080fd5b6001600160a01b03823516919081019060408101602082013564010000000081111561017957600080fd5b82018360208201111561018b57600080fd5b803590602001918460018302840111640100000000831117156101ad57600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250929550610371945050505050565b3480156101fa57600080fd5b5061011c610451565b61020b6104ab565b61021b6102166104b3565b6104d8565b565b336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016141561025c57610257816104fc565b610264565b610264610203565b50565b336001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000161415610317576102a1836104fc565b6000836001600160a01b031683836040518083838082843760405192019450600093509091505080830381855af49150503d80600081146102fe576040519150601f19603f3d011682016040523d82523d6000602084013e610303565b606091505b505090508061031157600080fd5b5061031f565b61031f610203565b505050565b6000336001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614156103665761035f6104b3565b905061036e565b61036e610203565b90565b600061037b6104b3565b6001600160a01b03161461038e57600080fd5b6103978261053c565b80511561044d576000826001600160a01b0316826040518082805190602001908083835b602083106103da5780518252601f1990920191602091820191016103bb565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d806000811461043a576040519150601f19603f3d011682016040523d82523d6000602084013e61043f565b606091505b505090508061031f57600080fd5b5050565b6000336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016141561036657507f000000000000000000000000000000000000000000000000000000000000000061036e565b61021b6105a4565b7f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc5490565b3660008037600080366000845af43d6000803e8080156104f7573d6000f35b3d6000fd5b6105058161053c565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b61054581610614565b6105805760405162461bcd60e51b815260040180806020018281038252603b815260200180610683603b913960400191505060405180910390fd5b7f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc55565b336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016141561060c5760405162461bcd60e51b81526004018080602001828103825260328152602001806106516032913960400191505060405180910390fd5b61021b61021b565b6000813f7fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a47081811480159061064857508115155b94935050505056fe43616e6e6f742063616c6c2066616c6c6261636b2066756e6374696f6e2066726f6d207468652070726f78792061646d696e43616e6e6f742073657420612070726f787920696d706c656d656e746174696f6e20746f2061206e6f6e2d636f6e74726163742061646472657373a2646970667358221220bf4834853c2a80390e05320e5ea68ad10845a8c8f4ab28dd786d9d64e6fea72764736f6c634300070600330000000000000000000000002c2e94ce6a4e5110fe230cc03a54efaec7c2445e

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

0000000000000000000000002c2e94ce6a4e5110fe230cc03a54efaec7c2445e

-----Decoded View---------------
Arg [0] : admin (address): 0x2c2e94ce6a4e5110fe230cc03a54efaec7c2445e

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 0000000000000000000000002c2e94ce6a4e5110fe230cc03a54efaec7c2445e


Deployed ByteCode Sourcemap

16102:455:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6422:11;:9;:11::i;:::-;16102:455;13576:105;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;13576:105:0;-1:-1:-1;;;;;13576:105:0;;:::i;14209:244::-;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;14209:244:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;14209:244:0;;-1:-1:-1;14209:244:0;-1:-1:-1;14209:244:0;:::i;13287:98::-;;;;;;;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;13287:98:0;;;;;;;;;;;;;;15529:373;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;15529:373:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;15529:373:0;;-1:-1:-1;15529:373:0;;-1:-1:-1;;;;;15529:373:0:i;13141:77::-;;;;;;;;;;;;;:::i;8070:93::-;8107:15;:13;:15::i;:::-;8129:28;8139:17;:15;:17::i;:::-;8129:9;:28::i;:::-;8070:93::o;13576:105::-;13011:5;-1:-1:-1;;;;;12997:19:0;:10;:19;12993:77;;;13646:29:::1;13657:17;13646:10;:29::i;:::-;12993:77:::0;;;13051:11;:9;:11::i;:::-;13576:105;:::o;14209:244::-;13011:5;-1:-1:-1;;;;;12997:19:0;:10;:19;12993:77;;;14333:29:::1;14344:17;14333:10;:29::i;:::-;14370:12;14388:17;-1:-1:-1::0;;;;;14388:30:0::1;14419:4;;14388:36;;;;;;;;;;::::0;;::::1;::::0;-1:-1:-1;14388:36:0::1;::::0;-1:-1:-1;14388:36:0;;-1:-1:-1;;14388:36:0;;::::1;::::0;;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14369:55;;;14439:7;14431:16;;;::::0;::::1;;13027:1;12993:77:::0;;;13051:11;:9;:11::i;:::-;14209:244;;;:::o;13287:98::-;13339:7;13011:5;-1:-1:-1;;;;;12997:19:0;:10;:19;12993:77;;;13362:17:::1;:15;:17::i;:::-;13355:24;;12993:77:::0;;;13051:11;:9;:11::i;:::-;13287:98;:::o;15529:373::-;15644:1;15615:17;:15;:17::i;:::-;-1:-1:-1;;;;;15615:31:0;;15607:40;;;;;;15755:26;15774:6;15755:18;:26::i;:::-;15792:12;;:16;15788:109;;15820:12;15838:6;-1:-1:-1;;;;;15838:19:0;15858:5;15838:26;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;15838:26:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15819:45;;;15881:7;15873:16;;;;;15788:109;15529:373;;:::o;13141:77::-;13184:7;13011:5;-1:-1:-1;;;;;12997:19:0;:10;:19;12993:77;;;-1:-1:-1;13207:5:0::1;12993:77:::0;;16399:155;16495:53;:51;:53::i;9119:202::-;8928:66;9298:11;;9281:35::o;6869:840::-;7208:14;7205:1;7202;7189:34;7408:1;7405;7389:14;7386:1;7370:14;7363:5;7350:60;7475:16;7472:1;7469;7454:38;7509:6;7570:58;;;;7669:16;7666:1;7659:27;7570:58;7600:16;7597:1;7590:27;9462:145;9525:37;9544:17;9525:18;:37::i;:::-;9574:27;;-1:-1:-1;;;;;9574:27:0;;;;;;;;9462:145;:::o;9750:346::-;9837:37;9856:17;9837:18;:37::i;:::-;9821:130;;;;-1:-1:-1;;;9821:130:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8928:66;10053:31;10044:47::o;14533:174::-;14613:5;-1:-1:-1;;;;;14599:19:0;:10;:19;;14591:82;;;;-1:-1:-1;;;14591:82:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14680:21;:19;:21::i;876:597::-;936:4;1383:20;;1227:66;1424:23;;;;;;:42;;-1:-1:-1;1451:15:0;;;1424:42;1416:51;876:597;-1:-1:-1;;;;876:597:0:o

Swarm Source

ipfs://bf4834853c2a80390e05320e5ea68ad10845a8c8f4ab28dd786d9d64e6fea727
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Block Uncle Number Difficulty Gas Used Reward
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.