From 8948983a22027067999de8eca29e79a00aac167b Mon Sep 17 00:00:00 2001 From: Doug Lance Date: Fri, 22 Sep 2023 09:18:40 -0400 Subject: [PATCH 1/6] chore: renames L1/2 to parentChain/chain in inbox --- scripts/sendL2SignedMsg.ts | 4 +- src/lib/inbox/inbox.ts | 136 +++++++++++++++------------- tests/integration/sendL2msg.test.ts | 4 +- 3 files changed, 76 insertions(+), 68 deletions(-) diff --git a/scripts/sendL2SignedMsg.ts b/scripts/sendL2SignedMsg.ts index 10ac03e9e7..088b19c0cf 100644 --- a/scripts/sendL2SignedMsg.ts +++ b/scripts/sendL2SignedMsg.ts @@ -29,8 +29,8 @@ const sendSignedMsg = async () => { value: BigNumber.from(0), data: '0x12', } - const signedTx = await inbox.signL2Tx(message, l2Deployer) - await inbox.sendL2SignedTx(signedTx) + const signedTx = await inbox.signChainTx(message, l2Deployer) + await inbox.sendChainSignedTx(signedTx) } sendSignedMsg() diff --git a/src/lib/inbox/inbox.ts b/src/lib/inbox/inbox.ts index 240bfb61b6..c6d28d74a0 100644 --- a/src/lib/inbox/inbox.ts +++ b/src/lib/inbox/inbox.ts @@ -28,7 +28,10 @@ import { SequencerInbox__factory } from '../abi/factories/SequencerInbox__factor import { IInbox__factory } from '../abi/factories/IInbox__factory' import { RequiredPick } from '../utils/types' import { MessageDeliveredEvent } from '../abi/Bridge' -import { l1Networks, L2Network } from '../dataEntities/networks' +import { + l1Networks as parentChainNetworks, + L2Network as ChainNetwork, +} from '../dataEntities/networks' import { SignerProviderUtils } from '../dataEntities/signerOrProvider' import { FetchedEvent, EventFetcher } from '../utils/eventFetcher' import { MultiCaller, CallInput } from '../utils/multicall' @@ -42,12 +45,12 @@ type ForceInclusionParams = FetchedEvent & { delayedAcc: string } -type GasComponentsWithL2Part = { +type GasComponentsWithChainPart = { gasEstimate: BigNumber gasEstimateForL1: BigNumber baseFee: BigNumber l1BaseFeeEstimate: BigNumber - gasEstimateForL2: BigNumber + gasEstimateForChain: BigNumber } type RequiredTransactionRequestType = RequiredPick< TransactionRequest, @@ -57,18 +60,20 @@ type RequiredTransactionRequestType = RequiredPick< * Tools for interacting with the inbox and bridge contracts */ export class InboxTools { - private readonly l1Provider - private readonly l1Network + private readonly parentChainProvider + private readonly parentChainNetwork constructor( - private readonly l1Signer: Signer, - private readonly l2Network: L2Network + private readonly parentChainSigner: Signer, + private readonly chainNetwork: ChainNetwork ) { - this.l1Provider = SignerProviderUtils.getProviderOrThrow(this.l1Signer) - this.l1Network = l1Networks[l2Network.partnerChainID] - if (!this.l1Network) + this.parentChainProvider = SignerProviderUtils.getProviderOrThrow( + this.parentChainSigner + ) + this.parentChainNetwork = parentChainNetworks[chainNetwork.partnerChainID] + if (!this.parentChainNetwork) throw new ArbSdkError( - `L1Network not found for chain id: ${l2Network.partnerChainID}.` + `ParentChainNetwork not found for chain id: ${chainNetwork.partnerChainID}.` ) } @@ -84,13 +89,16 @@ export class InboxTools { blockNumber: number, blockTimestamp: number ): Promise { - const block = await this.l1Provider.getBlock(blockNumber) + const block = await this.parentChainProvider.getBlock(blockNumber) const diff = block.timestamp - blockTimestamp if (diff < 0) return block // we take a long average block time of 14s // and always move at least 10 blocks - const diffBlocks = Math.max(Math.ceil(diff / this.l1Network.blockTime), 10) + const diffBlocks = Math.max( + Math.ceil(diff / this.parentChainNetwork.blockTime), + 10 + ) return await this.findFirstBlockBelow( blockNumber - diffBlocks, @@ -100,12 +108,12 @@ export class InboxTools { //Check if this request is contract creation or not. private isContractCreation( - transactionl2Request: TransactionRequest + transactionChainRequest: TransactionRequest ): boolean { if ( - transactionl2Request.to === '0x' || - !isDefined(transactionl2Request.to) || - transactionl2Request.to === ethers.constants.AddressZero + transactionChainRequest.to === '0x' || + !isDefined(transactionChainRequest.to) || + transactionChainRequest.to === ethers.constants.AddressZero ) { return true } @@ -114,32 +122,32 @@ export class InboxTools { /** * We should use nodeInterface to get the gas estimate is because we - * are making a delayed inbox message which doesn't need l1 calldata + * are making a delayed inbox message which doesn't need parentChain calldata * gas fee part. */ private async estimateArbitrumGas( - transactionl2Request: RequiredTransactionRequestType, - l2Provider: Provider - ): Promise { + transactionChainRequest: RequiredTransactionRequestType, + chainProvider: Provider + ): Promise { const nodeInterface = NodeInterface__factory.connect( NODE_INTERFACE_ADDRESS, - l2Provider + chainProvider ) - const contractCreation = this.isContractCreation(transactionl2Request) + const contractCreation = this.isContractCreation(transactionChainRequest) const gasComponents = await nodeInterface.callStatic.gasEstimateComponents( - transactionl2Request.to || ethers.constants.AddressZero, + transactionChainRequest.to || ethers.constants.AddressZero, contractCreation, - transactionl2Request.data, + transactionChainRequest.data, { - from: transactionl2Request.from, - value: transactionl2Request.value, + from: transactionChainRequest.from, + value: transactionChainRequest.value, } ) - const gasEstimateForL2: BigNumber = gasComponents.gasEstimate.sub( + const gasEstimateForChain: BigNumber = gasComponents.gasEstimate.sub( gasComponents.gasEstimateForL1 ) - return { ...gasComponents, gasEstimateForL2 } + return { ...gasComponents, gasEstimateForChain } } /** @@ -149,11 +157,11 @@ export class InboxTools { */ private async getForceIncludableBlockRange(blockNumberRangeSize: number) { const sequencerInbox = SequencerInbox__factory.connect( - this.l2Network.ethBridge.sequencerInbox, - this.l1Provider + this.chainNetwork.ethBridge.sequencerInbox, + this.parentChainProvider ) - const multicall = await MultiCaller.fromProvider(this.l1Provider) + const multicall = await MultiCaller.fromProvider(this.parentChainProvider) const multicallInput: [ CallInput>>, ReturnType, @@ -207,7 +215,7 @@ export class InboxTools { maxSearchRangeBlocks: number, rangeMultiplier: number ): Promise[]> { - const eFetcher = new EventFetcher(this.l1Provider) + const eFetcher = new EventFetcher(this.parentChainProvider) // events don't become eligible until they pass a delay // find a block range which will emit eligible events @@ -245,7 +253,7 @@ export class InboxTools { /** * Find the event of the latest message that can be force include * @param maxSearchRangeBlocks The max range of blocks to search in. - * Defaults to 3 * 6545 ( = ~3 days) prior to the first eligble block + * Defaults to 3 * 6545 ( = ~3 days) prior to the first eligible block * @param startSearchRangeBlocks The start range of block to search in. * Moves incrementally up to the maxSearchRangeBlocks. Defaults to 100; * @param rangeMultiplier The multiplier to use when increasing the block range @@ -255,11 +263,11 @@ export class InboxTools { public async getForceIncludableEvent( maxSearchRangeBlocks: number = 3 * 6545, startSearchRangeBlocks = 100, - rangeMultipler = 2 + rangeMultiplier = 2 ): Promise { const bridge = Bridge__factory.connect( - this.l2Network.ethBridge.bridge, - this.l1Provider + this.chainNetwork.ethBridge.bridge, + this.parentChainProvider ) // events dont become eligible until they pass a delay @@ -268,7 +276,7 @@ export class InboxTools { bridge, startSearchRangeBlocks, maxSearchRangeBlocks, - rangeMultipler + rangeMultiplier ) // no events appeared within that time period @@ -277,8 +285,8 @@ export class InboxTools { // take the last event - as including this one will include all previous events const eventInfo = events[events.length - 1] const sequencerInbox = SequencerInbox__factory.connect( - this.l2Network.ethBridge.sequencerInbox, - this.l1Provider + this.chainNetwork.ethBridge.sequencerInbox, + this.parentChainProvider ) // has the sequencer inbox already read this latest message const totalDelayedRead = await sequencerInbox.totalDelayedMessagesRead() @@ -317,14 +325,14 @@ export class InboxTools { overrides?: Overrides ): Promise { const sequencerInbox = SequencerInbox__factory.connect( - this.l2Network.ethBridge.sequencerInbox, - this.l1Signer + this.chainNetwork.ethBridge.sequencerInbox, + this.parentChainSigner ) const eventInfo = messageDeliveredEvent || (await this.getForceIncludableEvent()) if (!eventInfo) return null - const block = await this.l1Provider.getBlock(eventInfo.blockHash) + const block = await this.parentChainProvider.getBlock(eventInfo.blockHash) return await sequencerInbox.functions.forceInclusion( eventInfo.event.messageIndex.add(1), @@ -339,19 +347,19 @@ export class InboxTools { } /** - * Send l2 signed tx using delayed inox, which won't alias the sender's adddress - * It will be automatically included by the sequencer on l2, if it isn't included + * Send Chain signed tx using delayed inbox, which won't alias the sender's address + * It will be automatically included by the sequencer on Chain, if it isn't included * within 24 hours, you can force include it * @param signedTx A signed transaction which can be sent directly to network, - * you can call inboxTools.signL2Message to get. - * @returns The l1 delayed inbox's transaction itself. + * you can call inboxTools.signChainMessage to get. + * @returns The parentChain delayed inbox's transaction itself. */ - public async sendL2SignedTx( + public async sendChainSignedTx( signedTx: string ): Promise { const delayedInbox = IInbox__factory.connect( - this.l2Network.ethBridge.inbox, - this.l1Signer + this.chainNetwork.ethBridge.inbox, + this.parentChainSigner ) const sendData = ethers.utils.solidityPack( @@ -364,43 +372,43 @@ export class InboxTools { /** * Sign a transaction with msg.to, msg.value and msg.data. - * You can use this as a helper to call inboxTools.sendL2SignedMessage + * You can use this as a helper to call inboxTools.sendChainSignedMessage * above. * @param message A signed transaction which can be sent directly to network, * tx.to, tx.data, tx.value must be provided when not contract creation, if * contractCreation is true, no need provide tx.to. tx.gasPrice and tx.nonce * can be overrided. (You can also send contract creation transaction by set tx.to * to zero address or null) - * @param l2Signer ethers Signer type, used to sign l2 transaction - * @returns The l1 delayed inbox's transaction signed data. + * @param chainSigner ethers Signer type, used to sign Chain transaction + * @returns The parentChain delayed inbox's transaction signed data. */ - public async signL2Tx( + public async signChainTx( txRequest: RequiredTransactionRequestType, - l2Signer: Signer + chainSigner: Signer ): Promise { const tx: RequiredTransactionRequestType = { ...txRequest } const contractCreation = this.isContractCreation(tx) if (!isDefined(tx.nonce)) { - tx.nonce = await l2Signer.getTransactionCount() + tx.nonce = await chainSigner.getTransactionCount() } //check transaction type (if no transaction type or gasPrice provided, use eip1559 type) if (tx.type === 1 || tx.gasPrice) { if (tx.gasPrice) { - tx.gasPrice = await l2Signer.getGasPrice() + tx.gasPrice = await chainSigner.getGasPrice() } } else { if (!isDefined(tx.maxFeePerGas)) { - const feeData = await l2Signer.getFeeData() + const feeData = await chainSigner.getFeeData() tx.maxPriorityFeePerGas = feeData.maxPriorityFeePerGas! tx.maxFeePerGas = feeData.maxFeePerGas! } tx.type = 2 } - tx.from = await l2Signer.getAddress() - tx.chainId = await l2Signer.getChainId() + tx.from = await chainSigner.getAddress() + tx.chainId = await chainSigner.getChainId() // if this is contract creation, user might not input the to address, // however, it is needed when we call to estimateArbitrumGas, so @@ -409,17 +417,17 @@ export class InboxTools { tx.to = ethers.constants.AddressZero } - //estimate gas on l2 + //estimate gas on Chain try { tx.gasLimit = ( - await this.estimateArbitrumGas(tx, l2Signer.provider!) - ).gasEstimateForL2 + await this.estimateArbitrumGas(tx, chainSigner.provider!) + ).gasEstimateForChain } catch (error) { throw new ArbSdkError('execution failed (estimate gas failed)') } if (contractCreation) { delete tx.to } - return await l2Signer.signTransaction(tx) + return await chainSigner.signTransaction(tx) } } diff --git a/tests/integration/sendL2msg.test.ts b/tests/integration/sendL2msg.test.ts index e704ab0faa..6c1aeda558 100644 --- a/tests/integration/sendL2msg.test.ts +++ b/tests/integration/sendL2msg.test.ts @@ -33,9 +33,9 @@ const sendSignedTx = async (testState: any, info?: any) => { ...info, value: BigNumber.from(0), } - const signedTx = await inbox.signL2Tx(message, l2Deployer) + const signedTx = await inbox.signChainTx(message, l2Deployer) - const l1Tx = await inbox.sendL2SignedTx(signedTx) + const l1Tx = await inbox.sendChainSignedTx(signedTx) return { signedMsg: signedTx, l1TransactionReceipt: await l1Tx?.wait(), From 448b9590319cb386c24e4b8b2b0178bcf1c1b854 Mon Sep 17 00:00:00 2001 From: Doug Lance Date: Wed, 11 Oct 2023 12:00:15 -0400 Subject: [PATCH 2/6] update to use new childChain name with ArbitrumChain type --- src/lib/inbox/inbox.ts | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/src/lib/inbox/inbox.ts b/src/lib/inbox/inbox.ts index c6d28d74a0..f477037bff 100644 --- a/src/lib/inbox/inbox.ts +++ b/src/lib/inbox/inbox.ts @@ -30,7 +30,7 @@ import { RequiredPick } from '../utils/types' import { MessageDeliveredEvent } from '../abi/Bridge' import { l1Networks as parentChainNetworks, - L2Network as ChainNetwork, + L2Network as ArbitrumChain, } from '../dataEntities/networks' import { SignerProviderUtils } from '../dataEntities/signerOrProvider' import { FetchedEvent, EventFetcher } from '../utils/eventFetcher' @@ -65,15 +65,15 @@ export class InboxTools { constructor( private readonly parentChainSigner: Signer, - private readonly chainNetwork: ChainNetwork + private readonly childChain: ArbitrumChain ) { this.parentChainProvider = SignerProviderUtils.getProviderOrThrow( this.parentChainSigner ) - this.parentChainNetwork = parentChainNetworks[chainNetwork.partnerChainID] + this.parentChainNetwork = parentChainNetworks[childChain.partnerChainID] if (!this.parentChainNetwork) throw new ArbSdkError( - `ParentChainNetwork not found for chain id: ${chainNetwork.partnerChainID}.` + `ParentChainNetwork not found for chain id: ${childChain.partnerChainID}.` ) } @@ -157,7 +157,7 @@ export class InboxTools { */ private async getForceIncludableBlockRange(blockNumberRangeSize: number) { const sequencerInbox = SequencerInbox__factory.connect( - this.chainNetwork.ethBridge.sequencerInbox, + this.childChain.ethBridge.sequencerInbox, this.parentChainProvider ) @@ -266,7 +266,7 @@ export class InboxTools { rangeMultiplier = 2 ): Promise { const bridge = Bridge__factory.connect( - this.chainNetwork.ethBridge.bridge, + this.childChain.ethBridge.bridge, this.parentChainProvider ) @@ -285,7 +285,7 @@ export class InboxTools { // take the last event - as including this one will include all previous events const eventInfo = events[events.length - 1] const sequencerInbox = SequencerInbox__factory.connect( - this.chainNetwork.ethBridge.sequencerInbox, + this.childChain.ethBridge.sequencerInbox, this.parentChainProvider ) // has the sequencer inbox already read this latest message @@ -325,7 +325,7 @@ export class InboxTools { overrides?: Overrides ): Promise { const sequencerInbox = SequencerInbox__factory.connect( - this.chainNetwork.ethBridge.sequencerInbox, + this.childChain.ethBridge.sequencerInbox, this.parentChainSigner ) const eventInfo = @@ -358,7 +358,7 @@ export class InboxTools { signedTx: string ): Promise { const delayedInbox = IInbox__factory.connect( - this.chainNetwork.ethBridge.inbox, + this.childChain.ethBridge.inbox, this.parentChainSigner ) From 8391400af1f21452e68a09f649381f425eb21774 Mon Sep 17 00:00:00 2001 From: Doug Lance Date: Wed, 11 Oct 2023 12:16:25 -0400 Subject: [PATCH 3/6] updates name of methods on inbox to use childChain --- scripts/sendL2SignedMsg.ts | 4 ++-- src/lib/inbox/inbox.ts | 4 ++-- tests/integration/sendL2msg.test.ts | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/scripts/sendL2SignedMsg.ts b/scripts/sendL2SignedMsg.ts index 088b19c0cf..d117247518 100644 --- a/scripts/sendL2SignedMsg.ts +++ b/scripts/sendL2SignedMsg.ts @@ -29,8 +29,8 @@ const sendSignedMsg = async () => { value: BigNumber.from(0), data: '0x12', } - const signedTx = await inbox.signChainTx(message, l2Deployer) - await inbox.sendChainSignedTx(signedTx) + const signedTx = await inbox.signChildChainTx(message, l2Deployer) + await inbox.sendChildChainSignedTx(signedTx) } sendSignedMsg() diff --git a/src/lib/inbox/inbox.ts b/src/lib/inbox/inbox.ts index f477037bff..98acd719b0 100644 --- a/src/lib/inbox/inbox.ts +++ b/src/lib/inbox/inbox.ts @@ -354,7 +354,7 @@ export class InboxTools { * you can call inboxTools.signChainMessage to get. * @returns The parentChain delayed inbox's transaction itself. */ - public async sendChainSignedTx( + public async sendChildChainSignedTx( signedTx: string ): Promise { const delayedInbox = IInbox__factory.connect( @@ -382,7 +382,7 @@ export class InboxTools { * @param chainSigner ethers Signer type, used to sign Chain transaction * @returns The parentChain delayed inbox's transaction signed data. */ - public async signChainTx( + public async signChildChainTx( txRequest: RequiredTransactionRequestType, chainSigner: Signer ): Promise { diff --git a/tests/integration/sendL2msg.test.ts b/tests/integration/sendL2msg.test.ts index 6c1aeda558..e9bcdd97ae 100644 --- a/tests/integration/sendL2msg.test.ts +++ b/tests/integration/sendL2msg.test.ts @@ -33,9 +33,9 @@ const sendSignedTx = async (testState: any, info?: any) => { ...info, value: BigNumber.from(0), } - const signedTx = await inbox.signChainTx(message, l2Deployer) + const signedTx = await inbox.signChildChainTx(message, l2Deployer) - const l1Tx = await inbox.sendChainSignedTx(signedTx) + const l1Tx = await inbox.sendChildChainSignedTx(signedTx) return { signedMsg: signedTx, l1TransactionReceipt: await l1Tx?.wait(), From 6e77e7516c69c3afae8c9fabd696de23de4984d0 Mon Sep 17 00:00:00 2001 From: Doug Lance Date: Wed, 11 Oct 2023 13:26:04 -0400 Subject: [PATCH 4/6] Update childChainTransactionRequest --- src/lib/inbox/inbox.ts | 56 ++++++++++++++++++++++-------------------- 1 file changed, 29 insertions(+), 27 deletions(-) diff --git a/src/lib/inbox/inbox.ts b/src/lib/inbox/inbox.ts index 98acd719b0..af2a34d51d 100644 --- a/src/lib/inbox/inbox.ts +++ b/src/lib/inbox/inbox.ts @@ -50,7 +50,7 @@ type GasComponentsWithChainPart = { gasEstimateForL1: BigNumber baseFee: BigNumber l1BaseFeeEstimate: BigNumber - gasEstimateForChain: BigNumber + gasEstimateForChildChain: BigNumber } type RequiredTransactionRequestType = RequiredPick< TransactionRequest, @@ -106,14 +106,14 @@ export class InboxTools { ) } - //Check if this request is contract creation or not. + // Check if this request is contract creation or not. private isContractCreation( - transactionChainRequest: TransactionRequest + childChainTransactionRequest: TransactionRequest ): boolean { if ( - transactionChainRequest.to === '0x' || - !isDefined(transactionChainRequest.to) || - transactionChainRequest.to === ethers.constants.AddressZero + childChainTransactionRequest.to === '0x' || + !isDefined(childChainTransactionRequest.to) || + childChainTransactionRequest.to === ethers.constants.AddressZero ) { return true } @@ -126,7 +126,7 @@ export class InboxTools { * gas fee part. */ private async estimateArbitrumGas( - transactionChainRequest: RequiredTransactionRequestType, + childChainTransactionRequest: RequiredTransactionRequestType, chainProvider: Provider ): Promise { const nodeInterface = NodeInterface__factory.connect( @@ -134,20 +134,22 @@ export class InboxTools { chainProvider ) - const contractCreation = this.isContractCreation(transactionChainRequest) + const contractCreation = this.isContractCreation( + childChainTransactionRequest + ) const gasComponents = await nodeInterface.callStatic.gasEstimateComponents( - transactionChainRequest.to || ethers.constants.AddressZero, + childChainTransactionRequest.to || ethers.constants.AddressZero, contractCreation, - transactionChainRequest.data, + childChainTransactionRequest.data, { - from: transactionChainRequest.from, - value: transactionChainRequest.value, + from: childChainTransactionRequest.from, + value: childChainTransactionRequest.value, } ) - const gasEstimateForChain: BigNumber = gasComponents.gasEstimate.sub( + const gasEstimateForChildChain: BigNumber = gasComponents.gasEstimate.sub( gasComponents.gasEstimateForL1 ) - return { ...gasComponents, gasEstimateForChain } + return { ...gasComponents, gasEstimateForChildChain } } /** @@ -304,7 +306,7 @@ export class InboxTools { /** * Force includes all eligible messages in the delayed inbox. - * The inbox contract doesnt allow a message to be force-included + * The inbox contract doesn't allow a message to be force-included * until after a delay period has been completed. * @param messageDeliveredEvent Provide this to include all messages up to this one. Responsibility is on the caller to check the eligibility of this event. * @returns The force include transaction, or null if no eligible message were found for inclusion @@ -347,7 +349,7 @@ export class InboxTools { } /** - * Send Chain signed tx using delayed inbox, which won't alias the sender's address + * Send Child Chain signed tx using delayed inbox, which won't alias the sender's address * It will be automatically included by the sequencer on Chain, if it isn't included * within 24 hours, you can force include it * @param signedTx A signed transaction which can be sent directly to network, @@ -379,36 +381,36 @@ export class InboxTools { * contractCreation is true, no need provide tx.to. tx.gasPrice and tx.nonce * can be overrided. (You can also send contract creation transaction by set tx.to * to zero address or null) - * @param chainSigner ethers Signer type, used to sign Chain transaction + * @param childChainSigner ethers Signer type, used to sign Chain transaction * @returns The parentChain delayed inbox's transaction signed data. */ public async signChildChainTx( txRequest: RequiredTransactionRequestType, - chainSigner: Signer + childChainSigner: Signer ): Promise { const tx: RequiredTransactionRequestType = { ...txRequest } const contractCreation = this.isContractCreation(tx) if (!isDefined(tx.nonce)) { - tx.nonce = await chainSigner.getTransactionCount() + tx.nonce = await childChainSigner.getTransactionCount() } //check transaction type (if no transaction type or gasPrice provided, use eip1559 type) if (tx.type === 1 || tx.gasPrice) { if (tx.gasPrice) { - tx.gasPrice = await chainSigner.getGasPrice() + tx.gasPrice = await childChainSigner.getGasPrice() } } else { if (!isDefined(tx.maxFeePerGas)) { - const feeData = await chainSigner.getFeeData() + const feeData = await childChainSigner.getFeeData() tx.maxPriorityFeePerGas = feeData.maxPriorityFeePerGas! tx.maxFeePerGas = feeData.maxFeePerGas! } tx.type = 2 } - tx.from = await chainSigner.getAddress() - tx.chainId = await chainSigner.getChainId() + tx.from = await childChainSigner.getAddress() + tx.chainId = await childChainSigner.getChainId() // if this is contract creation, user might not input the to address, // however, it is needed when we call to estimateArbitrumGas, so @@ -417,17 +419,17 @@ export class InboxTools { tx.to = ethers.constants.AddressZero } - //estimate gas on Chain + //estimate gas on child chain try { tx.gasLimit = ( - await this.estimateArbitrumGas(tx, chainSigner.provider!) - ).gasEstimateForChain + await this.estimateArbitrumGas(tx, childChainSigner.provider!) + ).gasEstimateForChildChain } catch (error) { throw new ArbSdkError('execution failed (estimate gas failed)') } if (contractCreation) { delete tx.to } - return await chainSigner.signTransaction(tx) + return await childChainSigner.signTransaction(tx) } } From 7e23cad91d8d3d8262e11a9493f8df3016377ffb Mon Sep 17 00:00:00 2001 From: Doug Lance Date: Wed, 18 Oct 2023 13:42:30 -0400 Subject: [PATCH 5/6] remove `network` --- src/lib/inbox/inbox.ts | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/src/lib/inbox/inbox.ts b/src/lib/inbox/inbox.ts index af2a34d51d..11c71f97a0 100644 --- a/src/lib/inbox/inbox.ts +++ b/src/lib/inbox/inbox.ts @@ -29,8 +29,8 @@ import { IInbox__factory } from '../abi/factories/IInbox__factory' import { RequiredPick } from '../utils/types' import { MessageDeliveredEvent } from '../abi/Bridge' import { - l1Networks as parentChainNetworks, - L2Network as ArbitrumChain, + l1Networks as parentChains, + L2Network as ChildChain, } from '../dataEntities/networks' import { SignerProviderUtils } from '../dataEntities/signerOrProvider' import { FetchedEvent, EventFetcher } from '../utils/eventFetcher' @@ -61,17 +61,17 @@ type RequiredTransactionRequestType = RequiredPick< */ export class InboxTools { private readonly parentChainProvider - private readonly parentChainNetwork + private readonly parentChain constructor( private readonly parentChainSigner: Signer, - private readonly childChain: ArbitrumChain + private readonly childChain: ChildChain ) { this.parentChainProvider = SignerProviderUtils.getProviderOrThrow( this.parentChainSigner ) - this.parentChainNetwork = parentChainNetworks[childChain.partnerChainID] - if (!this.parentChainNetwork) + this.parentChain = parentChains[childChain.partnerChainID] + if (!this.parentChain) throw new ArbSdkError( `ParentChainNetwork not found for chain id: ${childChain.partnerChainID}.` ) @@ -96,7 +96,7 @@ export class InboxTools { // we take a long average block time of 14s // and always move at least 10 blocks const diffBlocks = Math.max( - Math.ceil(diff / this.parentChainNetwork.blockTime), + Math.ceil(diff / this.parentChain.blockTime), 10 ) @@ -352,7 +352,7 @@ export class InboxTools { * Send Child Chain signed tx using delayed inbox, which won't alias the sender's address * It will be automatically included by the sequencer on Chain, if it isn't included * within 24 hours, you can force include it - * @param signedTx A signed transaction which can be sent directly to network, + * @param signedTx A signed transaction which can be sent directly to chain, * you can call inboxTools.signChainMessage to get. * @returns The parentChain delayed inbox's transaction itself. */ @@ -376,7 +376,7 @@ export class InboxTools { * Sign a transaction with msg.to, msg.value and msg.data. * You can use this as a helper to call inboxTools.sendChainSignedMessage * above. - * @param message A signed transaction which can be sent directly to network, + * @param message A signed transaction which can be sent directly to chain, * tx.to, tx.data, tx.value must be provided when not contract creation, if * contractCreation is true, no need provide tx.to. tx.gasPrice and tx.nonce * can be overrided. (You can also send contract creation transaction by set tx.to From 3684f80564dd0166b58977f0efabcb7f76258ab8 Mon Sep 17 00:00:00 2001 From: Doug Lance Date: Thu, 19 Oct 2023 08:53:51 -0400 Subject: [PATCH 6/6] update names with from pr feedback --- src/lib/inbox/inbox.ts | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/lib/inbox/inbox.ts b/src/lib/inbox/inbox.ts index 11c71f97a0..5f2759164c 100644 --- a/src/lib/inbox/inbox.ts +++ b/src/lib/inbox/inbox.ts @@ -45,7 +45,7 @@ type ForceInclusionParams = FetchedEvent & { delayedAcc: string } -type GasComponentsWithChainPart = { +type GasComponentsWithChildChainPart = { gasEstimate: BigNumber gasEstimateForL1: BigNumber baseFee: BigNumber @@ -127,11 +127,11 @@ export class InboxTools { */ private async estimateArbitrumGas( childChainTransactionRequest: RequiredTransactionRequestType, - chainProvider: Provider - ): Promise { + childChainProvider: Provider + ): Promise { const nodeInterface = NodeInterface__factory.connect( NODE_INTERFACE_ADDRESS, - chainProvider + childChainProvider ) const contractCreation = this.isContractCreation(