From 38cdabb6dfd6f7f7b0258cb3642b120f982c0e30 Mon Sep 17 00:00:00 2001 From: Kirill Klimenko Date: Mon, 26 Feb 2024 19:00:32 +0100 Subject: [PATCH 1/3] Swap all the GnosisSafe to GnosisSafeL2 --- .../Proposals/MultisigProposalDetails/TxActions.tsx | 5 +++-- src/hooks/DAO/proposal/useSubmitProposal.ts | 9 +++------ src/hooks/DAO/useBuildDAOTx.ts | 7 ++++++- src/hooks/DAO/useDeployAzorius.ts | 6 ++++++ src/hooks/safe/useSafeContracts.ts | 6 +++--- src/models/AzoriusTxBuilder.ts | 6 +++--- src/models/DaoTxBuilder.ts | 6 +++--- src/models/FreezeGuardTxBuilder.ts | 8 ++++---- src/models/MultisigTxBuilder.ts | 6 +++--- src/models/TxBuilderFactory.ts | 11 ++++++++--- src/models/helpers/fractalModuleData.ts | 4 ++-- src/models/helpers/safeData.ts | 8 +++++--- src/providers/NetworkConfig/networks/mainnet.ts | 9 +++++++-- src/providers/NetworkConfig/networks/polygon.ts | 9 +++++++-- src/providers/NetworkConfig/networks/sepolia.ts | 9 +++++++-- src/types/contract.ts | 6 +++--- src/types/fractal.ts | 4 ++-- src/types/network.ts | 1 + 18 files changed, 76 insertions(+), 44 deletions(-) diff --git a/src/components/Proposals/MultisigProposalDetails/TxActions.tsx b/src/components/Proposals/MultisigProposalDetails/TxActions.tsx index bfc53bb3da..52df951948 100644 --- a/src/components/Proposals/MultisigProposalDetails/TxActions.tsx +++ b/src/components/Proposals/MultisigProposalDetails/TxActions.tsx @@ -1,10 +1,11 @@ import { Box, Button, Text, Flex } from '@chakra-ui/react'; import { Check } from '@decent-org/fractal-ui'; import { TypedDataSigner } from '@ethersproject/abstract-signer'; -import { GnosisSafe__factory, MultisigFreezeGuard } from '@fractal-framework/fractal-contracts'; +import { MultisigFreezeGuard } from '@fractal-framework/fractal-contracts'; import { SafeMultisigTransactionWithTransfersResponse } from '@safe-global/safe-service-client'; import { Signer } from 'ethers'; import { useTranslation } from 'react-i18next'; +import { GnosisSafeL2__factory } from '../../../assets/typechain-types/usul/factories/@gnosis.pm/safe-contracts/contracts'; import { BACKGROUND_SEMI_TRANSPARENT } from '../../../constants/common'; import { buildSafeTransaction, buildSignatureBytes, EIP712_SAFE_TX_TYPE } from '../../../helpers'; import { logError } from '../../../helpers/errorLogging'; @@ -121,7 +122,7 @@ export function TxActions({ if (!signerOrProvider || !safe?.address || !multisigTx.confirmations) { return; } - const safeContract = GnosisSafe__factory.connect(safe.address, signerOrProvider); + const safeContract = GnosisSafeL2__factory.connect(safe.address, signerOrProvider); const safeTx = buildSafeTransaction({ ...multisigTx, }); diff --git a/src/hooks/DAO/proposal/useSubmitProposal.ts b/src/hooks/DAO/proposal/useSubmitProposal.ts index 0236623160..b51047f93b 100644 --- a/src/hooks/DAO/proposal/useSubmitProposal.ts +++ b/src/hooks/DAO/proposal/useSubmitProposal.ts @@ -1,14 +1,11 @@ import { TypedDataSigner } from '@ethersproject/abstract-signer'; -import { - Azorius, - BaseStrategy__factory, - GnosisSafe__factory, -} from '@fractal-framework/fractal-contracts'; +import { Azorius, BaseStrategy__factory } from '@fractal-framework/fractal-contracts'; import axios from 'axios'; import { BigNumber, Signer, utils } from 'ethers'; import { getAddress, isAddress } from 'ethers/lib/utils'; import { useCallback, useMemo, useState, useEffect } from 'react'; import { toast } from 'react-toastify'; +import { GnosisSafeL2__factory } from '../../../assets/typechain-types/usul/factories/@gnosis.pm/safe-contracts/contracts'; import { ADDRESS_MULTISIG_METADATA } from '../../../constants/common'; import { buildSafeAPIPost, encodeMultiSend } from '../../../helpers'; import { logError } from '../../../helpers/errorLogging'; @@ -241,7 +238,7 @@ export default function useSubmitProposal() { operation = 0; } - const safeContract = GnosisSafe__factory.connect(safeAddress, signerOrProvider); + const safeContract = GnosisSafeL2__factory.connect(safeAddress, signerOrProvider); await axios.post( buildSafeApiUrl(safeBaseURL, `/safes/${safeAddress}/multisig-transactions/`), await buildSafeAPIPost( diff --git a/src/hooks/DAO/useBuildDAOTx.ts b/src/hooks/DAO/useBuildDAOTx.ts index 20cc8380ff..41c74bb4af 100644 --- a/src/hooks/DAO/useBuildDAOTx.ts +++ b/src/hooks/DAO/useBuildDAOTx.ts @@ -16,7 +16,10 @@ import useSignerOrProvider from '../utils/useSignerOrProvider'; const useBuildDAOTx = () => { const signerOrProvider = useSignerOrProvider(); - const { createOptions } = useNetworkConfig(); + const { + createOptions, + contracts: { fallbackHandler }, + } = useNetworkConfig(); const { baseContracts: { @@ -121,6 +124,7 @@ const useBuildDAOTx = () => { baseContracts, azoriusContracts, daoData, + fallbackHandler, parentAddress, parentTokenAddress ); @@ -183,6 +187,7 @@ const useBuildDAOTx = () => { dao, governance, createOptions, + fallbackHandler, ] ); diff --git a/src/hooks/DAO/useDeployAzorius.ts b/src/hooks/DAO/useDeployAzorius.ts index 8a7967d8ec..4828455bdb 100644 --- a/src/hooks/DAO/useDeployAzorius.ts +++ b/src/hooks/DAO/useDeployAzorius.ts @@ -5,6 +5,7 @@ import { useTranslation } from 'react-i18next'; import { DAO_ROUTES } from '../../constants/routes'; import { TxBuilderFactory } from '../../models/TxBuilderFactory'; import { useFractal } from '../../providers/App/AppProvider'; +import { useNetworkConfig } from '../../providers/NetworkConfig/NetworkConfigProvider'; import { BaseContracts, AzoriusContracts, @@ -18,6 +19,9 @@ import useSubmitProposal from './proposal/useSubmitProposal'; const useDeployAzorius = () => { const signerOrProvider = useSignerOrProvider(); const { push } = useRouter(); + const { + contracts: { fallbackHandler }, + } = useNetworkConfig(); const { node: { daoAddress, safe }, baseContracts: { @@ -81,6 +85,7 @@ const useDeployAzorius = () => { baseContracts, azoriusContracts, daoData, + fallbackHandler, undefined, undefined ); @@ -143,6 +148,7 @@ const useDeployAzorius = () => { submitProposal, push, safe, + fallbackHandler, ] ); diff --git a/src/hooks/safe/useSafeContracts.ts b/src/hooks/safe/useSafeContracts.ts index 1877c1c996..affd66fa51 100644 --- a/src/hooks/safe/useSafeContracts.ts +++ b/src/hooks/safe/useSafeContracts.ts @@ -7,7 +7,6 @@ import { MultisigFreezeVoting__factory, VotesERC20__factory, GnosisSafeProxyFactory__factory, - GnosisSafe__factory, ModuleProxyFactory__factory, LinearERC20Voting__factory, Azorius__factory, @@ -19,6 +18,7 @@ import { } from '@fractal-framework/fractal-contracts'; import { useMemo } from 'react'; import { MultiSend__factory } from '../../assets/typechain-types/usul'; +import { GnosisSafeL2__factory } from '../../assets/typechain-types/usul/factories/@gnosis.pm/safe-contracts/contracts'; import { useNetworkConfig } from '../../providers/NetworkConfig/NetworkConfigProvider'; import { useEthersProvider } from '../utils/useEthersProvider'; import useSignerOrProvider from '../utils/useSignerOrProvider'; @@ -76,8 +76,8 @@ export default function useSafeContracts() { }; const safeSingletonContract = { - asSigner: GnosisSafe__factory.connect(safe, signerOrProvider), - asProvider: GnosisSafe__factory.connect(safe, provider), + asSigner: GnosisSafeL2__factory.connect(safe, signerOrProvider), + asProvider: GnosisSafeL2__factory.connect(safe, provider), }; const zodiacModuleProxyFactoryContract = { diff --git a/src/models/AzoriusTxBuilder.ts b/src/models/AzoriusTxBuilder.ts index 331007d059..52655294fe 100644 --- a/src/models/AzoriusTxBuilder.ts +++ b/src/models/AzoriusTxBuilder.ts @@ -1,7 +1,6 @@ import { Azorius, Azorius__factory, - GnosisSafe, LinearERC20Voting, LinearERC20Voting__factory, LinearERC721Voting, @@ -11,6 +10,7 @@ import { } from '@fractal-framework/fractal-contracts'; import { BigNumber } from 'ethers'; import { defaultAbiCoder, getCreate2Address, solidityKeccak256 } from 'ethers/lib/utils'; +import { GnosisSafeL2 } from '../assets/typechain-types/usul/@gnosis.pm/safe-contracts/contracts'; import { buildContractCall, getRandomBytes } from '../helpers'; import { BaseContracts, @@ -25,7 +25,7 @@ import { BaseTxBuilder } from './BaseTxBuilder'; import { generateContractByteCodeLinear, generateSalt } from './helpers/utils'; export class AzoriusTxBuilder extends BaseTxBuilder { - private readonly safeContract: GnosisSafe; + private readonly safeContract: GnosisSafeL2; private readonly predictedSafeAddress: string; private encodedSetupTokenData: string | undefined; @@ -54,7 +54,7 @@ export class AzoriusTxBuilder extends BaseTxBuilder { baseContracts: BaseContracts, azoriusContracts: AzoriusContracts, daoData: AzoriusERC20DAO | AzoriusERC721DAO, - safeContract: GnosisSafe, + safeContract: GnosisSafeL2, predictedSafeAddress: string, parentAddress?: string, parentTokenAddress?: string diff --git a/src/models/DaoTxBuilder.ts b/src/models/DaoTxBuilder.ts index 90663b03db..970248d0a0 100644 --- a/src/models/DaoTxBuilder.ts +++ b/src/models/DaoTxBuilder.ts @@ -1,5 +1,5 @@ -import { GnosisSafe } from '@fractal-framework/fractal-contracts'; import { ethers } from 'ethers'; +import { GnosisSafeL2 } from '../assets/typechain-types/usul/@gnosis.pm/safe-contracts/contracts'; import { buildContractCall, encodeMultiSend } from '../helpers'; import { BaseContracts, @@ -24,7 +24,7 @@ export class DaoTxBuilder extends BaseTxBuilder { // Safe Data private predictedSafeAddress: string; private readonly createSafeTx: SafeTransaction; - private readonly safeContract: GnosisSafe; + private readonly safeContract: GnosisSafeL2; private readonly parentStrategyType?: VotingStrategyType; private readonly parentStrategyAddress?: string; @@ -42,7 +42,7 @@ export class DaoTxBuilder extends BaseTxBuilder { saltNum: string, predictedSafeAddress: string, createSafeTx: SafeTransaction, - safeContract: GnosisSafe, + safeContract: GnosisSafeL2, txBuilderFactory: TxBuilderFactory, parentAddress?: string, parentTokenAddress?: string, diff --git a/src/models/FreezeGuardTxBuilder.ts b/src/models/FreezeGuardTxBuilder.ts index 52dc5f3397..b276168f89 100644 --- a/src/models/FreezeGuardTxBuilder.ts +++ b/src/models/FreezeGuardTxBuilder.ts @@ -1,6 +1,5 @@ import { Azorius, - GnosisSafe, AzoriusFreezeGuard__factory, ERC20FreezeVoting__factory, MultisigFreezeGuard__factory, @@ -12,6 +11,7 @@ import { } from '@fractal-framework/fractal-contracts'; import { ethers } from 'ethers'; import { getCreate2Address, solidityKeccak256 } from 'ethers/lib/utils'; +import { GnosisSafeL2 } from '../assets/typechain-types/usul/@gnosis.pm/safe-contracts/contracts'; import { buildContractCall } from '../helpers'; import { BaseContracts, @@ -33,7 +33,7 @@ export class FreezeGuardTxBuilder extends BaseTxBuilder { private readonly saltNum; // Safe Data - private readonly safeContract: GnosisSafe; + private readonly safeContract: GnosisSafeL2; // Freeze Voting Data private freezeVotingType: any; @@ -55,7 +55,7 @@ export class FreezeGuardTxBuilder extends BaseTxBuilder { signerOrProvider: any, baseContracts: BaseContracts, daoData: SubDAO, - safeContract: GnosisSafe, + safeContract: GnosisSafeL2, saltNum: string, parentAddress: string, parentTokenAddress?: string, @@ -134,7 +134,7 @@ export class FreezeGuardTxBuilder extends BaseTxBuilder { ); } - public buildSetGuardTx(contract: GnosisSafe | Azorius): SafeTransaction { + public buildSetGuardTx(contract: GnosisSafeL2 | Azorius): SafeTransaction { return buildContractCall(contract, 'setGuard', [this.freezeGuardAddress], 0, false); } diff --git a/src/models/MultisigTxBuilder.ts b/src/models/MultisigTxBuilder.ts index ac55607dfb..c3eec410e2 100644 --- a/src/models/MultisigTxBuilder.ts +++ b/src/models/MultisigTxBuilder.ts @@ -1,13 +1,13 @@ -import { GnosisSafe } from '@fractal-framework/fractal-contracts'; +import { GnosisSafeL2 } from '../assets/typechain-types/usul/@gnosis.pm/safe-contracts/contracts'; import { buildContractCall } from '../helpers'; import { BaseContracts, SafeMultisigDAO, SafeTransaction } from '../types'; export class MultisigTxBuilder { private baseContracts: BaseContracts; private readonly daoData: SafeMultisigDAO; - private readonly safeContract: GnosisSafe; + private readonly safeContract: GnosisSafeL2; - constructor(baseContracts: BaseContracts, daoData: SafeMultisigDAO, safeContract: GnosisSafe) { + constructor(baseContracts: BaseContracts, daoData: SafeMultisigDAO, safeContract: GnosisSafeL2) { this.baseContracts = baseContracts; this.daoData = daoData; this.safeContract = safeContract; diff --git a/src/models/TxBuilderFactory.ts b/src/models/TxBuilderFactory.ts index 49787f15b2..cce5385120 100644 --- a/src/models/TxBuilderFactory.ts +++ b/src/models/TxBuilderFactory.ts @@ -1,5 +1,6 @@ -import { GnosisSafe, GnosisSafe__factory } from '@fractal-framework/fractal-contracts'; import { ethers } from 'ethers'; +import { GnosisSafeL2 } from '../assets/typechain-types/usul/@gnosis.pm/safe-contracts/contracts'; +import { GnosisSafeL2__factory } from '../assets/typechain-types/usul/factories/@gnosis.pm/safe-contracts/contracts'; import { getRandomBytes } from '../helpers'; import { BaseContracts, @@ -24,13 +25,15 @@ export class TxBuilderFactory extends BaseTxBuilder { // Safe Data public predictedSafeAddress: string | undefined; public createSafeTx: SafeTransaction | undefined; - private safeContract: GnosisSafe | undefined; + private safeContract: GnosisSafeL2 | undefined; + public fallbackHandler: string; constructor( signerOrProvider: ethers.Signer | any, baseContracts: BaseContracts, azoriusContracts: AzoriusContracts | undefined, daoData: SafeMultisigDAO | AzoriusERC20DAO | AzoriusERC721DAO | SubDAO, + fallbackHandler: string, parentAddress?: string, parentTokenAddress?: string ) { @@ -43,11 +46,12 @@ export class TxBuilderFactory extends BaseTxBuilder { parentTokenAddress ); + this.fallbackHandler = fallbackHandler; this.saltNum = getRandomBytes(); } public setSafeContract(safeAddress: string) { - const safeContract = GnosisSafe__factory.connect(safeAddress, this.signerOrProvider); + const safeContract = GnosisSafeL2__factory.connect(safeAddress, this.signerOrProvider); this.safeContract = safeContract; } @@ -58,6 +62,7 @@ export class TxBuilderFactory extends BaseTxBuilder { this.baseContracts.safeSingletonContract, this.daoData as SafeMultisigDAO, this.saltNum, + this.fallbackHandler, !!this.azoriusContracts ); diff --git a/src/models/helpers/fractalModuleData.ts b/src/models/helpers/fractalModuleData.ts index 6f87a4c235..efc35c9102 100644 --- a/src/models/helpers/fractalModuleData.ts +++ b/src/models/helpers/fractalModuleData.ts @@ -1,10 +1,10 @@ import { FractalModule, FractalModule__factory, - GnosisSafe, ModuleProxyFactory, } from '@fractal-framework/fractal-contracts'; import { ethers } from 'ethers'; +import { GnosisSafeL2 } from '../../assets/typechain-types/usul/@gnosis.pm/safe-contracts/contracts'; import { buildContractCall } from '../../helpers/crypto'; import { SafeTransaction } from '../../types'; import { @@ -23,7 +23,7 @@ export interface FractalModuleData { export const fractalModuleData = ( fractalModuleMasterCopyContract: FractalModule, zodiacModuleProxyFactoryContract: ModuleProxyFactory, - safeContract: GnosisSafe, + safeContract: GnosisSafeL2, saltNum: string, parentAddress?: string ): FractalModuleData => { diff --git a/src/models/helpers/safeData.ts b/src/models/helpers/safeData.ts index 144aa3f4a3..bf2de3060b 100644 --- a/src/models/helpers/safeData.ts +++ b/src/models/helpers/safeData.ts @@ -1,7 +1,8 @@ -import { GnosisSafe, GnosisSafeProxyFactory } from '@fractal-framework/fractal-contracts'; +import { GnosisSafeProxyFactory } from '@fractal-framework/fractal-contracts'; import { ethers } from 'ethers'; import { getCreate2Address, solidityKeccak256 } from 'ethers/lib/utils'; import { MultiSend } from '../../assets/typechain-types/usul'; +import { GnosisSafeL2 } from '../../assets/typechain-types/usul/@gnosis.pm/safe-contracts/contracts'; import { buildContractCall } from '../../helpers/crypto'; import { SafeMultisigDAO } from '../../types'; const { AddressZero, HashZero } = ethers.constants; @@ -9,9 +10,10 @@ const { AddressZero, HashZero } = ethers.constants; export const safeData = async ( multiSendContract: MultiSend, safeFactoryContract: GnosisSafeProxyFactory, - safeSingletonContract: GnosisSafe, + safeSingletonContract: GnosisSafeL2, daoData: SafeMultisigDAO, saltNum: string, + fallbackHandler: string, hasAzorius?: boolean ) => { const signers = hasAzorius @@ -26,7 +28,7 @@ export const safeData = async ( 1, // Threshold AddressZero, HashZero, - AddressZero, + fallbackHandler, // Fallback handler AddressZero, 0, AddressZero, diff --git a/src/providers/NetworkConfig/networks/mainnet.ts b/src/providers/NetworkConfig/networks/mainnet.ts index bed23eefb1..b4d55383b4 100644 --- a/src/providers/NetworkConfig/networks/mainnet.ts +++ b/src/providers/NetworkConfig/networks/mainnet.ts @@ -12,9 +12,10 @@ import MultisigFreezeVoting from '@fractal-framework/fractal-contracts/deploymen import VotesERC20 from '@fractal-framework/fractal-contracts/deployments/mainnet/VotesERC20.json'; import VotesERC20Wrapper from '@fractal-framework/fractal-contracts/deployments/mainnet/VotesERC20Wrapper.json'; import { - getSafeSingletonDeployment, getProxyFactoryDeployment, getMultiSendCallOnlyDeployment, + getSafeL2SingletonDeployment, + getCompatibilityFallbackHandlerDeployment, } from '@safe-global/safe-deployments'; import { mainnet } from 'wagmi/chains'; import { GovernanceType } from '../../../types'; @@ -47,7 +48,11 @@ export const mainnetConfig: NetworkConfig = { erc20FreezeVotingMasterCopy: ERC20FreezeVoting.address, erc721FreezeVotingMasterCopy: '', // TODO - Add actual address once contract is deployed on mainnet multisigFreezeGuardMasterCopy: MultisigFreezeGuard.address, - safe: getSafeSingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) + fallbackHandler: getCompatibilityFallbackHandlerDeployment({ + version: SAFE_VERSION, + network: CHAIN_ID.toString(), + })?.defaultAddress!, + safe: getSafeL2SingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) ?.defaultAddress!, safeFactory: getProxyFactoryDeployment({ version: SAFE_VERSION, diff --git a/src/providers/NetworkConfig/networks/polygon.ts b/src/providers/NetworkConfig/networks/polygon.ts index ae0e16c541..0e6581ea37 100644 --- a/src/providers/NetworkConfig/networks/polygon.ts +++ b/src/providers/NetworkConfig/networks/polygon.ts @@ -12,9 +12,10 @@ import MultisigFreezeVoting from '@fractal-framework/fractal-contracts/deploymen import VotesERC20 from '@fractal-framework/fractal-contracts/deployments/polygon/VotesERC20.json'; import VotesERC20Wrapper from '@fractal-framework/fractal-contracts/deployments/polygon/VotesERC20Wrapper.json'; import { - getSafeSingletonDeployment, getProxyFactoryDeployment, getMultiSendCallOnlyDeployment, + getSafeL2SingletonDeployment, + getCompatibilityFallbackHandlerDeployment, } from '@safe-global/safe-deployments'; import { polygon } from 'wagmi/chains'; import { GovernanceType } from '../../../types'; @@ -47,7 +48,11 @@ export const polygonConfig: NetworkConfig = { erc20FreezeVotingMasterCopy: ERC20FreezeVoting.address, erc721FreezeVotingMasterCopy: '', multisigFreezeGuardMasterCopy: MultisigFreezeGuard.address, - safe: getSafeSingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) + fallbackHandler: getCompatibilityFallbackHandlerDeployment({ + version: SAFE_VERSION, + network: CHAIN_ID.toString(), + })?.defaultAddress!, + safe: getSafeL2SingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) ?.defaultAddress!, safeFactory: getProxyFactoryDeployment({ version: SAFE_VERSION, diff --git a/src/providers/NetworkConfig/networks/sepolia.ts b/src/providers/NetworkConfig/networks/sepolia.ts index f6dcd59cb4..17093fe937 100644 --- a/src/providers/NetworkConfig/networks/sepolia.ts +++ b/src/providers/NetworkConfig/networks/sepolia.ts @@ -16,7 +16,8 @@ import VotesERC20Wrapper from '@fractal-framework/fractal-contracts/deployments/ import { getMultiSendCallOnlyDeployment, getProxyFactoryDeployment, - getSafeSingletonDeployment, + getSafeL2SingletonDeployment, + getCompatibilityFallbackHandlerDeployment, } from '@safe-global/safe-deployments'; import { sepolia } from 'wagmi/chains'; import { GovernanceType } from '../../../types'; @@ -48,7 +49,11 @@ export const sepoliaConfig: NetworkConfig = { erc20FreezeVotingMasterCopy: ERC20FreezeVoting.address, erc721FreezeVotingMasterCopy: ERC721FreezeVoting.address, multisigFreezeGuardMasterCopy: MultisigFreezeGuard.address, - safe: getSafeSingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) + fallbackHandler: getCompatibilityFallbackHandlerDeployment({ + version: SAFE_VERSION, + network: CHAIN_ID.toString(), + })?.defaultAddress!, + safe: getSafeL2SingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) ?.defaultAddress!, safeFactory: getProxyFactoryDeployment({ version: SAFE_VERSION, diff --git a/src/types/contract.ts b/src/types/contract.ts index 4e5c11ffe7..59c1b54b0b 100644 --- a/src/types/contract.ts +++ b/src/types/contract.ts @@ -1,6 +1,5 @@ import { GnosisSafeProxyFactory, - GnosisSafe, ModuleProxyFactory, Azorius, LinearERC20Voting, @@ -16,6 +15,7 @@ import { ERC721FreezeVoting, } from '@fractal-framework/fractal-contracts'; import { MultiSend } from '../assets/typechain-types/usul'; +import { GnosisSafeL2 } from '../assets/typechain-types/usul/@gnosis.pm/safe-contracts/contracts'; export interface ContractEvent { blockTimestamp: number; @@ -31,7 +31,7 @@ export interface DAOContracts { safeFactoryContract: ContractConnection; fractalAzoriusMasterCopyContract: ContractConnection; linearVotingMasterCopyContract: ContractConnection; - safeSingletonContract: ContractConnection; + safeSingletonContract: ContractConnection; zodiacModuleProxyFactoryContract: ContractConnection; fractalModuleMasterCopyContract: ContractConnection; fractalRegistryContract: ContractConnection; @@ -48,7 +48,7 @@ export interface BaseContracts { fractalModuleMasterCopyContract: FractalModule; fractalRegistryContract: FractalRegistry; safeFactoryContract: GnosisSafeProxyFactory; - safeSingletonContract: GnosisSafe; + safeSingletonContract: GnosisSafeL2; multisigFreezeGuardMasterCopyContract: MultisigFreezeGuard; multiSendContract: MultiSend; freezeERC20VotingMasterCopyContract: ERC20FreezeVoting; diff --git a/src/types/fractal.ts b/src/types/fractal.ts index 63a996aebd..64234e9b92 100644 --- a/src/types/fractal.ts +++ b/src/types/fractal.ts @@ -1,7 +1,6 @@ import { FractalModule, FractalRegistry, - GnosisSafe, GnosisSafeProxyFactory, ModuleProxyFactory, LinearERC20Voting, @@ -28,6 +27,7 @@ import { BigNumber } from 'ethers'; import { Dispatch } from 'react'; import { LockRelease } from '../assets/typechain-types/dcnt'; import { MultiSend } from '../assets/typechain-types/usul'; +import { GnosisSafeL2 } from '../assets/typechain-types/usul/@gnosis.pm/safe-contracts/contracts'; import { FractalGovernanceActions } from '../providers/App/governance/action'; import { GovernanceContractActions } from '../providers/App/governanceContracts/action'; import { FractalGuardActions } from '../providers/App/guard/action'; @@ -334,7 +334,7 @@ export interface FractalContracts { fractalAzoriusMasterCopyContract: ContractConnection; linearVotingMasterCopyContract: ContractConnection; linearVotingERC721MasterCopyContract: ContractConnection; - safeSingletonContract: ContractConnection; + safeSingletonContract: ContractConnection; zodiacModuleProxyFactoryContract: ContractConnection; fractalModuleMasterCopyContract: ContractConnection; fractalRegistryContract: ContractConnection; diff --git a/src/types/network.ts b/src/types/network.ts index 6833ad6645..74c2264d66 100644 --- a/src/types/network.ts +++ b/src/types/network.ts @@ -21,6 +21,7 @@ export type NetworkConfig = { contracts: { safe: string; safeFactory: string; + fallbackHandler: string; zodiacModuleProxyFactory: string; linearVotingMasterCopy: string; multisend: string; From 50339dcbe607057a5fe992fde84d6743b795f056 Mon Sep 17 00:00:00 2001 From: Kirill Klimenko Date: Mon, 26 Feb 2024 19:40:16 +0100 Subject: [PATCH 2/3] Fix getting fallback handler --- src/providers/NetworkConfig/networks/polygon.ts | 2 +- src/providers/NetworkConfig/networks/sepolia.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/providers/NetworkConfig/networks/polygon.ts b/src/providers/NetworkConfig/networks/polygon.ts index 0e6581ea37..145a956042 100644 --- a/src/providers/NetworkConfig/networks/polygon.ts +++ b/src/providers/NetworkConfig/networks/polygon.ts @@ -51,7 +51,7 @@ export const polygonConfig: NetworkConfig = { fallbackHandler: getCompatibilityFallbackHandlerDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString(), - })?.defaultAddress!, + })?.networkAddresses[CHAIN_ID.toString()]!, safe: getSafeL2SingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) ?.defaultAddress!, safeFactory: getProxyFactoryDeployment({ diff --git a/src/providers/NetworkConfig/networks/sepolia.ts b/src/providers/NetworkConfig/networks/sepolia.ts index 17093fe937..8dedbedb5e 100644 --- a/src/providers/NetworkConfig/networks/sepolia.ts +++ b/src/providers/NetworkConfig/networks/sepolia.ts @@ -52,7 +52,7 @@ export const sepoliaConfig: NetworkConfig = { fallbackHandler: getCompatibilityFallbackHandlerDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString(), - })?.defaultAddress!, + })?.networkAddresses[CHAIN_ID.toString()]!, safe: getSafeL2SingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) ?.defaultAddress!, safeFactory: getProxyFactoryDeployment({ From dffbb6a53f0bdab9a7ff5fce1bd6c65329ff71f1 Mon Sep 17 00:00:00 2001 From: Kirill Klimenko Date: Mon, 26 Feb 2024 21:10:01 +0100 Subject: [PATCH 3/3] Adjust getting deployment addresses for Safe-related contracts so that it retrieved from networkAddresses and not defaultAddress --- src/providers/NetworkConfig/networks/mainnet.ts | 8 ++++---- src/providers/NetworkConfig/networks/polygon.ts | 6 +++--- src/providers/NetworkConfig/networks/sepolia.ts | 6 +++--- 3 files changed, 10 insertions(+), 10 deletions(-) diff --git a/src/providers/NetworkConfig/networks/mainnet.ts b/src/providers/NetworkConfig/networks/mainnet.ts index b4d55383b4..4a841affd4 100644 --- a/src/providers/NetworkConfig/networks/mainnet.ts +++ b/src/providers/NetworkConfig/networks/mainnet.ts @@ -51,19 +51,19 @@ export const mainnetConfig: NetworkConfig = { fallbackHandler: getCompatibilityFallbackHandlerDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString(), - })?.defaultAddress!, + })?.networkAddresses[CHAIN_ID.toString()]!, safe: getSafeL2SingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) - ?.defaultAddress!, + ?.networkAddresses[CHAIN_ID.toString()]!, safeFactory: getProxyFactoryDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString(), - })?.defaultAddress!, + })?.networkAddresses[CHAIN_ID.toString()]!, zodiacModuleProxyFactory: ModuleProxyFactory.address, linearVotingMasterCopy: LinearERC20Voting.address, multisend: getMultiSendCallOnlyDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString(), - })?.defaultAddress!, + })?.networkAddresses[CHAIN_ID.toString()]!, votesERC20WrapperMasterCopy: VotesERC20Wrapper.address, keyValuePairs: KeyValuePairs.address, }, diff --git a/src/providers/NetworkConfig/networks/polygon.ts b/src/providers/NetworkConfig/networks/polygon.ts index 145a956042..b5bf44c120 100644 --- a/src/providers/NetworkConfig/networks/polygon.ts +++ b/src/providers/NetworkConfig/networks/polygon.ts @@ -53,17 +53,17 @@ export const polygonConfig: NetworkConfig = { network: CHAIN_ID.toString(), })?.networkAddresses[CHAIN_ID.toString()]!, safe: getSafeL2SingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) - ?.defaultAddress!, + ?.networkAddresses[CHAIN_ID.toString()]!, safeFactory: getProxyFactoryDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString(), - })?.defaultAddress!, + })?.networkAddresses[CHAIN_ID.toString()]!, zodiacModuleProxyFactory: ModuleProxyFactory.address, linearVotingMasterCopy: LinearERC20Voting.address, multisend: getMultiSendCallOnlyDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString(), - })?.defaultAddress!, + })?.networkAddresses[CHAIN_ID.toString()]!, votesERC20WrapperMasterCopy: VotesERC20Wrapper.address, keyValuePairs: KeyValuePairs.address, }, diff --git a/src/providers/NetworkConfig/networks/sepolia.ts b/src/providers/NetworkConfig/networks/sepolia.ts index 8dedbedb5e..360f30b568 100644 --- a/src/providers/NetworkConfig/networks/sepolia.ts +++ b/src/providers/NetworkConfig/networks/sepolia.ts @@ -54,17 +54,17 @@ export const sepoliaConfig: NetworkConfig = { network: CHAIN_ID.toString(), })?.networkAddresses[CHAIN_ID.toString()]!, safe: getSafeL2SingletonDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString() }) - ?.defaultAddress!, + ?.networkAddresses[CHAIN_ID.toString()]!, safeFactory: getProxyFactoryDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString(), - })?.defaultAddress!, + })?.networkAddresses[CHAIN_ID.toString()]!, zodiacModuleProxyFactory: ModuleProxyFactory.address, linearVotingMasterCopy: LinearERC20Voting.address, multisend: getMultiSendCallOnlyDeployment({ version: SAFE_VERSION, network: CHAIN_ID.toString(), - })?.defaultAddress!, + })?.networkAddresses[CHAIN_ID.toString()]!, votesERC20WrapperMasterCopy: VotesERC20Wrapper.address, keyValuePairs: KeyValuePairs.address, },