thirdweb 5.83.2-nightly-332536bdee05b6fb3b36d33761381826279b48f6-20250113000321 → 5.84.0

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 (322) hide show
  1. package/dist/cjs/ai/chat.js +29 -0
  2. package/dist/cjs/ai/chat.js.map +1 -0
  3. package/dist/cjs/ai/common.js +69 -0
  4. package/dist/cjs/ai/common.js.map +1 -0
  5. package/dist/cjs/ai/execute.js +43 -0
  6. package/dist/cjs/ai/execute.js.map +1 -0
  7. package/dist/cjs/ai/index.js +8 -0
  8. package/dist/cjs/ai/index.js.map +1 -0
  9. package/dist/cjs/auth/is-erc6492-signature.js +2 -2
  10. package/dist/cjs/auth/is-erc6492-signature.js.map +1 -1
  11. package/dist/cjs/auth/parse-erc6492-signature.js +10 -4
  12. package/dist/cjs/auth/parse-erc6492-signature.js.map +1 -1
  13. package/dist/cjs/auth/verify-hash.js +12 -11
  14. package/dist/cjs/auth/verify-hash.js.map +1 -1
  15. package/dist/cjs/auth/verify-signature.js +13 -5
  16. package/dist/cjs/auth/verify-signature.js.map +1 -1
  17. package/dist/cjs/auth/verify-typed-data.js +2 -2
  18. package/dist/cjs/auth/verify-typed-data.js.map +1 -1
  19. package/dist/cjs/contract/deployment/utils/create-2-factory.js +4 -3
  20. package/dist/cjs/contract/deployment/utils/create-2-factory.js.map +1 -1
  21. package/dist/cjs/contract/verification/constructor-params.js +5 -12
  22. package/dist/cjs/contract/verification/constructor-params.js.map +1 -1
  23. package/dist/cjs/exports/ai.js +5 -0
  24. package/dist/cjs/exports/ai.js.map +1 -0
  25. package/dist/cjs/exports/utils.js +9 -6
  26. package/dist/cjs/exports/utils.js.map +1 -1
  27. package/dist/cjs/exports/wallets/engine.js +6 -0
  28. package/dist/cjs/exports/wallets/engine.js.map +1 -0
  29. package/dist/cjs/exports/wallets.js +3 -1
  30. package/dist/cjs/exports/wallets.js.map +1 -1
  31. package/dist/cjs/extensions/ens/resolve-l2-name.js +10 -3
  32. package/dist/cjs/extensions/ens/resolve-l2-name.js.map +1 -1
  33. package/dist/cjs/extensions/erc1155/read/getNFTs.js +2 -2
  34. package/dist/cjs/extensions/erc1155/read/getNFTs.js.map +1 -1
  35. package/dist/cjs/extensions/erc1155/write/mintTo.js +2 -2
  36. package/dist/cjs/extensions/erc1155/write/mintTo.js.map +1 -1
  37. package/dist/cjs/extensions/erc1155/write/mintToBatch.js +2 -2
  38. package/dist/cjs/extensions/erc1155/write/mintToBatch.js.map +1 -1
  39. package/dist/cjs/extensions/erc1155/write/sigMint.js +2 -2
  40. package/dist/cjs/extensions/erc1155/write/sigMint.js.map +1 -1
  41. package/dist/cjs/extensions/modules/ClaimableERC1155/setClaimConditions.js +3 -2
  42. package/dist/cjs/extensions/modules/ClaimableERC1155/setClaimConditions.js.map +1 -1
  43. package/dist/cjs/extensions/modules/MintableERC1155/mintWithRole.js +2 -2
  44. package/dist/cjs/extensions/modules/MintableERC1155/mintWithRole.js.map +1 -1
  45. package/dist/cjs/extensions/modules/MintableERC1155/mintWithSignature.js +2 -2
  46. package/dist/cjs/extensions/modules/MintableERC1155/mintWithSignature.js.map +1 -1
  47. package/dist/cjs/react/core/hooks/wallets/useAutoConnect.js +10 -131
  48. package/dist/cjs/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
  49. package/dist/cjs/react/core/hooks/wallets/useSendToken.js +2 -1
  50. package/dist/cjs/react/core/hooks/wallets/useSendToken.js.map +1 -1
  51. package/dist/cjs/react/native/hooks/wallets/useAutoConnect.js.map +1 -1
  52. package/dist/cjs/react/web/hooks/wallets/useAutoConnect.js +1 -1
  53. package/dist/cjs/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
  54. package/dist/cjs/react/web/ui/ConnectWallet/ConnectButton.js +3 -1
  55. package/dist/cjs/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
  56. package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js +2 -1
  57. package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js.map +1 -1
  58. package/dist/cjs/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.js +1 -1
  59. package/dist/cjs/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.js.map +1 -1
  60. package/dist/cjs/react/web/ui/ConnectWallet/useConnectModal.js +1 -1
  61. package/dist/cjs/react/web/ui/ConnectWallet/useConnectModal.js.map +1 -1
  62. package/dist/cjs/react/web/wallets/in-app/WalletAuth.js +1 -1
  63. package/dist/cjs/react/web/wallets/in-app/WalletAuth.js.map +1 -1
  64. package/dist/cjs/utils/abi/encodeAbiParameters.js +10 -11
  65. package/dist/cjs/utils/abi/encodeAbiParameters.js.map +1 -1
  66. package/dist/cjs/utils/ens/isValidENSName.js +50 -0
  67. package/dist/cjs/utils/ens/isValidENSName.js.map +1 -0
  68. package/dist/cjs/utils/extensions/drops/convert-quantity.js +2 -2
  69. package/dist/cjs/utils/extensions/drops/convert-quantity.js.map +1 -1
  70. package/dist/cjs/utils/extensions/drops/get-multicall-set-claim-claim-conditon-transactions.js +3 -3
  71. package/dist/cjs/utils/extensions/drops/get-multicall-set-claim-claim-conditon-transactions.js.map +1 -1
  72. package/dist/cjs/utils/timeoutPromise.js.map +1 -0
  73. package/dist/cjs/version.js +1 -1
  74. package/dist/cjs/version.js.map +1 -1
  75. package/dist/cjs/wallets/connection/autoConnect.js +54 -0
  76. package/dist/cjs/wallets/connection/autoConnect.js.map +1 -0
  77. package/dist/cjs/wallets/connection/autoConnectCore.js +135 -0
  78. package/dist/cjs/wallets/connection/autoConnectCore.js.map +1 -0
  79. package/dist/cjs/wallets/connection/types.js.map +1 -0
  80. package/dist/cjs/{react/web/wallets → wallets}/defaultWallets.js +2 -2
  81. package/dist/cjs/wallets/defaultWallets.js.map +1 -0
  82. package/dist/cjs/wallets/engine/index.js +143 -0
  83. package/dist/cjs/wallets/engine/index.js.map +1 -0
  84. package/dist/cjs/wallets/in-app/web/lib/get-url-token.js +1 -1
  85. package/dist/cjs/wallets/in-app/web/lib/get-url-token.js.map +1 -1
  86. package/dist/cjs/wallets/smart/lib/signing.js +1 -1
  87. package/dist/esm/ai/chat.js +26 -0
  88. package/dist/esm/ai/chat.js.map +1 -0
  89. package/dist/esm/ai/common.js +66 -0
  90. package/dist/esm/ai/common.js.map +1 -0
  91. package/dist/esm/ai/execute.js +40 -0
  92. package/dist/esm/ai/execute.js.map +1 -0
  93. package/dist/esm/ai/index.js +3 -0
  94. package/dist/esm/ai/index.js.map +1 -0
  95. package/dist/esm/auth/is-erc6492-signature.js +2 -2
  96. package/dist/esm/auth/is-erc6492-signature.js.map +1 -1
  97. package/dist/esm/auth/parse-erc6492-signature.js +10 -4
  98. package/dist/esm/auth/parse-erc6492-signature.js.map +1 -1
  99. package/dist/esm/auth/verify-hash.js +12 -11
  100. package/dist/esm/auth/verify-hash.js.map +1 -1
  101. package/dist/esm/auth/verify-signature.js +13 -5
  102. package/dist/esm/auth/verify-signature.js.map +1 -1
  103. package/dist/esm/auth/verify-typed-data.js +2 -2
  104. package/dist/esm/auth/verify-typed-data.js.map +1 -1
  105. package/dist/esm/contract/deployment/utils/create-2-factory.js +4 -3
  106. package/dist/esm/contract/deployment/utils/create-2-factory.js.map +1 -1
  107. package/dist/esm/contract/verification/constructor-params.js +5 -12
  108. package/dist/esm/contract/verification/constructor-params.js.map +1 -1
  109. package/dist/esm/exports/ai.js +2 -0
  110. package/dist/esm/exports/ai.js.map +1 -0
  111. package/dist/esm/exports/utils.js +3 -1
  112. package/dist/esm/exports/utils.js.map +1 -1
  113. package/dist/esm/exports/wallets/engine.js +2 -0
  114. package/dist/esm/exports/wallets/engine.js.map +1 -0
  115. package/dist/esm/exports/wallets.js +1 -0
  116. package/dist/esm/exports/wallets.js.map +1 -1
  117. package/dist/esm/extensions/ens/resolve-l2-name.js +11 -4
  118. package/dist/esm/extensions/ens/resolve-l2-name.js.map +1 -1
  119. package/dist/esm/extensions/erc1155/read/getNFTs.js +1 -1
  120. package/dist/esm/extensions/erc1155/read/getNFTs.js.map +1 -1
  121. package/dist/esm/extensions/erc1155/write/mintTo.js +1 -1
  122. package/dist/esm/extensions/erc1155/write/mintTo.js.map +1 -1
  123. package/dist/esm/extensions/erc1155/write/mintToBatch.js +1 -1
  124. package/dist/esm/extensions/erc1155/write/mintToBatch.js.map +1 -1
  125. package/dist/esm/extensions/erc1155/write/sigMint.js +1 -1
  126. package/dist/esm/extensions/erc1155/write/sigMint.js.map +1 -1
  127. package/dist/esm/extensions/modules/ClaimableERC1155/setClaimConditions.js +2 -1
  128. package/dist/esm/extensions/modules/ClaimableERC1155/setClaimConditions.js.map +1 -1
  129. package/dist/esm/extensions/modules/MintableERC1155/mintWithRole.js +1 -1
  130. package/dist/esm/extensions/modules/MintableERC1155/mintWithRole.js.map +1 -1
  131. package/dist/esm/extensions/modules/MintableERC1155/mintWithSignature.js +1 -1
  132. package/dist/esm/extensions/modules/MintableERC1155/mintWithSignature.js.map +1 -1
  133. package/dist/esm/react/core/hooks/wallets/useAutoConnect.js +10 -130
  134. package/dist/esm/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
  135. package/dist/esm/react/core/hooks/wallets/useSendToken.js +2 -1
  136. package/dist/esm/react/core/hooks/wallets/useSendToken.js.map +1 -1
  137. package/dist/esm/react/native/hooks/wallets/useAutoConnect.js.map +1 -1
  138. package/dist/esm/react/web/hooks/wallets/useAutoConnect.js +1 -1
  139. package/dist/esm/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
  140. package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js +3 -1
  141. package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
  142. package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js +2 -1
  143. package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js.map +1 -1
  144. package/dist/esm/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.js +1 -1
  145. package/dist/esm/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.js.map +1 -1
  146. package/dist/esm/react/web/ui/ConnectWallet/useConnectModal.js +1 -1
  147. package/dist/esm/react/web/ui/ConnectWallet/useConnectModal.js.map +1 -1
  148. package/dist/esm/react/web/wallets/in-app/WalletAuth.js +1 -1
  149. package/dist/esm/react/web/wallets/in-app/WalletAuth.js.map +1 -1
  150. package/dist/esm/utils/abi/encodeAbiParameters.js +10 -11
  151. package/dist/esm/utils/abi/encodeAbiParameters.js.map +1 -1
  152. package/dist/esm/utils/ens/isValidENSName.js +47 -0
  153. package/dist/esm/utils/ens/isValidENSName.js.map +1 -0
  154. package/dist/esm/utils/extensions/drops/convert-quantity.js +1 -1
  155. package/dist/esm/utils/extensions/drops/convert-quantity.js.map +1 -1
  156. package/dist/esm/utils/extensions/drops/get-multicall-set-claim-claim-conditon-transactions.js +1 -1
  157. package/dist/esm/utils/extensions/drops/get-multicall-set-claim-claim-conditon-transactions.js.map +1 -1
  158. package/dist/esm/utils/timeoutPromise.js.map +1 -0
  159. package/dist/esm/version.js +1 -1
  160. package/dist/esm/version.js.map +1 -1
  161. package/dist/esm/wallets/connection/autoConnect.js +50 -0
  162. package/dist/esm/wallets/connection/autoConnect.js.map +1 -0
  163. package/dist/esm/wallets/connection/autoConnectCore.js +130 -0
  164. package/dist/esm/wallets/connection/autoConnectCore.js.map +1 -0
  165. package/dist/esm/wallets/connection/types.js.map +1 -0
  166. package/dist/esm/{react/web/wallets → wallets}/defaultWallets.js +2 -2
  167. package/dist/esm/wallets/defaultWallets.js.map +1 -0
  168. package/dist/esm/wallets/engine/index.js +140 -0
  169. package/dist/esm/wallets/engine/index.js.map +1 -0
  170. package/dist/esm/wallets/in-app/web/lib/get-url-token.js +1 -1
  171. package/dist/esm/wallets/in-app/web/lib/get-url-token.js.map +1 -1
  172. package/dist/esm/wallets/smart/lib/signing.js +1 -1
  173. package/dist/types/ai/chat.d.ts +24 -0
  174. package/dist/types/ai/chat.d.ts.map +1 -0
  175. package/dist/types/ai/common.d.ts +22 -0
  176. package/dist/types/ai/common.d.ts.map +1 -0
  177. package/dist/types/ai/execute.d.ts +29 -0
  178. package/dist/types/ai/execute.d.ts.map +1 -0
  179. package/dist/types/ai/index.d.ts +4 -0
  180. package/dist/types/ai/index.d.ts.map +1 -0
  181. package/dist/types/auth/parse-erc6492-signature.d.ts.map +1 -1
  182. package/dist/types/auth/verify-hash.d.ts +2 -2
  183. package/dist/types/auth/verify-hash.d.ts.map +1 -1
  184. package/dist/types/auth/verify-signature.d.ts +6 -3
  185. package/dist/types/auth/verify-signature.d.ts.map +1 -1
  186. package/dist/types/auth/verify-typed-data.d.ts +5 -4
  187. package/dist/types/auth/verify-typed-data.d.ts.map +1 -1
  188. package/dist/types/contract/deployment/utils/create-2-factory.d.ts.map +1 -1
  189. package/dist/types/contract/verification/constructor-params.d.ts +2 -2
  190. package/dist/types/contract/verification/constructor-params.d.ts.map +1 -1
  191. package/dist/types/event/types.d.ts +3 -2
  192. package/dist/types/event/types.d.ts.map +1 -1
  193. package/dist/types/exports/ai.d.ts +2 -0
  194. package/dist/types/exports/ai.d.ts.map +1 -0
  195. package/dist/types/exports/react.d.ts +1 -1
  196. package/dist/types/exports/react.d.ts.map +1 -1
  197. package/dist/types/exports/react.native.d.ts +1 -1
  198. package/dist/types/exports/react.native.d.ts.map +1 -1
  199. package/dist/types/exports/utils.d.ts +2 -1
  200. package/dist/types/exports/utils.d.ts.map +1 -1
  201. package/dist/types/exports/wallets/engine.d.ts +2 -0
  202. package/dist/types/exports/wallets/engine.d.ts.map +1 -0
  203. package/dist/types/exports/wallets.d.ts +2 -0
  204. package/dist/types/exports/wallets.d.ts.map +1 -1
  205. package/dist/types/extensions/ens/resolve-l2-name.d.ts.map +1 -1
  206. package/dist/types/extensions/erc1155/write/mintTo.d.ts +1 -1
  207. package/dist/types/extensions/erc1155/write/mintTo.d.ts.map +1 -1
  208. package/dist/types/extensions/erc1155/write/mintToBatch.d.ts +1 -1
  209. package/dist/types/extensions/erc1155/write/mintToBatch.d.ts.map +1 -1
  210. package/dist/types/extensions/modules/ClaimableERC1155/setClaimConditions.d.ts.map +1 -1
  211. package/dist/types/extensions/modules/MintableERC1155/mintWithRole.d.ts +1 -1
  212. package/dist/types/extensions/modules/MintableERC1155/mintWithRole.d.ts.map +1 -1
  213. package/dist/types/extensions/modules/MintableERC1155/mintWithSignature.d.ts +1 -1
  214. package/dist/types/extensions/modules/MintableERC1155/mintWithSignature.d.ts.map +1 -1
  215. package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts +1 -13
  216. package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts.map +1 -1
  217. package/dist/types/react/core/hooks/wallets/useSendToken.d.ts.map +1 -1
  218. package/dist/types/react/native/hooks/wallets/useAutoConnect.d.ts +1 -1
  219. package/dist/types/react/native/hooks/wallets/useAutoConnect.d.ts.map +1 -1
  220. package/dist/types/react/native/ui/AutoConnect/AutoConnect.d.ts +1 -1
  221. package/dist/types/react/web/hooks/wallets/useAutoConnect.d.ts +1 -1
  222. package/dist/types/react/web/hooks/wallets/useAutoConnect.d.ts.map +1 -1
  223. package/dist/types/react/web/ui/AutoConnect/AutoConnect.d.ts +1 -1
  224. package/dist/types/react/web/ui/ConnectWallet/ConnectButton.d.ts +2 -0
  225. package/dist/types/react/web/ui/ConnectWallet/ConnectButton.d.ts.map +1 -1
  226. package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectEmbed.d.ts +1 -0
  227. package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectEmbed.d.ts.map +1 -1
  228. package/dist/types/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.d.ts.map +1 -1
  229. package/dist/types/react/web/ui/ConnectWallet/useConnectModal.d.ts.map +1 -1
  230. package/dist/types/react/web/wallets/in-app/WalletAuth.d.ts.map +1 -1
  231. package/dist/types/utils/ens/isValidENSName.d.ts +14 -0
  232. package/dist/types/utils/ens/isValidENSName.d.ts.map +1 -0
  233. package/dist/types/utils/timeoutPromise.d.ts.map +1 -0
  234. package/dist/types/version.d.ts +1 -1
  235. package/dist/types/version.d.ts.map +1 -1
  236. package/dist/types/wallets/connection/autoConnect.d.ts +27 -0
  237. package/dist/types/wallets/connection/autoConnect.d.ts.map +1 -0
  238. package/dist/types/wallets/connection/autoConnectCore.d.ts +32 -0
  239. package/dist/types/wallets/connection/autoConnectCore.d.ts.map +1 -0
  240. package/dist/types/{react/core/hooks → wallets}/connection/types.d.ts +5 -5
  241. package/dist/types/wallets/connection/types.d.ts.map +1 -0
  242. package/dist/types/wallets/defaultWallets.d.ts +11 -0
  243. package/dist/types/wallets/defaultWallets.d.ts.map +1 -0
  244. package/dist/types/wallets/engine/index.d.ts +54 -0
  245. package/dist/types/wallets/engine/index.d.ts.map +1 -0
  246. package/dist/types/wallets/smart/lib/signing.d.ts +1 -1
  247. package/package.json +9 -1
  248. package/src/ai/chat.test.ts +31 -0
  249. package/src/ai/chat.ts +26 -0
  250. package/src/ai/common.ts +114 -0
  251. package/src/ai/execute.test.ts +43 -0
  252. package/src/ai/execute.ts +44 -0
  253. package/src/ai/index.ts +3 -0
  254. package/src/auth/is-erc6492-signature.ts +2 -2
  255. package/src/auth/parse-erc6492-signature.ts +10 -4
  256. package/src/auth/verify-hash.ts +16 -20
  257. package/src/auth/verify-signature.test.ts +48 -2
  258. package/src/auth/verify-signature.ts +24 -7
  259. package/src/auth/verify-typed-data.ts +9 -7
  260. package/src/contract/deployment/utils/create-2-factory.ts +4 -3
  261. package/src/contract/verification/constructor-params.ts +8 -15
  262. package/src/event/types.ts +6 -5
  263. package/src/exports/ai.ts +1 -0
  264. package/src/exports/react.native.ts +1 -1
  265. package/src/exports/react.ts +1 -1
  266. package/src/exports/utils.ts +4 -1
  267. package/src/exports/wallets/engine.ts +4 -0
  268. package/src/exports/wallets.ts +2 -0
  269. package/src/extensions/ens/resolve-l2-name.ts +21 -5
  270. package/src/extensions/erc1155/read/getNFTs.ts +1 -1
  271. package/src/extensions/erc1155/write/mintTo.ts +1 -1
  272. package/src/extensions/erc1155/write/mintToBatch.ts +1 -1
  273. package/src/extensions/erc1155/write/sigMint.ts +1 -1
  274. package/src/extensions/modules/ClaimableERC1155/setClaimConditions.ts +2 -1
  275. package/src/extensions/modules/MintableERC1155/mintWithRole.ts +1 -1
  276. package/src/extensions/modules/MintableERC1155/mintWithSignature.ts +1 -1
  277. package/src/react/core/hooks/wallets/useAutoConnect.ts +12 -158
  278. package/src/react/core/hooks/wallets/useAutoConnectCore.test.tsx +1 -31
  279. package/src/react/core/hooks/wallets/useSendToken.ts +2 -1
  280. package/src/react/native/hooks/wallets/useAutoConnect.ts +1 -1
  281. package/src/react/native/ui/AutoConnect/AutoConnect.tsx +1 -1
  282. package/src/react/web/hooks/wallets/useAutoConnect.ts +2 -2
  283. package/src/react/web/ui/AutoConnect/AutoConnect.tsx +1 -1
  284. package/src/react/web/ui/ConnectWallet/ConnectButton.tsx +3 -1
  285. package/src/react/web/ui/ConnectWallet/Modal/ConnectEmbed.tsx +2 -1
  286. package/src/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.tsx +1 -1
  287. package/src/react/web/ui/ConnectWallet/useConnectModal.tsx +1 -1
  288. package/src/react/web/wallets/in-app/WalletAuth.tsx +1 -1
  289. package/src/utils/abi/encodeAbiParameters.ts +15 -11
  290. package/src/utils/ens/isValidENSName.test.ts +39 -0
  291. package/src/utils/ens/isValidENSName.ts +54 -0
  292. package/src/utils/extensions/drops/convert-quantity.ts +1 -1
  293. package/src/utils/extensions/drops/get-multicall-set-claim-claim-conditon-transactions.ts +1 -1
  294. package/src/version.ts +1 -1
  295. package/src/wallets/connection/autoConnect.test.ts +67 -0
  296. package/src/wallets/connection/autoConnect.ts +58 -0
  297. package/src/wallets/connection/autoConnectCore.test.ts +403 -0
  298. package/src/wallets/connection/autoConnectCore.ts +184 -0
  299. package/src/{react/core/hooks → wallets}/connection/types.ts +5 -5
  300. package/src/{react/web/wallets → wallets}/defaultWallets.ts +5 -10
  301. package/src/wallets/engine/engine-account.test.ts +69 -0
  302. package/src/wallets/engine/index.ts +198 -0
  303. package/src/wallets/in-app/web/lib/get-url-token.ts +1 -1
  304. package/src/wallets/smart/lib/signing.ts +1 -1
  305. package/src/wallets/smart/smart-wallet-integration.test.ts +1 -0
  306. package/dist/cjs/react/core/hooks/connection/types.js.map +0 -1
  307. package/dist/cjs/react/core/utils/timeoutPromise.js.map +0 -1
  308. package/dist/cjs/react/web/wallets/defaultWallets.js.map +0 -1
  309. package/dist/esm/react/core/hooks/connection/types.js.map +0 -1
  310. package/dist/esm/react/core/utils/timeoutPromise.js.map +0 -1
  311. package/dist/esm/react/web/wallets/defaultWallets.js.map +0 -1
  312. package/dist/types/react/core/hooks/connection/types.d.ts.map +0 -1
  313. package/dist/types/react/core/utils/timeoutPromise.d.ts.map +0 -1
  314. package/dist/types/react/web/wallets/defaultWallets.d.ts +0 -11
  315. package/dist/types/react/web/wallets/defaultWallets.d.ts.map +0 -1
  316. /package/dist/cjs/{react/core/utils → utils}/timeoutPromise.js +0 -0
  317. /package/dist/cjs/{react/core/hooks → wallets}/connection/types.js +0 -0
  318. /package/dist/esm/{react/core/utils → utils}/timeoutPromise.js +0 -0
  319. /package/dist/esm/{react/core/hooks → wallets}/connection/types.js +0 -0
  320. /package/dist/types/{react/core/utils → utils}/timeoutPromise.d.ts +0 -0
  321. /package/src/{react/core/utils → utils}/timeoutPromise.test.ts +0 -0
  322. /package/src/{react/core/utils → utils}/timeoutPromise.ts +0 -0
@@ -0,0 +1,54 @@
1
+ // modified version of isFQDN from validator.js that checks if given string is a valid domain name
2
+ // https://github.com/validatorjs/validator.js/blob/master/src/lib/isFQDN.js
3
+ // underscores are allowed, hyphens are allowed, no max length check
4
+
5
+ /**
6
+ * Checks if a string is a valid ENS name.
7
+ * It does not check if the ENS name is currently registered or resolves to an address - it only validates the string format.
8
+ *
9
+ * @param name - The ENS name to check.
10
+ *
11
+ * @example
12
+ * ```ts
13
+ * isValidENSName("thirdweb.eth"); // true
14
+ * isValidENSName("foo.bar.com"); // true
15
+ * isValidENSName("xyz"); // false
16
+ */
17
+ export function isValidENSName(name: string) {
18
+ const parts = name.split(".");
19
+ const tld = parts[parts.length - 1];
20
+
21
+ // disallow fqdns without tld
22
+ if (parts.length < 2 || !tld) {
23
+ return false;
24
+ }
25
+
26
+ // disallow spaces
27
+ if (/\s/.test(tld)) {
28
+ return false;
29
+ }
30
+
31
+ // reject numeric TLDs
32
+ if (/^\d+$/.test(tld)) {
33
+ return false;
34
+ }
35
+
36
+ return parts.every((part) => {
37
+ // part must be at least 1 char long
38
+ if (part.length < 1) {
39
+ return false;
40
+ }
41
+
42
+ // disallow invalid chars
43
+ if (!/^[a-z_\u00a1-\uffff0-9-]+$/i.test(part)) {
44
+ return false;
45
+ }
46
+
47
+ // disallow full-width chars
48
+ if (/[\uff01-\uff5e]/.test(part)) {
49
+ return false;
50
+ }
51
+
52
+ return true;
53
+ });
54
+ }
@@ -1,4 +1,4 @@
1
- import { maxUint256 } from "viem";
1
+ import { maxUint256 } from "ox/Solidity";
2
2
  import { toUnits } from "../../units.js";
3
3
 
4
4
  export function convertQuantity(options: {
@@ -1,4 +1,4 @@
1
- import { maxUint256 } from "viem";
1
+ import { maxUint256 } from "ox/Solidity";
2
2
  import { NATIVE_TOKEN_ADDRESS } from "../../../constants/addresses.js";
3
3
  import type { ThirdwebContract } from "../../../contract/contract.js";
4
4
  import type { SetClaimConditionsParams as GeneratedParams } from "../../../extensions/erc1155/__generated__/IDrop1155/write/setClaimConditions.js";
package/src/version.ts CHANGED
@@ -1 +1 @@
1
- export const version = "5.83.2-nightly-332536bdee05b6fb3b36d33761381826279b48f6-20250113000321";
1
+ export const version = "5.84.0";
@@ -0,0 +1,67 @@
1
+ import { beforeEach, describe, expect, it, vi } from "vitest";
2
+ import { TEST_CLIENT } from "~test/test-clients.js";
3
+ import { TEST_ACCOUNT_A } from "~test/test-wallets.js";
4
+ import { createWalletAdapter } from "../../adapters/wallet-adapter.js";
5
+ import { ethereum } from "../../chains/chain-definitions/ethereum.js";
6
+ import { webLocalStorage } from "../../utils/storage/webStorage.js";
7
+ import { createWallet } from "../create-wallet.js";
8
+ import { getInstalledWalletProviders } from "../injected/mipdStore.js";
9
+ import { autoConnect } from "./autoConnect.js";
10
+ import { autoConnectCore } from "./autoConnectCore.js";
11
+
12
+ vi.mock("../../utils/storage/webStorage.js");
13
+ vi.mock("../create-wallet.js");
14
+ vi.mock("../injected/mipdStore.js");
15
+ vi.mock("./autoConnectCore.js");
16
+
17
+ describe("autoConnect", () => {
18
+ const mockWallet = createWalletAdapter({
19
+ adaptedAccount: TEST_ACCOUNT_A,
20
+ client: TEST_CLIENT,
21
+ chain: ethereum,
22
+ onDisconnect: () => {},
23
+ switchChain: () => {},
24
+ });
25
+
26
+ beforeEach(() => {
27
+ vi.clearAllMocks();
28
+ vi.mocked(getInstalledWalletProviders).mockReturnValue([]);
29
+ vi.mocked(createWallet).mockReturnValue(mockWallet);
30
+ vi.mocked(autoConnectCore).mockResolvedValue(true);
31
+ });
32
+
33
+ it("should call autoConnectCore with correct parameters when wallets are provided", async () => {
34
+ const result = await autoConnect({
35
+ client: TEST_CLIENT,
36
+ wallets: [mockWallet],
37
+ });
38
+
39
+ expect(autoConnectCore).toHaveBeenCalledWith({
40
+ storage: webLocalStorage,
41
+ props: {
42
+ client: TEST_CLIENT,
43
+ wallets: [mockWallet],
44
+ },
45
+ createWalletFn: createWallet,
46
+ getInstalledWallets: expect.any(Function),
47
+ manager: expect.any(Object),
48
+ });
49
+ expect(result).toBe(true);
50
+ });
51
+
52
+ it("should use default wallets when no wallets are provided", async () => {
53
+ await autoConnect({
54
+ wallets: [],
55
+ client: TEST_CLIENT,
56
+ });
57
+
58
+ expect(autoConnectCore).toHaveBeenCalledWith(
59
+ expect.objectContaining({
60
+ props: {
61
+ client: TEST_CLIENT,
62
+ wallets: [],
63
+ },
64
+ }),
65
+ );
66
+ });
67
+ });
@@ -0,0 +1,58 @@
1
+ import { webLocalStorage } from "../../utils/storage/webStorage.js";
2
+ import { createWallet } from "../create-wallet.js";
3
+ import { getDefaultWallets } from "../defaultWallets.js";
4
+ import { getInstalledWalletProviders } from "../injected/mipdStore.js";
5
+ import type { Wallet } from "../interfaces/wallet.js";
6
+ import { createConnectionManager } from "../manager/index.js";
7
+ import { autoConnectCore } from "./autoConnectCore.js";
8
+ import type { AutoConnectProps } from "./types.js";
9
+
10
+ /**
11
+ * Attempts to automatically connect to the last connected wallet.
12
+ * It combines both specified wallets and installed wallet providers that aren't already specified.
13
+ *
14
+ * @example
15
+ *
16
+ * ```tsx
17
+ * import { autoConnect } from "thirdweb/wallets";
18
+ *
19
+ * const autoConnected = await autoConnect({
20
+ * client,
21
+ * onConnect: (wallet) => {
22
+ * console.log("wallet", wallet);
23
+ * },
24
+ * });
25
+ * ```
26
+ *
27
+ * @param props - The auto-connect configuration properties
28
+ * @param props.wallets - Array of wallet instances to consider for auto-connection
29
+ * @returns {boolean} a promise resolving to true or false depending on whether the auto connect function connected to a wallet or not
30
+ */
31
+ export const autoConnect = async (
32
+ props: AutoConnectProps & {
33
+ wallets?: Wallet[];
34
+ },
35
+ ) => {
36
+ const wallets = props.wallets || getDefaultWallets(props);
37
+ const manager = createConnectionManager(webLocalStorage);
38
+ const result = await autoConnectCore({
39
+ storage: webLocalStorage,
40
+ props: {
41
+ ...props,
42
+ wallets,
43
+ },
44
+ createWalletFn: createWallet,
45
+ getInstalledWallets: () => {
46
+ const specifiedWalletIds = new Set(wallets.map((x) => x.id));
47
+
48
+ // pass the wallets that are not already specified but are installed by the user
49
+ const installedWallets = getInstalledWalletProviders()
50
+ .filter((x) => !specifiedWalletIds.has(x.info.rdns))
51
+ .map((x) => createWallet(x.info.rdns));
52
+
53
+ return installedWallets;
54
+ },
55
+ manager,
56
+ });
57
+ return result;
58
+ };
@@ -0,0 +1,403 @@
1
+ import { afterEach } from "node:test";
2
+ import { isAddress } from "ethers6";
3
+ import { describe, expect, it, vi } from "vitest";
4
+ import { MockStorage } from "~test/mocks/storage.js";
5
+ import { TEST_CLIENT } from "~test/test-clients.js";
6
+ import { TEST_ACCOUNT_A } from "~test/test-wallets.js";
7
+ import { createWalletAdapter } from "../../adapters/wallet-adapter.js";
8
+ import { ethereum } from "../../chains/chain-definitions/ethereum.js";
9
+ import { AUTH_TOKEN_LOCAL_STORAGE_NAME } from "../in-app/core/constants/settings.js";
10
+ import { getUrlToken } from "../in-app/web/lib/get-url-token.js";
11
+ import type { Wallet } from "../interfaces/wallet.js";
12
+ import { createConnectionManager } from "../manager/index.js";
13
+ import type { WalletId } from "../wallet-types.js";
14
+ import { autoConnectCore, handleWalletConnection } from "./autoConnectCore.js";
15
+
16
+ vi.mock("../in-app/web/lib/get-url-token.ts");
17
+
18
+ describe("useAutoConnectCore", () => {
19
+ const mockStorage = new MockStorage();
20
+ const manager = createConnectionManager(mockStorage);
21
+
22
+ afterEach(() => {
23
+ vi.restoreAllMocks();
24
+ });
25
+
26
+ it("should return a useQuery result", async () => {
27
+ vi.mocked(getUrlToken).mockReturnValue({});
28
+ const wallet = createWalletAdapter({
29
+ adaptedAccount: TEST_ACCOUNT_A,
30
+ client: TEST_CLIENT,
31
+ chain: ethereum,
32
+ onDisconnect: () => {},
33
+ switchChain: () => {},
34
+ });
35
+
36
+ expect(
37
+ await autoConnectCore({
38
+ storage: mockStorage,
39
+ props: {
40
+ wallets: [wallet],
41
+ client: TEST_CLIENT,
42
+ },
43
+ createWalletFn: (id: WalletId) =>
44
+ createWalletAdapter({
45
+ adaptedAccount: TEST_ACCOUNT_A,
46
+ client: TEST_CLIENT,
47
+ chain: ethereum,
48
+ onDisconnect: () => {
49
+ console.warn(id);
50
+ },
51
+ switchChain: () => {},
52
+ }),
53
+ manager,
54
+ }),
55
+ ).toBe(false);
56
+ });
57
+
58
+ it("should return `false` if there's no lastConnectedWalletIds", async () => {
59
+ vi.mocked(getUrlToken).mockReturnValue({});
60
+
61
+ const wallet = createWalletAdapter({
62
+ adaptedAccount: TEST_ACCOUNT_A,
63
+ client: TEST_CLIENT,
64
+ chain: ethereum,
65
+ onDisconnect: () => {},
66
+ switchChain: () => {},
67
+ });
68
+
69
+ expect(
70
+ await autoConnectCore({
71
+ storage: mockStorage,
72
+ props: {
73
+ wallets: [wallet],
74
+ client: TEST_CLIENT,
75
+ },
76
+ createWalletFn: (id: WalletId) =>
77
+ createWalletAdapter({
78
+ adaptedAccount: TEST_ACCOUNT_A,
79
+ client: TEST_CLIENT,
80
+ chain: ethereum,
81
+ onDisconnect: () => {
82
+ console.warn(id);
83
+ },
84
+ switchChain: () => {},
85
+ }),
86
+ manager,
87
+ }),
88
+ ).toBe(false);
89
+ });
90
+
91
+ it("should call onTimeout on ... timeout", async () => {
92
+ vi.mocked(getUrlToken).mockReturnValue({});
93
+
94
+ const wallet = createWalletAdapter({
95
+ adaptedAccount: TEST_ACCOUNT_A,
96
+ client: TEST_CLIENT,
97
+ chain: ethereum,
98
+ onDisconnect: () => {},
99
+ switchChain: () => {},
100
+ });
101
+ mockStorage.setItem("thirdweb:active-wallet-id", wallet.id);
102
+ const warnSpy = vi.spyOn(console, "warn").mockImplementation(() => {});
103
+ const infoSpy = vi.spyOn(console, "info").mockImplementation(() => {});
104
+ // Purposefully mock the wallet.autoConnect method to test the timeout logic
105
+ wallet.autoConnect = () =>
106
+ new Promise((resolve) => {
107
+ setTimeout(() => {
108
+ // @ts-ignore Mock purpose
109
+ resolve("Connection successful");
110
+ }, 2100);
111
+ });
112
+
113
+ await autoConnectCore({
114
+ storage: mockStorage,
115
+ props: {
116
+ wallets: [wallet],
117
+ client: TEST_CLIENT,
118
+ onTimeout: () => console.info("TIMEOUTTED"),
119
+ timeout: 0,
120
+ },
121
+ createWalletFn: (id: WalletId) =>
122
+ createWalletAdapter({
123
+ adaptedAccount: TEST_ACCOUNT_A,
124
+ client: TEST_CLIENT,
125
+ chain: ethereum,
126
+ onDisconnect: () => {
127
+ console.warn(id);
128
+ },
129
+ switchChain: () => {},
130
+ }),
131
+ manager,
132
+ });
133
+
134
+ expect(warnSpy).toHaveBeenCalled();
135
+ expect(warnSpy).toHaveBeenCalledWith(
136
+ "AutoConnect timeout: 0ms limit exceeded.",
137
+ );
138
+ expect(infoSpy).toHaveBeenCalled();
139
+ expect(infoSpy).toHaveBeenCalledWith("TIMEOUTTED");
140
+ warnSpy.mockRestore();
141
+ });
142
+
143
+ it("should handle auth cookie storage correctly", async () => {
144
+ const mockAuthCookie = "mock-auth-cookie";
145
+ const wallet = createWalletAdapter({
146
+ adaptedAccount: TEST_ACCOUNT_A,
147
+ client: TEST_CLIENT,
148
+ chain: ethereum,
149
+ onDisconnect: () => {},
150
+ switchChain: () => {},
151
+ });
152
+ vi.mocked(getUrlToken).mockReturnValue({
153
+ authCookie: mockAuthCookie,
154
+ walletId: wallet.id,
155
+ });
156
+
157
+ await autoConnectCore({
158
+ storage: mockStorage,
159
+ props: {
160
+ wallets: [wallet],
161
+ client: TEST_CLIENT,
162
+ },
163
+ createWalletFn: () => wallet,
164
+ manager,
165
+ });
166
+
167
+ const storedCookie = await mockStorage.getItem(
168
+ AUTH_TOKEN_LOCAL_STORAGE_NAME(TEST_CLIENT.clientId),
169
+ );
170
+ expect(storedCookie).toBe(mockAuthCookie);
171
+ });
172
+
173
+ it("should handle error when manager connection fails", async () => {
174
+ const wallet1 = createWalletAdapter({
175
+ adaptedAccount: TEST_ACCOUNT_A,
176
+ client: TEST_CLIENT,
177
+ chain: ethereum,
178
+ onDisconnect: () => {},
179
+ switchChain: () => {},
180
+ });
181
+
182
+ mockStorage.setItem("thirdweb:active-wallet-id", wallet1.id);
183
+ mockStorage.setItem(
184
+ "thirdweb:connected-wallet-ids",
185
+ JSON.stringify([wallet1.id]),
186
+ );
187
+
188
+ const addConnectedWalletSpy = vi
189
+ .spyOn(manager, "connect")
190
+ .mockRejectedValueOnce(new Error("Connection failed"));
191
+ const warnSpy = vi.spyOn(console, "warn").mockImplementation(() => {});
192
+
193
+ await autoConnectCore({
194
+ storage: mockStorage,
195
+ props: {
196
+ wallets: [wallet1],
197
+ client: TEST_CLIENT,
198
+ },
199
+ createWalletFn: () => wallet1,
200
+ manager,
201
+ });
202
+ expect(addConnectedWalletSpy).toHaveBeenCalled();
203
+
204
+ expect(warnSpy).toHaveBeenCalled();
205
+ expect(warnSpy).toHaveBeenCalledWith(
206
+ "Error auto connecting wallet:",
207
+ "Connection failed",
208
+ );
209
+ });
210
+
211
+ it("should connect multiple wallets correctly", async () => {
212
+ const wallet1 = createWalletAdapter({
213
+ adaptedAccount: TEST_ACCOUNT_A,
214
+ client: TEST_CLIENT,
215
+ chain: ethereum,
216
+ onDisconnect: () => {},
217
+ switchChain: () => {},
218
+ });
219
+
220
+ const wallet2 = createWalletAdapter({
221
+ adaptedAccount: { ...TEST_ACCOUNT_A, address: "0x123" },
222
+ client: TEST_CLIENT,
223
+ chain: ethereum,
224
+ onDisconnect: () => {},
225
+ switchChain: () => {},
226
+ });
227
+ wallet2.id = "io.metamask" as unknown as "adapter";
228
+
229
+ mockStorage.setItem("thirdweb:active-wallet-id", wallet1.id);
230
+ mockStorage.setItem(
231
+ "thirdweb:connected-wallet-ids",
232
+ JSON.stringify([wallet1.id, wallet2.id]),
233
+ );
234
+
235
+ const addConnectedWalletSpy = vi.spyOn(manager, "addConnectedWallet");
236
+
237
+ await autoConnectCore({
238
+ storage: mockStorage,
239
+ props: {
240
+ wallets: [wallet1, wallet2],
241
+ client: TEST_CLIENT,
242
+ },
243
+ createWalletFn: () => wallet1,
244
+ manager,
245
+ });
246
+
247
+ expect(addConnectedWalletSpy).toHaveBeenCalledWith(wallet2);
248
+ });
249
+
250
+ it("should handle onConnect callback correctly", async () => {
251
+ const mockOnConnect = vi.fn();
252
+ const wallet = createWalletAdapter({
253
+ adaptedAccount: TEST_ACCOUNT_A,
254
+ client: TEST_CLIENT,
255
+ chain: ethereum,
256
+ onDisconnect: () => {},
257
+ switchChain: () => {},
258
+ });
259
+
260
+ vi.mocked(getUrlToken).mockReturnValue({});
261
+ mockStorage.setItem("thirdweb:active-wallet-id", wallet.id);
262
+ mockStorage.setItem(
263
+ "thirdweb:connected-wallet-ids",
264
+ JSON.stringify([wallet.id]),
265
+ );
266
+ await autoConnectCore({
267
+ storage: mockStorage,
268
+ props: {
269
+ wallets: [wallet],
270
+ client: TEST_CLIENT,
271
+ onConnect: mockOnConnect,
272
+ },
273
+ createWalletFn: () => wallet,
274
+ manager,
275
+ });
276
+
277
+ expect(mockOnConnect).toHaveBeenCalledWith(wallet);
278
+ });
279
+ it("should continue even if onConnect callback throws", async () => {
280
+ const mockOnConnect = vi.fn();
281
+ mockOnConnect.mockImplementation(() => {
282
+ throw new Error("onConnect error");
283
+ });
284
+ const wallet = createWalletAdapter({
285
+ adaptedAccount: TEST_ACCOUNT_A,
286
+ client: TEST_CLIENT,
287
+ chain: ethereum,
288
+ onDisconnect: () => {},
289
+ switchChain: () => {},
290
+ });
291
+
292
+ vi.mocked(getUrlToken).mockReturnValue({});
293
+ mockStorage.setItem("thirdweb:active-wallet-id", wallet.id);
294
+ mockStorage.setItem(
295
+ "thirdweb:connected-wallet-ids",
296
+ JSON.stringify([wallet.id]),
297
+ );
298
+ await autoConnectCore({
299
+ storage: mockStorage,
300
+ props: {
301
+ wallets: [wallet],
302
+ client: TEST_CLIENT,
303
+ onConnect: mockOnConnect,
304
+ },
305
+ createWalletFn: () => wallet,
306
+ manager,
307
+ });
308
+
309
+ expect(mockOnConnect).toHaveBeenCalledWith(wallet);
310
+ });
311
+ it("should call setLastAuthProvider if authProvider is present", async () => {
312
+ const wallet = createWalletAdapter({
313
+ adaptedAccount: TEST_ACCOUNT_A,
314
+ client: TEST_CLIENT,
315
+ chain: ethereum,
316
+ onDisconnect: () => {},
317
+ switchChain: () => {},
318
+ });
319
+ vi.mocked(getUrlToken).mockReturnValue({
320
+ authProvider: "email",
321
+ walletId: wallet.id,
322
+ });
323
+ const mockSetLastAuthProvider = vi.fn();
324
+
325
+ mockStorage.setItem("thirdweb:active-wallet-id", wallet.id);
326
+ mockStorage.setItem(
327
+ "thirdweb:connected-wallet-ids",
328
+ JSON.stringify([wallet.id]),
329
+ );
330
+ await autoConnectCore({
331
+ storage: mockStorage,
332
+ props: {
333
+ wallets: [wallet],
334
+ client: TEST_CLIENT,
335
+ },
336
+ createWalletFn: () => wallet,
337
+ manager,
338
+ setLastAuthProvider: mockSetLastAuthProvider,
339
+ });
340
+
341
+ expect(mockSetLastAuthProvider).toHaveBeenCalledWith("email", mockStorage);
342
+ });
343
+ it("should set connection status to disconnect if no connectedWallet is returned", async () => {
344
+ const wallet = createWalletAdapter({
345
+ adaptedAccount: TEST_ACCOUNT_A,
346
+ client: TEST_CLIENT,
347
+ chain: ethereum,
348
+ onDisconnect: () => {},
349
+ switchChain: () => {},
350
+ });
351
+
352
+ mockStorage.setItem("thirdweb:active-wallet-id", wallet.id);
353
+ mockStorage.setItem(
354
+ "thirdweb:connected-wallet-ids",
355
+ JSON.stringify([wallet.id]),
356
+ );
357
+
358
+ const addConnectedWalletSpy = vi
359
+ .spyOn(manager, "connect")
360
+ .mockResolvedValueOnce(null as unknown as Wallet);
361
+
362
+ await autoConnectCore({
363
+ storage: mockStorage,
364
+ props: {
365
+ wallets: [wallet],
366
+ client: TEST_CLIENT,
367
+ },
368
+ createWalletFn: () => wallet,
369
+ manager,
370
+ });
371
+
372
+ expect(addConnectedWalletSpy).toHaveBeenCalled();
373
+ expect(manager.activeWalletConnectionStatusStore.getValue()).toBe(
374
+ "disconnected",
375
+ );
376
+ });
377
+ });
378
+
379
+ describe("handleWalletConnection", () => {
380
+ const wallet = createWalletAdapter({
381
+ adaptedAccount: TEST_ACCOUNT_A,
382
+ client: TEST_CLIENT,
383
+ chain: ethereum,
384
+ onDisconnect: () => {},
385
+ switchChain: () => {},
386
+ });
387
+ it("should return the correct result", async () => {
388
+ const result = await handleWalletConnection({
389
+ client: TEST_CLIENT,
390
+ lastConnectedChain: ethereum,
391
+ authResult: undefined,
392
+ wallet,
393
+ });
394
+
395
+ expect("address" in result).toBe(true);
396
+ expect(isAddress(result.address)).toBe(true);
397
+ expect("sendTransaction" in result).toBe(true);
398
+ expect(typeof result.sendTransaction).toBe("function");
399
+ expect("signMessage" in result).toBe(true);
400
+ expect("signTypedData" in result).toBe(true);
401
+ expect("signTransaction" in result).toBe(true);
402
+ });
403
+ });