Contract 0x9fad24f572045c7869117160a571b2e50b10d068 4

 

Contract Overview

Geist Finance: Lending Pool
Balance:
0 FTM

FTM Value:
$0.00

Token:
Txn Hash Method
Block
From
To
Value [Txn Fee]
0x823438e06ac42f06efb5662e5c36012592193ae224cdb55a1c69b1d9b5f93406Deposit450089142022-08-16 6:03:403 mins ago0x933258bddd49beeca77f6d1889633c5429af45ea IN  Geist Finance: Lending Pool0 FTM0.002628257109
0x5db844de9ee197c90dff7cca432ec9b5a6a31e981c9ee477ee239944058e1f47Borrow450073332022-08-16 5:29:5137 mins ago0xc00a6614b8030ce216302016e11c6b4140b5e499 IN  Geist Finance: Lending Pool0 FTM0.008142932
0xd0b37efec9a9c8298aa524f86cd35a971060c0dd385147e3d4b1ce595b66cfa7Withdraw450069832022-08-16 5:23:1643 mins ago0xa909be1ac709bc08bd8cd69604cee197360b3e33 IN  Geist Finance: Lending Pool0 FTM0.0022384
0xa082840711afba027007a4d1f37b9d6bd09aea8580c201b66f52e3168864898cWithdraw450069442022-08-16 5:22:3144 mins ago0xf61d6742eea5e1f29cb4b96cf7108f32424d562c IN  Geist Finance: Lending Pool0 FTM0.002233165
0x63e45fc9a9db916fe5c2eb204bce0b63461f05de0ea21f98ed34e63b71fa6c99Withdraw450068782022-08-16 5:21:2045 mins ago0xf61d6742eea5e1f29cb4b96cf7108f32424d562c IN  Geist Finance: Lending Pool0 FTM0.0028212
0x9a66710203fdfaeaa617c435863388ee501f416058114d1f638c6b36da6a45deRepay450067602022-08-16 5:19:1347 mins ago0x1b6617959114a29d97e1ab8949ebc78ea804275e IN  Geist Finance: Lending Pool0 FTM0.002261625
0xfdb9aeefe6826a90d2bd4a560936b056f1ec5b414ddde3e5bda07291581a9beeWithdraw450067402022-08-16 5:18:5248 mins ago0x7804c5f4fd50f7c12845e2951e24858b8c270e35 IN  Geist Finance: Lending Pool0 FTM0.002913431884
0x2a97cf285b850bb1d16ed912f8e407bcf6d0ff0174b661e403e36649ff0753b6Withdraw450065822022-08-16 5:15:2051 mins ago0xfb15c3af09fbf8a39a587c4ed137ee5737d7166b IN  Geist Finance: Lending Pool0 FTM0.002245545873
0x92ba3dbe2cd84e19b4e938521f76c93da756e41757566c32f2b335103b2e23f0Withdraw450065012022-08-16 5:13:3353 mins ago0xfb15c3af09fbf8a39a587c4ed137ee5737d7166b IN  Geist Finance: Lending Pool0 FTM0.002278892006
0xe4efc613dd5a8bf5473d211e4b73bf4b7c6c638d639e44f9056885850994c459Withdraw450064792022-08-16 5:13:0853 mins ago0xfb15c3af09fbf8a39a587c4ed137ee5737d7166b IN  Geist Finance: Lending Pool0 FTM0.002704044166
0x7287b3d8b5b9a213b139ecd62b8d076deff5e5cc3e8a2b0f8ae5ffbdbe86d0d4Repay450053922022-08-16 4:51:471 hr 15 mins ago0x5b3067c5e26fec823d6fbf8f315e43632658d2f6 IN  Geist Finance: Lending Pool0 FTM0.002347747357
0x37fbdc89d17cdadc7416ba131819063c68f7a7b6e8dc961efcfafe5ca53d28f9Borrow450049902022-08-16 4:43:281 hr 23 mins ago0x31d56454a6a8b8e51f98824bfbc6580486e51fd9 IN  Geist Finance: Lending Pool0 FTM0.003319124615
0xd9d8d56d33452d8aa47aa27b22bf44530fb5e4d192ffbe4e8cd39d8ed8c0f153Repay450049082022-08-16 4:41:561 hr 25 mins ago0x31d56454a6a8b8e51f98824bfbc6580486e51fd9 IN  Geist Finance: Lending Pool0 FTM0.002344400347
0x452b3d2ae467c77678c8c651a9248278402d20000e981d50141316e5a522dfe5Borrow450047802022-08-16 4:38:431 hr 28 mins ago0x31d56454a6a8b8e51f98824bfbc6580486e51fd9 IN  Geist Finance: Lending Pool0 FTM0.003175556843
0xd04ad4bd7effa9ced223981fc5a078b5893b98364837346a93821b50839eafe5Repay450046482022-08-16 4:36:131 hr 30 mins ago0x1b6617959114a29d97e1ab8949ebc78ea804275e IN  Geist Finance: Lending Pool0 FTM0.002376926553
0x57e8a199995b5db6d36b878f62235eb038683251658d6eaba692cd6906d894adDeposit450037212022-08-16 4:18:181 hr 48 mins ago0x31d56454a6a8b8e51f98824bfbc6580486e51fd9 IN  Geist Finance: Lending Pool0 FTM0.002368428174
0x4eaaf42679a9f50c3ffe62b4a17e1d607d0015c16a7c087ac345e14bbacacd55Deposit450017982022-08-16 3:40:242 hrs 26 mins ago0x3d6991085ab1ae3926cb96f25684c40a364b6856 IN  Geist Finance: Lending Pool0 FTM0.003282968776
0xd1f2713358430f3ad14a38d1ecead3bf5ec0cbd20195461f4cd767802dcdf19fWithdraw450016782022-08-16 3:38:062 hrs 29 mins ago0x4396e02c0a70e0aa26b7f07eb011cb6c59d7a7eb IN  Geist Finance: Lending Pool0 FTM0.002960836399
0x6105875e4f251eb58c368255ec07a893a5fdf5a49381772e5d2f8e46223c3b51Deposit449999632022-08-16 3:00:003 hrs 7 mins ago0x4d3869e2451d28bb4f03aeda60322eaf01e912db IN  Geist Finance: Lending Pool0 FTM0.13893176
0x52958f278331aecb94a696ee27084a5ff8cd62bd87aa039eebbc01d6005745d7Repay449999562022-08-16 2:59:433 hrs 7 mins ago0x4d3869e2451d28bb4f03aeda60322eaf01e912db IN  Geist Finance: Lending Pool0 FTM0.14775728
0xe67c8b354e4e56f84353028360aef4d55482ec091d6100a5f08d5c85fa61eae8Borrow449998652022-08-16 2:57:303 hrs 9 mins ago0xa6a2d935363669ea08723798284bc3fcdc58f9cd IN  Geist Finance: Lending Pool0 FTM0.314919245142
0x3f9b830618e72b7062b3601e729c3ec23e7542299a8c4e8de3ca241b4c571802Repay449998362022-08-16 2:56:393 hrs 10 mins ago0x4d3869e2451d28bb4f03aeda60322eaf01e912db IN  Geist Finance: Lending Pool0 FTM0.146917056
0x76c94c8038f3ac359d53f19e406165685fa6bd1c209ed0fa0f30a2efa68fa1e6Withdraw449997892022-08-16 2:55:483 hrs 11 mins ago0x4d3869e2451d28bb4f03aeda60322eaf01e912db IN  Geist Finance: Lending Pool0 FTM0.294554128
0xdfbfe2a99f9c54ab354090a527396c775d58e5d2ebed586670397867fa30d5d1Withdraw449978882022-08-16 2:16:563 hrs 50 mins ago0x5c7ab8a5f02acc6bb9d1f5304c588bf8472ffc86 IN  Geist Finance: Lending Pool0 FTM0.0022388925
0x8e6ea272d0d9644f494f17882dd46decb3bfd9e3addc147c6477e10b481aeee5Withdraw449978642022-08-16 2:16:303 hrs 50 mins ago0x5c7ab8a5f02acc6bb9d1f5304c588bf8472ffc86 IN  Geist Finance: Lending Pool0 FTM0.002238715
[ Download CSV Export 
Latest 1 internal transaction
Parent Txn Hash Block From To Value
0x76d32ddeac8cdef6c993b89057c204d0e6d0accd8a3a56bce3fb882ba8c649ab183996912021-10-06 1:15:10314 days 4 hrs 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.