@dynamic-labs-sdk/client 0.24.1 → 0.25.1

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 (266) hide show
  1. package/android/build.gradle +71 -0
  2. package/android/src/main/java/xyz/dynamic/client/DynamicClientPackage.kt +42 -0
  3. package/android/src/main/java/xyz/dynamic/client/keychain/KeyStoreKeyManager.kt +147 -0
  4. package/android/src/main/java/xyz/dynamic/client/keychain/KeychainModule.kt +85 -0
  5. package/android/src/main/java/xyz/dynamic/client/manifest/ReactNativeManifestModule.kt +25 -0
  6. package/dist/InvalidParamError-BDHw6nr1.native.esm.js +1178 -0
  7. package/dist/InvalidParamError-BDHw6nr1.native.esm.js.map +1 -0
  8. package/dist/{InvalidParamError-9IR2C0up.cjs.js → InvalidParamError-BqDEZ6er.cjs.js} +5 -5
  9. package/dist/InvalidParamError-BqDEZ6er.cjs.js.map +1 -0
  10. package/dist/{InvalidParamError-Bq5zAFj4.esm.js → InvalidParamError-DcN56mC-.esm.js} +4 -4
  11. package/dist/InvalidParamError-DcN56mC-.esm.js.map +1 -0
  12. package/dist/NotWaasWalletAccountError-B_TYSgak.native.esm.js +50 -0
  13. package/dist/NotWaasWalletAccountError-B_TYSgak.native.esm.js.map +1 -0
  14. package/dist/{NotWaasWalletAccountError-CIJRq-EG.esm.js → NotWaasWalletAccountError-CQ7CMol4.esm.js} +3 -3
  15. package/dist/{NotWaasWalletAccountError-CIJRq-EG.esm.js.map → NotWaasWalletAccountError-CQ7CMol4.esm.js.map} +1 -1
  16. package/dist/{NotWaasWalletAccountError-DpRIY6Pd.cjs.js → NotWaasWalletAccountError-ftYfHk_N.cjs.js} +3 -3
  17. package/dist/{NotWaasWalletAccountError-DpRIY6Pd.cjs.js.map → NotWaasWalletAccountError-ftYfHk_N.cjs.js.map} +1 -1
  18. package/dist/client/core/createCore/createCore.d.ts.map +1 -1
  19. package/dist/client/core/types/DynamicCore.d.ts +4 -0
  20. package/dist/client/core/types/DynamicCore.d.ts.map +1 -1
  21. package/dist/client/types/DynamicClientConfig.d.ts +10 -0
  22. package/dist/client/types/DynamicClientConfig.d.ts.map +1 -1
  23. package/dist/core.cjs.js +36 -6
  24. package/dist/core.cjs.js.map +1 -1
  25. package/dist/core.esm.js +34 -6
  26. package/dist/core.esm.js.map +1 -1
  27. package/dist/core.native.esm.js +417 -0
  28. package/dist/core.native.esm.js.map +1 -0
  29. package/dist/errors/APIError/APIError.d.ts.map +1 -1
  30. package/dist/errors/InvalidParamError.d.ts.map +1 -1
  31. package/dist/errors/InvalidStorageValue.d.ts.map +1 -1
  32. package/dist/errors/InvalidWalletProviderKeyError.d.ts.map +1 -1
  33. package/dist/errors/MethodNotImplementedError.d.ts.map +1 -1
  34. package/dist/errors/MissingSocialUrlParamError.d.ts.map +1 -1
  35. package/dist/errors/NativeModuleNotLinkedError.d.ts +9 -0
  36. package/dist/errors/NativeModuleNotLinkedError.d.ts.map +1 -0
  37. package/dist/errors/NoSmartWalletAccountSignerFoundError.d.ts.map +1 -1
  38. package/dist/errors/ReactNativeOnlyError.d.ts +9 -0
  39. package/dist/errors/ReactNativeOnlyError.d.ts.map +1 -0
  40. package/dist/errors/UnavailableInServerSideError.d.ts.map +1 -1
  41. package/dist/errors/ValueMustBeDefinedError.d.ts.map +1 -1
  42. package/dist/errors/WalletAccountAlreadyVerifiedError.d.ts.map +1 -1
  43. package/dist/exports/core.d.ts +8 -2
  44. package/dist/exports/core.d.ts.map +1 -1
  45. package/dist/exports/index.d.ts +4 -4
  46. package/dist/exports/index.d.ts.map +1 -1
  47. package/dist/getNetworkProviderFromNetworkId-BRWuk0I8.native.esm.js +1557 -0
  48. package/dist/getNetworkProviderFromNetworkId-BRWuk0I8.native.esm.js.map +1 -0
  49. package/dist/{getNetworkProviderFromNetworkId-C4aba1hS.esm.js → getNetworkProviderFromNetworkId-COHxfpo-.esm.js} +275 -48
  50. package/dist/getNetworkProviderFromNetworkId-COHxfpo-.esm.js.map +1 -0
  51. package/dist/{getNetworkProviderFromNetworkId-COxYamJy.cjs.js → getNetworkProviderFromNetworkId-ClfETwqS.cjs.js} +304 -53
  52. package/dist/getNetworkProviderFromNetworkId-ClfETwqS.cjs.js.map +1 -0
  53. package/dist/{getSignedSessionId-_vjv5TNw.esm.js → getSignedSessionId-B6ry-rvs.esm.js} +3 -3
  54. package/dist/{getSignedSessionId-_vjv5TNw.esm.js.map → getSignedSessionId-B6ry-rvs.esm.js.map} +1 -1
  55. package/dist/{getSignedSessionId-D7uV3dw0.cjs.js → getSignedSessionId-Bkw9TATj.cjs.js} +3 -3
  56. package/dist/{getSignedSessionId-D7uV3dw0.cjs.js.map → getSignedSessionId-Bkw9TATj.cjs.js.map} +1 -1
  57. package/dist/getSignedSessionId-C58DvQAd.native.esm.js +67 -0
  58. package/dist/getSignedSessionId-C58DvQAd.native.esm.js.map +1 -0
  59. package/dist/{getVerifiedCredentialForWalletAccount-Df_wN20i.cjs.js → getVerifiedCredentialForWalletAccount-DEiU9FZG.cjs.js} +11 -10
  60. package/dist/getVerifiedCredentialForWalletAccount-DEiU9FZG.cjs.js.map +1 -0
  61. package/dist/{getVerifiedCredentialForWalletAccount-Y-aJ2rY7.esm.js → getVerifiedCredentialForWalletAccount-DP4VQBly.esm.js} +10 -9
  62. package/dist/getVerifiedCredentialForWalletAccount-DP4VQBly.esm.js.map +1 -0
  63. package/dist/getVerifiedCredentialForWalletAccount-d_bHvLLE.native.esm.js +784 -0
  64. package/dist/getVerifiedCredentialForWalletAccount-d_bHvLLE.native.esm.js.map +1 -0
  65. package/dist/index.cjs.js +143 -320
  66. package/dist/index.cjs.js.map +1 -1
  67. package/dist/index.esm.js +139 -316
  68. package/dist/index.esm.js.map +1 -1
  69. package/dist/index.native.esm.js +6799 -0
  70. package/dist/index.native.esm.js.map +1 -0
  71. package/dist/isMfaRequiredForAction-Cjbuyen3.native.esm.js +89 -0
  72. package/dist/isMfaRequiredForAction-Cjbuyen3.native.esm.js.map +1 -0
  73. package/dist/{isMfaRequiredForAction-Cc6jkbY5.esm.js → isMfaRequiredForAction-D8GPFYzv.esm.js} +2 -2
  74. package/dist/{isMfaRequiredForAction-Cc6jkbY5.esm.js.map → isMfaRequiredForAction-D8GPFYzv.esm.js.map} +1 -1
  75. package/dist/{isMfaRequiredForAction-cfGmMd_g.cjs.js → isMfaRequiredForAction-mZub0YwI.cjs.js} +2 -2
  76. package/dist/{isMfaRequiredForAction-cfGmMd_g.cjs.js.map → isMfaRequiredForAction-mZub0YwI.cjs.js.map} +1 -1
  77. package/dist/modules/auth/decodeJwt/decodeJwt.d.ts.map +1 -1
  78. package/dist/modules/auth/externalAuth/requestExternalAuthElevatedToken/requestExternalAuthElevatedToken.d.ts.map +1 -1
  79. package/dist/modules/auth/externalAuth/signInWithExternalJwt/signInWithExternalJwt.d.ts +0 -1
  80. package/dist/modules/auth/externalAuth/signInWithExternalJwt/signInWithExternalJwt.d.ts.map +1 -1
  81. package/dist/modules/auth/extractSessionId/extractSessionId.d.ts.map +1 -1
  82. package/dist/modules/auth/initializeAuth/initializeAuth.d.ts +1 -1
  83. package/dist/modules/auth/initializeAuth/setLongTimeout/setLongTimeout.d.ts +8 -2
  84. package/dist/modules/auth/initializeAuth/setLongTimeout/setLongTimeout.d.ts.map +1 -1
  85. package/dist/modules/auth/logout/logout.d.ts +1 -1
  86. package/dist/modules/auth/logout/logout.d.ts.map +1 -1
  87. package/dist/modules/auth/logoutReason.d.ts +4 -7
  88. package/dist/modules/auth/logoutReason.d.ts.map +1 -1
  89. package/dist/modules/auth/logoutWithReason/index.d.ts +2 -0
  90. package/dist/modules/auth/logoutWithReason/index.d.ts.map +1 -0
  91. package/dist/modules/auth/logoutWithReason/logoutWithReason.d.ts +24 -0
  92. package/dist/modules/auth/logoutWithReason/logoutWithReason.d.ts.map +1 -0
  93. package/dist/modules/auth/social/oauth/authenticateWithSocial/buildOAuthUrl/addOAuthUrlParams/addOAuthUrlParams.d.ts +7 -4
  94. package/dist/modules/auth/social/oauth/authenticateWithSocial/buildOAuthUrl/addOAuthUrlParams/addOAuthUrlParams.d.ts.map +1 -1
  95. package/dist/modules/auth/social/oauth/authenticateWithSocial/buildOAuthUrl/buildOAuthUrl.d.ts.map +1 -1
  96. package/dist/modules/auth/social/removeDynamicOauthParamsFromUrl/removeDynamicOauthParamsFromUrl.d.ts.map +1 -1
  97. package/dist/modules/auth/updateAuthFromVerifyResponse/elevatedAccessTokens/normalizeScopes/normalizeScopes.d.ts.map +1 -1
  98. package/dist/modules/auth/updateAuthFromVerifyResponse/elevatedAccessTokens/parseElevatedAccessToken/parseElevatedAccessToken.d.ts +6 -4
  99. package/dist/modules/auth/updateAuthFromVerifyResponse/elevatedAccessTokens/parseElevatedAccessToken/parseElevatedAccessToken.d.ts.map +1 -1
  100. package/dist/modules/auth/updateAuthFromVerifyResponse/updateAuthFromVerifyResponse.d.ts.map +1 -1
  101. package/dist/modules/checkout/attachCheckoutTransactionSource/attachCheckoutTransactionSource.d.ts +34 -6
  102. package/dist/modules/checkout/attachCheckoutTransactionSource/attachCheckoutTransactionSource.d.ts.map +1 -1
  103. package/dist/modules/checkout/broadcastCheckoutTransaction/broadcastCheckoutTransaction.d.ts +11 -3
  104. package/dist/modules/checkout/broadcastCheckoutTransaction/broadcastCheckoutTransaction.d.ts.map +1 -1
  105. package/dist/modules/checkout/checkout.types.d.ts +1 -0
  106. package/dist/modules/checkout/checkout.types.d.ts.map +1 -1
  107. package/dist/modules/checkout/trackCheckoutTransaction/trackCheckoutTransaction.d.ts +7 -3
  108. package/dist/modules/checkout/trackCheckoutTransaction/trackCheckoutTransaction.d.ts.map +1 -1
  109. package/dist/modules/checkout/utils/createCheckoutSessionTokenStorageKey/createCheckoutSessionTokenStorageKey.d.ts.map +1 -1
  110. package/dist/modules/checkout/utils/subscribeToCheckoutTransaction/subscribeToCheckoutTransaction.d.ts.map +1 -1
  111. package/dist/modules/initializeClient/initializeClient.d.ts.map +1 -1
  112. package/dist/modules/instrumentation/setInstrumentationEnabled/setInstrumentationEnabled.d.ts +6 -2
  113. package/dist/modules/instrumentation/setInstrumentationEnabled/setInstrumentationEnabled.d.ts.map +1 -1
  114. package/dist/modules/keychainMigration/migrateSessionKeyToKeychain/KeyMigrationError.d.ts.map +1 -1
  115. package/dist/modules/legacyWalletBook/getWalletConnectCatalog/shouldFilterWallet/shouldFilterWallet.d.ts +9 -5
  116. package/dist/modules/legacyWalletBook/getWalletConnectCatalog/shouldFilterWallet/shouldFilterWallet.d.ts.map +1 -1
  117. package/dist/modules/otp/sendEmailOTP/sendEmailOTP.d.ts +0 -1
  118. package/dist/modules/otp/sendEmailOTP/sendEmailOTP.d.ts.map +1 -1
  119. package/dist/modules/otp/sendSmsOTP/sendSmsOTP.d.ts +0 -1
  120. package/dist/modules/otp/sendSmsOTP/sendSmsOTP.d.ts.map +1 -1
  121. package/dist/modules/storageSync/schema.d.ts.map +1 -1
  122. package/dist/modules/user/deleteUser/deleteUser.d.ts +1 -1
  123. package/dist/modules/user/updateUser/updateUser.d.ts +0 -1
  124. package/dist/modules/user/updateUser/updateUser.d.ts.map +1 -1
  125. package/dist/modules/waas/createWaasClient/createWaasClient.d.ts.map +1 -1
  126. package/dist/modules/waas/createWaasProvider/createWaasProvider.d.ts.map +1 -1
  127. package/dist/modules/waas/getWaasChainNameFromChain/getWaasChainNameFromChain.d.ts.map +1 -1
  128. package/dist/modules/wallets/networks/createBaseNetworkProvider/createBaseNetworkProvider.d.ts.map +1 -1
  129. package/dist/modules/wallets/networks/getSdkChainFromApiChainName/getSdkChainFromApiChainName.d.ts.map +1 -1
  130. package/dist/modules/wallets/utils/assertWalletProviderMethodDefined/assertWalletProviderMethodDefined.d.ts.map +1 -1
  131. package/dist/modules/wallets/utils/getAllProvidersFromWindow/getAllProvidersFromWindow.d.ts.map +1 -1
  132. package/dist/modules/wallets/utils/getInjectedProviderFromWindow/getInjectedProviderFromWindow.d.ts.map +1 -1
  133. package/dist/modules/wallets/utils/isSameAddress/isSameAddress.d.ts +9 -1
  134. package/dist/modules/wallets/utils/isSameAddress/isSameAddress.d.ts.map +1 -1
  135. package/dist/modules/wallets/utils/normalizeAddress/normalizeAddress.d.ts +7 -1
  136. package/dist/modules/wallets/utils/normalizeAddress/normalizeAddress.d.ts.map +1 -1
  137. package/dist/modules/wallets/verifyWalletAccountForSignInOrTransfer/verifyWalletAccountForSignInOrTransfer.d.ts.map +1 -1
  138. package/dist/modules/wallets/walletProvider/splitWalletProviderKey/splitWalletProviderKey.d.ts.map +1 -1
  139. package/dist/services/instrumentation/createInstrumentation/createInstrumentation.d.ts.map +1 -1
  140. package/dist/services/instrumentation/instrumentFunction/extractParams/extractParams.d.ts.map +1 -1
  141. package/dist/services/keychain/createKeychainService/ImportKeyNotSupportedError.d.ts +5 -0
  142. package/dist/services/keychain/createKeychainService/ImportKeyNotSupportedError.d.ts.map +1 -0
  143. package/dist/services/keychain/createKeychainService/KeyNotFoundError.d.ts.map +1 -0
  144. package/dist/services/keychain/createKeychainService/createKeychainService.d.ts +4 -0
  145. package/dist/services/keychain/createKeychainService/createKeychainService.d.ts.map +1 -0
  146. package/dist/services/keychain/createKeychainService/createKeychainService.types.d.ts +11 -0
  147. package/dist/services/keychain/createKeychainService/createKeychainService.types.d.ts.map +1 -0
  148. package/dist/services/keychain/createKeychainService/index.d.ts +2 -0
  149. package/dist/services/keychain/createKeychainService/index.d.ts.map +1 -0
  150. package/dist/services/keychain/createKeychainService/utils/constants.d.ts.map +1 -0
  151. package/dist/services/keychain/createKeychainService/utils/deleteIndexedDBItem.d.ts +9 -0
  152. package/dist/services/keychain/createKeychainService/utils/deleteIndexedDBItem.d.ts.map +1 -0
  153. package/dist/services/keychain/createKeychainService/utils/getIndexedDBItem.d.ts +10 -0
  154. package/dist/services/keychain/createKeychainService/utils/getIndexedDBItem.d.ts.map +1 -0
  155. package/dist/services/keychain/createKeychainService/utils/openDatabase.d.ts.map +1 -0
  156. package/dist/services/keychain/createKeychainService/utils/setIndexedDBItem.d.ts +10 -0
  157. package/dist/services/keychain/createKeychainService/utils/setIndexedDBItem.d.ts.map +1 -0
  158. package/dist/services/keychain/createKeychainService/utils/withDatabase/index.d.ts.map +1 -0
  159. package/dist/services/keychain/createKeychainService/utils/withDatabase/withDatabase.d.ts.map +1 -0
  160. package/dist/services/keychain/index.d.ts +1 -1
  161. package/dist/services/keychain/index.d.ts.map +1 -1
  162. package/dist/services/logger/createLogger/createLogger.d.ts.map +1 -1
  163. package/dist/services/nativeManifest/getReactNativeManifest/getReactNativeManifest.d.ts +11 -0
  164. package/dist/services/nativeManifest/getReactNativeManifest/getReactNativeManifest.d.ts.map +1 -0
  165. package/dist/services/nativeManifest/getReactNativeManifest/index.d.ts +2 -0
  166. package/dist/services/nativeManifest/getReactNativeManifest/index.d.ts.map +1 -0
  167. package/dist/services/nativeManifest/nativeManifest.types.d.ts +14 -0
  168. package/dist/services/nativeManifest/nativeManifest.types.d.ts.map +1 -0
  169. package/dist/services/realtime/createRealtimeService/createRealtimeService.d.ts.map +1 -1
  170. package/dist/services/realtime/realtime.types.d.ts +1 -0
  171. package/dist/services/realtime/realtime.types.d.ts.map +1 -1
  172. package/dist/services/runtimeServices/createRuntimeServiceAccessKey/createRuntimeServiceAccessKey.d.ts.map +1 -1
  173. package/dist/services/runtimeServices/createRuntimeServices/createRuntimeServices.d.ts.map +1 -1
  174. package/dist/services/storage/createLocalStorageAdapter/createLocalStorageAdapter.d.ts +2 -2
  175. package/dist/services/storage/createStorage/createStorage.d.ts +4 -2
  176. package/dist/services/storage/createStorage/createStorage.d.ts.map +1 -1
  177. package/dist/services/storage/createStorage/formatForStorage/isValidDateISOString/isValidDateISOString.d.ts.map +1 -1
  178. package/dist/services/storage/createStorageKeySchema/createStorageKeySchema.d.ts +2 -1
  179. package/dist/services/storage/createStorageKeySchema/createStorageKeySchema.d.ts.map +1 -1
  180. package/dist/services/storage/index.d.ts +1 -1
  181. package/dist/services/storage/index.d.ts.map +1 -1
  182. package/dist/services/storage/storage.types.d.ts +27 -3
  183. package/dist/services/storage/storage.types.d.ts.map +1 -1
  184. package/dist/tsconfig.lib.tsbuildinfo +1 -1
  185. package/dist/utils/assertDefined/assertDefined.d.ts.map +1 -1
  186. package/dist/utils/base64UrlDecode/base64UrlDecode.d.ts.map +1 -1
  187. package/dist/utils/base64urlFromBytes/base64urlFromBytes.d.ts +8 -0
  188. package/dist/utils/base64urlFromBytes/base64urlFromBytes.d.ts.map +1 -0
  189. package/dist/utils/base64urlFromBytes/index.d.ts +2 -0
  190. package/dist/utils/base64urlFromBytes/index.d.ts.map +1 -0
  191. package/dist/utils/bytesFromBase64url/bytesFromBase64url.d.ts +8 -0
  192. package/dist/utils/bytesFromBase64url/bytesFromBase64url.d.ts.map +1 -0
  193. package/dist/utils/bytesFromBase64url/index.d.ts +2 -0
  194. package/dist/utils/bytesFromBase64url/index.d.ts.map +1 -0
  195. package/dist/utils/derToP1363/InvalidDERSignatureError.d.ts +5 -0
  196. package/dist/utils/derToP1363/InvalidDERSignatureError.d.ts.map +1 -0
  197. package/dist/utils/derToP1363/derToP1363.d.ts +8 -0
  198. package/dist/utils/derToP1363/derToP1363.d.ts.map +1 -0
  199. package/dist/utils/derToP1363/index.d.ts +2 -0
  200. package/dist/utils/derToP1363/index.d.ts.map +1 -0
  201. package/dist/utils/digestSHA256/digestSHA256.d.ts.map +1 -1
  202. package/dist/utils/getChainFromVerifiedCredentialChain/getChainFromVerifiedCredentialChain.d.ts.map +1 -1
  203. package/dist/utils/isEqualShallow/isEqualShallow.d.ts.map +1 -1
  204. package/dist/utils/isErrorWithCode/isErrorWithCode.d.ts.map +1 -1
  205. package/dist/utils/isMobile/isMobile.d.ts.map +1 -1
  206. package/dist/utils/observable/createObservableState/createObservableState.d.ts.map +1 -1
  207. package/dist/utils/observable/subscribeWithSelector/subscribeWithSelector.d.ts.map +1 -1
  208. package/dist/utils/randomString/randomString.d.ts +1 -1
  209. package/dist/utils/randomString/randomString.d.ts.map +1 -1
  210. package/dist/utils/retryOnFail/InvalidRetryOnFailCallError.d.ts.map +1 -1
  211. package/dist/utils/setCookie/setCookie.d.ts.map +1 -1
  212. package/dist/waas.cjs.js +4 -4
  213. package/dist/waas.esm.js +3 -3
  214. package/dist/waas.native.esm.js +506 -0
  215. package/dist/waas.native.esm.js.map +1 -0
  216. package/dist/waasCore.cjs.js +7 -5
  217. package/dist/waasCore.cjs.js.map +1 -1
  218. package/dist/waasCore.esm.js +6 -4
  219. package/dist/waasCore.esm.js.map +1 -1
  220. package/dist/waasCore.native.esm.js +253 -0
  221. package/dist/waasCore.native.esm.js.map +1 -0
  222. package/dynamic-labs-sdk-client.podspec +27 -0
  223. package/ios/Keychain.h +4 -0
  224. package/ios/Keychain.mm +101 -0
  225. package/ios/ReactNativeManifest.h +4 -0
  226. package/ios/ReactNativeManifest.mm +45 -0
  227. package/ios/ReactNativeManifestImpl.swift +20 -0
  228. package/ios/SecureEnclaveKeyManager.swift +180 -0
  229. package/package.json +40 -6
  230. package/react-native.config.cjs +14 -0
  231. package/dist/InvalidParamError-9IR2C0up.cjs.js.map +0 -1
  232. package/dist/InvalidParamError-Bq5zAFj4.esm.js.map +0 -1
  233. package/dist/getNetworkProviderFromNetworkId-C4aba1hS.esm.js.map +0 -1
  234. package/dist/getNetworkProviderFromNetworkId-COxYamJy.cjs.js.map +0 -1
  235. package/dist/getVerifiedCredentialForWalletAccount-Df_wN20i.cjs.js.map +0 -1
  236. package/dist/getVerifiedCredentialForWalletAccount-Y-aJ2rY7.esm.js.map +0 -1
  237. package/dist/modules/auth/handleSessionExpiration/handleSessionExpiration.d.ts +0 -11
  238. package/dist/modules/auth/handleSessionExpiration/handleSessionExpiration.d.ts.map +0 -1
  239. package/dist/modules/auth/handleSessionExpiration/index.d.ts +0 -2
  240. package/dist/modules/auth/handleSessionExpiration/index.d.ts.map +0 -1
  241. package/dist/modules/auth/performLogout/index.d.ts +0 -2
  242. package/dist/modules/auth/performLogout/index.d.ts.map +0 -1
  243. package/dist/modules/auth/performLogout/performLogout.d.ts +0 -12
  244. package/dist/modules/auth/performLogout/performLogout.d.ts.map +0 -1
  245. package/dist/services/keychain/createIndexedDBKeychainService/KeyNotFoundError.d.ts.map +0 -1
  246. package/dist/services/keychain/createIndexedDBKeychainService/createIndexedDBKeychainService.d.ts +0 -8
  247. package/dist/services/keychain/createIndexedDBKeychainService/createIndexedDBKeychainService.d.ts.map +0 -1
  248. package/dist/services/keychain/createIndexedDBKeychainService/createIndexedDBKeychainService.types.d.ts +0 -6
  249. package/dist/services/keychain/createIndexedDBKeychainService/createIndexedDBKeychainService.types.d.ts.map +0 -1
  250. package/dist/services/keychain/createIndexedDBKeychainService/index.d.ts +0 -2
  251. package/dist/services/keychain/createIndexedDBKeychainService/index.d.ts.map +0 -1
  252. package/dist/services/keychain/createIndexedDBKeychainService/utils/constants.d.ts.map +0 -1
  253. package/dist/services/keychain/createIndexedDBKeychainService/utils/deleteIndexedDBItem.d.ts +0 -3
  254. package/dist/services/keychain/createIndexedDBKeychainService/utils/deleteIndexedDBItem.d.ts.map +0 -1
  255. package/dist/services/keychain/createIndexedDBKeychainService/utils/getIndexedDBItem.d.ts +0 -4
  256. package/dist/services/keychain/createIndexedDBKeychainService/utils/getIndexedDBItem.d.ts.map +0 -1
  257. package/dist/services/keychain/createIndexedDBKeychainService/utils/openDatabase.d.ts.map +0 -1
  258. package/dist/services/keychain/createIndexedDBKeychainService/utils/setIndexedDBItem.d.ts +0 -4
  259. package/dist/services/keychain/createIndexedDBKeychainService/utils/setIndexedDBItem.d.ts.map +0 -1
  260. package/dist/services/keychain/createIndexedDBKeychainService/utils/withDatabase/index.d.ts.map +0 -1
  261. package/dist/services/keychain/createIndexedDBKeychainService/utils/withDatabase/withDatabase.d.ts.map +0 -1
  262. /package/dist/services/keychain/{createIndexedDBKeychainService → createKeychainService}/KeyNotFoundError.d.ts +0 -0
  263. /package/dist/services/keychain/{createIndexedDBKeychainService → createKeychainService}/utils/constants.d.ts +0 -0
  264. /package/dist/services/keychain/{createIndexedDBKeychainService → createKeychainService}/utils/openDatabase.d.ts +0 -0
  265. /package/dist/services/keychain/{createIndexedDBKeychainService → createKeychainService}/utils/withDatabase/index.d.ts +0 -0
  266. /package/dist/services/keychain/{createIndexedDBKeychainService → createKeychainService}/utils/withDatabase/withDatabase.d.ts +0 -0
@@ -0,0 +1,784 @@
1
+ import { F as getDefaultClient, O as isCookieEnabled, R as BaseError, i as DYNAMIC_WAAS_METADATA, k as assertDefined, s as __getChainFromVerifiedCredentialChain_wrapped, t as InvalidParamError, w as instrumentFunction, z as getCore } from "./InvalidParamError-BDHw6nr1.native.esm.js";
2
+ import { JwtVerifiedCredentialFormatEnum, WalletProviderEnum } from "@dynamic-labs/sdk-api-core";
3
+
4
+ //#region src/utils/setCookie/setCookie.ts
5
+ /**
6
+ * Sefelly sets the cookie in the browser.
7
+ * @not-instrumented
8
+ */
9
+ const setCookie = (cookie) => {
10
+ document.cookie = cookie;
11
+ };
12
+
13
+ //#endregion
14
+ //#region src/modules/clientEvents/clientEvents.ts
15
+ /**
16
+ * Adds an event listener for Dynamic client events.
17
+ *
18
+ * This function allows you to listen for various events emitted by the Dynamic client,
19
+ * such as authentication state changes, wallet connections, and more.
20
+ *
21
+ * @param params.event - The event name to listen for.
22
+ * @param params.listener - The callback function to execute when the event is fired.
23
+ * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
24
+ * @returns A function that can be called to remove the listener.
25
+ * @instrumented
26
+ */
27
+ const onEvent = ({ event, listener }, client = getDefaultClient()) => {
28
+ const { eventEmitter } = getCore(client);
29
+ eventEmitter.on(event, listener);
30
+ return () => {
31
+ eventEmitter.off(event, listener);
32
+ };
33
+ };
34
+ /**
35
+ * Removes an event listener from Dynamic client events.
36
+ *
37
+ * This function unsubscribes a previously registered event listener
38
+ * from the specified Dynamic client event.
39
+ *
40
+ * @param params.event - The event name to remove the listener from.
41
+ * @param params.listener - The callback function to remove.
42
+ * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
43
+ * @instrumented
44
+ */
45
+ const offEvent = ({ event, listener }, client = getDefaultClient()) => {
46
+ const { eventEmitter } = getCore(client);
47
+ eventEmitter.off(event, listener);
48
+ };
49
+ /**
50
+ * Adds a one-time event listener for Dynamic client events.
51
+ *
52
+ * This function listens for an event that will automatically remove itself
53
+ * after being triggered once.
54
+ *
55
+ * @param params.event - The event name to listen for.
56
+ * @param params.listener - The callback function to execute when the event is fired.
57
+ * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
58
+ * @returns A function that can be called to remove the listener before it fires.
59
+ * @instrumented
60
+ */
61
+ const onceEvent = ({ event, listener }, client = getDefaultClient()) => {
62
+ const { eventEmitter } = getCore(client);
63
+ eventEmitter.once(event, listener);
64
+ return () => {
65
+ eventEmitter.off(event, listener);
66
+ };
67
+ };
68
+ /**
69
+ * Emits a Dynamic client event.
70
+ *
71
+ * This function triggers an event that will be received by all registered
72
+ * listeners for the specified event type.
73
+ *
74
+ * @param params.event - The event name to emit.
75
+ * @param params.args - The arguments to pass to event listeners.
76
+ * @param client - The Dynamic client instance.
77
+ * @not-instrumented
78
+ */
79
+ const emitEvent = ({ event, args }, client) => {
80
+ const { eventEmitter } = getCore(client);
81
+ eventEmitter.emit(event, args);
82
+ };
83
+ const __onEvent_impl = onEvent;
84
+ const __onEvent_wrapped = instrumentFunction({
85
+ fn: __onEvent_impl,
86
+ functionName: "onEvent",
87
+ getCore: () => {
88
+ try {
89
+ return getCore(getDefaultClient());
90
+ } catch {
91
+ return;
92
+ }
93
+ }
94
+ });
95
+ const __offEvent_impl = offEvent;
96
+ const __offEvent_wrapped = instrumentFunction({
97
+ fn: __offEvent_impl,
98
+ functionName: "offEvent",
99
+ getCore: () => {
100
+ try {
101
+ return getCore(getDefaultClient());
102
+ } catch {
103
+ return;
104
+ }
105
+ }
106
+ });
107
+ const __onceEvent_impl = onceEvent;
108
+ const __onceEvent_wrapped = instrumentFunction({
109
+ fn: __onceEvent_impl,
110
+ functionName: "onceEvent",
111
+ getCore: () => {
112
+ try {
113
+ return getCore(getDefaultClient());
114
+ } catch {
115
+ return;
116
+ }
117
+ }
118
+ });
119
+
120
+ //#endregion
121
+ //#region src/errors/InvalidWalletProviderKeyError.ts
122
+ var InvalidWalletProviderKeyError = class extends BaseError {
123
+ constructor(value) {
124
+ super({
125
+ cause: null,
126
+ code: "invalid_wallet_provider_key",
127
+ docsUrl: null,
128
+ name: "InvalidWalletProviderKeyError",
129
+ shortMessage: `Invalid wallet provider key: ${value}. Key must be in the format of <normalizedWalletNameWithChain>:<walletProviderType>[:<suffix>]`
130
+ });
131
+ }
132
+ };
133
+
134
+ //#endregion
135
+ //#region src/modules/wallets/walletProvider/splitWalletProviderKey/splitWalletProviderKey.ts
136
+ /** @not-instrumented */
137
+ const splitWalletProviderKey = (walletProviderKey) => {
138
+ const [normalizedWalletNameWithChain, walletProviderType, suffix, ...rest] = walletProviderKey.split(":");
139
+ if (!normalizedWalletNameWithChain || !Object.values(WalletProviderEnum).includes(walletProviderType) || rest.length > 0) throw new InvalidWalletProviderKeyError(walletProviderKey);
140
+ return {
141
+ normalizedWalletNameWithChain,
142
+ suffix,
143
+ walletProviderType
144
+ };
145
+ };
146
+
147
+ //#endregion
148
+ //#region src/modules/wallets/utils/normalizeAddress/normalizeAddress.ts
149
+ /** @not-instrumented */
150
+ const normalizeAddress = ({ address, chain }) => {
151
+ let normalizedAddress = address;
152
+ if (normalizedAddress?.startsWith("0x")) normalizedAddress = normalizedAddress.slice(2);
153
+ normalizedAddress = ["EVM", "FLOW"].includes(chain) ? normalizedAddress?.toLowerCase() : normalizedAddress;
154
+ return normalizedAddress;
155
+ };
156
+
157
+ //#endregion
158
+ //#region src/modules/wallets/utils/formatWalletAccountId/formatWalletAccountId.ts
159
+ /** @not-instrumented */
160
+ const formatWalletAccountId = ({ address, chain, walletProviderKey }) => {
161
+ const { normalizedWalletNameWithChain } = splitWalletProviderKey(walletProviderKey);
162
+ return `${normalizedWalletNameWithChain}:${normalizeAddress({
163
+ address,
164
+ chain
165
+ })}`;
166
+ };
167
+
168
+ //#endregion
169
+ //#region src/modules/wallets/utils/convertUnverifiedWalletAccountToWalletAccount/convertUnverifiedWalletAccountToWalletAccount.ts
170
+ /** @not-instrumented */
171
+ const convertUnverifiedWalletAccountToWalletAccount = ({ unverifiedWalletAccount }) => ({
172
+ address: unverifiedWalletAccount.address,
173
+ addressesWithTypes: unverifiedWalletAccount.addressesWithTypes,
174
+ chain: unverifiedWalletAccount.chain,
175
+ id: formatWalletAccountId({
176
+ address: unverifiedWalletAccount.address,
177
+ chain: unverifiedWalletAccount.chain,
178
+ walletProviderKey: unverifiedWalletAccount.walletProviderKey
179
+ }),
180
+ lastSelectedAt: unverifiedWalletAccount.lastSelectedAt,
181
+ verifiedCredentialId: null,
182
+ walletProviderKey: unverifiedWalletAccount.walletProviderKey
183
+ });
184
+
185
+ //#endregion
186
+ //#region src/modules/wallets/utils/normalizeWalletNameWithChain/normalizeWalletNameWithChain.ts
187
+ /**
188
+ * Format the raw wallet name and chain to get the value we can use for
189
+ * verified credentials' `walletName` field.
190
+ * @not-instrumented
191
+ */
192
+ const normalizeWalletNameWithChain = ({ displayName, chain }) => {
193
+ const sanitizedWalletName = displayName.replace(/[^a-zA-Z0-9]/g, "").toLowerCase();
194
+ const chainLowered = chain.toLocaleLowerCase();
195
+ if (sanitizedWalletName.endsWith(chainLowered)) return sanitizedWalletName;
196
+ return `${sanitizedWalletName}${chainLowered}`;
197
+ };
198
+
199
+ //#endregion
200
+ //#region src/modules/wallets/utils/formatWalletProviderKey/formatWalletProviderKey.ts
201
+ /**
202
+ * Assembles the wallet provider key from the wallet name, chain, and wallet provider type.
203
+ *
204
+ * The suffix is optional and can be used to add a uniquely identifying string to the key, which
205
+ * might be necessary for some wallet providers (like Wallet Connect).
206
+ *
207
+ * IMPORTANT: Do NOT add a suffix unless absolutely necessary, as it will cause the wallet account
208
+ * to not be able to find its wallet provider when connecting to a new device (it won't be possible
209
+ * to determine the full key just from the Verified Credential data).
210
+ * @not-instrumented
211
+ */
212
+ const formatWalletProviderKey = ({ suffix, chain, displayName, walletProviderType }) => {
213
+ return `${normalizeWalletNameWithChain({
214
+ chain,
215
+ displayName
216
+ })}:${walletProviderType}${suffix ? `:${suffix}` : ""}`;
217
+ };
218
+
219
+ //#endregion
220
+ //#region src/modules/wallets/walletProvider/walletProviderKeyMap/getWalletProviderKeyFromVerifiedCredential/getWalletProviderKeyFromVerifiedCredential.ts
221
+ /** @not-instrumented */
222
+ const getWalletProviderKeyFromVerifiedCredential = ({ verifiedCredential }, client) => {
223
+ const { walletProviderKeyMap } = getCore(client).state.get();
224
+ const storedWalletProviderKey = walletProviderKeyMap[verifiedCredential.id];
225
+ if (storedWalletProviderKey) return { walletProviderKey: storedWalletProviderKey };
226
+ /**
227
+ * We fallback to comprising the wallet provider key from walletName and walletProvider.
228
+ *
229
+ * Some wallet provider types (like Wallet Connect) also use a special suffix for their wallet provider
230
+ * keys, so this won't be enough for them.
231
+ * Therefore, for those specific wallet providers, the wallet account will remain without a wallet provider
232
+ * and will require reconnection.
233
+ * Read walletProvider.types.ts for more info.
234
+ */
235
+ assertDefined(verifiedCredential.walletName, `Failed to get wallet provider for verified credential with ID ${verifiedCredential.id}: missing walletName`);
236
+ assertDefined(verifiedCredential.walletProvider, `Failed to get wallet provider for verified credential with ID ${verifiedCredential.id}: missing walletProvider`);
237
+ assertDefined(verifiedCredential.chain, `Failed to get wallet provider for verified credential with ID ${verifiedCredential.id}: missing chain`);
238
+ return { walletProviderKey: formatWalletProviderKey({
239
+ chain: __getChainFromVerifiedCredentialChain_wrapped(verifiedCredential.chain),
240
+ displayName: verifiedCredential.walletName,
241
+ walletProviderType: verifiedCredential.walletProvider
242
+ }) };
243
+ };
244
+
245
+ //#endregion
246
+ //#region src/modules/wallets/utils/convertVerifiedCredentialToWalletAccount/convertVerifiedCredentialToWalletAccount.ts
247
+ /** @not-instrumented */
248
+ const convertVerifiedCredentialToWalletAccount = ({ verifiedCredential }, client) => {
249
+ assertDefined(verifiedCredential.address, "Missing address in verified credential");
250
+ assertDefined(verifiedCredential.chain, "Missing chain in verified credential");
251
+ const chain = __getChainFromVerifiedCredentialChain_wrapped(verifiedCredential.chain);
252
+ const { walletProviderKey } = getWalletProviderKeyFromVerifiedCredential({ verifiedCredential }, client);
253
+ const walletAccountId = formatWalletAccountId({
254
+ address: verifiedCredential.address,
255
+ chain,
256
+ walletProviderKey
257
+ });
258
+ return {
259
+ address: verifiedCredential.address,
260
+ addressesWithTypes: verifiedCredential.walletAdditionalAddresses,
261
+ chain,
262
+ hardwareWalletVendor: verifiedCredential.walletProperties?.hardwareWallet,
263
+ id: walletAccountId,
264
+ lastSelectedAt: verifiedCredential.lastSelectedAt ?? null,
265
+ verifiedCredentialId: verifiedCredential.id,
266
+ walletProviderKey
267
+ };
268
+ };
269
+
270
+ //#endregion
271
+ //#region src/modules/wallets/getWalletAccounts/getWalletAccountsFromState/getWalletAccountsFromState.ts
272
+ /** @not-instrumented */
273
+ const getWalletAccountsFromState = ({ unverifiedWalletAccounts, user }, client) => {
274
+ const walletAccountsMap = /* @__PURE__ */ new Map();
275
+ /**
276
+ * Handle the unverified wallet accounts before the user verified credentials
277
+ * so the later verified wallet accounts can override the unverified wallet accounts
278
+ */
279
+ unverifiedWalletAccounts.forEach((unverifiedWalletAccount) => {
280
+ const walletAccount = convertUnverifiedWalletAccountToWalletAccount({ unverifiedWalletAccount });
281
+ walletAccountsMap.set(walletAccount.id, walletAccount);
282
+ });
283
+ (user?.verifiedCredentials ?? []).filter((verified) => verified.format === JwtVerifiedCredentialFormatEnum.Blockchain).forEach((verifiedWalletAccount) => {
284
+ const walletAccount = convertVerifiedCredentialToWalletAccount({ verifiedCredential: verifiedWalletAccount }, client);
285
+ walletAccountsMap.set(walletAccount.id, walletAccount);
286
+ });
287
+ return Array.from(walletAccountsMap.values());
288
+ };
289
+
290
+ //#endregion
291
+ //#region src/modules/wallets/getWalletAccounts/getWalletAccounts.ts
292
+ /**
293
+ * Retrieves all wallet accounts associated with the current session.
294
+ *
295
+ * This function returns both verified and unverified wallet accounts,
296
+ * combining data from user credentials and local unverified accounts.
297
+ * You can differentiate between verified and unverified wallet accounts by
298
+ * checking the `verifiedCredentialId` property.
299
+ *
300
+ * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
301
+ * @returns An array of wallet accounts associated with the session.
302
+ * @instrumented
303
+ */
304
+ const getWalletAccounts = (client = getDefaultClient()) => {
305
+ const { unverifiedWalletAccounts, user } = getCore(client).state.get();
306
+ return getWalletAccountsFromState({
307
+ unverifiedWalletAccounts,
308
+ user
309
+ }, client);
310
+ };
311
+ const __getWalletAccounts_impl = getWalletAccounts;
312
+ const __getWalletAccounts_wrapped = instrumentFunction({
313
+ fn: __getWalletAccounts_impl,
314
+ functionName: "getWalletAccounts",
315
+ getCore: () => {
316
+ try {
317
+ return getCore(getDefaultClient());
318
+ } catch {
319
+ return;
320
+ }
321
+ }
322
+ });
323
+
324
+ //#endregion
325
+ //#region src/errors/NoWalletProviderFoundError.ts
326
+ var NoWalletProviderFoundError = class extends BaseError {
327
+ constructor({ walletProviderKey }) {
328
+ super({
329
+ cause: null,
330
+ code: "no_wallet_provider_found_error",
331
+ docsUrl: null,
332
+ name: "NoWalletProviderFoundError",
333
+ shortMessage: `No wallet provider found with key: ${walletProviderKey}`
334
+ });
335
+ }
336
+ };
337
+
338
+ //#endregion
339
+ //#region src/services/runtimeServices/createRuntimeServiceAccessKey/createRuntimeServiceAccessKey.ts
340
+ /**
341
+ * Creates a service accessor function that manages service instantiation and caching.
342
+ * The returned function will either retrieve an existing service from the registry or
343
+ * create a new one using the provided builder function.
344
+ *
345
+ * @template - The type of service to be created/accessed
346
+ * @param key - Unique identifier for the service in the registry
347
+ * @param builder - Function that creates the service instance when called with a DynamicClient
348
+ * @instrumented
349
+ */
350
+ const createRuntimeServiceAccessKey = (key, builder) => (client) => {
351
+ const { runtimeServices } = getCore(client);
352
+ const currentService = runtimeServices.getByKey(key);
353
+ if (currentService) return currentService;
354
+ const service = builder(client);
355
+ runtimeServices.register(key, service);
356
+ return service;
357
+ };
358
+ const __createRuntimeServiceAccessKey_impl = createRuntimeServiceAccessKey;
359
+ const __createRuntimeServiceAccessKey_wrapped = instrumentFunction({
360
+ fn: __createRuntimeServiceAccessKey_impl,
361
+ functionName: "createRuntimeServiceAccessKey",
362
+ getCore: () => {
363
+ try {
364
+ return getCore(getDefaultClient());
365
+ } catch {
366
+ return;
367
+ }
368
+ }
369
+ });
370
+
371
+ //#endregion
372
+ //#region src/modules/wallets/walletProviderRegistry/createWalletProviderRegistry/createWalletProviderRegistry.ts
373
+ /**
374
+ * Creates a new wallet provider registry that manages wallet providers with priority-based registration.
375
+ *
376
+ * @returns The wallet provider registry instance
377
+ *
378
+ * @example
379
+ * ```typescript
380
+ * const registry = createWalletProviderRegistry();
381
+ *
382
+ * registry.register({
383
+ * priority: WalletProviderPriority.WALLET_SDK,
384
+ * walletProvider: myWalletProvider
385
+ * });
386
+ *
387
+ * const provider = registry.getByKey('my-wallet-key');
388
+ * const providers = registry.listProviders();
389
+ * ```
390
+ * @not-instrumented
391
+ */
392
+ const createWalletProviderRegistry = (client) => {
393
+ const registry = /* @__PURE__ */ new Map();
394
+ return {
395
+ getByKey: (key) => registry.get(key)?.walletProvider,
396
+ listProviders: () => Array.from(registry.values()).map((v) => v.walletProvider),
397
+ register: (args) => {
398
+ const existingEntry = registry.get(args.walletProvider.key);
399
+ if (existingEntry) {
400
+ if (existingEntry.priority < args.priority) {
401
+ registry.set(args.walletProvider.key, args);
402
+ emitEvent({
403
+ args: { walletProviderKey: args.walletProvider.key },
404
+ event: "walletProviderChanged"
405
+ }, client);
406
+ }
407
+ } else {
408
+ registry.set(args.walletProvider.key, args);
409
+ emitEvent({
410
+ args: { walletProvider: args.walletProvider },
411
+ event: "walletProviderRegistered"
412
+ }, client);
413
+ emitEvent({
414
+ args: { walletProviderKey: args.walletProvider.key },
415
+ event: "walletProviderChanged"
416
+ }, client);
417
+ }
418
+ },
419
+ unregister: (key) => {
420
+ registry.delete(key);
421
+ emitEvent({
422
+ args: { walletProviderKey: key },
423
+ event: "walletProviderUnregistered"
424
+ }, client);
425
+ }
426
+ };
427
+ };
428
+
429
+ //#endregion
430
+ //#region src/modules/wallets/walletProviderRegistry/getWalletProviderRegistry/getWalletProviderRegistry.ts
431
+ /**
432
+ * This function provides access to a shared instance of the wallet provider registry.
433
+ *
434
+ * It ensures that the same registry instance is used throughout the client to maintaining
435
+ * consistency of registered wallet providers across different parts of the codebase.
436
+ *
437
+ * @returns The wallet provider registry instance
438
+ *
439
+ * @example
440
+ * ```typescript
441
+ * // Get the registry instance
442
+ * const registry = getWalletProviderRegistry();
443
+ *
444
+ * // Register a wallet provider
445
+ * registry.register({
446
+ * priority: WalletProviderPriority.WALLET_SDK,
447
+ * walletProvider: myWalletProvider
448
+ * });
449
+ *
450
+ * // Retrieve a specific provider
451
+ * const provider = registry.getByKey('metamaskevm');
452
+ * ```
453
+ */
454
+ const getWalletProviderRegistry = __createRuntimeServiceAccessKey_wrapped("walletProviderRegistry", (client) => createWalletProviderRegistry(client));
455
+
456
+ //#endregion
457
+ //#region src/modules/wallets/walletProviderRegistry/walletProviderRegistry.types.ts
458
+ let WalletProviderPriority = /* @__PURE__ */ function(WalletProviderPriority$1) {
459
+ /**
460
+ * Highest priority should be used by wallet providers that implement
461
+ * the most reliable wallet integration.
462
+ * example: The SDK provided by the wallet provider.
463
+ */
464
+ WalletProviderPriority$1[WalletProviderPriority$1["WALLET_SDK"] = 100] = "WALLET_SDK";
465
+ /**
466
+ * Medium priority should be used by wallet providers that implement
467
+ * a wallet integration via some reliable standard.
468
+ * example: A wallet provider that uses EIP6963 announcement.
469
+ */
470
+ WalletProviderPriority$1[WalletProviderPriority$1["WALLET_SELF_ANNOUNCEMENT_STANDARD"] = 50] = "WALLET_SELF_ANNOUNCEMENT_STANDARD";
471
+ /**
472
+ * Low priority should be used by wallet providers that implement
473
+ * a wallet integration on a less reliable standard.
474
+ * example: A wallet provider that uses window.ethereum, where the
475
+ * window key can be overridden by other extensions.
476
+ */
477
+ WalletProviderPriority$1[WalletProviderPriority$1["WINDOW_INJECT"] = 20] = "WINDOW_INJECT";
478
+ return WalletProviderPriority$1;
479
+ }({});
480
+
481
+ //#endregion
482
+ //#region src/modules/wallets/utils/getWalletProviderFromWalletAccount/getWalletProviderFromWalletAccount.ts
483
+ /** @instrumented */
484
+ const getWalletProviderFromWalletAccount = ({ walletAccount }, client) => {
485
+ const walletProvider = getWalletProviderRegistry(client).getByKey(walletAccount.walletProviderKey);
486
+ if (!walletProvider) throw new NoWalletProviderFoundError({ walletProviderKey: walletAccount.walletProviderKey });
487
+ return walletProvider;
488
+ };
489
+ const __getWalletProviderFromWalletAccount_impl = getWalletProviderFromWalletAccount;
490
+ const __getWalletProviderFromWalletAccount_wrapped = instrumentFunction({
491
+ fn: __getWalletProviderFromWalletAccount_impl,
492
+ functionName: "getWalletProviderFromWalletAccount",
493
+ getCore: () => {
494
+ try {
495
+ return getCore(getDefaultClient());
496
+ } catch {
497
+ return;
498
+ }
499
+ }
500
+ });
501
+
502
+ //#endregion
503
+ //#region src/modules/auth/consts.ts
504
+ const DYNAMIC_AUTH_COOKIE_NAME = "DYNAMIC_JWT_TOKEN";
505
+
506
+ //#endregion
507
+ //#region src/modules/wallets/emitWalletAccountsChangedEvent/emitWalletAccountsChangedEvent.ts
508
+ /**
509
+ * Emits the `walletAccountsChanged` event.
510
+ * @not-instrumented
511
+ */
512
+ const emitWalletAccountsChangedEvent = (client) => {
513
+ emitEvent({
514
+ args: { walletAccounts: __getWalletAccounts_wrapped(client) },
515
+ event: "walletAccountsChanged"
516
+ }, client);
517
+ };
518
+
519
+ //#endregion
520
+ //#region src/modules/auth/updateAuthFromVerifyResponse/checkAndRaiseWalletAccountsChangedEvent/checkAndRaiseWalletAccountsChangedEvent.ts
521
+ /** @not-instrumented */
522
+ const checkAndRaiseWalletAccountsChangedEvent = ({ previousState }, client) => {
523
+ const core = getCore(client);
524
+ if (getWalletAccountsHash(previousState, client) !== getWalletAccountsHash(core.state.get(), client)) emitWalletAccountsChangedEvent(client);
525
+ };
526
+ const getWalletAccountsHash = (state, client) => getWalletAccountsFromState(state, client).map((walletAccount) => JSON.stringify(walletAccount)).sort().join("-");
527
+
528
+ //#endregion
529
+ //#region src/modules/wallets/getWalletProviders/getWalletProviders.ts
530
+ /**
531
+ * Get all available wallet providers to interact with internally.
532
+ * @instrumented
533
+ */
534
+ const getWalletProviders = (client) => {
535
+ return getWalletProviderRegistry(client).listProviders();
536
+ };
537
+ const __getWalletProviders_impl = getWalletProviders;
538
+ const __getWalletProviders_wrapped = instrumentFunction({
539
+ fn: __getWalletProviders_impl,
540
+ functionName: "getWalletProviders",
541
+ getCore: () => {
542
+ try {
543
+ return getCore(getDefaultClient());
544
+ } catch {
545
+ return;
546
+ }
547
+ }
548
+ });
549
+
550
+ //#endregion
551
+ //#region src/modules/waas/isWaasWalletProvider/isWaasWalletProvider.ts
552
+ /** @not-instrumented */
553
+ const isWaasWalletProvider = (walletProvider) => {
554
+ return walletProvider.key.includes(DYNAMIC_WAAS_METADATA.normalizedWalletName);
555
+ };
556
+
557
+ //#endregion
558
+ //#region src/modules/waas/findWaasWalletProviderByChain/findWaasWalletProviderByChain.ts
559
+ /** @not-instrumented */
560
+ const findWaasWalletProviderByChain = ({ chain }, client) => {
561
+ const providers = __getWalletProviders_wrapped(client);
562
+ const waasProviderKey = formatWalletProviderKey({
563
+ chain,
564
+ displayName: DYNAMIC_WAAS_METADATA.displayName,
565
+ walletProviderType: WalletProviderEnum.EmbeddedWallet
566
+ });
567
+ const waasProvider = providers.find((provider) => provider.key === waasProviderKey && provider.chain === chain);
568
+ if (!waasProvider || !isWaasWalletProvider(waasProvider)) return null;
569
+ return waasProvider;
570
+ };
571
+
572
+ //#endregion
573
+ //#region src/modules/waas/isWaasWalletAccount/isWaasWalletAccount.ts
574
+ /**
575
+ * This function determines whether the provided wallet account is a Dynamic
576
+ * WaaS wallet account.
577
+ *
578
+ * @param params.walletAccount - The wallet account to check.
579
+ * @returns True if the wallet account is a WaaS wallet account, false otherwise.
580
+ * @not-instrumented
581
+ */
582
+ const isWaasWalletAccount = ({ walletAccount }) => {
583
+ return walletAccount.walletProviderKey.includes(DYNAMIC_WAAS_METADATA.normalizedWalletName);
584
+ };
585
+
586
+ //#endregion
587
+ //#region src/modules/waas/restoreUserSharesForAllWalletAccounts/restoreUserSharesForAllWalletAccounts.ts
588
+ /** @not-instrumented */
589
+ const restoreUserSharesForAllWalletAccounts = async (client) => {
590
+ const waasWalletAccounts = __getWalletAccounts_wrapped(client).filter((walletAccount) => isWaasWalletAccount({ walletAccount }));
591
+ await Promise.all(waasWalletAccounts.map(async (walletAccount) => {
592
+ const provider = findWaasWalletProviderByChain({ chain: walletAccount.chain }, client);
593
+ /**
594
+ * The environment might not have the embedded wallet extensions installed.
595
+ * In that case there is no provider for the chain and we can skip restoring the user share.
596
+ */
597
+ if (!provider) return;
598
+ return provider.restoreUserShareForWalletAccount({ walletAccount });
599
+ }));
600
+ };
601
+
602
+ //#endregion
603
+ //#region src/modules/auth/decodeJwt/decodeJwt.ts
604
+ /**
605
+ * Decodes a JWT token and returns the full payload.
606
+ *
607
+ * This function extracts and returns the complete JWT payload including scopes,
608
+ * expiration time, and other claims.
609
+ *
610
+ * @param jwt - The JWT token string.
611
+ * @returns The decoded JWT payload object.
612
+ * @throws InvalidParamError if the token is invalid or cannot be decoded.
613
+ *
614
+ * @example
615
+ * ```typescript
616
+ * const payload = decodeJwt(jwt);
617
+ * // Returns: { scopes: ['wallet:export'], exp: 1234567890, ... }
618
+ * ```
619
+ * @not-instrumented
620
+ */
621
+ const decodeJwt = (jwt) => {
622
+ try {
623
+ const parts = jwt.split(".");
624
+ if (parts.length !== 3) throw new InvalidParamError("Invalid JWT format");
625
+ const base64Payload = parts[1].replaceAll("-", "+").replaceAll("_", "/");
626
+ const paddedPayload = base64Payload + "=".repeat((4 - base64Payload.length % 4) % 4);
627
+ const decodedPayload = atob(paddedPayload);
628
+ return JSON.parse(decodedPayload);
629
+ } catch (error) {
630
+ if (error instanceof InvalidParamError) throw error;
631
+ throw new InvalidParamError(`Failed to decode JWT: ${error instanceof Error ? error.message : String(error)}`);
632
+ }
633
+ };
634
+
635
+ //#endregion
636
+ //#region src/modules/auth/updateAuthFromVerifyResponse/elevatedAccessTokens/normalizeScopes/normalizeScopes.ts
637
+ /**
638
+ * Normalizes scopes by deduplicating and sorting them.
639
+ * This creates a canonical representation for comparison.
640
+ *
641
+ * @param scopes - Array of scope strings (may contain duplicates)
642
+ * @returns Normalized, sorted array of unique scopes
643
+ * @not-instrumented
644
+ */
645
+ const normalizeScopes = (scopes) => {
646
+ return [...new Set(scopes)].sort((a, b) => a.localeCompare(b));
647
+ };
648
+
649
+ //#endregion
650
+ //#region src/modules/auth/updateAuthFromVerifyResponse/elevatedAccessTokens/parseElevatedAccessToken/parseElevatedAccessToken.ts
651
+ /**
652
+ * Validates and parses an elevated access token from a JWT string.
653
+ * Extracts scopes, expiration, and validates the token structure.
654
+ *
655
+ * Policy decisions:
656
+ * - Tokens without scopes are rejected (returns null)
657
+ * - Tokens with empty scopes array are rejected (returns null)
658
+ * - Tokens without exp field are rejected (returns null)
659
+ * - Expired tokens are rejected (returns null)
660
+ *
661
+ * @returns Parsed token data or null if token is invalid/expired
662
+ * @not-instrumented
663
+ */
664
+ const parseElevatedAccessToken = ({ token }) => {
665
+ const payload = decodeJwt(token);
666
+ const filteredScopes = ((payload?.scope)?.split(" ") ?? []).filter((s) => s.length > 0);
667
+ const singleUse = payload.singleUse ?? false;
668
+ if (!filteredScopes || filteredScopes.length === 0) return null;
669
+ if (!payload.exp) return null;
670
+ const expiresAt = /* @__PURE__ */ new Date(payload.exp * 1e3);
671
+ if (expiresAt <= /* @__PURE__ */ new Date()) return null;
672
+ return {
673
+ expiresAt,
674
+ normalizedScopes: normalizeScopes(filteredScopes),
675
+ scopes: filteredScopes,
676
+ singleUse,
677
+ token
678
+ };
679
+ };
680
+
681
+ //#endregion
682
+ //#region src/modules/auth/updateAuthFromVerifyResponse/elevatedAccessTokens/upsertElevatedAccessToken/upsertElevatedAccessToken.ts
683
+ /**
684
+ * Upserts an elevated access token into the current tokens array.
685
+ *
686
+ * Policy: Only one token per normalized scope-set is allowed.
687
+ * If a token with the same normalized scopes exists, it is replaced.
688
+ * This ensures we don't accumulate multiple tokens for the same scope combination.
689
+ *
690
+ * @param currentTokens - Current array of elevated access tokens
691
+ * @param newToken - New token to upsert
692
+ * @returns Updated array of tokens with the new token upserted
693
+ * @not-instrumented
694
+ */
695
+ const upsertElevatedAccessToken = ({ currentTokens, newToken }) => {
696
+ const newScopeKey = normalizeScopes(newToken.scopes).join(" ");
697
+ return [...currentTokens.filter((existingToken) => {
698
+ return normalizeScopes(existingToken.scopes).join(" ") !== newScopeKey;
699
+ }), {
700
+ expiresAt: newToken.expiresAt,
701
+ scopes: newToken.scopes,
702
+ singleUse: newToken.singleUse,
703
+ token: newToken.token
704
+ }];
705
+ };
706
+
707
+ //#endregion
708
+ //#region src/modules/auth/updateAuthFromVerifyResponse/updateAuthFromVerifyResponse.ts
709
+ /** @instrumented */
710
+ const updateAuthFromVerifyResponse = ({ response }, client) => {
711
+ const core = getCore(client);
712
+ const previousState = { ...core.state.get() };
713
+ const { user, minifiedJwt, jwt, expiresAt, mfaToken, elevatedAccessToken } = response;
714
+ const sessionExpiresAt = /* @__PURE__ */ new Date(expiresAt * 1e3);
715
+ const newState = {
716
+ legacyToken: jwt ?? null,
717
+ sessionExpiresAt,
718
+ token: minifiedJwt ?? null,
719
+ user
720
+ };
721
+ if (mfaToken) newState.mfaToken = mfaToken;
722
+ const currentTokens = core.state.get().elevatedAccessTokens || [];
723
+ newState.elevatedAccessTokens = currentTokens;
724
+ if (elevatedAccessToken) {
725
+ const parsedToken = parseElevatedAccessToken({ token: elevatedAccessToken });
726
+ if (parsedToken) newState.elevatedAccessTokens = upsertElevatedAccessToken({
727
+ currentTokens,
728
+ newToken: parsedToken
729
+ });
730
+ }
731
+ core.state.set(newState);
732
+ /**
733
+ * For customers using a sandbox environment with cookies enabled, we need to set the cookie
734
+ * programmatically because Redcoast won't set the cookie via headers. We set the cookie programmatically
735
+ * so customers can access the cookie from document.cookie consistently between sandbox and live environments.
736
+ */
737
+ if (minifiedJwt && isCookieEnabled(client)) setCookie(`${DYNAMIC_AUTH_COOKIE_NAME}=${minifiedJwt}; expires=${sessionExpiresAt.toUTCString()}; path=/; SameSite=Lax`);
738
+ checkAndRaiseWalletAccountsChangedEvent({ previousState }, client);
739
+ if (!previousState.user && Boolean(newState.user)) restoreUserSharesForAllWalletAccounts(client);
740
+ };
741
+ const __updateAuthFromVerifyResponse_impl = updateAuthFromVerifyResponse;
742
+ const __updateAuthFromVerifyResponse_wrapped = instrumentFunction({
743
+ fn: __updateAuthFromVerifyResponse_impl,
744
+ functionName: "updateAuthFromVerifyResponse",
745
+ getCore: () => {
746
+ try {
747
+ return getCore(getDefaultClient());
748
+ } catch {
749
+ return;
750
+ }
751
+ }
752
+ });
753
+
754
+ //#endregion
755
+ //#region src/modules/wallets/getWalletProviderByKey/getWalletProviderByKey.ts
756
+ /** @not-instrumented */
757
+ const getWalletProviderByKey = ({ walletProviderKey }, client) => {
758
+ const walletProvider = __getWalletProviders_wrapped(client).find((walletProvider$1) => walletProvider$1.key === walletProviderKey);
759
+ if (!walletProvider) throw new NoWalletProviderFoundError({ walletProviderKey });
760
+ return walletProvider;
761
+ };
762
+
763
+ //#endregion
764
+ //#region src/modules/wallets/utils/getVerifiedCredentialForWalletAccount/getVerifiedCredentialForWalletAccount.ts
765
+ /** @instrumented */
766
+ const getVerifiedCredentialForWalletAccount = ({ walletAccount }, client) => {
767
+ return client.user?.verifiedCredentials.find((vc) => vc.id === walletAccount.verifiedCredentialId);
768
+ };
769
+ const __getVerifiedCredentialForWalletAccount_impl = getVerifiedCredentialForWalletAccount;
770
+ const __getVerifiedCredentialForWalletAccount_wrapped = instrumentFunction({
771
+ fn: __getVerifiedCredentialForWalletAccount_impl,
772
+ functionName: "getVerifiedCredentialForWalletAccount",
773
+ getCore: () => {
774
+ try {
775
+ return getCore(getDefaultClient());
776
+ } catch {
777
+ return;
778
+ }
779
+ }
780
+ });
781
+
782
+ //#endregion
783
+ export { setCookie as A, normalizeAddress as C, __onEvent_wrapped as D, __offEvent_wrapped as E, __onceEvent_wrapped as O, formatWalletAccountId as S, InvalidWalletProviderKeyError as T, __createRuntimeServiceAccessKey_wrapped as _, parseElevatedAccessToken as a, formatWalletProviderKey as b, findWaasWalletProviderByChain as c, checkAndRaiseWalletAccountsChangedEvent as d, emitWalletAccountsChangedEvent as f, getWalletProviderRegistry as g, WalletProviderPriority as h, upsertElevatedAccessToken as i, emitEvent as k, isWaasWalletProvider as l, __getWalletProviderFromWalletAccount_wrapped as m, getWalletProviderByKey as n, restoreUserSharesForAllWalletAccounts as o, DYNAMIC_AUTH_COOKIE_NAME as p, __updateAuthFromVerifyResponse_wrapped as r, isWaasWalletAccount as s, __getVerifiedCredentialForWalletAccount_wrapped as t, __getWalletProviders_wrapped as u, NoWalletProviderFoundError as v, splitWalletProviderKey as w, normalizeWalletNameWithChain as x, __getWalletAccounts_wrapped as y };
784
+ //# sourceMappingURL=getVerifiedCredentialForWalletAccount-d_bHvLLE.native.esm.js.map