Contract 0x9fad24f572045c7869117160a571b2e50b10d068 2

Txn Hash Method
Block
From
To
Value [Txn Fee]
0xdc5bdb896e1f391074037f80d6b10d90ae704be23f0f256342efe8ab14df23caDeposit195739882021-10-20 8:40:4922 mins ago0x84c298cdfa2a4f1758c5989692c6c3c91e9fd024 IN  Geist Lending Pool0 FTM0.096898186971
0x9f5e5bc5bda937cda332c13baf1b5305c6e18c185792418903a5ea81055e2bbdWithdraw195739412021-10-20 8:40:1423 mins ago0xe5a25a48c65a044341bca3829243c9232935b8dc IN  Geist Lending Pool0 FTM0.154103433151
0xa36a35bace7c413d099b6697e5d3785af71920f0776981b72293a3dce9db0384Deposit195738212021-10-20 8:38:3624 mins ago0xc49a9687dd62a4eb30226f3b243626eba6b7387d IN  Geist Lending Pool0 FTM0.127061956735
0xd7d4e34945eb59774cdcacf40a25bc1d1292c77c8933ba6563110a9bb35038dbRepay195736952021-10-20 8:36:5126 mins ago0x18da60ee9db6865b0a1d6d232fb93e3bf466ae67 IN  Geist Lending Pool0 FTM0.138281283787
0xa5b7a0c0756632ba1c00087b3558e41502cac5d423284fbaa5d5a279f92cff05Repay195736072021-10-20 8:35:4027 mins ago0xbff36b0e434f7ddd28c523571c3b9f93f60132f6 IN  Geist Lending Pool0 FTM0.151276805089
0x4b38df625160d3730cd88c6e567fbbfa324880d1bcc4b6e00cc2a52bbcd01585Deposit195736062021-10-20 8:35:3927 mins ago0xcfb523e598e5d9fc18ca8798996c43475478c1ed IN  Geist Lending Pool0 FTM0.153236426928
0xf61e6edb27a0853e61d46e28d0e1ad2238db9222b3911709349d2d0e768bd03dBorrow195735912021-10-20 8:35:2627 mins ago0x4d6afe95850212a15ff41038c3d836a81a11cd10 IN  Geist Lending Pool0 FTM0.120963709193
0x95386a3d94cc58841530dd40ae0646a8c2ac405a50329b24a43abc8b82fbfcb1Withdraw195735622021-10-20 8:34:5828 mins ago0xf8519302749ff98990e9627d0c23ff28b757e2b3 IN  Geist Lending Pool0 FTM0.196471903455
0x12d347902cd1e05f421242d72f770d98e0760b5cf3d656c79d6083a54d7e9310Withdraw195735262021-10-20 8:34:2428 mins ago0xf8519302749ff98990e9627d0c23ff28b757e2b3 IN  Geist Lending Pool0 FTM0.205292967094
0x49d9f1dde0486dc7ec070759de320e4c0a1b5e026f5d824bc54f4e52ef374527Borrow195735202021-10-20 8:34:1929 mins ago0xbff36b0e434f7ddd28c523571c3b9f93f60132f6 IN  Geist Lending Pool0 FTM0.23242416449
0x47f6327c3e1503e53aa918312546dcddd9395f4fadd9164c962384aed57e3430Withdraw195734952021-10-20 8:33:5729 mins ago0xf8519302749ff98990e9627d0c23ff28b757e2b3 IN  Geist Lending Pool0 FTM0.218228582428
0x988647eddec4e47fbb81cef2b0b42f640feca0ad8775d874bc640b6e6ac94dedWithdraw195734742021-10-20 8:33:4029 mins ago0xf8519302749ff98990e9627d0c23ff28b757e2b3 IN  Geist Lending Pool0 FTM0.237970911349
0x068cf0e381fffe4ba3a3585b900c598c2d2e081fc18a66923ee28a0e84e2576fWithdraw195734422021-10-20 8:33:0430 mins ago0x04eaf5de988573be402bdf05f68325e6b7f30ad2 IN  Geist Lending Pool0 FTM0.130912534089
0x4bc7aa2166a5e5cd5a3c687ad3ff20396bef4bdae99470cd9d71c3a1966af01dBorrow195734362021-10-20 8:32:5630 mins ago0xa809a233f33921e46869ced49283fe6c90563256 IN  Geist Lending Pool0 FTM0.137578921498
0x7b51f0b424ea70cdb5c564203b02bb2dc498eb5d360fc20e6c38ca48af8ada5eRepay195733902021-10-20 8:32:0131 mins ago0xa3ee6f6ee35a92e66d7790cba9848a2777f605cb IN  Geist Lending Pool0 FTM0.143222127631
0x03d1b7131b3bcbf0c8b40f235ff313c7c043c192a2eb75726a995b1ac2cd7605Withdraw195733352021-10-20 8:31:0632 mins ago0xfb97f58b605dc1f324bdcb7bbb06f7262b43c2d2 IN  Geist Lending Pool0 FTM0.120666519355
0x7137d454943bb89a7cb26dca08974f058e20b280198c8571ce0ae7db342d8c97Deposit195733342021-10-20 8:31:0632 mins ago0xe4388e3dc6c52795afa14cbe867abeaba635c32a IN  Geist Lending Pool0 FTM0.08742922337
0xd7f74229f3502e65bf240e4555de479d7b7e003c6ef5f8ddb382c2eb8142c1a4Withdraw195733312021-10-20 8:31:0132 mins ago0xe5a25a48c65a044341bca3829243c9232935b8dc IN  Geist Lending Pool0 FTM0.147144427007
0x923c9c7f42ce389c983268323fe58c4733ecc8b63fcc378c41e389254a16a941Borrow195733152021-10-20 8:30:4432 mins ago0x3465d93b84ed7557d42d84cb7c8999fc3db2113d IN  Geist Lending Pool0 FTM0.244741409974
0xf674430fd8b3c53c6604cb550ef720cba2043863f3bdb33a5136965a600ebeb3Withdraw195733102021-10-20 8:30:3832 mins ago0xd4ee113548dd66913dff6743e9b89e9fca7e4ead IN  Geist Lending Pool0 FTM0.220884023818
0x9833d43fe3b1ecc260946de227d084b1b6745957d3e160cc7dc623151868434fWithdraw195733022021-10-20 8:30:3132 mins ago0xfb97f58b605dc1f324bdcb7bbb06f7262b43c2d2 IN  Geist Lending Pool0 FTM0.135990859228
0x5ddea865aaef480db01282f28819c5ab3f1ab1f524889a0324a66e2913a00b5dWithdraw195733002021-10-20 8:30:2632 mins ago0x3ddfa8ec3052539b6c9549f12cea2c295cff5296 IN  Geist Lending Pool0 FTM0.2699528
0x71f5b3efc54f01622d5c2461af4ec45147c2c3abcab55a162bf2ebf44dd35254Borrow195732732021-10-20 8:30:0433 mins ago0xac98d52eff08d2bf9cb82d22343fb2b6996a1ead IN  Geist Lending Pool0 FTM0.149290746
0xba278d97c04190d439ca28c404833c2605a2ebb516fca1abcc4c3157e280510fRepay195732692021-10-20 8:30:0133 mins ago0xd4ee113548dd66913dff6743e9b89e9fca7e4ead IN  Geist Lending Pool0 FTM0.145240330893
0x82ca5bff32ad42d4ccbad7b1063787335322c6b7879f77391f9c4f9eb24f1cbaRepay195732352021-10-20 8:29:3733 mins ago0xfb97f58b605dc1f324bdcb7bbb06f7262b43c2d2 IN  Geist Lending Pool0 FTM0.145342427069
[ Download CSV Export 
Latest 3 internal transactions
[ Download CSV Export 
Loading

Contract Source Code Verified (Similar Match)
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.