From 32be69a670046cd46587b69571240b3aaffc5844 Mon Sep 17 00:00:00 2001 From: Alain Nicolas Date: Mon, 18 Sep 2023 14:27:29 +0200 Subject: [PATCH] fix: Portal should not be initializable/upgradeable --- src/PortalRegistry.sol | 3 +-- src/example/EASPortal.sol | 2 ++ src/interface/AbstractPortal.sol | 14 ++++++-------- src/portal/DefaultPortal.sol | 2 ++ test/PortalRegistry.t.sol | 2 +- test/example/EASPortal.t.sol | 7 +------ test/integration/AttestationRegistryMass.t.sol | 3 +-- test/mocks/ValidPortalMock.sol | 2 ++ test/portal/DefaultPortal.t.sol | 17 +++-------------- 9 files changed, 19 insertions(+), 33 deletions(-) diff --git a/src/PortalRegistry.sol b/src/PortalRegistry.sol index e602e2ce..e77172b3 100644 --- a/src/PortalRegistry.sol +++ b/src/PortalRegistry.sol @@ -157,8 +157,7 @@ contract PortalRegistry is OwnableUpgradeable { bool isRevocable, string memory ownerName ) external onlyIssuers(msg.sender) { - DefaultPortal defaultPortal = new DefaultPortal(); - defaultPortal.initialize(modules, address(router)); + DefaultPortal defaultPortal = new DefaultPortal(modules, address(router)); register(address(defaultPortal), name, description, isRevocable, ownerName); } diff --git a/src/example/EASPortal.sol b/src/example/EASPortal.sol index a3b22af4..6687b0ce 100644 --- a/src/example/EASPortal.sol +++ b/src/example/EASPortal.sol @@ -38,6 +38,8 @@ contract EASPortal is AbstractPortal { /// @notice Error thrown when trying to bulk revoke attestations error NoBulkRevocation(); + constructor(address[] memory modules, address router) AbstractPortal(modules, router) {} + function withdraw(address payable to, uint256 amount) external override {} function attest(AttestationRequest memory attestationRequest) public payable { diff --git a/src/interface/AbstractPortal.sol b/src/interface/AbstractPortal.sol index 11637aa0..aea0fa18 100644 --- a/src/interface/AbstractPortal.sol +++ b/src/interface/AbstractPortal.sol @@ -5,12 +5,10 @@ import { AttestationRegistry } from "../AttestationRegistry.sol"; import { ModuleRegistry } from "../ModuleRegistry.sol"; import { PortalRegistry } from "../PortalRegistry.sol"; import { AttestationPayload } from "../types/Structs.sol"; -// solhint-disable-next-line max-line-length -import { IERC165Upgradeable } from "openzeppelin-contracts-upgradeable/contracts/utils/introspection/ERC165Upgradeable.sol"; -import { Initializable } from "openzeppelin-contracts-upgradeable/contracts/proxy/utils/Initializable.sol"; +import { IERC165 } from "openzeppelin-contracts/contracts/utils/introspection/ERC165.sol"; import { IRouter } from "../interface/IRouter.sol"; -abstract contract AbstractPortal is Initializable, IERC165Upgradeable { +abstract contract AbstractPortal is IERC165 { IRouter public router; address[] public modules; ModuleRegistry public moduleRegistry; @@ -21,12 +19,12 @@ abstract contract AbstractPortal is Initializable, IERC165Upgradeable { error OnlyPortalOwner(); /** - * @notice Contract initialization + * @notice Contract constructor * @param _modules list of modules to use for the portal (can be empty) * @param _router Router's address + * @dev This sets the addresses for the AttestationRegistry, ModuleRegistry and PortalRegistry */ - function initialize(address[] calldata _modules, address _router) public virtual initializer { - // Store addresses for linked modules, ModuleRegistry and AttestationRegistry + constructor(address[] memory _modules, address _router) { modules = _modules; router = IRouter(_router); attestationRegistry = AttestationRegistry(router.getAttestationRegistry()); @@ -144,7 +142,7 @@ abstract contract AbstractPortal is Initializable, IERC165Upgradeable { * @return The list of modules addresses linked to the Portal */ function supportsInterface(bytes4 interfaceID) public pure virtual override returns (bool) { - return interfaceID == type(AbstractPortal).interfaceId || interfaceID == type(IERC165Upgradeable).interfaceId; + return interfaceID == type(AbstractPortal).interfaceId || interfaceID == type(IERC165).interfaceId; } /** diff --git a/src/portal/DefaultPortal.sol b/src/portal/DefaultPortal.sol index 067ac041..26674153 100644 --- a/src/portal/DefaultPortal.sol +++ b/src/portal/DefaultPortal.sol @@ -10,5 +10,7 @@ import { AbstractPortal } from "../interface/AbstractPortal.sol"; * @dev This Portal does not add any logic to the AbstractPortal */ contract DefaultPortal is AbstractPortal { + constructor(address[] memory modules, address router) AbstractPortal(modules, router) {} + function withdraw(address payable to, uint256 amount) external override {} } diff --git a/test/PortalRegistry.t.sol b/test/PortalRegistry.t.sol index 438517d4..6fc583ba 100644 --- a/test/PortalRegistry.t.sol +++ b/test/PortalRegistry.t.sol @@ -43,7 +43,7 @@ contract PortalRegistryTest is Test { vm.prank(address(0)); portalRegistry.setIssuer(user); - validPortalMock = new ValidPortalMock(); + validPortalMock = new ValidPortalMock(new address[](0), address(router)); } function test_alreadyInitialized() public { diff --git a/test/example/EASPortal.t.sol b/test/example/EASPortal.t.sol index 3205b6b4..061d1938 100644 --- a/test/example/EASPortal.t.sol +++ b/test/example/EASPortal.t.sol @@ -22,16 +22,11 @@ contract EASPortalTest is Test { event BulkAttestationsRegistered(); function setUp() public { - easPortal = new EASPortal(); router.initialize(); router.updateModuleRegistry(address(moduleRegistryMock)); router.updateAttestationRegistry(address(attestationRegistryMock)); - easPortal.initialize(modules, address(router)); - } - function test_initialize() public { - vm.expectRevert("Initializable: contract is already initialized"); - easPortal.initialize(modules, address(router)); + easPortal = new EASPortal(modules, address(router)); } function test_attest() public { diff --git a/test/integration/AttestationRegistryMass.t.sol b/test/integration/AttestationRegistryMass.t.sol index 5a661fd6..b1dfe395 100644 --- a/test/integration/AttestationRegistryMass.t.sol +++ b/test/integration/AttestationRegistryMass.t.sol @@ -57,8 +57,7 @@ contract AttestationRegistryMassTest is Test { portalRegistry.setIssuer(portalOwner); vm.prank(portalOwner); address[] memory modules = new address[](0); - defaultPortal = new DefaultPortal(); - defaultPortal.initialize(modules, address(router)); + defaultPortal = new DefaultPortal(modules, address(router)); vm.prank(portalOwner); portalRegistry.register(address(defaultPortal), "Name", "Description", true, "Linea"); diff --git a/test/mocks/ValidPortalMock.sol b/test/mocks/ValidPortalMock.sol index a9480651..5d06e065 100644 --- a/test/mocks/ValidPortalMock.sol +++ b/test/mocks/ValidPortalMock.sol @@ -4,6 +4,8 @@ pragma solidity 0.8.21; import { AbstractPortal } from "../../src/interface/AbstractPortal.sol"; contract ValidPortalMock is AbstractPortal { + constructor(address[] memory modules, address router) AbstractPortal(modules, router) {} + function test() public {} function withdraw(address payable to, uint256 amount) external override {} diff --git a/test/portal/DefaultPortal.t.sol b/test/portal/DefaultPortal.t.sol index e601cf6f..8bc83448 100644 --- a/test/portal/DefaultPortal.t.sol +++ b/test/portal/DefaultPortal.t.sol @@ -32,17 +32,16 @@ contract DefaultPortalTest is Test { event BulkAttestationsRevoked(bytes32[] attestationId); function setUp() public { - modules.push(address(correctModule)); - defaultPortal = new DefaultPortal(); router.initialize(); router.updateModuleRegistry(address(moduleRegistryMock)); router.updateAttestationRegistry(address(attestationRegistryMock)); router.updatePortalRegistry(address(portalRegistryMock)); + modules.push(address(correctModule)); + defaultPortal = new DefaultPortal(modules, address(router)); + vm.prank(portalOwner); portalRegistryMock.register(address(defaultPortal), "Name", "Description", true, "Owner name"); - - defaultPortal.initialize(modules, address(router)); } function test_setup() public { @@ -53,16 +52,6 @@ contract DefaultPortalTest is Test { assertEq(portalRegistryMock.getPortalByAddress(address(defaultPortal)).ownerAddress, portalOwner); } - function test_initialize() public { - DefaultPortal defaultPortalTest = new DefaultPortal(); - vm.expectEmit(); - emit Initialized(1); - defaultPortalTest.initialize(modules, address(router)); - - vm.expectRevert("Initializable: contract is already initialized"); - defaultPortalTest.initialize(modules, address(router)); - } - function test_getModules() public { address[] memory _modules = defaultPortal.getModules(); assertEq(_modules, modules);