@dynamic-labs-sdk/client 0.2.3 → 0.3.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 (77) hide show
  1. package/dist/{InvalidParamError-CJIvJNbF.cjs.js → InvalidParamError-quxEncyd.cjs.js} +2 -2
  2. package/dist/{InvalidParamError-CJIvJNbF.cjs.js.map → InvalidParamError-quxEncyd.cjs.js.map} +1 -1
  3. package/dist/{InvalidParamError-DkpF0xkO.esm.js → InvalidParamError-tpCmR-0K.esm.js} +2 -2
  4. package/dist/{InvalidParamError-DkpF0xkO.esm.js.map → InvalidParamError-tpCmR-0K.esm.js.map} +1 -1
  5. package/dist/NotWaasWalletAccountError-B5f6_w78.esm.js +37 -0
  6. package/dist/NotWaasWalletAccountError-B5f6_w78.esm.js.map +1 -0
  7. package/dist/{NotWaasWalletAccountError-hsivqekP.cjs.js → NotWaasWalletAccountError-DuMMt1dJ.cjs.js} +13 -11
  8. package/dist/NotWaasWalletAccountError-DuMMt1dJ.cjs.js.map +1 -0
  9. package/dist/{constants-B_XuwMeC.cjs.js → constants-COTx8_KG.cjs.js} +38 -5
  10. package/dist/constants-COTx8_KG.cjs.js.map +1 -0
  11. package/dist/{constants-CWf6oCKJ.esm.js → constants-Cg3ipRSQ.esm.js} +20 -5
  12. package/dist/constants-Cg3ipRSQ.esm.js.map +1 -0
  13. package/dist/core.cjs.js +5 -5
  14. package/dist/core.esm.js +7 -7
  15. package/dist/core.esm.js.map +1 -1
  16. package/dist/exports/index.d.ts +1 -0
  17. package/dist/exports/index.d.ts.map +1 -1
  18. package/dist/{getNetworkProviderFromNetworkId-BHsPtt_G.cjs.js → getNetworkProviderFromNetworkId-DM3nd8O1.cjs.js} +3 -3
  19. package/dist/{getNetworkProviderFromNetworkId-BHsPtt_G.cjs.js.map → getNetworkProviderFromNetworkId-DM3nd8O1.cjs.js.map} +1 -1
  20. package/dist/{getNetworkProviderFromNetworkId-D8BsiPYZ.esm.js → getNetworkProviderFromNetworkId-O11XpA9s.esm.js} +5 -5
  21. package/dist/getNetworkProviderFromNetworkId-O11XpA9s.esm.js.map +1 -0
  22. package/dist/{getSignedSessionId-CLTOI68w.cjs.js → getSignedSessionId-BGAnr5jS.cjs.js} +3 -3
  23. package/dist/{getSignedSessionId-CLTOI68w.cjs.js.map → getSignedSessionId-BGAnr5jS.cjs.js.map} +1 -1
  24. package/dist/{getSignedSessionId-lPL9Oude.esm.js → getSignedSessionId-C3t_B6ZU.esm.js} +3 -3
  25. package/dist/{getSignedSessionId-lPL9Oude.esm.js.map → getSignedSessionId-C3t_B6ZU.esm.js.map} +1 -1
  26. package/dist/{getVerifiedCredentialForWalletAccount-HCLyjhLC.cjs.js → getVerifiedCredentialForWalletAccount-B96b7nLc.cjs.js} +79 -12
  27. package/dist/getVerifiedCredentialForWalletAccount-B96b7nLc.cjs.js.map +1 -0
  28. package/dist/{getVerifiedCredentialForWalletAccount-Bh27tpbm.esm.js → getVerifiedCredentialForWalletAccount-ryH7FulV.esm.js} +55 -12
  29. package/dist/getVerifiedCredentialForWalletAccount-ryH7FulV.esm.js.map +1 -0
  30. package/dist/index.cjs.js +30 -8
  31. package/dist/index.cjs.js.map +1 -1
  32. package/dist/index.esm.js +32 -11
  33. package/dist/index.esm.js.map +1 -1
  34. package/dist/{isMfaRequiredForAction-CBvaJAqD.cjs.js → isMfaRequiredForAction-CZEDBXNT.cjs.js} +2 -2
  35. package/dist/{isMfaRequiredForAction-CBvaJAqD.cjs.js.map → isMfaRequiredForAction-CZEDBXNT.cjs.js.map} +1 -1
  36. package/dist/{isMfaRequiredForAction-DDWwiFPT.esm.js → isMfaRequiredForAction-CjKgE8dm.esm.js} +2 -2
  37. package/dist/{isMfaRequiredForAction-DDWwiFPT.esm.js.map → isMfaRequiredForAction-CjKgE8dm.esm.js.map} +1 -1
  38. package/dist/modules/auth/updateAuthFromVerifyResponse/updateAuthFromVerifyResponse.d.ts.map +1 -1
  39. package/dist/modules/initializeClient/initializeClient.d.ts.map +1 -1
  40. package/dist/modules/user/refreshAuth/index.d.ts +2 -0
  41. package/dist/modules/user/refreshAuth/index.d.ts.map +1 -0
  42. package/dist/modules/user/refreshAuth/refreshAuth.d.ts +12 -0
  43. package/dist/modules/user/refreshAuth/refreshAuth.d.ts.map +1 -0
  44. package/dist/modules/user/refreshUser/refreshUser.d.ts +5 -4
  45. package/dist/modules/user/refreshUser/refreshUser.d.ts.map +1 -1
  46. package/dist/modules/waas/createWaasProvider/createWaasProvider.d.ts.map +1 -1
  47. package/dist/modules/waas/createWaasWalletAccounts/createWaasWalletAccounts.d.ts +15 -1
  48. package/dist/modules/waas/createWaasWalletAccounts/createWaasWalletAccounts.d.ts.map +1 -1
  49. package/dist/modules/waas/restoreUserSharesForAllWalletAccounts/index.d.ts +2 -0
  50. package/dist/modules/waas/restoreUserSharesForAllWalletAccounts/index.d.ts.map +1 -0
  51. package/dist/modules/waas/restoreUserSharesForAllWalletAccounts/restoreUserSharesForAllWalletAccounts.d.ts +3 -0
  52. package/dist/modules/waas/restoreUserSharesForAllWalletAccounts/restoreUserSharesForAllWalletAccounts.d.ts.map +1 -0
  53. package/dist/modules/waas/waas.types.d.ts +6 -1
  54. package/dist/modules/waas/waas.types.d.ts.map +1 -1
  55. package/dist/modules/wallets/constants.d.ts.map +1 -1
  56. package/dist/tsconfig.lib.tsbuildinfo +1 -1
  57. package/dist/waas.cjs.js +19 -48
  58. package/dist/waas.cjs.js.map +1 -1
  59. package/dist/waas.esm.js +13 -42
  60. package/dist/waas.esm.js.map +1 -1
  61. package/dist/waasCore.cjs.js +23 -13
  62. package/dist/waasCore.cjs.js.map +1 -1
  63. package/dist/waasCore.esm.js +19 -9
  64. package/dist/waasCore.esm.js.map +1 -1
  65. package/package.json +15 -14
  66. package/dist/NotWaasWalletAccountError-EM-jS7v3.esm.js +0 -35
  67. package/dist/NotWaasWalletAccountError-EM-jS7v3.esm.js.map +0 -1
  68. package/dist/NotWaasWalletAccountError-hsivqekP.cjs.js.map +0 -1
  69. package/dist/constants-B_XuwMeC.cjs.js.map +0 -1
  70. package/dist/constants-CWf6oCKJ.esm.js.map +0 -1
  71. package/dist/constants-DHMXlIUo.esm.js +0 -14
  72. package/dist/constants-DHMXlIUo.esm.js.map +0 -1
  73. package/dist/constants-vfnggq88.cjs.js +0 -31
  74. package/dist/constants-vfnggq88.cjs.js.map +0 -1
  75. package/dist/getNetworkProviderFromNetworkId-D8BsiPYZ.esm.js.map +0 -1
  76. package/dist/getVerifiedCredentialForWalletAccount-Bh27tpbm.esm.js.map +0 -1
  77. package/dist/getVerifiedCredentialForWalletAccount-HCLyjhLC.cjs.js.map +0 -1
package/dist/index.esm.js CHANGED
@@ -1,13 +1,13 @@
1
- import { C as BaseError, E as version, T as name, _ as randomString, a as createApiClient, b as getDefaultClient, c as MfaInvalidOtpError, d as APIError, g as ValueMustBeDefinedError, h as assertDefined, i as CHAINS_INFO_MAP, l as LinkCredentialError, m as isCookieEnabled, n as SDK_API_CORE_VERSION, o as SandboxMaximumThresholdReachedError, p as getBuffer, r as getChainFromVerifiedCredentialChain, s as MfaRateLimitedError, t as DYNAMIC_ICONIC_SPRITE_URL, u as InvalidExternalAuthError, v as CLIENT_SDK_NAME, w as getCore, x as setDefaultClient } from "./constants-CWf6oCKJ.esm.js";
2
- import { A as isEqualShallow, C as INITIALIZE_STORAGE_SYNC_TRACKER_KEY, E as createStorage, O as createLocalStorageAdapter, S as GENERATE_SESSION_KEYS_TRACKER_KEY, T as createStorageKeySchema, _ as NoNetworkProvidersError, a as updateWalletProviderKeysForVerifiedCredentials, b as createDeferredPromise, c as createSignInMessageStatement, d as createVisit, f as hasExtension, g as WalletAlreadyLinkedToAnotherUserError, h as isCaptchaRequired, i as getNetworksData, k as subscribeWithSelector, l as formatSignInMessage, m as consumeCaptchaToken, o as verifyMessageSignatureOwnership, p as setCaptchaToken, s as removeUnverifiedWalletAccount, t as getNetworkProviderFromNetworkId, u as setUnverifiedWalletAccounts, v as createLogger, w as REFRESH_USER_STATE_FROM_COOKIE_TRACKER_KEY, x as FETCH_PROJECT_SETTINGS_TRACKER_KEY, y as CannotTrackError } from "./getNetworkProviderFromNetworkId-D8BsiPYZ.esm.js";
3
- import { C as onceEvent, S as onEvent, _ as normalizeAddress, a as checkAndRaiseWalletAccountsChangedEvent, b as emitEvent, c as getWalletProviderFromWalletAccount, f as NoWalletProviderFoundError, g as formatWalletAccountId, i as updateAuthFromVerifyResponse, n as getWalletProviderByKey, o as emitWalletAccountsChangedEvent, p as getWalletAccounts, r as getWalletProviders, s as DYNAMIC_AUTH_COOKIE_NAME, t as getVerifiedCredentialForWalletAccount, v as splitWalletProviderKey, w as setCookie, x as offEvent } from "./getVerifiedCredentialForWalletAccount-Bh27tpbm.esm.js";
4
- import { i as bufferToHex, n as getMfaMethods, r as consumeMfaToken, t as isMfaRequiredForAction } from "./isMfaRequiredForAction-DDWwiFPT.esm.js";
5
- import { n as refreshUser, t as NotWaasWalletAccountError } from "./NotWaasWalletAccountError-EM-jS7v3.esm.js";
6
- import { t as InvalidParamError } from "./InvalidParamError-DkpF0xkO.esm.js";
1
+ import { C as getDefaultClient, D as getCore, E as BaseError, O as name, _ as isCookieEnabled, a as SDK_API_CORE_VERSION, b as randomString, c as createApiClient, d as MfaInvalidOtpError, f as LinkCredentialError, g as getBuffer, i as DYNAMIC_ICONIC_SPRITE_URL, k as version, l as SandboxMaximumThresholdReachedError, m as APIError, o as getChainFromVerifiedCredentialChain, p as InvalidExternalAuthError, s as CHAINS_INFO_MAP, u as MfaRateLimitedError, v as assertDefined, w as setDefaultClient, x as CLIENT_SDK_NAME, y as ValueMustBeDefinedError } from "./constants-Cg3ipRSQ.esm.js";
2
+ import { A as isEqualShallow, C as INITIALIZE_STORAGE_SYNC_TRACKER_KEY, E as createStorage, O as createLocalStorageAdapter, S as GENERATE_SESSION_KEYS_TRACKER_KEY, T as createStorageKeySchema, _ as NoNetworkProvidersError, a as updateWalletProviderKeysForVerifiedCredentials, b as createDeferredPromise, c as createSignInMessageStatement, d as createVisit, f as hasExtension, g as WalletAlreadyLinkedToAnotherUserError, h as isCaptchaRequired, i as getNetworksData, k as subscribeWithSelector, l as formatSignInMessage, m as consumeCaptchaToken, o as verifyMessageSignatureOwnership, p as setCaptchaToken, s as removeUnverifiedWalletAccount, t as getNetworkProviderFromNetworkId, u as setUnverifiedWalletAccounts, v as createLogger, w as REFRESH_USER_STATE_FROM_COOKIE_TRACKER_KEY, x as FETCH_PROJECT_SETTINGS_TRACKER_KEY, y as CannotTrackError } from "./getNetworkProviderFromNetworkId-O11XpA9s.esm.js";
3
+ import { D as onceEvent, E as onEvent, O as setCookie, S as splitWalletProviderKey, T as offEvent, _ as getWalletAccounts, b as formatWalletAccountId, c as getWalletProviders, d as DYNAMIC_AUTH_COOKIE_NAME, f as getWalletProviderFromWalletAccount, g as NoWalletProviderFoundError, i as restoreUserSharesForAllWalletAccounts, l as checkAndRaiseWalletAccountsChangedEvent, n as getWalletProviderByKey, r as updateAuthFromVerifyResponse, t as getVerifiedCredentialForWalletAccount, u as emitWalletAccountsChangedEvent, w as emitEvent, x as normalizeAddress } from "./getVerifiedCredentialForWalletAccount-ryH7FulV.esm.js";
4
+ import { i as bufferToHex, n as getMfaMethods, r as consumeMfaToken, t as isMfaRequiredForAction } from "./isMfaRequiredForAction-CjKgE8dm.esm.js";
5
+ import { n as refreshAuth, t as NotWaasWalletAccountError } from "./NotWaasWalletAccountError-B5f6_w78.esm.js";
6
+ import { t as InvalidParamError } from "./InvalidParamError-tpCmR-0K.esm.js";
7
7
  import { assertPackageVersion } from "@dynamic-labs-sdk/assert-package-version";
8
8
  import { AuthModeEnum, JwtVerifiedCredentialFormatEnum, MFAAction, MfaBackupCodeAcknowledgement, ProviderEnum } from "@dynamic-labs/sdk-api-core";
9
9
  import * as z from "zod/mini";
10
- import EventEmitter, { EventEmitter as EventEmitter$1 } from "eventemitter3";
10
+ import EventEmitter$1, { EventEmitter } from "eventemitter3";
11
11
  import { browserSupportsWebAuthn, startAuthentication, startRegistration } from "@simplewebauthn/browser";
12
12
 
13
13
  //#region src/modules/state/raiseStateEvents/events.ts
@@ -501,7 +501,7 @@ const initializeClient = async (client = getDefaultClient()) => {
501
501
  * This call can fail with a 401 error if the user is not logged in and the SDK should finish its initialization process
502
502
  * without throwing an error because that is an expected behavior.
503
503
  */
504
- if (isCookieEnabled(client)) await refreshUser(client).catch(async (error) => {
504
+ if (isCookieEnabled(client)) await refreshAuth(client).catch(async (error) => {
505
505
  if (error.status === 401) {
506
506
  if (client.user) await logout(client);
507
507
  } else throw error;
@@ -530,6 +530,7 @@ const initializeClient = async (client = getDefaultClient()) => {
530
530
  core.state.set({ initStatus: "failed" });
531
531
  throw error;
532
532
  }
533
+ if (client.user) restoreUserSharesForAllWalletAccounts(client);
533
534
  };
534
535
 
535
536
  //#endregion
@@ -552,7 +553,7 @@ const createAsyncTrack = () => {
552
553
  * This ensures no process is missed (as it would throw when tracked on a different node tick).
553
554
  */
554
555
  let isTrackEnabled = true;
555
- const eventEmitter = new EventEmitter$1();
556
+ const eventEmitter = new EventEmitter();
556
557
  const allSettledPromise = createDeferredPromise();
557
558
  const tracker = /* @__PURE__ */ new Map();
558
559
  /**
@@ -598,7 +599,7 @@ const createAsyncTrack = () => {
598
599
 
599
600
  //#endregion
600
601
  //#region src/services/eventEmitter/createEventEmitter.ts
601
- const createEventEmitter = () => new EventEmitter();
602
+ const createEventEmitter = () => new EventEmitter$1();
602
603
 
603
604
  //#endregion
604
605
  //#region src/errors/UnavailableInServerSideError.ts
@@ -3589,6 +3590,26 @@ const deleteUser = async (client = getDefaultClient()) => {
3589
3590
  await logout(client);
3590
3591
  };
3591
3592
 
3593
+ //#endregion
3594
+ //#region src/modules/user/refreshUser/refreshUser.ts
3595
+ /**
3596
+ * Refreshes the current user's data from the server.
3597
+ *
3598
+ * This function fetches the latest authenticated user information from the backend
3599
+ * and updates the local user state.
3600
+ *
3601
+ * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
3602
+ * @returns A promise that resolves to the authenticated user.
3603
+ */
3604
+ const refreshUser = async (client = getDefaultClient()) => {
3605
+ const core = getCore(client);
3606
+ const previousState = { ...core.state.get() };
3607
+ const user = await createApiClient({ headers: { "x-dynamic-convert-user-to-json": "true" } }, client).getAuthenticatedUser({ environmentId: core.environmentId });
3608
+ core.state.set({ user });
3609
+ checkAndRaiseWalletAccountsChangedEvent({ previousState }, client);
3610
+ return user;
3611
+ };
3612
+
3592
3613
  //#endregion
3593
3614
  //#region src/modules/wallets/assertWalletAccountSigningAvailability/assertWalletAccountSigningAvailability.ts
3594
3615
  /**
@@ -4245,5 +4266,5 @@ const isIPad = (maxTouchPointsOverride) => {
4245
4266
  assertPackageVersion(name, version);
4246
4267
 
4247
4268
  //#endregion
4248
- export { BaseError, ClientAlreadyInitializedError, InvalidExternalAuthError, InvalidParamError, InvalidRedirectStorageStateError, LinkCredentialError, MFAAction, MfaInvalidOtpError, MfaRateLimitedError, MissingRedirectStorageStateError, MissingSocialUrlParamError, MissingUserVerificationError, NetworkSwitchingUnavailableError, NoAddressFoundError, NoNetworkProvidersError, NoPasskeyCredentialsFoundError, NoSmartWalletAccountSignerFoundError, NoWebAuthNSupportError, NotWaasWalletAccountError, SandboxMaximumThresholdReachedError, UnavailableInServerSideError, UnrecognizedNetworkError, UserNotAuthenticatedError, UserRejectedError, WalletAccountAlreadyVerifiedError, WalletAccountNotSelectedError, WalletAlreadyLinkedToAnotherUserError, WalletProviderMethodUnavailableError, acknowledgeRecoveryCodes, addCoinbaseOnrampOrderEventListener, assertWalletAccountSigningAvailability, assertWalletProviderMethodDefined, authenticateMfaRecoveryCode, authenticatePasskeyMFA, authenticateTotpMfaDevice, authenticateWithSocial, completeSocialAuthentication, connectAndVerifyWithWalletProvider, connectWithWalletProvider, consumeMfaToken, createCoinbaseOnrampOrder, createCryptoDotComPayment, createDynamicClient, createNewMfaRecoveryCodes, deleteMfaDevice, deletePasskey, deleteUser, detectOAuthRedirect, fetchProjectSettings, getActiveNetworkData, getActiveNetworkId, getAvailableWalletProvidersData, getBalance, getBalanceForAddress, getCoinbaseBuyUrl, getConnectedAddresses, getDefaultClient, getMfaDevices, getMfaMethods, getMfaRecoveryCodes, getMissingVerificationForCoinbaseOnrampOrder, getMultichainBalances, getNetworksData, getOwnerWalletAccountForSmartWalletAccount, getPasskeys, getPrimaryWalletAccount, getTransactionHistory, getUserSocialAccounts, getWalletAccountAddressByType, getWalletAccountFromAddress, getWalletAccounts, getWalletConnectCatalog, getWalletConnectCatalogWalletByWalletProviderKey, getWalletProviderDataByKey, hasExtension, initializeClient, isCaptchaRequired, isMfaRequiredForAction, isMobile, isPendingRecoveryCodesAcknowledgment, isProgrammaticNetworkSwitchAvailable, isSignedIn, isUserMissingMfaAuth, isWalletAccountVerified, logout, offEvent, offWalletProviderEvent, onEvent, onWalletProviderEvent, onceEvent, proveWalletAccountOwnership, refreshUser, registerPasskey, registerTotpMfaDevice, removeWalletAccount, selectPrimaryWalletAccount, sendEmailOTP, sendSmsOTP, setCaptchaToken, setDefaultMfaDevice, signInWithExternalJwt, signInWithPasskey, signMessage, switchActiveNetwork, transferWalletAccount, unlinkSocialAccount, updateUser, verifyOTP, verifyWalletAccount, waitForClientInitialized };
4269
+ export { BaseError, ClientAlreadyInitializedError, InvalidExternalAuthError, InvalidParamError, InvalidRedirectStorageStateError, LinkCredentialError, MFAAction, MfaInvalidOtpError, MfaRateLimitedError, MissingRedirectStorageStateError, MissingSocialUrlParamError, MissingUserVerificationError, NetworkSwitchingUnavailableError, NoAddressFoundError, NoNetworkProvidersError, NoPasskeyCredentialsFoundError, NoSmartWalletAccountSignerFoundError, NoWebAuthNSupportError, NotWaasWalletAccountError, SandboxMaximumThresholdReachedError, UnavailableInServerSideError, UnrecognizedNetworkError, UserNotAuthenticatedError, UserRejectedError, WalletAccountAlreadyVerifiedError, WalletAccountNotSelectedError, WalletAlreadyLinkedToAnotherUserError, WalletProviderMethodUnavailableError, acknowledgeRecoveryCodes, addCoinbaseOnrampOrderEventListener, assertWalletAccountSigningAvailability, assertWalletProviderMethodDefined, authenticateMfaRecoveryCode, authenticatePasskeyMFA, authenticateTotpMfaDevice, authenticateWithSocial, completeSocialAuthentication, connectAndVerifyWithWalletProvider, connectWithWalletProvider, consumeMfaToken, createCoinbaseOnrampOrder, createCryptoDotComPayment, createDynamicClient, createNewMfaRecoveryCodes, deleteMfaDevice, deletePasskey, deleteUser, detectOAuthRedirect, fetchProjectSettings, getActiveNetworkData, getActiveNetworkId, getAvailableWalletProvidersData, getBalance, getBalanceForAddress, getCoinbaseBuyUrl, getConnectedAddresses, getDefaultClient, getMfaDevices, getMfaMethods, getMfaRecoveryCodes, getMissingVerificationForCoinbaseOnrampOrder, getMultichainBalances, getNetworksData, getOwnerWalletAccountForSmartWalletAccount, getPasskeys, getPrimaryWalletAccount, getTransactionHistory, getUserSocialAccounts, getWalletAccountAddressByType, getWalletAccountFromAddress, getWalletAccounts, getWalletConnectCatalog, getWalletConnectCatalogWalletByWalletProviderKey, getWalletProviderDataByKey, hasExtension, initializeClient, isCaptchaRequired, isMfaRequiredForAction, isMobile, isPendingRecoveryCodesAcknowledgment, isProgrammaticNetworkSwitchAvailable, isSignedIn, isUserMissingMfaAuth, isWalletAccountVerified, logout, offEvent, offWalletProviderEvent, onEvent, onWalletProviderEvent, onceEvent, proveWalletAccountOwnership, refreshAuth, refreshUser, registerPasskey, registerTotpMfaDevice, removeWalletAccount, selectPrimaryWalletAccount, sendEmailOTP, sendSmsOTP, setCaptchaToken, setDefaultMfaDevice, signInWithExternalJwt, signInWithPasskey, signMessage, switchActiveNetwork, transferWalletAccount, unlinkSocialAccount, updateUser, verifyOTP, verifyWalletAccount, waitForClientInitialized };
4249
4270
  //# sourceMappingURL=index.esm.js.map