From c46fbdcdb6197e02f086d0a51c9c70acf0842565 Mon Sep 17 00:00:00 2001 From: JaredBorders Date: Tue, 26 Sep 2023 17:43:30 -0400 Subject: [PATCH] =?UTF-8?q?=F0=9F=9A=80=20Write=20v2.1.1=20upgrade=20scrip?= =?UTF-8?q?t?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- script/upgrades/v2.1.1/Upgrade.s.sol | 129 +++++++++++++++++++++++++++ 1 file changed, 129 insertions(+) create mode 100644 script/upgrades/v2.1.1/Upgrade.s.sol diff --git a/script/upgrades/v2.1.1/Upgrade.s.sol b/script/upgrades/v2.1.1/Upgrade.s.sol new file mode 100644 index 00000000..db6aa49c --- /dev/null +++ b/script/upgrades/v2.1.1/Upgrade.s.sol @@ -0,0 +1,129 @@ +// SPDX-License-Identifier: GPL-3.0-or-later +pragma solidity 0.8.18; + +import {Script} from "lib/forge-std/src/Script.sol"; + +import {IAddressResolver} from "script/utils/interfaces/IAddressResolver.sol"; + +import {Account} from "src/Account.sol"; +import {Events} from "src/Events.sol"; +import {Settings} from "src/Settings.sol"; +import {IAccount} from "src/interfaces/IAccount.sol"; + +import { + OPTIMISM_PDAO, + OPTIMISM_GELATO, + OPTIMISM_OPS, + FUTURES_MARKET_MANAGER, + OPTIMISM_FACTORY, + OPTIMISM_EVENTS, + OPTIMISM_SETTINGS, + OPTIMISM_SYNTHETIX_ADDRESS_RESOLVER, + OPTIMISM_UNISWAP_PERMIT2, + OPTIMISM_UNISWAP_UNIVERSAL_ROUTER, + PERPS_V2_EXCHANGE_RATE, + PROXY_SUSD, + SYSTEM_STATUS +} from "script/utils/parameters/OptimismParameters.sol"; +import { + OPTIMISM_GOERLI_DEPLOYER, + OPTIMISM_GOERLI_EVENTS, + OPTIMISM_GOERLI_SETTINGS, + OPTIMISM_GOERLI_FACTORY, + OPTIMISM_GOERLI_GELATO, + OPTIMISM_GOERLI_OPS, + OPTIMISM_GOERLI_SYNTHETIX_ADDRESS_RESOLVER, + OPTIMISM_GOERLI_UNISWAP_PERMIT2, + OPTIMISM_GOERLI_UNISWAP_UNIVERSAL_ROUTER +} from "script/utils/parameters/OptimismGoerliParameters.sol"; + +/// @title Script to upgrade the Account implementation v2.1.0 -> v2.1.1 +/// @author JaredBorders (jaredborders@pm.me) + +/// @dev steps to deploy and verify on Optimism: +/// (1) load the variables in the .env file via `source .env` +/// (2) run `forge script script/upgrades/v2.1.1/Upgrade.s.sol:UpgradeAccountOptimism --rpc-url $ARCHIVE_NODE_URL_L2 --broadcast --verify -vvvv` +/// (3) Smart Margin Account Factory owner (i.e. Kwenta pDAO) will need to call `upgradeAccountImplementation` on the Factory with the address of the new Account implementation +contract UpgradeAccountOptimism is Script { + function run() public { + uint256 deployerPrivateKey = vm.envUint("DEPLOYER_PRIVATE_KEY"); + vm.startBroadcast(deployerPrivateKey); + + upgrade(); + + vm.stopBroadcast(); + } + + function upgrade() public returns (address implementation) { + IAddressResolver addressResolver = + IAddressResolver(OPTIMISM_SYNTHETIX_ADDRESS_RESOLVER); + + address marginAsset = addressResolver.getAddress({name: PROXY_SUSD}); + address perpsV2ExchangeRate = + addressResolver.getAddress({name: PERPS_V2_EXCHANGE_RATE}); + address futuresMarketManager = + addressResolver.getAddress({name: FUTURES_MARKET_MANAGER}); + address systemStatus = addressResolver.getAddress({name: SYSTEM_STATUS}); + + IAccount.AccountConstructorParams memory params = IAccount + .AccountConstructorParams({ + factory: OPTIMISM_FACTORY, + events: OPTIMISM_EVENTS, + marginAsset: marginAsset, + perpsV2ExchangeRate: perpsV2ExchangeRate, + futuresMarketManager: futuresMarketManager, + systemStatus: systemStatus, + gelato: OPTIMISM_GELATO, + ops: OPTIMISM_OPS, + settings: OPTIMISM_SETTINGS, + universalRouter: OPTIMISM_UNISWAP_UNIVERSAL_ROUTER, + permit2: OPTIMISM_UNISWAP_PERMIT2 + }); + + implementation = address(new Account(params)); + } +} + +/// @dev steps to deploy and verify on Optimism Goerli: +/// (1) load the variables in the .env file via `source .env` +/// (2) run `forge script script/upgrades/v2.1.1/Upgrade.s.sol:UpgradeAccountOptimismGoerli --rpc-url $ARCHIVE_NODE_URL_GOERLI_L2 --broadcast --verify -vvvv` +/// (3) Smart Margin Account Factory owner (i.e. Kwenta pDAO) will need to call `upgradeAccountImplementation` on the Factory with the address of the new Account implementation +contract UpgradeAccountOptimismGoerli is Script { + function run() public { + uint256 deployerPrivateKey = vm.envUint("DEPLOYER_PRIVATE_KEY"); + vm.startBroadcast(deployerPrivateKey); + + upgrade(); + + vm.stopBroadcast(); + } + + function upgrade() public returns (address implementation) { + IAddressResolver addressResolver = + IAddressResolver(OPTIMISM_GOERLI_SYNTHETIX_ADDRESS_RESOLVER); + + address marginAsset = addressResolver.getAddress({name: PROXY_SUSD}); + address perpsV2ExchangeRate = + addressResolver.getAddress({name: PERPS_V2_EXCHANGE_RATE}); + address futuresMarketManager = + addressResolver.getAddress({name: FUTURES_MARKET_MANAGER}); + address systemStatus = addressResolver.getAddress({name: SYSTEM_STATUS}); + + IAccount.AccountConstructorParams memory params = IAccount + .AccountConstructorParams({ + factory: OPTIMISM_GOERLI_FACTORY, + events: OPTIMISM_GOERLI_EVENTS, + marginAsset: marginAsset, + perpsV2ExchangeRate: perpsV2ExchangeRate, + futuresMarketManager: futuresMarketManager, + systemStatus: systemStatus, + gelato: OPTIMISM_GOERLI_GELATO, + ops: OPTIMISM_GOERLI_OPS, + settings: OPTIMISM_GOERLI_SETTINGS, + universalRouter: OPTIMISM_GOERLI_UNISWAP_UNIVERSAL_ROUTER, + permit2: OPTIMISM_GOERLI_UNISWAP_PERMIT2 + }); + + implementation = address(new Account(params)); + } +}