thirdweb 5.73.1-nightly-33c23e789e577bd6463e135cec4e25cfcfc9964a-20241205000340 → 5.75.0-nightly-ec84ed37d6db8281d3afb12bc47a20ccc5fe9713-20241207000341

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.
Files changed (597) hide show
  1. package/dist/cjs/adapters/ethers5.js +2 -2
  2. package/dist/cjs/adapters/ethers5.js.map +1 -1
  3. package/dist/cjs/adapters/ethers6.js.map +1 -1
  4. package/dist/cjs/auth/verify-hash.js +2 -1
  5. package/dist/cjs/auth/verify-hash.js.map +1 -1
  6. package/dist/cjs/auth/verify-signature.js.map +1 -1
  7. package/dist/cjs/contract/actions/resolve-abi.js +4 -0
  8. package/dist/cjs/contract/actions/resolve-abi.js.map +1 -1
  9. package/dist/cjs/exports/wallets/smart.js +4 -1
  10. package/dist/cjs/exports/wallets/smart.js.map +1 -1
  11. package/dist/cjs/extensions/erc1271/checkContractWalletSignedTypedData.js +6 -2
  12. package/dist/cjs/extensions/erc1271/checkContractWalletSignedTypedData.js.map +1 -1
  13. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.js +27 -0
  14. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.js.map +1 -0
  15. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.js +27 -0
  16. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.js.map +1 -0
  17. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/accountId.js +71 -0
  18. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/accountId.js.map +1 -0
  19. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.js +132 -0
  20. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.js.map +1 -0
  21. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.js +121 -0
  22. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.js.map +1 -0
  23. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.js +114 -0
  24. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.js.map +1 -0
  25. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.js +114 -0
  26. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.js.map +1 -0
  27. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/execute.js +127 -0
  28. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/execute.js.map +1 -0
  29. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.js +132 -0
  30. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.js.map +1 -0
  31. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/installModule.js +139 -0
  32. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/installModule.js.map +1 -0
  33. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.js +139 -0
  34. package/dist/cjs/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.js.map +1 -0
  35. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.js +32 -0
  36. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.js.map +1 -0
  37. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.js +31 -0
  38. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.js.map +1 -0
  39. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.js +70 -0
  40. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.js.map +1 -0
  41. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.js +70 -0
  42. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.js.map +1 -0
  43. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.js +122 -0
  44. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.js.map +1 -0
  45. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.js +71 -0
  46. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.js.map +1 -0
  47. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.js +71 -0
  48. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.js.map +1 -0
  49. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.js +117 -0
  50. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.js.map +1 -0
  51. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.js +157 -0
  52. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.js.map +1 -0
  53. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.js +51 -0
  54. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.js.map +1 -0
  55. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.js +117 -0
  56. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.js.map +1 -0
  57. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.js +51 -0
  58. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.js.map +1 -0
  59. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.js +117 -0
  60. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.js.map +1 -0
  61. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.js +139 -0
  62. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.js.map +1 -0
  63. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.js +117 -0
  64. package/dist/cjs/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.js.map +1 -0
  65. package/dist/cjs/extensions/marketplace/direct-listings/write/buyFromListing.js +6 -0
  66. package/dist/cjs/extensions/marketplace/direct-listings/write/buyFromListing.js.map +1 -1
  67. package/dist/cjs/extensions/pack/createNewPack.js +1 -0
  68. package/dist/cjs/extensions/pack/createNewPack.js.map +1 -1
  69. package/dist/cjs/react/web/ui/ConnectWallet/screens/SignatureScreen.js +12 -10
  70. package/dist/cjs/react/web/ui/ConnectWallet/screens/SignatureScreen.js.map +1 -1
  71. package/dist/cjs/react/web/ui/prebuilt/Account/avatar.js +1 -0
  72. package/dist/cjs/react/web/ui/prebuilt/Account/avatar.js.map +1 -1
  73. package/dist/cjs/react/web/ui/prebuilt/Account/balance.js +1 -0
  74. package/dist/cjs/react/web/ui/prebuilt/Account/balance.js.map +1 -1
  75. package/dist/cjs/react/web/ui/prebuilt/Account/name.js +1 -0
  76. package/dist/cjs/react/web/ui/prebuilt/Account/name.js.map +1 -1
  77. package/dist/cjs/react/web/utils/usePreloadWalletProviders.js +1 -1
  78. package/dist/cjs/react/web/utils/usePreloadWalletProviders.js.map +1 -1
  79. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +1 -1
  80. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  81. package/dist/cjs/transaction/actions/estimate-gas.js.map +1 -1
  82. package/dist/cjs/transaction/actions/gasless/providers/biconomy.js.map +1 -1
  83. package/dist/cjs/transaction/actions/gasless/providers/engine.js.map +1 -1
  84. package/dist/cjs/transaction/actions/gasless/providers/openzeppelin.js.map +1 -1
  85. package/dist/cjs/transaction/actions/sign-transaction.js +4 -7
  86. package/dist/cjs/transaction/actions/sign-transaction.js.map +1 -1
  87. package/dist/cjs/transaction/actions/to-serializable-transaction.js.map +1 -1
  88. package/dist/cjs/transaction/actions/zksync/getEip721Domain.js.map +1 -1
  89. package/dist/cjs/transaction/serialize-transaction.js +76 -9
  90. package/dist/cjs/transaction/serialize-transaction.js.map +1 -1
  91. package/dist/cjs/utils/any-evm/keyless-transaction.js +25 -4
  92. package/dist/cjs/utils/any-evm/keyless-transaction.js.map +1 -1
  93. package/dist/cjs/utils/hashing/hashMessage.js +2 -2
  94. package/dist/cjs/utils/hashing/hashMessage.js.map +1 -1
  95. package/dist/cjs/utils/hashing/hashTypedData.js +8 -6
  96. package/dist/cjs/utils/hashing/hashTypedData.js.map +1 -1
  97. package/dist/cjs/utils/signatures/helpers/{parseTypedData.js → parse-typed-data.js} +4 -4
  98. package/dist/cjs/utils/signatures/helpers/parse-typed-data.js.map +1 -0
  99. package/dist/cjs/utils/signatures/sign-message.js +12 -6
  100. package/dist/cjs/utils/signatures/sign-message.js.map +1 -1
  101. package/dist/cjs/utils/signatures/sign-typed-data.js +11 -8
  102. package/dist/cjs/utils/signatures/sign-typed-data.js.map +1 -1
  103. package/dist/cjs/utils/signatures/sign.js +4 -4
  104. package/dist/cjs/utils/signatures/sign.js.map +1 -1
  105. package/dist/cjs/utils/signatures/signature-to-hex.js +17 -10
  106. package/dist/cjs/utils/signatures/signature-to-hex.js.map +1 -1
  107. package/dist/cjs/utils/types.js +5 -0
  108. package/dist/cjs/utils/types.js.map +1 -1
  109. package/dist/cjs/version.js +1 -1
  110. package/dist/cjs/wallets/coinbase/{coinbaseMobileSDK.js → coinbase-mobile.js} +1 -1
  111. package/dist/cjs/wallets/coinbase/coinbase-mobile.js.map +1 -0
  112. package/dist/cjs/wallets/coinbase/coinbase-wallet.js +2 -2
  113. package/dist/cjs/wallets/coinbase/coinbase-wallet.js.map +1 -1
  114. package/dist/cjs/wallets/coinbase/{coinbaseWebSDK.js → coinbase-web.js} +11 -11
  115. package/dist/cjs/wallets/coinbase/coinbase-web.js.map +1 -0
  116. package/dist/cjs/wallets/create-wallet.js +2 -2
  117. package/dist/cjs/wallets/create-wallet.js.map +1 -1
  118. package/dist/cjs/wallets/ecosystem/is-ecosystem-wallet.js +1 -1
  119. package/dist/cjs/wallets/eip5792/get-calls-status.js +3 -3
  120. package/dist/cjs/wallets/eip5792/get-calls-status.js.map +1 -1
  121. package/dist/cjs/wallets/eip5792/get-capabilities.js +3 -3
  122. package/dist/cjs/wallets/eip5792/get-capabilities.js.map +1 -1
  123. package/dist/cjs/wallets/eip5792/send-calls.js +3 -3
  124. package/dist/cjs/wallets/eip5792/send-calls.js.map +1 -1
  125. package/dist/cjs/wallets/eip5792/show-calls-status.js +3 -3
  126. package/dist/cjs/wallets/eip5792/show-calls-status.js.map +1 -1
  127. package/dist/cjs/wallets/in-app/core/actions/sign-typed-data.enclave.js.map +1 -1
  128. package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js +2 -2
  129. package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
  130. package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js +8 -4
  131. package/dist/cjs/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
  132. package/dist/cjs/wallets/in-app/web/ecosystem.js +1 -1
  133. package/dist/cjs/wallets/in-app/web/in-app.js +2 -2
  134. package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js +3 -3
  135. package/dist/cjs/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
  136. package/dist/cjs/wallets/injected/index.js +2 -2
  137. package/dist/cjs/wallets/injected/index.js.map +1 -1
  138. package/dist/cjs/wallets/native/create-wallet.js +2 -2
  139. package/dist/cjs/wallets/native/create-wallet.js.map +1 -1
  140. package/dist/cjs/wallets/private-key.js +2 -5
  141. package/dist/cjs/wallets/private-key.js.map +1 -1
  142. package/dist/cjs/wallets/smart/index.js +45 -172
  143. package/dist/cjs/wallets/smart/index.js.map +1 -1
  144. package/dist/cjs/wallets/smart/lib/bundler.js +2 -1
  145. package/dist/cjs/wallets/smart/lib/bundler.js.map +1 -1
  146. package/dist/cjs/wallets/smart/lib/calls.js +2 -2
  147. package/dist/cjs/wallets/smart/lib/calls.js.map +1 -1
  148. package/dist/cjs/wallets/smart/lib/constants.js +21 -1
  149. package/dist/cjs/wallets/smart/lib/constants.js.map +1 -1
  150. package/dist/cjs/wallets/smart/lib/paymaster.js +7 -6
  151. package/dist/cjs/wallets/smart/lib/paymaster.js.map +1 -1
  152. package/dist/cjs/wallets/smart/lib/signing.js +166 -0
  153. package/dist/cjs/wallets/smart/lib/signing.js.map +1 -0
  154. package/dist/cjs/wallets/smart/lib/userop.js +20 -5
  155. package/dist/cjs/wallets/smart/lib/userop.js.map +1 -1
  156. package/dist/cjs/wallets/smart/presets/7579.js +218 -0
  157. package/dist/cjs/wallets/smart/presets/7579.js.map +1 -0
  158. package/dist/cjs/wallets/smart/presets/index.js +6 -0
  159. package/dist/cjs/wallets/smart/presets/index.js.map +1 -0
  160. package/dist/cjs/wallets/smart/smart-wallet.js +1 -1
  161. package/dist/cjs/wallets/smart/smart-wallet.js.map +1 -1
  162. package/dist/cjs/wallets/smart/types.js.map +1 -1
  163. package/dist/cjs/wallets/wallet-connect/controller.js +2 -2
  164. package/dist/cjs/wallets/wallet-connect/controller.js.map +1 -1
  165. package/dist/esm/adapters/ethers5.js +2 -2
  166. package/dist/esm/adapters/ethers5.js.map +1 -1
  167. package/dist/esm/adapters/ethers6.js.map +1 -1
  168. package/dist/esm/auth/verify-hash.js +2 -1
  169. package/dist/esm/auth/verify-hash.js.map +1 -1
  170. package/dist/esm/auth/verify-signature.js.map +1 -1
  171. package/dist/esm/contract/actions/resolve-abi.js +4 -0
  172. package/dist/esm/contract/actions/resolve-abi.js.map +1 -1
  173. package/dist/esm/exports/wallets/smart.js +3 -1
  174. package/dist/esm/exports/wallets/smart.js.map +1 -1
  175. package/dist/esm/extensions/erc1271/checkContractWalletSignedTypedData.js +6 -2
  176. package/dist/esm/extensions/erc1271/checkContractWalletSignedTypedData.js.map +1 -1
  177. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.js +24 -0
  178. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.js.map +1 -0
  179. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.js +24 -0
  180. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.js.map +1 -0
  181. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/accountId.js +65 -0
  182. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/accountId.js.map +1 -0
  183. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.js +124 -0
  184. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.js.map +1 -0
  185. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.js +113 -0
  186. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.js.map +1 -0
  187. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.js +106 -0
  188. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.js.map +1 -0
  189. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.js +106 -0
  190. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.js.map +1 -0
  191. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/execute.js +120 -0
  192. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/execute.js.map +1 -0
  193. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.js +125 -0
  194. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.js.map +1 -0
  195. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/installModule.js +132 -0
  196. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/installModule.js.map +1 -0
  197. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.js +132 -0
  198. package/dist/esm/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.js.map +1 -0
  199. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.js +29 -0
  200. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.js.map +1 -0
  201. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.js +28 -0
  202. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.js.map +1 -0
  203. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.js +64 -0
  204. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.js.map +1 -0
  205. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.js +64 -0
  206. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.js.map +1 -0
  207. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.js +114 -0
  208. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.js.map +1 -0
  209. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.js +65 -0
  210. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.js.map +1 -0
  211. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.js +65 -0
  212. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.js.map +1 -0
  213. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.js +110 -0
  214. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.js.map +1 -0
  215. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.js +150 -0
  216. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.js.map +1 -0
  217. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.js +46 -0
  218. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.js.map +1 -0
  219. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.js +110 -0
  220. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.js.map +1 -0
  221. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.js +46 -0
  222. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.js.map +1 -0
  223. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.js +110 -0
  224. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.js.map +1 -0
  225. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.js +132 -0
  226. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.js.map +1 -0
  227. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.js +110 -0
  228. package/dist/esm/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.js.map +1 -0
  229. package/dist/esm/extensions/marketplace/direct-listings/write/buyFromListing.js +6 -0
  230. package/dist/esm/extensions/marketplace/direct-listings/write/buyFromListing.js.map +1 -1
  231. package/dist/esm/extensions/pack/createNewPack.js +1 -0
  232. package/dist/esm/extensions/pack/createNewPack.js.map +1 -1
  233. package/dist/esm/react/web/ui/ConnectWallet/screens/SignatureScreen.js +12 -10
  234. package/dist/esm/react/web/ui/ConnectWallet/screens/SignatureScreen.js.map +1 -1
  235. package/dist/esm/react/web/ui/prebuilt/Account/avatar.js +1 -0
  236. package/dist/esm/react/web/ui/prebuilt/Account/avatar.js.map +1 -1
  237. package/dist/esm/react/web/ui/prebuilt/Account/balance.js +1 -0
  238. package/dist/esm/react/web/ui/prebuilt/Account/balance.js.map +1 -1
  239. package/dist/esm/react/web/ui/prebuilt/Account/name.js +1 -0
  240. package/dist/esm/react/web/ui/prebuilt/Account/name.js.map +1 -1
  241. package/dist/esm/react/web/utils/usePreloadWalletProviders.js +1 -1
  242. package/dist/esm/react/web/utils/usePreloadWalletProviders.js.map +1 -1
  243. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +1 -1
  244. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  245. package/dist/esm/transaction/actions/estimate-gas.js +3 -3
  246. package/dist/esm/transaction/actions/estimate-gas.js.map +1 -1
  247. package/dist/esm/transaction/actions/gasless/providers/biconomy.js.map +1 -1
  248. package/dist/esm/transaction/actions/gasless/providers/engine.js.map +1 -1
  249. package/dist/esm/transaction/actions/gasless/providers/openzeppelin.js.map +1 -1
  250. package/dist/esm/transaction/actions/sign-transaction.js +5 -8
  251. package/dist/esm/transaction/actions/sign-transaction.js.map +1 -1
  252. package/dist/esm/transaction/actions/to-serializable-transaction.js.map +1 -1
  253. package/dist/esm/transaction/actions/zksync/getEip721Domain.js.map +1 -1
  254. package/dist/esm/transaction/serialize-transaction.js +76 -9
  255. package/dist/esm/transaction/serialize-transaction.js.map +1 -1
  256. package/dist/esm/utils/any-evm/keyless-transaction.js +26 -5
  257. package/dist/esm/utils/any-evm/keyless-transaction.js.map +1 -1
  258. package/dist/esm/utils/hashing/hashMessage.js +2 -2
  259. package/dist/esm/utils/hashing/hashMessage.js.map +1 -1
  260. package/dist/esm/utils/hashing/hashTypedData.js +8 -6
  261. package/dist/esm/utils/hashing/hashTypedData.js.map +1 -1
  262. package/dist/esm/utils/signatures/helpers/parse-typed-data.js +15 -0
  263. package/dist/esm/utils/signatures/helpers/parse-typed-data.js.map +1 -0
  264. package/dist/esm/utils/signatures/sign-message.js +12 -6
  265. package/dist/esm/utils/signatures/sign-message.js.map +1 -1
  266. package/dist/esm/utils/signatures/sign-typed-data.js +11 -8
  267. package/dist/esm/utils/signatures/sign-typed-data.js.map +1 -1
  268. package/dist/esm/utils/signatures/sign.js +4 -4
  269. package/dist/esm/utils/signatures/sign.js.map +1 -1
  270. package/dist/esm/utils/signatures/signature-to-hex.js +17 -10
  271. package/dist/esm/utils/signatures/signature-to-hex.js.map +1 -1
  272. package/dist/esm/utils/types.js +4 -1
  273. package/dist/esm/utils/types.js.map +1 -1
  274. package/dist/esm/version.js +1 -1
  275. package/dist/esm/wallets/coinbase/{coinbaseMobileSDK.js → coinbase-mobile.js} +1 -1
  276. package/dist/esm/wallets/coinbase/coinbase-mobile.js.map +1 -0
  277. package/dist/esm/wallets/coinbase/coinbase-wallet.js +2 -2
  278. package/dist/esm/wallets/coinbase/coinbase-wallet.js.map +1 -1
  279. package/dist/esm/wallets/coinbase/{coinbaseWebSDK.js → coinbase-web.js} +11 -11
  280. package/dist/esm/wallets/coinbase/coinbase-web.js.map +1 -0
  281. package/dist/esm/wallets/create-wallet.js +1 -1
  282. package/dist/esm/wallets/create-wallet.js.map +1 -1
  283. package/dist/esm/wallets/ecosystem/is-ecosystem-wallet.js +1 -1
  284. package/dist/esm/wallets/eip5792/get-calls-status.js +2 -2
  285. package/dist/esm/wallets/eip5792/get-calls-status.js.map +1 -1
  286. package/dist/esm/wallets/eip5792/get-capabilities.js +2 -2
  287. package/dist/esm/wallets/eip5792/get-capabilities.js.map +1 -1
  288. package/dist/esm/wallets/eip5792/send-calls.js +2 -2
  289. package/dist/esm/wallets/eip5792/send-calls.js.map +1 -1
  290. package/dist/esm/wallets/eip5792/show-calls-status.js +2 -2
  291. package/dist/esm/wallets/eip5792/show-calls-status.js.map +1 -1
  292. package/dist/esm/wallets/in-app/core/actions/sign-typed-data.enclave.js.map +1 -1
  293. package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js +1 -1
  294. package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
  295. package/dist/esm/wallets/in-app/core/wallet/in-app-core.js +9 -5
  296. package/dist/esm/wallets/in-app/core/wallet/in-app-core.js.map +1 -1
  297. package/dist/esm/wallets/in-app/web/ecosystem.js +1 -1
  298. package/dist/esm/wallets/in-app/web/in-app.js +2 -2
  299. package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js +2 -2
  300. package/dist/esm/wallets/in-app/web/lib/iframe-wallet.js.map +1 -1
  301. package/dist/esm/wallets/injected/index.js +1 -1
  302. package/dist/esm/wallets/injected/index.js.map +1 -1
  303. package/dist/esm/wallets/native/create-wallet.js +1 -1
  304. package/dist/esm/wallets/native/create-wallet.js.map +1 -1
  305. package/dist/esm/wallets/private-key.js +2 -5
  306. package/dist/esm/wallets/private-key.js.map +1 -1
  307. package/dist/esm/wallets/smart/index.js +44 -171
  308. package/dist/esm/wallets/smart/index.js.map +1 -1
  309. package/dist/esm/wallets/smart/lib/bundler.js +2 -1
  310. package/dist/esm/wallets/smart/lib/bundler.js.map +1 -1
  311. package/dist/esm/wallets/smart/lib/calls.js +2 -2
  312. package/dist/esm/wallets/smart/lib/calls.js.map +1 -1
  313. package/dist/esm/wallets/smart/lib/constants.js +20 -0
  314. package/dist/esm/wallets/smart/lib/constants.js.map +1 -1
  315. package/dist/esm/wallets/smart/lib/paymaster.js +7 -6
  316. package/dist/esm/wallets/smart/lib/paymaster.js.map +1 -1
  317. package/dist/esm/wallets/smart/lib/signing.js +161 -0
  318. package/dist/esm/wallets/smart/lib/signing.js.map +1 -0
  319. package/dist/esm/wallets/smart/lib/userop.js +21 -6
  320. package/dist/esm/wallets/smart/lib/userop.js.map +1 -1
  321. package/dist/esm/wallets/smart/presets/7579.js +215 -0
  322. package/dist/esm/wallets/smart/presets/7579.js.map +1 -0
  323. package/dist/esm/wallets/smart/presets/index.js +2 -0
  324. package/dist/esm/wallets/smart/presets/index.js.map +1 -0
  325. package/dist/esm/wallets/smart/smart-wallet.js +1 -1
  326. package/dist/esm/wallets/smart/smart-wallet.js.map +1 -1
  327. package/dist/esm/wallets/smart/types.js.map +1 -1
  328. package/dist/esm/wallets/wallet-connect/controller.js +1 -1
  329. package/dist/esm/wallets/wallet-connect/controller.js.map +1 -1
  330. package/dist/types/adapters/ethers5.d.ts.map +1 -1
  331. package/dist/types/adapters/ethers6.d.ts.map +1 -1
  332. package/dist/types/auth/verify-hash.d.ts.map +1 -1
  333. package/dist/types/auth/verify-signature.d.ts +2 -2
  334. package/dist/types/auth/verify-signature.d.ts.map +1 -1
  335. package/dist/types/contract/actions/resolve-abi.d.ts.map +1 -1
  336. package/dist/types/exports/wallets/smart.d.ts +2 -1
  337. package/dist/types/exports/wallets/smart.d.ts.map +1 -1
  338. package/dist/types/exports/wallets.d.ts +1 -1
  339. package/dist/types/exports/wallets.d.ts.map +1 -1
  340. package/dist/types/exports/wallets.native.d.ts +1 -1
  341. package/dist/types/exports/wallets.native.d.ts.map +1 -1
  342. package/dist/types/extensions/erc1271/checkContractWalletSignedTypedData.d.ts +4 -4
  343. package/dist/types/extensions/erc1271/checkContractWalletSignedTypedData.d.ts.map +1 -1
  344. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.d.ts +29 -0
  345. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.d.ts.map +1 -0
  346. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.d.ts +29 -0
  347. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.d.ts.map +1 -0
  348. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/accountId.d.ts +44 -0
  349. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/accountId.d.ts.map +1 -0
  350. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.d.ts +97 -0
  351. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.d.ts.map +1 -0
  352. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.d.ts +90 -0
  353. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.d.ts.map +1 -0
  354. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.d.ts +83 -0
  355. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.d.ts.map +1 -0
  356. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.d.ts +83 -0
  357. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.d.ts.map +1 -0
  358. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/execute.d.ts +86 -0
  359. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/execute.d.ts.map +1 -0
  360. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.d.ts +86 -0
  361. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.d.ts.map +1 -0
  362. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/installModule.d.ts +93 -0
  363. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/installModule.d.ts.map +1 -0
  364. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.d.ts +93 -0
  365. package/dist/types/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.d.ts.map +1 -0
  366. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.d.ts +51 -0
  367. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.d.ts.map +1 -0
  368. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.d.ts +41 -0
  369. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.d.ts.map +1 -0
  370. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.d.ts +44 -0
  371. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.d.ts.map +1 -0
  372. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.d.ts +44 -0
  373. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.d.ts.map +1 -0
  374. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.d.ts +90 -0
  375. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.d.ts.map +1 -0
  376. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.d.ts +44 -0
  377. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.d.ts.map +1 -0
  378. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.d.ts +44 -0
  379. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.d.ts.map +1 -0
  380. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.d.ts +79 -0
  381. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.d.ts.map +1 -0
  382. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.d.ts +107 -0
  383. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.d.ts.map +1 -0
  384. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.d.ts +33 -0
  385. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.d.ts.map +1 -0
  386. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.d.ts +79 -0
  387. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.d.ts.map +1 -0
  388. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.d.ts +33 -0
  389. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.d.ts.map +1 -0
  390. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.d.ts +79 -0
  391. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.d.ts.map +1 -0
  392. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.d.ts +93 -0
  393. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.d.ts.map +1 -0
  394. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.d.ts +79 -0
  395. package/dist/types/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.d.ts.map +1 -0
  396. package/dist/types/extensions/marketplace/direct-listings/write/buyFromListing.d.ts.map +1 -1
  397. package/dist/types/extensions/pack/createNewPack.d.ts.map +1 -1
  398. package/dist/types/react/web/ui/ConnectWallet/screens/SignatureScreen.d.ts.map +1 -1
  399. package/dist/types/react/web/ui/prebuilt/Account/avatar.d.ts.map +1 -1
  400. package/dist/types/react/web/ui/prebuilt/Account/balance.d.ts.map +1 -1
  401. package/dist/types/react/web/ui/prebuilt/Account/name.d.ts.map +1 -1
  402. package/dist/types/transaction/actions/gasless/providers/biconomy.d.ts +2 -2
  403. package/dist/types/transaction/actions/gasless/providers/biconomy.d.ts.map +1 -1
  404. package/dist/types/transaction/actions/gasless/providers/engine.d.ts +2 -2
  405. package/dist/types/transaction/actions/gasless/providers/engine.d.ts.map +1 -1
  406. package/dist/types/transaction/actions/gasless/providers/openzeppelin.d.ts +2 -2
  407. package/dist/types/transaction/actions/gasless/providers/openzeppelin.d.ts.map +1 -1
  408. package/dist/types/transaction/actions/gasless/send-gasless-transaction.d.ts +2 -2
  409. package/dist/types/transaction/actions/gasless/send-gasless-transaction.d.ts.map +1 -1
  410. package/dist/types/transaction/actions/sign-transaction.d.ts +2 -2
  411. package/dist/types/transaction/actions/sign-transaction.d.ts.map +1 -1
  412. package/dist/types/transaction/actions/to-serializable-transaction.d.ts.map +1 -1
  413. package/dist/types/transaction/actions/zksync/getEip721Domain.d.ts +2 -2
  414. package/dist/types/transaction/actions/zksync/getEip721Domain.d.ts.map +1 -1
  415. package/dist/types/transaction/serialize-transaction.d.ts +24 -4
  416. package/dist/types/transaction/serialize-transaction.d.ts.map +1 -1
  417. package/dist/types/utils/any-evm/keyless-transaction.d.ts +6 -4
  418. package/dist/types/utils/any-evm/keyless-transaction.d.ts.map +1 -1
  419. package/dist/types/utils/hashing/hashMessage.d.ts +3 -2
  420. package/dist/types/utils/hashing/hashMessage.d.ts.map +1 -1
  421. package/dist/types/utils/hashing/hashTypedData.d.ts +3 -3
  422. package/dist/types/utils/hashing/hashTypedData.d.ts.map +1 -1
  423. package/dist/types/utils/signatures/helpers/parse-typed-data.d.ts +6 -0
  424. package/dist/types/utils/signatures/helpers/parse-typed-data.d.ts.map +1 -0
  425. package/dist/types/utils/signatures/sign-message.d.ts.map +1 -1
  426. package/dist/types/utils/signatures/sign-typed-data.d.ts +3 -4
  427. package/dist/types/utils/signatures/sign-typed-data.d.ts.map +1 -1
  428. package/dist/types/utils/signatures/sign.d.ts +6 -2
  429. package/dist/types/utils/signatures/sign.d.ts.map +1 -1
  430. package/dist/types/utils/signatures/signature-to-hex.d.ts +7 -3
  431. package/dist/types/utils/signatures/signature-to-hex.d.ts.map +1 -1
  432. package/dist/types/utils/types.d.ts +13 -0
  433. package/dist/types/utils/types.d.ts.map +1 -1
  434. package/dist/types/version.d.ts +1 -1
  435. package/dist/types/wallets/coinbase/{coinbaseMobileSDK.d.ts → coinbase-mobile.d.ts} +2 -2
  436. package/dist/types/wallets/coinbase/coinbase-mobile.d.ts.map +1 -0
  437. package/dist/types/wallets/coinbase/{coinbaseWebSDK.d.ts → coinbase-web.d.ts} +1 -1
  438. package/dist/types/wallets/coinbase/coinbase-web.d.ts.map +1 -0
  439. package/dist/types/wallets/ecosystem/get-ecosystem-wallet-auth-options.d.ts +1 -1
  440. package/dist/types/wallets/ecosystem/get-ecosystem-wallet-auth-options.d.ts.map +1 -1
  441. package/dist/types/wallets/in-app/core/actions/sign-typed-data.enclave.d.ts +3 -4
  442. package/dist/types/wallets/in-app/core/actions/sign-typed-data.enclave.d.ts.map +1 -1
  443. package/dist/types/wallets/in-app/core/wallet/in-app-core.d.ts.map +1 -1
  444. package/dist/types/wallets/in-app/web/ecosystem.d.ts +1 -1
  445. package/dist/types/wallets/in-app/web/in-app.d.ts +2 -2
  446. package/dist/types/wallets/interfaces/wallet.d.ts +6 -4
  447. package/dist/types/wallets/interfaces/wallet.d.ts.map +1 -1
  448. package/dist/types/wallets/private-key.d.ts.map +1 -1
  449. package/dist/types/wallets/smart/index.d.ts +3 -2
  450. package/dist/types/wallets/smart/index.d.ts.map +1 -1
  451. package/dist/types/wallets/smart/lib/bundler.d.ts +9 -3
  452. package/dist/types/wallets/smart/lib/bundler.d.ts.map +1 -1
  453. package/dist/types/wallets/smart/lib/calls.d.ts +2 -2
  454. package/dist/types/wallets/smart/lib/calls.d.ts.map +1 -1
  455. package/dist/types/wallets/smart/lib/constants.d.ts +4 -0
  456. package/dist/types/wallets/smart/lib/constants.d.ts.map +1 -1
  457. package/dist/types/wallets/smart/lib/paymaster.d.ts.map +1 -1
  458. package/dist/types/wallets/smart/lib/signing.d.ts +20 -0
  459. package/dist/types/wallets/smart/lib/signing.d.ts.map +1 -0
  460. package/dist/types/wallets/smart/lib/userop.d.ts.map +1 -1
  461. package/dist/types/wallets/smart/presets/7579.d.ts +34 -0
  462. package/dist/types/wallets/smart/presets/7579.d.ts.map +1 -0
  463. package/dist/types/wallets/smart/presets/index.d.ts +2 -0
  464. package/dist/types/wallets/smart/presets/index.d.ts.map +1 -0
  465. package/dist/types/wallets/smart/smart-wallet.d.ts +3 -3
  466. package/dist/types/wallets/smart/smart-wallet.d.ts.map +1 -1
  467. package/dist/types/wallets/smart/types.d.ts +30 -13
  468. package/dist/types/wallets/smart/types.d.ts.map +1 -1
  469. package/dist/types/wallets/wallet-types.d.ts +1 -1
  470. package/dist/types/wallets/wallet-types.d.ts.map +1 -1
  471. package/package.json +23 -23
  472. package/src/adapters/ethers5.test.ts +92 -0
  473. package/src/adapters/ethers5.ts +6 -5
  474. package/src/adapters/ethers6.ts +3 -2
  475. package/src/adapters/viem.test.ts +5 -4
  476. package/src/auth/verify-hash.ts +2 -1
  477. package/src/auth/verify-signature.ts +2 -2
  478. package/src/contract/actions/resolve-abi.ts +6 -0
  479. package/src/exports/wallets/smart.ts +4 -0
  480. package/src/exports/wallets.native.ts +1 -1
  481. package/src/exports/wallets.ts +1 -1
  482. package/src/extensions/erc1271/checkContractWalletSignedTypedData.ts +9 -5
  483. package/src/extensions/erc7579/__generated__/IERC7579Account/events/ModuleInstalled.ts +24 -0
  484. package/src/extensions/erc7579/__generated__/IERC7579Account/events/ModuleUninstalled.ts +24 -0
  485. package/src/extensions/erc7579/__generated__/IERC7579Account/read/accountId.ts +71 -0
  486. package/src/extensions/erc7579/__generated__/IERC7579Account/read/isModuleInstalled.ts +153 -0
  487. package/src/extensions/erc7579/__generated__/IERC7579Account/read/isValidSignature.ts +133 -0
  488. package/src/extensions/erc7579/__generated__/IERC7579Account/read/supportsExecutionMode.ts +132 -0
  489. package/src/extensions/erc7579/__generated__/IERC7579Account/read/supportsModule.ts +128 -0
  490. package/src/extensions/erc7579/__generated__/IERC7579Account/write/execute.ts +149 -0
  491. package/src/extensions/erc7579/__generated__/IERC7579Account/write/executeFromExecutor.ts +158 -0
  492. package/src/extensions/erc7579/__generated__/IERC7579Account/write/installModule.ts +164 -0
  493. package/src/extensions/erc7579/__generated__/IERC7579Account/write/uninstallModule.ts +167 -0
  494. package/src/extensions/erc7579/__generated__/ModularAccountFactory/events/OwnershipTransferred.ts +49 -0
  495. package/src/extensions/erc7579/__generated__/ModularAccountFactory/events/Upgraded.ts +40 -0
  496. package/src/extensions/erc7579/__generated__/ModularAccountFactory/read/accountImplementation.ts +70 -0
  497. package/src/extensions/erc7579/__generated__/ModularAccountFactory/read/entrypoint.ts +70 -0
  498. package/src/extensions/erc7579/__generated__/ModularAccountFactory/read/getAddress.ts +134 -0
  499. package/src/extensions/erc7579/__generated__/ModularAccountFactory/read/implementation.ts +71 -0
  500. package/src/extensions/erc7579/__generated__/ModularAccountFactory/read/owner.ts +71 -0
  501. package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/addStake.ts +138 -0
  502. package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/createAccountWithModules.ts +193 -0
  503. package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/renounceOwnership.ts +50 -0
  504. package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/transferOwnership.ts +139 -0
  505. package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/unlockStake.ts +50 -0
  506. package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/upgradeTo.ts +140 -0
  507. package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/withdraw.ts +159 -0
  508. package/src/extensions/erc7579/__generated__/ModularAccountFactory/write/withdrawStake.ts +137 -0
  509. package/src/extensions/marketplace/direct-listings/direct-listings.test.ts +74 -14
  510. package/src/extensions/marketplace/direct-listings/write/buyFromListing.ts +6 -0
  511. package/src/extensions/pack/createNewPack.ts +1 -0
  512. package/src/react/web/ui/ConnectWallet/screens/SignatureScreen.test.tsx +287 -0
  513. package/src/react/web/ui/ConnectWallet/screens/SignatureScreen.tsx +13 -5
  514. package/src/react/web/ui/prebuilt/Account/avatar.tsx +1 -0
  515. package/src/react/web/ui/prebuilt/Account/balance.tsx +1 -0
  516. package/src/react/web/ui/prebuilt/Account/name.tsx +1 -0
  517. package/src/react/web/utils/usePreloadWalletProviders.ts +1 -1
  518. package/src/react/web/wallets/shared/ConnectWalletSocialOptions.test.tsx +87 -0
  519. package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +1 -1
  520. package/src/transaction/actions/estimate-gas.ts +3 -3
  521. package/src/transaction/actions/gasless/providers/biconomy.ts +3 -2
  522. package/src/transaction/actions/gasless/providers/engine.ts +2 -2
  523. package/src/transaction/actions/gasless/providers/openzeppelin.ts +2 -2
  524. package/src/transaction/actions/gasless/send-gasless-transaction.ts +2 -2
  525. package/src/transaction/actions/sign-transaction.test.ts +8 -15
  526. package/src/transaction/actions/sign-transaction.ts +9 -11
  527. package/src/transaction/actions/to-serializable-transaction.ts +2 -2
  528. package/src/transaction/actions/zksync/getEip721Domain.ts +2 -2
  529. package/src/transaction/serialize-transaction.test.ts +135 -229
  530. package/src/transaction/serialize-transaction.ts +131 -22
  531. package/src/utils/any-evm/keyless-transaction.test.ts +91 -0
  532. package/src/utils/any-evm/keyless-transaction.ts +43 -14
  533. package/src/utils/hashing/hashMessage.ts +4 -3
  534. package/src/utils/hashing/hashTypedData.ts +24 -27
  535. package/src/utils/signatures/helpers/parse-typed-data.test.ts +56 -0
  536. package/src/utils/signatures/helpers/parse-typed-data.ts +29 -0
  537. package/src/utils/signatures/sign-message.ts +15 -6
  538. package/src/utils/signatures/sign-typed-data.ts +18 -12
  539. package/src/utils/signatures/sign.ts +5 -6
  540. package/src/utils/signatures/signature-to-hex.ts +29 -13
  541. package/src/utils/types.ts +17 -0
  542. package/src/version.ts +1 -1
  543. package/src/wallets/coinbase/coinbase-mobile.test.ts +69 -0
  544. package/src/wallets/coinbase/{coinbaseMobileSDK.ts → coinbase-mobile.ts} +1 -1
  545. package/src/wallets/coinbase/coinbase-wallet.ts +2 -2
  546. package/src/wallets/coinbase/coinbase-web.test.ts +176 -0
  547. package/src/wallets/coinbase/{coinbaseWebSDK.ts → coinbase-web.ts} +13 -17
  548. package/src/wallets/create-wallet.ts +1 -1
  549. package/src/wallets/ecosystem/get-ecosystem-wallet-auth-options.ts +1 -1
  550. package/src/wallets/ecosystem/is-ecosystem-wallet.ts +1 -1
  551. package/src/wallets/eip5792/get-calls-status.ts +2 -2
  552. package/src/wallets/eip5792/get-capabilities.ts +2 -2
  553. package/src/wallets/eip5792/send-calls.ts +2 -2
  554. package/src/wallets/eip5792/show-calls-status.ts +2 -2
  555. package/src/wallets/in-app/core/actions/sign-typed-data.enclave.ts +3 -4
  556. package/src/wallets/in-app/core/wallet/enclave-wallet.ts +1 -1
  557. package/src/wallets/in-app/core/wallet/in-app-core.test.ts +270 -0
  558. package/src/wallets/in-app/core/wallet/in-app-core.ts +16 -5
  559. package/src/wallets/in-app/web/ecosystem.ts +1 -1
  560. package/src/wallets/in-app/web/in-app.ts +2 -2
  561. package/src/wallets/in-app/web/lib/iframe-wallet.ts +2 -2
  562. package/src/wallets/injected/index.ts +1 -1
  563. package/src/wallets/interfaces/wallet.ts +7 -11
  564. package/src/wallets/native/create-wallet.ts +1 -1
  565. package/src/wallets/private-key.ts +16 -14
  566. package/src/wallets/smart/index.ts +68 -235
  567. package/src/wallets/smart/lib/bundler.ts +18 -7
  568. package/src/wallets/smart/lib/calls.ts +4 -2
  569. package/src/wallets/smart/lib/constants.ts +23 -0
  570. package/src/wallets/smart/lib/paymaster.ts +8 -6
  571. package/src/wallets/smart/lib/signing.ts +231 -0
  572. package/src/wallets/smart/lib/userop.ts +34 -10
  573. package/src/wallets/smart/presets/7579.ts +269 -0
  574. package/src/wallets/smart/presets/index.ts +1 -0
  575. package/src/wallets/smart/smart-wallet-dev.test.ts +5 -4
  576. package/src/wallets/smart/smart-wallet-integration-v07.test.ts +299 -0
  577. package/src/wallets/smart/smart-wallet-integration.test.ts +399 -0
  578. package/src/wallets/smart/smart-wallet-modular.test.ts +134 -0
  579. package/src/wallets/smart/smart-wallet-tokenpaymaster.test.ts +117 -0
  580. package/src/wallets/smart/smart-wallet.ts +4 -6
  581. package/src/wallets/smart/smart.test.ts +87 -0
  582. package/src/wallets/smart/types.ts +39 -12
  583. package/src/wallets/wallet-connect/controller.ts +1 -1
  584. package/src/wallets/wallet-connect/receiver/session-request.test.ts +5 -5
  585. package/src/wallets/wallet-types.ts +1 -1
  586. package/dist/cjs/utils/signatures/helpers/parseTypedData.js.map +0 -1
  587. package/dist/cjs/wallets/coinbase/coinbaseMobileSDK.js.map +0 -1
  588. package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js.map +0 -1
  589. package/dist/esm/utils/signatures/helpers/parseTypedData.js +0 -15
  590. package/dist/esm/utils/signatures/helpers/parseTypedData.js.map +0 -1
  591. package/dist/esm/wallets/coinbase/coinbaseMobileSDK.js.map +0 -1
  592. package/dist/esm/wallets/coinbase/coinbaseWebSDK.js.map +0 -1
  593. package/dist/types/utils/signatures/helpers/parseTypedData.d.ts +0 -7
  594. package/dist/types/utils/signatures/helpers/parseTypedData.d.ts.map +0 -1
  595. package/dist/types/wallets/coinbase/coinbaseMobileSDK.d.ts.map +0 -1
  596. package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts.map +0 -1
  597. package/src/utils/signatures/helpers/parseTypedData.ts +0 -25
@@ -1,11 +1,4 @@
1
- import {
2
- type SignableMessage,
3
- type TypedData,
4
- type TypedDataDefinition,
5
- type TypedDataDomain,
6
- hashTypedData,
7
- maxUint96,
8
- } from "viem";
1
+ import type * as ox__TypedData from "ox/TypedData";
9
2
  import type { Chain } from "../../chains/types.js";
10
3
  import { getCachedChain } from "../../chains/utils.js";
11
4
  import type { ThirdwebClient } from "../../client/client.js";
@@ -22,19 +15,15 @@ import type { PreparedTransaction } from "../../transaction/prepare-transaction.
22
15
  import { readContract } from "../../transaction/read-contract.js";
23
16
  import { getAddress } from "../../utils/address.js";
24
17
  import { isZkSyncChain } from "../../utils/any-evm/zksync/isZkSyncChain.js";
25
- import { concatHex } from "../../utils/encoding/helpers/concat-hex.js";
26
18
  import type { Hex } from "../../utils/encoding/hex.js";
27
- import { parseTypedData } from "../../utils/signatures/helpers/parseTypedData.js";
19
+ import { parseTypedData } from "../../utils/signatures/helpers/parse-typed-data.js";
20
+ import { type SignableMessage, maxUint96 } from "../../utils/types.js";
28
21
  import type {
29
22
  Account,
30
23
  SendTransactionOption,
31
24
  Wallet,
32
25
  } from "../interfaces/wallet.js";
33
- import type {
34
- CreateWalletArgs,
35
- WalletConnectionOption,
36
- WalletId,
37
- } from "../wallet-types.js";
26
+ import type { WalletId } from "../wallet-types.js";
38
27
  import {
39
28
  broadcastZkTransaction,
40
29
  bundleUserOp,
@@ -45,7 +34,12 @@ import {
45
34
  prepareBatchExecute,
46
35
  prepareExecute,
47
36
  } from "./lib/calls.js";
48
- import { getDefaultAccountFactory } from "./lib/constants.js";
37
+ import {
38
+ ENTRYPOINT_ADDRESS_v0_6,
39
+ ENTRYPOINT_ADDRESS_v0_7,
40
+ getDefaultAccountFactory,
41
+ getEntryPointVersion,
42
+ } from "./lib/constants.js";
49
43
  import {
50
44
  clearAccountDeploying,
51
45
  createUnsignedUserOp,
@@ -58,6 +52,7 @@ import type {
58
52
  SmartAccountOptions,
59
53
  SmartWalletConnectionOptions,
60
54
  SmartWalletOptions,
55
+ TokenPaymasterConfig,
61
56
  UserOperationV06,
62
57
  UserOperationV07,
63
58
  } from "./types.js";
@@ -89,8 +84,8 @@ const smartWalletToPersonalAccountMap = new WeakMap<Wallet<"smart">, Account>();
89
84
  */
90
85
  export async function connectSmartWallet(
91
86
  wallet: Wallet<"smart">,
92
- connectionOptions: WalletConnectionOption<"smart">,
93
- creationOptions: CreateWalletArgs<"smart">[1],
87
+ connectionOptions: SmartWalletConnectionOptions,
88
+ creationOptions: SmartWalletOptions,
94
89
  ): Promise<[Account, Chain]> {
95
90
  const { personalAccount, client, chain: connectChain } = connectionOptions;
96
91
 
@@ -116,6 +111,17 @@ export async function connectSmartWallet(
116
111
  }
117
112
  }
118
113
 
114
+ if (
115
+ options.overrides?.tokenPaymaster &&
116
+ !options.overrides?.entrypointAddress
117
+ ) {
118
+ // if token paymaster is set, but no entrypoint address, set the entrypoint address to v0.7
119
+ options.overrides = {
120
+ ...options.overrides,
121
+ entrypointAddress: ENTRYPOINT_ADDRESS_v0_7,
122
+ };
123
+ }
124
+
119
125
  const factoryAddress =
120
126
  options.factoryAddress ??
121
127
  getDefaultAccountFactory(options.overrides?.entrypointAddress);
@@ -140,7 +146,6 @@ export async function connectSmartWallet(
140
146
  chain: chain,
141
147
  });
142
148
 
143
- // TODO: listen for chainChanged event on the personal wallet and emit the disconnect event on the smart wallet
144
149
  const accountAddress = await predictAddress({
145
150
  factoryContract,
146
151
  adminAddress: personalAccount.address,
@@ -196,12 +201,24 @@ export async function disconnectSmartWallet(
196
201
  async function createSmartAccount(
197
202
  options: SmartAccountOptions,
198
203
  ): Promise<Account> {
204
+ const erc20Paymaster = options.overrides?.tokenPaymaster;
205
+ if (erc20Paymaster) {
206
+ if (
207
+ getEntryPointVersion(
208
+ options.overrides?.entrypointAddress || ENTRYPOINT_ADDRESS_v0_6,
209
+ ) !== "v0.7"
210
+ ) {
211
+ throw new Error(
212
+ "Token paymaster is only supported for entrypoint version v0.7",
213
+ );
214
+ }
215
+ }
216
+
199
217
  const { accountContract } = options;
200
218
  const account: Account = {
201
219
  address: getAddress(accountContract.address),
202
220
  async sendTransaction(transaction: SendTransactionOption) {
203
221
  // if erc20 paymaster - check allowance and approve if needed
204
- const erc20Paymaster = options.overrides?.erc20Paymaster;
205
222
  let paymasterOverride:
206
223
  | undefined
207
224
  | ((
@@ -215,12 +232,7 @@ async function createSmartAccount(
215
232
  });
216
233
  const paymasterCallback = async (): Promise<PaymasterResult> => {
217
234
  return {
218
- paymasterAndData: concatHex([
219
- erc20Paymaster.address as Hex,
220
- erc20Paymaster?.token as Hex,
221
- ]),
222
- // for 0.7 compatibility
223
- paymaster: erc20Paymaster.address as Hex,
235
+ paymaster: erc20Paymaster.paymasterAddress as Hex,
224
236
  paymasterData: "0x",
225
237
  };
226
238
  };
@@ -256,175 +268,43 @@ async function createSmartAccount(
256
268
  });
257
269
  },
258
270
  async signMessage({ message }: { message: SignableMessage }) {
259
- const [
260
- { isContractDeployed },
261
- { readContract },
262
- { encodeAbiParameters },
263
- { hashMessage },
264
- { checkContractWalletSignature },
265
- ] = await Promise.all([
266
- import("../../utils/bytecode/is-contract-deployed.js"),
267
- import("../../transaction/read-contract.js"),
268
- import("../../utils/abi/encodeAbiParameters.js"),
269
- import("../../utils/hashing/hashMessage.js"),
270
- import("../../extensions/erc1271/checkContractWalletSignature.js"),
271
- ]);
272
- const isDeployed = await isContractDeployed(accountContract);
273
- if (!isDeployed) {
274
- await _deployAccount({
275
- options,
276
- account,
277
- accountContract,
278
- });
279
- // the bundler and rpc might not be in sync, so while the bundler has a transaction hash for the deployment,
280
- // the rpc might not have it yet, so we wait until the rpc confirms the contract is deployed
281
- await confirmContractDeployment({
271
+ if (options.overrides?.signMessage) {
272
+ return options.overrides.signMessage({
273
+ adminAccount: options.personalAccount,
274
+ factoryContract: options.factoryContract,
282
275
  accountContract,
276
+ message,
283
277
  });
284
278
  }
285
279
 
286
- const originalMsgHash = hashMessage(message);
287
- // check if the account contract supports EIP721 domain separator based signing
288
- let factorySupports712 = false;
289
- try {
290
- // this will throw if the contract does not support it (old factories)
291
- await readContract({
292
- contract: accountContract,
293
- method:
294
- "function getMessageHash(bytes32 _hash) public view returns (bytes32)",
295
- params: [originalMsgHash],
296
- });
297
- factorySupports712 = true;
298
- } catch {
299
- // ignore
300
- }
301
-
302
- let sig: `0x${string}`;
303
- if (factorySupports712) {
304
- const wrappedMessageHash = encodeAbiParameters(
305
- [{ type: "bytes32" }],
306
- [originalMsgHash],
307
- );
308
- sig = await options.personalAccount.signTypedData({
309
- domain: {
310
- name: "Account",
311
- version: "1",
312
- chainId: options.chain.id,
313
- verifyingContract: accountContract.address,
314
- },
315
- primaryType: "AccountMessage",
316
- types: { AccountMessage: [{ name: "message", type: "bytes" }] },
317
- message: { message: wrappedMessageHash },
318
- });
319
- } else {
320
- sig = await options.personalAccount.signMessage({ message });
321
- }
322
-
323
- const isValid = await checkContractWalletSignature({
324
- contract: accountContract,
280
+ const { deployAndSignMessage } = await import("./lib/signing.js");
281
+ return deployAndSignMessage({
282
+ accountContract,
283
+ factoryContract: options.factoryContract,
284
+ options,
325
285
  message,
326
- signature: sig,
327
286
  });
328
-
329
- if (isValid) {
330
- return sig;
331
- }
332
- throw new Error(
333
- "Unable to verify signature on smart account, please make sure the smart account is deployed and the signature is valid.",
334
- );
335
287
  },
336
288
  async signTypedData<
337
- const typedData extends TypedData | Record<string, unknown>,
289
+ const typedData extends ox__TypedData.TypedData | Record<string, unknown>,
338
290
  primaryType extends keyof typedData | "EIP712Domain" = keyof typedData,
339
- >(_typedData: TypedDataDefinition<typedData, primaryType>) {
340
- const typedData = parseTypedData(_typedData);
341
- const [
342
- { isContractDeployed },
343
- { readContract },
344
- { encodeAbiParameters },
345
- { checkContractWalletSignedTypedData },
346
- ] = await Promise.all([
347
- import("../../utils/bytecode/is-contract-deployed.js"),
348
- import("../../transaction/read-contract.js"),
349
- import("../../utils/abi/encodeAbiParameters.js"),
350
- import(
351
- "../../extensions/erc1271/checkContractWalletSignedTypedData.js"
352
- ),
353
- ]);
354
- const isSelfVerifyingContract =
355
- (
356
- typedData.domain as TypedDataDomain
357
- )?.verifyingContract?.toLowerCase() ===
358
- accountContract.address?.toLowerCase();
359
-
360
- if (isSelfVerifyingContract) {
361
- // if the contract is self-verifying, we can just sign the message with the EOA (ie. adding a session key)
362
- return options.personalAccount.signTypedData(typedData);
363
- }
364
-
365
- const isDeployed = await isContractDeployed(accountContract);
366
- if (!isDeployed) {
367
- await _deployAccount({
368
- options,
369
- account,
370
- accountContract,
371
- });
372
- // the bundler and rpc might not be in sync, so while the bundler has a transaction hash for the deployment,
373
- // the rpc might not have it yet, so we wait until the rpc confirms the contract is deployed
374
- await confirmContractDeployment({
291
+ >(typedData: ox__TypedData.Definition<typedData, primaryType>) {
292
+ if (options.overrides?.signTypedData) {
293
+ return options.overrides.signTypedData({
294
+ adminAccount: options.personalAccount,
295
+ factoryContract: options.factoryContract,
375
296
  accountContract,
297
+ typedData,
376
298
  });
377
299
  }
378
300
 
379
- const originalMsgHash = hashTypedData(typedData);
380
- // check if the account contract supports EIP721 domain separator based signing
381
- let factorySupports712 = false;
382
- try {
383
- // this will throw if the contract does not support it (old factories)
384
- await readContract({
385
- contract: accountContract,
386
- method:
387
- "function getMessageHash(bytes32 _hash) public view returns (bytes32)",
388
- params: [originalMsgHash],
389
- });
390
- factorySupports712 = true;
391
- } catch {
392
- // ignore
393
- }
394
-
395
- let sig: `0x${string}`;
396
- if (factorySupports712) {
397
- const wrappedMessageHash = encodeAbiParameters(
398
- [{ type: "bytes32" }],
399
- [originalMsgHash],
400
- );
401
- sig = await options.personalAccount.signTypedData({
402
- domain: {
403
- name: "Account",
404
- version: "1",
405
- chainId: options.chain.id,
406
- verifyingContract: accountContract.address,
407
- },
408
- primaryType: "AccountMessage",
409
- types: { AccountMessage: [{ name: "message", type: "bytes" }] },
410
- message: { message: wrappedMessageHash },
411
- });
412
- } else {
413
- sig = await options.personalAccount.signTypedData(typedData);
414
- }
415
-
416
- const isValid = await checkContractWalletSignedTypedData({
417
- contract: accountContract,
418
- data: typedData,
419
- signature: sig,
301
+ const { deployAndSignTypedData } = await import("./lib/signing.js");
302
+ return deployAndSignTypedData({
303
+ accountContract,
304
+ factoryContract: options.factoryContract,
305
+ options,
306
+ typedData,
420
307
  });
421
-
422
- if (isValid) {
423
- return sig;
424
- }
425
- throw new Error(
426
- "Unable to verify signature on smart account, please make sure the smart account is deployed and the signature is valid.",
427
- );
428
308
  },
429
309
  async onTransactionRequested(transaction) {
430
310
  return options.personalAccount.onTransactionRequested?.(transaction);
@@ -436,13 +316,10 @@ async function createSmartAccount(
436
316
  async function approveERC20(args: {
437
317
  accountContract: ThirdwebContract;
438
318
  options: SmartAccountOptions;
439
- erc20Paymaster: {
440
- address: string;
441
- token: string;
442
- };
319
+ erc20Paymaster: TokenPaymasterConfig;
443
320
  }) {
444
321
  const { accountContract, erc20Paymaster, options } = args;
445
- const tokenAddress = erc20Paymaster.token;
322
+ const tokenAddress = erc20Paymaster.tokenAddress;
446
323
  const tokenContract = getContract({
447
324
  address: tokenAddress,
448
325
  chain: accountContract.chain,
@@ -451,7 +328,7 @@ async function approveERC20(args: {
451
328
  const accountAllowance = await allowance({
452
329
  contract: tokenContract,
453
330
  owner: accountContract.address,
454
- spender: erc20Paymaster.address,
331
+ spender: erc20Paymaster.paymasterAddress,
455
332
  });
456
333
 
457
334
  if (accountAllowance > 0n) {
@@ -460,7 +337,7 @@ async function approveERC20(args: {
460
337
 
461
338
  const approveTx = approve({
462
339
  contract: tokenContract,
463
- spender: erc20Paymaster.address,
340
+ spender: erc20Paymaster.paymasterAddress,
464
341
  amountWei: maxUint96 - 1n,
465
342
  });
466
343
  const transaction = await toSerializableTransaction({
@@ -478,7 +355,7 @@ async function approveERC20(args: {
478
355
  ...options,
479
356
  overrides: {
480
357
  ...options.overrides,
481
- erc20Paymaster: undefined,
358
+ tokenPaymaster: undefined,
482
359
  },
483
360
  },
484
361
  });
@@ -554,9 +431,9 @@ function createZkSyncAccount(args: {
554
431
  return connectionOptions.personalAccount.signMessage({ message });
555
432
  },
556
433
  async signTypedData<
557
- const typedData extends TypedData | Record<string, unknown>,
434
+ const typedData extends ox__TypedData.TypedData | Record<string, unknown>,
558
435
  primaryType extends keyof typedData | "EIP712Domain" = keyof typedData,
559
- >(_typedData: TypedDataDefinition<typedData, primaryType>) {
436
+ >(_typedData: ox__TypedData.Definition<typedData, primaryType>) {
560
437
  const typedData = parseTypedData(_typedData);
561
438
  return connectionOptions.personalAccount.signTypedData(typedData);
562
439
  },
@@ -569,30 +446,6 @@ function createZkSyncAccount(args: {
569
446
  return account;
570
447
  }
571
448
 
572
- async function _deployAccount(args: {
573
- options: SmartAccountOptions;
574
- account: Account;
575
- accountContract: ThirdwebContract;
576
- }) {
577
- const { options, account, accountContract } = args;
578
- const [{ sendTransaction }, { prepareTransaction }] = await Promise.all([
579
- import("../../transaction/actions/send-transaction.js"),
580
- import("../../transaction/prepare-transaction.js"),
581
- ]);
582
- const dummyTx = prepareTransaction({
583
- client: options.client,
584
- chain: options.chain,
585
- to: accountContract.address,
586
- value: 0n,
587
- gas: 50000n, // force gas to avoid simulation error
588
- });
589
- const deployResult = await sendTransaction({
590
- transaction: dummyTx,
591
- account,
592
- });
593
- return deployResult;
594
- }
595
-
596
449
  async function _sendUserOp(args: {
597
450
  executeTx: PreparedTransaction;
598
451
  options: SmartAccountOptions;
@@ -639,26 +492,6 @@ async function _sendUserOp(args: {
639
492
  };
640
493
  }
641
494
 
642
- async function confirmContractDeployment(args: {
643
- accountContract: ThirdwebContract;
644
- }) {
645
- const { accountContract } = args;
646
- const startTime = Date.now();
647
- const timeout = 60000; // wait 1 minute max
648
- const { isContractDeployed } = await import(
649
- "../../utils/bytecode/is-contract-deployed.js"
650
- );
651
- let isDeployed = await isContractDeployed(accountContract);
652
- while (!isDeployed) {
653
- if (Date.now() - startTime > timeout) {
654
- throw new Error(
655
- "Timeout: Smart account deployment not confirmed after 1 minute",
656
- );
657
- }
658
- await new Promise((resolve) => setTimeout(resolve, 500));
659
- isDeployed = await isContractDeployed(accountContract);
660
- }
661
- }
662
495
  async function getEntrypointFromFactory(
663
496
  factoryAddress: string,
664
497
  client: ThirdwebClient,
@@ -1,7 +1,8 @@
1
- import { type TransactionSerializable, decodeErrorResult } from "viem";
1
+ import { decodeErrorResult } from "viem";
2
2
  import { parseEventLogs } from "../../../event/actions/parse-logs.js";
3
3
  import { userOperationRevertReasonEvent } from "../../../extensions/erc4337/__generated__/IEntryPoint/events/UserOperationRevertReason.js";
4
4
  import { postOpRevertReasonEvent } from "../../../extensions/erc4337/__generated__/IEntryPoint_v07/events/PostOpRevertReason.js";
5
+ import type { SerializableTransaction } from "../../../transaction/serialize-transaction.js";
5
6
  import type { TransactionReceipt } from "../../../transaction/types.js";
6
7
  import { type Hex, hexToBigInt } from "../../../utils/encoding/hex.js";
7
8
  import { getClientFetch } from "../../../utils/fetch.js";
@@ -67,16 +68,26 @@ export async function bundleUserOp(args: {
67
68
  * ```
68
69
  * @walletUtils
69
70
  */
70
- export async function estimateUserOpGas(args: {
71
- userOp: UserOperationV06 | UserOperationV07;
72
- options: BundlerOptions;
73
- }): Promise<EstimationResult> {
71
+ export async function estimateUserOpGas(
72
+ args: {
73
+ userOp: UserOperationV06 | UserOperationV07;
74
+ options: BundlerOptions;
75
+ },
76
+ stateOverrides?: {
77
+ [x: string]: {
78
+ stateDiff: {
79
+ [x: string]: `0x${string}`;
80
+ };
81
+ };
82
+ },
83
+ ): Promise<EstimationResult> {
74
84
  const res = await sendBundlerRequest({
75
85
  ...args,
76
86
  operation: "eth_estimateUserOperationGas",
77
87
  params: [
78
88
  hexlifyUserOp(args.userOp),
79
89
  args.options.entrypointAddress ?? ENTRYPOINT_ADDRESS_v0_6,
90
+ stateOverrides ?? {},
80
91
  ],
81
92
  });
82
93
 
@@ -217,7 +228,7 @@ export async function getUserOpReceiptRaw(
217
228
  */
218
229
  export async function getZkPaymasterData(args: {
219
230
  options: BundlerOptions;
220
- transaction: TransactionSerializable;
231
+ transaction: SerializableTransaction;
221
232
  }): Promise<PmTransactionData> {
222
233
  const res = await sendBundlerRequest({
223
234
  options: args.options,
@@ -233,7 +244,7 @@ export async function getZkPaymasterData(args: {
233
244
 
234
245
  export async function broadcastZkTransaction(args: {
235
246
  options: BundlerOptions;
236
- transaction: TransactionSerializable;
247
+ transaction: SerializableTransaction;
237
248
  signedTransaction: Hex;
238
249
  }): Promise<{ transactionHash: Hex }> {
239
250
  const res = await sendBundlerRequest({
@@ -66,6 +66,7 @@ export async function predictAddress(args: {
66
66
  factoryContract: ThirdwebContract;
67
67
  predictAddressOverride?: (
68
68
  factoryContract: ThirdwebContract,
69
+ admin: string,
69
70
  ) => Promise<string>;
70
71
  adminAddress: string;
71
72
  accountSalt?: string;
@@ -79,7 +80,7 @@ export async function predictAddress(args: {
79
80
  accountAddress,
80
81
  } = args;
81
82
  if (predictAddress) {
82
- return predictAddress(factoryContract);
83
+ return predictAddress(factoryContract, adminAddress);
83
84
  }
84
85
  if (accountAddress) {
85
86
  return accountAddress;
@@ -109,6 +110,7 @@ export function prepareCreateAccount(args: {
109
110
  accountSalt?: string;
110
111
  createAccountOverride?: (
111
112
  factoryContract: ThirdwebContract,
113
+ admin: string,
112
114
  ) => PreparedTransaction;
113
115
  }): PreparedTransaction {
114
116
  const {
@@ -118,7 +120,7 @@ export function prepareCreateAccount(args: {
118
120
  accountSalt,
119
121
  } = args;
120
122
  if (createAccount) {
121
- return createAccount(factoryContract);
123
+ return createAccount(factoryContract, adminAddress);
122
124
  }
123
125
  const saltHex =
124
126
  accountSalt && isHex(accountSalt)
@@ -1,6 +1,7 @@
1
1
  import type { Chain } from "../../../chains/types.js";
2
2
  import { getAddress } from "../../../utils/address.js";
3
3
  import { getThirdwebDomains } from "../../../utils/domains.js";
4
+ import type { TokenPaymasterConfig } from "../types.js";
4
5
 
5
6
  export const DUMMY_SIGNATURE =
6
7
  "0xfffffffffffffffffffffffffffffff0000000000000000000000000000000007aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa1c";
@@ -17,6 +18,28 @@ export const ENTRYPOINT_ADDRESS_v0_7 =
17
18
 
18
19
  export const MANAGED_ACCOUNT_GAS_BUFFER = 50000n;
19
20
 
21
+ type PAYMASTERS = "BASE_USDC" | "CELO_CUSD" | "LISK_LSK";
22
+ export const TokenPaymaster: Record<PAYMASTERS, TokenPaymasterConfig> = {
23
+ BASE_USDC: {
24
+ chainId: 8453,
25
+ paymasterAddress: "0x2222f2738BE6bB7aA0Bfe4AEeAf2908172CF5539",
26
+ tokenAddress: "0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913",
27
+ balanceStorageSlot: 9n,
28
+ },
29
+ CELO_CUSD: {
30
+ chainId: 42220,
31
+ paymasterAddress: "0x3feA3c5744D715ff46e91C4e5C9a94426DfF2aF9",
32
+ tokenAddress: "0x765DE816845861e75A25fCA122bb6898B8B1282a",
33
+ balanceStorageSlot: 9n,
34
+ },
35
+ LISK_LSK: {
36
+ chainId: 1135,
37
+ paymasterAddress: "0x9eb8cf7fBa5ed9EeDCC97a0d52254cc0e9B1AC25",
38
+ tokenAddress: "0xac485391EB2d7D88253a7F1eF18C37f4242D1A24",
39
+ balanceStorageSlot: 9n,
40
+ },
41
+ };
42
+
20
43
  /*
21
44
  * @internal
22
45
  */
@@ -51,17 +51,19 @@ export async function getPaymasterAndData(args: {
51
51
  const entrypoint = entrypointAddress ?? ENTRYPOINT_ADDRESS_v0_6;
52
52
  const paymasterUrl = getDefaultBundlerUrl(chain);
53
53
 
54
+ const body = {
55
+ jsonrpc: "2.0",
56
+ id: 1,
57
+ method: "pm_sponsorUserOperation",
58
+ params: [hexlifyUserOp(userOp), entrypoint],
59
+ };
60
+
54
61
  // Ask the paymaster to sign the transaction and return a valid paymasterAndData value.
55
62
  const fetchWithHeaders = getClientFetch(client);
56
63
  const response = await fetchWithHeaders(paymasterUrl, {
57
64
  method: "POST",
58
65
  headers,
59
- body: stringify({
60
- jsonrpc: "2.0",
61
- id: 1,
62
- method: "pm_sponsorUserOperation",
63
- params: [hexlifyUserOp(userOp), entrypoint],
64
- }),
66
+ body: stringify(body),
65
67
  });
66
68
  const res = await response.json();
67
69