viem 2.17.11 → 2.18.0
Sign up to get free protection for your applications and to get access to all the features.
- package/CHANGELOG.md +8 -2
- package/_cjs/account-abstraction/accounts/createWebAuthnCredential.js +6 -0
- package/_cjs/account-abstraction/accounts/createWebAuthnCredential.js.map +1 -0
- package/_cjs/account-abstraction/accounts/implementations/toCoinbaseSmartAccount.js +688 -0
- package/_cjs/account-abstraction/accounts/implementations/toCoinbaseSmartAccount.js.map +1 -0
- package/_cjs/account-abstraction/accounts/implementations/toSoladySmartAccount.js +704 -0
- package/_cjs/account-abstraction/accounts/implementations/toSoladySmartAccount.js.map +1 -0
- package/_cjs/account-abstraction/accounts/toSmartAccount.js +93 -0
- package/_cjs/account-abstraction/accounts/toSmartAccount.js.map +1 -0
- package/_cjs/account-abstraction/accounts/toWebAuthnAccount.js +24 -0
- package/_cjs/account-abstraction/accounts/toWebAuthnAccount.js.map +1 -0
- package/_cjs/account-abstraction/accounts/types.js +3 -0
- package/_cjs/account-abstraction/accounts/types.js.map +1 -0
- package/_cjs/account-abstraction/actions/bundler/estimateUserOperationGas.js +37 -0
- package/_cjs/account-abstraction/actions/bundler/estimateUserOperationGas.js.map +1 -0
- package/_cjs/account-abstraction/actions/bundler/getSupportedEntryPoints.js +7 -0
- package/_cjs/account-abstraction/actions/bundler/getSupportedEntryPoints.js.map +1 -0
- package/_cjs/account-abstraction/actions/bundler/getUserOperation.js +22 -0
- package/_cjs/account-abstraction/actions/bundler/getUserOperation.js.map +1 -0
- package/_cjs/account-abstraction/actions/bundler/getUserOperationReceipt.js +15 -0
- package/_cjs/account-abstraction/actions/bundler/getUserOperationReceipt.js.map +1 -0
- package/_cjs/account-abstraction/actions/bundler/prepareUserOperation.js +239 -0
- package/_cjs/account-abstraction/actions/bundler/prepareUserOperation.js.map +1 -0
- package/_cjs/account-abstraction/actions/bundler/sendUserOperation.js +36 -0
- package/_cjs/account-abstraction/actions/bundler/sendUserOperation.js.map +1 -0
- package/_cjs/account-abstraction/actions/bundler/waitForUserOperationReceipt.js +48 -0
- package/_cjs/account-abstraction/actions/bundler/waitForUserOperationReceipt.js.map +1 -0
- package/_cjs/account-abstraction/actions/paymaster/getPaymasterData.js +34 -0
- package/_cjs/account-abstraction/actions/paymaster/getPaymasterData.js.map +1 -0
- package/_cjs/account-abstraction/actions/paymaster/getPaymasterStubData.js +34 -0
- package/_cjs/account-abstraction/actions/paymaster/getPaymasterStubData.js.map +1 -0
- package/_cjs/account-abstraction/clients/createBundlerClient.js +18 -0
- package/_cjs/account-abstraction/clients/createBundlerClient.js.map +1 -0
- package/_cjs/account-abstraction/clients/createPaymasterClient.js +17 -0
- package/_cjs/account-abstraction/clients/createPaymasterClient.js.map +1 -0
- package/_cjs/account-abstraction/clients/decorators/bundler.js +24 -0
- package/_cjs/account-abstraction/clients/decorators/bundler.js.map +1 -0
- package/_cjs/account-abstraction/clients/decorators/paymaster.js +12 -0
- package/_cjs/account-abstraction/clients/decorators/paymaster.js.map +1 -0
- package/_cjs/account-abstraction/constants/abis.js +1318 -0
- package/_cjs/account-abstraction/constants/abis.js.map +1 -0
- package/_cjs/account-abstraction/constants/address.js +6 -0
- package/_cjs/account-abstraction/constants/address.js.map +1 -0
- package/_cjs/account-abstraction/errors/bundler.js +813 -0
- package/_cjs/account-abstraction/errors/bundler.js.map +1 -0
- package/_cjs/account-abstraction/errors/userOperation.js +91 -0
- package/_cjs/account-abstraction/errors/userOperation.js.map +1 -0
- package/_cjs/account-abstraction/index.js +90 -0
- package/_cjs/account-abstraction/index.js.map +1 -0
- package/_cjs/account-abstraction/types/account.js +3 -0
- package/_cjs/account-abstraction/types/account.js.map +1 -0
- package/_cjs/account-abstraction/types/entryPointVersion.js +3 -0
- package/_cjs/account-abstraction/types/entryPointVersion.js.map +1 -0
- package/_cjs/account-abstraction/types/rpc.js +3 -0
- package/_cjs/account-abstraction/types/rpc.js.map +1 -0
- package/_cjs/account-abstraction/types/userOperation.js +3 -0
- package/_cjs/account-abstraction/types/userOperation.js.map +1 -0
- package/_cjs/account-abstraction/utils/errors/getBundlerError.js +186 -0
- package/_cjs/account-abstraction/utils/errors/getBundlerError.js.map +1 -0
- package/_cjs/account-abstraction/utils/errors/getUserOperationError.js +87 -0
- package/_cjs/account-abstraction/utils/errors/getUserOperationError.js.map +1 -0
- package/_cjs/account-abstraction/utils/formatters/userOperation.js +24 -0
- package/_cjs/account-abstraction/utils/formatters/userOperation.js.map +1 -0
- package/_cjs/account-abstraction/utils/formatters/userOperationGas.js +18 -0
- package/_cjs/account-abstraction/utils/formatters/userOperationGas.js.map +1 -0
- package/_cjs/account-abstraction/utils/formatters/userOperationReceipt.js +18 -0
- package/_cjs/account-abstraction/utils/formatters/userOperationReceipt.js.map +1 -0
- package/_cjs/account-abstraction/utils/formatters/userOperationRequest.js +43 -0
- package/_cjs/account-abstraction/utils/formatters/userOperationRequest.js.map +1 -0
- package/_cjs/account-abstraction/utils/userOperation/getUserOperationHash.js +88 -0
- package/_cjs/account-abstraction/utils/userOperation/getUserOperationHash.js.map +1 -0
- package/_cjs/account-abstraction/utils/userOperation/toPackedUserOperation.js +44 -0
- package/_cjs/account-abstraction/utils/userOperation/toPackedUserOperation.js.map +1 -0
- package/_cjs/accounts/index.js +1 -3
- package/_cjs/accounts/index.js.map +1 -1
- package/_cjs/accounts/privateKeyToAccount.js +4 -0
- package/_cjs/accounts/privateKeyToAccount.js.map +1 -1
- package/_cjs/accounts/toAccount.js +1 -0
- package/_cjs/accounts/toAccount.js.map +1 -1
- package/_cjs/accounts/utils/parseAccount.js.map +1 -1
- package/_cjs/accounts/utils/sign.js +8 -2
- package/_cjs/accounts/utils/sign.js.map +1 -1
- package/_cjs/accounts/utils/signMessage.js +1 -3
- package/_cjs/accounts/utils/signMessage.js.map +1 -1
- package/_cjs/accounts/utils/signTypedData.js +2 -3
- package/_cjs/accounts/utils/signTypedData.js.map +1 -1
- package/_cjs/actions/wallet/sendTransaction.js +35 -22
- package/_cjs/actions/wallet/sendTransaction.js.map +1 -1
- package/_cjs/actions/wallet/signMessage.js +1 -1
- package/_cjs/actions/wallet/signMessage.js.map +1 -1
- package/_cjs/actions/wallet/signTransaction.js +1 -2
- package/_cjs/actions/wallet/signTransaction.js.map +1 -1
- package/_cjs/actions/wallet/signTypedData.js +1 -1
- package/_cjs/actions/wallet/signTypedData.js.map +1 -1
- package/_cjs/constants/abis.js +0 -3
- package/_cjs/constants/abis.js.map +1 -1
- package/_cjs/constants/address.js +3 -1
- package/_cjs/constants/address.js.map +1 -1
- package/_cjs/errors/account.js +17 -2
- package/_cjs/errors/account.js.map +1 -1
- package/_cjs/errors/contract.js +1 -1
- package/_cjs/errors/contract.js.map +1 -1
- package/_cjs/errors/rpc.js +6 -6
- package/_cjs/errors/rpc.js.map +1 -1
- package/_cjs/errors/version.js +1 -1
- package/_cjs/errors/version.js.map +1 -1
- package/_cjs/index.js +5 -3
- package/_cjs/index.js.map +1 -1
- package/_cjs/types/eip1193.js.map +1 -1
- package/_cjs/utils/buildRequest.js +4 -2
- package/_cjs/utils/buildRequest.js.map +1 -1
- package/_cjs/utils/errors/getNodeError.js +1 -2
- package/_cjs/utils/errors/getNodeError.js.map +1 -1
- package/_cjs/utils/index.js +3 -1
- package/_cjs/utils/index.js.map +1 -1
- package/_cjs/utils/signature/serializeErc6492Signature.js +6 -2
- package/_cjs/utils/signature/serializeErc6492Signature.js.map +1 -1
- package/_cjs/utils/signature/serializeSignature.js +6 -2
- package/_cjs/utils/signature/serializeSignature.js.map +1 -1
- package/_cjs/utils/signature/verifyHash.js +10 -0
- package/_cjs/utils/signature/verifyHash.js.map +1 -0
- package/_esm/account-abstraction/accounts/createWebAuthnCredential.js +3 -0
- package/_esm/account-abstraction/accounts/createWebAuthnCredential.js.map +1 -0
- package/_esm/account-abstraction/accounts/implementations/toCoinbaseSmartAccount.js +709 -0
- package/_esm/account-abstraction/accounts/implementations/toCoinbaseSmartAccount.js.map +1 -0
- package/_esm/account-abstraction/accounts/implementations/toSoladySmartAccount.js +718 -0
- package/_esm/account-abstraction/accounts/implementations/toSoladySmartAccount.js.map +1 -0
- package/_esm/account-abstraction/accounts/toSmartAccount.js +96 -0
- package/_esm/account-abstraction/accounts/toSmartAccount.js.map +1 -0
- package/_esm/account-abstraction/accounts/toWebAuthnAccount.js +26 -0
- package/_esm/account-abstraction/accounts/toWebAuthnAccount.js.map +1 -0
- package/_esm/account-abstraction/accounts/types.js +2 -0
- package/_esm/account-abstraction/accounts/types.js.map +1 -0
- package/_esm/account-abstraction/actions/bundler/estimateUserOperationGas.js +61 -0
- package/_esm/account-abstraction/actions/bundler/estimateUserOperationGas.js.map +1 -0
- package/_esm/account-abstraction/actions/bundler/getSupportedEntryPoints.js +25 -0
- package/_esm/account-abstraction/actions/bundler/getSupportedEntryPoints.js.map +1 -0
- package/_esm/account-abstraction/actions/bundler/getUserOperation.js +42 -0
- package/_esm/account-abstraction/actions/bundler/getUserOperation.js.map +1 -0
- package/_esm/account-abstraction/actions/bundler/getUserOperationReceipt.js +35 -0
- package/_esm/account-abstraction/actions/bundler/getUserOperationReceipt.js.map +1 -0
- package/_esm/account-abstraction/actions/bundler/prepareUserOperation.js +323 -0
- package/_esm/account-abstraction/actions/bundler/prepareUserOperation.js.map +1 -0
- package/_esm/account-abstraction/actions/bundler/sendUserOperation.js +60 -0
- package/_esm/account-abstraction/actions/bundler/sendUserOperation.js.map +1 -0
- package/_esm/account-abstraction/actions/bundler/waitForUserOperationReceipt.js +68 -0
- package/_esm/account-abstraction/actions/bundler/waitForUserOperationReceipt.js.map +1 -0
- package/_esm/account-abstraction/actions/paymaster/getPaymasterData.js +56 -0
- package/_esm/account-abstraction/actions/paymaster/getPaymasterData.js.map +1 -0
- package/_esm/account-abstraction/actions/paymaster/getPaymasterStubData.js +56 -0
- package/_esm/account-abstraction/actions/paymaster/getPaymasterStubData.js.map +1 -0
- package/_esm/account-abstraction/clients/createBundlerClient.js +15 -0
- package/_esm/account-abstraction/clients/createBundlerClient.js.map +1 -0
- package/_esm/account-abstraction/clients/createPaymasterClient.js +14 -0
- package/_esm/account-abstraction/clients/createPaymasterClient.js.map +1 -0
- package/_esm/account-abstraction/clients/decorators/bundler.js +21 -0
- package/_esm/account-abstraction/clients/decorators/bundler.js.map +1 -0
- package/_esm/account-abstraction/clients/decorators/paymaster.js +9 -0
- package/_esm/account-abstraction/clients/decorators/paymaster.js.map +1 -0
- package/_esm/account-abstraction/constants/abis.js +1315 -0
- package/_esm/account-abstraction/constants/abis.js.map +1 -0
- package/_esm/account-abstraction/constants/address.js +3 -0
- package/_esm/account-abstraction/constants/address.js.map +1 -0
- package/_esm/account-abstraction/errors/bundler.js +774 -0
- package/_esm/account-abstraction/errors/bundler.js.map +1 -0
- package/_esm/account-abstraction/errors/userOperation.js +84 -0
- package/_esm/account-abstraction/errors/userOperation.js.map +1 -0
- package/_esm/account-abstraction/index.js +31 -0
- package/_esm/account-abstraction/index.js.map +1 -0
- package/_esm/account-abstraction/types/account.js +2 -0
- package/_esm/account-abstraction/types/account.js.map +1 -0
- package/_esm/account-abstraction/types/entryPointVersion.js +2 -0
- package/_esm/account-abstraction/types/entryPointVersion.js.map +1 -0
- package/_esm/account-abstraction/types/rpc.js +2 -0
- package/_esm/account-abstraction/types/rpc.js.map +1 -0
- package/_esm/account-abstraction/types/userOperation.js +2 -0
- package/_esm/account-abstraction/types/userOperation.js.map +1 -0
- package/_esm/account-abstraction/utils/errors/getBundlerError.js +183 -0
- package/_esm/account-abstraction/utils/errors/getBundlerError.js.map +1 -0
- package/_esm/account-abstraction/utils/errors/getUserOperationError.js +85 -0
- package/_esm/account-abstraction/utils/errors/getUserOperationError.js.map +1 -0
- package/_esm/account-abstraction/utils/formatters/userOperation.js +21 -0
- package/_esm/account-abstraction/utils/formatters/userOperation.js.map +1 -0
- package/_esm/account-abstraction/utils/formatters/userOperationGas.js +15 -0
- package/_esm/account-abstraction/utils/formatters/userOperationGas.js.map +1 -0
- package/_esm/account-abstraction/utils/formatters/userOperationReceipt.js +15 -0
- package/_esm/account-abstraction/utils/formatters/userOperationReceipt.js.map +1 -0
- package/_esm/account-abstraction/utils/formatters/userOperationRequest.js +40 -0
- package/_esm/account-abstraction/utils/formatters/userOperationRequest.js.map +1 -0
- package/_esm/account-abstraction/utils/userOperation/getUserOperationHash.js +85 -0
- package/_esm/account-abstraction/utils/userOperation/getUserOperationHash.js.map +1 -0
- package/_esm/account-abstraction/utils/userOperation/toPackedUserOperation.js +41 -0
- package/_esm/account-abstraction/utils/userOperation/toPackedUserOperation.js.map +1 -0
- package/_esm/accounts/index.js +0 -1
- package/_esm/accounts/index.js.map +1 -1
- package/_esm/accounts/privateKeyToAccount.js +4 -0
- package/_esm/accounts/privateKeyToAccount.js.map +1 -1
- package/_esm/accounts/toAccount.js +2 -0
- package/_esm/accounts/toAccount.js.map +1 -1
- package/_esm/accounts/utils/parseAccount.js.map +1 -1
- package/_esm/accounts/utils/sign.js +9 -3
- package/_esm/accounts/utils/sign.js.map +1 -1
- package/_esm/accounts/utils/signMessage.js +1 -3
- package/_esm/accounts/utils/signMessage.js.map +1 -1
- package/_esm/accounts/utils/signTypedData.js +2 -3
- package/_esm/accounts/utils/signTypedData.js.map +1 -1
- package/_esm/actions/wallet/sendTransaction.js +37 -24
- package/_esm/actions/wallet/sendTransaction.js.map +1 -1
- package/_esm/actions/wallet/signMessage.js +1 -1
- package/_esm/actions/wallet/signMessage.js.map +1 -1
- package/_esm/actions/wallet/signTransaction.js +1 -2
- package/_esm/actions/wallet/signTransaction.js.map +1 -1
- package/_esm/actions/wallet/signTypedData.js +1 -1
- package/_esm/actions/wallet/signTypedData.js.map +1 -1
- package/_esm/constants/abis.js +0 -3
- package/_esm/constants/abis.js.map +1 -1
- package/_esm/constants/address.js +2 -0
- package/_esm/constants/address.js.map +1 -1
- package/_esm/errors/account.js +15 -1
- package/_esm/errors/account.js.map +1 -1
- package/_esm/errors/contract.js +1 -1
- package/_esm/errors/contract.js.map +1 -1
- package/_esm/errors/rpc.js +6 -6
- package/_esm/errors/rpc.js.map +1 -1
- package/_esm/errors/version.js +1 -1
- package/_esm/errors/version.js.map +1 -1
- package/_esm/index.js +1 -0
- package/_esm/index.js.map +1 -1
- package/_esm/types/eip1193.js.map +1 -1
- package/_esm/utils/buildRequest.js +4 -2
- package/_esm/utils/buildRequest.js.map +1 -1
- package/_esm/utils/errors/getNodeError.js +1 -2
- package/_esm/utils/errors/getNodeError.js.map +1 -1
- package/_esm/utils/index.js +1 -0
- package/_esm/utils/index.js.map +1 -1
- package/_esm/utils/signature/serializeErc6492Signature.js +6 -2
- package/_esm/utils/signature/serializeErc6492Signature.js.map +1 -1
- package/_esm/utils/signature/serializeSignature.js +6 -2
- package/_esm/utils/signature/serializeSignature.js.map +1 -1
- package/_esm/utils/signature/verifyHash.js +19 -0
- package/_esm/utils/signature/verifyHash.js.map +1 -0
- package/_types/account-abstraction/accounts/createWebAuthnCredential.d.ts +2 -0
- package/_types/account-abstraction/accounts/createWebAuthnCredential.d.ts.map +1 -0
- package/_types/account-abstraction/accounts/implementations/toCoinbaseSmartAccount.d.ts +648 -0
- package/_types/account-abstraction/accounts/implementations/toCoinbaseSmartAccount.d.ts.map +1 -0
- package/_types/account-abstraction/accounts/implementations/toSoladySmartAccount.d.ts +464 -0
- package/_types/account-abstraction/accounts/implementations/toSoladySmartAccount.d.ts.map +1 -0
- package/_types/account-abstraction/accounts/toSmartAccount.d.ts +14 -0
- package/_types/account-abstraction/accounts/toSmartAccount.d.ts.map +1 -0
- package/_types/account-abstraction/accounts/toWebAuthnAccount.d.ts +32 -0
- package/_types/account-abstraction/accounts/toWebAuthnAccount.d.ts.map +1 -0
- package/_types/account-abstraction/accounts/types.d.ts +174 -0
- package/_types/account-abstraction/accounts/types.d.ts.map +1 -0
- package/_types/account-abstraction/actions/bundler/estimateUserOperationGas.d.ts +62 -0
- package/_types/account-abstraction/actions/bundler/estimateUserOperationGas.d.ts.map +1 -0
- package/_types/account-abstraction/actions/bundler/getSupportedEntryPoints.d.ts +30 -0
- package/_types/account-abstraction/actions/bundler/getSupportedEntryPoints.d.ts.map +1 -0
- package/_types/account-abstraction/actions/bundler/getUserOperation.d.ts +57 -0
- package/_types/account-abstraction/actions/bundler/getUserOperation.d.ts.map +1 -0
- package/_types/account-abstraction/actions/bundler/getUserOperationReceipt.d.ts +39 -0
- package/_types/account-abstraction/actions/bundler/getUserOperationReceipt.d.ts.map +1 -0
- package/_types/account-abstraction/actions/bundler/prepareUserOperation.d.ts +106 -0
- package/_types/account-abstraction/actions/bundler/prepareUserOperation.d.ts.map +1 -0
- package/_types/account-abstraction/actions/bundler/sendUserOperation.d.ts +60 -0
- package/_types/account-abstraction/actions/bundler/sendUserOperation.d.ts.map +1 -0
- package/_types/account-abstraction/actions/bundler/waitForUserOperationReceipt.d.ts +52 -0
- package/_types/account-abstraction/actions/bundler/waitForUserOperationReceipt.d.ts.map +1 -0
- package/_types/account-abstraction/actions/paymaster/getPaymasterData.d.ts +49 -0
- package/_types/account-abstraction/actions/paymaster/getPaymasterData.d.ts.map +1 -0
- package/_types/account-abstraction/actions/paymaster/getPaymasterStubData.d.ts +55 -0
- package/_types/account-abstraction/actions/paymaster/getPaymasterStubData.d.ts.map +1 -0
- package/_types/account-abstraction/clients/createBundlerClient.d.ts +66 -0
- package/_types/account-abstraction/clients/createBundlerClient.d.ts.map +1 -0
- package/_types/account-abstraction/clients/createPaymasterClient.d.ts +27 -0
- package/_types/account-abstraction/clients/createPaymasterClient.d.ts.map +1 -0
- package/_types/account-abstraction/clients/decorators/bundler.d.ts +206 -0
- package/_types/account-abstraction/clients/decorators/bundler.d.ts.map +1 -0
- package/_types/account-abstraction/clients/decorators/paymaster.d.ts +60 -0
- package/_types/account-abstraction/clients/decorators/paymaster.d.ts.map +1 -0
- package/_types/account-abstraction/constants/abis.d.ts +1468 -0
- package/_types/account-abstraction/constants/abis.d.ts.map +1 -0
- package/_types/account-abstraction/constants/address.d.ts +3 -0
- package/_types/account-abstraction/constants/address.d.ts.map +1 -0
- package/_types/account-abstraction/errors/bundler.d.ts +391 -0
- package/_types/account-abstraction/errors/bundler.d.ts.map +1 -0
- package/_types/account-abstraction/errors/userOperation.d.ts +41 -0
- package/_types/account-abstraction/errors/userOperation.d.ts.map +1 -0
- package/_types/account-abstraction/index.d.ts +34 -0
- package/_types/account-abstraction/index.d.ts.map +1 -0
- package/_types/account-abstraction/types/account.d.ts +11 -0
- package/_types/account-abstraction/types/account.d.ts.map +1 -0
- package/_types/account-abstraction/types/entryPointVersion.d.ts +9 -0
- package/_types/account-abstraction/types/entryPointVersion.d.ts.map +1 -0
- package/_types/account-abstraction/types/rpc.d.ts +9 -0
- package/_types/account-abstraction/types/rpc.d.ts.map +1 -0
- package/_types/account-abstraction/types/userOperation.d.ts +157 -0
- package/_types/account-abstraction/types/userOperation.d.ts.map +1 -0
- package/_types/account-abstraction/utils/errors/getBundlerError.d.ts +8 -0
- package/_types/account-abstraction/utils/errors/getBundlerError.d.ts.map +1 -0
- package/_types/account-abstraction/utils/errors/getUserOperationError.d.ts +15 -0
- package/_types/account-abstraction/utils/errors/getUserOperationError.d.ts.map +1 -0
- package/_types/account-abstraction/utils/formatters/userOperation.d.ts +6 -0
- package/_types/account-abstraction/utils/formatters/userOperation.d.ts.map +1 -0
- package/_types/account-abstraction/utils/formatters/userOperationGas.d.ts +6 -0
- package/_types/account-abstraction/utils/formatters/userOperationGas.d.ts.map +1 -0
- package/_types/account-abstraction/utils/formatters/userOperationReceipt.d.ts +6 -0
- package/_types/account-abstraction/utils/formatters/userOperationReceipt.d.ts.map +1 -0
- package/_types/account-abstraction/utils/formatters/userOperationRequest.d.ts +7 -0
- package/_types/account-abstraction/utils/formatters/userOperationRequest.d.ts.map +1 -0
- package/_types/account-abstraction/utils/userOperation/getUserOperationHash.d.ts +13 -0
- package/_types/account-abstraction/utils/userOperation/getUserOperationHash.d.ts.map +1 -0
- package/_types/account-abstraction/utils/userOperation/toPackedUserOperation.d.ts +3 -0
- package/_types/account-abstraction/utils/userOperation/toPackedUserOperation.d.ts.map +1 -0
- package/_types/accounts/index.d.ts +0 -1
- package/_types/accounts/index.d.ts.map +1 -1
- package/_types/accounts/privateKeyToAccount.d.ts +2 -1
- package/_types/accounts/privateKeyToAccount.d.ts.map +1 -1
- package/_types/accounts/toAccount.d.ts.map +1 -1
- package/_types/accounts/types.d.ts +14 -7
- package/_types/accounts/types.d.ts.map +1 -1
- package/_types/accounts/utils/parseAccount.d.ts +1 -1
- package/_types/accounts/utils/parseAccount.d.ts.map +1 -1
- package/_types/accounts/utils/sign.d.ts +9 -6
- package/_types/accounts/utils/sign.d.ts.map +1 -1
- package/_types/accounts/utils/signMessage.d.ts +1 -2
- package/_types/accounts/utils/signMessage.d.ts.map +1 -1
- package/_types/accounts/utils/signTypedData.d.ts +1 -2
- package/_types/accounts/utils/signTypedData.d.ts.map +1 -1
- package/_types/actions/wallet/sendTransaction.d.ts +2 -1
- package/_types/actions/wallet/sendTransaction.d.ts.map +1 -1
- package/_types/actions/wallet/signMessage.d.ts.map +1 -1
- package/_types/actions/wallet/signTransaction.d.ts.map +1 -1
- package/_types/chains/definitions/lisk.d.ts +2 -2
- package/_types/chains/definitions/playfiAlbireo.d.ts +2 -2
- package/_types/chains/definitions/zkSync.d.ts +2 -2
- package/_types/chains/definitions/zkSyncInMemoryNode.d.ts +2 -2
- package/_types/chains/definitions/zkSyncLocalNode.d.ts +2 -2
- package/_types/chains/definitions/zkSyncSepoliaTestnet.d.ts +2 -2
- package/_types/chains/definitions/zkSyncTestnet.d.ts +2 -2
- package/_types/clients/decorators/public.d.ts +1 -1
- package/_types/clients/decorators/public.d.ts.map +1 -1
- package/_types/constants/abis.d.ts +0 -3
- package/_types/constants/abis.d.ts.map +1 -1
- package/_types/constants/address.d.ts +2 -0
- package/_types/constants/address.d.ts.map +1 -1
- package/_types/errors/account.d.ts +11 -0
- package/_types/errors/account.d.ts.map +1 -1
- package/_types/errors/rpc.d.ts +9 -3
- package/_types/errors/rpc.d.ts.map +1 -1
- package/_types/errors/version.d.ts +1 -1
- package/_types/errors/version.d.ts.map +1 -1
- package/_types/index.d.ts +5 -3
- package/_types/index.d.ts.map +1 -1
- package/_types/types/eip1193.d.ts +239 -2
- package/_types/types/eip1193.d.ts.map +1 -1
- package/_types/types/multicall.d.ts +1 -1
- package/_types/types/multicall.d.ts.map +1 -1
- package/_types/utils/buildRequest.d.ts.map +1 -1
- package/_types/utils/errors/getNodeError.d.ts.map +1 -1
- package/_types/utils/formatters/transaction.d.ts +1 -1
- package/_types/utils/index.d.ts +1 -0
- package/_types/utils/index.d.ts.map +1 -1
- package/_types/utils/signature/hashTypedData.d.ts +2 -2
- package/_types/utils/signature/hashTypedData.d.ts.map +1 -1
- package/_types/utils/signature/serializeErc6492Signature.d.ts +7 -4
- package/_types/utils/signature/serializeErc6492Signature.d.ts.map +1 -1
- package/_types/utils/signature/serializeSignature.d.ts +8 -2
- package/_types/utils/signature/serializeSignature.d.ts.map +1 -1
- package/_types/utils/signature/verifyHash.d.ts +30 -0
- package/_types/utils/signature/verifyHash.d.ts.map +1 -0
- package/_types/zksync/chainConfig.d.ts +2 -2
- package/_types/zksync/formatters.d.ts +2 -2
- package/account-abstraction/accounts/createWebAuthnCredential.ts +7 -0
- package/account-abstraction/accounts/implementations/toCoinbaseSmartAccount.ts +817 -0
- package/account-abstraction/accounts/implementations/toSoladySmartAccount.ts +794 -0
- package/account-abstraction/accounts/toSmartAccount.ts +126 -0
- package/account-abstraction/accounts/toWebAuthnAccount.ts +56 -0
- package/account-abstraction/accounts/types.ts +208 -0
- package/account-abstraction/actions/bundler/estimateUserOperationGas.ts +170 -0
- package/account-abstraction/actions/bundler/getSupportedEntryPoints.ts +33 -0
- package/account-abstraction/actions/bundler/getUserOperation.ts +85 -0
- package/account-abstraction/actions/bundler/getUserOperationReceipt.ts +64 -0
- package/account-abstraction/actions/bundler/prepareUserOperation.ts +637 -0
- package/account-abstraction/actions/bundler/sendUserOperation.ts +149 -0
- package/account-abstraction/actions/bundler/waitForUserOperationReceipt.ts +139 -0
- package/account-abstraction/actions/paymaster/getPaymasterData.ts +135 -0
- package/account-abstraction/actions/paymaster/getPaymasterStubData.ts +138 -0
- package/account-abstraction/clients/createBundlerClient.ts +155 -0
- package/account-abstraction/clients/createPaymasterClient.ts +78 -0
- package/account-abstraction/clients/decorators/bundler.ts +296 -0
- package/account-abstraction/clients/decorators/paymaster.ts +81 -0
- package/account-abstraction/constants/abis.ts +1404 -0
- package/account-abstraction/constants/address.ts +4 -0
- package/account-abstraction/errors/bundler.ts +781 -0
- package/account-abstraction/errors/userOperation.ts +111 -0
- package/account-abstraction/index.ts +228 -0
- package/account-abstraction/package.json +6 -0
- package/account-abstraction/types/account.ts +21 -0
- package/account-abstraction/types/entryPointVersion.ts +24 -0
- package/account-abstraction/types/rpc.ts +29 -0
- package/account-abstraction/types/userOperation.ts +262 -0
- package/account-abstraction/utils/errors/getBundlerError.ts +309 -0
- package/account-abstraction/utils/errors/getUserOperationError.ts +153 -0
- package/account-abstraction/utils/formatters/userOperation.ts +31 -0
- package/account-abstraction/utils/formatters/userOperationGas.ts +26 -0
- package/account-abstraction/utils/formatters/userOperationReceipt.ts +24 -0
- package/account-abstraction/utils/formatters/userOperationRequest.ts +53 -0
- package/account-abstraction/utils/userOperation/getUserOperationHash.ts +138 -0
- package/account-abstraction/utils/userOperation/toPackedUserOperation.ts +64 -0
- package/accounts/index.ts +1 -1
- package/accounts/privateKeyToAccount.ts +5 -0
- package/accounts/toAccount.ts +3 -0
- package/accounts/types.ts +34 -12
- package/accounts/utils/parseAccount.ts +6 -3
- package/accounts/utils/sign.ts +24 -8
- package/accounts/utils/signMessage.ts +1 -7
- package/accounts/utils/signTypedData.ts +2 -7
- package/actions/wallet/sendTransaction.ts +48 -27
- package/actions/wallet/signMessage.ts +2 -1
- package/actions/wallet/signTransaction.ts +1 -2
- package/actions/wallet/signTypedData.ts +1 -1
- package/clients/decorators/public.ts +1 -1
- package/constants/abis.ts +0 -3
- package/constants/address.ts +4 -0
- package/errors/account.ts +22 -1
- package/errors/contract.ts +1 -1
- package/errors/rpc.ts +6 -6
- package/errors/version.ts +1 -1
- package/index.ts +20 -3
- package/package.json +7 -1
- package/types/eip1193.ts +314 -2
- package/types/multicall.ts +1 -1
- package/utils/buildRequest.ts +4 -2
- package/utils/errors/getNodeError.ts +1 -2
- package/utils/index.ts +6 -0
- package/utils/signature/hashTypedData.ts +6 -6
- package/utils/signature/serializeErc6492Signature.ts +17 -8
- package/utils/signature/serializeSignature.ts +24 -4
- package/utils/signature/verifyHash.ts +54 -0
@@ -0,0 +1,323 @@
|
|
1
|
+
import { parseAccount, } from '../../../accounts/utils/parseAccount.js';
|
2
|
+
import { estimateFeesPerGas, } from '../../../actions/public/estimateFeesPerGas.js';
|
3
|
+
import { AccountNotFoundError } from '../../../errors/account.js';
|
4
|
+
import { encodeFunctionData, } from '../../../utils/abi/encodeFunctionData.js';
|
5
|
+
import { concat } from '../../../utils/data/concat.js';
|
6
|
+
import { getAction } from '../../../utils/getAction.js';
|
7
|
+
import { parseGwei } from '../../../utils/unit/parseGwei.js';
|
8
|
+
import { getPaymasterData as getPaymasterData_, } from '../paymaster/getPaymasterData.js';
|
9
|
+
import { getPaymasterStubData as getPaymasterStubData_, } from '../paymaster/getPaymasterStubData.js';
|
10
|
+
import { estimateUserOperationGas, } from './estimateUserOperationGas.js';
|
11
|
+
const defaultParameters = [
|
12
|
+
'factory',
|
13
|
+
'fees',
|
14
|
+
'gas',
|
15
|
+
'paymaster',
|
16
|
+
'nonce',
|
17
|
+
'signature',
|
18
|
+
];
|
19
|
+
/**
|
20
|
+
* Prepares a User Operation and fills in missing properties.
|
21
|
+
*
|
22
|
+
* - Docs: https://viem.sh/actions/bundler/prepareUserOperation
|
23
|
+
*
|
24
|
+
* @param args - {@link PrepareUserOperationParameters}
|
25
|
+
* @returns The User Operation. {@link PrepareUserOperationReturnType}
|
26
|
+
*
|
27
|
+
* @example
|
28
|
+
* import { createBundlerClient, http } from 'viem'
|
29
|
+
* import { toSmartAccount } from 'viem/accounts'
|
30
|
+
* import { mainnet } from 'viem/chains'
|
31
|
+
* import { prepareUserOperation } from 'viem/actions'
|
32
|
+
*
|
33
|
+
* const account = await toSmartAccount({ ... })
|
34
|
+
*
|
35
|
+
* const client = createBundlerClient({
|
36
|
+
* chain: mainnet,
|
37
|
+
* transport: http(),
|
38
|
+
* })
|
39
|
+
*
|
40
|
+
* const request = await prepareUserOperation(client, {
|
41
|
+
* account,
|
42
|
+
* calls: [{ to: '0x...', value: parseEther('1') }],
|
43
|
+
* })
|
44
|
+
*/
|
45
|
+
export async function prepareUserOperation(client, parameters_) {
|
46
|
+
const parameters = parameters_;
|
47
|
+
const { account: account_ = client.account, parameters: properties = defaultParameters, } = parameters;
|
48
|
+
////////////////////////////////////////////////////////////////////////////////
|
49
|
+
// Assert that an Account is defined.
|
50
|
+
////////////////////////////////////////////////////////////////////////////////
|
51
|
+
if (!account_)
|
52
|
+
throw new AccountNotFoundError();
|
53
|
+
const account = parseAccount(account_);
|
54
|
+
////////////////////////////////////////////////////////////////////////////////
|
55
|
+
// Declare typed Bundler Client.
|
56
|
+
////////////////////////////////////////////////////////////////////////////////
|
57
|
+
const bundlerClient = client;
|
58
|
+
////////////////////////////////////////////////////////////////////////////////
|
59
|
+
// Declare Paymaster properties.
|
60
|
+
////////////////////////////////////////////////////////////////////////////////
|
61
|
+
const paymaster = parameters.paymaster ?? bundlerClient?.paymaster;
|
62
|
+
const paymasterAddress = typeof paymaster === 'string' ? paymaster : undefined;
|
63
|
+
const { getPaymasterStubData, getPaymasterData } = (() => {
|
64
|
+
// If `paymaster: true`, we will assume the Bundler Client supports Paymaster Actions.
|
65
|
+
if (paymaster === true)
|
66
|
+
return {
|
67
|
+
getPaymasterStubData: (parameters) => getAction(bundlerClient, getPaymasterStubData_, 'getPaymasterStubData')(parameters),
|
68
|
+
getPaymasterData: (parameters) => getAction(bundlerClient, getPaymasterData_, 'getPaymasterData')(parameters),
|
69
|
+
};
|
70
|
+
// If Actions are passed to `paymaster` (via Paymaster Client or directly), we will use them.
|
71
|
+
if (typeof paymaster === 'object') {
|
72
|
+
const { getPaymasterStubData, getPaymasterData } = paymaster;
|
73
|
+
return {
|
74
|
+
getPaymasterStubData: (getPaymasterData && getPaymasterStubData
|
75
|
+
? getPaymasterStubData
|
76
|
+
: getPaymasterData),
|
77
|
+
getPaymasterData: getPaymasterData && getPaymasterStubData
|
78
|
+
? getPaymasterData
|
79
|
+
: undefined,
|
80
|
+
};
|
81
|
+
}
|
82
|
+
// No Paymaster functions.
|
83
|
+
return {
|
84
|
+
getPaymasterStubData: undefined,
|
85
|
+
getPaymasterData: undefined,
|
86
|
+
};
|
87
|
+
})();
|
88
|
+
const paymasterContext = parameters.paymasterContext
|
89
|
+
? parameters.paymasterContext
|
90
|
+
: bundlerClient?.paymasterContext;
|
91
|
+
////////////////////////////////////////////////////////////////////////////////
|
92
|
+
// Set up the User Operation request.
|
93
|
+
////////////////////////////////////////////////////////////////////////////////
|
94
|
+
let request = {
|
95
|
+
...parameters,
|
96
|
+
paymaster: paymasterAddress,
|
97
|
+
sender: account.address,
|
98
|
+
};
|
99
|
+
////////////////////////////////////////////////////////////////////////////////
|
100
|
+
// Concurrently prepare properties required to fill the User Operation.
|
101
|
+
////////////////////////////////////////////////////////////////////////////////
|
102
|
+
const [callData, factory, fees, nonce, signature] = await Promise.all([
|
103
|
+
(async () => {
|
104
|
+
if (parameters.calls)
|
105
|
+
return account.encodeCalls(parameters.calls.map((call_) => {
|
106
|
+
const call = call_;
|
107
|
+
if ('abi' in call)
|
108
|
+
return {
|
109
|
+
data: encodeFunctionData(call),
|
110
|
+
to: call.to,
|
111
|
+
value: call.value,
|
112
|
+
};
|
113
|
+
return call;
|
114
|
+
}));
|
115
|
+
return parameters.callData;
|
116
|
+
})(),
|
117
|
+
(async () => {
|
118
|
+
if (!properties.includes('factory'))
|
119
|
+
return undefined;
|
120
|
+
if (parameters.initCode)
|
121
|
+
return { initCode: parameters.initCode };
|
122
|
+
if (parameters.factory && parameters.factoryData) {
|
123
|
+
return {
|
124
|
+
factory: parameters.factory,
|
125
|
+
factoryData: parameters.factoryData,
|
126
|
+
};
|
127
|
+
}
|
128
|
+
const { factory, factoryData } = await account.getFactoryArgs();
|
129
|
+
if (account.entryPoint.version === '0.6')
|
130
|
+
return {
|
131
|
+
initCode: factory && factoryData ? concat([factory, factoryData]) : undefined,
|
132
|
+
};
|
133
|
+
return {
|
134
|
+
factory,
|
135
|
+
factoryData,
|
136
|
+
};
|
137
|
+
})(),
|
138
|
+
(async () => {
|
139
|
+
if (!properties.includes('fees'))
|
140
|
+
return undefined;
|
141
|
+
// If the Bundler Client has a `estimateFeesPerGas` hook, run it.
|
142
|
+
if (bundlerClient?.userOperation?.estimateFeesPerGas) {
|
143
|
+
const fees = await bundlerClient.userOperation.estimateFeesPerGas({
|
144
|
+
account,
|
145
|
+
bundlerClient,
|
146
|
+
userOperation: request,
|
147
|
+
});
|
148
|
+
request = {
|
149
|
+
...request,
|
150
|
+
...fees,
|
151
|
+
};
|
152
|
+
}
|
153
|
+
// If we have sufficient properties for fees, return them.
|
154
|
+
if (typeof parameters.maxFeePerGas === 'bigint' &&
|
155
|
+
typeof parameters.maxPriorityFeePerGas === 'bigint')
|
156
|
+
return request;
|
157
|
+
// Otherwise, we will need to estimate the fees to fill the fee properties.
|
158
|
+
try {
|
159
|
+
const client_ = 'client' in client ? client.client : client;
|
160
|
+
const fees = await getAction(client_, estimateFeesPerGas, 'estimateFeesPerGas')({
|
161
|
+
chain: client_.chain,
|
162
|
+
type: 'eip1559',
|
163
|
+
});
|
164
|
+
return {
|
165
|
+
maxFeePerGas: typeof parameters.maxFeePerGas === 'bigint'
|
166
|
+
? parameters.maxFeePerGas
|
167
|
+
: BigInt(
|
168
|
+
// Bundlers unfortunately have strict rules on fee prechecks – we will need to set a generous buffer.
|
169
|
+
Math.max(Number(2n * fees.maxFeePerGas), Number(parseGwei('3')))),
|
170
|
+
maxPriorityFeePerGas: typeof parameters.maxPriorityFeePerGas === 'bigint'
|
171
|
+
? parameters.maxPriorityFeePerGas
|
172
|
+
: BigInt(
|
173
|
+
// Bundlers unfortunately have strict rules on fee prechecks – we will need to set a generous buffer.
|
174
|
+
Math.max(Number(2n * fees.maxPriorityFeePerGas), Number(parseGwei('1')))),
|
175
|
+
};
|
176
|
+
}
|
177
|
+
catch {
|
178
|
+
return undefined;
|
179
|
+
}
|
180
|
+
})(),
|
181
|
+
(async () => {
|
182
|
+
if (!properties.includes('nonce'))
|
183
|
+
return undefined;
|
184
|
+
if (typeof parameters.nonce === 'bigint')
|
185
|
+
return parameters.nonce;
|
186
|
+
return account.getNonce();
|
187
|
+
})(),
|
188
|
+
(async () => {
|
189
|
+
if (!properties.includes('signature'))
|
190
|
+
return undefined;
|
191
|
+
return account.getStubSignature();
|
192
|
+
})(),
|
193
|
+
]);
|
194
|
+
////////////////////////////////////////////////////////////////////////////////
|
195
|
+
// Fill User Operation with the prepared properties from above.
|
196
|
+
////////////////////////////////////////////////////////////////////////////////
|
197
|
+
if (typeof callData !== 'undefined')
|
198
|
+
request.callData = callData;
|
199
|
+
if (typeof factory !== 'undefined')
|
200
|
+
request = { ...request, ...factory };
|
201
|
+
if (typeof fees !== 'undefined')
|
202
|
+
request = { ...request, ...fees };
|
203
|
+
if (typeof nonce !== 'undefined')
|
204
|
+
request.nonce = nonce;
|
205
|
+
if (typeof signature !== 'undefined')
|
206
|
+
request.signature = signature;
|
207
|
+
////////////////////////////////////////////////////////////////////////////////
|
208
|
+
// `initCode` is required to be filled with EntryPoint 0.6.
|
209
|
+
////////////////////////////////////////////////////////////////////////////////
|
210
|
+
// If no `initCode` is provided, we use an empty bytes string.
|
211
|
+
if (account.entryPoint.version === '0.6' && !request.initCode)
|
212
|
+
request.initCode = '0x';
|
213
|
+
////////////////////////////////////////////////////////////////////////////////
|
214
|
+
// Fill User Operation with paymaster-related properties for **gas estimation**.
|
215
|
+
////////////////////////////////////////////////////////////////////////////////
|
216
|
+
// console.log('wat')
|
217
|
+
// If the User Operation is intended to be sponsored, we will need to fill the paymaster-related
|
218
|
+
// User Operation properties required to estimate the User Operation gas.
|
219
|
+
let isPaymasterPopulated = false;
|
220
|
+
if (properties.includes('paymaster') &&
|
221
|
+
getPaymasterStubData &&
|
222
|
+
!paymasterAddress &&
|
223
|
+
!parameters.paymasterAndData) {
|
224
|
+
const { isFinal = false, sponsor, ...paymasterArgs } = await getPaymasterStubData({
|
225
|
+
chainId: client.chain.id,
|
226
|
+
entryPointAddress: account.entryPoint.address,
|
227
|
+
context: paymasterContext,
|
228
|
+
...request,
|
229
|
+
});
|
230
|
+
isPaymasterPopulated = isFinal;
|
231
|
+
request = {
|
232
|
+
...request,
|
233
|
+
...paymasterArgs,
|
234
|
+
};
|
235
|
+
}
|
236
|
+
////////////////////////////////////////////////////////////////////////////////
|
237
|
+
// `paymasterAndData` is required to be filled with EntryPoint 0.6.
|
238
|
+
////////////////////////////////////////////////////////////////////////////////
|
239
|
+
// If no `paymasterAndData` is provided, we use an empty bytes string.
|
240
|
+
if (account.entryPoint.version === '0.6' && !request.paymasterAndData)
|
241
|
+
request.paymasterAndData = '0x';
|
242
|
+
////////////////////////////////////////////////////////////////////////////////
|
243
|
+
// Fill User Operation with gas-related properties.
|
244
|
+
////////////////////////////////////////////////////////////////////////////////
|
245
|
+
if (properties.includes('gas')) {
|
246
|
+
// If the Account has opinionated gas estimation logic, run the `estimateGas` hook and
|
247
|
+
// fill the request with the prepared gas properties.
|
248
|
+
if (account.userOperation?.estimateGas) {
|
249
|
+
const gas = await account.userOperation.estimateGas(request);
|
250
|
+
request = {
|
251
|
+
...request,
|
252
|
+
...gas,
|
253
|
+
};
|
254
|
+
}
|
255
|
+
// If not all the gas properties are already populated, we will need to estimate the gas
|
256
|
+
// to fill the gas properties.
|
257
|
+
if (typeof request.callGasLimit === 'undefined' ||
|
258
|
+
typeof request.preVerificationGas === 'undefined' ||
|
259
|
+
typeof request.verificationGasLimit === 'undefined' ||
|
260
|
+
(request.paymaster &&
|
261
|
+
typeof request.paymasterPostOpGasLimit === 'undefined') ||
|
262
|
+
(request.paymaster &&
|
263
|
+
typeof request.paymasterVerificationGasLimit === 'undefined')) {
|
264
|
+
const gas = await getAction(client, estimateUserOperationGas, 'estimateUserOperationGas')({
|
265
|
+
account,
|
266
|
+
// Some Bundlers fail if nullish gas values are provided for gas estimation :') –
|
267
|
+
// so we will need to set a default zeroish value.
|
268
|
+
callGasLimit: 0n,
|
269
|
+
preVerificationGas: 0n,
|
270
|
+
verificationGasLimit: 0n,
|
271
|
+
...(request.paymaster
|
272
|
+
? {
|
273
|
+
paymasterPostOpGasLimit: 0n,
|
274
|
+
paymasterVerificationGasLimit: 0n,
|
275
|
+
}
|
276
|
+
: {}),
|
277
|
+
...request,
|
278
|
+
});
|
279
|
+
request = {
|
280
|
+
...request,
|
281
|
+
callGasLimit: request.callGasLimit ?? gas.callGasLimit,
|
282
|
+
preVerificationGas: request.preVerificationGas ?? gas.preVerificationGas,
|
283
|
+
verificationGasLimit: request.verificationGasLimit ?? gas.verificationGasLimit,
|
284
|
+
paymasterPostOpGasLimit: request.paymasterPostOpGasLimit ?? gas.paymasterPostOpGasLimit,
|
285
|
+
paymasterVerificationGasLimit: request.paymasterVerificationGasLimit ??
|
286
|
+
gas.paymasterVerificationGasLimit,
|
287
|
+
};
|
288
|
+
}
|
289
|
+
}
|
290
|
+
////////////////////////////////////////////////////////////////////////////////
|
291
|
+
// Fill User Operation with paymaster-related properties for **sending** the User Operation.
|
292
|
+
////////////////////////////////////////////////////////////////////////////////
|
293
|
+
// If the User Operation is intended to be sponsored, we will need to fill the paymaster-related
|
294
|
+
// User Operation properties required to send the User Operation.
|
295
|
+
if (properties.includes('paymaster') &&
|
296
|
+
getPaymasterData &&
|
297
|
+
!paymasterAddress &&
|
298
|
+
!parameters.paymasterAndData &&
|
299
|
+
!isPaymasterPopulated) {
|
300
|
+
// Retrieve paymaster-related User Operation properties to be used for **sending** the User Operation.
|
301
|
+
const paymaster = await getPaymasterData({
|
302
|
+
chainId: client.chain.id,
|
303
|
+
entryPointAddress: account.entryPoint.address,
|
304
|
+
context: paymasterContext,
|
305
|
+
...request,
|
306
|
+
});
|
307
|
+
request = {
|
308
|
+
...request,
|
309
|
+
...paymaster,
|
310
|
+
};
|
311
|
+
}
|
312
|
+
////////////////////////////////////////////////////////////////////////////////
|
313
|
+
// Remove redundant properties that do not conform to the User Operation schema.
|
314
|
+
////////////////////////////////////////////////////////////////////////////////
|
315
|
+
delete request.calls;
|
316
|
+
delete request.parameters;
|
317
|
+
delete request.paymasterContext;
|
318
|
+
if (typeof request.paymaster !== 'string')
|
319
|
+
delete request.paymaster;
|
320
|
+
////////////////////////////////////////////////////////////////////////////////
|
321
|
+
return request;
|
322
|
+
}
|
323
|
+
//# sourceMappingURL=prepareUserOperation.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"prepareUserOperation.js","sourceRoot":"","sources":["../../../../account-abstraction/actions/bundler/prepareUserOperation.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,60 @@
|
|
1
|
+
import { parseAccount } from '../../../accounts/utils/parseAccount.js';
|
2
|
+
import { AccountNotFoundError } from '../../../errors/account.js';
|
3
|
+
import { getAction } from '../../../utils/getAction.js';
|
4
|
+
import { getUserOperationError } from '../../utils/errors/getUserOperationError.js';
|
5
|
+
import { formatUserOperationRequest, } from '../../utils/formatters/userOperationRequest.js';
|
6
|
+
import { prepareUserOperation, } from './prepareUserOperation.js';
|
7
|
+
/**
|
8
|
+
* Broadcasts a User Operation to the Bundler.
|
9
|
+
*
|
10
|
+
* - Docs: https://viem.sh/actions/bundler/sendUserOperation
|
11
|
+
*
|
12
|
+
* @param client - Client to use
|
13
|
+
* @param parameters - {@link SendUserOperationParameters}
|
14
|
+
* @returns The User Operation hash. {@link SendUserOperationReturnType}
|
15
|
+
*
|
16
|
+
* @example
|
17
|
+
* import { createBundlerClient, http, parseEther } from 'viem'
|
18
|
+
* import { mainnet } from 'viem/chains'
|
19
|
+
* import { toSmartAccount } from 'viem/accounts'
|
20
|
+
* import { sendUserOperation } from 'viem/actions'
|
21
|
+
*
|
22
|
+
* const account = await toSmartAccount({ ... })
|
23
|
+
*
|
24
|
+
* const bundlerClient = createBundlerClient({
|
25
|
+
* chain: mainnet,
|
26
|
+
* transport: http(),
|
27
|
+
* })
|
28
|
+
*
|
29
|
+
* const values = await sendUserOperation(bundlerClient, {
|
30
|
+
* account,
|
31
|
+
* calls: [{ to: '0x...', value: parseEther('1') }],
|
32
|
+
* })
|
33
|
+
*/
|
34
|
+
export async function sendUserOperation(client, parameters) {
|
35
|
+
const { account: account_ = client.account } = parameters;
|
36
|
+
if (!account_)
|
37
|
+
throw new AccountNotFoundError();
|
38
|
+
const account = parseAccount(account_);
|
39
|
+
const request = await getAction(client, prepareUserOperation, 'prepareUserOperation')(parameters);
|
40
|
+
const signature = parameters.signature ||
|
41
|
+
(await account.signUserOperation(request));
|
42
|
+
const rpcParameters = formatUserOperationRequest({
|
43
|
+
...request,
|
44
|
+
signature,
|
45
|
+
});
|
46
|
+
try {
|
47
|
+
return await client.request({
|
48
|
+
method: 'eth_sendUserOperation',
|
49
|
+
params: [rpcParameters, account.entryPoint.address],
|
50
|
+
}, { retryCount: 0 });
|
51
|
+
}
|
52
|
+
catch (error) {
|
53
|
+
throw getUserOperationError(error, {
|
54
|
+
...request,
|
55
|
+
calls: parameters.calls,
|
56
|
+
signature,
|
57
|
+
});
|
58
|
+
}
|
59
|
+
}
|
60
|
+
//# sourceMappingURL=sendUserOperation.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"sendUserOperation.js","sourceRoot":"","sources":["../../../../account-abstraction/actions/bundler/sendUserOperation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,yCAAyC,CAAA;AAGtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAA;AAOjE,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAA;AAgBvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,6CAA6C,CAAA;AACnF,OAAO,EAEL,0BAA0B,GAC3B,MAAM,gDAAgD,CAAA;AACvD,OAAO,EAGL,oBAAoB,GACrB,MAAM,2BAA2B,CAAA;AA0ClC;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAKrC,MAAqD,EACrD,UAAwE;IAExE,MAAM,EAAE,OAAO,EAAE,QAAQ,GAAG,MAAM,CAAC,OAAO,EAAE,GAAG,UAAU,CAAA;IAEzD,IAAI,CAAC,QAAQ;QAAE,MAAM,IAAI,oBAAoB,EAAE,CAAA;IAC/C,MAAM,OAAO,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAA;IAEtC,MAAM,OAAO,GAAG,MAAM,SAAS,CAC7B,MAAM,EACN,oBAAoB,EACpB,sBAAsB,CACvB,CAAC,UAAuD,CAAC,CAAA;IAE1D,MAAM,SAAS,GACb,UAAU,CAAC,SAAS;QACpB,CAAC,MAAM,OAAO,CAAC,iBAAiB,CAAC,OAAwB,CAAC,CAAC,CAAA;IAE7D,MAAM,aAAa,GAAG,0BAA0B,CAAC;QAC/C,GAAG,OAAO;QACV,SAAS;KACO,CAAC,CAAA;IAEnB,IAAI,CAAC;QACH,OAAO,MAAM,MAAM,CAAC,OAAO,CACzB;YACE,MAAM,EAAE,uBAAuB;YAC/B,MAAM,EAAE,CAAC,aAAa,EAAE,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC;SACpD,EACD,EAAE,UAAU,EAAE,CAAC,EAAE,CAClB,CAAA;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,qBAAqB,CAAC,KAAkB,EAAE;YAC9C,GAAI,OAAyB;YAC7B,KAAK,EAAE,UAAU,CAAC,KAAK;YACvB,SAAS;SACV,CAAC,CAAA;IACJ,CAAC;AACH,CAAC"}
|
@@ -0,0 +1,68 @@
|
|
1
|
+
import { getAction } from '../../../utils/getAction.js';
|
2
|
+
import { observe } from '../../../utils/observe.js';
|
3
|
+
import { poll } from '../../../utils/poll.js';
|
4
|
+
import { stringify } from '../../../utils/stringify.js';
|
5
|
+
import { WaitForUserOperationReceiptTimeoutError, } from '../../errors/userOperation.js';
|
6
|
+
import { getUserOperationReceipt, } from './getUserOperationReceipt.js';
|
7
|
+
/**
|
8
|
+
* Waits for the User Operation to be included on a [Block](https://viem.sh/docs/glossary/terms#block) (one confirmation), and then returns the User Operation receipt.
|
9
|
+
*
|
10
|
+
* - Docs: https://viem.sh/docs/actions/bundler/waitForUserOperationReceipt
|
11
|
+
*
|
12
|
+
* @param client - Client to use
|
13
|
+
* @param parameters - {@link WaitForUserOperationReceiptParameters}
|
14
|
+
* @returns The receipt. {@link WaitForUserOperationReceiptReturnType}
|
15
|
+
*
|
16
|
+
* @example
|
17
|
+
* import { createBundlerClient, http } from 'viem'
|
18
|
+
* import { mainnet } from 'viem/chains'
|
19
|
+
* import { waitForUserOperationReceipt } from 'viem/actions'
|
20
|
+
*
|
21
|
+
* const client = createBundlerClient({
|
22
|
+
* chain: mainnet,
|
23
|
+
* transport: http(),
|
24
|
+
* })
|
25
|
+
*
|
26
|
+
* const receipt = await waitForUserOperationReceipt(client, {
|
27
|
+
* hash: '0x4ca7ee652d57678f26e887c149ab0735f41de37bcad58c9f6d3ed5824f15b74d',
|
28
|
+
* })
|
29
|
+
*/
|
30
|
+
export function waitForUserOperationReceipt(client, parameters) {
|
31
|
+
const { hash, pollingInterval = client.pollingInterval, retryCount, timeout = 120_000, } = parameters;
|
32
|
+
let count = 0;
|
33
|
+
const observerId = stringify([
|
34
|
+
'waitForUserOperationReceipt',
|
35
|
+
client.uid,
|
36
|
+
hash,
|
37
|
+
]);
|
38
|
+
return new Promise((resolve, reject) => {
|
39
|
+
const unobserve = observe(observerId, { resolve, reject }, (emit) => {
|
40
|
+
const done = (fn) => {
|
41
|
+
unpoll();
|
42
|
+
fn();
|
43
|
+
unobserve();
|
44
|
+
};
|
45
|
+
const unpoll = poll(async () => {
|
46
|
+
if (retryCount && count >= retryCount)
|
47
|
+
done(() => emit.reject(new WaitForUserOperationReceiptTimeoutError({ hash })));
|
48
|
+
try {
|
49
|
+
const receipt = await getAction(client, getUserOperationReceipt, 'getUserOperationReceipt')({ hash });
|
50
|
+
done(() => emit.resolve(receipt));
|
51
|
+
}
|
52
|
+
catch (err) {
|
53
|
+
const error = err;
|
54
|
+
if (error.name !== 'UserOperationReceiptNotFoundError')
|
55
|
+
done(() => emit.reject(error));
|
56
|
+
}
|
57
|
+
count++;
|
58
|
+
}, {
|
59
|
+
emitOnBegin: true,
|
60
|
+
interval: pollingInterval,
|
61
|
+
});
|
62
|
+
if (timeout)
|
63
|
+
setTimeout(() => done(() => emit.reject(new WaitForUserOperationReceiptTimeoutError({ hash }))), timeout);
|
64
|
+
return unpoll;
|
65
|
+
});
|
66
|
+
});
|
67
|
+
}
|
68
|
+
//# sourceMappingURL=waitForUserOperationReceipt.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"waitForUserOperationReceipt.js","sourceRoot":"","sources":["../../../../account-abstraction/actions/bundler/waitForUserOperationReceipt.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAA;AACvD,OAAO,EAAyB,OAAO,EAAE,MAAM,2BAA2B,CAAA;AAC1E,OAAO,EAAsB,IAAI,EAAE,MAAM,wBAAwB,CAAA;AACjE,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAA;AACvD,OAAO,EACL,uCAAuC,GAExC,MAAM,+BAA+B,CAAA;AAEtC,OAAO,EAEL,uBAAuB,GACxB,MAAM,8BAA8B,CAAA;AA4BrC;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,UAAU,2BAA2B,CACzC,MAAyB,EACzB,UAAiD;IAEjD,MAAM,EACJ,IAAI,EACJ,eAAe,GAAG,MAAM,CAAC,eAAe,EACxC,UAAU,EACV,OAAO,GAAG,OAAO,GAClB,GAAG,UAAU,CAAA;IAEd,IAAI,KAAK,GAAG,CAAC,CAAA;IACb,MAAM,UAAU,GAAG,SAAS,CAAC;QAC3B,6BAA6B;QAC7B,MAAM,CAAC,GAAG;QACV,IAAI;KACL,CAAC,CAAA;IAEF,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,SAAS,GAAG,OAAO,CAAC,UAAU,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE;YAClE,MAAM,IAAI,GAAG,CAAC,EAAc,EAAE,EAAE;gBAC9B,MAAM,EAAE,CAAA;gBACR,EAAE,EAAE,CAAA;gBACJ,SAAS,EAAE,CAAA;YACb,CAAC,CAAA;YAED,MAAM,MAAM,GAAG,IAAI,CACjB,KAAK,IAAI,EAAE;gBACT,IAAI,UAAU,IAAI,KAAK,IAAI,UAAU;oBACnC,IAAI,CAAC,GAAG,EAAE,CACR,IAAI,CAAC,MAAM,CACT,IAAI,uCAAuC,CAAC,EAAE,IAAI,EAAE,CAAC,CACtD,CACF,CAAA;gBAEH,IAAI,CAAC;oBACH,MAAM,OAAO,GAAG,MAAM,SAAS,CAC7B,MAAM,EACN,uBAAuB,EACvB,yBAAyB,CAC1B,CAAC,EAAE,IAAI,EAAE,CAAC,CAAA;oBACX,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAA;gBACnC,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,MAAM,KAAK,GAAG,GAAuC,CAAA;oBACrD,IAAI,KAAK,CAAC,IAAI,KAAK,mCAAmC;wBACpD,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;gBAClC,CAAC;gBAED,KAAK,EAAE,CAAA;YACT,CAAC,EACD;gBACE,WAAW,EAAE,IAAI;gBACjB,QAAQ,EAAE,eAAe;aAC1B,CACF,CAAA;YAED,IAAI,OAAO;gBACT,UAAU,CACR,GAAG,EAAE,CACH,IAAI,CAAC,GAAG,EAAE,CACR,IAAI,CAAC,MAAM,CACT,IAAI,uCAAuC,CAAC,EAAE,IAAI,EAAE,CAAC,CACtD,CACF,EACH,OAAO,CACR,CAAA;YAEH,OAAO,MAAM,CAAA;QACf,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC"}
|
@@ -0,0 +1,56 @@
|
|
1
|
+
import { hexToBigInt } from '../../../utils/encoding/fromHex.js';
|
2
|
+
import { numberToHex } from '../../../utils/encoding/toHex.js';
|
3
|
+
import { formatUserOperationRequest, } from '../../utils/formatters/userOperationRequest.js';
|
4
|
+
/**
|
5
|
+
* Retrieves paymaster-related User Operation properties to be used for sending the User Operation.
|
6
|
+
*
|
7
|
+
* - Docs: https://viem.sh/account-abstraction/actions/paymaster/getPaymasterData
|
8
|
+
*
|
9
|
+
* @param client - Client to use
|
10
|
+
* @param parameters - {@link GetPaymasterDataParameters}
|
11
|
+
* @returns Paymaster-related User Operation properties. {@link GetPaymasterDataReturnType}
|
12
|
+
*
|
13
|
+
* @example
|
14
|
+
* import { http } from 'viem'
|
15
|
+
* import { createPaymasterClient, getPaymasterData } from 'viem/account-abstraction'
|
16
|
+
*
|
17
|
+
* const paymasterClient = createPaymasterClient({
|
18
|
+
* transport: http('https://...'),
|
19
|
+
* })
|
20
|
+
*
|
21
|
+
* const userOperation = { ... }
|
22
|
+
*
|
23
|
+
* const values = await getPaymasterData(paymasterClient, {
|
24
|
+
* chainId: 1,
|
25
|
+
* entryPointAddress: '0x...',
|
26
|
+
* ...userOperation,
|
27
|
+
* })
|
28
|
+
*/
|
29
|
+
export async function getPaymasterData(client, parameters) {
|
30
|
+
const { chainId, entryPointAddress, context, ...userOperation } = parameters;
|
31
|
+
const request = formatUserOperationRequest(userOperation);
|
32
|
+
const { paymasterPostOpGasLimit, paymasterVerificationGasLimit, ...rest } = await client.request({
|
33
|
+
method: 'pm_getPaymasterData',
|
34
|
+
params: [
|
35
|
+
{
|
36
|
+
...request,
|
37
|
+
callGasLimit: request.callGasLimit ?? '0x0',
|
38
|
+
verificationGasLimit: request.verificationGasLimit ?? '0x0',
|
39
|
+
preVerificationGas: request.preVerificationGas ?? '0x0',
|
40
|
+
},
|
41
|
+
entryPointAddress,
|
42
|
+
numberToHex(chainId),
|
43
|
+
context,
|
44
|
+
],
|
45
|
+
});
|
46
|
+
return {
|
47
|
+
...rest,
|
48
|
+
...(paymasterPostOpGasLimit && {
|
49
|
+
paymasterPostOpGasLimit: hexToBigInt(paymasterPostOpGasLimit),
|
50
|
+
}),
|
51
|
+
...(paymasterVerificationGasLimit && {
|
52
|
+
paymasterVerificationGasLimit: hexToBigInt(paymasterVerificationGasLimit),
|
53
|
+
}),
|
54
|
+
};
|
55
|
+
}
|
56
|
+
//# sourceMappingURL=getPaymasterData.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"getPaymasterData.js","sourceRoot":"","sources":["../../../../account-abstraction/actions/paymaster/getPaymasterData.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAA;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAA;AAE9D,OAAO,EAEL,0BAA0B,GAC3B,MAAM,gDAAgD,CAAA;AAmEvD;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,MAAyB,EACzB,UAAsC;IAEtC,MAAM,EAAE,OAAO,EAAE,iBAAiB,EAAE,OAAO,EAAE,GAAG,aAAa,EAAE,GAAG,UAAU,CAAA;IAC5E,MAAM,OAAO,GAAG,0BAA0B,CAAC,aAAa,CAAC,CAAA;IACzD,MAAM,EAAE,uBAAuB,EAAE,6BAA6B,EAAE,GAAG,IAAI,EAAE,GACvE,MAAM,MAAM,CAAC,OAAO,CAAC;QACnB,MAAM,EAAE,qBAAqB;QAC7B,MAAM,EAAE;YACN;gBACE,GAAG,OAAO;gBACV,YAAY,EAAE,OAAO,CAAC,YAAY,IAAI,KAAK;gBAC3C,oBAAoB,EAAE,OAAO,CAAC,oBAAoB,IAAI,KAAK;gBAC3D,kBAAkB,EAAE,OAAO,CAAC,kBAAkB,IAAI,KAAK;aACxD;YACD,iBAAiB;YACjB,WAAW,CAAC,OAAO,CAAC;YACpB,OAAO;SACR;KACF,CAAC,CAAA;IACJ,OAAO;QACL,GAAG,IAAI;QACP,GAAG,CAAC,uBAAuB,IAAI;YAC7B,uBAAuB,EAAE,WAAW,CAAC,uBAAuB,CAAC;SAC9D,CAAC;QACF,GAAG,CAAC,6BAA6B,IAAI;YACnC,6BAA6B,EAAE,WAAW,CAAC,6BAA6B,CAAC;SAC1E,CAAC;KACsC,CAAA;AAC5C,CAAC"}
|
@@ -0,0 +1,56 @@
|
|
1
|
+
import { hexToBigInt } from '../../../utils/encoding/fromHex.js';
|
2
|
+
import { numberToHex } from '../../../utils/encoding/toHex.js';
|
3
|
+
import { formatUserOperationRequest, } from '../../utils/formatters/userOperationRequest.js';
|
4
|
+
/**
|
5
|
+
* Retrieves paymaster-related User Operation properties to be used for gas estimation.
|
6
|
+
*
|
7
|
+
* - Docs: https://viem.sh/account-abstraction/actions/paymaster/getPaymasterStubData
|
8
|
+
*
|
9
|
+
* @param client - Client to use
|
10
|
+
* @param parameters - {@link GetPaymasterStubDataParameters}
|
11
|
+
* @returns Paymaster-related User Operation properties. {@link GetPaymasterStubDataReturnType}
|
12
|
+
*
|
13
|
+
* @example
|
14
|
+
* import { http } from 'viem'
|
15
|
+
* import { createPaymasterClient, getPaymasterStubData } from 'viem/account-abstraction'
|
16
|
+
*
|
17
|
+
* const paymasterClient = createPaymasterClient({
|
18
|
+
* transport: http('https://...'),
|
19
|
+
* })
|
20
|
+
*
|
21
|
+
* const userOperation = { ... }
|
22
|
+
*
|
23
|
+
* const values = await getPaymasterStubData(paymasterClient, {
|
24
|
+
* chainId: 1,
|
25
|
+
* entryPointAddress: '0x...',
|
26
|
+
* ...userOperation,
|
27
|
+
* })
|
28
|
+
*/
|
29
|
+
export async function getPaymasterStubData(client, parameters) {
|
30
|
+
const { chainId, entryPointAddress, context, ...userOperation } = parameters;
|
31
|
+
const request = formatUserOperationRequest(userOperation);
|
32
|
+
const { paymasterPostOpGasLimit, paymasterVerificationGasLimit, ...rest } = await client.request({
|
33
|
+
method: 'pm_getPaymasterStubData',
|
34
|
+
params: [
|
35
|
+
{
|
36
|
+
...request,
|
37
|
+
callGasLimit: request.callGasLimit ?? '0x0',
|
38
|
+
verificationGasLimit: request.verificationGasLimit ?? '0x0',
|
39
|
+
preVerificationGas: request.preVerificationGas ?? '0x0',
|
40
|
+
},
|
41
|
+
entryPointAddress,
|
42
|
+
numberToHex(chainId),
|
43
|
+
context,
|
44
|
+
],
|
45
|
+
});
|
46
|
+
return {
|
47
|
+
...rest,
|
48
|
+
...(paymasterPostOpGasLimit && {
|
49
|
+
paymasterPostOpGasLimit: hexToBigInt(paymasterPostOpGasLimit),
|
50
|
+
}),
|
51
|
+
...(paymasterVerificationGasLimit && {
|
52
|
+
paymasterVerificationGasLimit: hexToBigInt(paymasterVerificationGasLimit),
|
53
|
+
}),
|
54
|
+
};
|
55
|
+
}
|
56
|
+
//# sourceMappingURL=getPaymasterStubData.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"getPaymasterStubData.js","sourceRoot":"","sources":["../../../../account-abstraction/actions/paymaster/getPaymasterStubData.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAA;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAA;AAE9D,OAAO,EAEL,0BAA0B,GAC3B,MAAM,gDAAgD,CAAA;AAsEvD;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,MAAM,CAAC,KAAK,UAAU,oBAAoB,CACxC,MAAyB,EACzB,UAA0C;IAE1C,MAAM,EAAE,OAAO,EAAE,iBAAiB,EAAE,OAAO,EAAE,GAAG,aAAa,EAAE,GAAG,UAAU,CAAA;IAC5E,MAAM,OAAO,GAAG,0BAA0B,CAAC,aAAa,CAAC,CAAA;IACzD,MAAM,EAAE,uBAAuB,EAAE,6BAA6B,EAAE,GAAG,IAAI,EAAE,GACvE,MAAM,MAAM,CAAC,OAAO,CAAC;QACnB,MAAM,EAAE,yBAAyB;QACjC,MAAM,EAAE;YACN;gBACE,GAAG,OAAO;gBACV,YAAY,EAAE,OAAO,CAAC,YAAY,IAAI,KAAK;gBAC3C,oBAAoB,EAAE,OAAO,CAAC,oBAAoB,IAAI,KAAK;gBAC3D,kBAAkB,EAAE,OAAO,CAAC,kBAAkB,IAAI,KAAK;aACxD;YACD,iBAAiB;YACjB,WAAW,CAAC,OAAO,CAAC;YACpB,OAAO;SACR;KACF,CAAC,CAAA;IACJ,OAAO;QACL,GAAG,IAAI;QACP,GAAG,CAAC,uBAAuB,IAAI;YAC7B,uBAAuB,EAAE,WAAW,CAAC,uBAAuB,CAAC;SAC9D,CAAC;QACF,GAAG,CAAC,6BAA6B,IAAI;YACnC,6BAA6B,EAAE,WAAW,CAAC,6BAA6B,CAAC;SAC1E,CAAC;KAC0C,CAAA;AAChD,CAAC"}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import { createClient, } from '../../clients/createClient.js';
|
2
|
+
import { bundlerActions } from './decorators/bundler.js';
|
3
|
+
export function createBundlerClient(parameters) {
|
4
|
+
const { client: client_, key = 'bundler', name = 'Bundler Client', paymaster, paymasterContext, transport, userOperation, } = parameters;
|
5
|
+
const client = Object.assign(createClient({
|
6
|
+
...parameters,
|
7
|
+
chain: parameters.chain ?? client_?.chain,
|
8
|
+
key,
|
9
|
+
name,
|
10
|
+
transport,
|
11
|
+
type: 'bundlerClient',
|
12
|
+
}), { client: client_, paymaster, paymasterContext, userOperation });
|
13
|
+
return client.extend(bundlerActions);
|
14
|
+
}
|
15
|
+
//# sourceMappingURL=createBundlerClient.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"createBundlerClient.js","sourceRoot":"","sources":["../../../account-abstraction/clients/createBundlerClient.ts"],"names":[],"mappings":"AACA,OAAO,EAIL,YAAY,GACb,MAAM,+BAA+B,CAAA;AAStC,OAAO,EAAuB,cAAc,EAAE,MAAM,yBAAyB,CAAA;AAmH7E,MAAM,UAAU,mBAAmB,CACjC,UAA+B;IAE/B,MAAM,EACJ,MAAM,EAAE,OAAO,EACf,GAAG,GAAG,SAAS,EACf,IAAI,GAAG,gBAAgB,EACvB,SAAS,EACT,gBAAgB,EAChB,SAAS,EACT,aAAa,GACd,GAAG,UAAU,CAAA;IACd,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAC1B,YAAY,CAAC;QACX,GAAG,UAAU;QACb,KAAK,EAAE,UAAU,CAAC,KAAK,IAAI,OAAO,EAAE,KAAK;QACzC,GAAG;QACH,IAAI;QACJ,SAAS;QACT,IAAI,EAAE,eAAe;KACtB,CAAC,EACF,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,aAAa,EAAE,CAChE,CAAA;IACD,OAAO,MAAM,CAAC,MAAM,CAAC,cAAc,CAAQ,CAAA;AAC7C,CAAC"}
|