ERC1967Proxy.sol 1.6 KB

123456789101112131415161718192021222324252627282930313233343536
  1. // SPDX-License-Identifier: MIT
  2. // OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)
  3. pragma solidity ^0.8.19;
  4. import {Proxy} from "../Proxy.sol";
  5. import {ERC1967Utils} from "./ERC1967Utils.sol";
  6. /**
  7. * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an
  8. * implementation address that can be changed. This address is stored in storage in the location specified by
  9. * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the
  10. * implementation behind the proxy.
  11. */
  12. contract ERC1967Proxy is Proxy {
  13. /**
  14. * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.
  15. *
  16. * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded
  17. * function call, and allows initializing the storage of the proxy like a Solidity constructor.
  18. */
  19. constructor(address _logic, bytes memory _data) payable {
  20. ERC1967Utils.upgradeToAndCall(_logic, _data, false);
  21. }
  22. /**
  23. * @dev Returns the current implementation address.
  24. *
  25. * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the
  26. * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.
  27. * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`
  28. */
  29. function _implementation() internal view virtual override returns (address impl) {
  30. return ERC1967Utils.getImplementation();
  31. }
  32. }