From c947423b279e5b4d4b71d9fce46a001c91b6ba41 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Thu, 14 Nov 2024 09:02:14 -0500 Subject: [PATCH 01/19] initial commit for viem api --- package.json | 7 +- .../arbitrumDeposit/abis/inbox.ts | 42 ++ .../arbitrumDeposit/abis/l1GatewayRouter.ts | 23 + src/experimental/arbitrumDeposit/actions.ts | 90 +++ src/experimental/arbitrumDeposit/types.ts | 56 ++ src/experimental/chains.ts | 39 ++ tests/integration/arbitrumDeposit.test.ts | 90 +++ tsconfig.json | 2 +- yarn.lock | 581 +++++++++++++++++- 9 files changed, 923 insertions(+), 7 deletions(-) create mode 100644 src/experimental/arbitrumDeposit/abis/inbox.ts create mode 100644 src/experimental/arbitrumDeposit/abis/l1GatewayRouter.ts create mode 100644 src/experimental/arbitrumDeposit/actions.ts create mode 100644 src/experimental/arbitrumDeposit/types.ts create mode 100644 src/experimental/chains.ts create mode 100644 tests/integration/arbitrumDeposit.test.ts diff --git a/package.json b/package.json index fad6ee2bb0..1b1e4790eb 100644 --- a/package.json +++ b/package.json @@ -24,6 +24,7 @@ "prepare": "yarn run gen:abi", "gen:abi": "node ./scripts/genAbi.js", "gen:network": "ts-node ./scripts/genNetwork.ts", + "gen:wagmi": "wagmi generate", "prepublishOnly": "yarn build && yarn format", "preversion": "yarn lint", "prebuild": "yarn gen:abi", @@ -50,7 +51,8 @@ "@ethersproject/bignumber": "^5.1.1", "@ethersproject/bytes": "^5.0.8", "async-mutex": "^0.4.0", - "ethers": "^5.1.0" + "ethers": "^5.1.0", + "viem": "^2.21.45" }, "devDependencies": { "@arbitrum/nitro-contracts": "^1.1.1", @@ -65,6 +67,7 @@ "@typescript-eslint/eslint-plugin": "^5.14.0", "@typescript-eslint/eslint-plugin-tslint": "^5.27.1", "@typescript-eslint/parser": "^5.14.0", + "@wagmi/cli": "^2.1.18", "audit-ci": "^6.3.0", "axios": "^1.7.4", "chai": "^4.2.0", @@ -84,7 +87,7 @@ "ts-node": "^10.2.1", "tslint": "^6.1.3", "typechain": "7.0.0", - "typescript": "^4.9.5", + "typescript": "^5.5.4", "yargs": "^17.3.1" }, "files": [ diff --git a/src/experimental/arbitrumDeposit/abis/inbox.ts b/src/experimental/arbitrumDeposit/abis/inbox.ts new file mode 100644 index 0000000000..38bb10f858 --- /dev/null +++ b/src/experimental/arbitrumDeposit/abis/inbox.ts @@ -0,0 +1,42 @@ +export const inboxAbi = [ + { + inputs: [], + name: 'depositEth', + outputs: [{ type: 'uint256' }], + stateMutability: 'payable', + type: 'function' + }, + { + inputs: [ + { name: 'to', type: 'address' }, + { name: 'l2CallValue', type: 'uint256' }, + { name: 'maxSubmissionCost', type: 'uint256' }, + { name: 'excessFeeRefundAddress', type: 'address' }, + { name: 'callValueRefundAddress', type: 'address' }, + { name: 'gasLimit', type: 'uint256' }, + { name: 'maxFeePerGas', type: 'uint256' }, + { name: 'data', type: 'bytes' } + ], + name: 'createRetryableTicket', + outputs: [{ type: 'uint256' }], + stateMutability: 'payable', + type: 'function' + }, + { + anonymous: false, + inputs: [ + { indexed: false, name: 'messageNum', type: 'uint256' }, + { indexed: false, name: 'data', type: 'bytes' } + ], + name: 'InboxMessageDelivered', + type: 'event' + }, + { + anonymous: false, + inputs: [ + { indexed: false, name: 'messageNum', type: 'uint256' } + ], + name: 'InboxMessageDeliveredFromOrigin', + type: 'event' + } +] as const \ No newline at end of file diff --git a/src/experimental/arbitrumDeposit/abis/l1GatewayRouter.ts b/src/experimental/arbitrumDeposit/abis/l1GatewayRouter.ts new file mode 100644 index 0000000000..dfe202aa65 --- /dev/null +++ b/src/experimental/arbitrumDeposit/abis/l1GatewayRouter.ts @@ -0,0 +1,23 @@ +export const l1GatewayRouterAbi = [ + { + inputs: [ + { name: '_token', type: 'address' }, + { name: '_to', type: 'address' }, + { name: '_amount', type: 'uint256' }, + { name: '_maxGas', type: 'uint256' }, + { name: '_gasPriceBid', type: 'uint256' }, + { name: '_data', type: 'bytes' } + ], + name: 'outboundTransfer', + outputs: [{ type: 'bytes' }], + stateMutability: 'payable', + type: 'function' + }, + { + inputs: [{ name: '_token', type: 'address' }], + name: 'getGateway', + outputs: [{ type: 'address' }], + stateMutability: 'view', + type: 'function' + } +] as const \ No newline at end of file diff --git a/src/experimental/arbitrumDeposit/actions.ts b/src/experimental/arbitrumDeposit/actions.ts new file mode 100644 index 0000000000..d87d3cfc8f --- /dev/null +++ b/src/experimental/arbitrumDeposit/actions.ts @@ -0,0 +1,90 @@ +import { + type PublicClient, + type WalletClient, + type Client, + encodeFunctionData, + Account, + Address, + parseTransaction, + serializeTransaction +} from 'viem' +import { localEthChain } from '../chains' +import { inboxAbi } from './abis/inbox' + +export type ArbitrumDepositActions = { + depositEth: (args: { + amount: bigint; + account: Account | Address; + walletClient: WalletClient; + }) => Promise<`0x${string}`> +} + +type ArbitrumChainConfig = { + ethBridge: { + inbox: `0x${string}` + } +} + +export function arbitrumDepositActions(childChain: ArbitrumChainConfig) { + return (parentPublicClient: TClient): ArbitrumDepositActions => { + const getDepositRequest = async ({ + amount, + account + }: { + amount: bigint + account: Account | Address + }) => { + const from = typeof account === 'string' ? account : account.address + + return { + to: childChain.ethBridge.inbox, + value: amount, + data: encodeFunctionData({ + abi: inboxAbi, + functionName: 'depositEth', + args: [] + }), + from + } + } + + return { + async depositEth({ amount, account, walletClient }) { + const request = await getDepositRequest({ + amount, + account + }) + + const gasPrice = await parentPublicClient.getGasPrice() + + const nonce = await parentPublicClient.getTransactionCount({ + address: typeof account === 'string' ? account as `0x${string}` : account.address, + blockTag: 'latest' + }) + + const signedTx = await walletClient.signTransaction({ + ...request, + account, + chain: localEthChain, + gas: BigInt('130000'), + maxFeePerGas: gasPrice, + maxPriorityFeePerGas: gasPrice, + nonce + }) + + // Parse and serialize with L2 chain ID + const parsedTx = parseTransaction((signedTx as any).raw) + const serializedTx = serializeTransaction({ + ...parsedTx, + }) + + // Send to L2 + const hash = await parentPublicClient.sendRawTransaction({ + serializedTransaction: serializedTx + }) + + return hash + } + } + } +} \ No newline at end of file diff --git a/src/experimental/arbitrumDeposit/types.ts b/src/experimental/arbitrumDeposit/types.ts new file mode 100644 index 0000000000..dd76192202 --- /dev/null +++ b/src/experimental/arbitrumDeposit/types.ts @@ -0,0 +1,56 @@ +import type { Address, Hash, Transport } from 'viem' +import type { + PublicClient, + WalletClient, + Account, + Chain +} from 'viem' + +export type ArbitrumDepositConfig = { + inboxAddress: Address +} + +export type GasOverrides = { + gasLimit?: { + min?: bigint + max?: bigint + } + maxFeePerGas?: { + min?: bigint + max?: bigint + } + maxSubmissionCost?: { + min?: bigint + max?: bigint + } +} + +export type RetryableGasParams = { + gasLimit: bigint + maxFeePerGas: bigint + maxSubmissionCost: bigint +} + +export type EthDepositParameters = { + amount: bigint + account: Account | Address + to?: Address // Optional destination address + retryableGasOverrides?: GasOverrides +} + +export type Erc20DepositParameters = { + token: Address + amount: bigint + account: Account | Address + to?: Address // Optional destination address, defaults to sender +} + +export type ApproveErc20Parameters = { + token: Address + amount: bigint + account: Account | Address +} + +export type ArbitrumDepositActions = { + depositEth: (args: EthDepositParameters) => Promise +} \ No newline at end of file diff --git a/src/experimental/chains.ts b/src/experimental/chains.ts new file mode 100644 index 0000000000..91d7bace69 --- /dev/null +++ b/src/experimental/chains.ts @@ -0,0 +1,39 @@ +import { type Chain } from 'viem' + +export const localEthChain = { + id: 1337, + name: 'EthLocal', + nativeCurrency: { + decimals: 18, + name: 'Ether', + symbol: 'ETH', + }, + rpcUrls: { + default: { http: ['http://localhost:8545'] }, + public: { http: ['http://localhost:8545'] }, + } +} as const satisfies Chain + +export const localArbChain = { + id: 412346, + name: 'ArbLocal', + nativeCurrency: { + decimals: 18, + name: 'Ether', + symbol: 'ETH', + }, + rpcUrls: { + default: { http: ['http://localhost:8547'] }, + public: { http: ['http://localhost:8547'] }, + } +} as const satisfies Chain + +function getChainConfig(chainId: number) { + const chains = { + [localEthChain.id]: localEthChain, + [localArbChain.id]: localArbChain + } + return chains[chainId as keyof typeof chains] +} + +export { getChainConfig } \ No newline at end of file diff --git a/tests/integration/arbitrumDeposit.test.ts b/tests/integration/arbitrumDeposit.test.ts new file mode 100644 index 0000000000..9f6bc822a9 --- /dev/null +++ b/tests/integration/arbitrumDeposit.test.ts @@ -0,0 +1,90 @@ +import { expect } from 'chai' +import { createWalletClient, createPublicClient, http, parseEther } from 'viem' +import { privateKeyToAccount } from 'viem/accounts' +import { arbitrumDepositActions } from '../../src/experimental/arbitrumDeposit/actions' +import { testSetup, config } from '../../scripts/testSetup' +import { localEthChain, localArbChain } from '../../src/experimental/chains' + +describe('arbitrumDepositActions', function() { + this.timeout(60000) + + it('deposits ether', async function() { + const { childChain } = await testSetup() + + const account = privateKeyToAccount(`0x${config.ethKey}` as `0x${string}`) + + // Create parent clients + const parentWalletClient = createWalletClient({ + account, + chain: localEthChain, + transport: http(config.ethUrl) + }) + + const parentPublicClient = createPublicClient({ + chain: localEthChain, + transport: http(config.ethUrl) + }).extend(arbitrumDepositActions({ + ethBridge: { + inbox: childChain.ethBridge.inbox as `0x${string}` + } + })) + + // Create child client for balance checks + const childPublicClient = createPublicClient({ + chain: localArbChain, + transport: http(config.arbUrl) + }) + + const initialBalance = await childPublicClient.getBalance({ + address: account.address + }) + console.log('Initial child balance:', initialBalance) + + const depositAmount = parseEther('0.01') + console.log('Deposit amount:', depositAmount) + + const hash = await parentPublicClient.depositEth({ + amount: depositAmount, + account: account.address, + walletClient: parentWalletClient + }) + + // Wait for parent transaction + const receipt = await parentPublicClient.waitForTransactionReceipt({ + hash, + confirmations: 1 + }) + + expect(receipt.status).to.equal('success') + + // Poll for child balance change + let finalBalance = initialBalance + let attempts = 0 + const maxAttempts = 10 + + while (attempts < maxAttempts) { + await new Promise(resolve => setTimeout(resolve, 3000)) + + const currentBalance = await childPublicClient.getBalance({ + address: account.address + }) + + console.log(`Attempt ${attempts + 1} - Current balance:`, currentBalance) + + if (currentBalance > initialBalance) { + finalBalance = currentBalance + break + } + + attempts++ + } + + console.log('Final child balance:', finalBalance) + console.log('Balance difference:', finalBalance - initialBalance) + + expect(Number(finalBalance)).to.be.greaterThan( + Number(initialBalance), + 'child balance did not increase after deposit' + ) + }) +}) \ No newline at end of file diff --git a/tsconfig.json b/tsconfig.json index 3a5901b621..8fba0a8926 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -1,6 +1,6 @@ { "compilerOptions": { - "target": "ES2017", + "target": "ES2020", "module": "commonjs", "declaration": true, "rootDir": "./src", diff --git a/yarn.lock b/yarn.lock index 07788bae1e..ffccb87e64 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2,6 +2,11 @@ # yarn lockfile v1 +"@adraffy/ens-normalize@^1.10.1": + version "1.11.0" + resolved "https://registry.yarnpkg.com/@adraffy/ens-normalize/-/ens-normalize-1.11.0.tgz#42cc67c5baa407ac25059fcd7d405cc5ecdb0c33" + integrity sha512-/3DDPKHqqIqxUULp8yP4zODUY1i+2xvVWsv8A79xGWdCAG+8sb0hRh0Rk2QyOJUnnbyPUAZYcpBuRe3nS2OIUg== + "@aduh95/viz.js@^3.7.0": version "3.7.0" resolved "https://registry.yarnpkg.com/@aduh95/viz.js/-/viz.js-3.7.0.tgz#a20d86c5fc8f6abebdc39b96a4326e10375d77c0" @@ -311,6 +316,121 @@ dependencies: "@cspotcode/source-map-consumer" "0.8.0" +"@esbuild/aix-ppc64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/aix-ppc64/-/aix-ppc64-0.19.12.tgz#d1bc06aedb6936b3b6d313bf809a5a40387d2b7f" + integrity sha512-bmoCYyWdEL3wDQIVbcyzRyeKLgk2WtWLTWz1ZIAZF/EGbNOwSA6ew3PftJ1PqMiOOGu0OyFMzG53L0zqIpPeNA== + +"@esbuild/android-arm64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/android-arm64/-/android-arm64-0.19.12.tgz#7ad65a36cfdb7e0d429c353e00f680d737c2aed4" + integrity sha512-P0UVNGIienjZv3f5zq0DP3Nt2IE/3plFzuaS96vihvD0Hd6H/q4WXUGpCxD/E8YrSXfNyRPbpTq+T8ZQioSuPA== + +"@esbuild/android-arm@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/android-arm/-/android-arm-0.19.12.tgz#b0c26536f37776162ca8bde25e42040c203f2824" + integrity sha512-qg/Lj1mu3CdQlDEEiWrlC4eaPZ1KztwGJ9B6J+/6G+/4ewxJg7gqj8eVYWvao1bXrqGiW2rsBZFSX3q2lcW05w== + +"@esbuild/android-x64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/android-x64/-/android-x64-0.19.12.tgz#cb13e2211282012194d89bf3bfe7721273473b3d" + integrity sha512-3k7ZoUW6Q6YqhdhIaq/WZ7HwBpnFBlW905Fa4s4qWJyiNOgT1dOqDiVAQFwBH7gBRZr17gLrlFCRzF6jFh7Kew== + +"@esbuild/darwin-arm64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/darwin-arm64/-/darwin-arm64-0.19.12.tgz#cbee41e988020d4b516e9d9e44dd29200996275e" + integrity sha512-B6IeSgZgtEzGC42jsI+YYu9Z3HKRxp8ZT3cqhvliEHovq8HSX2YX8lNocDn79gCKJXOSaEot9MVYky7AKjCs8g== + +"@esbuild/darwin-x64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/darwin-x64/-/darwin-x64-0.19.12.tgz#e37d9633246d52aecf491ee916ece709f9d5f4cd" + integrity sha512-hKoVkKzFiToTgn+41qGhsUJXFlIjxI/jSYeZf3ugemDYZldIXIxhvwN6erJGlX4t5h417iFuheZ7l+YVn05N3A== + +"@esbuild/freebsd-arm64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/freebsd-arm64/-/freebsd-arm64-0.19.12.tgz#1ee4d8b682ed363b08af74d1ea2b2b4dbba76487" + integrity sha512-4aRvFIXmwAcDBw9AueDQ2YnGmz5L6obe5kmPT8Vd+/+x/JMVKCgdcRwH6APrbpNXsPz+K653Qg8HB/oXvXVukA== + +"@esbuild/freebsd-x64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/freebsd-x64/-/freebsd-x64-0.19.12.tgz#37a693553d42ff77cd7126764b535fb6cc28a11c" + integrity sha512-EYoXZ4d8xtBoVN7CEwWY2IN4ho76xjYXqSXMNccFSx2lgqOG/1TBPW0yPx1bJZk94qu3tX0fycJeeQsKovA8gg== + +"@esbuild/linux-arm64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/linux-arm64/-/linux-arm64-0.19.12.tgz#be9b145985ec6c57470e0e051d887b09dddb2d4b" + integrity sha512-EoTjyYyLuVPfdPLsGVVVC8a0p1BFFvtpQDB/YLEhaXyf/5bczaGeN15QkR+O4S5LeJ92Tqotve7i1jn35qwvdA== + +"@esbuild/linux-arm@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/linux-arm/-/linux-arm-0.19.12.tgz#207ecd982a8db95f7b5279207d0ff2331acf5eef" + integrity sha512-J5jPms//KhSNv+LO1S1TX1UWp1ucM6N6XuL6ITdKWElCu8wXP72l9MM0zDTzzeikVyqFE6U8YAV9/tFyj0ti+w== + +"@esbuild/linux-ia32@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/linux-ia32/-/linux-ia32-0.19.12.tgz#d0d86b5ca1562523dc284a6723293a52d5860601" + integrity sha512-Thsa42rrP1+UIGaWz47uydHSBOgTUnwBwNq59khgIwktK6x60Hivfbux9iNR0eHCHzOLjLMLfUMLCypBkZXMHA== + +"@esbuild/linux-loong64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/linux-loong64/-/linux-loong64-0.19.12.tgz#9a37f87fec4b8408e682b528391fa22afd952299" + integrity sha512-LiXdXA0s3IqRRjm6rV6XaWATScKAXjI4R4LoDlvO7+yQqFdlr1Bax62sRwkVvRIrwXxvtYEHHI4dm50jAXkuAA== + +"@esbuild/linux-mips64el@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/linux-mips64el/-/linux-mips64el-0.19.12.tgz#4ddebd4e6eeba20b509d8e74c8e30d8ace0b89ec" + integrity sha512-fEnAuj5VGTanfJ07ff0gOA6IPsvrVHLVb6Lyd1g2/ed67oU1eFzL0r9WL7ZzscD+/N6i3dWumGE1Un4f7Amf+w== + +"@esbuild/linux-ppc64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/linux-ppc64/-/linux-ppc64-0.19.12.tgz#adb67dadb73656849f63cd522f5ecb351dd8dee8" + integrity sha512-nYJA2/QPimDQOh1rKWedNOe3Gfc8PabU7HT3iXWtNUbRzXS9+vgB0Fjaqr//XNbd82mCxHzik2qotuI89cfixg== + +"@esbuild/linux-riscv64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/linux-riscv64/-/linux-riscv64-0.19.12.tgz#11bc0698bf0a2abf8727f1c7ace2112612c15adf" + integrity sha512-2MueBrlPQCw5dVJJpQdUYgeqIzDQgw3QtiAHUC4RBz9FXPrskyyU3VI1hw7C0BSKB9OduwSJ79FTCqtGMWqJHg== + +"@esbuild/linux-s390x@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/linux-s390x/-/linux-s390x-0.19.12.tgz#e86fb8ffba7c5c92ba91fc3b27ed5a70196c3cc8" + integrity sha512-+Pil1Nv3Umes4m3AZKqA2anfhJiVmNCYkPchwFJNEJN5QxmTs1uzyy4TvmDrCRNT2ApwSari7ZIgrPeUx4UZDg== + +"@esbuild/linux-x64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/linux-x64/-/linux-x64-0.19.12.tgz#5f37cfdc705aea687dfe5dfbec086a05acfe9c78" + integrity sha512-B71g1QpxfwBvNrfyJdVDexenDIt1CiDN1TIXLbhOw0KhJzE78KIFGX6OJ9MrtC0oOqMWf+0xop4qEU8JrJTwCg== + +"@esbuild/netbsd-x64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/netbsd-x64/-/netbsd-x64-0.19.12.tgz#29da566a75324e0d0dd7e47519ba2f7ef168657b" + integrity sha512-3ltjQ7n1owJgFbuC61Oj++XhtzmymoCihNFgT84UAmJnxJfm4sYCiSLTXZtE00VWYpPMYc+ZQmB6xbSdVh0JWA== + +"@esbuild/openbsd-x64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/openbsd-x64/-/openbsd-x64-0.19.12.tgz#306c0acbdb5a99c95be98bdd1d47c916e7dc3ff0" + integrity sha512-RbrfTB9SWsr0kWmb9srfF+L933uMDdu9BIzdA7os2t0TXhCRjrQyCeOt6wVxr79CKD4c+p+YhCj31HBkYcXebw== + +"@esbuild/sunos-x64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/sunos-x64/-/sunos-x64-0.19.12.tgz#0933eaab9af8b9b2c930236f62aae3fc593faf30" + integrity sha512-HKjJwRrW8uWtCQnQOz9qcU3mUZhTUQvi56Q8DPTLLB+DawoiQdjsYq+j+D3s9I8VFtDr+F9CjgXKKC4ss89IeA== + +"@esbuild/win32-arm64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/win32-arm64/-/win32-arm64-0.19.12.tgz#773bdbaa1971b36db2f6560088639ccd1e6773ae" + integrity sha512-URgtR1dJnmGvX864pn1B2YUYNzjmXkuJOIqG2HdU62MVS4EHpU2946OZoTMnRUHklGtJdJZ33QfzdjGACXhn1A== + +"@esbuild/win32-ia32@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/win32-ia32/-/win32-ia32-0.19.12.tgz#000516cad06354cc84a73f0943a4aa690ef6fd67" + integrity sha512-+ZOE6pUkMOJfmxmBZElNOx72NKpIa/HFOMGzu8fqzQJ5kgf6aTGrcJaFsNiVMH4JKpMipyK+7k0n2UXN7a8YKQ== + +"@esbuild/win32-x64@0.19.12": + version "0.19.12" + resolved "https://registry.yarnpkg.com/@esbuild/win32-x64/-/win32-x64-0.19.12.tgz#c57c8afbb4054a3ab8317591a0b7320360b444ae" + integrity sha512-T1QyPSDCyMXaO3pzBkF96E8xMkiRYbUEZADd29SyPGabqxMViNoii+NcK7eWJAEoU6RZyEm5lVSIjTmcdoB9HA== + "@eslint/eslintrc@^0.4.3": version "0.4.3" resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-0.4.3.tgz#9e42981ef035beb3dd49add17acb96e8ff6f394c" @@ -1086,11 +1206,23 @@ tweetnacl "^1.0.3" tweetnacl-util "^0.15.1" +"@noble/curves@1.6.0", "@noble/curves@^1.4.0", "@noble/curves@^1.6.0", "@noble/curves@~1.6.0": + version "1.6.0" + resolved "https://registry.yarnpkg.com/@noble/curves/-/curves-1.6.0.tgz#be5296ebcd5a1730fccea4786d420f87abfeb40b" + integrity sha512-TlaHRXDehJuRNR9TfZDNQ45mMEd5dwUwmicsafcIX4SsNiqnCHKjE/1alYPd/lDRVhxdhUAlv8uEhMCI5zjIJQ== + dependencies: + "@noble/hashes" "1.5.0" + "@noble/hashes@1.2.0", "@noble/hashes@~1.2.0": version "1.2.0" resolved "https://registry.yarnpkg.com/@noble/hashes/-/hashes-1.2.0.tgz#a3150eeb09cc7ab207ebf6d7b9ad311a9bdbed12" integrity sha512-FZfhjEDbT5GRswV3C6uvLPHMiVD6lQBmpoX5+eSiPaMTXte/IKqI5dykDxzZB/WBeK/CDuQRBWarPdi3FNY2zQ== +"@noble/hashes@1.5.0", "@noble/hashes@^1.4.0", "@noble/hashes@^1.5.0", "@noble/hashes@~1.5.0": + version "1.5.0" + resolved "https://registry.yarnpkg.com/@noble/hashes/-/hashes-1.5.0.tgz#abadc5ca20332db2b1b2aa3e496e9af1213570b0" + integrity sha512-1j6kQFb7QRru7eKN3ZDvRcP13rugwdxZqCjbiAVZfIJwgj2A65UmT4TgARXGlXgnRkORLTDTrO19ZErt7+QXgA== + "@noble/secp256k1@1.7.1", "@noble/secp256k1@~1.7.0": version "1.7.1" resolved "https://registry.yarnpkg.com/@noble/secp256k1/-/secp256k1-1.7.1.tgz#b251c70f824ce3ca7f8dc3df08d58f005cc0507c" @@ -1393,6 +1525,11 @@ resolved "https://registry.yarnpkg.com/@scure/base/-/base-1.1.3.tgz#8584115565228290a6c6c4961973e0903bb3df2f" integrity sha512-/+SgoRjLq7Xlf0CWuLHq2LUZeL/w65kfzAPG5NH9pcmBhs+nunQTn4gvdwgMTIXnt9b2C/1SeL2XiysZEyIC9Q== +"@scure/base@~1.1.7", "@scure/base@~1.1.8": + version "1.1.9" + resolved "https://registry.yarnpkg.com/@scure/base/-/base-1.1.9.tgz#e5e142fbbfe251091f9c5f1dd4c834ac04c3dbd1" + integrity sha512-8YKhl8GHiNI/pU2VMaofa2Tor7PJRAjwQLBBuilkJ9L5+13yVbC7JO/wS7piioAvPSwR3JKM1IJ/u4xQzbcXKg== + "@scure/bip32@1.1.5": version "1.1.5" resolved "https://registry.yarnpkg.com/@scure/bip32/-/bip32-1.1.5.tgz#d2ccae16dcc2e75bc1d75f5ef3c66a338d1ba300" @@ -1402,6 +1539,15 @@ "@noble/secp256k1" "~1.7.0" "@scure/base" "~1.1.0" +"@scure/bip32@1.5.0", "@scure/bip32@^1.5.0": + version "1.5.0" + resolved "https://registry.yarnpkg.com/@scure/bip32/-/bip32-1.5.0.tgz#dd4a2e1b8a9da60e012e776d954c4186db6328e6" + integrity sha512-8EnFYkqEQdnkuGBVpCzKxyIwDCBLDVj3oiX0EKUFre/tOjL/Hqba1D6n/8RcmaQy4f95qQFrO2A8Sr6ybh4NRw== + dependencies: + "@noble/curves" "~1.6.0" + "@noble/hashes" "~1.5.0" + "@scure/base" "~1.1.7" + "@scure/bip39@1.1.1": version "1.1.1" resolved "https://registry.yarnpkg.com/@scure/bip39/-/bip39-1.1.1.tgz#b54557b2e86214319405db819c4b6a370cf340c5" @@ -1410,6 +1556,14 @@ "@noble/hashes" "~1.2.0" "@scure/base" "~1.1.0" +"@scure/bip39@1.4.0", "@scure/bip39@^1.4.0": + version "1.4.0" + resolved "https://registry.yarnpkg.com/@scure/bip39/-/bip39-1.4.0.tgz#664d4f851564e2e1d4bffa0339f9546ea55960a6" + integrity sha512-BEEm6p8IueV/ZTfQLp/0vhw4NPnT9oWf5+28nvmeUICjP99f4vr2d+qc7AVGDDtwRep6ifR43Yed9ERVmiITzw== + dependencies: + "@noble/hashes" "~1.5.0" + "@scure/base" "~1.1.8" + "@sentry/core@5.30.0": version "5.30.0" resolved "https://registry.yarnpkg.com/@sentry/core/-/core-5.30.0.tgz#6b203664f69e75106ee8b5a2fe1d717379b331f3" @@ -1753,6 +1907,32 @@ resolved "https://registry.yarnpkg.com/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz#aa58042711d6e3275dd37dc597e5d31e8c290a44" integrity sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q== +"@wagmi/cli@^2.1.18": + version "2.1.18" + resolved "https://registry.yarnpkg.com/@wagmi/cli/-/cli-2.1.18.tgz#d10ddd7a3517a723b48714538e1585c66dff029f" + integrity sha512-1Vqz3Kj0WY/p6vUq1a2m8NH+64wAcoV+fUC8j5BrEgaeCDbQrWdZ2nMLbz/I6ao2oPNvv1eNWCjR6r8QiscXlA== + dependencies: + abitype "^1.0.4" + bundle-require "^4.0.2" + cac "^6.7.14" + change-case "^5.4.4" + chokidar "4.0.1" + dedent "^0.7.0" + dotenv "^16.3.1" + dotenv-expand "^10.0.0" + esbuild "^0.19.0" + execa "^8.0.1" + fdir "^6.1.1" + find-up "^6.3.0" + fs-extra "^11.2.0" + ora "^6.3.1" + pathe "^1.1.2" + picocolors "^1.0.0" + picomatch "^3.0.0" + prettier "^3.0.3" + viem "2.x" + zod "^3.22.2" + "@yarnpkg/lockfile@^1.1.0": version "1.1.0" resolved "https://registry.yarnpkg.com/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz#e77a97fbd345b76d83245edcd17d393b1b41fb31" @@ -1766,6 +1946,11 @@ JSONStream@^1.3.5: jsonparse "^1.2.0" through ">=2.2.7 <3" +abitype@1.0.6, abitype@^1.0.4, abitype@^1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/abitype/-/abitype-1.0.6.tgz#76410903e1d88e34f1362746e2d407513c38565b" + integrity sha512-MMSqYh4+C/aVqI2RQaWqbvI4Kxo5cQV40WQ4QFtDnNzCkqChm8MuENhElmynZlO0qUy/ObkEUaXtKqYnx1Kp3A== + abstract-level@^1.0.0, abstract-level@^1.0.2, abstract-level@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/abstract-level/-/abstract-level-1.0.3.tgz#78a67d3d84da55ee15201486ab44c09560070741" @@ -1866,6 +2051,11 @@ ansi-regex@^5.0.1: resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== +ansi-regex@^6.0.1: + version "6.1.0" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-6.1.0.tgz#95ec409c69619d6cb1b8b34f14b660ef28ebd654" + integrity sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA== + ansi-styles@^3.2.1: version "3.2.1" resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" @@ -2074,6 +2264,15 @@ bl@^4.0.3: inherits "^2.0.4" readable-stream "^3.4.0" +bl@^5.0.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/bl/-/bl-5.1.0.tgz#183715f678c7188ecef9fe475d90209400624273" + integrity sha512-tv1ZJHLfTDnXE6tMHv73YgSJaWR2AFuPwMntBe7XL/GBFHnT0CLnsHMogfk5+GzCDC5ZWarSCYaIGATZt9dNsQ== + dependencies: + buffer "^6.0.3" + inherits "^2.0.4" + readable-stream "^3.4.0" + blakejs@^1.1.0: version "1.2.1" resolved "https://registry.yarnpkg.com/blakejs/-/blakejs-1.2.1.tgz#5057e4206eadb4a97f7c0b6e197a505042fc3814" @@ -2217,11 +2416,23 @@ builtin-modules@^1.1.1: resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-1.1.1.tgz#270f076c5a72c02f5b65a47df94c5fe3a278892f" integrity sha512-wxXCdllwGhI2kCC0MnvTGYTMvnVZTvqgypkiTI8Pa5tcz2i6VqsqwYGgqwXji+4RgCzms6EajE4IxiUH6HH8nQ== +bundle-require@^4.0.2: + version "4.2.1" + resolved "https://registry.yarnpkg.com/bundle-require/-/bundle-require-4.2.1.tgz#4c450a5807381d20ade987bde8ac391544257919" + integrity sha512-7Q/6vkyYAwOmQNRw75x+4yRtZCZJXUDmHHlFdkiV0wgv/reNjtJwpu1jPJ0w2kbEpIM0uoKI3S4/f39dU7AjSA== + dependencies: + load-tsconfig "^0.2.3" + bytes@3.1.2: version "3.1.2" resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== +cac@^6.7.14: + version "6.7.14" + resolved "https://registry.yarnpkg.com/cac/-/cac-6.7.14.tgz#804e1e6f506ee363cb0e3ccbb09cad5dd9870959" + integrity sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ== + caching-transform@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/caching-transform/-/caching-transform-4.0.0.tgz#00d297a4206d71e2163c39eaffa8157ac0651f0f" @@ -2309,6 +2520,16 @@ chalk@^4.0.0, chalk@^4.1.0, chalk@^4.1.2: ansi-styles "^4.1.0" supports-color "^7.1.0" +chalk@^5.0.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-5.3.0.tgz#67c20a7ebef70e7f3970a01f90fa210cb6860385" + integrity sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w== + +change-case@^5.4.4: + version "5.4.4" + resolved "https://registry.yarnpkg.com/change-case/-/change-case-5.4.4.tgz#0d52b507d8fb8f204343432381d1a6d7bff97a02" + integrity sha512-HRQyTk2/YPEkt9TnUPbOpr64Uw3KOicFWPVBb+xiHvd6eBx/qPr9xqfBFDT8P2vWsvvz4jbEkfDe71W3VyNu2w== + check-error@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/check-error/-/check-error-1.0.3.tgz#a6502e4312a7ee969f646e83bb3ddd56281bd694" @@ -2356,6 +2577,13 @@ chokidar@3.5.3, chokidar@^3.4.0: optionalDependencies: fsevents "~2.3.2" +chokidar@4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-4.0.1.tgz#4a6dff66798fb0f72a94f616abbd7e1a19f31d41" + integrity sha512-n8enUVCED/KVRQlab1hr3MVpcVMvxtZjmEa956u+4YijlmQED223XMSYj2tLuKvr4jcCTzNNMpQDUer72MMmzA== + dependencies: + readdirp "^4.0.1" + chownr@^1.1.1: version "1.1.4" resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.1.4.tgz#6fc9d7b42d32a583596337666e7d08084da2cc6b" @@ -2390,6 +2618,18 @@ clean-stack@^2.0.0: resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== +cli-cursor@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-4.0.0.tgz#3cecfe3734bf4fe02a8361cbdc0f6fe28c6a57ea" + integrity sha512-VGtlMu3x/4DOtIUwEkRezxUZ2lBacNJCHash0N0WeZDBS+7Ux1dm3XWAgWYxLJFMMdOeXMHXorshEFhbMSGelg== + dependencies: + restore-cursor "^4.0.0" + +cli-spinners@^2.6.1: + version "2.9.2" + resolved "https://registry.yarnpkg.com/cli-spinners/-/cli-spinners-2.9.2.tgz#1773a8f4b9c4d6ac31563df53b3fc1d79462fe41" + integrity sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg== + cliui@^6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/cliui/-/cliui-6.0.0.tgz#511d702c0c4e41ca156d7d0e96021f23e13225b1" @@ -2408,6 +2648,11 @@ cliui@^7.0.2: strip-ansi "^6.0.0" wrap-ansi "^7.0.0" +clone@^1.0.2: + version "1.0.4" + resolved "https://registry.yarnpkg.com/clone/-/clone-1.0.4.tgz#da309cc263df15994c688ca902179ca3c7cd7c7e" + integrity sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg== + color-convert@^1.9.0: version "1.9.3" resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" @@ -2633,6 +2878,11 @@ decamelize@^4.0.0: resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-4.0.0.tgz#aa472d7bf660eb15f3494efd531cab7f2a709837" integrity sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ== +dedent@^0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz#2495ddbaf6eb874abb0e1be9df22d2e5a544326c" + integrity sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA== + deep-eql@^4.1.3: version "4.1.3" resolved "https://registry.yarnpkg.com/deep-eql/-/deep-eql-4.1.3.tgz#7c7775513092f7df98d8df9996dd085eb668cc6d" @@ -2657,6 +2907,13 @@ default-require-extensions@^3.0.0: dependencies: strip-bom "^4.0.0" +defaults@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/defaults/-/defaults-1.0.4.tgz#b0b02062c1e2aa62ff5d9528f0f98baa90978d7a" + integrity sha512-eFuaLoy/Rxalv2kr+lqMlUnrDWV+3j4pljOIJgLIhI058IQfWJ7vXhyEIHu+HtC738klGALYxOKDO0bQP3tg8A== + dependencies: + clone "^1.0.2" + define-data-property@^1.0.1, define-data-property@^1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/define-data-property/-/define-data-property-1.1.2.tgz#f3c33b4f0102360cd7c0f5f28700f5678510b63a" @@ -2745,11 +3002,21 @@ domutils@^3.0.1: domelementtype "^2.3.0" domhandler "^5.0.3" +dotenv-expand@^10.0.0: + version "10.0.0" + resolved "https://registry.yarnpkg.com/dotenv-expand/-/dotenv-expand-10.0.0.tgz#12605d00fb0af6d0a592e6558585784032e4ef37" + integrity sha512-GopVGCpVS1UKH75VKHGuQFqS1Gusej0z4FyQkPdwjil2gNIv+LNsqBlboOzpJFZKVT95GkCyWJbBSdFEFUWI2A== + dotenv@^10.0.0: version "10.0.0" resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-10.0.0.tgz#3d4227b8fb95f81096cdd2b66653fb2c7085ba81" integrity sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q== +dotenv@^16.3.1: + version "16.4.5" + resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-16.4.5.tgz#cdd3b3b604cb327e286b4762e13502f717cb099f" + integrity sha512-ZmdL2rui+eB2YwhsWzjInR8LldtZHGDoQ1ugH85ppHKwpUHL7j7rN0Ti9NCnGiQbhaZ11FpR+7ao1dNsmduNUg== + duplexer@^0.1.1, duplexer@~0.1.1: version "0.1.2" resolved "https://registry.yarnpkg.com/duplexer/-/duplexer-0.1.2.tgz#3abe43aef3835f8ae077d136ddce0f276b0400e6" @@ -2895,6 +3162,35 @@ es6-error@^4.0.1: resolved "https://registry.yarnpkg.com/es6-error/-/es6-error-4.1.1.tgz#9e3af407459deed47e9a91f9b885a84eb05c561d" integrity sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg== +esbuild@^0.19.0: + version "0.19.12" + resolved "https://registry.yarnpkg.com/esbuild/-/esbuild-0.19.12.tgz#dc82ee5dc79e82f5a5c3b4323a2a641827db3e04" + integrity sha512-aARqgq8roFBj054KvQr5f1sFu0D65G+miZRCuJyJ0G13Zwx7vRar5Zhn2tkQNzIXcBrNVsv/8stehpj+GAjgbg== + optionalDependencies: + "@esbuild/aix-ppc64" "0.19.12" + "@esbuild/android-arm" "0.19.12" + "@esbuild/android-arm64" "0.19.12" + "@esbuild/android-x64" "0.19.12" + "@esbuild/darwin-arm64" "0.19.12" + "@esbuild/darwin-x64" "0.19.12" + "@esbuild/freebsd-arm64" "0.19.12" + "@esbuild/freebsd-x64" "0.19.12" + "@esbuild/linux-arm" "0.19.12" + "@esbuild/linux-arm64" "0.19.12" + "@esbuild/linux-ia32" "0.19.12" + "@esbuild/linux-loong64" "0.19.12" + "@esbuild/linux-mips64el" "0.19.12" + "@esbuild/linux-ppc64" "0.19.12" + "@esbuild/linux-riscv64" "0.19.12" + "@esbuild/linux-s390x" "0.19.12" + "@esbuild/linux-x64" "0.19.12" + "@esbuild/netbsd-x64" "0.19.12" + "@esbuild/openbsd-x64" "0.19.12" + "@esbuild/sunos-x64" "0.19.12" + "@esbuild/win32-arm64" "0.19.12" + "@esbuild/win32-ia32" "0.19.12" + "@esbuild/win32-x64" "0.19.12" + escalade@^3.1.1: version "3.1.1" resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" @@ -3212,6 +3508,11 @@ event-stream@4.0.1: stream-combiner "^0.2.2" through "^2.3.8" +eventemitter3@5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/eventemitter3/-/eventemitter3-5.0.1.tgz#53f5ffd0a492ac800721bb42c66b841de96423c4" + integrity sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA== + evp_bytestokey@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz#7fcbdb198dc71959432efe13842684e0525acb02" @@ -3220,6 +3521,21 @@ evp_bytestokey@^1.0.3: md5.js "^1.3.4" safe-buffer "^5.1.1" +execa@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/execa/-/execa-8.0.1.tgz#51f6a5943b580f963c3ca9c6321796db8cc39b8c" + integrity sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg== + dependencies: + cross-spawn "^7.0.3" + get-stream "^8.0.1" + human-signals "^5.0.0" + is-stream "^3.0.0" + merge-stream "^2.0.0" + npm-run-path "^5.1.0" + onetime "^6.0.0" + signal-exit "^4.1.0" + strip-final-newline "^3.0.0" + extract-zip@2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/extract-zip/-/extract-zip-2.0.1.tgz#663dca56fe46df890d5f131ef4a06d22bb8ba13a" @@ -3276,6 +3592,11 @@ fd-slicer@~1.1.0: dependencies: pend "~1.2.0" +fdir@^6.1.1: + version "6.4.2" + resolved "https://registry.yarnpkg.com/fdir/-/fdir-6.4.2.tgz#ddaa7ce1831b161bc3657bb99cb36e1622702689" + integrity sha512-KnhMXsKSPZlAhp7+IjUkRZKPb4fUyccpDrdFXbi4QL1qkmFh9kVY09Yox+n4MaOb3lHZ1Tv829C3oaaXoMYPDQ== + file-entry-cache@^6.0.1: version "6.0.1" resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz#211b2dd9659cb0394b073e7323ac3c933d522027" @@ -3341,6 +3662,14 @@ find-up@^4.0.0, find-up@^4.1.0: locate-path "^5.0.0" path-exists "^4.0.0" +find-up@^6.3.0: + version "6.3.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-6.3.0.tgz#2abab3d3280b2dc7ac10199ef324c4e002c8c790" + integrity sha512-v2ZsoEuVHYy8ZIlYqwPe/39Cy+cFDzp4dXPaxNvkEuouymu+2Jbz0PxpKarJHYJTmv2HWT3O382qY8l4jMWthw== + dependencies: + locate-path "^7.1.0" + path-exists "^5.0.0" + find-yarn-workspace-root@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/find-yarn-workspace-root/-/find-yarn-workspace-root-2.0.0.tgz#f47fb8d239c900eb78179aa81b66673eac88f7bd" @@ -3436,6 +3765,15 @@ fs-extra@^0.30.0: path-is-absolute "^1.0.0" rimraf "^2.2.8" +fs-extra@^11.2.0: + version "11.2.0" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-11.2.0.tgz#e70e17dfad64232287d01929399e0ea7c86b0e5b" + integrity sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw== + dependencies: + graceful-fs "^4.2.0" + jsonfile "^6.0.1" + universalify "^2.0.0" + fs-extra@^7.0.0, fs-extra@^7.0.1: version "7.0.1" resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-7.0.1.tgz#4f189c44aa123b895f722804f55ea23eadc348e9" @@ -3543,6 +3881,11 @@ get-stream@^5.1.0: dependencies: pump "^3.0.0" +get-stream@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-8.0.1.tgz#def9dfd71742cd7754a7761ed43749a27d02eca2" + integrity sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA== + get-symbol-description@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/get-symbol-description/-/get-symbol-description-1.0.0.tgz#7fdb81c900101fbd564dd5f1a30af5aadc1e58d6" @@ -3819,6 +4162,11 @@ https-proxy-agent@5.0.1, https-proxy-agent@^5.0.0: agent-base "6" debug "4" +human-signals@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-5.0.0.tgz#42665a284f9ae0dade3ba41ebc37eb4b852f3a28" + integrity sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ== + iconv-lite@0.4.24: version "0.4.24" resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" @@ -3981,6 +4329,11 @@ is-hex-prefixed@1.0.0: resolved "https://registry.yarnpkg.com/is-hex-prefixed/-/is-hex-prefixed-1.0.0.tgz#7d8d37e6ad77e5d127148913c573e082d777f554" integrity sha512-WvtOiug1VFrE9v1Cydwm+FnXd3+w9GaeVUss5W4v/SLy3UW00vP+6iNF2SdnfiBoLy4bTqVdkftNGTUeOFVsbA== +is-interactive@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/is-interactive/-/is-interactive-2.0.0.tgz#40c57614593826da1100ade6059778d597f16e90" + integrity sha512-qP1vozQRI+BMOPcjFzrjXuQvdak2pHNUMZoeG2eRbiSqyvbEf/wQtEOTOX1guk6E3t36RkaqiSt8A/6YElNxLQ== + is-negative-zero@^2.0.2: version "2.0.2" resolved "https://registry.yarnpkg.com/is-negative-zero/-/is-negative-zero-2.0.2.tgz#7bf6f03a28003b8b3965de3ac26f664d765f3150" @@ -4023,6 +4376,11 @@ is-stream@^2.0.0: resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== +is-stream@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-3.0.0.tgz#e6bfd7aa6bef69f4f472ce9bb681e3e57b4319ac" + integrity sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA== + is-string@^1.0.5, is-string@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.7.tgz#0dd12bf2006f255bb58f695110eff7491eebc0fd" @@ -4054,6 +4412,11 @@ is-unicode-supported@^0.1.0: resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== +is-unicode-supported@^1.1.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-1.3.0.tgz#d824984b616c292a2e198207d4a609983842f714" + integrity sha512-43r2mRvz+8JRIKnWJ+3j8JtjRKZ6GmjzfaE/qiBJnikNnYv/6bagRJ1kUhNk8R5EX/GkobD+r+sfxCPJsiKBLQ== + is-weakref@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/is-weakref/-/is-weakref-1.0.2.tgz#9529f383a9338205e89765e0392efc2f100f06f2" @@ -4083,6 +4446,11 @@ isexe@^2.0.0: resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== +isows@1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/isows/-/isows-1.0.6.tgz#0da29d706fa51551c663c627ace42769850f86e7" + integrity sha512-lPHCayd40oW98/I0uvgaHKWCSvkzY27LjWLbtzOm64yQ+G3Q5npjjbdppU65iZXkK1Zt+kH9pfegli0AYfwYYw== + istanbul-lib-coverage@^3.0.0, istanbul-lib-coverage@^3.2.0: version "3.2.0" resolved "https://registry.yarnpkg.com/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz#189e7909d0a39fa5a3dfad5b03f71947770191d3" @@ -4298,6 +4666,11 @@ levn@^0.4.1: prelude-ls "^1.2.1" type-check "~0.4.0" +load-tsconfig@^0.2.3: + version "0.2.5" + resolved "https://registry.yarnpkg.com/load-tsconfig/-/load-tsconfig-0.2.5.tgz#453b8cd8961bfb912dea77eb6c168fe8cca3d3a1" + integrity sha512-IXO6OCs9yg8tMKzfPZ1YmheJbZCiEsnBdcB03l0OcfK9prKnJb96siuHCr5Fl37/yo9DnKU+TLpxzTUspw9shg== + locate-path@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz#2b568b265eec944c6d9c0de9c3dbbbca0354cd8e" @@ -4320,6 +4693,13 @@ locate-path@^6.0.0: dependencies: p-locate "^5.0.0" +locate-path@^7.1.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-7.2.0.tgz#69cb1779bd90b35ab1e771e1f2f89a202c2a8a8a" + integrity sha512-gvVijfZvn7R+2qyPX8mAuKcFGDf6Nc61GdvGafQsHL0sBIxfKzA+usWn4GFC/bk+QdwPUD4kWFJLhElipq+0VA== + dependencies: + p-locate "^6.0.0" + lodash.camelcase@^4.3.0: version "4.3.0" resolved "https://registry.yarnpkg.com/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz#b28aa6288a2b9fc651035c7711f65ab6190331a6" @@ -4362,6 +4742,14 @@ log-symbols@4.1.0: chalk "^4.1.0" is-unicode-supported "^0.1.0" +log-symbols@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/log-symbols/-/log-symbols-5.1.0.tgz#a20e3b9a5f53fac6aeb8e2bb22c07cf2c8f16d93" + integrity sha512-l0x2DvrW294C9uDCoQe1VSU4gf529FkSZ6leBl4TiqZH/e+0R7hSfHQBNut2mNygDgHwvYHfFLn6Oxb3VWj2rA== + dependencies: + chalk "^5.0.0" + is-unicode-supported "^1.1.0" + loupe@^2.3.6: version "2.3.6" resolved "https://registry.yarnpkg.com/loupe/-/loupe-2.3.6.tgz#76e4af498103c532d1ecc9be102036a21f787b53" @@ -4440,6 +4828,11 @@ memorystream@^0.3.1: resolved "https://registry.yarnpkg.com/memorystream/-/memorystream-0.3.1.tgz#86d7090b30ce455d63fbae12dda51a47ddcaf9b2" integrity sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw== +merge-stream@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" + integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== + merge2@^1.3.0, merge2@^1.4.1: version "1.4.1" resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" @@ -4465,6 +4858,16 @@ mime-types@^2.1.12: dependencies: mime-db "1.52.0" +mimic-fn@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" + integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== + +mimic-fn@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-4.0.0.tgz#60a90550d5cb0b239cca65d893b1a53b29871ecc" + integrity sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw== + minimalistic-assert@^1.0.0, minimalistic-assert@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz#2e194de044626d4a10e7f7fbc00ce73e83e4d5c7" @@ -4678,6 +5081,13 @@ normalize-path@^3.0.0, normalize-path@~3.0.0: resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== +npm-run-path@^5.1.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-5.3.0.tgz#e23353d0ebb9317f174e93417e4a4d82d0249e9f" + integrity sha512-ppwTtiJZq0O/ai0z7yfudtBpWIoxM8yE6nHi1X47eFR2EWORqfbu6CnPlNsjeN683eT0qG6H/Pyf9fCcvjnnnQ== + dependencies: + path-key "^4.0.0" + nth-check@^2.0.1: version "2.1.1" resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-2.1.1.tgz#c9eab428effce36cd6b92c924bdb000ef1f1ed1d" @@ -4750,6 +5160,20 @@ once@^1.3.0, once@^1.3.1, once@^1.4.0: dependencies: wrappy "1" +onetime@^5.1.0: + version "5.1.2" + resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" + integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== + dependencies: + mimic-fn "^2.1.0" + +onetime@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/onetime/-/onetime-6.0.0.tgz#7c24c18ed1fd2e9bca4bd26806a33613c77d34b4" + integrity sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ== + dependencies: + mimic-fn "^4.0.0" + open@^7.4.2: version "7.4.2" resolved "https://registry.yarnpkg.com/open/-/open-7.4.2.tgz#b8147e26dcf3e426316c730089fd71edd29c2321" @@ -4770,11 +5194,39 @@ optionator@^0.9.1: type-check "^0.4.0" word-wrap "^1.2.3" +ora@^6.3.1: + version "6.3.1" + resolved "https://registry.yarnpkg.com/ora/-/ora-6.3.1.tgz#a4e9e5c2cf5ee73c259e8b410273e706a2ad3ed6" + integrity sha512-ERAyNnZOfqM+Ao3RAvIXkYh5joP220yf59gVe2X/cI6SiCxIdi4c9HZKZD8R6q/RDXEje1THBju6iExiSsgJaQ== + dependencies: + chalk "^5.0.0" + cli-cursor "^4.0.0" + cli-spinners "^2.6.1" + is-interactive "^2.0.0" + is-unicode-supported "^1.1.0" + log-symbols "^5.1.0" + stdin-discarder "^0.1.0" + strip-ansi "^7.0.1" + wcwidth "^1.0.1" + os-tmpdir@~1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" integrity sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g== +ox@0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/ox/-/ox-0.1.2.tgz#0f791be2ccabeaf4928e6d423498fe1c8094e560" + integrity sha512-ak/8K0Rtphg9vnRJlbOdaX9R7cmxD2MiSthjWGaQdMk3D7hrAlDoM+6Lxn7hN52Za3vrXfZ7enfke/5WjolDww== + dependencies: + "@adraffy/ens-normalize" "^1.10.1" + "@noble/curves" "^1.6.0" + "@noble/hashes" "^1.5.0" + "@scure/bip32" "^1.5.0" + "@scure/bip39" "^1.4.0" + abitype "^1.0.6" + eventemitter3 "5.0.1" + p-limit@^1.1.0: version "1.3.0" resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-1.3.0.tgz#b86bd5f0c25690911c7590fcbfc2010d54b3ccb8" @@ -4796,6 +5248,13 @@ p-limit@^3.0.2: dependencies: yocto-queue "^0.1.0" +p-limit@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-4.0.0.tgz#914af6544ed32bfa54670b061cafcbd04984b644" + integrity sha512-5b0R4txpzjPWVw/cXXUResoD4hb6U/x9BH08L7nw+GN1sezDzPdxeRvpc9c433fZhBan/wusjbCsqwqm4EIBIQ== + dependencies: + yocto-queue "^1.0.0" + p-locate@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43" @@ -4817,6 +5276,13 @@ p-locate@^5.0.0: dependencies: p-limit "^3.0.2" +p-locate@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-6.0.0.tgz#3da9a49d4934b901089dca3302fa65dc5a05c04f" + integrity sha512-wPrq66Llhl7/4AGC6I+cqxT07LhXvWL08LNXz1fENOw0Ap4sRZZ/gZpTTJ5jpurzzzfS2W/Ge9BY3LgLjCShcw== + dependencies: + p-limit "^4.0.0" + p-map@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/p-map/-/p-map-3.0.0.tgz#d704d9af8a2ba684e2600d9a215983d4141a979d" @@ -4903,6 +5369,11 @@ path-exists@^4.0.0: resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== +path-exists@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-5.0.0.tgz#a6aad9489200b21fab31e49cf09277e5116fb9e7" + integrity sha512-RjhtfwJOxzcFmNOi6ltcbcu4Iu+FL3zEj83dk4kAS+fVpTxXLO1b38RvJgT/0QwvV/L3aY9TAnyv0EOqW4GoMQ== + path-is-absolute@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" @@ -4918,6 +5389,11 @@ path-key@^3.1.0: resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== +path-key@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-4.0.0.tgz#295588dc3aee64154f877adb9d780b81c554bf18" + integrity sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ== + path-parse@^1.0.6, path-parse@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" @@ -4928,6 +5404,11 @@ path-type@^4.0.0: resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== +pathe@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/pathe/-/pathe-1.1.2.tgz#6c4cb47a945692e48a1ddd6e4094d170516437ec" + integrity sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ== + pathval@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/pathval/-/pathval-1.1.1.tgz#8534e77a77ce7ac5a2512ea21e0fdb8fcf6c3d8d" @@ -4966,6 +5447,11 @@ picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1: resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== +picomatch@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-3.0.1.tgz#817033161def55ec9638567a2f3bbc876b3e7516" + integrity sha512-I3EurrIQMlRc9IaAZnqRR044Phh2DXY+55o7uJ0V+hYZAcQYSuFWsc9q5PvyDHUSCe1Qxn/iBz+78s86zWnGag== + pkg-dir@4.2.0, pkg-dir@^4.1.0: version "4.2.0" resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" @@ -5007,6 +5493,11 @@ prettier@^2.1.2, prettier@^2.3.2: resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.6.2.tgz#e26d71a18a74c3d0f0597f55f01fb6c06c206032" integrity sha512-PkUpF+qoXTqhOeWL9fu7As8LXsIUZ1WYaJiY/a7McAQzxjk82OF0tibkFXVCDImZtWxbvojFjerkiLb0/q8mew== +prettier@^3.0.3: + version "3.3.3" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-3.3.3.tgz#30c54fe0be0d8d12e6ae61dbb10109ea00d53105" + integrity sha512-i2tDNA0O5IrMO757lfrdQZCc2jPNDVntV0m/+4whiDfWaTKfMNgR7Qz0NAeGz/nRqF4m5/6CLzbP4/liHt12Ew== + process-on-spawn@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/process-on-spawn/-/process-on-spawn-1.0.0.tgz#95b05a23073d30a17acfdc92a440efd2baefdc93" @@ -5108,6 +5599,11 @@ readable-stream@^3.1.1, readable-stream@^3.4.0, readable-stream@^3.6.0: string_decoder "^1.1.1" util-deprecate "^1.0.1" +readdirp@^4.0.1: + version "4.0.2" + resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-4.0.2.tgz#388fccb8b75665da3abffe2d8f8ed59fe74c230a" + integrity sha512-yDMz9g+VaZkqBYS/ozoBJwaBhTbZo3UNYQHNRw1D3UFQB8oHB4uS/tAODO+ZLjGWmUbKnIlOWO+aaIiAxrUWHA== + readdirp@~3.6.0: version "3.6.0" resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" @@ -5187,6 +5683,14 @@ resolve@^1.3.2: path-parse "^1.0.7" supports-preserve-symlinks-flag "^1.0.0" +restore-cursor@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-4.0.0.tgz#519560a4318975096def6e609d44100edaa4ccb9" + integrity sha512-I9fPXU9geO9bHOt9pHHOhOkYerIMsmVaWB0rA2AI9ERh/+x/i7MV5HKBNrg+ljO5eoPVgCcnFuRjJ9uH6I/3eg== + dependencies: + onetime "^5.1.0" + signal-exit "^3.0.2" + retry@^0.12.0: version "0.12.0" resolved "https://registry.yarnpkg.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" @@ -5400,6 +5904,11 @@ signal-exit@^3.0.2: resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== +signal-exit@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-4.1.0.tgz#952188c1cbd546070e2dd20d0f41c0ae0530cb04" + integrity sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw== + sisteransi@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed" @@ -5515,6 +6024,13 @@ statuses@2.0.1: resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== +stdin-discarder@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/stdin-discarder/-/stdin-discarder-0.1.0.tgz#22b3e400393a8e28ebf53f9958f3880622efde21" + integrity sha512-xhV7w8S+bUwlPTb4bAOUQhv8/cSS5offJuX8GQGq32ONF0ZtDWKfkdomM3HMRA+LhX6um/FZ0COqlwsjD53LeQ== + dependencies: + bl "^5.0.0" + stream-combiner@^0.2.2: version "0.2.2" resolved "https://registry.yarnpkg.com/stream-combiner/-/stream-combiner-0.2.2.tgz#aec8cbac177b56b6f4fa479ced8c1912cee52858" @@ -5578,11 +6094,23 @@ strip-ansi@^6.0.0, strip-ansi@^6.0.1: dependencies: ansi-regex "^5.0.1" +strip-ansi@^7.0.1: + version "7.1.0" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-7.1.0.tgz#d5b6568ca689d8561370b0707685d22434faff45" + integrity sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ== + dependencies: + ansi-regex "^6.0.1" + strip-bom@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-4.0.0.tgz#9c3505c1db45bcedca3d9cf7a16f5c5aa3901878" integrity sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w== +strip-final-newline@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-3.0.0.tgz#52894c313fbff318835280aed60ff71ebf12b8fd" + integrity sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw== + strip-hex-prefix@1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/strip-hex-prefix/-/strip-hex-prefix-1.0.0.tgz#0c5f155fef1151373377de9dbb588da05500e36f" @@ -5911,10 +6439,10 @@ typedarray-to-buffer@^3.1.5: dependencies: is-typedarray "^1.0.0" -typescript@^4.9.5: - version "4.9.5" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.9.5.tgz#095979f9bcc0d09da324d58d03ce8f8374cbe65a" - integrity sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g== +typescript@^5.5.4: + version "5.6.3" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.6.3.tgz#5f3449e31c9d94febb17de03cc081dd56d81db5b" + integrity sha512-hjcS1mhfuyi4WW8IWtjP7brDrG2cuDZukyrYrSauoXGNgx0S7zceP07adYkJycEr56BOUTNPzbInooiN3fn1qw== typical@^4.0.0: version "4.0.0" @@ -6006,6 +6534,36 @@ v8-compile-cache@^2.0.3: resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz#2de19618c66dc247dcfb6f99338035d8245a2cee" integrity sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA== +viem@2.x, viem@^2.21.45: + version "2.21.45" + resolved "https://registry.yarnpkg.com/viem/-/viem-2.21.45.tgz#7a445428d4909cc334f231ee916ede1b69190603" + integrity sha512-I+On/IiaObQdhDKWU5Rurh6nf3G7reVkAODG5ECIfjsrGQ3EPJnxirUPT4FNV6bWER5iphoG62/TidwuTSOA1A== + dependencies: + "@noble/curves" "1.6.0" + "@noble/hashes" "1.5.0" + "@scure/bip32" "1.5.0" + "@scure/bip39" "1.4.0" + abitype "1.0.6" + isows "1.0.6" + ox "0.1.2" + webauthn-p256 "0.0.10" + ws "8.18.0" + +wcwidth@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/wcwidth/-/wcwidth-1.0.1.tgz#f0b0dcf915bc5ff1528afadb2c0e17b532da2fe8" + integrity sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg== + dependencies: + defaults "^1.0.3" + +webauthn-p256@0.0.10: + version "0.0.10" + resolved "https://registry.yarnpkg.com/webauthn-p256/-/webauthn-p256-0.0.10.tgz#877e75abe8348d3e14485932968edf3325fd2fdd" + integrity sha512-EeYD+gmIT80YkSIDb2iWq0lq2zbHo1CxHlQTeJ+KkCILWpVy3zASH3ByD4bopzfk0uCwXxLqKGLqp2W4O28VFA== + dependencies: + "@noble/curves" "^1.4.0" + "@noble/hashes" "^1.4.0" + webidl-conversions@^3.0.0: version "3.0.1" resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" @@ -6121,6 +6679,11 @@ ws@7.4.6, ws@7.5.10, ws@^7.4.6: resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.10.tgz#58b5c20dc281633f6c19113f39b349bd8bd558d9" integrity sha512-+dbF1tHwZpXcbOJdVOkzLDxZP1ailvSxM6ZweXTegylPny803bFhA+vqBYw4s31NSAk4S2Qz+AKXK9a4wkdjcQ== +ws@8.18.0: + version "8.18.0" + resolved "https://registry.yarnpkg.com/ws/-/ws-8.18.0.tgz#0d7505a6eafe2b0e712d232b42279f53bc289bbc" + integrity sha512-8VbfWfHLbbwu3+N6OKsOMpBdT4kXPDDB9cJk2bJ6mh9ucxdlnNvH1e+roYkKmN9Nxw2yjz7VzeO9oOz2zJ04Pw== + ws@8.5.0: version "8.5.0" resolved "https://registry.yarnpkg.com/ws/-/ws-8.5.0.tgz#bfb4be96600757fe5382de12c670dab984a1ed4f" @@ -6257,3 +6820,13 @@ yocto-queue@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== + +yocto-queue@^1.0.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-1.1.1.tgz#fef65ce3ac9f8a32ceac5a634f74e17e5b232110" + integrity sha512-b4JR1PFR10y1mKjhHY9LaGo6tmrgjit7hxVIeAmyMw3jegXR4dhYqLaQF5zMXZxY7tLpMyJeLjr1C4rLmkVe8g== + +zod@^3.22.2: + version "3.23.8" + resolved "https://registry.yarnpkg.com/zod/-/zod-3.23.8.tgz#e37b957b5d52079769fb8097099b592f0ef4067d" + integrity sha512-XBx9AXhXktjUqnepgTiE5flcKIYWi/rme0Eaj+5Y0lftuGBq+jyRu/md4WnuxqgP1ubdpNCsYEYPxrzVHD8d6g== From f0c6ca25af8d02c41c5f784b200bf41cdb76e6d6 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Mon, 18 Nov 2024 16:04:40 -0500 Subject: [PATCH 02/19] update to internal ethers api --- src/experimental/arbitrumDeposit/actions.ts | 141 ++++++++--------- .../arbitrumDeposit/transformViemToEthers.ts | 44 ++++++ tests/integration/arbitrumDeposit.test.ts | 147 +++++++++++++----- 3 files changed, 215 insertions(+), 117 deletions(-) create mode 100644 src/experimental/arbitrumDeposit/transformViemToEthers.ts diff --git a/src/experimental/arbitrumDeposit/actions.ts b/src/experimental/arbitrumDeposit/actions.ts index d87d3cfc8f..52556982c1 100644 --- a/src/experimental/arbitrumDeposit/actions.ts +++ b/src/experimental/arbitrumDeposit/actions.ts @@ -1,90 +1,77 @@ -import { - type PublicClient, - type WalletClient, - type Client, - encodeFunctionData, - Account, - Address, - parseTransaction, - serializeTransaction +import { BigNumber } from 'ethers' +import { + Account, + Address, + Client, + type PublicClient, + TransactionRequest, } from 'viem' -import { localEthChain } from '../chains' -import { inboxAbi } from './abis/inbox' +import { EthBridger } from '../../lib/assetBridger/ethBridger' +import { transformPublicClientToProvider } from './transformViemToEthers' -export type ArbitrumDepositActions = { - depositEth: (args: { - amount: bigint; - account: Account | Address; - walletClient: WalletClient; - }) => Promise<`0x${string}`> +export type PrepareDepositEthParameters = { + amount: bigint + account: Account | Address } -type ArbitrumChainConfig = { - ethBridge: { - inbox: `0x${string}` - } +export type PrepareDepositEthToParameters = PrepareDepositEthParameters & { + destinationAddress: Address + parentPublicClient: PublicClient } -export function arbitrumDepositActions(childChain: ArbitrumChainConfig) { - return (parentPublicClient: TClient): ArbitrumDepositActions => { - const getDepositRequest = async ({ - amount, - account - }: { - amount: bigint - account: Account | Address - }) => { - const from = typeof account === 'string' ? account : account.address - - return { - to: childChain.ethBridge.inbox, - value: amount, - data: encodeFunctionData({ - abi: inboxAbi, - functionName: 'depositEth', - args: [] - }), - from - } - } +export async function prepareDepositEthTransaction( + client: Client, + { amount, account }: PrepareDepositEthParameters +): Promise { + const provider = transformPublicClientToProvider(client) + const ethBridger = await EthBridger.fromProvider(provider) + const request = await ethBridger.getDepositRequest({ + amount: BigNumber.from(amount), + from: typeof account === 'string' ? account : account.address, + }) - return { - async depositEth({ amount, account, walletClient }) { - const request = await getDepositRequest({ - amount, - account - }) + return { + to: request.txRequest.to as `0x${string}`, + value: BigNumber.from(request.txRequest.value).toBigInt(), + data: request.txRequest.data as `0x${string}`, + } +} - const gasPrice = await parentPublicClient.getGasPrice() - - const nonce = await parentPublicClient.getTransactionCount({ - address: typeof account === 'string' ? account as `0x${string}` : account.address, - blockTag: 'latest' - }) - - const signedTx = await walletClient.signTransaction({ - ...request, - account, - chain: localEthChain, - gas: BigInt('130000'), - maxFeePerGas: gasPrice, - maxPriorityFeePerGas: gasPrice, - nonce - }) +export async function prepareDepositEthToTransaction( + client: Client, + { + amount, + account, + destinationAddress, + parentPublicClient, + }: PrepareDepositEthToParameters +): Promise { + const childProvider = transformPublicClientToProvider(client) + const parentProvider = transformPublicClientToProvider(parentPublicClient) + const ethBridger = await EthBridger.fromProvider(childProvider) - // Parse and serialize with L2 chain ID - const parsedTx = parseTransaction((signedTx as any).raw) - const serializedTx = serializeTransaction({ - ...parsedTx, - }) + const request = await ethBridger.getDepositToRequest({ + amount: BigNumber.from(amount), + destinationAddress, + from: typeof account === 'string' ? account : account.address, + parentProvider, + childProvider, + }) - // Send to L2 - const hash = await parentPublicClient.sendRawTransaction({ - serializedTransaction: serializedTx - }) + return { + to: request.txRequest.to as `0x${string}`, + value: BigNumber.from(request.txRequest.value).toBigInt(), + data: request.txRequest.data as `0x${string}`, + } +} - return hash - } +export function arbitrumDepositActions() { + return function (client: Client) { + return { + prepareDepositEthTransaction: (args: PrepareDepositEthParameters) => + prepareDepositEthTransaction(client, args), + prepareDepositEthToTransaction: (args: PrepareDepositEthToParameters) => + prepareDepositEthToTransaction(client, args), } } -} \ No newline at end of file +} diff --git a/src/experimental/arbitrumDeposit/transformViemToEthers.ts b/src/experimental/arbitrumDeposit/transformViemToEthers.ts new file mode 100644 index 0000000000..73d63d875f --- /dev/null +++ b/src/experimental/arbitrumDeposit/transformViemToEthers.ts @@ -0,0 +1,44 @@ +import { StaticJsonRpcProvider } from '@ethersproject/providers' +import { Chain, Client, PublicClient, Transport } from 'viem' + +// based on https://wagmi.sh/react/ethers-adapters#reference-implementation +export function publicClientToProvider( + publicClient: PublicClient +) { + const { chain } = publicClient + + if (typeof chain === 'undefined') { + throw new Error(`[publicClientToProvider] "chain" is undefined`) + } + + const network = { + chainId: chain.id, + name: chain.name, + ensAddress: chain.contracts?.ensRegistry?.address, + } + + return new StaticJsonRpcProvider(chain.rpcUrls.default.http[0], network) +} + +function isPublicClient(object: any): object is PublicClient { + return ( + object !== undefined && + object !== null && + typeof object === 'object' && + 'transport' in object && + object.transport !== null && + typeof object.transport === 'object' && + 'url' in object.transport && + typeof object.transport.url === 'string' && + object.type === 'publicClient' + ) +} + +export const transformPublicClientToProvider = ( + provider: PublicClient | Client +): StaticJsonRpcProvider => { + if (isPublicClient(provider)) { + return publicClientToProvider(provider) + } + throw new Error('Invalid provider') +} diff --git a/tests/integration/arbitrumDeposit.test.ts b/tests/integration/arbitrumDeposit.test.ts index 9f6bc822a9..f448b6397c 100644 --- a/tests/integration/arbitrumDeposit.test.ts +++ b/tests/integration/arbitrumDeposit.test.ts @@ -1,90 +1,157 @@ import { expect } from 'chai' -import { createWalletClient, createPublicClient, http, parseEther } from 'viem' +import { + createWalletClient, + createPublicClient, + http, + parseEther, + type PublicClient, +} from 'viem' import { privateKeyToAccount } from 'viem/accounts' +import { config, testSetup } from '../../scripts/testSetup' import { arbitrumDepositActions } from '../../src/experimental/arbitrumDeposit/actions' -import { testSetup, config } from '../../scripts/testSetup' import { localEthChain, localArbChain } from '../../src/experimental/chains' -describe('arbitrumDepositActions', function() { - this.timeout(60000) - - it('deposits ether', async function() { - const { childChain } = await testSetup() +describe('arbitrumDepositActions', function () { + before(async function () { + await testSetup() + }) + it('deposits ETH from L1 to L2', async function () { const account = privateKeyToAccount(`0x${config.ethKey}` as `0x${string}`) + const depositAmount = parseEther('0.01') - // Create parent clients + // Create L1 clients const parentWalletClient = createWalletClient({ account, chain: localEthChain, - transport: http(config.ethUrl) + transport: http(config.ethUrl), }) const parentPublicClient = createPublicClient({ chain: localEthChain, - transport: http(config.ethUrl) - }).extend(arbitrumDepositActions({ - ethBridge: { - inbox: childChain.ethBridge.inbox as `0x${string}` - } - })) + transport: http(config.ethUrl), + }) - // Create child client for balance checks + // Create L2 client and extend with deposit actions const childPublicClient = createPublicClient({ chain: localArbChain, - transport: http(config.arbUrl) - }) + transport: http(config.arbUrl), + }).extend(arbitrumDepositActions()) + // Get initial L2 balance const initialBalance = await childPublicClient.getBalance({ - address: account.address + address: account.address, }) - console.log('Initial child balance:', initialBalance) + // Prepare and send deposit transaction + const request = await childPublicClient.prepareDepositEthTransaction({ + amount: depositAmount, + account, + }) + + const hash = await parentWalletClient.sendTransaction(request) + + // Wait for L1 transaction + const receipt = await parentPublicClient.waitForTransactionReceipt({ + hash, + }) + + expect(receipt.status).to.equal('success') + + // Wait for L2 balance to increase + let finalBalance = initialBalance + let attempts = 0 + const maxAttempts = 10 + + while (attempts < maxAttempts) { + await new Promise(resolve => setTimeout(resolve, 3000)) + + const currentBalance = await childPublicClient.getBalance({ + address: account.address, + }) + + if (currentBalance > initialBalance) { + finalBalance = currentBalance + break + } + + attempts++ + } + + const balanceDiff = finalBalance - initialBalance + expect(balanceDiff).to.equal(depositAmount) + }) + + it('deposits ETH from L1 to a different L2 address', async function () { + const account = privateKeyToAccount(`0x${config.ethKey}` as `0x${string}`) + const destinationAddress = + '0x1234567890123456789012345678901234567890' as `0x${string}` const depositAmount = parseEther('0.01') - console.log('Deposit amount:', depositAmount) - const hash = await parentPublicClient.depositEth({ + // Create L1 clients + const parentWalletClient = createWalletClient({ + account, + chain: localEthChain, + transport: http(config.ethUrl), + }) + + const parentPublicClient = createPublicClient({ + chain: localEthChain, + transport: http(config.ethUrl), + }) + + // Create L2 client and extend with deposit actions + const childPublicClient = createPublicClient({ + chain: localArbChain, + transport: http(config.arbUrl), + }).extend(arbitrumDepositActions()) + + // Get initial destination balance + const initialBalance = await childPublicClient.getBalance({ + address: destinationAddress, + }) + + // Prepare and send deposit transaction + const request = await childPublicClient.prepareDepositEthToTransaction({ amount: depositAmount, account: account.address, - walletClient: parentWalletClient + destinationAddress, + parentPublicClient, + }) + + const hash = await parentWalletClient.sendTransaction({ + ...request, + chain: localEthChain, }) - // Wait for parent transaction - const receipt = await parentPublicClient.waitForTransactionReceipt({ + // Wait for L1 transaction + const receipt = await parentPublicClient.waitForTransactionReceipt({ hash, - confirmations: 1 }) expect(receipt.status).to.equal('success') - // Poll for child balance change + // Wait for L2 balance to increase let finalBalance = initialBalance let attempts = 0 const maxAttempts = 10 while (attempts < maxAttempts) { await new Promise(resolve => setTimeout(resolve, 3000)) - + const currentBalance = await childPublicClient.getBalance({ - address: account.address + address: destinationAddress, }) - console.log(`Attempt ${attempts + 1} - Current balance:`, currentBalance) - if (currentBalance > initialBalance) { finalBalance = currentBalance break } - + attempts++ } - console.log('Final child balance:', finalBalance) - console.log('Balance difference:', finalBalance - initialBalance) - - expect(Number(finalBalance)).to.be.greaterThan( - Number(initialBalance), - 'child balance did not increase after deposit' - ) + const balanceDiff = finalBalance - initialBalance + expect(balanceDiff).to.equal(depositAmount) }) -}) \ No newline at end of file +}) From f7067c25d91a3e46a13d0707b6ccff1f5b130aae Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Mon, 18 Nov 2024 16:04:51 -0500 Subject: [PATCH 03/19] adds createArbitrumClient function --- .../arbitrumDeposit/createArbitrumClient.ts | 42 +++++++++ tests/integration/arbitrumDeposit.test.ts | 87 +++++++++---------- 2 files changed, 85 insertions(+), 44 deletions(-) create mode 100644 src/experimental/arbitrumDeposit/createArbitrumClient.ts diff --git a/src/experimental/arbitrumDeposit/createArbitrumClient.ts b/src/experimental/arbitrumDeposit/createArbitrumClient.ts new file mode 100644 index 0000000000..0fb8568e69 --- /dev/null +++ b/src/experimental/arbitrumDeposit/createArbitrumClient.ts @@ -0,0 +1,42 @@ +import { Chain, PublicClient, createPublicClient, http } from 'viem' +import { ArbitrumNetwork } from '../../lib/dataEntities/networks' +import { arbitrumDepositActions } from './actions' + +export type ArbitrumChain = Chain & ArbitrumNetwork + +export type ArbitrumClients = { + parentChainPublicClient: PublicClient + childChainPublicClient: PublicClient & + ReturnType +} +export type ChildChainPublicClient = PublicClient & + ReturnType + +export type CreateArbitrumClientParams = { + parentChain: Chain + childChain: ArbitrumChain + parentRpcUrl?: string + childRpcUrl?: string +} + +export function createArbitrumClient({ + parentChain, + childChain, + parentRpcUrl, + childRpcUrl, +}: CreateArbitrumClientParams): ArbitrumClients { + const parentChainPublicClient = createPublicClient({ + chain: parentChain, + transport: http(parentRpcUrl || parentChain.rpcUrls.default.http[0]), + }) + + const childChainPublicClient = createPublicClient({ + chain: childChain, + transport: http(childRpcUrl || childChain.rpcUrls.default.http[0]), + }).extend(arbitrumDepositActions()) + + return { + parentChainPublicClient, + childChainPublicClient, + } as any as ArbitrumClients +} diff --git a/tests/integration/arbitrumDeposit.test.ts b/tests/integration/arbitrumDeposit.test.ts index f448b6397c..e99df74b87 100644 --- a/tests/integration/arbitrumDeposit.test.ts +++ b/tests/integration/arbitrumDeposit.test.ts @@ -1,15 +1,9 @@ import { expect } from 'chai' -import { - createWalletClient, - createPublicClient, - http, - parseEther, - type PublicClient, -} from 'viem' +import { createWalletClient, http, parseEther } from 'viem' import { privateKeyToAccount } from 'viem/accounts' import { config, testSetup } from '../../scripts/testSetup' -import { arbitrumDepositActions } from '../../src/experimental/arbitrumDeposit/actions' import { localEthChain, localArbChain } from '../../src/experimental/chains' +import { createArbitrumClient } from '../../src/experimental/arbitrumDeposit/createArbitrumClient' describe('arbitrumDepositActions', function () { before(async function () { @@ -20,39 +14,42 @@ describe('arbitrumDepositActions', function () { const account = privateKeyToAccount(`0x${config.ethKey}` as `0x${string}`) const depositAmount = parseEther('0.01') - // Create L1 clients + // Create L1 wallet client const parentWalletClient = createWalletClient({ account, chain: localEthChain, transport: http(config.ethUrl), }) - const parentPublicClient = createPublicClient({ - chain: localEthChain, - transport: http(config.ethUrl), - }) - - // Create L2 client and extend with deposit actions - const childPublicClient = createPublicClient({ - chain: localArbChain, - transport: http(config.arbUrl), - }).extend(arbitrumDepositActions()) + // Create public clients using helper + const { parentChainPublicClient, childChainPublicClient } = + createArbitrumClient({ + parentChain: localEthChain, + // @ts-expect-error + childChain: localArbChain, + parentRpcUrl: config.ethUrl, + childRpcUrl: config.arbUrl, + }) // Get initial L2 balance - const initialBalance = await childPublicClient.getBalance({ + const initialBalance = await childChainPublicClient.getBalance({ address: account.address, }) // Prepare and send deposit transaction - const request = await childPublicClient.prepareDepositEthTransaction({ + // @ts-expect-error + const request = await childChainPublicClient.prepareDepositEthTransaction({ amount: depositAmount, account, }) - const hash = await parentWalletClient.sendTransaction(request) + const hash = await parentWalletClient.sendTransaction({ + ...request, + chain: localEthChain, + }) // Wait for L1 transaction - const receipt = await parentPublicClient.waitForTransactionReceipt({ + const receipt = await parentChainPublicClient.waitForTransactionReceipt({ hash, }) @@ -66,7 +63,7 @@ describe('arbitrumDepositActions', function () { while (attempts < maxAttempts) { await new Promise(resolve => setTimeout(resolve, 3000)) - const currentBalance = await childPublicClient.getBalance({ + const currentBalance = await childChainPublicClient.getBalance({ address: account.address, }) @@ -88,36 +85,38 @@ describe('arbitrumDepositActions', function () { '0x1234567890123456789012345678901234567890' as `0x${string}` const depositAmount = parseEther('0.01') - // Create L1 clients + // Create L1 wallet client const parentWalletClient = createWalletClient({ account, chain: localEthChain, transport: http(config.ethUrl), }) - const parentPublicClient = createPublicClient({ - chain: localEthChain, - transport: http(config.ethUrl), - }) - - // Create L2 client and extend with deposit actions - const childPublicClient = createPublicClient({ - chain: localArbChain, - transport: http(config.arbUrl), - }).extend(arbitrumDepositActions()) + // Create public clients using helper + const { parentChainPublicClient, childChainPublicClient } = + createArbitrumClient({ + parentChain: localEthChain, + // @ts-expect-error + childChain: localArbChain, + parentRpcUrl: config.ethUrl, + childRpcUrl: config.arbUrl, + }) // Get initial destination balance - const initialBalance = await childPublicClient.getBalance({ + const initialBalance = await childChainPublicClient.getBalance({ address: destinationAddress, }) // Prepare and send deposit transaction - const request = await childPublicClient.prepareDepositEthToTransaction({ - amount: depositAmount, - account: account.address, - destinationAddress, - parentPublicClient, - }) + // @ts-expect-error + const request = await childChainPublicClient.prepareDepositEthToTransaction( + { + amount: depositAmount, + account: account.address, + destinationAddress, + parentPublicClient: parentChainPublicClient, + } + ) const hash = await parentWalletClient.sendTransaction({ ...request, @@ -125,7 +124,7 @@ describe('arbitrumDepositActions', function () { }) // Wait for L1 transaction - const receipt = await parentPublicClient.waitForTransactionReceipt({ + const receipt = await parentChainPublicClient.waitForTransactionReceipt({ hash, }) @@ -139,7 +138,7 @@ describe('arbitrumDepositActions', function () { while (attempts < maxAttempts) { await new Promise(resolve => setTimeout(resolve, 3000)) - const currentBalance = await childPublicClient.getBalance({ + const currentBalance = await childChainPublicClient.getBalance({ address: destinationAddress, }) From fe1b33c823945943f173e2d52c58284a9a769c7d Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Mon, 18 Nov 2024 16:43:44 -0500 Subject: [PATCH 04/19] clean up --- .../{arbitrumDeposit => }/actions.ts | 2 +- .../arbitrumDeposit/abis/inbox.ts | 42 ------------- .../arbitrumDeposit/abis/l1GatewayRouter.ts | 23 ------- src/experimental/arbitrumDeposit/types.ts | 56 ----------------- .../createArbitrumClient.ts | 15 +++-- .../transformViemToEthers.ts | 0 ...test.ts => arbitrumDepositActions.test.ts} | 60 +++++++++---------- 7 files changed, 36 insertions(+), 162 deletions(-) rename src/experimental/{arbitrumDeposit => }/actions.ts (97%) delete mode 100644 src/experimental/arbitrumDeposit/abis/inbox.ts delete mode 100644 src/experimental/arbitrumDeposit/abis/l1GatewayRouter.ts delete mode 100644 src/experimental/arbitrumDeposit/types.ts rename src/experimental/{arbitrumDeposit => }/createArbitrumClient.ts (70%) rename src/experimental/{arbitrumDeposit => }/transformViemToEthers.ts (100%) rename tests/integration/{arbitrumDeposit.test.ts => arbitrumDepositActions.test.ts} (68%) diff --git a/src/experimental/arbitrumDeposit/actions.ts b/src/experimental/actions.ts similarity index 97% rename from src/experimental/arbitrumDeposit/actions.ts rename to src/experimental/actions.ts index 52556982c1..c3a5c2788e 100644 --- a/src/experimental/arbitrumDeposit/actions.ts +++ b/src/experimental/actions.ts @@ -6,7 +6,7 @@ import { type PublicClient, TransactionRequest, } from 'viem' -import { EthBridger } from '../../lib/assetBridger/ethBridger' +import { EthBridger } from '../lib/assetBridger/ethBridger' import { transformPublicClientToProvider } from './transformViemToEthers' export type PrepareDepositEthParameters = { diff --git a/src/experimental/arbitrumDeposit/abis/inbox.ts b/src/experimental/arbitrumDeposit/abis/inbox.ts deleted file mode 100644 index 38bb10f858..0000000000 --- a/src/experimental/arbitrumDeposit/abis/inbox.ts +++ /dev/null @@ -1,42 +0,0 @@ -export const inboxAbi = [ - { - inputs: [], - name: 'depositEth', - outputs: [{ type: 'uint256' }], - stateMutability: 'payable', - type: 'function' - }, - { - inputs: [ - { name: 'to', type: 'address' }, - { name: 'l2CallValue', type: 'uint256' }, - { name: 'maxSubmissionCost', type: 'uint256' }, - { name: 'excessFeeRefundAddress', type: 'address' }, - { name: 'callValueRefundAddress', type: 'address' }, - { name: 'gasLimit', type: 'uint256' }, - { name: 'maxFeePerGas', type: 'uint256' }, - { name: 'data', type: 'bytes' } - ], - name: 'createRetryableTicket', - outputs: [{ type: 'uint256' }], - stateMutability: 'payable', - type: 'function' - }, - { - anonymous: false, - inputs: [ - { indexed: false, name: 'messageNum', type: 'uint256' }, - { indexed: false, name: 'data', type: 'bytes' } - ], - name: 'InboxMessageDelivered', - type: 'event' - }, - { - anonymous: false, - inputs: [ - { indexed: false, name: 'messageNum', type: 'uint256' } - ], - name: 'InboxMessageDeliveredFromOrigin', - type: 'event' - } -] as const \ No newline at end of file diff --git a/src/experimental/arbitrumDeposit/abis/l1GatewayRouter.ts b/src/experimental/arbitrumDeposit/abis/l1GatewayRouter.ts deleted file mode 100644 index dfe202aa65..0000000000 --- a/src/experimental/arbitrumDeposit/abis/l1GatewayRouter.ts +++ /dev/null @@ -1,23 +0,0 @@ -export const l1GatewayRouterAbi = [ - { - inputs: [ - { name: '_token', type: 'address' }, - { name: '_to', type: 'address' }, - { name: '_amount', type: 'uint256' }, - { name: '_maxGas', type: 'uint256' }, - { name: '_gasPriceBid', type: 'uint256' }, - { name: '_data', type: 'bytes' } - ], - name: 'outboundTransfer', - outputs: [{ type: 'bytes' }], - stateMutability: 'payable', - type: 'function' - }, - { - inputs: [{ name: '_token', type: 'address' }], - name: 'getGateway', - outputs: [{ type: 'address' }], - stateMutability: 'view', - type: 'function' - } -] as const \ No newline at end of file diff --git a/src/experimental/arbitrumDeposit/types.ts b/src/experimental/arbitrumDeposit/types.ts deleted file mode 100644 index dd76192202..0000000000 --- a/src/experimental/arbitrumDeposit/types.ts +++ /dev/null @@ -1,56 +0,0 @@ -import type { Address, Hash, Transport } from 'viem' -import type { - PublicClient, - WalletClient, - Account, - Chain -} from 'viem' - -export type ArbitrumDepositConfig = { - inboxAddress: Address -} - -export type GasOverrides = { - gasLimit?: { - min?: bigint - max?: bigint - } - maxFeePerGas?: { - min?: bigint - max?: bigint - } - maxSubmissionCost?: { - min?: bigint - max?: bigint - } -} - -export type RetryableGasParams = { - gasLimit: bigint - maxFeePerGas: bigint - maxSubmissionCost: bigint -} - -export type EthDepositParameters = { - amount: bigint - account: Account | Address - to?: Address // Optional destination address - retryableGasOverrides?: GasOverrides -} - -export type Erc20DepositParameters = { - token: Address - amount: bigint - account: Account | Address - to?: Address // Optional destination address, defaults to sender -} - -export type ApproveErc20Parameters = { - token: Address - amount: bigint - account: Account | Address -} - -export type ArbitrumDepositActions = { - depositEth: (args: EthDepositParameters) => Promise -} \ No newline at end of file diff --git a/src/experimental/arbitrumDeposit/createArbitrumClient.ts b/src/experimental/createArbitrumClient.ts similarity index 70% rename from src/experimental/arbitrumDeposit/createArbitrumClient.ts rename to src/experimental/createArbitrumClient.ts index 0fb8568e69..abbd982188 100644 --- a/src/experimental/arbitrumDeposit/createArbitrumClient.ts +++ b/src/experimental/createArbitrumClient.ts @@ -1,13 +1,12 @@ import { Chain, PublicClient, createPublicClient, http } from 'viem' -import { ArbitrumNetwork } from '../../lib/dataEntities/networks' +import { ArbitrumNetwork } from '../lib/dataEntities/networks' import { arbitrumDepositActions } from './actions' export type ArbitrumChain = Chain & ArbitrumNetwork export type ArbitrumClients = { - parentChainPublicClient: PublicClient - childChainPublicClient: PublicClient & - ReturnType + parentPublicClient: PublicClient + childPublicClient: PublicClient & ReturnType } export type ChildChainPublicClient = PublicClient & ReturnType @@ -25,18 +24,18 @@ export function createArbitrumClient({ parentRpcUrl, childRpcUrl, }: CreateArbitrumClientParams): ArbitrumClients { - const parentChainPublicClient = createPublicClient({ + const parentPublicClient = createPublicClient({ chain: parentChain, transport: http(parentRpcUrl || parentChain.rpcUrls.default.http[0]), }) - const childChainPublicClient = createPublicClient({ + const childPublicClient = createPublicClient({ chain: childChain, transport: http(childRpcUrl || childChain.rpcUrls.default.http[0]), }).extend(arbitrumDepositActions()) return { - parentChainPublicClient, - childChainPublicClient, + parentPublicClient, + childPublicClient, } as any as ArbitrumClients } diff --git a/src/experimental/arbitrumDeposit/transformViemToEthers.ts b/src/experimental/transformViemToEthers.ts similarity index 100% rename from src/experimental/arbitrumDeposit/transformViemToEthers.ts rename to src/experimental/transformViemToEthers.ts diff --git a/tests/integration/arbitrumDeposit.test.ts b/tests/integration/arbitrumDepositActions.test.ts similarity index 68% rename from tests/integration/arbitrumDeposit.test.ts rename to tests/integration/arbitrumDepositActions.test.ts index e99df74b87..397e671b4a 100644 --- a/tests/integration/arbitrumDeposit.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -3,7 +3,7 @@ import { createWalletClient, http, parseEther } from 'viem' import { privateKeyToAccount } from 'viem/accounts' import { config, testSetup } from '../../scripts/testSetup' import { localEthChain, localArbChain } from '../../src/experimental/chains' -import { createArbitrumClient } from '../../src/experimental/arbitrumDeposit/createArbitrumClient' +import { createArbitrumClient } from '../../src/experimental/createArbitrumClient' describe('arbitrumDepositActions', function () { before(async function () { @@ -22,23 +22,22 @@ describe('arbitrumDepositActions', function () { }) // Create public clients using helper - const { parentChainPublicClient, childChainPublicClient } = - createArbitrumClient({ - parentChain: localEthChain, - // @ts-expect-error - childChain: localArbChain, - parentRpcUrl: config.ethUrl, - childRpcUrl: config.arbUrl, - }) + const { parentPublicClient, childPublicClient } = createArbitrumClient({ + parentChain: localEthChain, + // @ts-expect-error + childChain: localArbChain, + parentRpcUrl: config.ethUrl, + childRpcUrl: config.arbUrl, + }) // Get initial L2 balance - const initialBalance = await childChainPublicClient.getBalance({ + const initialBalance = await childPublicClient.getBalance({ address: account.address, }) // Prepare and send deposit transaction // @ts-expect-error - const request = await childChainPublicClient.prepareDepositEthTransaction({ + const request = await childPublicClient.prepareDepositEthTransaction({ amount: depositAmount, account, }) @@ -49,7 +48,7 @@ describe('arbitrumDepositActions', function () { }) // Wait for L1 transaction - const receipt = await parentChainPublicClient.waitForTransactionReceipt({ + const receipt = await parentPublicClient.waitForTransactionReceipt({ hash, }) @@ -63,7 +62,7 @@ describe('arbitrumDepositActions', function () { while (attempts < maxAttempts) { await new Promise(resolve => setTimeout(resolve, 3000)) - const currentBalance = await childChainPublicClient.getBalance({ + const currentBalance = await childPublicClient.getBalance({ address: account.address, }) @@ -93,30 +92,27 @@ describe('arbitrumDepositActions', function () { }) // Create public clients using helper - const { parentChainPublicClient, childChainPublicClient } = - createArbitrumClient({ - parentChain: localEthChain, - // @ts-expect-error - childChain: localArbChain, - parentRpcUrl: config.ethUrl, - childRpcUrl: config.arbUrl, - }) + const { parentPublicClient, childPublicClient } = createArbitrumClient({ + parentChain: localEthChain, + // @ts-expect-error + childChain: localArbChain, + parentRpcUrl: config.ethUrl, + childRpcUrl: config.arbUrl, + }) // Get initial destination balance - const initialBalance = await childChainPublicClient.getBalance({ + const initialBalance = await childPublicClient.getBalance({ address: destinationAddress, }) // Prepare and send deposit transaction // @ts-expect-error - const request = await childChainPublicClient.prepareDepositEthToTransaction( - { - amount: depositAmount, - account: account.address, - destinationAddress, - parentPublicClient: parentChainPublicClient, - } - ) + const request = await childPublicClient.prepareDepositEthToTransaction({ + amount: depositAmount, + account: account.address, + destinationAddress, + parentPublicClient, + }) const hash = await parentWalletClient.sendTransaction({ ...request, @@ -124,7 +120,7 @@ describe('arbitrumDepositActions', function () { }) // Wait for L1 transaction - const receipt = await parentChainPublicClient.waitForTransactionReceipt({ + const receipt = await parentPublicClient.waitForTransactionReceipt({ hash, }) @@ -138,7 +134,7 @@ describe('arbitrumDepositActions', function () { while (attempts < maxAttempts) { await new Promise(resolve => setTimeout(resolve, 3000)) - const currentBalance = await childChainPublicClient.getBalance({ + const currentBalance = await childPublicClient.getBalance({ address: destinationAddress, }) From f42cb706f3443642ca01f0c48b7af1c48d1cc533 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Mon, 18 Nov 2024 16:50:35 -0500 Subject: [PATCH 05/19] tweak tests --- .../arbitrumDepositActions.test.ts | 26 +++++++++---------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index 397e671b4a..4602609bc8 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -10,11 +10,11 @@ describe('arbitrumDepositActions', function () { await testSetup() }) - it('deposits ETH from L1 to L2', async function () { + it('deposits ETH from parent to child', async function () { const account = privateKeyToAccount(`0x${config.ethKey}` as `0x${string}`) const depositAmount = parseEther('0.01') - // Create L1 wallet client + // Create parent wallet client const parentWalletClient = createWalletClient({ account, chain: localEthChain, @@ -30,7 +30,7 @@ describe('arbitrumDepositActions', function () { childRpcUrl: config.arbUrl, }) - // Get initial L2 balance + // Get initial child balance const initialBalance = await childPublicClient.getBalance({ address: account.address, }) @@ -47,20 +47,20 @@ describe('arbitrumDepositActions', function () { chain: localEthChain, }) - // Wait for L1 transaction + // Wait for parent transaction const receipt = await parentPublicClient.waitForTransactionReceipt({ hash, }) expect(receipt.status).to.equal('success') - // Wait for L2 balance to increase + // Wait for child balance to increase let finalBalance = initialBalance let attempts = 0 - const maxAttempts = 10 + const maxAttempts = 12 while (attempts < maxAttempts) { - await new Promise(resolve => setTimeout(resolve, 3000)) + await new Promise(resolve => setTimeout(resolve, 1500)) const currentBalance = await childPublicClient.getBalance({ address: account.address, @@ -78,13 +78,13 @@ describe('arbitrumDepositActions', function () { expect(balanceDiff).to.equal(depositAmount) }) - it('deposits ETH from L1 to a different L2 address', async function () { + it('deposits ETH from parent to a different child address', async function () { const account = privateKeyToAccount(`0x${config.ethKey}` as `0x${string}`) const destinationAddress = '0x1234567890123456789012345678901234567890' as `0x${string}` const depositAmount = parseEther('0.01') - // Create L1 wallet client + // Create parent wallet client const parentWalletClient = createWalletClient({ account, chain: localEthChain, @@ -119,20 +119,20 @@ describe('arbitrumDepositActions', function () { chain: localEthChain, }) - // Wait for L1 transaction + // Wait for parent transaction const receipt = await parentPublicClient.waitForTransactionReceipt({ hash, }) expect(receipt.status).to.equal('success') - // Wait for L2 balance to increase + // Wait for child balance to increase let finalBalance = initialBalance let attempts = 0 - const maxAttempts = 10 + const maxAttempts = 12 while (attempts < maxAttempts) { - await new Promise(resolve => setTimeout(resolve, 3000)) + await new Promise(resolve => setTimeout(resolve, 1500)) const currentBalance = await childPublicClient.getBalance({ address: destinationAddress, From 48555db03e6b0f0cc5444c492d85f59a04402d91 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Tue, 19 Nov 2024 15:40:52 -0500 Subject: [PATCH 06/19] more cleanup --- package.json | 2 - scripts/testSetup.ts | 44 ++ src/experimental/actions.ts | 45 +- src/experimental/chains.ts | 39 -- src/experimental/createArbitrumClient.ts | 13 +- .../arbitrumDepositActions.test.ts | 34 +- yarn.lock | 482 +----------------- 7 files changed, 87 insertions(+), 572 deletions(-) delete mode 100644 src/experimental/chains.ts diff --git a/package.json b/package.json index 1b1e4790eb..094e161a84 100644 --- a/package.json +++ b/package.json @@ -24,7 +24,6 @@ "prepare": "yarn run gen:abi", "gen:abi": "node ./scripts/genAbi.js", "gen:network": "ts-node ./scripts/genNetwork.ts", - "gen:wagmi": "wagmi generate", "prepublishOnly": "yarn build && yarn format", "preversion": "yarn lint", "prebuild": "yarn gen:abi", @@ -67,7 +66,6 @@ "@typescript-eslint/eslint-plugin": "^5.14.0", "@typescript-eslint/eslint-plugin-tslint": "^5.27.1", "@typescript-eslint/parser": "^5.14.0", - "@wagmi/cli": "^2.1.18", "audit-ci": "^6.3.0", "axios": "^1.7.4", "chai": "^4.2.0", diff --git a/scripts/testSetup.ts b/scripts/testSetup.ts index 10bc2c68ba..64cc762383 100644 --- a/scripts/testSetup.ts +++ b/scripts/testSetup.ts @@ -40,6 +40,7 @@ import { isArbitrumNetworkWithCustomFeeToken, } from '../tests/integration/custom-fee-token/customFeeTokenTestHelpers' import { fundParentSigner } from '../tests/integration/testHelpers' +import { Chain } from 'viem' dotenv.config() @@ -85,6 +86,8 @@ export const testSetup = async (): Promise<{ inboxTools: InboxTools parentDeployer: Signer childDeployer: Signer + localEthChain: Chain + localArbChain: Chain }> => { const ethProvider = new JsonRpcProvider(config.ethUrl) const arbProvider = new JsonRpcProvider(config.arbUrl) @@ -113,6 +116,23 @@ export const testSetup = async (): Promise<{ assertArbitrumNetworkHasTokenBridge(setChildChain) + // Generate Viem chains using the network data we already have + const localEthChain = generateViemChain( + { + chainId: setChildChain.parentChainId, + name: 'EthLocal', + }, + config.ethUrl + ) + + const localArbChain = generateViemChain( + { + chainId: setChildChain.chainId, + name: setChildChain.name, + }, + config.arbUrl + ) + const erc20Bridger = new Erc20Bridger(setChildChain) const adminErc20Bridger = new AdminErc20Bridger(setChildChain) const ethBridger = new EthBridger(setChildChain) @@ -136,6 +156,8 @@ export const testSetup = async (): Promise<{ inboxTools, parentDeployer, childDeployer, + localEthChain, + localArbChain, } } @@ -153,3 +175,25 @@ export function getLocalNetworksFromFile(): { return { l2Network: localL2, l3Network: localL3 } } + +function generateViemChain( + networkData: { + chainId: number + name: string + }, + rpcUrl: string +): Chain { + return { + id: networkData.chainId, + name: networkData.name, + nativeCurrency: { + decimals: 18, + name: 'Ether', + symbol: 'ETH', + }, + rpcUrls: { + default: { http: [rpcUrl] }, + public: { http: [rpcUrl] }, + } + } as const satisfies Chain +} \ No newline at end of file diff --git a/src/experimental/actions.ts b/src/experimental/actions.ts index c3a5c2788e..514e9fb709 100644 --- a/src/experimental/actions.ts +++ b/src/experimental/actions.ts @@ -1,11 +1,5 @@ import { BigNumber } from 'ethers' -import { - Account, - Address, - Client, - type PublicClient, - TransactionRequest, -} from 'viem' +import { Account, Address, Chain, PublicClient, TransactionRequest } from 'viem' import { EthBridger } from '../lib/assetBridger/ethBridger' import { transformPublicClientToProvider } from './transformViemToEthers' @@ -14,13 +8,24 @@ export type PrepareDepositEthParameters = { account: Account | Address } -export type PrepareDepositEthToParameters = PrepareDepositEthParameters & { +export type PrepareDepositEthToParameters = { + amount: bigint + account: Address destinationAddress: Address parentPublicClient: PublicClient } -export async function prepareDepositEthTransaction( - client: Client, +export type ArbitrumDepositActions = { + prepareDepositEthTransaction: ( + params: PrepareDepositEthParameters + ) => Promise + prepareDepositEthToTransaction: ( + params: PrepareDepositEthToParameters + ) => Promise +} + +async function prepareDepositEthTransaction( + client: PublicClient, { amount, account }: PrepareDepositEthParameters ): Promise { const provider = transformPublicClientToProvider(client) @@ -37,8 +42,8 @@ export async function prepareDepositEthTransaction( } } -export async function prepareDepositEthToTransaction( - client: Client, +async function prepareDepositEthToTransaction( + client: PublicClient, { amount, account, @@ -53,7 +58,7 @@ export async function prepareDepositEthToTransaction( const request = await ethBridger.getDepositToRequest({ amount: BigNumber.from(amount), destinationAddress, - from: typeof account === 'string' ? account : account.address, + from: account, parentProvider, childProvider, }) @@ -66,12 +71,10 @@ export async function prepareDepositEthToTransaction( } export function arbitrumDepositActions() { - return function (client: Client) { - return { - prepareDepositEthTransaction: (args: PrepareDepositEthParameters) => - prepareDepositEthTransaction(client, args), - prepareDepositEthToTransaction: (args: PrepareDepositEthToParameters) => - prepareDepositEthToTransaction(client, args), - } - } + return (client: PublicClient): ArbitrumDepositActions => ({ + prepareDepositEthTransaction: params => + prepareDepositEthTransaction(client, params), + prepareDepositEthToTransaction: params => + prepareDepositEthToTransaction(client, params), + }) } diff --git a/src/experimental/chains.ts b/src/experimental/chains.ts deleted file mode 100644 index 91d7bace69..0000000000 --- a/src/experimental/chains.ts +++ /dev/null @@ -1,39 +0,0 @@ -import { type Chain } from 'viem' - -export const localEthChain = { - id: 1337, - name: 'EthLocal', - nativeCurrency: { - decimals: 18, - name: 'Ether', - symbol: 'ETH', - }, - rpcUrls: { - default: { http: ['http://localhost:8545'] }, - public: { http: ['http://localhost:8545'] }, - } -} as const satisfies Chain - -export const localArbChain = { - id: 412346, - name: 'ArbLocal', - nativeCurrency: { - decimals: 18, - name: 'Ether', - symbol: 'ETH', - }, - rpcUrls: { - default: { http: ['http://localhost:8547'] }, - public: { http: ['http://localhost:8547'] }, - } -} as const satisfies Chain - -function getChainConfig(chainId: number) { - const chains = { - [localEthChain.id]: localEthChain, - [localArbChain.id]: localArbChain - } - return chains[chainId as keyof typeof chains] -} - -export { getChainConfig } \ No newline at end of file diff --git a/src/experimental/createArbitrumClient.ts b/src/experimental/createArbitrumClient.ts index abbd982188..98e972d54a 100644 --- a/src/experimental/createArbitrumClient.ts +++ b/src/experimental/createArbitrumClient.ts @@ -1,19 +1,14 @@ import { Chain, PublicClient, createPublicClient, http } from 'viem' -import { ArbitrumNetwork } from '../lib/dataEntities/networks' -import { arbitrumDepositActions } from './actions' - -export type ArbitrumChain = Chain & ArbitrumNetwork +import { arbitrumDepositActions, ArbitrumDepositActions } from './actions' export type ArbitrumClients = { parentPublicClient: PublicClient - childPublicClient: PublicClient & ReturnType + childPublicClient: PublicClient & ArbitrumDepositActions } -export type ChildChainPublicClient = PublicClient & - ReturnType export type CreateArbitrumClientParams = { parentChain: Chain - childChain: ArbitrumChain + childChain: Chain parentRpcUrl?: string childRpcUrl?: string } @@ -37,5 +32,5 @@ export function createArbitrumClient({ return { parentPublicClient, childPublicClient, - } as any as ArbitrumClients + } } diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index 4602609bc8..da05622a6b 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -1,42 +1,40 @@ import { expect } from 'chai' -import { createWalletClient, http, parseEther } from 'viem' +import { createWalletClient, http, parseEther, type Chain } from 'viem' import { privateKeyToAccount } from 'viem/accounts' import { config, testSetup } from '../../scripts/testSetup' -import { localEthChain, localArbChain } from '../../src/experimental/chains' import { createArbitrumClient } from '../../src/experimental/createArbitrumClient' describe('arbitrumDepositActions', function () { + let localEthChain: Chain + let localArbChain: Chain + before(async function () { - await testSetup() + const setup = await testSetup() + localEthChain = setup.localEthChain + localArbChain = setup.localArbChain }) it('deposits ETH from parent to child', async function () { const account = privateKeyToAccount(`0x${config.ethKey}` as `0x${string}`) const depositAmount = parseEther('0.01') - // Create parent wallet client const parentWalletClient = createWalletClient({ account, chain: localEthChain, transport: http(config.ethUrl), }) - // Create public clients using helper const { parentPublicClient, childPublicClient } = createArbitrumClient({ parentChain: localEthChain, - // @ts-expect-error childChain: localArbChain, parentRpcUrl: config.ethUrl, childRpcUrl: config.arbUrl, }) - // Get initial child balance const initialBalance = await childPublicClient.getBalance({ address: account.address, }) - // Prepare and send deposit transaction - // @ts-expect-error const request = await childPublicClient.prepareDepositEthTransaction({ amount: depositAmount, account, @@ -45,16 +43,16 @@ describe('arbitrumDepositActions', function () { const hash = await parentWalletClient.sendTransaction({ ...request, chain: localEthChain, - }) + account, + kzg: undefined, + } as const) - // Wait for parent transaction const receipt = await parentPublicClient.waitForTransactionReceipt({ hash, }) expect(receipt.status).to.equal('success') - // Wait for child balance to increase let finalBalance = initialBalance let attempts = 0 const maxAttempts = 12 @@ -84,29 +82,23 @@ describe('arbitrumDepositActions', function () { '0x1234567890123456789012345678901234567890' as `0x${string}` const depositAmount = parseEther('0.01') - // Create parent wallet client const parentWalletClient = createWalletClient({ account, chain: localEthChain, transport: http(config.ethUrl), }) - // Create public clients using helper const { parentPublicClient, childPublicClient } = createArbitrumClient({ parentChain: localEthChain, - // @ts-expect-error childChain: localArbChain, parentRpcUrl: config.ethUrl, childRpcUrl: config.arbUrl, }) - // Get initial destination balance const initialBalance = await childPublicClient.getBalance({ address: destinationAddress, }) - // Prepare and send deposit transaction - // @ts-expect-error const request = await childPublicClient.prepareDepositEthToTransaction({ amount: depositAmount, account: account.address, @@ -117,16 +109,16 @@ describe('arbitrumDepositActions', function () { const hash = await parentWalletClient.sendTransaction({ ...request, chain: localEthChain, - }) + account, + kzg: undefined, + } as const) - // Wait for parent transaction const receipt = await parentPublicClient.waitForTransactionReceipt({ hash, }) expect(receipt.status).to.equal('success') - // Wait for child balance to increase let finalBalance = initialBalance let attempts = 0 const maxAttempts = 12 diff --git a/yarn.lock b/yarn.lock index ffccb87e64..80b50295d6 100644 --- a/yarn.lock +++ b/yarn.lock @@ -316,121 +316,6 @@ dependencies: "@cspotcode/source-map-consumer" "0.8.0" -"@esbuild/aix-ppc64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/aix-ppc64/-/aix-ppc64-0.19.12.tgz#d1bc06aedb6936b3b6d313bf809a5a40387d2b7f" - integrity sha512-bmoCYyWdEL3wDQIVbcyzRyeKLgk2WtWLTWz1ZIAZF/EGbNOwSA6ew3PftJ1PqMiOOGu0OyFMzG53L0zqIpPeNA== - -"@esbuild/android-arm64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/android-arm64/-/android-arm64-0.19.12.tgz#7ad65a36cfdb7e0d429c353e00f680d737c2aed4" - integrity sha512-P0UVNGIienjZv3f5zq0DP3Nt2IE/3plFzuaS96vihvD0Hd6H/q4WXUGpCxD/E8YrSXfNyRPbpTq+T8ZQioSuPA== - -"@esbuild/android-arm@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/android-arm/-/android-arm-0.19.12.tgz#b0c26536f37776162ca8bde25e42040c203f2824" - integrity sha512-qg/Lj1mu3CdQlDEEiWrlC4eaPZ1KztwGJ9B6J+/6G+/4ewxJg7gqj8eVYWvao1bXrqGiW2rsBZFSX3q2lcW05w== - -"@esbuild/android-x64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/android-x64/-/android-x64-0.19.12.tgz#cb13e2211282012194d89bf3bfe7721273473b3d" - integrity sha512-3k7ZoUW6Q6YqhdhIaq/WZ7HwBpnFBlW905Fa4s4qWJyiNOgT1dOqDiVAQFwBH7gBRZr17gLrlFCRzF6jFh7Kew== - -"@esbuild/darwin-arm64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/darwin-arm64/-/darwin-arm64-0.19.12.tgz#cbee41e988020d4b516e9d9e44dd29200996275e" - integrity sha512-B6IeSgZgtEzGC42jsI+YYu9Z3HKRxp8ZT3cqhvliEHovq8HSX2YX8lNocDn79gCKJXOSaEot9MVYky7AKjCs8g== - -"@esbuild/darwin-x64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/darwin-x64/-/darwin-x64-0.19.12.tgz#e37d9633246d52aecf491ee916ece709f9d5f4cd" - integrity sha512-hKoVkKzFiToTgn+41qGhsUJXFlIjxI/jSYeZf3ugemDYZldIXIxhvwN6erJGlX4t5h417iFuheZ7l+YVn05N3A== - -"@esbuild/freebsd-arm64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/freebsd-arm64/-/freebsd-arm64-0.19.12.tgz#1ee4d8b682ed363b08af74d1ea2b2b4dbba76487" - integrity sha512-4aRvFIXmwAcDBw9AueDQ2YnGmz5L6obe5kmPT8Vd+/+x/JMVKCgdcRwH6APrbpNXsPz+K653Qg8HB/oXvXVukA== - -"@esbuild/freebsd-x64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/freebsd-x64/-/freebsd-x64-0.19.12.tgz#37a693553d42ff77cd7126764b535fb6cc28a11c" - integrity sha512-EYoXZ4d8xtBoVN7CEwWY2IN4ho76xjYXqSXMNccFSx2lgqOG/1TBPW0yPx1bJZk94qu3tX0fycJeeQsKovA8gg== - -"@esbuild/linux-arm64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/linux-arm64/-/linux-arm64-0.19.12.tgz#be9b145985ec6c57470e0e051d887b09dddb2d4b" - integrity sha512-EoTjyYyLuVPfdPLsGVVVC8a0p1BFFvtpQDB/YLEhaXyf/5bczaGeN15QkR+O4S5LeJ92Tqotve7i1jn35qwvdA== - -"@esbuild/linux-arm@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/linux-arm/-/linux-arm-0.19.12.tgz#207ecd982a8db95f7b5279207d0ff2331acf5eef" - integrity sha512-J5jPms//KhSNv+LO1S1TX1UWp1ucM6N6XuL6ITdKWElCu8wXP72l9MM0zDTzzeikVyqFE6U8YAV9/tFyj0ti+w== - -"@esbuild/linux-ia32@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/linux-ia32/-/linux-ia32-0.19.12.tgz#d0d86b5ca1562523dc284a6723293a52d5860601" - integrity sha512-Thsa42rrP1+UIGaWz47uydHSBOgTUnwBwNq59khgIwktK6x60Hivfbux9iNR0eHCHzOLjLMLfUMLCypBkZXMHA== - -"@esbuild/linux-loong64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/linux-loong64/-/linux-loong64-0.19.12.tgz#9a37f87fec4b8408e682b528391fa22afd952299" - integrity sha512-LiXdXA0s3IqRRjm6rV6XaWATScKAXjI4R4LoDlvO7+yQqFdlr1Bax62sRwkVvRIrwXxvtYEHHI4dm50jAXkuAA== - -"@esbuild/linux-mips64el@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/linux-mips64el/-/linux-mips64el-0.19.12.tgz#4ddebd4e6eeba20b509d8e74c8e30d8ace0b89ec" - integrity sha512-fEnAuj5VGTanfJ07ff0gOA6IPsvrVHLVb6Lyd1g2/ed67oU1eFzL0r9WL7ZzscD+/N6i3dWumGE1Un4f7Amf+w== - -"@esbuild/linux-ppc64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/linux-ppc64/-/linux-ppc64-0.19.12.tgz#adb67dadb73656849f63cd522f5ecb351dd8dee8" - integrity sha512-nYJA2/QPimDQOh1rKWedNOe3Gfc8PabU7HT3iXWtNUbRzXS9+vgB0Fjaqr//XNbd82mCxHzik2qotuI89cfixg== - -"@esbuild/linux-riscv64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/linux-riscv64/-/linux-riscv64-0.19.12.tgz#11bc0698bf0a2abf8727f1c7ace2112612c15adf" - integrity sha512-2MueBrlPQCw5dVJJpQdUYgeqIzDQgw3QtiAHUC4RBz9FXPrskyyU3VI1hw7C0BSKB9OduwSJ79FTCqtGMWqJHg== - -"@esbuild/linux-s390x@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/linux-s390x/-/linux-s390x-0.19.12.tgz#e86fb8ffba7c5c92ba91fc3b27ed5a70196c3cc8" - integrity sha512-+Pil1Nv3Umes4m3AZKqA2anfhJiVmNCYkPchwFJNEJN5QxmTs1uzyy4TvmDrCRNT2ApwSari7ZIgrPeUx4UZDg== - -"@esbuild/linux-x64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/linux-x64/-/linux-x64-0.19.12.tgz#5f37cfdc705aea687dfe5dfbec086a05acfe9c78" - integrity sha512-B71g1QpxfwBvNrfyJdVDexenDIt1CiDN1TIXLbhOw0KhJzE78KIFGX6OJ9MrtC0oOqMWf+0xop4qEU8JrJTwCg== - -"@esbuild/netbsd-x64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/netbsd-x64/-/netbsd-x64-0.19.12.tgz#29da566a75324e0d0dd7e47519ba2f7ef168657b" - integrity sha512-3ltjQ7n1owJgFbuC61Oj++XhtzmymoCihNFgT84UAmJnxJfm4sYCiSLTXZtE00VWYpPMYc+ZQmB6xbSdVh0JWA== - -"@esbuild/openbsd-x64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/openbsd-x64/-/openbsd-x64-0.19.12.tgz#306c0acbdb5a99c95be98bdd1d47c916e7dc3ff0" - integrity sha512-RbrfTB9SWsr0kWmb9srfF+L933uMDdu9BIzdA7os2t0TXhCRjrQyCeOt6wVxr79CKD4c+p+YhCj31HBkYcXebw== - -"@esbuild/sunos-x64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/sunos-x64/-/sunos-x64-0.19.12.tgz#0933eaab9af8b9b2c930236f62aae3fc593faf30" - integrity sha512-HKjJwRrW8uWtCQnQOz9qcU3mUZhTUQvi56Q8DPTLLB+DawoiQdjsYq+j+D3s9I8VFtDr+F9CjgXKKC4ss89IeA== - -"@esbuild/win32-arm64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/win32-arm64/-/win32-arm64-0.19.12.tgz#773bdbaa1971b36db2f6560088639ccd1e6773ae" - integrity sha512-URgtR1dJnmGvX864pn1B2YUYNzjmXkuJOIqG2HdU62MVS4EHpU2946OZoTMnRUHklGtJdJZ33QfzdjGACXhn1A== - -"@esbuild/win32-ia32@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/win32-ia32/-/win32-ia32-0.19.12.tgz#000516cad06354cc84a73f0943a4aa690ef6fd67" - integrity sha512-+ZOE6pUkMOJfmxmBZElNOx72NKpIa/HFOMGzu8fqzQJ5kgf6aTGrcJaFsNiVMH4JKpMipyK+7k0n2UXN7a8YKQ== - -"@esbuild/win32-x64@0.19.12": - version "0.19.12" - resolved "https://registry.yarnpkg.com/@esbuild/win32-x64/-/win32-x64-0.19.12.tgz#c57c8afbb4054a3ab8317591a0b7320360b444ae" - integrity sha512-T1QyPSDCyMXaO3pzBkF96E8xMkiRYbUEZADd29SyPGabqxMViNoii+NcK7eWJAEoU6RZyEm5lVSIjTmcdoB9HA== - "@eslint/eslintrc@^0.4.3": version "0.4.3" resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-0.4.3.tgz#9e42981ef035beb3dd49add17acb96e8ff6f394c" @@ -1907,32 +1792,6 @@ resolved "https://registry.yarnpkg.com/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz#aa58042711d6e3275dd37dc597e5d31e8c290a44" integrity sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q== -"@wagmi/cli@^2.1.18": - version "2.1.18" - resolved "https://registry.yarnpkg.com/@wagmi/cli/-/cli-2.1.18.tgz#d10ddd7a3517a723b48714538e1585c66dff029f" - integrity sha512-1Vqz3Kj0WY/p6vUq1a2m8NH+64wAcoV+fUC8j5BrEgaeCDbQrWdZ2nMLbz/I6ao2oPNvv1eNWCjR6r8QiscXlA== - dependencies: - abitype "^1.0.4" - bundle-require "^4.0.2" - cac "^6.7.14" - change-case "^5.4.4" - chokidar "4.0.1" - dedent "^0.7.0" - dotenv "^16.3.1" - dotenv-expand "^10.0.0" - esbuild "^0.19.0" - execa "^8.0.1" - fdir "^6.1.1" - find-up "^6.3.0" - fs-extra "^11.2.0" - ora "^6.3.1" - pathe "^1.1.2" - picocolors "^1.0.0" - picomatch "^3.0.0" - prettier "^3.0.3" - viem "2.x" - zod "^3.22.2" - "@yarnpkg/lockfile@^1.1.0": version "1.1.0" resolved "https://registry.yarnpkg.com/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz#e77a97fbd345b76d83245edcd17d393b1b41fb31" @@ -1946,7 +1805,7 @@ JSONStream@^1.3.5: jsonparse "^1.2.0" through ">=2.2.7 <3" -abitype@1.0.6, abitype@^1.0.4, abitype@^1.0.6: +abitype@1.0.6, abitype@^1.0.6: version "1.0.6" resolved "https://registry.yarnpkg.com/abitype/-/abitype-1.0.6.tgz#76410903e1d88e34f1362746e2d407513c38565b" integrity sha512-MMSqYh4+C/aVqI2RQaWqbvI4Kxo5cQV40WQ4QFtDnNzCkqChm8MuENhElmynZlO0qUy/ObkEUaXtKqYnx1Kp3A== @@ -2051,11 +1910,6 @@ ansi-regex@^5.0.1: resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== -ansi-regex@^6.0.1: - version "6.1.0" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-6.1.0.tgz#95ec409c69619d6cb1b8b34f14b660ef28ebd654" - integrity sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA== - ansi-styles@^3.2.1: version "3.2.1" resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" @@ -2264,15 +2118,6 @@ bl@^4.0.3: inherits "^2.0.4" readable-stream "^3.4.0" -bl@^5.0.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/bl/-/bl-5.1.0.tgz#183715f678c7188ecef9fe475d90209400624273" - integrity sha512-tv1ZJHLfTDnXE6tMHv73YgSJaWR2AFuPwMntBe7XL/GBFHnT0CLnsHMogfk5+GzCDC5ZWarSCYaIGATZt9dNsQ== - dependencies: - buffer "^6.0.3" - inherits "^2.0.4" - readable-stream "^3.4.0" - blakejs@^1.1.0: version "1.2.1" resolved "https://registry.yarnpkg.com/blakejs/-/blakejs-1.2.1.tgz#5057e4206eadb4a97f7c0b6e197a505042fc3814" @@ -2416,23 +2261,11 @@ builtin-modules@^1.1.1: resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-1.1.1.tgz#270f076c5a72c02f5b65a47df94c5fe3a278892f" integrity sha512-wxXCdllwGhI2kCC0MnvTGYTMvnVZTvqgypkiTI8Pa5tcz2i6VqsqwYGgqwXji+4RgCzms6EajE4IxiUH6HH8nQ== -bundle-require@^4.0.2: - version "4.2.1" - resolved "https://registry.yarnpkg.com/bundle-require/-/bundle-require-4.2.1.tgz#4c450a5807381d20ade987bde8ac391544257919" - integrity sha512-7Q/6vkyYAwOmQNRw75x+4yRtZCZJXUDmHHlFdkiV0wgv/reNjtJwpu1jPJ0w2kbEpIM0uoKI3S4/f39dU7AjSA== - dependencies: - load-tsconfig "^0.2.3" - bytes@3.1.2: version "3.1.2" resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== -cac@^6.7.14: - version "6.7.14" - resolved "https://registry.yarnpkg.com/cac/-/cac-6.7.14.tgz#804e1e6f506ee363cb0e3ccbb09cad5dd9870959" - integrity sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ== - caching-transform@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/caching-transform/-/caching-transform-4.0.0.tgz#00d297a4206d71e2163c39eaffa8157ac0651f0f" @@ -2520,16 +2353,6 @@ chalk@^4.0.0, chalk@^4.1.0, chalk@^4.1.2: ansi-styles "^4.1.0" supports-color "^7.1.0" -chalk@^5.0.0: - version "5.3.0" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-5.3.0.tgz#67c20a7ebef70e7f3970a01f90fa210cb6860385" - integrity sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w== - -change-case@^5.4.4: - version "5.4.4" - resolved "https://registry.yarnpkg.com/change-case/-/change-case-5.4.4.tgz#0d52b507d8fb8f204343432381d1a6d7bff97a02" - integrity sha512-HRQyTk2/YPEkt9TnUPbOpr64Uw3KOicFWPVBb+xiHvd6eBx/qPr9xqfBFDT8P2vWsvvz4jbEkfDe71W3VyNu2w== - check-error@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/check-error/-/check-error-1.0.3.tgz#a6502e4312a7ee969f646e83bb3ddd56281bd694" @@ -2577,13 +2400,6 @@ chokidar@3.5.3, chokidar@^3.4.0: optionalDependencies: fsevents "~2.3.2" -chokidar@4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-4.0.1.tgz#4a6dff66798fb0f72a94f616abbd7e1a19f31d41" - integrity sha512-n8enUVCED/KVRQlab1hr3MVpcVMvxtZjmEa956u+4YijlmQED223XMSYj2tLuKvr4jcCTzNNMpQDUer72MMmzA== - dependencies: - readdirp "^4.0.1" - chownr@^1.1.1: version "1.1.4" resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.1.4.tgz#6fc9d7b42d32a583596337666e7d08084da2cc6b" @@ -2618,18 +2434,6 @@ clean-stack@^2.0.0: resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== -cli-cursor@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-4.0.0.tgz#3cecfe3734bf4fe02a8361cbdc0f6fe28c6a57ea" - integrity sha512-VGtlMu3x/4DOtIUwEkRezxUZ2lBacNJCHash0N0WeZDBS+7Ux1dm3XWAgWYxLJFMMdOeXMHXorshEFhbMSGelg== - dependencies: - restore-cursor "^4.0.0" - -cli-spinners@^2.6.1: - version "2.9.2" - resolved "https://registry.yarnpkg.com/cli-spinners/-/cli-spinners-2.9.2.tgz#1773a8f4b9c4d6ac31563df53b3fc1d79462fe41" - integrity sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg== - cliui@^6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/cliui/-/cliui-6.0.0.tgz#511d702c0c4e41ca156d7d0e96021f23e13225b1" @@ -2648,11 +2452,6 @@ cliui@^7.0.2: strip-ansi "^6.0.0" wrap-ansi "^7.0.0" -clone@^1.0.2: - version "1.0.4" - resolved "https://registry.yarnpkg.com/clone/-/clone-1.0.4.tgz#da309cc263df15994c688ca902179ca3c7cd7c7e" - integrity sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg== - color-convert@^1.9.0: version "1.9.3" resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" @@ -2878,11 +2677,6 @@ decamelize@^4.0.0: resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-4.0.0.tgz#aa472d7bf660eb15f3494efd531cab7f2a709837" integrity sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ== -dedent@^0.7.0: - version "0.7.0" - resolved "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz#2495ddbaf6eb874abb0e1be9df22d2e5a544326c" - integrity sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA== - deep-eql@^4.1.3: version "4.1.3" resolved "https://registry.yarnpkg.com/deep-eql/-/deep-eql-4.1.3.tgz#7c7775513092f7df98d8df9996dd085eb668cc6d" @@ -2907,13 +2701,6 @@ default-require-extensions@^3.0.0: dependencies: strip-bom "^4.0.0" -defaults@^1.0.3: - version "1.0.4" - resolved "https://registry.yarnpkg.com/defaults/-/defaults-1.0.4.tgz#b0b02062c1e2aa62ff5d9528f0f98baa90978d7a" - integrity sha512-eFuaLoy/Rxalv2kr+lqMlUnrDWV+3j4pljOIJgLIhI058IQfWJ7vXhyEIHu+HtC738klGALYxOKDO0bQP3tg8A== - dependencies: - clone "^1.0.2" - define-data-property@^1.0.1, define-data-property@^1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/define-data-property/-/define-data-property-1.1.2.tgz#f3c33b4f0102360cd7c0f5f28700f5678510b63a" @@ -3002,21 +2789,11 @@ domutils@^3.0.1: domelementtype "^2.3.0" domhandler "^5.0.3" -dotenv-expand@^10.0.0: - version "10.0.0" - resolved "https://registry.yarnpkg.com/dotenv-expand/-/dotenv-expand-10.0.0.tgz#12605d00fb0af6d0a592e6558585784032e4ef37" - integrity sha512-GopVGCpVS1UKH75VKHGuQFqS1Gusej0z4FyQkPdwjil2gNIv+LNsqBlboOzpJFZKVT95GkCyWJbBSdFEFUWI2A== - dotenv@^10.0.0: version "10.0.0" resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-10.0.0.tgz#3d4227b8fb95f81096cdd2b66653fb2c7085ba81" integrity sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q== -dotenv@^16.3.1: - version "16.4.5" - resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-16.4.5.tgz#cdd3b3b604cb327e286b4762e13502f717cb099f" - integrity sha512-ZmdL2rui+eB2YwhsWzjInR8LldtZHGDoQ1ugH85ppHKwpUHL7j7rN0Ti9NCnGiQbhaZ11FpR+7ao1dNsmduNUg== - duplexer@^0.1.1, duplexer@~0.1.1: version "0.1.2" resolved "https://registry.yarnpkg.com/duplexer/-/duplexer-0.1.2.tgz#3abe43aef3835f8ae077d136ddce0f276b0400e6" @@ -3162,35 +2939,6 @@ es6-error@^4.0.1: resolved "https://registry.yarnpkg.com/es6-error/-/es6-error-4.1.1.tgz#9e3af407459deed47e9a91f9b885a84eb05c561d" integrity sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg== -esbuild@^0.19.0: - version "0.19.12" - resolved "https://registry.yarnpkg.com/esbuild/-/esbuild-0.19.12.tgz#dc82ee5dc79e82f5a5c3b4323a2a641827db3e04" - integrity sha512-aARqgq8roFBj054KvQr5f1sFu0D65G+miZRCuJyJ0G13Zwx7vRar5Zhn2tkQNzIXcBrNVsv/8stehpj+GAjgbg== - optionalDependencies: - "@esbuild/aix-ppc64" "0.19.12" - "@esbuild/android-arm" "0.19.12" - "@esbuild/android-arm64" "0.19.12" - "@esbuild/android-x64" "0.19.12" - "@esbuild/darwin-arm64" "0.19.12" - "@esbuild/darwin-x64" "0.19.12" - "@esbuild/freebsd-arm64" "0.19.12" - "@esbuild/freebsd-x64" "0.19.12" - "@esbuild/linux-arm" "0.19.12" - "@esbuild/linux-arm64" "0.19.12" - "@esbuild/linux-ia32" "0.19.12" - "@esbuild/linux-loong64" "0.19.12" - "@esbuild/linux-mips64el" "0.19.12" - "@esbuild/linux-ppc64" "0.19.12" - "@esbuild/linux-riscv64" "0.19.12" - "@esbuild/linux-s390x" "0.19.12" - "@esbuild/linux-x64" "0.19.12" - "@esbuild/netbsd-x64" "0.19.12" - "@esbuild/openbsd-x64" "0.19.12" - "@esbuild/sunos-x64" "0.19.12" - "@esbuild/win32-arm64" "0.19.12" - "@esbuild/win32-ia32" "0.19.12" - "@esbuild/win32-x64" "0.19.12" - escalade@^3.1.1: version "3.1.1" resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" @@ -3521,21 +3269,6 @@ evp_bytestokey@^1.0.3: md5.js "^1.3.4" safe-buffer "^5.1.1" -execa@^8.0.1: - version "8.0.1" - resolved "https://registry.yarnpkg.com/execa/-/execa-8.0.1.tgz#51f6a5943b580f963c3ca9c6321796db8cc39b8c" - integrity sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg== - dependencies: - cross-spawn "^7.0.3" - get-stream "^8.0.1" - human-signals "^5.0.0" - is-stream "^3.0.0" - merge-stream "^2.0.0" - npm-run-path "^5.1.0" - onetime "^6.0.0" - signal-exit "^4.1.0" - strip-final-newline "^3.0.0" - extract-zip@2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/extract-zip/-/extract-zip-2.0.1.tgz#663dca56fe46df890d5f131ef4a06d22bb8ba13a" @@ -3592,11 +3325,6 @@ fd-slicer@~1.1.0: dependencies: pend "~1.2.0" -fdir@^6.1.1: - version "6.4.2" - resolved "https://registry.yarnpkg.com/fdir/-/fdir-6.4.2.tgz#ddaa7ce1831b161bc3657bb99cb36e1622702689" - integrity sha512-KnhMXsKSPZlAhp7+IjUkRZKPb4fUyccpDrdFXbi4QL1qkmFh9kVY09Yox+n4MaOb3lHZ1Tv829C3oaaXoMYPDQ== - file-entry-cache@^6.0.1: version "6.0.1" resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz#211b2dd9659cb0394b073e7323ac3c933d522027" @@ -3662,14 +3390,6 @@ find-up@^4.0.0, find-up@^4.1.0: locate-path "^5.0.0" path-exists "^4.0.0" -find-up@^6.3.0: - version "6.3.0" - resolved "https://registry.yarnpkg.com/find-up/-/find-up-6.3.0.tgz#2abab3d3280b2dc7ac10199ef324c4e002c8c790" - integrity sha512-v2ZsoEuVHYy8ZIlYqwPe/39Cy+cFDzp4dXPaxNvkEuouymu+2Jbz0PxpKarJHYJTmv2HWT3O382qY8l4jMWthw== - dependencies: - locate-path "^7.1.0" - path-exists "^5.0.0" - find-yarn-workspace-root@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/find-yarn-workspace-root/-/find-yarn-workspace-root-2.0.0.tgz#f47fb8d239c900eb78179aa81b66673eac88f7bd" @@ -3765,15 +3485,6 @@ fs-extra@^0.30.0: path-is-absolute "^1.0.0" rimraf "^2.2.8" -fs-extra@^11.2.0: - version "11.2.0" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-11.2.0.tgz#e70e17dfad64232287d01929399e0ea7c86b0e5b" - integrity sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw== - dependencies: - graceful-fs "^4.2.0" - jsonfile "^6.0.1" - universalify "^2.0.0" - fs-extra@^7.0.0, fs-extra@^7.0.1: version "7.0.1" resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-7.0.1.tgz#4f189c44aa123b895f722804f55ea23eadc348e9" @@ -3881,11 +3592,6 @@ get-stream@^5.1.0: dependencies: pump "^3.0.0" -get-stream@^8.0.1: - version "8.0.1" - resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-8.0.1.tgz#def9dfd71742cd7754a7761ed43749a27d02eca2" - integrity sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA== - get-symbol-description@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/get-symbol-description/-/get-symbol-description-1.0.0.tgz#7fdb81c900101fbd564dd5f1a30af5aadc1e58d6" @@ -4162,11 +3868,6 @@ https-proxy-agent@5.0.1, https-proxy-agent@^5.0.0: agent-base "6" debug "4" -human-signals@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-5.0.0.tgz#42665a284f9ae0dade3ba41ebc37eb4b852f3a28" - integrity sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ== - iconv-lite@0.4.24: version "0.4.24" resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" @@ -4329,11 +4030,6 @@ is-hex-prefixed@1.0.0: resolved "https://registry.yarnpkg.com/is-hex-prefixed/-/is-hex-prefixed-1.0.0.tgz#7d8d37e6ad77e5d127148913c573e082d777f554" integrity sha512-WvtOiug1VFrE9v1Cydwm+FnXd3+w9GaeVUss5W4v/SLy3UW00vP+6iNF2SdnfiBoLy4bTqVdkftNGTUeOFVsbA== -is-interactive@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/is-interactive/-/is-interactive-2.0.0.tgz#40c57614593826da1100ade6059778d597f16e90" - integrity sha512-qP1vozQRI+BMOPcjFzrjXuQvdak2pHNUMZoeG2eRbiSqyvbEf/wQtEOTOX1guk6E3t36RkaqiSt8A/6YElNxLQ== - is-negative-zero@^2.0.2: version "2.0.2" resolved "https://registry.yarnpkg.com/is-negative-zero/-/is-negative-zero-2.0.2.tgz#7bf6f03a28003b8b3965de3ac26f664d765f3150" @@ -4376,11 +4072,6 @@ is-stream@^2.0.0: resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== -is-stream@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-3.0.0.tgz#e6bfd7aa6bef69f4f472ce9bb681e3e57b4319ac" - integrity sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA== - is-string@^1.0.5, is-string@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.7.tgz#0dd12bf2006f255bb58f695110eff7491eebc0fd" @@ -4412,11 +4103,6 @@ is-unicode-supported@^0.1.0: resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== -is-unicode-supported@^1.1.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-1.3.0.tgz#d824984b616c292a2e198207d4a609983842f714" - integrity sha512-43r2mRvz+8JRIKnWJ+3j8JtjRKZ6GmjzfaE/qiBJnikNnYv/6bagRJ1kUhNk8R5EX/GkobD+r+sfxCPJsiKBLQ== - is-weakref@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/is-weakref/-/is-weakref-1.0.2.tgz#9529f383a9338205e89765e0392efc2f100f06f2" @@ -4666,11 +4352,6 @@ levn@^0.4.1: prelude-ls "^1.2.1" type-check "~0.4.0" -load-tsconfig@^0.2.3: - version "0.2.5" - resolved "https://registry.yarnpkg.com/load-tsconfig/-/load-tsconfig-0.2.5.tgz#453b8cd8961bfb912dea77eb6c168fe8cca3d3a1" - integrity sha512-IXO6OCs9yg8tMKzfPZ1YmheJbZCiEsnBdcB03l0OcfK9prKnJb96siuHCr5Fl37/yo9DnKU+TLpxzTUspw9shg== - locate-path@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz#2b568b265eec944c6d9c0de9c3dbbbca0354cd8e" @@ -4693,13 +4374,6 @@ locate-path@^6.0.0: dependencies: p-locate "^5.0.0" -locate-path@^7.1.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-7.2.0.tgz#69cb1779bd90b35ab1e771e1f2f89a202c2a8a8a" - integrity sha512-gvVijfZvn7R+2qyPX8mAuKcFGDf6Nc61GdvGafQsHL0sBIxfKzA+usWn4GFC/bk+QdwPUD4kWFJLhElipq+0VA== - dependencies: - p-locate "^6.0.0" - lodash.camelcase@^4.3.0: version "4.3.0" resolved "https://registry.yarnpkg.com/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz#b28aa6288a2b9fc651035c7711f65ab6190331a6" @@ -4742,14 +4416,6 @@ log-symbols@4.1.0: chalk "^4.1.0" is-unicode-supported "^0.1.0" -log-symbols@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/log-symbols/-/log-symbols-5.1.0.tgz#a20e3b9a5f53fac6aeb8e2bb22c07cf2c8f16d93" - integrity sha512-l0x2DvrW294C9uDCoQe1VSU4gf529FkSZ6leBl4TiqZH/e+0R7hSfHQBNut2mNygDgHwvYHfFLn6Oxb3VWj2rA== - dependencies: - chalk "^5.0.0" - is-unicode-supported "^1.1.0" - loupe@^2.3.6: version "2.3.6" resolved "https://registry.yarnpkg.com/loupe/-/loupe-2.3.6.tgz#76e4af498103c532d1ecc9be102036a21f787b53" @@ -4828,11 +4494,6 @@ memorystream@^0.3.1: resolved "https://registry.yarnpkg.com/memorystream/-/memorystream-0.3.1.tgz#86d7090b30ce455d63fbae12dda51a47ddcaf9b2" integrity sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw== -merge-stream@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" - integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== - merge2@^1.3.0, merge2@^1.4.1: version "1.4.1" resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" @@ -4858,16 +4519,6 @@ mime-types@^2.1.12: dependencies: mime-db "1.52.0" -mimic-fn@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" - integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== - -mimic-fn@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-4.0.0.tgz#60a90550d5cb0b239cca65d893b1a53b29871ecc" - integrity sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw== - minimalistic-assert@^1.0.0, minimalistic-assert@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz#2e194de044626d4a10e7f7fbc00ce73e83e4d5c7" @@ -5081,13 +4732,6 @@ normalize-path@^3.0.0, normalize-path@~3.0.0: resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== -npm-run-path@^5.1.0: - version "5.3.0" - resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-5.3.0.tgz#e23353d0ebb9317f174e93417e4a4d82d0249e9f" - integrity sha512-ppwTtiJZq0O/ai0z7yfudtBpWIoxM8yE6nHi1X47eFR2EWORqfbu6CnPlNsjeN683eT0qG6H/Pyf9fCcvjnnnQ== - dependencies: - path-key "^4.0.0" - nth-check@^2.0.1: version "2.1.1" resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-2.1.1.tgz#c9eab428effce36cd6b92c924bdb000ef1f1ed1d" @@ -5160,20 +4804,6 @@ once@^1.3.0, once@^1.3.1, once@^1.4.0: dependencies: wrappy "1" -onetime@^5.1.0: - version "5.1.2" - resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" - integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== - dependencies: - mimic-fn "^2.1.0" - -onetime@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/onetime/-/onetime-6.0.0.tgz#7c24c18ed1fd2e9bca4bd26806a33613c77d34b4" - integrity sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ== - dependencies: - mimic-fn "^4.0.0" - open@^7.4.2: version "7.4.2" resolved "https://registry.yarnpkg.com/open/-/open-7.4.2.tgz#b8147e26dcf3e426316c730089fd71edd29c2321" @@ -5194,21 +4824,6 @@ optionator@^0.9.1: type-check "^0.4.0" word-wrap "^1.2.3" -ora@^6.3.1: - version "6.3.1" - resolved "https://registry.yarnpkg.com/ora/-/ora-6.3.1.tgz#a4e9e5c2cf5ee73c259e8b410273e706a2ad3ed6" - integrity sha512-ERAyNnZOfqM+Ao3RAvIXkYh5joP220yf59gVe2X/cI6SiCxIdi4c9HZKZD8R6q/RDXEje1THBju6iExiSsgJaQ== - dependencies: - chalk "^5.0.0" - cli-cursor "^4.0.0" - cli-spinners "^2.6.1" - is-interactive "^2.0.0" - is-unicode-supported "^1.1.0" - log-symbols "^5.1.0" - stdin-discarder "^0.1.0" - strip-ansi "^7.0.1" - wcwidth "^1.0.1" - os-tmpdir@~1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" @@ -5248,13 +4863,6 @@ p-limit@^3.0.2: dependencies: yocto-queue "^0.1.0" -p-limit@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-4.0.0.tgz#914af6544ed32bfa54670b061cafcbd04984b644" - integrity sha512-5b0R4txpzjPWVw/cXXUResoD4hb6U/x9BH08L7nw+GN1sezDzPdxeRvpc9c433fZhBan/wusjbCsqwqm4EIBIQ== - dependencies: - yocto-queue "^1.0.0" - p-locate@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43" @@ -5276,13 +4884,6 @@ p-locate@^5.0.0: dependencies: p-limit "^3.0.2" -p-locate@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-6.0.0.tgz#3da9a49d4934b901089dca3302fa65dc5a05c04f" - integrity sha512-wPrq66Llhl7/4AGC6I+cqxT07LhXvWL08LNXz1fENOw0Ap4sRZZ/gZpTTJ5jpurzzzfS2W/Ge9BY3LgLjCShcw== - dependencies: - p-limit "^4.0.0" - p-map@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/p-map/-/p-map-3.0.0.tgz#d704d9af8a2ba684e2600d9a215983d4141a979d" @@ -5369,11 +4970,6 @@ path-exists@^4.0.0: resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== -path-exists@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-5.0.0.tgz#a6aad9489200b21fab31e49cf09277e5116fb9e7" - integrity sha512-RjhtfwJOxzcFmNOi6ltcbcu4Iu+FL3zEj83dk4kAS+fVpTxXLO1b38RvJgT/0QwvV/L3aY9TAnyv0EOqW4GoMQ== - path-is-absolute@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" @@ -5389,11 +4985,6 @@ path-key@^3.1.0: resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== -path-key@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/path-key/-/path-key-4.0.0.tgz#295588dc3aee64154f877adb9d780b81c554bf18" - integrity sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ== - path-parse@^1.0.6, path-parse@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" @@ -5404,11 +4995,6 @@ path-type@^4.0.0: resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== -pathe@^1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/pathe/-/pathe-1.1.2.tgz#6c4cb47a945692e48a1ddd6e4094d170516437ec" - integrity sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ== - pathval@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/pathval/-/pathval-1.1.1.tgz#8534e77a77ce7ac5a2512ea21e0fdb8fcf6c3d8d" @@ -5447,11 +5033,6 @@ picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1: resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== -picomatch@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-3.0.1.tgz#817033161def55ec9638567a2f3bbc876b3e7516" - integrity sha512-I3EurrIQMlRc9IaAZnqRR044Phh2DXY+55o7uJ0V+hYZAcQYSuFWsc9q5PvyDHUSCe1Qxn/iBz+78s86zWnGag== - pkg-dir@4.2.0, pkg-dir@^4.1.0: version "4.2.0" resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" @@ -5493,11 +5074,6 @@ prettier@^2.1.2, prettier@^2.3.2: resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.6.2.tgz#e26d71a18a74c3d0f0597f55f01fb6c06c206032" integrity sha512-PkUpF+qoXTqhOeWL9fu7As8LXsIUZ1WYaJiY/a7McAQzxjk82OF0tibkFXVCDImZtWxbvojFjerkiLb0/q8mew== -prettier@^3.0.3: - version "3.3.3" - resolved "https://registry.yarnpkg.com/prettier/-/prettier-3.3.3.tgz#30c54fe0be0d8d12e6ae61dbb10109ea00d53105" - integrity sha512-i2tDNA0O5IrMO757lfrdQZCc2jPNDVntV0m/+4whiDfWaTKfMNgR7Qz0NAeGz/nRqF4m5/6CLzbP4/liHt12Ew== - process-on-spawn@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/process-on-spawn/-/process-on-spawn-1.0.0.tgz#95b05a23073d30a17acfdc92a440efd2baefdc93" @@ -5599,11 +5175,6 @@ readable-stream@^3.1.1, readable-stream@^3.4.0, readable-stream@^3.6.0: string_decoder "^1.1.1" util-deprecate "^1.0.1" -readdirp@^4.0.1: - version "4.0.2" - resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-4.0.2.tgz#388fccb8b75665da3abffe2d8f8ed59fe74c230a" - integrity sha512-yDMz9g+VaZkqBYS/ozoBJwaBhTbZo3UNYQHNRw1D3UFQB8oHB4uS/tAODO+ZLjGWmUbKnIlOWO+aaIiAxrUWHA== - readdirp@~3.6.0: version "3.6.0" resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" @@ -5683,14 +5254,6 @@ resolve@^1.3.2: path-parse "^1.0.7" supports-preserve-symlinks-flag "^1.0.0" -restore-cursor@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-4.0.0.tgz#519560a4318975096def6e609d44100edaa4ccb9" - integrity sha512-I9fPXU9geO9bHOt9pHHOhOkYerIMsmVaWB0rA2AI9ERh/+x/i7MV5HKBNrg+ljO5eoPVgCcnFuRjJ9uH6I/3eg== - dependencies: - onetime "^5.1.0" - signal-exit "^3.0.2" - retry@^0.12.0: version "0.12.0" resolved "https://registry.yarnpkg.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" @@ -5904,11 +5467,6 @@ signal-exit@^3.0.2: resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== -signal-exit@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-4.1.0.tgz#952188c1cbd546070e2dd20d0f41c0ae0530cb04" - integrity sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw== - sisteransi@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed" @@ -6024,13 +5582,6 @@ statuses@2.0.1: resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== -stdin-discarder@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/stdin-discarder/-/stdin-discarder-0.1.0.tgz#22b3e400393a8e28ebf53f9958f3880622efde21" - integrity sha512-xhV7w8S+bUwlPTb4bAOUQhv8/cSS5offJuX8GQGq32ONF0ZtDWKfkdomM3HMRA+LhX6um/FZ0COqlwsjD53LeQ== - dependencies: - bl "^5.0.0" - stream-combiner@^0.2.2: version "0.2.2" resolved "https://registry.yarnpkg.com/stream-combiner/-/stream-combiner-0.2.2.tgz#aec8cbac177b56b6f4fa479ced8c1912cee52858" @@ -6094,23 +5645,11 @@ strip-ansi@^6.0.0, strip-ansi@^6.0.1: dependencies: ansi-regex "^5.0.1" -strip-ansi@^7.0.1: - version "7.1.0" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-7.1.0.tgz#d5b6568ca689d8561370b0707685d22434faff45" - integrity sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ== - dependencies: - ansi-regex "^6.0.1" - strip-bom@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-4.0.0.tgz#9c3505c1db45bcedca3d9cf7a16f5c5aa3901878" integrity sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w== -strip-final-newline@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-3.0.0.tgz#52894c313fbff318835280aed60ff71ebf12b8fd" - integrity sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw== - strip-hex-prefix@1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/strip-hex-prefix/-/strip-hex-prefix-1.0.0.tgz#0c5f155fef1151373377de9dbb588da05500e36f" @@ -6534,7 +6073,7 @@ v8-compile-cache@^2.0.3: resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz#2de19618c66dc247dcfb6f99338035d8245a2cee" integrity sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA== -viem@2.x, viem@^2.21.45: +viem@^2.21.45: version "2.21.45" resolved "https://registry.yarnpkg.com/viem/-/viem-2.21.45.tgz#7a445428d4909cc334f231ee916ede1b69190603" integrity sha512-I+On/IiaObQdhDKWU5Rurh6nf3G7reVkAODG5ECIfjsrGQ3EPJnxirUPT4FNV6bWER5iphoG62/TidwuTSOA1A== @@ -6549,13 +6088,6 @@ viem@2.x, viem@^2.21.45: webauthn-p256 "0.0.10" ws "8.18.0" -wcwidth@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/wcwidth/-/wcwidth-1.0.1.tgz#f0b0dcf915bc5ff1528afadb2c0e17b532da2fe8" - integrity sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg== - dependencies: - defaults "^1.0.3" - webauthn-p256@0.0.10: version "0.0.10" resolved "https://registry.yarnpkg.com/webauthn-p256/-/webauthn-p256-0.0.10.tgz#877e75abe8348d3e14485932968edf3325fd2fdd" @@ -6820,13 +6352,3 @@ yocto-queue@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== - -yocto-queue@^1.0.0: - version "1.1.1" - resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-1.1.1.tgz#fef65ce3ac9f8a32ceac5a634f74e17e5b232110" - integrity sha512-b4JR1PFR10y1mKjhHY9LaGo6tmrgjit7hxVIeAmyMw3jegXR4dhYqLaQF5zMXZxY7tLpMyJeLjr1C4rLmkVe8g== - -zod@^3.22.2: - version "3.23.8" - resolved "https://registry.yarnpkg.com/zod/-/zod-3.23.8.tgz#e37b957b5d52079769fb8097099b592f0ef4067d" - integrity sha512-XBx9AXhXktjUqnepgTiE5flcKIYWi/rme0Eaj+5Y0lftuGBq+jyRu/md4WnuxqgP1ubdpNCsYEYPxrzVHD8d6g== From d34d0663925e5ffbeeb2628b8437c0396e4271df Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Tue, 19 Nov 2024 16:04:42 -0500 Subject: [PATCH 07/19] fix linting --- scripts/testSetup.ts | 6 +++--- src/experimental/actions.ts | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/scripts/testSetup.ts b/scripts/testSetup.ts index 64cc762383..6a827c8ffa 100644 --- a/scripts/testSetup.ts +++ b/scripts/testSetup.ts @@ -194,6 +194,6 @@ function generateViemChain( rpcUrls: { default: { http: [rpcUrl] }, public: { http: [rpcUrl] }, - } - } as const satisfies Chain -} \ No newline at end of file + }, + } as const +} diff --git a/src/experimental/actions.ts b/src/experimental/actions.ts index 514e9fb709..24687d8c09 100644 --- a/src/experimental/actions.ts +++ b/src/experimental/actions.ts @@ -1,5 +1,5 @@ import { BigNumber } from 'ethers' -import { Account, Address, Chain, PublicClient, TransactionRequest } from 'viem' +import { Account, Address, PublicClient, TransactionRequest } from 'viem' import { EthBridger } from '../lib/assetBridger/ethBridger' import { transformPublicClientToProvider } from './transformViemToEthers' From 6e0a966b6e53cb940ea97828a0f55559dd326857 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Tue, 19 Nov 2024 16:37:07 -0500 Subject: [PATCH 08/19] fix build failure --- package.json | 4 ++-- tsconfig.json | 3 ++- yarn.lock | 10 +++++----- 3 files changed, 9 insertions(+), 8 deletions(-) diff --git a/package.json b/package.json index 094e161a84..b268069f28 100644 --- a/package.json +++ b/package.json @@ -51,7 +51,7 @@ "@ethersproject/bytes": "^5.0.8", "async-mutex": "^0.4.0", "ethers": "^5.1.0", - "viem": "^2.21.45" + "viem": "^2.21.48" }, "devDependencies": { "@arbitrum/nitro-contracts": "^1.1.1", @@ -85,7 +85,7 @@ "ts-node": "^10.2.1", "tslint": "^6.1.3", "typechain": "7.0.0", - "typescript": "^5.5.4", + "typescript": "^5.6.3", "yargs": "^17.3.1" }, "files": [ diff --git a/tsconfig.json b/tsconfig.json index 8fba0a8926..0cff0f779c 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -14,7 +14,8 @@ "noImplicitThis": true, "resolveJsonModule": true, "esModuleInterop": true, - "experimentalDecorators": true + "experimentalDecorators": true, + "skipLibCheck": true }, "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.js"] } diff --git a/yarn.lock b/yarn.lock index 80b50295d6..21d707f73f 100644 --- a/yarn.lock +++ b/yarn.lock @@ -5978,7 +5978,7 @@ typedarray-to-buffer@^3.1.5: dependencies: is-typedarray "^1.0.0" -typescript@^5.5.4: +typescript@^5.6.3: version "5.6.3" resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.6.3.tgz#5f3449e31c9d94febb17de03cc081dd56d81db5b" integrity sha512-hjcS1mhfuyi4WW8IWtjP7brDrG2cuDZukyrYrSauoXGNgx0S7zceP07adYkJycEr56BOUTNPzbInooiN3fn1qw== @@ -6073,10 +6073,10 @@ v8-compile-cache@^2.0.3: resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz#2de19618c66dc247dcfb6f99338035d8245a2cee" integrity sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA== -viem@^2.21.45: - version "2.21.45" - resolved "https://registry.yarnpkg.com/viem/-/viem-2.21.45.tgz#7a445428d4909cc334f231ee916ede1b69190603" - integrity sha512-I+On/IiaObQdhDKWU5Rurh6nf3G7reVkAODG5ECIfjsrGQ3EPJnxirUPT4FNV6bWER5iphoG62/TidwuTSOA1A== +viem@^2.21.48: + version "2.21.48" + resolved "https://registry.yarnpkg.com/viem/-/viem-2.21.48.tgz#f8f1d0bf5381282e22e6a1f8b72ebd6e64426480" + integrity sha512-/hBHyG1gdIIuiQv0z9YmzXl5eWJa0UCZGwkeuQzH2Bmg6FIEwZeEcxgiytXZydip+p2wMBFa1jdr7o5O1+mrIg== dependencies: "@noble/curves" "1.6.0" "@noble/hashes" "1.5.0" From 71c0b475ff4f857a3d0c6a925b6917b48c81e752 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Wed, 20 Nov 2024 11:25:30 -0500 Subject: [PATCH 09/19] increase funding for parent to accomodate depsoits --- tests/integration/arbitrumDepositActions.test.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index da05622a6b..ee5a758e30 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -3,6 +3,7 @@ import { createWalletClient, http, parseEther, type Chain } from 'viem' import { privateKeyToAccount } from 'viem/accounts' import { config, testSetup } from '../../scripts/testSetup' import { createArbitrumClient } from '../../src/experimental/createArbitrumClient' +import { fundParentSigner } from './testHelpers' describe('arbitrumDepositActions', function () { let localEthChain: Chain @@ -12,6 +13,7 @@ describe('arbitrumDepositActions', function () { const setup = await testSetup() localEthChain = setup.localEthChain localArbChain = setup.localArbChain + await fundParentSigner(setup.parentSigner) }) it('deposits ETH from parent to child', async function () { From b6d72e94746a395650958b981e5d47500d16a44a Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Wed, 20 Nov 2024 15:31:31 -0500 Subject: [PATCH 10/19] fund/approve custom fee token --- tests/integration/arbitrumDepositActions.test.ts | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index ee5a758e30..e10983dc72 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -4,6 +4,11 @@ import { privateKeyToAccount } from 'viem/accounts' import { config, testSetup } from '../../scripts/testSetup' import { createArbitrumClient } from '../../src/experimental/createArbitrumClient' import { fundParentSigner } from './testHelpers' +import { + approveParentCustomFeeToken, + fundParentCustomFeeToken, + isArbitrumNetworkWithCustomFeeToken, +} from './custom-fee-token/customFeeTokenTestHelpers' describe('arbitrumDepositActions', function () { let localEthChain: Chain @@ -14,6 +19,10 @@ describe('arbitrumDepositActions', function () { localEthChain = setup.localEthChain localArbChain = setup.localArbChain await fundParentSigner(setup.parentSigner) + if (isArbitrumNetworkWithCustomFeeToken()) { + await fundParentCustomFeeToken(setup.parentSigner) + await approveParentCustomFeeToken(setup.parentSigner) + } }) it('deposits ETH from parent to child', async function () { From d9f2e9244b0fc067da8bc02f9a0bca954e8807e5 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Thu, 21 Nov 2024 17:10:29 -0500 Subject: [PATCH 11/19] implements walletclient method to wait for tx --- src/experimental/actions.ts | 124 +++++++++++++----- src/experimental/createArbitrumClient.ts | 27 +++- src/experimental/transformViemToEthers.ts | 53 +++++++- .../arbitrumDepositActions.test.ts | 122 ++++------------- 4 files changed, 192 insertions(+), 134 deletions(-) diff --git a/src/experimental/actions.ts b/src/experimental/actions.ts index 24687d8c09..6a2a74e893 100644 --- a/src/experimental/actions.ts +++ b/src/experimental/actions.ts @@ -1,27 +1,48 @@ import { BigNumber } from 'ethers' -import { Account, Address, PublicClient, TransactionRequest } from 'viem' +import { + Account, + Address, + Hash, + PublicClient, + TransactionRequest, + WalletClient, +} from 'viem' import { EthBridger } from '../lib/assetBridger/ethBridger' -import { transformPublicClientToProvider } from './transformViemToEthers' +import { + transformPublicClientToProvider, + viemTransactionReceiptToEthersTransactionReceipt, +} from './transformViemToEthers' +import { ParentTransactionReceipt } from '../lib/message/ParentTransaction' +import { ParentToChildMessageStatus } from '../lib/message/ParentToChildMessage' export type PrepareDepositEthParameters = { amount: bigint account: Account | Address } -export type PrepareDepositEthToParameters = { - amount: bigint - account: Address - destinationAddress: Address - parentPublicClient: PublicClient +export type WaitForCrossChainTxParameters = { + hash: Hash + timeout?: number + confirmations?: number +} + +export type CrossChainTransactionStatus = { + status: 'success' | 'failed' + complete: boolean + message?: unknown + childTxReceipt?: unknown } export type ArbitrumDepositActions = { prepareDepositEthTransaction: ( params: PrepareDepositEthParameters ) => Promise - prepareDepositEthToTransaction: ( - params: PrepareDepositEthToParameters - ) => Promise +} + +export type ArbitrumParentWalletActions = { + waitForCrossChainTransaction: ( + params: WaitForCrossChainTxParameters + ) => Promise } async function prepareDepositEthTransaction( @@ -42,39 +63,74 @@ async function prepareDepositEthTransaction( } } -async function prepareDepositEthToTransaction( - client: PublicClient, - { - amount, - account, - destinationAddress, - parentPublicClient, - }: PrepareDepositEthToParameters -): Promise { - const childProvider = transformPublicClientToProvider(client) - const parentProvider = transformPublicClientToProvider(parentPublicClient) - const ethBridger = await EthBridger.fromProvider(childProvider) +async function waitForCrossChainTransaction( + parentClient: PublicClient, + childClient: PublicClient, + { hash, timeout, confirmations }: WaitForCrossChainTxParameters +): Promise { + const childProvider = transformPublicClientToProvider(childClient) - const request = await ethBridger.getDepositToRequest({ - amount: BigNumber.from(amount), - destinationAddress, - from: account, - parentProvider, - childProvider, + // Wait for the transaction to be mined and get the receipt + const viemReceipt = await parentClient.waitForTransactionReceipt({ + hash, + confirmations, }) - return { - to: request.txRequest.to as `0x${string}`, - value: BigNumber.from(request.txRequest.value).toBigInt(), - data: request.txRequest.data as `0x${string}`, + const ethersReceipt = + viemTransactionReceiptToEthersTransactionReceipt(viemReceipt) + const parentReceipt = new ParentTransactionReceipt(ethersReceipt) + + // Try to get eth deposits first + try { + const ethDeposits = await parentReceipt.getEthDeposits(childProvider) + if (ethDeposits.length > 0) { + const result = await ethDeposits[0].wait(confirmations, timeout) + return { + status: result ? 'success' : 'failed', + complete: Boolean(result), + message: ethDeposits[0], + childTxReceipt: result, + } + } + } catch (e) { + // Not an eth deposit, continue to check for other message types + } + + // Check for other cross chain messages + try { + const messages = await parentReceipt.getParentToChildMessages(childProvider) + if (messages.length > 0) { + const result = await messages[0].waitForStatus(confirmations, timeout) + return { + status: + result.status === ParentToChildMessageStatus.REDEEMED + ? 'success' + : 'failed', + complete: result.status === ParentToChildMessageStatus.REDEEMED, + message: messages[0], + childTxReceipt: result, + } + } + } catch (e) { + // Not a cross chain message } + + throw new Error('No cross chain message found in transaction') } export function arbitrumDepositActions() { return (client: PublicClient): ArbitrumDepositActions => ({ prepareDepositEthTransaction: params => prepareDepositEthTransaction(client, params), - prepareDepositEthToTransaction: params => - prepareDepositEthToTransaction(client, params), + }) +} + +export function arbitrumParentWalletActions( + parentClient: PublicClient, + childClient: PublicClient +) { + return (walletClient: WalletClient): ArbitrumParentWalletActions => ({ + waitForCrossChainTransaction: (params: WaitForCrossChainTxParameters) => + waitForCrossChainTransaction(parentClient, childClient, params), }) } diff --git a/src/experimental/createArbitrumClient.ts b/src/experimental/createArbitrumClient.ts index 98e972d54a..3b4101d970 100644 --- a/src/experimental/createArbitrumClient.ts +++ b/src/experimental/createArbitrumClient.ts @@ -1,9 +1,22 @@ -import { Chain, PublicClient, createPublicClient, http } from 'viem' -import { arbitrumDepositActions, ArbitrumDepositActions } from './actions' +import { + Chain, + PublicClient, + WalletClient, + createPublicClient, + http, +} from 'viem' +import { + ArbitrumDepositActions, + ArbitrumParentWalletActions, + arbitrumDepositActions, + arbitrumParentWalletActions, +} from './actions' export type ArbitrumClients = { parentPublicClient: PublicClient childPublicClient: PublicClient & ArbitrumDepositActions + parentWalletClient: WalletClient & ArbitrumParentWalletActions + childWalletClient: WalletClient } export type CreateArbitrumClientParams = { @@ -11,6 +24,8 @@ export type CreateArbitrumClientParams = { childChain: Chain parentRpcUrl?: string childRpcUrl?: string + parentWalletClient: WalletClient + childWalletClient: WalletClient } export function createArbitrumClient({ @@ -18,6 +33,8 @@ export function createArbitrumClient({ childChain, parentRpcUrl, childRpcUrl, + parentWalletClient, + childWalletClient, }: CreateArbitrumClientParams): ArbitrumClients { const parentPublicClient = createPublicClient({ chain: parentChain, @@ -29,8 +46,14 @@ export function createArbitrumClient({ transport: http(childRpcUrl || childChain.rpcUrls.default.http[0]), }).extend(arbitrumDepositActions()) + const extendedParentWalletClient = parentWalletClient.extend( + arbitrumParentWalletActions(parentPublicClient, childPublicClient) + ) + return { parentPublicClient, childPublicClient, + parentWalletClient: extendedParentWalletClient, + childWalletClient, } } diff --git a/src/experimental/transformViemToEthers.ts b/src/experimental/transformViemToEthers.ts index 73d63d875f..9acee96d49 100644 --- a/src/experimental/transformViemToEthers.ts +++ b/src/experimental/transformViemToEthers.ts @@ -1,5 +1,17 @@ +import { + Log as EthersLog, + TransactionReceipt as EthersTransactionReceipt, +} from '@ethersproject/abstract-provider' import { StaticJsonRpcProvider } from '@ethersproject/providers' -import { Chain, Client, PublicClient, Transport } from 'viem' +import { BigNumber } from 'ethers' +import { + Chain, + Client, + PublicClient, + Transport, + Log as ViemLog, + TransactionReceipt as ViemTransactionReceipt, +} from 'viem' // based on https://wagmi.sh/react/ethers-adapters#reference-implementation export function publicClientToProvider( @@ -42,3 +54,42 @@ export const transformPublicClientToProvider = ( } throw new Error('Invalid provider') } + +function viemLogToEthersLog(log: ViemLog): EthersLog { + return { + blockNumber: Number(log.blockNumber), + blockHash: log.blockHash!, + transactionIndex: log.transactionIndex!, + removed: log.removed, + address: log.address, + data: log.data, + topics: log.topics, + transactionHash: log.transactionHash!, + logIndex: log.logIndex!, + } +} + +export function viemTransactionReceiptToEthersTransactionReceipt( + receipt: ViemTransactionReceipt +): EthersTransactionReceipt { + return { + to: receipt.to!, + from: receipt.from!, + contractAddress: receipt.contractAddress!, + transactionIndex: receipt.transactionIndex, + gasUsed: BigNumber.from(receipt.gasUsed), + logsBloom: receipt.logsBloom, + blockHash: receipt.blockHash, + transactionHash: receipt.transactionHash, + logs: receipt.logs.map(log => viemLogToEthersLog(log)), + blockNumber: Number(receipt.blockNumber), + // todo: if we need this we can add it later + confirmations: -1, + cumulativeGasUsed: BigNumber.from(receipt.cumulativeGasUsed), + effectiveGasPrice: BigNumber.from(receipt.effectiveGasPrice), + // all transactions that we care about are well past byzantium + byzantium: true, + type: Number(receipt.type), + status: receipt.status === 'success' ? 1 : 0, + } +} diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index e10983dc72..e21412fa26 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -18,6 +18,7 @@ describe('arbitrumDepositActions', function () { const setup = await testSetup() localEthChain = setup.localEthChain localArbChain = setup.localArbChain + await fundParentSigner(setup.parentSigner) if (isArbitrumNetworkWithCustomFeeToken()) { await fundParentCustomFeeToken(setup.parentSigner) @@ -25,129 +26,56 @@ describe('arbitrumDepositActions', function () { } }) - it('deposits ETH from parent to child', async function () { - const account = privateKeyToAccount(`0x${config.ethKey}` as `0x${string}`) + it('deposits ETH from parent to child and waits for completion', async function () { + const parentAccount = privateKeyToAccount( + `0x${config.ethKey}` as `0x${string}` + ) const depositAmount = parseEther('0.01') - const parentWalletClient = createWalletClient({ - account, + const baseParentWalletClient = createWalletClient({ + account: parentAccount, chain: localEthChain, transport: http(config.ethUrl), }) - const { parentPublicClient, childPublicClient } = createArbitrumClient({ - parentChain: localEthChain, - childChain: localArbChain, - parentRpcUrl: config.ethUrl, - childRpcUrl: config.arbUrl, - }) - - const initialBalance = await childPublicClient.getBalance({ - address: account.address, - }) - - const request = await childPublicClient.prepareDepositEthTransaction({ - amount: depositAmount, - account, - }) - - const hash = await parentWalletClient.sendTransaction({ - ...request, - chain: localEthChain, - account, - kzg: undefined, - } as const) - - const receipt = await parentPublicClient.waitForTransactionReceipt({ - hash, - }) - - expect(receipt.status).to.equal('success') - - let finalBalance = initialBalance - let attempts = 0 - const maxAttempts = 12 - - while (attempts < maxAttempts) { - await new Promise(resolve => setTimeout(resolve, 1500)) - - const currentBalance = await childPublicClient.getBalance({ - address: account.address, - }) - - if (currentBalance > initialBalance) { - finalBalance = currentBalance - break - } - - attempts++ - } - - const balanceDiff = finalBalance - initialBalance - expect(balanceDiff).to.equal(depositAmount) - }) - - it('deposits ETH from parent to a different child address', async function () { - const account = privateKeyToAccount(`0x${config.ethKey}` as `0x${string}`) - const destinationAddress = - '0x1234567890123456789012345678901234567890' as `0x${string}` - const depositAmount = parseEther('0.01') - - const parentWalletClient = createWalletClient({ - account, - chain: localEthChain, - transport: http(config.ethUrl), + const baseChildWalletClient = createWalletClient({ + account: parentAccount, + chain: localArbChain, + transport: http(config.arbUrl), }) - const { parentPublicClient, childPublicClient } = createArbitrumClient({ + const { childPublicClient, parentWalletClient } = createArbitrumClient({ parentChain: localEthChain, childChain: localArbChain, - parentRpcUrl: config.ethUrl, - childRpcUrl: config.arbUrl, + parentWalletClient: baseParentWalletClient, + childWalletClient: baseChildWalletClient, }) const initialBalance = await childPublicClient.getBalance({ - address: destinationAddress, + address: parentAccount.address, }) - const request = await childPublicClient.prepareDepositEthToTransaction({ + const request = await childPublicClient.prepareDepositEthTransaction({ amount: depositAmount, - account: account.address, - destinationAddress, - parentPublicClient, + account: parentAccount, }) const hash = await parentWalletClient.sendTransaction({ ...request, chain: localEthChain, - account, - kzg: undefined, - } as const) + account: parentAccount, + }) - const receipt = await parentPublicClient.waitForTransactionReceipt({ + const result = await parentWalletClient.waitForCrossChainTransaction({ hash, }) - expect(receipt.status).to.equal('success') - - let finalBalance = initialBalance - let attempts = 0 - const maxAttempts = 12 + expect(result.status).to.equal('success') + expect(result.complete).to.be.true - while (attempts < maxAttempts) { - await new Promise(resolve => setTimeout(resolve, 1500)) - - const currentBalance = await childPublicClient.getBalance({ - address: destinationAddress, - }) - - if (currentBalance > initialBalance) { - finalBalance = currentBalance - break - } - - attempts++ - } + const finalBalance = await childPublicClient.getBalance({ + address: parentAccount.address, + }) const balanceDiff = finalBalance - initialBalance expect(balanceDiff).to.equal(depositAmount) From bdd936ba40687357253f6c72f55bf0a3c31072fb Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Fri, 22 Nov 2024 10:05:17 -0500 Subject: [PATCH 12/19] adds depositEth and sendCrossChainTx --- src/experimental/actions.ts | 91 ++++++++++++++++++- src/experimental/createArbitrumClient.ts | 4 +- .../arbitrumDepositActions.test.ts | 54 +++++++---- 3 files changed, 128 insertions(+), 21 deletions(-) diff --git a/src/experimental/actions.ts b/src/experimental/actions.ts index 6a2a74e893..c4f6364cd9 100644 --- a/src/experimental/actions.ts +++ b/src/experimental/actions.ts @@ -20,17 +20,34 @@ export type PrepareDepositEthParameters = { account: Account | Address } +const DEFAULT_CONFIRMATIONS = 1 +const DEFAULT_TIMEOUT = 1000 * 60 * 5 // 5 minutes + export type WaitForCrossChainTxParameters = { hash: Hash timeout?: number confirmations?: number } +export type SendCrossChainTransactionParameters = { + request: TransactionRequest + timeout?: number + confirmations?: number +} + export type CrossChainTransactionStatus = { status: 'success' | 'failed' complete: boolean message?: unknown childTxReceipt?: unknown + hash: Hash +} + +export type DepositEthParameters = { + amount: bigint + account: Account | Address + confirmations?: number + timeout?: number } export type ArbitrumDepositActions = { @@ -43,6 +60,14 @@ export type ArbitrumParentWalletActions = { waitForCrossChainTransaction: ( params: WaitForCrossChainTxParameters ) => Promise + + sendCrossChainTransaction: ( + params: SendCrossChainTransactionParameters + ) => Promise + + depositEth: ( + params: DepositEthParameters + ) => Promise } async function prepareDepositEthTransaction( @@ -66,11 +91,14 @@ async function prepareDepositEthTransaction( async function waitForCrossChainTransaction( parentClient: PublicClient, childClient: PublicClient, - { hash, timeout, confirmations }: WaitForCrossChainTxParameters + { + hash, + confirmations = DEFAULT_CONFIRMATIONS, + timeout = DEFAULT_TIMEOUT, + }: WaitForCrossChainTxParameters ): Promise { const childProvider = transformPublicClientToProvider(childClient) - // Wait for the transaction to be mined and get the receipt const viemReceipt = await parentClient.waitForTransactionReceipt({ hash, confirmations, @@ -90,6 +118,7 @@ async function waitForCrossChainTransaction( complete: Boolean(result), message: ethDeposits[0], childTxReceipt: result, + hash, } } } catch (e) { @@ -109,6 +138,7 @@ async function waitForCrossChainTransaction( complete: result.status === ParentToChildMessageStatus.REDEEMED, message: messages[0], childTxReceipt: result, + hash, } } } catch (e) { @@ -118,7 +148,53 @@ async function waitForCrossChainTransaction( throw new Error('No cross chain message found in transaction') } -export function arbitrumDepositActions() { +async function sendCrossChainTransaction( + parentClient: PublicClient, + childClient: PublicClient, + walletClient: WalletClient, + { + request, + confirmations = DEFAULT_CONFIRMATIONS, + timeout = DEFAULT_TIMEOUT, + }: SendCrossChainTransactionParameters +): Promise { + const hash = await walletClient.sendTransaction({ + ...request, + chain: walletClient.chain, + account: walletClient.account as Account, + }) + + return waitForCrossChainTransaction(parentClient, childClient, { + hash, + confirmations, + timeout, + }) +} + +async function depositEth( + parentClient: PublicClient, + childClient: PublicClient, + walletClient: WalletClient, + { + amount, + account, + confirmations = DEFAULT_CONFIRMATIONS, + timeout = DEFAULT_TIMEOUT, + }: DepositEthParameters +): Promise { + const request = await prepareDepositEthTransaction(childClient, { + amount, + account, + }) + + return sendCrossChainTransaction(parentClient, childClient, walletClient, { + request, + confirmations, + timeout, + }) +} + +export function arbitrumParentClientActions() { return (client: PublicClient): ArbitrumDepositActions => ({ prepareDepositEthTransaction: params => prepareDepositEthTransaction(client, params), @@ -132,5 +208,14 @@ export function arbitrumParentWalletActions( return (walletClient: WalletClient): ArbitrumParentWalletActions => ({ waitForCrossChainTransaction: (params: WaitForCrossChainTxParameters) => waitForCrossChainTransaction(parentClient, childClient, params), + sendCrossChainTransaction: (params: SendCrossChainTransactionParameters) => + sendCrossChainTransaction( + parentClient, + childClient, + walletClient, + params + ), + depositEth: (params: DepositEthParameters) => + depositEth(parentClient, childClient, walletClient, params), }) } diff --git a/src/experimental/createArbitrumClient.ts b/src/experimental/createArbitrumClient.ts index 3b4101d970..5138f88f87 100644 --- a/src/experimental/createArbitrumClient.ts +++ b/src/experimental/createArbitrumClient.ts @@ -8,7 +8,7 @@ import { import { ArbitrumDepositActions, ArbitrumParentWalletActions, - arbitrumDepositActions, + arbitrumParentClientActions, arbitrumParentWalletActions, } from './actions' @@ -44,7 +44,7 @@ export function createArbitrumClient({ const childPublicClient = createPublicClient({ chain: childChain, transport: http(childRpcUrl || childChain.rpcUrls.default.http[0]), - }).extend(arbitrumDepositActions()) + }).extend(arbitrumParentClientActions()) const extendedParentWalletClient = parentWalletClient.extend( arbitrumParentWalletActions(parentPublicClient, childPublicClient) diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index e21412fa26..98125432da 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -26,10 +26,8 @@ describe('arbitrumDepositActions', function () { } }) - it('deposits ETH from parent to child and waits for completion', async function () { - const parentAccount = privateKeyToAccount( - `0x${config.ethKey}` as `0x${string}` - ) + it('deposits ETH from parent to child using deposit action', async function () { + const parentAccount = privateKeyToAccount(`0x${config.ethKey}`) const depositAmount = parseEther('0.01') const baseParentWalletClient = createWalletClient({ @@ -55,23 +53,12 @@ describe('arbitrumDepositActions', function () { address: parentAccount.address, }) - const request = await childPublicClient.prepareDepositEthTransaction({ + const result = await parentWalletClient.depositEth({ amount: depositAmount, account: parentAccount, }) - const hash = await parentWalletClient.sendTransaction({ - ...request, - chain: localEthChain, - account: parentAccount, - }) - - const result = await parentWalletClient.waitForCrossChainTransaction({ - hash, - }) - expect(result.status).to.equal('success') - expect(result.complete).to.be.true const finalBalance = await childPublicClient.getBalance({ address: parentAccount.address, @@ -80,4 +67,39 @@ describe('arbitrumDepositActions', function () { const balanceDiff = finalBalance - initialBalance expect(balanceDiff).to.equal(depositAmount) }) + + it('handles deposit failure gracefully', async function () { + const parentAccount = privateKeyToAccount(`0x${config.ethKey}`) + // Use an amount too large to cause a failure + const depositAmount = parseEther('999999999') + + const baseParentWalletClient = createWalletClient({ + account: parentAccount, + chain: localEthChain, + transport: http(config.ethUrl), + }) + + const baseChildWalletClient = createWalletClient({ + account: parentAccount, + chain: localArbChain, + transport: http(config.arbUrl), + }) + + const { parentWalletClient } = createArbitrumClient({ + parentChain: localEthChain, + childChain: localArbChain, + parentWalletClient: baseParentWalletClient, + childWalletClient: baseChildWalletClient, + }) + + try { + await parentWalletClient.depositEth({ + amount: depositAmount, + account: parentAccount, + }) + expect.fail('Should have thrown an error') + } catch (error) { + expect(error).to.exist + } + }) }) From b78ae37d0f90356f48a240a80d1c6456d4b31b77 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Mon, 25 Nov 2024 09:52:56 -0500 Subject: [PATCH 13/19] fix tests --- src/experimental/createArbitrumClient.ts | 4 ++-- tests/integration/arbitrumDepositActions.test.ts | 5 ++++- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/experimental/createArbitrumClient.ts b/src/experimental/createArbitrumClient.ts index 5138f88f87..eb30876ed1 100644 --- a/src/experimental/createArbitrumClient.ts +++ b/src/experimental/createArbitrumClient.ts @@ -16,7 +16,7 @@ export type ArbitrumClients = { parentPublicClient: PublicClient childPublicClient: PublicClient & ArbitrumDepositActions parentWalletClient: WalletClient & ArbitrumParentWalletActions - childWalletClient: WalletClient + childWalletClient?: WalletClient } export type CreateArbitrumClientParams = { @@ -25,7 +25,7 @@ export type CreateArbitrumClientParams = { parentRpcUrl?: string childRpcUrl?: string parentWalletClient: WalletClient - childWalletClient: WalletClient + childWalletClient?: WalletClient } export function createArbitrumClient({ diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index 98125432da..fd5c72929f 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -13,12 +13,15 @@ import { describe('arbitrumDepositActions', function () { let localEthChain: Chain let localArbChain: Chain + let setup: Awaited> before(async function () { - const setup = await testSetup() + setup = await testSetup() localEthChain = setup.localEthChain localArbChain = setup.localArbChain + }) + beforeEach(async function () { await fundParentSigner(setup.parentSigner) if (isArbitrumNetworkWithCustomFeeToken()) { await fundParentCustomFeeToken(setup.parentSigner) From 350f5f737dc2cd6f350c95420f03799e45153878 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Tue, 26 Nov 2024 16:49:59 -0500 Subject: [PATCH 14/19] fix custom fee handling --- .../arbitrumDepositActions.test.ts | 24 ++++++- .../customFeeTokenTestHelpers.ts | 62 +++++++++++++++++++ 2 files changed, 83 insertions(+), 3 deletions(-) diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index fd5c72929f..02ff310b07 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -8,9 +8,12 @@ import { approveParentCustomFeeToken, fundParentCustomFeeToken, isArbitrumNetworkWithCustomFeeToken, + getAmountInEnvironmentDecimals, + normalizeBalanceDiffByDecimals as normalizeBalanceDiffFByDecimals, + approveCustomFeeTokenWithViem, } from './custom-fee-token/customFeeTokenTestHelpers' -describe('arbitrumDepositActions', function () { +describe.only('arbitrumDepositActions', function () { let localEthChain: Chain let localArbChain: Chain let setup: Awaited> @@ -31,7 +34,10 @@ describe('arbitrumDepositActions', function () { it('deposits ETH from parent to child using deposit action', async function () { const parentAccount = privateKeyToAccount(`0x${config.ethKey}`) - const depositAmount = parseEther('0.01') + + const [depositAmount, tokenDecimals] = await getAmountInEnvironmentDecimals( + '0.01' + ) const baseParentWalletClient = createWalletClient({ account: parentAccount, @@ -56,6 +62,12 @@ describe('arbitrumDepositActions', function () { address: parentAccount.address, }) + await approveCustomFeeTokenWithViem({ + parentAccount, + parentWalletClient, + chain: localEthChain, + }) + const result = await parentWalletClient.depositEth({ amount: depositAmount, account: parentAccount, @@ -68,7 +80,13 @@ describe('arbitrumDepositActions', function () { }) const balanceDiff = finalBalance - initialBalance - expect(balanceDiff).to.equal(depositAmount) + + const normalizedBalanceDiff = normalizeBalanceDiffFByDecimals( + balanceDiff, + tokenDecimals + ) + + expect(normalizedBalanceDiff.toString()).to.equal(depositAmount.toString()) }) it('handles deposit failure gracefully', async function () { diff --git a/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts b/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts index a6e04a79d2..69df0c9c2c 100644 --- a/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts +++ b/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts @@ -1,5 +1,13 @@ import { StaticJsonRpcProvider } from '@ethersproject/providers' import { Signer, Wallet, ethers, utils } from 'ethers' +import { + Account, + parseEther, + parseUnits, + type Hex, + type WalletClient, + type Chain, +} from 'viem' import { testSetup as _testSetup, @@ -109,3 +117,57 @@ export async function fundChildCustomFeeToken(childSigner: Signer) { }) await tx.wait() } + +export async function getAmountInEnvironmentDecimals( + amount: string +): Promise<[bigint, number]> { + if (isArbitrumNetworkWithCustomFeeToken()) { + const tokenDecimals = await getNativeTokenDecimals({ + parentProvider: ethProvider(), + childNetwork: localNetworks().l3Network!, + }) + return [parseUnits(amount, tokenDecimals), tokenDecimals] + } + return [parseEther(amount), 18] // ETH decimals +} + +export function normalizeBalanceDiffByDecimals( + balanceDiff: bigint, + tokenDecimals: number +): bigint { + return balanceDiff / BigInt(10 ** (18 - tokenDecimals)) +} + +export async function approveCustomFeeTokenWithViem({ + parentAccount, + parentWalletClient, + chain, +}: { + parentAccount: { address: string } + parentWalletClient: WalletClient + chain: Chain +}) { + if (!isArbitrumNetworkWithCustomFeeToken()) return + + const networks = localNetworks() + const inbox = networks.l3Network!.ethBridge.inbox + + const currentAllowance = await getParentCustomFeeTokenAllowance( + parentAccount.address, + inbox + ) + + // Only approve if allowance is insufficient + if (currentAllowance.lt(ethers.constants.MaxUint256)) { + const ethBridger = await EthBridger.fromProvider(arbProvider()) + const approveRequest = ethBridger.getApproveGasTokenRequest() + await parentWalletClient.sendTransaction({ + to: approveRequest.to as Hex, + data: approveRequest.data as Hex, + account: parentAccount as Account, + chain, + value: BigInt(0), + kzg: undefined, + }) + } +} From c5a151ca25e3d65e78176c0f9dbb1c21f0bc6286 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Tue, 26 Nov 2024 17:33:55 -0500 Subject: [PATCH 15/19] test more amount --- tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts b/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts index 69df0c9c2c..62aab73a0d 100644 --- a/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts +++ b/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts @@ -66,7 +66,7 @@ export async function fundParentCustomFeeToken( const tx = await tokenContract.transfer( address, - utils.parseUnits('10', decimals) + utils.parseUnits('1000', decimals) ) await tx.wait() } From 782e7c589276cc3a7b747a11cf3e4cfffc8cb884 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Wed, 27 Nov 2024 14:17:57 -0500 Subject: [PATCH 16/19] add a bunch of logs to fix issue in ci --- .../arbitrumDepositActions.test.ts | 152 +++++++++++++++++- 1 file changed, 149 insertions(+), 3 deletions(-) diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index 02ff310b07..89b12469db 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -1,9 +1,14 @@ import { expect } from 'chai' import { createWalletClient, http, parseEther, type Chain } from 'viem' import { privateKeyToAccount } from 'viem/accounts' -import { config, testSetup } from '../../scripts/testSetup' +import { + config, + testSetup, + getLocalNetworksFromFile, +} from '../../scripts/testSetup' import { createArbitrumClient } from '../../src/experimental/createArbitrumClient' import { fundParentSigner } from './testHelpers' +import { ERC20__factory } from '../../src/lib/abi/factories/ERC20__factory' import { approveParentCustomFeeToken, fundParentCustomFeeToken, @@ -12,6 +17,9 @@ import { normalizeBalanceDiffByDecimals as normalizeBalanceDiffFByDecimals, approveCustomFeeTokenWithViem, } from './custom-fee-token/customFeeTokenTestHelpers' +import { JsonRpcProvider } from '@ethersproject/providers' + +const localNetworks = getLocalNetworksFromFile describe.only('arbitrumDepositActions', function () { let localEthChain: Chain @@ -25,19 +33,76 @@ describe.only('arbitrumDepositActions', function () { }) beforeEach(async function () { + const parentAccount = privateKeyToAccount(`0x${config.ethKey}`) + console.log('\n=== beforeEach setup ===') + console.log('Parent Account:', parentAccount.address) + console.log('Parent Signer:', await setup.parentSigner.getAddress()) + console.log( + 'Parent Provider URL:', + (setup.parentProvider as JsonRpcProvider).connection.url + ) + console.log( + 'Child Provider URL:', + (setup.childProvider as JsonRpcProvider).connection.url + ) + await fundParentSigner(setup.parentSigner) if (isArbitrumNetworkWithCustomFeeToken()) { - await fundParentCustomFeeToken(setup.parentSigner) + console.log('\n=== Custom Fee Token Setup ===') + const nativeToken = localNetworks().l3Network?.nativeToken + console.log('Native Token Address:', nativeToken) + + const tokenContract = ERC20__factory.connect( + nativeToken!, + setup.parentProvider + ) + + // Log token details + const symbol = await tokenContract.symbol() + const decimals = await tokenContract.decimals() + const totalSupply = await tokenContract.totalSupply() + console.log('Token Symbol:', symbol) + console.log('Token Decimals:', decimals) + console.log('Token Total Supply:', totalSupply.toString()) + + // Log balances before funding + const balanceBefore = await tokenContract.balanceOf(parentAccount.address) + console.log('Balance Before Funding:', balanceBefore.toString()) + + await fundParentCustomFeeToken(parentAccount.address) + + // Log balances after funding + const balanceAfter = await tokenContract.balanceOf(parentAccount.address) + console.log('Balance After Funding:', balanceAfter.toString()) + console.log('Funding Amount:', balanceAfter.sub(balanceBefore).toString()) + await approveParentCustomFeeToken(setup.parentSigner) + + // Log network details + const network = localNetworks().l3Network! + console.log('\n=== Network Configuration ===') + console.log('Chain ID:', network.chainId) + console.log('Bridge:', network.ethBridge.bridge) + console.log('Inbox:', network.ethBridge.inbox) + console.log('Native Token:', network.nativeToken) } }) it('deposits ETH from parent to child using deposit action', async function () { const parentAccount = privateKeyToAccount(`0x${config.ethKey}`) + console.log('\n=== Starting Deposit Test ===') + console.log('Parent Account:', parentAccount.address) + console.log('Test Environment:', { + ORBIT_TEST: process.env.ORBIT_TEST, + DECIMALS: process.env.DECIMALS, + }) const [depositAmount, tokenDecimals] = await getAmountInEnvironmentDecimals( '0.01' ) + console.log('\n=== Deposit Parameters ===') + console.log('Deposit Amount:', depositAmount.toString()) + console.log('Token Decimals:', tokenDecimals) const baseParentWalletClient = createWalletClient({ account: parentAccount, @@ -45,6 +110,18 @@ describe.only('arbitrumDepositActions', function () { transport: http(config.ethUrl), }) + console.log('\n=== Chain Configuration ===') + console.log('Parent Chain:', { + id: localEthChain.id, + name: localEthChain.name, + rpcUrl: config.ethUrl, + }) + console.log('Child Chain:', { + id: localArbChain.id, + name: localArbChain.name, + rpcUrl: config.arbUrl, + }) + const baseChildWalletClient = createWalletClient({ account: parentAccount, chain: localArbChain, @@ -61,18 +138,67 @@ describe.only('arbitrumDepositActions', function () { const initialBalance = await childPublicClient.getBalance({ address: parentAccount.address, }) + console.log('\n=== Initial State ===') + console.log('Initial Child Chain Balance:', initialBalance.toString()) + if (isArbitrumNetworkWithCustomFeeToken()) { + const nativeToken = localNetworks().l3Network?.nativeToken + const tokenContract = ERC20__factory.connect( + nativeToken!, + setup.parentProvider + ) + + // Get token details + const symbol = await tokenContract.symbol() + const decimals = await tokenContract.decimals() + const balance = await tokenContract.balanceOf(parentAccount.address) + const allowance = await tokenContract.allowance( + parentAccount.address, + localNetworks().l3Network!.ethBridge.inbox + ) + + console.log('\n=== Custom Fee Token State ===') + console.log('Token Symbol:', symbol) + console.log('Token Decimals:', decimals) + console.log('Balance Before Deposit:', balance.toString()) + console.log('Current Allowance:', allowance.toString()) + console.log('Inbox Address:', localNetworks().l3Network!.ethBridge.inbox) + } + + console.log('\n=== Approving Custom Fee Token ===') await approveCustomFeeTokenWithViem({ parentAccount, parentWalletClient, chain: localEthChain, }) + if (isArbitrumNetworkWithCustomFeeToken()) { + const nativeToken = localNetworks().l3Network?.nativeToken + const tokenContract = ERC20__factory.connect( + nativeToken!, + setup.parentProvider + ) + const allowance = await tokenContract.allowance( + parentAccount.address, + localNetworks().l3Network!.ethBridge.inbox + ) + console.log('New Allowance After Approval:', allowance.toString()) + } + + console.log('\n=== Executing Deposit ===') const result = await parentWalletClient.depositEth({ amount: depositAmount, account: parentAccount, }) + console.log('\n=== Deposit Result ===') + console.log('Transaction Hash:', result.hash) + console.log('Status:', result.status) + console.log('Complete:', result.complete) + if (result.message) { + console.log('Message:', result.message) + } + expect(result.status).to.equal('success') const finalBalance = await childPublicClient.getBalance({ @@ -80,12 +206,32 @@ describe.only('arbitrumDepositActions', function () { }) const balanceDiff = finalBalance - initialBalance - const normalizedBalanceDiff = normalizeBalanceDiffFByDecimals( balanceDiff, tokenDecimals ) + console.log('\n=== Final State ===') + console.log('Final Balance:', finalBalance.toString()) + console.log('Balance Difference:', balanceDiff.toString()) + console.log( + 'Normalized Balance Difference:', + normalizedBalanceDiff.toString() + ) + console.log('Expected Amount:', depositAmount.toString()) + + if (isArbitrumNetworkWithCustomFeeToken()) { + const nativeToken = localNetworks().l3Network?.nativeToken + const tokenContract = ERC20__factory.connect( + nativeToken!, + setup.parentProvider + ) + const finalTokenBalance = await tokenContract.balanceOf( + parentAccount.address + ) + console.log('Final Token Balance:', finalTokenBalance.toString()) + } + expect(normalizedBalanceDiff.toString()).to.equal(depositAmount.toString()) }) From 952b6b543dc64acdd8fff27c96c3b10bf465fa4c Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Wed, 27 Nov 2024 14:39:46 -0500 Subject: [PATCH 17/19] fix decimal handling --- .../custom-fee-token/customFeeTokenTestHelpers.ts | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts b/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts index 62aab73a0d..a4cc493cd1 100644 --- a/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts +++ b/tests/integration/custom-fee-token/customFeeTokenTestHelpers.ts @@ -7,6 +7,7 @@ import { type Hex, type WalletClient, type Chain, + formatUnits, } from 'viem' import { @@ -135,7 +136,13 @@ export function normalizeBalanceDiffByDecimals( balanceDiff: bigint, tokenDecimals: number ): bigint { - return balanceDiff / BigInt(10 ** (18 - tokenDecimals)) + // Convert to 18 decimals (ETH standard) for comparison + if (tokenDecimals === 18) return balanceDiff + + // Convert to decimal string with proper precision + const formattedDiff = formatUnits(balanceDiff, 18) + // Parse back with target decimals + return parseUnits(formattedDiff, tokenDecimals) } export async function approveCustomFeeTokenWithViem({ From a05c9f577c5d6cdf969b3bd1e4a8a13493945402 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Wed, 27 Nov 2024 15:06:38 -0500 Subject: [PATCH 18/19] remove debug logs --- .../arbitrumDepositActions.test.ts | 158 +----------------- 1 file changed, 6 insertions(+), 152 deletions(-) diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index 89b12469db..6533f4a484 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -1,14 +1,9 @@ import { expect } from 'chai' import { createWalletClient, http, parseEther, type Chain } from 'viem' import { privateKeyToAccount } from 'viem/accounts' -import { - config, - testSetup, - getLocalNetworksFromFile, -} from '../../scripts/testSetup' +import { config, testSetup } from '../../scripts/testSetup' import { createArbitrumClient } from '../../src/experimental/createArbitrumClient' import { fundParentSigner } from './testHelpers' -import { ERC20__factory } from '../../src/lib/abi/factories/ERC20__factory' import { approveParentCustomFeeToken, fundParentCustomFeeToken, @@ -17,9 +12,6 @@ import { normalizeBalanceDiffByDecimals as normalizeBalanceDiffFByDecimals, approveCustomFeeTokenWithViem, } from './custom-fee-token/customFeeTokenTestHelpers' -import { JsonRpcProvider } from '@ethersproject/providers' - -const localNetworks = getLocalNetworksFromFile describe.only('arbitrumDepositActions', function () { let localEthChain: Chain @@ -34,75 +26,18 @@ describe.only('arbitrumDepositActions', function () { beforeEach(async function () { const parentAccount = privateKeyToAccount(`0x${config.ethKey}`) - console.log('\n=== beforeEach setup ===') - console.log('Parent Account:', parentAccount.address) - console.log('Parent Signer:', await setup.parentSigner.getAddress()) - console.log( - 'Parent Provider URL:', - (setup.parentProvider as JsonRpcProvider).connection.url - ) - console.log( - 'Child Provider URL:', - (setup.childProvider as JsonRpcProvider).connection.url - ) - await fundParentSigner(setup.parentSigner) if (isArbitrumNetworkWithCustomFeeToken()) { - console.log('\n=== Custom Fee Token Setup ===') - const nativeToken = localNetworks().l3Network?.nativeToken - console.log('Native Token Address:', nativeToken) - - const tokenContract = ERC20__factory.connect( - nativeToken!, - setup.parentProvider - ) - - // Log token details - const symbol = await tokenContract.symbol() - const decimals = await tokenContract.decimals() - const totalSupply = await tokenContract.totalSupply() - console.log('Token Symbol:', symbol) - console.log('Token Decimals:', decimals) - console.log('Token Total Supply:', totalSupply.toString()) - - // Log balances before funding - const balanceBefore = await tokenContract.balanceOf(parentAccount.address) - console.log('Balance Before Funding:', balanceBefore.toString()) - await fundParentCustomFeeToken(parentAccount.address) - - // Log balances after funding - const balanceAfter = await tokenContract.balanceOf(parentAccount.address) - console.log('Balance After Funding:', balanceAfter.toString()) - console.log('Funding Amount:', balanceAfter.sub(balanceBefore).toString()) - await approveParentCustomFeeToken(setup.parentSigner) - - // Log network details - const network = localNetworks().l3Network! - console.log('\n=== Network Configuration ===') - console.log('Chain ID:', network.chainId) - console.log('Bridge:', network.ethBridge.bridge) - console.log('Inbox:', network.ethBridge.inbox) - console.log('Native Token:', network.nativeToken) } }) it('deposits ETH from parent to child using deposit action', async function () { const parentAccount = privateKeyToAccount(`0x${config.ethKey}`) - console.log('\n=== Starting Deposit Test ===') - console.log('Parent Account:', parentAccount.address) - console.log('Test Environment:', { - ORBIT_TEST: process.env.ORBIT_TEST, - DECIMALS: process.env.DECIMALS, - }) - const [depositAmount, tokenDecimals] = await getAmountInEnvironmentDecimals( '0.01' ) - console.log('\n=== Deposit Parameters ===') - console.log('Deposit Amount:', depositAmount.toString()) - console.log('Token Decimals:', tokenDecimals) const baseParentWalletClient = createWalletClient({ account: parentAccount, @@ -110,18 +45,6 @@ describe.only('arbitrumDepositActions', function () { transport: http(config.ethUrl), }) - console.log('\n=== Chain Configuration ===') - console.log('Parent Chain:', { - id: localEthChain.id, - name: localEthChain.name, - rpcUrl: config.ethUrl, - }) - console.log('Child Chain:', { - id: localArbChain.id, - name: localArbChain.name, - rpcUrl: config.arbUrl, - }) - const baseChildWalletClient = createWalletClient({ account: parentAccount, chain: localArbChain, @@ -138,67 +61,20 @@ describe.only('arbitrumDepositActions', function () { const initialBalance = await childPublicClient.getBalance({ address: parentAccount.address, }) - console.log('\n=== Initial State ===') - console.log('Initial Child Chain Balance:', initialBalance.toString()) if (isArbitrumNetworkWithCustomFeeToken()) { - const nativeToken = localNetworks().l3Network?.nativeToken - const tokenContract = ERC20__factory.connect( - nativeToken!, - setup.parentProvider - ) - - // Get token details - const symbol = await tokenContract.symbol() - const decimals = await tokenContract.decimals() - const balance = await tokenContract.balanceOf(parentAccount.address) - const allowance = await tokenContract.allowance( - parentAccount.address, - localNetworks().l3Network!.ethBridge.inbox - ) - - console.log('\n=== Custom Fee Token State ===') - console.log('Token Symbol:', symbol) - console.log('Token Decimals:', decimals) - console.log('Balance Before Deposit:', balance.toString()) - console.log('Current Allowance:', allowance.toString()) - console.log('Inbox Address:', localNetworks().l3Network!.ethBridge.inbox) - } - - console.log('\n=== Approving Custom Fee Token ===') - await approveCustomFeeTokenWithViem({ - parentAccount, - parentWalletClient, - chain: localEthChain, - }) - - if (isArbitrumNetworkWithCustomFeeToken()) { - const nativeToken = localNetworks().l3Network?.nativeToken - const tokenContract = ERC20__factory.connect( - nativeToken!, - setup.parentProvider - ) - const allowance = await tokenContract.allowance( - parentAccount.address, - localNetworks().l3Network!.ethBridge.inbox - ) - console.log('New Allowance After Approval:', allowance.toString()) + await approveCustomFeeTokenWithViem({ + parentAccount, + parentWalletClient, + chain: localEthChain, + }) } - console.log('\n=== Executing Deposit ===') const result = await parentWalletClient.depositEth({ amount: depositAmount, account: parentAccount, }) - console.log('\n=== Deposit Result ===') - console.log('Transaction Hash:', result.hash) - console.log('Status:', result.status) - console.log('Complete:', result.complete) - if (result.message) { - console.log('Message:', result.message) - } - expect(result.status).to.equal('success') const finalBalance = await childPublicClient.getBalance({ @@ -211,33 +87,11 @@ describe.only('arbitrumDepositActions', function () { tokenDecimals ) - console.log('\n=== Final State ===') - console.log('Final Balance:', finalBalance.toString()) - console.log('Balance Difference:', balanceDiff.toString()) - console.log( - 'Normalized Balance Difference:', - normalizedBalanceDiff.toString() - ) - console.log('Expected Amount:', depositAmount.toString()) - - if (isArbitrumNetworkWithCustomFeeToken()) { - const nativeToken = localNetworks().l3Network?.nativeToken - const tokenContract = ERC20__factory.connect( - nativeToken!, - setup.parentProvider - ) - const finalTokenBalance = await tokenContract.balanceOf( - parentAccount.address - ) - console.log('Final Token Balance:', finalTokenBalance.toString()) - } - expect(normalizedBalanceDiff.toString()).to.equal(depositAmount.toString()) }) it('handles deposit failure gracefully', async function () { const parentAccount = privateKeyToAccount(`0x${config.ethKey}`) - // Use an amount too large to cause a failure const depositAmount = parseEther('999999999') const baseParentWalletClient = createWalletClient({ From e3c48a460e058f624a456133173a43fb91c1b036 Mon Sep 17 00:00:00 2001 From: Doug Lance <4741454+douglance@users.noreply.github.com> Date: Wed, 27 Nov 2024 15:06:54 -0500 Subject: [PATCH 19/19] restore other tests --- tests/integration/arbitrumDepositActions.test.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/integration/arbitrumDepositActions.test.ts b/tests/integration/arbitrumDepositActions.test.ts index 6533f4a484..3ae4cb9b62 100644 --- a/tests/integration/arbitrumDepositActions.test.ts +++ b/tests/integration/arbitrumDepositActions.test.ts @@ -13,7 +13,7 @@ import { approveCustomFeeTokenWithViem, } from './custom-fee-token/customFeeTokenTestHelpers' -describe.only('arbitrumDepositActions', function () { +describe('arbitrumDepositActions', function () { let localEthChain: Chain let localArbChain: Chain let setup: Awaited>