Contract 0x9fad24f572045c7869117160a571b2e50b10d068 4

 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0x9bdbde5ac3073df409df6edaf95294ba94c5b169b5c4ea7060f15b561376f1e9Borrow553013992023-02-08 0:58:241 hr 55 mins ago0xaa40cb43f78b97701d0e5981d83822ed77dd57e9 IN  Geist Finance: Lending Pool0 FTM0.239426400168
0x616cd91edecd1543784470df468dfcbd8649df25a13f5784050bdc2bbc4fddfbWithdraw553007792023-02-08 0:48:102 hrs 5 mins ago0x3309cfac19795ba74377d0471f0f1facc9483c7e IN  Geist Finance: Lending Pool0 FTM0.189351525912
0x01779cead71e9f220602b4392d6a4718125f46c2f3557d1c352c9103e92d51f1Withdraw553007402023-02-08 0:47:352 hrs 6 mins ago0x3c5a62e6153c5d36a41c7599656e3acdb98f9a21 IN  Geist Finance: Lending Pool0 FTM0.362645784
0x10706a1b1623c1edabcd41992b29e72655a95eacbda87a8acae2f04c246f2e43Repay553006622023-02-08 0:46:202 hrs 7 mins ago0x0db3dbd610cb235bb4858660aa1823c664661aa4 IN  Geist Finance: Lending Pool0 FTM0.178849995
0x850b22414977fdb924561ce370bc742bce56569a2234180d902478864bc8a966Deposit553006552023-02-08 0:46:142 hrs 7 mins ago0x72495d2dd7f0b1efd05ee76a1c582801386a9320 IN  Geist Finance: Lending Pool0 FTM0.155835632372
0x734b8fb7a5fc4426a85d44d9e2ba1bb722a5adcf3fce351b234f0f703111aeb5Repay553005812023-02-08 0:44:532 hrs 8 mins ago0xc9ce22634703ec7c430d620ec267b3e042d2b881 IN  Geist Finance: Lending Pool0 FTM0.145704762288
0x452fce5c6a01af26c78fde608296a05b9d58b60587c6179611630d36fa748fa0Deposit553005382023-02-08 0:44:082 hrs 9 mins ago0x6e4084315030747edd36e5780e0f4e6879d9a1db IN  Geist Finance: Lending Pool0 FTM0.160885948509
0x69e447d0be4d317ad89795aece47a95e033ae4a0cbbe9cf8da012d4e037b5fa2Borrow553003732023-02-08 0:40:452 hrs 12 mins ago0x3c5a62e6153c5d36a41c7599656e3acdb98f9a21 IN  Geist Finance: Lending Pool0 FTM0.308372736
0xbfae0ca1a64396e868292f0ba8992042dd81ac582b743d28fdac38a39a148eefWithdraw552993462023-02-08 0:22:082 hrs 31 mins ago0x1654515c7ccd0a148e8c3724a161b93d656c4684 IN  Geist Finance: Lending Pool0 FTM0.203248802319
0xe3de085299240e492394191e94a0bf9991005632300849ee3ede34b8192b3b70Repay552983342023-02-08 0:04:482 hrs 48 mins ago0xac116d5c076f346691f334954e583df580bd50c9 IN  Geist Finance: Lending Pool0 FTM0.184787890097
0x6168b0a867ae718c7894fc97b53ddcf0cdb52bcae53446a5f42635d93fb11dd8Borrow552980452023-02-07 23:58:402 hrs 54 mins ago0xd2d281a66855977a337ca1bb9bf0ac07249538c7 IN  Geist Finance: Lending Pool0 FTM0.154987505639
0xc2404c09945561a300d11b5f256a417eb600a0ddb904b8559b3f4e2db5a2ba43Withdraw552980452023-02-07 23:58:402 hrs 54 mins ago0x32144a3f0ed8145aa42896a811c7a7ceb1717f24 IN  Geist Finance: Lending Pool0 FTM0.191459343875
0x5db2bef6440792a068ceab9952a1bf79301fe7b83e2aeca63b6b1118951e6dd8Withdraw552980342023-02-07 23:58:202 hrs 55 mins ago0x32144a3f0ed8145aa42896a811c7a7ceb1717f24 IN  Geist Finance: Lending Pool0 FTM0.082743385854
0x30a154eeabe3561fbb6b4e599c7466fe7efe117e1edff91bfad69865401d3ba1Withdraw552980152023-02-07 23:57:552 hrs 55 mins ago0x32144a3f0ed8145aa42896a811c7a7ceb1717f24 IN  Geist Finance: Lending Pool0 FTM0.13628001694
0xf06859e7b868c59936b50c824af38c80077ca98d08f7e73c58038ece383ebd17Withdraw552970642023-02-07 23:41:093 hrs 12 mins ago0xb64c4f9ea00a1b8508e855773174b8a4520a41a4 IN  Geist Finance: Lending Pool0 FTM0.098669257028
0x671c61be9c6e2be3ee6891c3712aae74c0f64032e5ae487b4c953527311d445eWithdraw552970162023-02-07 23:40:183 hrs 13 mins ago0xd29932d75b4c7ddce52d9c99262be05252951b42 IN  Geist Finance: Lending Pool0 FTM0.154528879594
0x215a214f9b6bed0ad5ce76a31ec26c123a8210432ccd9f88e99740314e4446c3Borrow552969732023-02-07 23:39:403 hrs 13 mins ago0xd29932d75b4c7ddce52d9c99262be05252951b42 IN  Geist Finance: Lending Pool0 FTM0.159116231372
0xb382c357308a38016489725b48c491dbe1e71e5adf1616c1a8860aa2d8739882Withdraw552969652023-02-07 23:39:253 hrs 14 mins ago0xa049afef83d112f9b9ac4e9d743c50ad08ebee01 IN  Geist Finance: Lending Pool0 FTM0.078186607682
0xade186764027c68e1090e856c132bb7e916740c395aa24468deb7e8aeb150734Deposit552969412023-02-07 23:39:033 hrs 14 mins ago0xd29932d75b4c7ddce52d9c99262be05252951b42 IN  Geist Finance: Lending Pool0 FTM0.074960720205
0x1ba7f34709cf05bd19ddf2105a90ef604757d5ac26bd234c7bd584a95b8dfe79Borrow552969242023-02-07 23:38:473 hrs 14 mins ago0xd29932d75b4c7ddce52d9c99262be05252951b42 IN  Geist Finance: Lending Pool0 FTM0.157524207436
0x437497ddcf929462fd0074be3bb2d623031f081bd60961426aad361e62bf2e95Repay552969012023-02-07 23:38:253 hrs 15 mins ago0xa049afef83d112f9b9ac4e9d743c50ad08ebee01 IN  Geist Finance: Lending Pool0 FTM0.079198275897
0x64fe0b4ff1f0f20586a53cbfdcf754e27de4cd5809b6eff8767ad7e763ba41c5Borrow552968672023-02-07 23:37:553 hrs 15 mins ago0xd29932d75b4c7ddce52d9c99262be05252951b42 IN  Geist Finance: Lending Pool0 FTM0.15884063262
0x08fca5e4125efcb6607ca886016fb196ddeb9bd367dfac933ee3b4918d4c6bb8Deposit552968572023-02-07 23:37:463 hrs 15 mins ago0xd29932d75b4c7ddce52d9c99262be05252951b42 IN  Geist Finance: Lending Pool0 FTM0.074971356087
0xee979b08bc9a66fd14b98502994f0a875b6b1c777d8ff0142dc76f62770c8da1Deposit552968472023-02-07 23:37:363 hrs 16 mins ago0xb64c4f9ea00a1b8508e855773174b8a4520a41a4 IN  Geist Finance: Lending Pool0 FTM0.065661458559
0x1ed2678def88f45669fbb03f79194fa74dc335481918b986a7623101961af6ddWithdraw552968342023-02-07 23:37:243 hrs 16 mins ago0x73ef2f1b0dbca5b4d6828195907066ce6264af3e IN  Geist Finance: Lending Pool0 FTM0.108983566
[ Download CSV Export 
Latest 1 internal transaction
Parent Txn Hash Block From To Value
0x76d32ddeac8cdef6c993b89057c204d0e6d0accd8a3a56bce3fb882ba8c649ab183996912021-10-06 1:15:10490 days 1 hr ago Geist Finance: Lending Pool Provider  Contract Creation0 FTM
[ Download CSV Export 
Loading

Similar Match Source Code
Note: This contract matches the deployed ByteCode of the Source Code for Contract 0xb7C10e5089d3fd281F51998543510675A52B6aa8

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 FtmScan.com on 2021-10-06
*/

/**
 *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 Security Audit

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"}]

60a060405234801561001057600080fd5b506040516107733803806107738339818101604052602081101561003357600080fd5b5051606081901b6001600160601b0319166080526001600160a01b03166106f36100806000398061022852806102725280610331528061045e528061048752806105af52506106f36000f3fe60806040526004361061004a5760003560e01c80633659cfe6146100545780634f1ef286146100875780635c60da1b14610107578063d1f5789414610138578063f851a440146101ee575b610052610203565b005b34801561006057600080fd5b506100526004803603602081101561007757600080fd5b50356001600160a01b031661021d565b6100526004803603604081101561009d57600080fd5b6001600160a01b0382351691908101906040810160208201356401000000008111156100c857600080fd5b8201836020820111156100da57600080fd5b803590602001918460018302840111640100000000831117156100fc57600080fd5b509092509050610267565b34801561011357600080fd5b5061011c610324565b604080516001600160a01b039092168252519081900360200190f35b6100526004803603604081101561014e57600080fd5b6001600160a01b03823516919081019060408101602082013564010000000081111561017957600080fd5b82018360208201111561018b57600080fd5b803590602001918460018302840111640100000000831117156101ad57600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250929550610371945050505050565b3480156101fa57600080fd5b5061011c610451565b61020b6104ab565b61021b6102166104b3565b6104d8565b565b336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016141561025c57610257816104fc565b610264565b610264610203565b50565b336001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000161415610317576102a1836104fc565b6000836001600160a01b031683836040518083838082843760405192019450600093509091505080830381855af49150503d80600081146102fe576040519150601f19603f3d011682016040523d82523d6000602084013e610303565b606091505b505090508061031157600080fd5b5061031f565b61031f610203565b505050565b6000336001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614156103665761035f6104b3565b905061036e565b61036e610203565b90565b600061037b6104b3565b6001600160a01b03161461038e57600080fd5b6103978261053c565b80511561044d576000826001600160a01b0316826040518082805190602001908083835b602083106103da5780518252601f1990920191602091820191016103bb565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d806000811461043a576040519150601f19603f3d011682016040523d82523d6000602084013e61043f565b606091505b505090508061031f57600080fd5b5050565b6000336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016141561036657507f000000000000000000000000000000000000000000000000000000000000000061036e565b61021b6105a4565b7f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc5490565b3660008037600080366000845af43d6000803e8080156104f7573d6000f35b3d6000fd5b6105058161053c565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b61054581610614565b6105805760405162461bcd60e51b815260040180806020018281038252603b815260200180610683603b913960400191505060405180910390fd5b7f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc55565b336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016141561060c5760405162461bcd60e51b81526004018080602001828103825260328152602001806106516032913960400191505060405180910390fd5b61021b61021b565b6000813f7fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a47081811480159061064857508115155b94935050505056fe43616e6e6f742063616c6c2066616c6c6261636b2066756e6374696f6e2066726f6d207468652070726f78792061646d696e43616e6e6f742073657420612070726f787920696d706c656d656e746174696f6e20746f2061206e6f6e2d636f6e74726163742061646472657373a2646970667358221220638dac581bb3ce605814b9da93de7342fb960b7455dc63eb70b4d61449e6e70c64736f6c634300070600330000000000000000000000006c793c628fe2b480c5e6fb7957dda4b9291f9c9b

Deployed ByteCode Sourcemap

16031:455:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6351:11;:9;:11::i;:::-;16031:455;13505:105;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;13505:105:0;-1:-1:-1;;;;;13505:105:0;;:::i;14138:244::-;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;14138:244:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;14138:244:0;;-1:-1:-1;14138:244:0;-1:-1:-1;14138:244:0;:::i;13216:98::-;;;;;;;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;13216:98:0;;;;;;;;;;;;;;15458:373;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;15458:373:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;15458:373:0;;-1:-1:-1;15458:373:0;;-1:-1:-1;;;;;15458:373:0:i;13070:77::-;;;;;;;;;;;;;:::i;7999:93::-;8036:15;:13;:15::i;:::-;8058:28;8068:17;:15;:17::i;:::-;8058:9;:28::i;:::-;7999:93::o;13505:105::-;12940:5;-1:-1:-1;;;;;12926:19:0;:10;:19;12922:77;;;13575:29:::1;13586:17;13575:10;:29::i;:::-;12922:77:::0;;;12980:11;:9;:11::i;:::-;13505:105;:::o;14138:244::-;12940:5;-1:-1:-1;;;;;12926:19:0;:10;:19;12922:77;;;14262:29:::1;14273:17;14262:10;:29::i;:::-;14299:12;14317:17;-1:-1:-1::0;;;;;14317:30:0::1;14348:4;;14317:36;;;;;;;;;;::::0;;::::1;::::0;-1:-1:-1;14317:36:0::1;::::0;-1:-1:-1;14317:36:0;;-1:-1:-1;;14317:36:0;;::::1;::::0;;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14298:55;;;14368:7;14360:16;;;::::0;::::1;;12956:1;12922:77:::0;;;12980:11;:9;:11::i;:::-;14138:244;;;:::o;13216:98::-;13268:7;12940:5;-1:-1:-1;;;;;12926:19:0;:10;:19;12922:77;;;13291:17:::1;:15;:17::i;:::-;13284:24;;12922:77:::0;;;12980:11;:9;:11::i;:::-;13216:98;:::o;15458:373::-;15573:1;15544:17;:15;:17::i;:::-;-1:-1:-1;;;;;15544:31:0;;15536:40;;;;;;15684:26;15703:6;15684:18;:26::i;:::-;15721:12;;:16;15717:109;;15749:12;15767:6;-1:-1:-1;;;;;15767:19:0;15787:5;15767:26;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;15767:26:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15748:45;;;15810:7;15802:16;;;;;15717:109;15458:373;;:::o;13070:77::-;13113:7;12940:5;-1:-1:-1;;;;;12926:19:0;:10;:19;12922:77;;;-1:-1:-1;13136:5:0::1;12922:77:::0;;16328:155;16424:53;:51;:53::i;9048:202::-;8857:66;9227:11;;9210:35::o;6798:840::-;7137:14;7134:1;7131;7118:34;7337:1;7334;7318:14;7315:1;7299:14;7292:5;7279:60;7404:16;7401:1;7398;7383:38;7438:6;7499:58;;;;7598:16;7595:1;7588:27;7499:58;7529:16;7526:1;7519:27;9391:145;9454:37;9473:17;9454:18;:37::i;:::-;9503:27;;-1:-1:-1;;;;;9503:27:0;;;;;;;;9391:145;:::o;9679:346::-;9766:37;9785:17;9766:18;:37::i;:::-;9750:130;;;;-1:-1:-1;;;9750:130:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8857:66;9982:31;9973:47::o;14462:174::-;14542:5;-1:-1:-1;;;;;14528:19:0;:10;:19;;14520:82;;;;-1:-1:-1;;;14520:82:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14609:21;:19;:21::i;805:597::-;865:4;1312:20;;1156:66;1353:23;;;;;;:42;;-1:-1:-1;1380:15:0;;;1353:42;1345:51;805:597;-1:-1:-1;;;;805:597:0:o

Swarm Source

ipfs://638dac581bb3ce605814b9da93de7342fb960b7455dc63eb70b4d61449e6e70c
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Validator ID :
0 FTM

Amount Staked
0

Amount Delegated
0

Staking Total
0

Staking Start Epoch
0

Staking Start Time
0

Proof of Importance
0

Origination Score
0

Validation Score
0

Active
0

Online
0

Downtime
0 s
Address Amount claimed Rewards Created On Epoch Created On
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.