thirdweb 5.61.6 → 5.62.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/exports/extensions/erc1155.js +3 -1
- package/dist/cjs/exports/extensions/erc1155.js.map +1 -1
- package/dist/cjs/extensions/erc1155/write/mintToBatch.js +79 -0
- package/dist/cjs/extensions/erc1155/write/mintToBatch.js.map +1 -0
- package/dist/cjs/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.js +15 -4
- package/dist/cjs/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.js.map +1 -1
- package/dist/cjs/react/native/ui/components/WalletImage.js +3 -2
- package/dist/cjs/react/native/ui/components/WalletImage.js.map +1 -1
- package/dist/cjs/react/native/ui/connect/ConnectModal.js +6 -6
- package/dist/cjs/react/native/ui/connect/ConnectModal.js.map +1 -1
- package/dist/cjs/react/native/ui/connect/ConnectedButton.js +2 -2
- package/dist/cjs/react/native/ui/connect/ConnectedButton.js.map +1 -1
- package/dist/cjs/react/native/ui/connect/ConnectedModal.js +3 -3
- package/dist/cjs/react/native/ui/connect/ConnectedModal.js.map +1 -1
- package/dist/cjs/react/native/ui/connect/ReceiveScreen.js +2 -2
- package/dist/cjs/react/native/ui/connect/ReceiveScreen.js.map +1 -1
- package/dist/cjs/react/web/wallets/in-app/WalletAuth.js +8 -0
- package/dist/cjs/react/web/wallets/in-app/WalletAuth.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +1 -0
- package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/OTPLoginUI.js +11 -16
- package/dist/cjs/react/web/wallets/shared/OTPLoginUI.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/PassKeyLogin.js +7 -0
- package/dist/cjs/react/web/wallets/shared/PassKeyLogin.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/SocialLogin.js +9 -12
- package/dist/cjs/react/web/wallets/shared/SocialLogin.js.map +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/wallets/in-app/{web/lib → core}/actions/generate-wallet.enclave.js +2 -2
- package/dist/cjs/wallets/in-app/core/actions/generate-wallet.enclave.js.map +1 -0
- package/dist/cjs/wallets/in-app/{web/lib → core}/actions/get-enclave-user-status.js +2 -2
- package/dist/cjs/wallets/in-app/core/actions/get-enclave-user-status.js.map +1 -0
- package/dist/cjs/wallets/in-app/{web/lib → core}/actions/sign-message.enclave.js +6 -5
- package/dist/cjs/wallets/in-app/core/actions/sign-message.enclave.js.map +1 -0
- package/dist/cjs/wallets/in-app/{web/lib → core}/actions/sign-transaction.enclave.js +6 -5
- package/dist/cjs/wallets/in-app/core/actions/sign-transaction.enclave.js.map +1 -0
- package/dist/cjs/wallets/in-app/{web/lib → core}/actions/sign-typed-data.enclave.js +6 -5
- package/dist/cjs/wallets/in-app/core/actions/sign-typed-data.enclave.js.map +1 -0
- package/dist/cjs/wallets/in-app/core/authentication/client-scoped-storage.js +9 -2
- package/dist/cjs/wallets/in-app/core/authentication/client-scoped-storage.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/authentication/guest.js +1 -1
- package/dist/cjs/wallets/in-app/core/authentication/guest.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js +4 -8
- package/dist/cjs/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/auth/passkeys.js +1 -1
- package/dist/cjs/wallets/in-app/native/auth/passkeys.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/api/fetchers.js +14 -0
- package/dist/cjs/wallets/in-app/native/helpers/api/fetchers.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/auth/middleware.js +3 -2
- package/dist/cjs/wallets/in-app/native/helpers/auth/middleware.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/constants.js +2 -1
- package/dist/cjs/wallets/in-app/native/helpers/constants.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/helpers/wallet/migration.js +133 -0
- package/dist/cjs/wallets/in-app/native/helpers/wallet/migration.js.map +1 -0
- package/dist/cjs/wallets/in-app/native/helpers/wallet/retrieval.js +2 -0
- package/dist/cjs/wallets/in-app/native/helpers/wallet/retrieval.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/native-connector.js +50 -28
- package/dist/cjs/wallets/in-app/native/native-connector.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/auth/iframe-auth.js +2 -2
- package/dist/cjs/wallets/in-app/web/lib/auth/iframe-auth.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/auth/passkeys.js +1 -1
- package/dist/cjs/wallets/in-app/web/lib/auth/passkeys.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/web-connector.js +13 -13
- package/dist/cjs/wallets/in-app/web/lib/web-connector.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/utils/iFrameCommunication/InAppWalletIframeCommunicator.js +1 -1
- package/dist/cjs/wallets/in-app/web/utils/iFrameCommunication/InAppWalletIframeCommunicator.js.map +1 -1
- package/dist/esm/exports/extensions/erc1155.js +1 -0
- package/dist/esm/exports/extensions/erc1155.js.map +1 -1
- package/dist/esm/extensions/erc1155/write/mintToBatch.js +76 -0
- package/dist/esm/extensions/erc1155/write/mintToBatch.js.map +1 -0
- package/dist/esm/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.js +15 -4
- package/dist/esm/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.js.map +1 -1
- package/dist/esm/react/native/ui/components/WalletImage.js +3 -2
- package/dist/esm/react/native/ui/components/WalletImage.js.map +1 -1
- package/dist/esm/react/native/ui/connect/ConnectModal.js +6 -6
- package/dist/esm/react/native/ui/connect/ConnectModal.js.map +1 -1
- package/dist/esm/react/native/ui/connect/ConnectedButton.js +2 -2
- package/dist/esm/react/native/ui/connect/ConnectedButton.js.map +1 -1
- package/dist/esm/react/native/ui/connect/ConnectedModal.js +3 -3
- package/dist/esm/react/native/ui/connect/ConnectedModal.js.map +1 -1
- package/dist/esm/react/native/ui/connect/ReceiveScreen.js +2 -2
- package/dist/esm/react/native/ui/connect/ReceiveScreen.js.map +1 -1
- package/dist/esm/react/web/wallets/in-app/WalletAuth.js +8 -0
- package/dist/esm/react/web/wallets/in-app/WalletAuth.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +1 -0
- package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/OTPLoginUI.js +12 -17
- package/dist/esm/react/web/wallets/shared/OTPLoginUI.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/PassKeyLogin.js +7 -0
- package/dist/esm/react/web/wallets/shared/PassKeyLogin.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/SocialLogin.js +9 -12
- package/dist/esm/react/web/wallets/shared/SocialLogin.js.map +1 -1
- package/dist/esm/version.js +1 -1
- package/dist/esm/wallets/in-app/{web/lib → core}/actions/generate-wallet.enclave.js +2 -2
- package/dist/esm/wallets/in-app/core/actions/generate-wallet.enclave.js.map +1 -0
- package/dist/esm/wallets/in-app/{web/lib → core}/actions/get-enclave-user-status.js +2 -2
- package/dist/esm/wallets/in-app/core/actions/get-enclave-user-status.js.map +1 -0
- package/dist/esm/wallets/in-app/{web/lib → core}/actions/sign-message.enclave.js +6 -5
- package/dist/esm/wallets/in-app/core/actions/sign-message.enclave.js.map +1 -0
- package/dist/esm/wallets/in-app/{web/lib → core}/actions/sign-transaction.enclave.js +6 -5
- package/dist/esm/wallets/in-app/core/actions/sign-transaction.enclave.js.map +1 -0
- package/dist/esm/wallets/in-app/{web/lib → core}/actions/sign-typed-data.enclave.js +6 -5
- package/dist/esm/wallets/in-app/core/actions/sign-typed-data.enclave.js.map +1 -0
- package/dist/esm/wallets/in-app/core/authentication/client-scoped-storage.js +9 -2
- package/dist/esm/wallets/in-app/core/authentication/client-scoped-storage.js.map +1 -1
- package/dist/esm/wallets/in-app/core/authentication/guest.js +1 -1
- package/dist/esm/wallets/in-app/core/authentication/guest.js.map +1 -1
- package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js +4 -8
- package/dist/esm/wallets/in-app/core/wallet/enclave-wallet.js.map +1 -1
- package/dist/esm/wallets/in-app/native/auth/passkeys.js +1 -1
- package/dist/esm/wallets/in-app/native/auth/passkeys.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/api/fetchers.js +14 -0
- package/dist/esm/wallets/in-app/native/helpers/api/fetchers.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/auth/middleware.js +3 -2
- package/dist/esm/wallets/in-app/native/helpers/auth/middleware.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/constants.js +1 -0
- package/dist/esm/wallets/in-app/native/helpers/constants.js.map +1 -1
- package/dist/esm/wallets/in-app/native/helpers/wallet/migration.js +130 -0
- package/dist/esm/wallets/in-app/native/helpers/wallet/migration.js.map +1 -0
- package/dist/esm/wallets/in-app/native/helpers/wallet/retrieval.js +2 -2
- package/dist/esm/wallets/in-app/native/helpers/wallet/retrieval.js.map +1 -1
- package/dist/esm/wallets/in-app/native/native-connector.js +50 -28
- package/dist/esm/wallets/in-app/native/native-connector.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/auth/iframe-auth.js +2 -2
- package/dist/esm/wallets/in-app/web/lib/auth/iframe-auth.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/auth/passkeys.js +1 -1
- package/dist/esm/wallets/in-app/web/lib/auth/passkeys.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/web-connector.js +13 -13
- package/dist/esm/wallets/in-app/web/lib/web-connector.js.map +1 -1
- package/dist/esm/wallets/in-app/web/utils/iFrameCommunication/InAppWalletIframeCommunicator.js +1 -1
- package/dist/esm/wallets/in-app/web/utils/iFrameCommunication/InAppWalletIframeCommunicator.js.map +1 -1
- package/dist/types/exports/extensions/erc1155.d.ts +1 -0
- package/dist/types/exports/extensions/erc1155.d.ts.map +1 -1
- package/dist/types/extensions/erc1155/write/mintToBatch.d.ts +72 -0
- package/dist/types/extensions/erc1155/write/mintToBatch.d.ts.map +1 -0
- package/dist/types/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.d.ts.map +1 -1
- package/dist/types/react/native/ui/components/WalletImage.d.ts +2 -0
- package/dist/types/react/native/ui/components/WalletImage.d.ts.map +1 -1
- package/dist/types/react/native/ui/connect/ConnectModal.d.ts.map +1 -1
- package/dist/types/react/native/ui/connect/ConnectedButton.d.ts.map +1 -1
- package/dist/types/react/native/ui/connect/ConnectedModal.d.ts.map +1 -1
- package/dist/types/react/native/ui/connect/ReceiveScreen.d.ts +2 -0
- package/dist/types/react/native/ui/connect/ReceiveScreen.d.ts.map +1 -1
- package/dist/types/react/web/wallets/in-app/WalletAuth.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/ConnectWalletSocialOptions.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/OTPLoginUI.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/SocialLogin.d.ts.map +1 -1
- package/dist/types/version.d.ts +1 -1
- package/dist/types/wallets/in-app/core/actions/generate-wallet.enclave.d.ts +13 -0
- package/dist/types/wallets/in-app/core/actions/generate-wallet.enclave.d.ts.map +1 -0
- package/dist/types/wallets/in-app/core/actions/get-enclave-user-status.d.ts +14 -0
- package/dist/types/wallets/in-app/core/actions/get-enclave-user-status.d.ts.map +1 -0
- package/dist/types/wallets/in-app/core/actions/sign-message.enclave.d.ts +17 -0
- package/dist/types/wallets/in-app/core/actions/sign-message.enclave.d.ts.map +1 -0
- package/dist/types/wallets/in-app/core/actions/sign-transaction.enclave.d.ts +9 -0
- package/dist/types/wallets/in-app/core/actions/sign-transaction.enclave.d.ts.map +1 -0
- package/dist/types/wallets/in-app/{web/lib → core}/actions/sign-typed-data.enclave.d.ts +3 -5
- package/dist/types/wallets/in-app/core/actions/sign-typed-data.enclave.d.ts.map +1 -0
- package/dist/types/wallets/in-app/core/authentication/client-scoped-storage.d.ts +4 -3
- package/dist/types/wallets/in-app/core/authentication/client-scoped-storage.d.ts.map +1 -1
- package/dist/types/wallets/in-app/core/wallet/enclave-wallet.d.ts +6 -7
- package/dist/types/wallets/in-app/core/wallet/enclave-wallet.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/api/fetchers.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/constants.d.ts +1 -0
- package/dist/types/wallets/in-app/native/helpers/constants.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/helpers/wallet/migration.d.ts +17 -0
- package/dist/types/wallets/in-app/native/helpers/wallet/migration.d.ts.map +1 -0
- package/dist/types/wallets/in-app/native/helpers/wallet/retrieval.d.ts +27 -0
- package/dist/types/wallets/in-app/native/helpers/wallet/retrieval.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/native-connector.d.ts +2 -2
- package/dist/types/wallets/in-app/native/native-connector.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/auth/iframe-auth.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/web-connector.d.ts +1 -1
- package/dist/types/wallets/in-app/web/lib/web-connector.d.ts.map +1 -1
- package/package.json +32 -28
- package/src/exports/extensions/erc1155.ts +5 -0
- package/src/extensions/erc1155/read/getNFTs.test.ts +44 -0
- package/src/extensions/erc1155/write/lazyMint.test.ts +35 -0
- package/src/extensions/erc1155/write/mintAdditionalSupplyTo.test.ts +38 -0
- package/src/extensions/erc1155/write/mintTo.test.ts +43 -0
- package/src/extensions/erc1155/write/mintToBatch.test.ts +74 -0
- package/src/extensions/erc1155/write/mintToBatch.ts +117 -0
- package/src/extensions/erc20/read/isERC20.test.ts +1 -1
- package/src/extensions/erc20/write/transferBatch.test.ts +1 -1
- package/src/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.test.ts +75 -80
- package/src/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.ts +18 -4
- package/src/react/native/ui/components/WalletImage.tsx +5 -2
- package/src/react/native/ui/connect/ConnectModal.tsx +19 -2
- package/src/react/native/ui/connect/ConnectedButton.tsx +8 -2
- package/src/react/native/ui/connect/ConnectedModal.tsx +9 -2
- package/src/react/native/ui/connect/ReceiveScreen.tsx +5 -2
- package/src/react/web/wallets/in-app/WalletAuth.tsx +8 -0
- package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +1 -0
- package/src/react/web/wallets/shared/OTPLoginUI.tsx +12 -18
- package/src/react/web/wallets/shared/PassKeyLogin.tsx +7 -0
- package/src/react/web/wallets/shared/SocialLogin.tsx +9 -12
- package/src/version.ts +1 -1
- package/src/wallets/in-app/{web/lib → core}/actions/generate-wallet.enclave.ts +6 -8
- package/src/wallets/in-app/{web/lib → core}/actions/get-enclave-user-status.ts +5 -5
- package/src/wallets/in-app/{web/lib → core}/actions/sign-message.enclave.ts +7 -9
- package/src/wallets/in-app/{web/lib → core}/actions/sign-transaction.enclave.ts +8 -10
- package/src/wallets/in-app/{web/lib → core}/actions/sign-typed-data.enclave.ts +7 -9
- package/src/wallets/in-app/core/authentication/client-scoped-storage.ts +6 -4
- package/src/wallets/in-app/core/authentication/guest.ts +1 -1
- package/src/wallets/in-app/core/wallet/enclave-wallet.ts +11 -17
- package/src/wallets/in-app/native/auth/passkeys.ts +1 -1
- package/src/wallets/in-app/native/helpers/api/fetchers.ts +14 -0
- package/src/wallets/in-app/native/helpers/auth/middleware.ts +3 -2
- package/src/wallets/in-app/native/helpers/constants.ts +2 -0
- package/src/wallets/in-app/native/helpers/wallet/migration.ts +185 -0
- package/src/wallets/in-app/native/helpers/wallet/retrieval.ts +2 -2
- package/src/wallets/in-app/native/native-connector.ts +62 -28
- package/src/wallets/in-app/web/lib/auth/iframe-auth.ts +2 -2
- package/src/wallets/in-app/web/lib/auth/passkeys.ts +1 -1
- package/src/wallets/in-app/web/lib/web-connector.ts +13 -13
- package/src/wallets/in-app/web/utils/iFrameCommunication/InAppWalletIframeCommunicator.ts +1 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/generate-wallet.enclave.js.map +0 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/get-enclave-user-status.js.map +0 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-message.enclave.js.map +0 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-transaction.enclave.js.map +0 -1
- package/dist/cjs/wallets/in-app/web/lib/actions/sign-typed-data.enclave.js.map +0 -1
- package/dist/esm/wallets/in-app/web/lib/actions/generate-wallet.enclave.js.map +0 -1
- package/dist/esm/wallets/in-app/web/lib/actions/get-enclave-user-status.js.map +0 -1
- package/dist/esm/wallets/in-app/web/lib/actions/sign-message.enclave.js.map +0 -1
- package/dist/esm/wallets/in-app/web/lib/actions/sign-transaction.enclave.js.map +0 -1
- package/dist/esm/wallets/in-app/web/lib/actions/sign-typed-data.enclave.js.map +0 -1
- package/dist/types/wallets/in-app/web/lib/actions/generate-wallet.enclave.d.ts +0 -15
- package/dist/types/wallets/in-app/web/lib/actions/generate-wallet.enclave.d.ts.map +0 -1
- package/dist/types/wallets/in-app/web/lib/actions/get-enclave-user-status.d.ts +0 -14
- package/dist/types/wallets/in-app/web/lib/actions/get-enclave-user-status.d.ts.map +0 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-message.enclave.d.ts +0 -19
- package/dist/types/wallets/in-app/web/lib/actions/sign-message.enclave.d.ts.map +0 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-transaction.enclave.d.ts +0 -11
- package/dist/types/wallets/in-app/web/lib/actions/sign-transaction.enclave.d.ts.map +0 -1
- package/dist/types/wallets/in-app/web/lib/actions/sign-typed-data.enclave.d.ts.map +0 -1
@@ -1,26 +1,24 @@
|
|
1
|
-
import type { ThirdwebClient } from "
|
2
|
-
import { getThirdwebBaseUrl } from "
|
3
|
-
import { getClientFetch } from "
|
4
|
-
import { stringify } from "
|
5
|
-
import type { ClientScopedStorage } from "
|
6
|
-
import type { Ecosystem } from "../../../core/wallet/types.js";
|
1
|
+
import type { ThirdwebClient } from "../../../../client/client.js";
|
2
|
+
import { getThirdwebBaseUrl } from "../../../../utils/domains.js";
|
3
|
+
import { getClientFetch } from "../../../../utils/fetch.js";
|
4
|
+
import { stringify } from "../../../../utils/json.js";
|
5
|
+
import type { ClientScopedStorage } from "../authentication/client-scoped-storage.js";
|
7
6
|
|
8
7
|
export async function signMessage({
|
9
8
|
client,
|
10
|
-
ecosystem,
|
11
9
|
payload: { message, isRaw },
|
12
10
|
storage,
|
13
11
|
}: {
|
14
12
|
client: ThirdwebClient;
|
15
|
-
ecosystem?: Ecosystem;
|
16
13
|
payload: {
|
17
14
|
message: string;
|
18
15
|
isRaw: boolean;
|
19
16
|
};
|
20
17
|
storage: ClientScopedStorage;
|
21
18
|
}) {
|
22
|
-
const clientFetch = getClientFetch(client, ecosystem);
|
23
19
|
const authToken = await storage.getAuthCookie();
|
20
|
+
const ecosystem = storage.ecosystem;
|
21
|
+
const clientFetch = getClientFetch(client, ecosystem);
|
24
22
|
|
25
23
|
if (!authToken) {
|
26
24
|
throw new Error("No auth token found when signing message");
|
@@ -1,24 +1,22 @@
|
|
1
|
-
import type { ThirdwebClient } from "
|
2
|
-
import { getThirdwebBaseUrl } from "
|
3
|
-
import type { Hex } from "
|
4
|
-
import { getClientFetch } from "
|
5
|
-
import { stringify } from "
|
6
|
-
import type { ClientScopedStorage } from "
|
7
|
-
import type { Ecosystem } from "../../../core/wallet/types.js";
|
1
|
+
import type { ThirdwebClient } from "../../../../client/client.js";
|
2
|
+
import { getThirdwebBaseUrl } from "../../../../utils/domains.js";
|
3
|
+
import type { Hex } from "../../../../utils/encoding/hex.js";
|
4
|
+
import { getClientFetch } from "../../../../utils/fetch.js";
|
5
|
+
import { stringify } from "../../../../utils/json.js";
|
6
|
+
import type { ClientScopedStorage } from "../authentication/client-scoped-storage.js";
|
8
7
|
|
9
8
|
export async function signTransaction({
|
10
9
|
client,
|
11
|
-
ecosystem,
|
12
10
|
payload,
|
13
11
|
storage,
|
14
12
|
}: {
|
15
13
|
client: ThirdwebClient;
|
16
|
-
ecosystem?: Ecosystem;
|
17
14
|
payload: Record<string, Hex | number | undefined>;
|
18
15
|
storage: ClientScopedStorage;
|
19
16
|
}) {
|
20
|
-
const clientFetch = getClientFetch(client, ecosystem);
|
21
17
|
const authToken = await storage.getAuthCookie();
|
18
|
+
const ecosystem = storage.ecosystem;
|
19
|
+
const clientFetch = getClientFetch(client, ecosystem);
|
22
20
|
|
23
21
|
if (!authToken) {
|
24
22
|
throw new Error("No auth token found when signing transaction");
|
@@ -1,28 +1,26 @@
|
|
1
1
|
import type { TypedData } from "abitype";
|
2
2
|
import type { TypedDataDefinition } from "viem";
|
3
|
-
import type { ThirdwebClient } from "
|
4
|
-
import { getThirdwebBaseUrl } from "
|
5
|
-
import { getClientFetch } from "
|
6
|
-
import { stringify } from "
|
7
|
-
import type { ClientScopedStorage } from "
|
8
|
-
import type { Ecosystem } from "../../../core/wallet/types.js";
|
3
|
+
import type { ThirdwebClient } from "../../../../client/client.js";
|
4
|
+
import { getThirdwebBaseUrl } from "../../../../utils/domains.js";
|
5
|
+
import { getClientFetch } from "../../../../utils/fetch.js";
|
6
|
+
import { stringify } from "../../../../utils/json.js";
|
7
|
+
import type { ClientScopedStorage } from "../authentication/client-scoped-storage.js";
|
9
8
|
|
10
9
|
export async function signTypedData<
|
11
10
|
const typedData extends TypedData | Record<string, unknown>,
|
12
11
|
primaryType extends keyof typedData | "EIP712Domain" = keyof typedData,
|
13
12
|
>({
|
14
13
|
client,
|
15
|
-
ecosystem,
|
16
14
|
payload,
|
17
15
|
storage,
|
18
16
|
}: {
|
19
17
|
client: ThirdwebClient;
|
20
|
-
ecosystem?: Ecosystem;
|
21
18
|
payload: TypedDataDefinition<typedData, primaryType>;
|
22
19
|
storage: ClientScopedStorage;
|
23
20
|
}) {
|
24
|
-
const clientFetch = getClientFetch(client, ecosystem);
|
25
21
|
const authToken = await storage.getAuthCookie();
|
22
|
+
const ecosystem = storage.ecosystem;
|
23
|
+
const clientFetch = getClientFetch(client, ecosystem);
|
26
24
|
|
27
25
|
if (!authToken) {
|
28
26
|
throw new Error("No auth token found when signing typed data");
|
@@ -1,5 +1,4 @@
|
|
1
1
|
import type { AsyncStorage } from "../../../../utils/storage/AsyncStorage.js";
|
2
|
-
import type { EcosystemWalletId } from "../../../wallet-types.js";
|
3
2
|
import {
|
4
3
|
AUTH_TOKEN_LOCAL_STORAGE_NAME,
|
5
4
|
DEVICE_SHARE_LOCAL_STORAGE_NAME,
|
@@ -8,6 +7,7 @@ import {
|
|
8
7
|
WALLET_CONNECT_SESSIONS_LOCAL_STORAGE_NAME,
|
9
8
|
WALLET_USER_ID_LOCAL_STORAGE_NAME,
|
10
9
|
} from "../constants/settings.js";
|
10
|
+
import type { Ecosystem } from "../wallet/types.js";
|
11
11
|
|
12
12
|
const data = new Map<string, string>();
|
13
13
|
|
@@ -17,20 +17,22 @@ const data = new Map<string, string>();
|
|
17
17
|
export class ClientScopedStorage {
|
18
18
|
protected key: string;
|
19
19
|
protected storage: AsyncStorage | null;
|
20
|
+
public ecosystem?: Ecosystem;
|
20
21
|
/**
|
21
22
|
* @internal
|
22
23
|
*/
|
23
24
|
constructor({
|
24
25
|
storage,
|
25
26
|
clientId,
|
26
|
-
|
27
|
+
ecosystem,
|
27
28
|
}: {
|
28
29
|
storage: AsyncStorage | null;
|
29
30
|
clientId: string;
|
30
|
-
|
31
|
+
ecosystem?: Ecosystem;
|
31
32
|
}) {
|
32
33
|
this.storage = storage;
|
33
|
-
this.key = getLocalStorageKey(clientId,
|
34
|
+
this.key = getLocalStorageKey(clientId, ecosystem?.id);
|
35
|
+
this.ecosystem = ecosystem;
|
34
36
|
}
|
35
37
|
|
36
38
|
protected async getItem(key: string): Promise<string | null> {
|
@@ -19,7 +19,7 @@ export async function guestAuthenticate(args: {
|
|
19
19
|
const storage = new ClientScopedStorage({
|
20
20
|
storage: args.storage,
|
21
21
|
clientId: args.client.clientId,
|
22
|
-
|
22
|
+
ecosystem: args.ecosystem,
|
23
23
|
});
|
24
24
|
|
25
25
|
let sessionId = await storage.getGuestSessionId();
|
@@ -11,10 +11,10 @@ import type {
|
|
11
11
|
Account,
|
12
12
|
SendTransactionOption,
|
13
13
|
} from "../../../interfaces/wallet.js";
|
14
|
-
import { getUserStatus } from "
|
15
|
-
import { signMessage as signEnclaveMessage } from "
|
16
|
-
import { signTransaction as signEnclaveTransaction } from "
|
17
|
-
import { signTypedData as signEnclaveTypedData } from "
|
14
|
+
import { getUserStatus } from "../actions/get-enclave-user-status.js";
|
15
|
+
import { signMessage as signEnclaveMessage } from "../actions/sign-message.enclave.js";
|
16
|
+
import { signTransaction as signEnclaveTransaction } from "../actions/sign-transaction.enclave.js";
|
17
|
+
import { signTypedData as signEnclaveTypedData } from "../actions/sign-typed-data.enclave.js";
|
18
18
|
import type { ClientScopedStorage } from "../authentication/client-scoped-storage.js";
|
19
19
|
import type {
|
20
20
|
AuthDetails,
|
@@ -33,18 +33,16 @@ export type UserStatus = {
|
|
33
33
|
| { address: string; [key: string]: string }
|
34
34
|
| { id: string; [key: string]: string };
|
35
35
|
}[];
|
36
|
-
wallets:
|
37
|
-
| [
|
38
|
-
{
|
39
|
-
address: string;
|
40
|
-
createdAt: string;
|
41
|
-
type: "sharded" | "enclave";
|
42
|
-
},
|
43
|
-
]
|
44
|
-
| [];
|
36
|
+
wallets: UserWallet[];
|
45
37
|
id: string;
|
46
38
|
};
|
47
39
|
|
40
|
+
export type UserWallet = {
|
41
|
+
address: string;
|
42
|
+
createdAt: string;
|
43
|
+
type: "sharded" | "enclave";
|
44
|
+
};
|
45
|
+
|
48
46
|
export class EnclaveWallet implements IWebWallet {
|
49
47
|
private client: ThirdwebClient;
|
50
48
|
private ecosystem?: Ecosystem;
|
@@ -130,7 +128,6 @@ export class EnclaveWallet implements IWebWallet {
|
|
130
128
|
*/
|
131
129
|
async getAccount(): Promise<Account> {
|
132
130
|
const client = this.client;
|
133
|
-
const ecosystem = this.ecosystem;
|
134
131
|
const storage = this.localStorage;
|
135
132
|
|
136
133
|
const _signTransaction = async (tx: SendTransactionOption) => {
|
@@ -171,7 +168,6 @@ export class EnclaveWallet implements IWebWallet {
|
|
171
168
|
|
172
169
|
return signEnclaveTransaction({
|
173
170
|
client,
|
174
|
-
ecosystem,
|
175
171
|
storage,
|
176
172
|
payload: transaction,
|
177
173
|
});
|
@@ -218,7 +214,6 @@ export class EnclaveWallet implements IWebWallet {
|
|
218
214
|
|
219
215
|
const { signature } = await signEnclaveMessage({
|
220
216
|
client,
|
221
|
-
ecosystem,
|
222
217
|
payload: messagePayload,
|
223
218
|
storage,
|
224
219
|
});
|
@@ -228,7 +223,6 @@ export class EnclaveWallet implements IWebWallet {
|
|
228
223
|
const parsedTypedData = parseTypedData(_typedData);
|
229
224
|
const { signature } = await signEnclaveTypedData({
|
230
225
|
client,
|
231
|
-
ecosystem,
|
232
226
|
payload: parsedTypedData,
|
233
227
|
storage,
|
234
228
|
});
|
@@ -125,7 +125,7 @@ export async function hasStoredPasskey(
|
|
125
125
|
const storage = new ClientScopedStorage({
|
126
126
|
storage: nativeLocalStorage,
|
127
127
|
clientId: client.clientId,
|
128
|
-
ecosystemId: ecosystemId,
|
128
|
+
ecosystem: ecosystemId ? { id: ecosystemId } : undefined,
|
129
129
|
});
|
130
130
|
const credId = await storage.getPasskeyCredentialId();
|
131
131
|
return !!credId;
|
@@ -14,6 +14,8 @@ import { createErrorMessage } from "../errors.js";
|
|
14
14
|
|
15
15
|
const EMBEDDED_WALLET_TOKEN_HEADER = "embedded-wallet-token";
|
16
16
|
const PAPER_CLIENT_ID_HEADER = "x-thirdweb-client-id";
|
17
|
+
const ECOSYSTEM_ID_HEADER = "x-ecosystem-id";
|
18
|
+
const ECOSYSTEM_PARTNER_ID_HEADER = "x-ecosystem-partner-id";
|
17
19
|
|
18
20
|
let sessionNonce: Hex | undefined = undefined;
|
19
21
|
|
@@ -63,6 +65,12 @@ export async function authFetchEmbeddedWalletUser(args: {
|
|
63
65
|
authTokenClient || ""
|
64
66
|
}`,
|
65
67
|
[PAPER_CLIENT_ID_HEADER]: client.clientId,
|
68
|
+
...(storage.ecosystem
|
69
|
+
? {
|
70
|
+
[ECOSYSTEM_ID_HEADER]: storage.ecosystem.id,
|
71
|
+
[ECOSYSTEM_PARTNER_ID_HEADER]: storage.ecosystem?.partnerId,
|
72
|
+
}
|
73
|
+
: {}),
|
66
74
|
...getSessionHeaders(),
|
67
75
|
}
|
68
76
|
: {
|
@@ -70,6 +78,12 @@ export async function authFetchEmbeddedWalletUser(args: {
|
|
70
78
|
authTokenClient || ""
|
71
79
|
}`,
|
72
80
|
[PAPER_CLIENT_ID_HEADER]: client.clientId,
|
81
|
+
...(storage.ecosystem
|
82
|
+
? {
|
83
|
+
[ECOSYSTEM_ID_HEADER]: storage.ecosystem.id,
|
84
|
+
[ECOSYSTEM_PARTNER_ID_HEADER]: storage.ecosystem?.partnerId,
|
85
|
+
}
|
86
|
+
: {}),
|
73
87
|
...getSessionHeaders(),
|
74
88
|
};
|
75
89
|
|
@@ -102,10 +102,11 @@ async function getRecoveryCode(args: {
|
|
102
102
|
}
|
103
103
|
try {
|
104
104
|
return await getCognitoRecoveryPasswordV2({ client, storage });
|
105
|
-
} catch {
|
105
|
+
} catch (err) {
|
106
|
+
console.error("Error recovering wallet", err);
|
106
107
|
return await getCognitoRecoveryPasswordV1({ client, storage }).catch(
|
107
108
|
() => {
|
108
|
-
throw new Error("Something went wrong
|
109
|
+
throw new Error("Something went wrong while recovering wallet");
|
109
110
|
},
|
110
111
|
);
|
111
112
|
}
|
@@ -22,6 +22,8 @@ export const GENERATE_RECOVERY_PASSWORD_LAMBDA_FUNCTION_V1 =
|
|
22
22
|
"arn:aws:lambda:us-west-2:324457261097:function:recovery-share-password-GenerateRecoverySharePassw-bbE5ZbVAToil";
|
23
23
|
export const GENERATE_RECOVERY_PASSWORD_LAMBDA_FUNCTION_V2 =
|
24
24
|
"arn:aws:lambda:us-west-2:324457261097:function:lambda-thirdweb-auth-enc-key-prod-ThirdwebAuthEncKeyFunction";
|
25
|
+
export const ENCLAVE_KMS_KEY_ARN =
|
26
|
+
"arn:aws:kms:us-west-2:324457261097:key/8b2a8cd5-9b22-4ea0-a6bc-463824a78f20";
|
25
27
|
|
26
28
|
// TODO allow overriding domain
|
27
29
|
const DOMAIN_URL_2023 = getThirdwebBaseUrl("inAppWallet");
|
@@ -0,0 +1,185 @@
|
|
1
|
+
import { GenerateDataKeyCommand, KMSClient } from "@aws-sdk/client-kms";
|
2
|
+
import { fromCognitoIdentity } from "@aws-sdk/credential-providers";
|
3
|
+
import QuickCrypto from "react-native-quick-crypto";
|
4
|
+
import type { ThirdwebClient } from "../../../../../client/client.js";
|
5
|
+
import { getThirdwebBaseUrl } from "../../../../../utils/domains.js";
|
6
|
+
import { stringToBytes } from "../../../../../utils/encoding/to-bytes.js";
|
7
|
+
import { randomBytesBuffer } from "../../../../../utils/random.js";
|
8
|
+
import {
|
9
|
+
concatUint8Arrays,
|
10
|
+
uint8ArrayToBase64,
|
11
|
+
} from "../../../../../utils/uint8-array.js";
|
12
|
+
import { privateKeyToAccount } from "../../../../private-key.js";
|
13
|
+
import type { ClientScopedStorage } from "../../../core/authentication/client-scoped-storage.js";
|
14
|
+
import type { AuthStoredTokenWithCookieReturnType } from "../../../core/authentication/types.js";
|
15
|
+
import type { UserWallet } from "../../../core/wallet/enclave-wallet.js";
|
16
|
+
import { authFetchEmbeddedWalletUser } from "../api/fetchers.js";
|
17
|
+
import { postAuth } from "../auth/middleware.js";
|
18
|
+
import {
|
19
|
+
AWS_REGION,
|
20
|
+
ENCLAVE_KMS_KEY_ARN,
|
21
|
+
ROUTE_AUTH_COGNITO_ID_TOKEN_V2,
|
22
|
+
} from "../constants.js";
|
23
|
+
import { getShares, getWalletPrivateKeyFromShares } from "./retrieval.js";
|
24
|
+
|
25
|
+
/**
|
26
|
+
* Migrate a sharded wallet to an enclave wallet.
|
27
|
+
*
|
28
|
+
* @param args - The arguments for the migration process.
|
29
|
+
* @returns The migrated user wallet.
|
30
|
+
*/
|
31
|
+
export async function migrateToEnclaveWallet(args: {
|
32
|
+
client: ThirdwebClient;
|
33
|
+
storage: ClientScopedStorage;
|
34
|
+
storedToken: AuthStoredTokenWithCookieReturnType["storedToken"];
|
35
|
+
encryptionKey?: string;
|
36
|
+
}): Promise<UserWallet> {
|
37
|
+
// setup sharded wallet first, so we have the shares available
|
38
|
+
await postAuth({
|
39
|
+
storedToken: args.storedToken,
|
40
|
+
client: args.client,
|
41
|
+
storage: args.storage,
|
42
|
+
encryptionKey: args.encryptionKey,
|
43
|
+
});
|
44
|
+
|
45
|
+
const { authShare, deviceShare } = await getShares({
|
46
|
+
client: args.client,
|
47
|
+
authShare: { toRetrieve: true },
|
48
|
+
deviceShare: { toRetrieve: true },
|
49
|
+
recoveryShare: { toRetrieve: false },
|
50
|
+
storage: args.storage,
|
51
|
+
});
|
52
|
+
|
53
|
+
// construct the sharded wallet
|
54
|
+
const privateKey = await getWalletPrivateKeyFromShares([
|
55
|
+
authShare,
|
56
|
+
deviceShare,
|
57
|
+
]);
|
58
|
+
const account = privateKeyToAccount({
|
59
|
+
client: args.client,
|
60
|
+
privateKey,
|
61
|
+
});
|
62
|
+
const address = account.address;
|
63
|
+
|
64
|
+
// get cognito identity
|
65
|
+
const idTokenResponse = await authFetchEmbeddedWalletUser({
|
66
|
+
client: args.client,
|
67
|
+
url: ROUTE_AUTH_COGNITO_ID_TOKEN_V2,
|
68
|
+
props: {
|
69
|
+
method: "GET",
|
70
|
+
},
|
71
|
+
storage: args.storage,
|
72
|
+
});
|
73
|
+
if (!idTokenResponse.ok) {
|
74
|
+
throw new Error(
|
75
|
+
`Failed to fetch id token from Cognito: ${JSON.stringify(
|
76
|
+
await idTokenResponse.json(),
|
77
|
+
null,
|
78
|
+
2,
|
79
|
+
)}`,
|
80
|
+
);
|
81
|
+
}
|
82
|
+
const idTokenResult = await idTokenResponse.json();
|
83
|
+
const { token, identityId } = idTokenResult;
|
84
|
+
|
85
|
+
const cognitoIdentity = fromCognitoIdentity({
|
86
|
+
clientConfig: {
|
87
|
+
region: AWS_REGION,
|
88
|
+
},
|
89
|
+
identityId,
|
90
|
+
logins: {
|
91
|
+
"cognito-identity.amazonaws.com": token,
|
92
|
+
},
|
93
|
+
});
|
94
|
+
|
95
|
+
// get kms key
|
96
|
+
const kmsClient = new KMSClient({
|
97
|
+
region: AWS_REGION,
|
98
|
+
credentials: cognitoIdentity,
|
99
|
+
});
|
100
|
+
const generateDataKeyCommand = new GenerateDataKeyCommand({
|
101
|
+
KeyId: ENCLAVE_KMS_KEY_ARN,
|
102
|
+
KeySpec: "AES_256",
|
103
|
+
});
|
104
|
+
const encryptedKeyResult = await kmsClient.send(generateDataKeyCommand);
|
105
|
+
const plaintextKeyBlob = encryptedKeyResult.Plaintext;
|
106
|
+
const cipherTextBlob = encryptedKeyResult.CiphertextBlob;
|
107
|
+
if (!plaintextKeyBlob || !cipherTextBlob) {
|
108
|
+
throw new Error("No migration key found. Please try again.");
|
109
|
+
}
|
110
|
+
|
111
|
+
// encrypt private key
|
112
|
+
const iv = randomBytesBuffer(16);
|
113
|
+
// @ts-ignore - default import buils but ts doesn't like it
|
114
|
+
const key = await QuickCrypto.subtle.importKey(
|
115
|
+
"raw",
|
116
|
+
plaintextKeyBlob,
|
117
|
+
"AES-CBC",
|
118
|
+
false,
|
119
|
+
["encrypt", "decrypt"],
|
120
|
+
);
|
121
|
+
|
122
|
+
// @ts-ignore - default import buils but ts doesn't like it
|
123
|
+
const encryptedPrivateKey = await QuickCrypto.subtle.encrypt(
|
124
|
+
{
|
125
|
+
name: "AES-CBC",
|
126
|
+
iv,
|
127
|
+
},
|
128
|
+
key,
|
129
|
+
stringToBytes(privateKey),
|
130
|
+
);
|
131
|
+
|
132
|
+
const encryptedData = concatUint8Arrays([
|
133
|
+
iv,
|
134
|
+
new Uint8Array(encryptedPrivateKey),
|
135
|
+
]);
|
136
|
+
|
137
|
+
const ivB64 = uint8ArrayToBase64(iv);
|
138
|
+
const cipherTextB64 = uint8ArrayToBase64(cipherTextBlob);
|
139
|
+
const encryptedPrivateKeyB64 = uint8ArrayToBase64(encryptedData);
|
140
|
+
|
141
|
+
// execute migration
|
142
|
+
const result = await executeMigration({
|
143
|
+
client: args.client,
|
144
|
+
storage: args.storage,
|
145
|
+
address,
|
146
|
+
kmsCiphertextB64: cipherTextB64,
|
147
|
+
encryptedPrivateKeyB64: encryptedPrivateKeyB64,
|
148
|
+
ivB64,
|
149
|
+
});
|
150
|
+
|
151
|
+
return result;
|
152
|
+
}
|
153
|
+
|
154
|
+
async function executeMigration(args: {
|
155
|
+
client: ThirdwebClient;
|
156
|
+
storage: ClientScopedStorage;
|
157
|
+
address: string;
|
158
|
+
kmsCiphertextB64: string;
|
159
|
+
encryptedPrivateKeyB64: string;
|
160
|
+
ivB64: string;
|
161
|
+
}): Promise<UserWallet> {
|
162
|
+
const migrationResponse = await authFetchEmbeddedWalletUser({
|
163
|
+
client: args.client,
|
164
|
+
url: `${getThirdwebBaseUrl("inAppWallet")}/api/v1/enclave-wallet/migrate`,
|
165
|
+
props: {
|
166
|
+
method: "POST",
|
167
|
+
body: JSON.stringify({
|
168
|
+
address: args.address,
|
169
|
+
kmsCiphertextB64: args.kmsCiphertextB64,
|
170
|
+
encryptedPrivateKeyB64: args.encryptedPrivateKeyB64,
|
171
|
+
ivB64: args.ivB64,
|
172
|
+
}),
|
173
|
+
},
|
174
|
+
storage: args.storage,
|
175
|
+
});
|
176
|
+
if (!migrationResponse.ok) {
|
177
|
+
throw new Error(
|
178
|
+
`Failed to migrate to enclave wallet: ${JSON.stringify(
|
179
|
+
await migrationResponse.json(),
|
180
|
+
)}`,
|
181
|
+
);
|
182
|
+
}
|
183
|
+
const migrationResult = (await migrationResponse.json()) as UserWallet;
|
184
|
+
return migrationResult;
|
185
|
+
}
|
@@ -40,7 +40,7 @@ export async function getExistingUserAccount(args: {
|
|
40
40
|
});
|
41
41
|
}
|
42
42
|
|
43
|
-
async function getWalletPrivateKeyFromShares(shares: string[]) {
|
43
|
+
export async function getWalletPrivateKeyFromShares(shares: string[]) {
|
44
44
|
const { secrets } = await import("./sss.js");
|
45
45
|
let privateKeyHex = secrets.combine(shares, 0);
|
46
46
|
if (!isHex(privateKeyHex)) {
|
@@ -86,7 +86,7 @@ async function getAccountFromShares(args: {
|
|
86
86
|
* @returns The requested shares
|
87
87
|
* @throws if attempting to get deviceShare when it's not present
|
88
88
|
*/
|
89
|
-
async function getShares<
|
89
|
+
export async function getShares<
|
90
90
|
A extends boolean,
|
91
91
|
D extends boolean,
|
92
92
|
R extends boolean,
|