From 0937f6170d5fe266b8cd7bf620165e45c91dc8a2 Mon Sep 17 00:00:00 2001 From: CodeSandwich Date: Mon, 17 Jun 2024 02:10:51 +0200 Subject: [PATCH] Make Giver native token wrapper configurable --- src/Giver.sol | 18 ++++-------------- test/Giver.t.sol | 5 ++--- 2 files changed, 6 insertions(+), 17 deletions(-) diff --git a/src/Giver.sol b/src/Giver.sol index 8ceb336c..cf2273cf 100644 --- a/src/Giver.sol +++ b/src/Giver.sol @@ -39,7 +39,7 @@ contract Giver { /// Any ERC-20 tokens or native tokens sent to `Giver` will /// eventually be `give`n to the account assigned to it. contract GiversRegistry is Managed { - /// @notice The ERC-20 contract used to wrap the native tokens before `give`ing. + /// @notice The ERC-20 contract used to wrap the native tokens. IERC20 public immutable nativeTokenWrapper; /// @notice The driver to use to `give`. AddressDriver public immutable addressDriver; @@ -51,22 +51,12 @@ contract GiversRegistry is Managed { uint128 internal immutable _maxTotalBalance; /// @param addressDriver_ The driver to use to `give`. - constructor(AddressDriver addressDriver_) { + /// @param nativeTokenWrapper_ The ERC-20 contract used to wrap the native tokens. + constructor(AddressDriver addressDriver_, IERC20 nativeTokenWrapper_) { addressDriver = addressDriver_; + nativeTokenWrapper = nativeTokenWrapper_; _drips = addressDriver.drips(); _maxTotalBalance = _drips.MAX_TOTAL_BALANCE(); - - address nativeTokenWrapper_; - if (block.chainid == 1 /* Mainnet */ ) { - nativeTokenWrapper_ = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2; - } else if (block.chainid == 5 /* Goerli */ ) { - nativeTokenWrapper_ = 0xB4FBF271143F4FBf7B91A5ded31805e42b2208d6; - } else if (block.chainid == 11155111 /* Sepolia */ ) { - nativeTokenWrapper_ = 0xfFf9976782d46CC05630D1f6eBAb18b2324d6B14; - } else { - nativeTokenWrapper_ = address(bytes20("native token wrapper")); - } - nativeTokenWrapper = IERC20(nativeTokenWrapper_); } /// @notice Calculate the address of the `Giver` assigned to the account ID. diff --git a/test/Giver.t.sol b/test/Giver.t.sol index f1c62b7c..0363cd95 100644 --- a/test/Giver.t.sol +++ b/test/Giver.t.sol @@ -71,10 +71,9 @@ contract GiversRegistryTest is Test { addressDriver = AddressDriver(address(new ManagedProxy(addressDriverLogic, admin))); drips.registerDriver(address(addressDriver)); - GiversRegistry giversRegistryLogic = new GiversRegistry(addressDriver); + nativeTokenWrapper = new NativeTokenWrapper(); + GiversRegistry giversRegistryLogic = new GiversRegistry(addressDriver, nativeTokenWrapper); giversRegistry = GiversRegistry(address(new ManagedProxy(giversRegistryLogic, admin))); - nativeTokenWrapper = giversRegistry.nativeTokenWrapper(); - vm.etch(address(nativeTokenWrapper), address(new NativeTokenWrapper()).code); accountId = 1234; giver = payable(giversRegistry.giver(accountId)); emit log_named_address("GIVER", giver);