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.
- package/dist/cjs/ai/chat.js +29 -0
- package/dist/cjs/ai/chat.js.map +1 -0
- package/dist/cjs/ai/common.js +69 -0
- package/dist/cjs/ai/common.js.map +1 -0
- package/dist/cjs/ai/execute.js +43 -0
- package/dist/cjs/ai/execute.js.map +1 -0
- package/dist/cjs/ai/index.js +8 -0
- package/dist/cjs/ai/index.js.map +1 -0
- package/dist/cjs/auth/is-erc6492-signature.js +2 -2
- package/dist/cjs/auth/is-erc6492-signature.js.map +1 -1
- package/dist/cjs/auth/parse-erc6492-signature.js +10 -4
- package/dist/cjs/auth/parse-erc6492-signature.js.map +1 -1
- package/dist/cjs/auth/verify-hash.js +12 -11
- package/dist/cjs/auth/verify-hash.js.map +1 -1
- package/dist/cjs/auth/verify-signature.js +13 -5
- package/dist/cjs/auth/verify-signature.js.map +1 -1
- package/dist/cjs/auth/verify-typed-data.js +2 -2
- package/dist/cjs/auth/verify-typed-data.js.map +1 -1
- package/dist/cjs/contract/deployment/utils/create-2-factory.js +4 -3
- package/dist/cjs/contract/deployment/utils/create-2-factory.js.map +1 -1
- package/dist/cjs/contract/verification/constructor-params.js +5 -12
- package/dist/cjs/contract/verification/constructor-params.js.map +1 -1
- package/dist/cjs/exports/ai.js +5 -0
- package/dist/cjs/exports/ai.js.map +1 -0
- package/dist/cjs/exports/utils.js +9 -6
- package/dist/cjs/exports/utils.js.map +1 -1
- package/dist/cjs/exports/wallets/engine.js +6 -0
- package/dist/cjs/exports/wallets/engine.js.map +1 -0
- package/dist/cjs/exports/wallets.js +3 -1
- package/dist/cjs/exports/wallets.js.map +1 -1
- package/dist/cjs/extensions/ens/resolve-l2-name.js +10 -3
- package/dist/cjs/extensions/ens/resolve-l2-name.js.map +1 -1
- package/dist/cjs/extensions/erc1155/read/getNFTs.js +2 -2
- package/dist/cjs/extensions/erc1155/read/getNFTs.js.map +1 -1
- package/dist/cjs/extensions/erc1155/write/mintTo.js +2 -2
- package/dist/cjs/extensions/erc1155/write/mintTo.js.map +1 -1
- package/dist/cjs/extensions/erc1155/write/mintToBatch.js +2 -2
- package/dist/cjs/extensions/erc1155/write/mintToBatch.js.map +1 -1
- package/dist/cjs/extensions/erc1155/write/sigMint.js +2 -2
- package/dist/cjs/extensions/erc1155/write/sigMint.js.map +1 -1
- package/dist/cjs/extensions/modules/ClaimableERC1155/setClaimConditions.js +3 -2
- package/dist/cjs/extensions/modules/ClaimableERC1155/setClaimConditions.js.map +1 -1
- package/dist/cjs/extensions/modules/MintableERC1155/mintWithRole.js +2 -2
- package/dist/cjs/extensions/modules/MintableERC1155/mintWithRole.js.map +1 -1
- package/dist/cjs/extensions/modules/MintableERC1155/mintWithSignature.js +2 -2
- package/dist/cjs/extensions/modules/MintableERC1155/mintWithSignature.js.map +1 -1
- package/dist/cjs/react/core/hooks/wallets/useAutoConnect.js +10 -131
- package/dist/cjs/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/cjs/react/core/hooks/wallets/useSendToken.js +2 -1
- package/dist/cjs/react/core/hooks/wallets/useSendToken.js.map +1 -1
- package/dist/cjs/react/native/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/cjs/react/web/hooks/wallets/useAutoConnect.js +1 -1
- package/dist/cjs/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/ConnectButton.js +3 -1
- package/dist/cjs/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js +2 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.js +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/useConnectModal.js +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/useConnectModal.js.map +1 -1
- package/dist/cjs/react/web/wallets/in-app/WalletAuth.js +1 -1
- package/dist/cjs/react/web/wallets/in-app/WalletAuth.js.map +1 -1
- package/dist/cjs/utils/abi/encodeAbiParameters.js +10 -11
- package/dist/cjs/utils/abi/encodeAbiParameters.js.map +1 -1
- package/dist/cjs/utils/ens/isValidENSName.js +50 -0
- package/dist/cjs/utils/ens/isValidENSName.js.map +1 -0
- package/dist/cjs/utils/extensions/drops/convert-quantity.js +2 -2
- package/dist/cjs/utils/extensions/drops/convert-quantity.js.map +1 -1
- package/dist/cjs/utils/extensions/drops/get-multicall-set-claim-claim-conditon-transactions.js +3 -3
- package/dist/cjs/utils/extensions/drops/get-multicall-set-claim-claim-conditon-transactions.js.map +1 -1
- package/dist/cjs/utils/timeoutPromise.js.map +1 -0
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/version.js.map +1 -1
- package/dist/cjs/wallets/connection/autoConnect.js +54 -0
- package/dist/cjs/wallets/connection/autoConnect.js.map +1 -0
- package/dist/cjs/wallets/connection/autoConnectCore.js +135 -0
- package/dist/cjs/wallets/connection/autoConnectCore.js.map +1 -0
- package/dist/cjs/wallets/connection/types.js.map +1 -0
- package/dist/cjs/{react/web/wallets → wallets}/defaultWallets.js +2 -2
- package/dist/cjs/wallets/defaultWallets.js.map +1 -0
- package/dist/cjs/wallets/engine/index.js +143 -0
- package/dist/cjs/wallets/engine/index.js.map +1 -0
- package/dist/cjs/wallets/in-app/web/lib/get-url-token.js +1 -1
- package/dist/cjs/wallets/in-app/web/lib/get-url-token.js.map +1 -1
- package/dist/cjs/wallets/smart/lib/signing.js +1 -1
- package/dist/esm/ai/chat.js +26 -0
- package/dist/esm/ai/chat.js.map +1 -0
- package/dist/esm/ai/common.js +66 -0
- package/dist/esm/ai/common.js.map +1 -0
- package/dist/esm/ai/execute.js +40 -0
- package/dist/esm/ai/execute.js.map +1 -0
- package/dist/esm/ai/index.js +3 -0
- package/dist/esm/ai/index.js.map +1 -0
- package/dist/esm/auth/is-erc6492-signature.js +2 -2
- package/dist/esm/auth/is-erc6492-signature.js.map +1 -1
- package/dist/esm/auth/parse-erc6492-signature.js +10 -4
- package/dist/esm/auth/parse-erc6492-signature.js.map +1 -1
- package/dist/esm/auth/verify-hash.js +12 -11
- package/dist/esm/auth/verify-hash.js.map +1 -1
- package/dist/esm/auth/verify-signature.js +13 -5
- package/dist/esm/auth/verify-signature.js.map +1 -1
- package/dist/esm/auth/verify-typed-data.js +2 -2
- package/dist/esm/auth/verify-typed-data.js.map +1 -1
- package/dist/esm/contract/deployment/utils/create-2-factory.js +4 -3
- package/dist/esm/contract/deployment/utils/create-2-factory.js.map +1 -1
- package/dist/esm/contract/verification/constructor-params.js +5 -12
- package/dist/esm/contract/verification/constructor-params.js.map +1 -1
- package/dist/esm/exports/ai.js +2 -0
- package/dist/esm/exports/ai.js.map +1 -0
- package/dist/esm/exports/utils.js +3 -1
- package/dist/esm/exports/utils.js.map +1 -1
- package/dist/esm/exports/wallets/engine.js +2 -0
- package/dist/esm/exports/wallets/engine.js.map +1 -0
- package/dist/esm/exports/wallets.js +1 -0
- package/dist/esm/exports/wallets.js.map +1 -1
- package/dist/esm/extensions/ens/resolve-l2-name.js +11 -4
- package/dist/esm/extensions/ens/resolve-l2-name.js.map +1 -1
- package/dist/esm/extensions/erc1155/read/getNFTs.js +1 -1
- package/dist/esm/extensions/erc1155/read/getNFTs.js.map +1 -1
- package/dist/esm/extensions/erc1155/write/mintTo.js +1 -1
- package/dist/esm/extensions/erc1155/write/mintTo.js.map +1 -1
- package/dist/esm/extensions/erc1155/write/mintToBatch.js +1 -1
- package/dist/esm/extensions/erc1155/write/mintToBatch.js.map +1 -1
- package/dist/esm/extensions/erc1155/write/sigMint.js +1 -1
- package/dist/esm/extensions/erc1155/write/sigMint.js.map +1 -1
- package/dist/esm/extensions/modules/ClaimableERC1155/setClaimConditions.js +2 -1
- package/dist/esm/extensions/modules/ClaimableERC1155/setClaimConditions.js.map +1 -1
- package/dist/esm/extensions/modules/MintableERC1155/mintWithRole.js +1 -1
- package/dist/esm/extensions/modules/MintableERC1155/mintWithRole.js.map +1 -1
- package/dist/esm/extensions/modules/MintableERC1155/mintWithSignature.js +1 -1
- package/dist/esm/extensions/modules/MintableERC1155/mintWithSignature.js.map +1 -1
- package/dist/esm/react/core/hooks/wallets/useAutoConnect.js +10 -130
- package/dist/esm/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/esm/react/core/hooks/wallets/useSendToken.js +2 -1
- package/dist/esm/react/core/hooks/wallets/useSendToken.js.map +1 -1
- package/dist/esm/react/native/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/esm/react/web/hooks/wallets/useAutoConnect.js +1 -1
- package/dist/esm/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js +3 -1
- package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js +2 -1
- package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/useConnectModal.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/useConnectModal.js.map +1 -1
- package/dist/esm/react/web/wallets/in-app/WalletAuth.js +1 -1
- package/dist/esm/react/web/wallets/in-app/WalletAuth.js.map +1 -1
- package/dist/esm/utils/abi/encodeAbiParameters.js +10 -11
- package/dist/esm/utils/abi/encodeAbiParameters.js.map +1 -1
- package/dist/esm/utils/ens/isValidENSName.js +47 -0
- package/dist/esm/utils/ens/isValidENSName.js.map +1 -0
- package/dist/esm/utils/extensions/drops/convert-quantity.js +1 -1
- package/dist/esm/utils/extensions/drops/convert-quantity.js.map +1 -1
- package/dist/esm/utils/extensions/drops/get-multicall-set-claim-claim-conditon-transactions.js +1 -1
- package/dist/esm/utils/extensions/drops/get-multicall-set-claim-claim-conditon-transactions.js.map +1 -1
- package/dist/esm/utils/timeoutPromise.js.map +1 -0
- package/dist/esm/version.js +1 -1
- package/dist/esm/version.js.map +1 -1
- package/dist/esm/wallets/connection/autoConnect.js +50 -0
- package/dist/esm/wallets/connection/autoConnect.js.map +1 -0
- package/dist/esm/wallets/connection/autoConnectCore.js +130 -0
- package/dist/esm/wallets/connection/autoConnectCore.js.map +1 -0
- package/dist/esm/wallets/connection/types.js.map +1 -0
- package/dist/esm/{react/web/wallets → wallets}/defaultWallets.js +2 -2
- package/dist/esm/wallets/defaultWallets.js.map +1 -0
- package/dist/esm/wallets/engine/index.js +140 -0
- package/dist/esm/wallets/engine/index.js.map +1 -0
- package/dist/esm/wallets/in-app/web/lib/get-url-token.js +1 -1
- package/dist/esm/wallets/in-app/web/lib/get-url-token.js.map +1 -1
- package/dist/esm/wallets/smart/lib/signing.js +1 -1
- package/dist/types/ai/chat.d.ts +24 -0
- package/dist/types/ai/chat.d.ts.map +1 -0
- package/dist/types/ai/common.d.ts +22 -0
- package/dist/types/ai/common.d.ts.map +1 -0
- package/dist/types/ai/execute.d.ts +29 -0
- package/dist/types/ai/execute.d.ts.map +1 -0
- package/dist/types/ai/index.d.ts +4 -0
- package/dist/types/ai/index.d.ts.map +1 -0
- package/dist/types/auth/parse-erc6492-signature.d.ts.map +1 -1
- package/dist/types/auth/verify-hash.d.ts +2 -2
- package/dist/types/auth/verify-hash.d.ts.map +1 -1
- package/dist/types/auth/verify-signature.d.ts +6 -3
- package/dist/types/auth/verify-signature.d.ts.map +1 -1
- package/dist/types/auth/verify-typed-data.d.ts +5 -4
- package/dist/types/auth/verify-typed-data.d.ts.map +1 -1
- package/dist/types/contract/deployment/utils/create-2-factory.d.ts.map +1 -1
- package/dist/types/contract/verification/constructor-params.d.ts +2 -2
- package/dist/types/contract/verification/constructor-params.d.ts.map +1 -1
- package/dist/types/event/types.d.ts +3 -2
- package/dist/types/event/types.d.ts.map +1 -1
- package/dist/types/exports/ai.d.ts +2 -0
- package/dist/types/exports/ai.d.ts.map +1 -0
- package/dist/types/exports/react.d.ts +1 -1
- package/dist/types/exports/react.d.ts.map +1 -1
- package/dist/types/exports/react.native.d.ts +1 -1
- package/dist/types/exports/react.native.d.ts.map +1 -1
- package/dist/types/exports/utils.d.ts +2 -1
- package/dist/types/exports/utils.d.ts.map +1 -1
- package/dist/types/exports/wallets/engine.d.ts +2 -0
- package/dist/types/exports/wallets/engine.d.ts.map +1 -0
- package/dist/types/exports/wallets.d.ts +2 -0
- package/dist/types/exports/wallets.d.ts.map +1 -1
- package/dist/types/extensions/ens/resolve-l2-name.d.ts.map +1 -1
- package/dist/types/extensions/erc1155/write/mintTo.d.ts +1 -1
- package/dist/types/extensions/erc1155/write/mintTo.d.ts.map +1 -1
- package/dist/types/extensions/erc1155/write/mintToBatch.d.ts +1 -1
- package/dist/types/extensions/erc1155/write/mintToBatch.d.ts.map +1 -1
- package/dist/types/extensions/modules/ClaimableERC1155/setClaimConditions.d.ts.map +1 -1
- package/dist/types/extensions/modules/MintableERC1155/mintWithRole.d.ts +1 -1
- package/dist/types/extensions/modules/MintableERC1155/mintWithRole.d.ts.map +1 -1
- package/dist/types/extensions/modules/MintableERC1155/mintWithSignature.d.ts +1 -1
- package/dist/types/extensions/modules/MintableERC1155/mintWithSignature.d.ts.map +1 -1
- package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts +1 -13
- package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts.map +1 -1
- package/dist/types/react/core/hooks/wallets/useSendToken.d.ts.map +1 -1
- package/dist/types/react/native/hooks/wallets/useAutoConnect.d.ts +1 -1
- package/dist/types/react/native/hooks/wallets/useAutoConnect.d.ts.map +1 -1
- package/dist/types/react/native/ui/AutoConnect/AutoConnect.d.ts +1 -1
- package/dist/types/react/web/hooks/wallets/useAutoConnect.d.ts +1 -1
- package/dist/types/react/web/hooks/wallets/useAutoConnect.d.ts.map +1 -1
- package/dist/types/react/web/ui/AutoConnect/AutoConnect.d.ts +1 -1
- package/dist/types/react/web/ui/ConnectWallet/ConnectButton.d.ts +2 -0
- package/dist/types/react/web/ui/ConnectWallet/ConnectButton.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectEmbed.d.ts +1 -0
- package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectEmbed.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/useConnectModal.d.ts.map +1 -1
- package/dist/types/react/web/wallets/in-app/WalletAuth.d.ts.map +1 -1
- package/dist/types/utils/ens/isValidENSName.d.ts +14 -0
- package/dist/types/utils/ens/isValidENSName.d.ts.map +1 -0
- package/dist/types/utils/timeoutPromise.d.ts.map +1 -0
- package/dist/types/version.d.ts +1 -1
- package/dist/types/version.d.ts.map +1 -1
- package/dist/types/wallets/connection/autoConnect.d.ts +27 -0
- package/dist/types/wallets/connection/autoConnect.d.ts.map +1 -0
- package/dist/types/wallets/connection/autoConnectCore.d.ts +32 -0
- package/dist/types/wallets/connection/autoConnectCore.d.ts.map +1 -0
- package/dist/types/{react/core/hooks → wallets}/connection/types.d.ts +5 -5
- package/dist/types/wallets/connection/types.d.ts.map +1 -0
- package/dist/types/wallets/defaultWallets.d.ts +11 -0
- package/dist/types/wallets/defaultWallets.d.ts.map +1 -0
- package/dist/types/wallets/engine/index.d.ts +54 -0
- package/dist/types/wallets/engine/index.d.ts.map +1 -0
- package/dist/types/wallets/smart/lib/signing.d.ts +1 -1
- package/package.json +9 -1
- package/src/ai/chat.test.ts +31 -0
- package/src/ai/chat.ts +26 -0
- package/src/ai/common.ts +114 -0
- package/src/ai/execute.test.ts +43 -0
- package/src/ai/execute.ts +44 -0
- package/src/ai/index.ts +3 -0
- package/src/auth/is-erc6492-signature.ts +2 -2
- package/src/auth/parse-erc6492-signature.ts +10 -4
- package/src/auth/verify-hash.ts +16 -20
- package/src/auth/verify-signature.test.ts +48 -2
- package/src/auth/verify-signature.ts +24 -7
- package/src/auth/verify-typed-data.ts +9 -7
- package/src/contract/deployment/utils/create-2-factory.ts +4 -3
- package/src/contract/verification/constructor-params.ts +8 -15
- package/src/event/types.ts +6 -5
- package/src/exports/ai.ts +1 -0
- package/src/exports/react.native.ts +1 -1
- package/src/exports/react.ts +1 -1
- package/src/exports/utils.ts +4 -1
- package/src/exports/wallets/engine.ts +4 -0
- package/src/exports/wallets.ts +2 -0
- package/src/extensions/ens/resolve-l2-name.ts +21 -5
- package/src/extensions/erc1155/read/getNFTs.ts +1 -1
- package/src/extensions/erc1155/write/mintTo.ts +1 -1
- package/src/extensions/erc1155/write/mintToBatch.ts +1 -1
- package/src/extensions/erc1155/write/sigMint.ts +1 -1
- package/src/extensions/modules/ClaimableERC1155/setClaimConditions.ts +2 -1
- package/src/extensions/modules/MintableERC1155/mintWithRole.ts +1 -1
- package/src/extensions/modules/MintableERC1155/mintWithSignature.ts +1 -1
- package/src/react/core/hooks/wallets/useAutoConnect.ts +12 -158
- package/src/react/core/hooks/wallets/useAutoConnectCore.test.tsx +1 -31
- package/src/react/core/hooks/wallets/useSendToken.ts +2 -1
- package/src/react/native/hooks/wallets/useAutoConnect.ts +1 -1
- package/src/react/native/ui/AutoConnect/AutoConnect.tsx +1 -1
- package/src/react/web/hooks/wallets/useAutoConnect.ts +2 -2
- package/src/react/web/ui/AutoConnect/AutoConnect.tsx +1 -1
- package/src/react/web/ui/ConnectWallet/ConnectButton.tsx +3 -1
- package/src/react/web/ui/ConnectWallet/Modal/ConnectEmbed.tsx +2 -1
- package/src/react/web/ui/ConnectWallet/screens/WalletSwitcherConnectionScreen.tsx +1 -1
- package/src/react/web/ui/ConnectWallet/useConnectModal.tsx +1 -1
- package/src/react/web/wallets/in-app/WalletAuth.tsx +1 -1
- package/src/utils/abi/encodeAbiParameters.ts +15 -11
- package/src/utils/ens/isValidENSName.test.ts +39 -0
- package/src/utils/ens/isValidENSName.ts +54 -0
- package/src/utils/extensions/drops/convert-quantity.ts +1 -1
- package/src/utils/extensions/drops/get-multicall-set-claim-claim-conditon-transactions.ts +1 -1
- package/src/version.ts +1 -1
- package/src/wallets/connection/autoConnect.test.ts +67 -0
- package/src/wallets/connection/autoConnect.ts +58 -0
- package/src/wallets/connection/autoConnectCore.test.ts +403 -0
- package/src/wallets/connection/autoConnectCore.ts +184 -0
- package/src/{react/core/hooks → wallets}/connection/types.ts +5 -5
- package/src/{react/web/wallets → wallets}/defaultWallets.ts +5 -10
- package/src/wallets/engine/engine-account.test.ts +69 -0
- package/src/wallets/engine/index.ts +198 -0
- package/src/wallets/in-app/web/lib/get-url-token.ts +1 -1
- package/src/wallets/smart/lib/signing.ts +1 -1
- package/src/wallets/smart/smart-wallet-integration.test.ts +1 -0
- package/dist/cjs/react/core/hooks/connection/types.js.map +0 -1
- package/dist/cjs/react/core/utils/timeoutPromise.js.map +0 -1
- package/dist/cjs/react/web/wallets/defaultWallets.js.map +0 -1
- package/dist/esm/react/core/hooks/connection/types.js.map +0 -1
- package/dist/esm/react/core/utils/timeoutPromise.js.map +0 -1
- package/dist/esm/react/web/wallets/defaultWallets.js.map +0 -1
- package/dist/types/react/core/hooks/connection/types.d.ts.map +0 -1
- package/dist/types/react/core/utils/timeoutPromise.d.ts.map +0 -1
- package/dist/types/react/web/wallets/defaultWallets.d.ts +0 -11
- package/dist/types/react/web/wallets/defaultWallets.d.ts.map +0 -1
- /package/dist/cjs/{react/core/utils → utils}/timeoutPromise.js +0 -0
- /package/dist/cjs/{react/core/hooks → wallets}/connection/types.js +0 -0
- /package/dist/esm/{react/core/utils → utils}/timeoutPromise.js +0 -0
- /package/dist/esm/{react/core/hooks → wallets}/connection/types.js +0 -0
- /package/dist/types/{react/core/utils → utils}/timeoutPromise.d.ts +0 -0
- /package/src/{react/core/utils → utils}/timeoutPromise.test.ts +0 -0
- /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 "
|
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.
|
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
|
+
});
|