viem 2.10.1 → 2.10.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +20 -0
- package/_cjs/chains/definitions/celo.js +2 -2
- package/_cjs/chains/definitions/celo.js.map +1 -1
- package/_cjs/chains/definitions/dodochainTestnet.js +23 -0
- package/_cjs/chains/definitions/dodochainTestnet.js.map +1 -0
- package/_cjs/chains/definitions/inEVM.js +30 -0
- package/_cjs/chains/definitions/inEVM.js.map +1 -0
- package/_cjs/chains/definitions/otimDevnet.js +2 -2
- package/_cjs/chains/definitions/otimDevnet.js.map +1 -1
- package/_cjs/chains/index.js +9 -5
- package/_cjs/chains/index.js.map +1 -1
- package/_cjs/errors/version.js +1 -1
- package/_cjs/op-stack/abis.js +142 -359
- package/_cjs/op-stack/abis.js.map +1 -1
- package/_cjs/op-stack/actions/getTimeToFinalize.js +14 -6
- package/_cjs/op-stack/actions/getTimeToFinalize.js.map +1 -1
- package/_cjs/op-stack/actions/getWithdrawalStatus.js +10 -2
- package/_cjs/op-stack/actions/getWithdrawalStatus.js.map +1 -1
- package/_esm/chains/definitions/celo.js +2 -2
- package/_esm/chains/definitions/celo.js.map +1 -1
- package/_esm/chains/definitions/dodochainTestnet.js +20 -0
- package/_esm/chains/definitions/dodochainTestnet.js.map +1 -0
- package/_esm/chains/definitions/inEVM.js +27 -0
- package/_esm/chains/definitions/inEVM.js.map +1 -0
- package/_esm/chains/definitions/otimDevnet.js +2 -2
- package/_esm/chains/definitions/otimDevnet.js.map +1 -1
- package/_esm/chains/index.js +2 -0
- package/_esm/chains/index.js.map +1 -1
- package/_esm/errors/version.js +1 -1
- package/_esm/op-stack/abis.js +142 -359
- package/_esm/op-stack/abis.js.map +1 -1
- package/_esm/op-stack/actions/getTimeToFinalize.js +14 -6
- package/_esm/op-stack/actions/getTimeToFinalize.js.map +1 -1
- package/_esm/op-stack/actions/getWithdrawalStatus.js +10 -2
- package/_esm/op-stack/actions/getWithdrawalStatus.js.map +1 -1
- package/_types/chains/definitions/celo.d.ts +2 -2
- package/_types/chains/definitions/dodochainTestnet.d.ts +36 -0
- package/_types/chains/definitions/dodochainTestnet.d.ts.map +1 -0
- package/_types/chains/definitions/inEVM.d.ts +34 -0
- package/_types/chains/definitions/inEVM.d.ts.map +1 -0
- package/_types/chains/definitions/otimDevnet.d.ts +2 -2
- package/_types/chains/index.d.ts +2 -0
- package/_types/chains/index.d.ts.map +1 -1
- package/_types/errors/version.d.ts +1 -1
- package/_types/op-stack/abis.d.ts +174 -87
- package/_types/op-stack/abis.d.ts.map +1 -1
- package/_types/op-stack/actions/getTimeToFinalize.d.ts.map +1 -1
- package/_types/op-stack/actions/getWithdrawalStatus.d.ts.map +1 -1
- package/_types/types/eip1193.d.ts +14 -0
- package/_types/types/eip1193.d.ts.map +1 -1
- package/chains/definitions/celo.ts +2 -2
- package/chains/definitions/dodochainTestnet.ts +20 -0
- package/chains/definitions/inEVM.ts +27 -0
- package/chains/definitions/otimDevnet.ts +2 -2
- package/chains/index.ts +2 -0
- package/errors/version.ts +1 -1
- package/op-stack/abis.ts +142 -359
- package/op-stack/actions/getTimeToFinalize.ts +15 -6
- package/op-stack/actions/getWithdrawalStatus.ts +13 -2
- package/package.json +1 -1
- package/types/eip1193.ts +12 -0
@@ -128,14 +128,23 @@ export async function getTimeToFinalize<
|
|
128
128
|
return { period: Number(period), seconds, timestamp }
|
129
129
|
}
|
130
130
|
|
131
|
+
const proofSubmitter = await readContract(client, {
|
132
|
+
abi: portal2Abi,
|
133
|
+
address: portalAddress,
|
134
|
+
functionName: 'proofSubmitters',
|
135
|
+
args: [withdrawalHash, 0n],
|
136
|
+
}).catch(() => undefined)
|
137
|
+
|
131
138
|
const [[_disputeGameProxy, proveTimestamp], proofMaturityDelaySeconds] =
|
132
139
|
await Promise.all([
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
140
|
+
proofSubmitter
|
141
|
+
? readContract(client, {
|
142
|
+
abi: portal2Abi,
|
143
|
+
address: portalAddress,
|
144
|
+
functionName: 'provenWithdrawals',
|
145
|
+
args: [withdrawalHash, proofSubmitter],
|
146
|
+
})
|
147
|
+
: Promise.resolve(['0x', 0n]),
|
139
148
|
readContract(client, {
|
140
149
|
abi: portal2Abi,
|
141
150
|
address: portalAddress,
|
@@ -192,6 +192,13 @@ export async function getWithdrawalStatus<
|
|
192
192
|
return seconds > 0 ? 'waiting-to-finalize' : 'ready-to-finalize'
|
193
193
|
}
|
194
194
|
|
195
|
+
const proofSubmitter = await readContract(client, {
|
196
|
+
abi: portal2Abi,
|
197
|
+
address: portalAddress,
|
198
|
+
functionName: 'proofSubmitters',
|
199
|
+
args: [withdrawal.withdrawalHash, 0n],
|
200
|
+
}).catch(() => withdrawal.sender)
|
201
|
+
|
195
202
|
const [disputeGameResult, checkWithdrawalResult, finalizedResult] =
|
196
203
|
await Promise.allSettled([
|
197
204
|
getGame(client, {
|
@@ -203,7 +210,7 @@ export async function getWithdrawalStatus<
|
|
203
210
|
abi: portal2Abi,
|
204
211
|
address: portalAddress,
|
205
212
|
functionName: 'checkWithdrawal',
|
206
|
-
args: [withdrawal.withdrawalHash],
|
213
|
+
args: [withdrawal.withdrawalHash, proofSubmitter],
|
207
214
|
}),
|
208
215
|
readContract(client, {
|
209
216
|
abi: portal2Abi,
|
@@ -225,7 +232,11 @@ export async function getWithdrawalStatus<
|
|
225
232
|
const error = checkWithdrawalResult.reason as ReadContractErrorType
|
226
233
|
if (error.cause instanceof ContractFunctionRevertedError) {
|
227
234
|
const errorMessage = error.cause.data?.args?.[0]
|
228
|
-
if (
|
235
|
+
if (
|
236
|
+
errorMessage === 'OptimismPortal: withdrawal has not been proven yet' ||
|
237
|
+
errorMessage ===
|
238
|
+
'OptimismPortal: withdrawal has not been proven by proof submitter address yet'
|
239
|
+
)
|
229
240
|
return 'ready-to-prove'
|
230
241
|
if (
|
231
242
|
errorMessage ===
|
package/package.json
CHANGED
package/types/eip1193.ts
CHANGED
@@ -1370,6 +1370,18 @@ export type WalletRpcSchema = [
|
|
1370
1370
|
Parameters: [permissions: { eth_accounts: Record<string, any> }]
|
1371
1371
|
ReturnType: WalletPermission[]
|
1372
1372
|
},
|
1373
|
+
/**
|
1374
|
+
* @description Revokes the given permissions from the user.
|
1375
|
+
* @link https://github.com/MetaMask/metamask-improvement-proposals/blob/main/MIPs/mip-2.md
|
1376
|
+
* @example
|
1377
|
+
* provider.request({ method: 'wallet_revokePermissions', params: [{ eth_accounts: {} }] })
|
1378
|
+
* // => { ... }
|
1379
|
+
*/
|
1380
|
+
{
|
1381
|
+
Method: 'wallet_revokePermissions'
|
1382
|
+
Parameters: [permissions: { eth_accounts: Record<string, any> }]
|
1383
|
+
ReturnType: null
|
1384
|
+
},
|
1373
1385
|
/**
|
1374
1386
|
* @description Requests the connected wallet to send a batch of calls.
|
1375
1387
|
* @link https://eips.ethereum.org/EIPS/eip-5792
|