@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,1178 @@
1
+ import { AuthStorageEnum, Configuration, SDKApi, isDeviceNonceSignatureRequiredForUrl } from "@dynamic-labs/sdk-api-core";
2
+
3
+ //#region package.json
4
+ var name = "@dynamic-labs-sdk/client";
5
+ var version = "0.25.1";
6
+ var dependencies = {
7
+ "@dynamic-labs-sdk/assert-package-version": "workspace:*",
8
+ "@dynamic-labs-wallet/browser-wallet-client": "0.0.325",
9
+ "@dynamic-labs/sdk-api-core": "0.0.941",
10
+ "@simplewebauthn/browser": "13.1.0",
11
+ "ably": "2.17.1",
12
+ "buffer": "6.0.3",
13
+ "eventemitter3": "5.0.1",
14
+ "zod": "4.0.5"
15
+ };
16
+
17
+ //#endregion
18
+ //#region src/client/core/getCore/getCore.ts
19
+ /** @not-instrumented */
20
+ const getCore = (client) => {
21
+ return client.__core;
22
+ };
23
+
24
+ //#endregion
25
+ //#region src/errors/base/BaseError.ts
26
+ const getDetails = ({ details, cause }) => {
27
+ if (cause instanceof BaseError) return cause.details;
28
+ if (cause?.message) return cause.message;
29
+ return details;
30
+ };
31
+ /**
32
+ * Formats the error message with all available information
33
+ */
34
+ const formatMessage = ({ shortMessage, details, docsUrl, metaMessages }) => {
35
+ return [
36
+ "[Dynamic JS SDK]",
37
+ shortMessage,
38
+ "",
39
+ ...metaMessages ? [...metaMessages, ""] : [],
40
+ ...docsUrl ? [`Docs: ${docsUrl}`] : [],
41
+ ...details ? [`Details: ${details}`] : [],
42
+ `Version: ${version}`,
43
+ `Timestamp: ${(/* @__PURE__ */ new Date()).toISOString()}`
44
+ ].join("\n");
45
+ };
46
+ /**
47
+ * Base error class that provides structured error handling with detailed information
48
+ */
49
+ var BaseError = class BaseError extends Error {
50
+ /** The error unique code */
51
+ code;
52
+ details;
53
+ formattedMessage;
54
+ name = "BaseError";
55
+ cause;
56
+ constructor(args) {
57
+ const details = getDetails(args);
58
+ const formattedMessage = formatMessage({
59
+ ...args,
60
+ details
61
+ });
62
+ super(args.shortMessage ?? formattedMessage, args.cause ? { cause: args.cause } : void 0);
63
+ this.formattedMessage = formattedMessage;
64
+ this.details = details;
65
+ this.name = args.name ?? this.name;
66
+ this.cause = args.cause ?? this.cause;
67
+ this.code = args.code;
68
+ }
69
+ /**
70
+ * Walks the cause chain of the error and returns the root error
71
+ */
72
+ walk() {
73
+ const cause = this.cause;
74
+ if (cause instanceof BaseError) return cause.walk();
75
+ return cause;
76
+ }
77
+ toString() {
78
+ return this.formattedMessage;
79
+ }
80
+ };
81
+
82
+ //#endregion
83
+ //#region src/errors/ClientNotFoundError.ts
84
+ var ClientNotFoundError = class extends BaseError {
85
+ constructor() {
86
+ super({
87
+ cause: null,
88
+ code: "client_not_found_error",
89
+ docsUrl: null,
90
+ name: "ClientNotFoundError",
91
+ shortMessage: "No Dynamic client has been created yet. Make sure you have called createDynamicClient() first."
92
+ });
93
+ }
94
+ };
95
+
96
+ //#endregion
97
+ //#region src/client/defaultClient/defaultClient.ts
98
+ let defaultClient = null;
99
+ let numOfInitializedClients = 0;
100
+ /**
101
+ * Returns the DynamicClient instance that was initialized with createDynamicClient.
102
+ *
103
+ * If more than one instance of DynamicClient was initialized, you should not use this function.
104
+ * Instead, you should pass the client instance you stored to the function that needs it.
105
+ * @not-instrumented
106
+ */
107
+ const getDefaultClient = () => {
108
+ if (!defaultClient) throw new ClientNotFoundError();
109
+ if (numOfInitializedClients > 1) getCore(defaultClient).logger.debug("Multiple instances of DynamicClient found. If you are only using one client (recommended), make sure you are not calling \"createDynamicClient\" multiple times. If you are using multiple clients, make sure you are passing which client to use as the last param of all Dynamic functions.");
110
+ return defaultClient;
111
+ };
112
+ /** @not-instrumented */
113
+ const setDefaultClient = (client) => {
114
+ defaultClient = client;
115
+ numOfInitializedClients++;
116
+ };
117
+
118
+ //#endregion
119
+ //#region src/utils/getNonce/constants.ts
120
+ const NONCE_POOL_EXPIRATION_TIME = 6e4 * 60 * 24;
121
+ const NONCE_POOL_SIZE = 5;
122
+
123
+ //#endregion
124
+ //#region src/modules/apiClient/constants.ts
125
+ const DYNAMIC_API_VERSION_HEADER = "x-dyn-api-version";
126
+ const DYNAMIC_REQUEST_ID_HEADER = "x-dyn-request-id";
127
+ const DYNAMIC_SDK_VERSION_HEADER = "x-dyn-version";
128
+ const ELEVATED_ACCESS_TOKEN_HEADER = "x-dyn-elevated-access-token";
129
+ const MFA_TOKEN_HEADER = "x-mfa-auth-token";
130
+ const SESSION_PUBLIC_KEY_HEADER = "x-dyn-session-public-key";
131
+ const DYNAMIC_SDK_API_VERSION = dependencies["@dynamic-labs/sdk-api-core"];
132
+ const DYNAMIC_SDK_SESSION_ID_HEADER = "x-dyn-session-id";
133
+ const CLIENT_SDK_NAME = "ClientSDK";
134
+
135
+ //#endregion
136
+ //#region src/utils/randomString/randomString.native.ts
137
+ const DEFAULT_CHARS = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
138
+ /** @not-instrumented */
139
+ const randomString = ({ chars = DEFAULT_CHARS, length }) => {
140
+ /**
141
+ * React native does not include crypto.getRandomValues, so we use Math.random instead.
142
+ */
143
+ let result = "";
144
+ for (let i = 0; i < length; i++) result += chars[Math.floor(Math.random() * chars.length)];
145
+ return result;
146
+ };
147
+
148
+ //#endregion
149
+ //#region src/errors/ValueMustBeDefinedError.ts
150
+ var ValueMustBeDefinedError = class extends BaseError {
151
+ constructor(message) {
152
+ super({
153
+ cause: null,
154
+ code: "value_must_be_defined_error",
155
+ docsUrl: null,
156
+ name: "ValueMustBeDefined",
157
+ shortMessage: message
158
+ });
159
+ }
160
+ };
161
+
162
+ //#endregion
163
+ //#region src/utils/assertDefined/assertDefined.ts
164
+ /**
165
+ * Asserts that a value is not null or undefined, throwing an error if it is.
166
+ * This function acts as a type guard, narrowing the type to exclude null and undefined.
167
+ *
168
+ * @template T - The type of the value being checked
169
+ * @param value - The value to check for null or undefined
170
+ * @param message - The error message to throw if the value is null or undefined
171
+ * @throws Throws an error with the provided message if value is null or undefined
172
+ * @example
173
+ * ```typescript
174
+ * const maybeString: string | null = getValue();
175
+ * assertDefined(maybeString, 'String value is required');
176
+ * // maybeString is now typed as string (null is excluded)
177
+ * ```
178
+ */
179
+ function assertDefined(value, message) {
180
+ if (value === null || value === void 0) throw new ValueMustBeDefinedError(message);
181
+ }
182
+
183
+ //#endregion
184
+ //#region src/modules/projectSettings/isCookieEnabled/isCookieEnabled.ts
185
+ /**
186
+ * Returns true if the client is using Dynamic cookies or a BYO JWT cookie.
187
+ * @not-instrumented
188
+ */
189
+ const isCookieEnabled = (client) => {
190
+ assertDefined(client.projectSettings, "Project settings are not defined");
191
+ const securitySettings = client.projectSettings.security;
192
+ if (!securitySettings) return false;
193
+ const dynamicCookiesEnabled = (securitySettings.auth?.storage || []).includes(AuthStorageEnum.Cookie);
194
+ const byoJwtCookieEnabled = Boolean(securitySettings.externalAuth?.cookieName);
195
+ return dynamicCookiesEnabled || byoJwtCookieEnabled;
196
+ };
197
+
198
+ //#endregion
199
+ //#region src/modules/auth/extractSessionId/extractSessionId.ts
200
+ /**
201
+ * Extracts the session ID (`sid` claim) from a JWT token string.
202
+ *
203
+ * Decodes the base64url-encoded payload segment of the token and reads the
204
+ * `sid` field. This is used to correlate instrumentation events with the
205
+ * authenticated session, without ever forwarding the full token.
206
+ *
207
+ * Returns `null` when no token is present, when the token is malformed, or
208
+ * when the payload does not contain a `sid` claim.
209
+ * @not-instrumented
210
+ */
211
+ const extractSessionId = (token) => {
212
+ try {
213
+ const payload = token.split(".")[1];
214
+ return JSON.parse(atob(payload)).sid ?? null;
215
+ } catch {
216
+ return null;
217
+ }
218
+ };
219
+
220
+ //#endregion
221
+ //#region src/utils/getUserAgent/getUserAgent.ts
222
+ /**
223
+ * Returns the browser's `navigator.userAgent` string for inclusion in
224
+ * instrumentation events.
225
+ *
226
+ * Falls back to an empty string in environments where `navigator` is not
227
+ * available (e.g., Node.js SSR, service workers) so that callers never need
228
+ * to guard against undefined.
229
+ * @not-instrumented
230
+ */
231
+ const getUserAgent = () => {
232
+ try {
233
+ return navigator.userAgent;
234
+ } catch {
235
+ return "";
236
+ }
237
+ };
238
+
239
+ //#endregion
240
+ //#region src/services/instrumentation/constants.ts
241
+ const DEFAULT_PII_FIELDS = [
242
+ "password",
243
+ "token",
244
+ "secret",
245
+ "privateKey",
246
+ "mnemonic",
247
+ "seed",
248
+ "email",
249
+ "phone",
250
+ "ssn",
251
+ "address",
252
+ "authorization"
253
+ ];
254
+ const REDACTED_VALUE = "[REDACTED]";
255
+ const MAX_STRING_LENGTH = 500;
256
+ const TRUNCATED_SUFFIX = "...[truncated]";
257
+ /**
258
+ * Label prefix for binary data placeholders. The full placeholder includes the
259
+ * byte length, e.g. `[Binary:16 bytes]`, so consumers can gauge data size
260
+ * without the actual bytes appearing in logs.
261
+ */
262
+ const BINARY_LABEL = "Binary";
263
+ /**
264
+ * Placeholder emitted when a circular reference is detected in the value tree.
265
+ * Using a named constant makes it easy to search for or filter in downstream
266
+ * log tooling.
267
+ */
268
+ const CIRCULAR_VALUE = "[Circular]";
269
+
270
+ //#endregion
271
+ //#region src/services/instrumentation/scrubParameters/scrubParameters.ts
272
+ const scrubString = ({ key, piiFieldsLower, redactAll, value }) => {
273
+ if (piiFieldsLower.includes(key.toLowerCase())) return REDACTED_VALUE;
274
+ if (redactAll) return REDACTED_VALUE;
275
+ if (value.length > MAX_STRING_LENGTH) return value.slice(0, MAX_STRING_LENGTH) + TRUNCATED_SUFFIX;
276
+ return value;
277
+ };
278
+ const scrubArray = ({ context, value }) => {
279
+ if (context.visited.has(value)) return [CIRCULAR_VALUE];
280
+ context.visited.add(value);
281
+ const result = value.map((item, index) => scrubValue({
282
+ context,
283
+ key: String(index),
284
+ value: item
285
+ }));
286
+ context.visited.delete(value);
287
+ return result;
288
+ };
289
+ const scrubObject = ({ context, value }) => {
290
+ if (context.visited.has(value)) return { [CIRCULAR_VALUE]: true };
291
+ context.visited.add(value);
292
+ const result = Object.create(null);
293
+ for (const key of Object.keys(value)) result[key] = scrubValue({
294
+ context,
295
+ key,
296
+ value: value[key]
297
+ });
298
+ context.visited.delete(value);
299
+ return result;
300
+ };
301
+ const scrubValue = ({ context, key, value }) => {
302
+ if (value === null || value === void 0) return value;
303
+ if (value instanceof Uint8Array) return `[${BINARY_LABEL}:${value.byteLength} bytes]`;
304
+ if (context.piiFieldsLower.includes(key.toLowerCase())) return REDACTED_VALUE;
305
+ if (typeof value === "string") return scrubString({
306
+ key,
307
+ piiFieldsLower: context.piiFieldsLower,
308
+ redactAll: context.redactAll,
309
+ value
310
+ });
311
+ if (Array.isArray(value)) return scrubArray({
312
+ context,
313
+ value
314
+ });
315
+ if (value instanceof Set) {
316
+ if (context.visited.has(value)) return [CIRCULAR_VALUE];
317
+ context.visited.add(value);
318
+ const setResult = scrubArray({
319
+ context,
320
+ value: [...value]
321
+ });
322
+ context.visited.delete(value);
323
+ return setResult;
324
+ }
325
+ if (value instanceof Map) {
326
+ if (context.visited.has(value)) return { [CIRCULAR_VALUE]: true };
327
+ context.visited.add(value);
328
+ const asObject = Object.create(null);
329
+ for (const [k, v] of value.entries()) asObject[String(k)] = v;
330
+ const mapResult = scrubObject({
331
+ context,
332
+ value: asObject
333
+ });
334
+ context.visited.delete(value);
335
+ return mapResult;
336
+ }
337
+ if (value instanceof WeakMap) return "[WeakMap]";
338
+ if (value instanceof WeakSet) return "[WeakSet]";
339
+ if (value instanceof Date) return value.toISOString();
340
+ if (value instanceof Error) return `[Error: ${value.message}]`;
341
+ if (typeof value === "object") return scrubObject({
342
+ context,
343
+ value
344
+ });
345
+ return value;
346
+ };
347
+ /** @not-instrumented */
348
+ const scrubParameters = ({ piiFields, redactAll, value }) => {
349
+ return scrubObject({
350
+ context: {
351
+ piiFieldsLower: piiFields.map((field) => field.toLowerCase()),
352
+ redactAll,
353
+ visited: /* @__PURE__ */ new WeakSet()
354
+ },
355
+ value
356
+ });
357
+ };
358
+
359
+ //#endregion
360
+ //#region src/services/instrumentation/instrumentFunction/extractParams/extractParams.ts
361
+ /**
362
+ * Normalises the raw positional arguments of an instrumented function call
363
+ * into a flat `Record<string, unknown>` suitable for structured logging.
364
+ *
365
+ * ## Why this is needed
366
+ *
367
+ * Instrumented functions are wrapped with `(...args: unknown[])`, so their
368
+ * parameters arrive as an array. Logging a raw array loses the semantic names
369
+ * of each argument. This function recovers a named representation:
370
+ *
371
+ * - **No arguments** → `{}`
372
+ * - **Single plain-object argument** → that object is returned as-is, because
373
+ * SDK functions follow the single-object-parameter convention, so the object
374
+ * already carries named keys (`{ amount, to }`, etc.).
375
+ * - **Everything else** (multiple args, a single primitive, a single array) →
376
+ * each value is indexed as `arg0`, `arg1`, …
377
+ *
378
+ * ## Why arrays are NOT treated as plain objects
379
+ *
380
+ * `typeof [] === 'object'` and `[] !== null`, so without the `Array.isArray`
381
+ * guard a single-array argument would be returned as-is. That would produce
382
+ * an object with numeric string keys (`{ '0': ..., '1': ... }`), which is
383
+ * misleading and inconsistent with how multi-arg calls are handled. Instead,
384
+ * arrays fall through to the indexed `arg0` path.
385
+ * @not-instrumented
386
+ */
387
+ const extractParams = (args) => {
388
+ if (args.length === 0) return {};
389
+ if (args.length === 1 && typeof args[0] === "object" && args[0] !== null && !Array.isArray(args[0])) return args[0];
390
+ const result = {};
391
+ for (let i = 0; i < args.length; i++) result[`arg${i}`] = args[i];
392
+ return result;
393
+ };
394
+
395
+ //#endregion
396
+ //#region src/services/instrumentation/instrumentFunction/scrubResolvedValue/scrubResolvedValue.ts
397
+ /**
398
+ * Scrubs a resolved return value of any type before logging it.
399
+ * Routes through `scrubParameters` by wrapping the value so that strings,
400
+ * arrays, Dates, Errors, and all other types are handled identically to
401
+ * nested object fields.
402
+ * @not-instrumented
403
+ */
404
+ const scrubResolvedValue = ({ piiFields, redactAll, value }) => scrubParameters({
405
+ piiFields,
406
+ redactAll,
407
+ value: { result: value }
408
+ }).result;
409
+
410
+ //#endregion
411
+ //#region src/services/instrumentation/instrumentFunction/instrumentFunction.ts
412
+ const serializeError = (error) => {
413
+ if (error instanceof Error) return {
414
+ message: error.message,
415
+ name: error.name,
416
+ stack: error.stack
417
+ };
418
+ return {
419
+ message: String(error),
420
+ name: "UnknownError"
421
+ };
422
+ };
423
+ /**
424
+ * Wraps a function so that each invocation emits a structured
425
+ * `FunctionInstrumentationEvent` at three lifecycle points:
426
+ *
427
+ * - **started** — immediately before the function body executes, with the
428
+ * PII-scrubbed call parameters.
429
+ * - **resolved** — after the function (or its returned Promise) settles
430
+ * successfully, with the PII-scrubbed return value.
431
+ * - **rejected** — if the function throws synchronously or its returned
432
+ * Promise rejects.
433
+ *
434
+ * The original return value (or thrown error) is always forwarded to the
435
+ * caller unchanged — instrumentation is purely observational.
436
+ *
437
+ * ## Usage
438
+ *
439
+ * ```ts
440
+ * const transfer = instrumentFunction({
441
+ * fn: rawTransfer,
442
+ * functionName: 'transfer',
443
+ * getCore: () => core,
444
+ * });
445
+ *
446
+ * // When called, three events are emitted automatically:
447
+ * await transfer({ amount: 1, to: '0xabc' });
448
+ * ```
449
+ *
450
+ * ## How functions are wrapped
451
+ *
452
+ * `instrumentFunction` is not called manually in application code. Instead,
453
+ * the esbuild instrumentation plugin (`tools/instrumentation-plugin`) injects
454
+ * it at build time: any exported function annotated with `@instrumented` in its
455
+ * JSDoc is automatically wrapped by the plugin during the build step.
456
+ * The plugin strips the original `export`, renames the function, and re-exports
457
+ * it under the original name via `instrumentFunction(...)` — so the public API
458
+ * is unchanged and no call sites need to be updated.
459
+ *
460
+ * ## Opting out
461
+ *
462
+ * Instrumentation is skipped entirely when:
463
+ * - `getCore()` returns `undefined` (SDK not initialised), or
464
+ * - `core.instrumentation.config.enabled` is `false`.
465
+ *
466
+ * In both cases the original function is called directly with no overhead.
467
+ *
468
+ * ## PII scrubbing
469
+ *
470
+ * All string values whose key appears in `piiFields` are replaced with
471
+ * `"[redacted]"` before events are emitted. Pass `redactAll: true` to redact
472
+ * every field, regardless of key name.
473
+ * @not-instrumented
474
+ */
475
+ const instrumentFunction = ({ fn, functionName, getCore: getCore$1, redactAll }) => {
476
+ const wrapped = (...args) => {
477
+ const core = getCore$1();
478
+ if (!core) return fn(...args);
479
+ if (!core.instrumentation.config.enabled) return fn(...args);
480
+ const instrumentation = core.instrumentation;
481
+ const state = core.state.get();
482
+ const baseEvent = {
483
+ environmentId: core.environmentId,
484
+ functionName,
485
+ parameters: scrubParameters({
486
+ piiFields: instrumentation.config.piiFields,
487
+ redactAll,
488
+ value: extractParams(args)
489
+ }),
490
+ sdkSessionId: core.sdkSessionId,
491
+ sdkVersion: core.version,
492
+ status: "info",
493
+ tokenSessionId: state.token ? extractSessionId(state.token) : null,
494
+ userAgent: getUserAgent(),
495
+ userId: state.user?.id ?? null
496
+ };
497
+ instrumentation.logFunction({
498
+ ...baseEvent,
499
+ phase: "started",
500
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
501
+ });
502
+ try {
503
+ const result = fn(...args);
504
+ if (result instanceof Promise) return result.then((value) => {
505
+ instrumentation.logFunction({
506
+ ...baseEvent,
507
+ phase: "resolved",
508
+ resolvedValue: scrubResolvedValue({
509
+ piiFields: instrumentation.config.piiFields,
510
+ redactAll,
511
+ value
512
+ }),
513
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
514
+ });
515
+ return value;
516
+ }).catch((error) => {
517
+ instrumentation.logFunction({
518
+ ...baseEvent,
519
+ phase: "rejected",
520
+ rejectedError: serializeError(error),
521
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
522
+ });
523
+ throw error;
524
+ });
525
+ instrumentation.logFunction({
526
+ ...baseEvent,
527
+ phase: "resolved",
528
+ resolvedValue: scrubResolvedValue({
529
+ piiFields: instrumentation.config.piiFields,
530
+ redactAll,
531
+ value: result
532
+ }),
533
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
534
+ });
535
+ return result;
536
+ } catch (error) {
537
+ instrumentation.logFunction({
538
+ ...baseEvent,
539
+ phase: "rejected",
540
+ rejectedError: serializeError(error),
541
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
542
+ });
543
+ throw error;
544
+ }
545
+ };
546
+ return wrapped;
547
+ };
548
+
549
+ //#endregion
550
+ //#region src/modules/sessionKeys/getSessionKeys/getSessionKeys.ts
551
+ /** @instrumented */
552
+ const getSessionKeys = (client) => {
553
+ const publicKey = getCore(client).state.get().sessionKeys;
554
+ if (!publicKey) return;
555
+ return { publicKey };
556
+ };
557
+ const __getSessionKeys_impl = getSessionKeys;
558
+ const __getSessionKeys_wrapped = instrumentFunction({
559
+ fn: __getSessionKeys_impl,
560
+ functionName: "getSessionKeys",
561
+ getCore: () => {
562
+ try {
563
+ return getCore(getDefaultClient());
564
+ } catch {
565
+ return;
566
+ }
567
+ }
568
+ });
569
+
570
+ //#endregion
571
+ //#region src/modules/auth/getElevatedAccessToken/getElevatedAccessToken.ts
572
+ /**
573
+ * Gets an elevated access token by scope.
574
+ *
575
+ * This function retrieves an elevated access token that contains the specified scope.
576
+ * Expired tokens are automatically filtered out.
577
+ *
578
+ * By default, if the token has `singleUse: true`, it will be automatically
579
+ * consumed (removed from state) after retrieval. Pass `consume: false` to
580
+ * check for token existence without consuming it.
581
+ *
582
+ * @param params - The parameters object.
583
+ * @param params.scope - The scope to match (e.g., 'wallet:export').
584
+ * @param params.consume - Whether to consume single-use tokens (default: true).
585
+ * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
586
+ * @returns The elevated access token if found and not expired, or undefined if not found or expired.
587
+ *
588
+ * @example
589
+ * ```typescript
590
+ * // Retrieve and consume (default)
591
+ * const token = getElevatedAccessToken({ scope: 'wallet:export' });
592
+ *
593
+ * // Check existence without consuming
594
+ * const token = getElevatedAccessToken({ scope: 'credential:unlink', consume: false });
595
+ * ```
596
+ * @not-instrumented
597
+ */
598
+ const getElevatedAccessToken = ({ consume = true, scope }, client = getDefaultClient()) => {
599
+ const core = getCore(client);
600
+ const now = /* @__PURE__ */ new Date();
601
+ const elevatedAccessTokens = core.state.get().elevatedAccessTokens || [];
602
+ const validTokens = elevatedAccessTokens.filter((token$1) => !token$1.expiresAt || token$1.expiresAt > now);
603
+ if (validTokens.length !== elevatedAccessTokens.length) core.state.set({ elevatedAccessTokens: validTokens });
604
+ const token = validTokens.find((token$1) => token$1.scopes.includes(scope));
605
+ if (!token) return;
606
+ if (consume && token.singleUse) {
607
+ const updatedTokens = validTokens.filter((t) => t !== token);
608
+ core.state.set({ elevatedAccessTokens: updatedTokens });
609
+ }
610
+ return token.token;
611
+ };
612
+ const __getElevatedAccessToken_impl = getElevatedAccessToken;
613
+ const __getElevatedAccessToken_wrapped = instrumentFunction({
614
+ fn: __getElevatedAccessToken_impl,
615
+ functionName: "getElevatedAccessToken",
616
+ getCore: () => {
617
+ try {
618
+ return getCore(getDefaultClient());
619
+ } catch {
620
+ return;
621
+ }
622
+ }
623
+ });
624
+
625
+ //#endregion
626
+ //#region src/errors/APIError/APIError.ts
627
+ var APIError = class APIError extends BaseError {
628
+ status;
629
+ constructor(message, code, status) {
630
+ super({
631
+ cause: null,
632
+ code,
633
+ docsUrl: null,
634
+ name: "APIError",
635
+ shortMessage: message
636
+ });
637
+ this.status = status;
638
+ }
639
+ static async fromResponse(response) {
640
+ try {
641
+ const errorBody = await response.clone().json();
642
+ if (errorBody && "error" in errorBody && typeof errorBody.error === "string") {
643
+ const errorCode = "code" in errorBody && typeof errorBody.code === "string" ? errorBody.code : "unknown_error";
644
+ return new APIError(errorBody.error, errorCode, response.status);
645
+ }
646
+ return null;
647
+ } catch {
648
+ return null;
649
+ }
650
+ }
651
+ };
652
+
653
+ //#endregion
654
+ //#region src/errors/InvalidExternalAuthError.ts
655
+ var InvalidExternalAuthError = class extends BaseError {
656
+ constructor({ cause }) {
657
+ super({
658
+ cause,
659
+ code: "invalid_external_auth_error",
660
+ docsUrl: "https://www.dynamic.xyz/docs/external-auth/third-party-auth-overview",
661
+ name: "InvalidExternalAuthError",
662
+ shortMessage: "Error authenticating with external JWT"
663
+ });
664
+ }
665
+ };
666
+
667
+ //#endregion
668
+ //#region src/errors/LinkCredentialError.ts
669
+ var LinkCredentialError = class extends BaseError {
670
+ constructor({ cause }) {
671
+ super({
672
+ cause,
673
+ code: "link_credential_error",
674
+ docsUrl: null,
675
+ name: "LinkCredentialError",
676
+ shortMessage: "The credential you are trying to link is associated with another account and cannot be reassigned."
677
+ });
678
+ }
679
+ };
680
+
681
+ //#endregion
682
+ //#region src/errors/MfaInvalidOtpError.ts
683
+ var MfaInvalidOtpError = class extends BaseError {
684
+ constructor({ cause }) {
685
+ super({
686
+ cause,
687
+ code: "mfa_invalid_otp_error",
688
+ docsUrl: null,
689
+ name: "MfaInvalidOtpError",
690
+ shortMessage: "Invalid OTP"
691
+ });
692
+ }
693
+ };
694
+
695
+ //#endregion
696
+ //#region src/errors/MfaRateLimitedError.ts
697
+ var MfaRateLimitedError = class extends BaseError {
698
+ constructor({ cause }) {
699
+ super({
700
+ cause,
701
+ code: "mfa_rate_limited_error",
702
+ docsUrl: null,
703
+ name: "MfaRateLimitedError",
704
+ shortMessage: "Rate limited"
705
+ });
706
+ }
707
+ };
708
+
709
+ //#endregion
710
+ //#region src/errors/SandboxMaximumThresholdReachedError.ts
711
+ var SandboxMaximumThresholdReachedError = class extends BaseError {
712
+ constructor({ cause }) {
713
+ super({
714
+ cause,
715
+ code: "sandbox_maximum_threshold_reached_error",
716
+ docsUrl: "https://www.dynamic.xyz/docs/developer-dashboard/sandbox-vs-live#sandbox-vs-live",
717
+ name: "SandboxMaximumThresholdReachedError",
718
+ shortMessage: "Your sandbox environment has reached the maximum MAU. Please use a live environment for production traffic."
719
+ });
720
+ }
721
+ };
722
+
723
+ //#endregion
724
+ //#region src/modules/apiClient/utils/clientErrorMapper/clientErrorMapper.ts
725
+ /**
726
+ * Default error mapper for the client that handles common API error codes.
727
+ *
728
+ * This mapper transforms specific API error codes into more specific error types:
729
+ * - `mfa_invalid_code` → `MfaInvalidOtpError`
730
+ * - `mfa_rate_limited` → `MfaRateLimitedError`
731
+ *
732
+ * @param error - The error to be mapped
733
+ * @returns A transformed error if the error code matches a known pattern, or null if no transformation is needed
734
+ *
735
+ * @example
736
+ * ```typescript
737
+ * // This will be automatically applied to all API errors
738
+ * const apiClient = createApiClient({}, client);
739
+ *
740
+ * // The clientErrorMapper will automatically convert mfa_invalid_code errors
741
+ * // to MfaInvalidOtpError instances
742
+ * ```
743
+ * @not-instrumented
744
+ */
745
+ const clientErrorMapper = (error) => {
746
+ if (error instanceof APIError) {
747
+ if (error.code === "mfa_invalid_code") return new MfaInvalidOtpError({ cause: error });
748
+ if (error.code === "mfa_rate_limited") return new MfaRateLimitedError({ cause: error });
749
+ if (error.code === "invalid_external_auth") return new InvalidExternalAuthError({ cause: error });
750
+ if (error.code === "sandbox_maximum_threshold_reached") return new SandboxMaximumThresholdReachedError({ cause: error });
751
+ if (error.code === "merge_accounts_invalid" || error.code === "reassign_wallet_error") return new LinkCredentialError({ cause: error });
752
+ }
753
+ return null;
754
+ };
755
+
756
+ //#endregion
757
+ //#region src/modules/apiClient/utils/convertToApiErrorMiddleware/convertToApiErrorMiddleware.ts
758
+ /**
759
+ * Creates middleware that converts HTTP error responses to APIError instances
760
+ * and optionally applies custom error mappers to transform them into specific error types.
761
+ *
762
+ * @param options.errorMappers - Array of error mappers to apply to API errors
763
+ * @returns A middleware function that handles error conversion and mapping
764
+ * @not-instrumented
765
+ */
766
+ const createConvertToApiErrorMiddleware = ({ errorMappers = [] }) => ({ post: async (context) => {
767
+ if (context.response.status >= 400) {
768
+ const apiError = await APIError.fromResponse(context.response);
769
+ if (apiError) {
770
+ let errorToThrow = apiError;
771
+ for (const mapper of errorMappers) {
772
+ const newError = mapper(apiError);
773
+ if (newError) {
774
+ errorToThrow = newError;
775
+ break;
776
+ }
777
+ }
778
+ throw errorToThrow;
779
+ }
780
+ }
781
+ return context.response;
782
+ } });
783
+
784
+ //#endregion
785
+ //#region src/utils/getNonce/getNonce.ts
786
+ /**
787
+ * Returns a nonce for wallet ownership verification.
788
+ *
789
+ * Pops the first nonce from the prefetched pool. When the pool is running low
790
+ * (≤1 remaining after pop) a background refetch is triggered. If the pool is
791
+ * empty, nonces are fetched on-demand before returning.
792
+ * @instrumented
793
+ */
794
+ const getNonce = async (client) => {
795
+ const core = getCore(client);
796
+ const pool = core.state.get().prefetchedNonces;
797
+ if (pool.length > 0) {
798
+ const [nonce, ...remaining] = pool;
799
+ core.state.set({ prefetchedNonces: remaining });
800
+ if (remaining.length <= 1) fetchAndStoreNonces(client);
801
+ return nonce;
802
+ }
803
+ await fetchAndStoreNonces(client);
804
+ return getNonce(client);
805
+ };
806
+ const __getNonce_impl = getNonce;
807
+ const __getNonce_wrapped = instrumentFunction({
808
+ fn: __getNonce_impl,
809
+ functionName: "getNonce",
810
+ getCore: () => {
811
+ try {
812
+ return getCore(getDefaultClient());
813
+ } catch {
814
+ return;
815
+ }
816
+ }
817
+ });
818
+
819
+ //#endregion
820
+ //#region src/modules/deviceRegistration/getDeviceSigner/getDeviceSigner.ts
821
+ /** @instrumented */
822
+ const getDeviceSigner = async (client) => {
823
+ const { deviceSigner, keychain } = getCore(client);
824
+ /**
825
+ * If the device signer is available, it should handle the device signing.
826
+ * This is used for mobile devices with secure enclave.
827
+ */
828
+ if (deviceSigner) return deviceSigner;
829
+ const keyName = "device";
830
+ if (!await keychain.getPublicKey(keyName)) await keychain.generateKey(keyName);
831
+ return {
832
+ getPublicKey: () => keychain.getPublicKey(keyName),
833
+ sign: (payload) => keychain.sign(keyName, payload)
834
+ };
835
+ };
836
+ const __getDeviceSigner_impl = getDeviceSigner;
837
+ const __getDeviceSigner_wrapped = instrumentFunction({
838
+ fn: __getDeviceSigner_impl,
839
+ functionName: "getDeviceSigner",
840
+ getCore: () => {
841
+ try {
842
+ return getCore(getDefaultClient());
843
+ } catch {
844
+ return;
845
+ }
846
+ }
847
+ });
848
+
849
+ //#endregion
850
+ //#region src/modules/deviceRegistration/getHeadersForNonceSignedByDeviceSigners/getHeadersForNonceSignedByDeviceSigners.ts
851
+ /** @instrumented */
852
+ const getHeadersForNonceSignedByDeviceSigners = async (client) => {
853
+ const { projectSettings } = client;
854
+ assertDefined(projectSettings, "Project settings not found");
855
+ /**
856
+ * For cookie based environments, the device registration is handled
857
+ * by settings the cookie in the browser.
858
+ * Then we dont need to provide the headers
859
+ */
860
+ if (isCookieEnabled(client)) return {};
861
+ const deviceSigner = await __getDeviceSigner_wrapped(client);
862
+ const nonce = await __getNonce_wrapped(client);
863
+ const signedNonce = await deviceSigner.sign(nonce);
864
+ const publicKey = await deviceSigner.getPublicKey();
865
+ return {
866
+ "x-dynamic-device-nonce": nonce,
867
+ "x-dynamic-device-publickey": publicKey,
868
+ "x-dynamic-device-signed-nonce": signedNonce
869
+ };
870
+ };
871
+ const __getHeadersForNonceSignedByDeviceSigners_impl = getHeadersForNonceSignedByDeviceSigners;
872
+ const __getHeadersForNonceSignedByDeviceSigners_wrapped = instrumentFunction({
873
+ fn: __getHeadersForNonceSignedByDeviceSigners_impl,
874
+ functionName: "getHeadersForNonceSignedByDeviceSigners",
875
+ getCore: () => {
876
+ try {
877
+ return getCore(getDefaultClient());
878
+ } catch {
879
+ return;
880
+ }
881
+ }
882
+ });
883
+
884
+ //#endregion
885
+ //#region src/modules/apiClient/utils/deviceSignatureHeadersMiddleware/createDeviceSignatureHeadersMiddleware.ts
886
+ /** @instrumented */
887
+ const createDeviceSignatureHeadersMiddleware = (client) => {
888
+ return { pre: async (context) => {
889
+ /**
890
+ * The signed nonce is not required for cookie based environments.
891
+ */
892
+ if (isDeviceNonceSignatureRequiredForUrl(context.url) && !isCookieEnabled(client)) {
893
+ const deviceSignerHeaders = await __getHeadersForNonceSignedByDeviceSigners_wrapped(client);
894
+ return {
895
+ init: {
896
+ ...context.init,
897
+ headers: {
898
+ ...context.init.headers,
899
+ ...deviceSignerHeaders
900
+ }
901
+ },
902
+ url: context.url
903
+ };
904
+ }
905
+ } };
906
+ };
907
+ const __createDeviceSignatureHeadersMiddleware_impl = createDeviceSignatureHeadersMiddleware;
908
+ const __createDeviceSignatureHeadersMiddleware_wrapped = instrumentFunction({
909
+ fn: __createDeviceSignatureHeadersMiddleware_impl,
910
+ functionName: "createDeviceSignatureHeadersMiddleware",
911
+ getCore: () => {
912
+ try {
913
+ return getCore(getDefaultClient());
914
+ } catch {
915
+ return;
916
+ }
917
+ }
918
+ });
919
+
920
+ //#endregion
921
+ //#region src/errors/UnauthorizedError.ts
922
+ var UnauthorizedError = class extends BaseError {
923
+ constructor({ cause }) {
924
+ super({
925
+ cause,
926
+ code: "unauthorized_error",
927
+ docsUrl: null,
928
+ name: "UnauthorizedError",
929
+ shortMessage: "Unauthorized"
930
+ });
931
+ }
932
+ };
933
+
934
+ //#endregion
935
+ //#region src/modules/apiClient/utils/unauthorizedMiddleware/createUnauthorizedMiddleware.ts
936
+ /** @not-instrumented */
937
+ const createUnauthorizedMiddleware = () => ({ post: async (context) => {
938
+ if (context.response.status === 401) {
939
+ let cause = null;
940
+ try {
941
+ const errorBody = await context.response.clone().json();
942
+ if (errorBody && "error" in errorBody && typeof errorBody.error === "string") cause = new Error(errorBody.error);
943
+ } catch {}
944
+ throw new UnauthorizedError({ cause });
945
+ }
946
+ return context.response;
947
+ } });
948
+
949
+ //#endregion
950
+ //#region src/modules/apiClient/createApiClient.ts
951
+ /**
952
+ * Returns a new instance of the SDK API client.
953
+ *
954
+ * This is not meant for storing, as it is very light we can create it whenever needed.
955
+ * @instrumented
956
+ */
957
+ const createApiClient = (options = {}, client) => {
958
+ const core = getCore(client);
959
+ const coreState = core.state.get();
960
+ const settings = {
961
+ basePath: core.apiBaseUrl,
962
+ headers: {
963
+ "Content-Type": "application/json",
964
+ [DYNAMIC_API_VERSION_HEADER]: `API/${DYNAMIC_SDK_API_VERSION}`,
965
+ [DYNAMIC_REQUEST_ID_HEADER]: randomString({ length: 50 }),
966
+ [DYNAMIC_SDK_SESSION_ID_HEADER]: core.sdkSessionId,
967
+ [DYNAMIC_SDK_VERSION_HEADER]: `${CLIENT_SDK_NAME}/${version}`,
968
+ ...core.getApiHeaders(),
969
+ ...options.headers
970
+ }
971
+ };
972
+ if (client.token) settings.headers.Authorization = `Bearer ${client.token}`;
973
+ if (client.projectSettings && isCookieEnabled(client)) settings.credentials = "include";
974
+ if (options.includeMfaToken && coreState.mfaToken) settings.headers[MFA_TOKEN_HEADER] = coreState.mfaToken;
975
+ if (options.elevatedAccessTokenScope) {
976
+ const elevatedToken = __getElevatedAccessToken_wrapped({ scope: options.elevatedAccessTokenScope }, client);
977
+ if (elevatedToken) settings.headers[ELEVATED_ACCESS_TOKEN_HEADER] = elevatedToken;
978
+ }
979
+ const sessionPublicKey = __getSessionKeys_wrapped(client)?.publicKey;
980
+ const isSessionPublicKeyHeaderPresent = settings.headers[SESSION_PUBLIC_KEY_HEADER] !== void 0;
981
+ if (sessionPublicKey && !isSessionPublicKeyHeaderPresent) settings.headers[SESSION_PUBLIC_KEY_HEADER] = sessionPublicKey;
982
+ return new SDKApi(new Configuration({
983
+ ...settings,
984
+ fetchApi: core.fetch,
985
+ middleware: [
986
+ __createDeviceSignatureHeadersMiddleware_wrapped(client),
987
+ createConvertToApiErrorMiddleware({ errorMappers: [...options.errorMappers || [], clientErrorMapper] }),
988
+ createUnauthorizedMiddleware()
989
+ ]
990
+ }));
991
+ };
992
+ const __createApiClient_impl = createApiClient;
993
+ const __createApiClient_wrapped = instrumentFunction({
994
+ fn: __createApiClient_impl,
995
+ functionName: "createApiClient",
996
+ getCore: () => {
997
+ try {
998
+ return getCore(getDefaultClient());
999
+ } catch {
1000
+ return;
1001
+ }
1002
+ }
1003
+ });
1004
+
1005
+ //#endregion
1006
+ //#region src/utils/getNonce/fetchAndStoreNonces/fetchAndStoreNonces.ts
1007
+ /**
1008
+ * Fetches a batch of nonces from the API.
1009
+ *
1010
+ * Prefetching is critical for iOS deep link wallet providers (e.g. Phantom
1011
+ * redirect). On iOS, a network request (like fetching a nonce) between a user
1012
+ * action and a deeplink call will break the gesture chain, causing iOS to
1013
+ * silently ignore the deeplink. By prefetching nonces ahead of time,
1014
+ * `getNonce` can return synchronously from cache and the deeplink fires
1015
+ * without an interrupting network round-trip.
1016
+ *
1017
+ * New nonces are **appended** to the existing pool so that unconsumed entries
1018
+ * are not discarded by a background refetch.
1019
+ * @not-instrumented
1020
+ */
1021
+ const fetchAndStoreNonces = async (client) => {
1022
+ const core = getCore(client);
1023
+ const { environmentId } = core;
1024
+ const { nonces } = await __createApiClient_wrapped({}, client).getNonces({
1025
+ count: NONCE_POOL_SIZE,
1026
+ environmentId
1027
+ });
1028
+ const existing = core.state.get().prefetchedNonces;
1029
+ core.state.set({
1030
+ prefetchedNonces: [...existing, ...nonces],
1031
+ prefetchedNoncesExpiration: Date.now() + NONCE_POOL_EXPIRATION_TIME
1032
+ });
1033
+ };
1034
+
1035
+ //#endregion
1036
+ //#region src/modules/wallets/constants.ts
1037
+ const CHAINS_INFO_MAP = {
1038
+ ALEO: {
1039
+ apiChainName: "aleo",
1040
+ blockchainName: "Aleo",
1041
+ verifiedCredentialChainName: "aleo"
1042
+ },
1043
+ ALGO: {
1044
+ apiChainName: "algo",
1045
+ blockchainName: "Algorand",
1046
+ verifiedCredentialChainName: "algorand"
1047
+ },
1048
+ APTOS: {
1049
+ apiChainName: "aptos",
1050
+ blockchainName: "Aptos",
1051
+ verifiedCredentialChainName: "aptos"
1052
+ },
1053
+ BTC: {
1054
+ apiChainName: "bitcoin",
1055
+ blockchainName: "Bitcoin",
1056
+ verifiedCredentialChainName: "bip122"
1057
+ },
1058
+ COSMOS: {
1059
+ apiChainName: "cosmos",
1060
+ blockchainName: "Cosmos",
1061
+ verifiedCredentialChainName: "cosmos"
1062
+ },
1063
+ ECLIPSE: {
1064
+ apiChainName: "eclipse",
1065
+ blockchainName: "Eclipse",
1066
+ verifiedCredentialChainName: "eclipse"
1067
+ },
1068
+ EVM: {
1069
+ apiChainName: "evm",
1070
+ blockchainName: "Ethereum",
1071
+ verifiedCredentialChainName: "eip155"
1072
+ },
1073
+ FLOW: {
1074
+ apiChainName: "flow",
1075
+ blockchainName: "Flow",
1076
+ verifiedCredentialChainName: "flow"
1077
+ },
1078
+ MIDNIGHT: {
1079
+ apiChainName: "midnight",
1080
+ blockchainName: "Midnight",
1081
+ verifiedCredentialChainName: "midnight"
1082
+ },
1083
+ SOL: {
1084
+ apiChainName: "solana",
1085
+ blockchainName: "Solana",
1086
+ verifiedCredentialChainName: "solana",
1087
+ waasChainNameOverride: "SVM"
1088
+ },
1089
+ SPARK: {
1090
+ apiChainName: "spark",
1091
+ blockchainName: "Spark",
1092
+ verifiedCredentialChainName: "spark"
1093
+ },
1094
+ STARK: {
1095
+ apiChainName: "starknet",
1096
+ blockchainName: "Starknet",
1097
+ verifiedCredentialChainName: "starknet"
1098
+ },
1099
+ STELLAR: {
1100
+ apiChainName: "stellar",
1101
+ blockchainName: "Stellar",
1102
+ verifiedCredentialChainName: "stellar"
1103
+ },
1104
+ SUI: {
1105
+ apiChainName: "sui",
1106
+ blockchainName: "Sui",
1107
+ verifiedCredentialChainName: "sui"
1108
+ },
1109
+ TEMPO: {
1110
+ apiChainName: "tempo",
1111
+ blockchainName: "Tempo",
1112
+ verifiedCredentialChainName: "tempo"
1113
+ },
1114
+ TON: {
1115
+ apiChainName: "ton",
1116
+ blockchainName: "TON",
1117
+ verifiedCredentialChainName: "ton"
1118
+ },
1119
+ TRON: {
1120
+ apiChainName: "tron",
1121
+ blockchainName: "Tron",
1122
+ verifiedCredentialChainName: "tron"
1123
+ }
1124
+ };
1125
+
1126
+ //#endregion
1127
+ //#region src/utils/getChainFromVerifiedCredentialChain/getChainFromVerifiedCredentialChain.ts
1128
+ /** @instrumented */
1129
+ const getChainFromVerifiedCredentialChain = (verifiedCredentialChain) => {
1130
+ const chain = Object.keys(CHAINS_INFO_MAP).find((chain$1) => CHAINS_INFO_MAP[chain$1].verifiedCredentialChainName === verifiedCredentialChain);
1131
+ assertDefined(chain, `Unknown chain: ${verifiedCredentialChain}`);
1132
+ return chain;
1133
+ };
1134
+ const __getChainFromVerifiedCredentialChain_impl = getChainFromVerifiedCredentialChain;
1135
+ const __getChainFromVerifiedCredentialChain_wrapped = instrumentFunction({
1136
+ fn: __getChainFromVerifiedCredentialChain_impl,
1137
+ functionName: "getChainFromVerifiedCredentialChain",
1138
+ getCore: () => {
1139
+ try {
1140
+ return getCore(getDefaultClient());
1141
+ } catch {
1142
+ return;
1143
+ }
1144
+ }
1145
+ });
1146
+
1147
+ //#endregion
1148
+ //#region src/constants.ts
1149
+ const SDK_API_CORE_VERSION = dependencies["@dynamic-labs/sdk-api-core"];
1150
+ const DYNAMIC_ICONIC_SPRITE_URL = "https://iconic.dynamic-static-assets.com/icons/sprite.svg";
1151
+
1152
+ //#endregion
1153
+ //#region src/modules/waas/constants.ts
1154
+ const DEFAULT_WAAS_BASE_API_URL = "https://app.dynamicauth.com";
1155
+ const DEFAULT_WAAS_BASE_MPC_RELAY_API_URL = "https://relay.dynamicauth.com";
1156
+ const DYNAMIC_WAAS_METADATA = {
1157
+ displayName: "Dynamic WaaS",
1158
+ icon: `${DYNAMIC_ICONIC_SPRITE_URL}#dynamicwaas`,
1159
+ normalizedWalletName: "dynamicwaas"
1160
+ };
1161
+
1162
+ //#endregion
1163
+ //#region src/errors/InvalidParamError.ts
1164
+ var InvalidParamError = class extends BaseError {
1165
+ constructor(message) {
1166
+ super({
1167
+ cause: null,
1168
+ code: "invalid_param_error",
1169
+ docsUrl: null,
1170
+ name: "InvalidParamError",
1171
+ shortMessage: message
1172
+ });
1173
+ }
1174
+ };
1175
+
1176
+ //#endregion
1177
+ export { ValueMustBeDefinedError as A, name as B, __getSessionKeys_wrapped as C, extractSessionId as D, getUserAgent as E, getDefaultClient as F, setDefaultClient as I, ClientNotFoundError as L, CLIENT_SDK_NAME as M, DYNAMIC_SDK_API_VERSION as N, isCookieEnabled as O, NONCE_POOL_SIZE as P, BaseError as R, __getElevatedAccessToken_wrapped as S, DEFAULT_PII_FIELDS as T, version as V, MfaRateLimitedError as _, DYNAMIC_ICONIC_SPRITE_URL as a, InvalidExternalAuthError as b, CHAINS_INFO_MAP as c, UnauthorizedError as d, __createDeviceSignatureHeadersMiddleware_wrapped as f, SandboxMaximumThresholdReachedError as g, __getNonce_wrapped as h, DYNAMIC_WAAS_METADATA as i, randomString as j, assertDefined as k, fetchAndStoreNonces as l, __getDeviceSigner_wrapped as m, DEFAULT_WAAS_BASE_API_URL as n, SDK_API_CORE_VERSION as o, __getHeadersForNonceSignedByDeviceSigners_wrapped as p, DEFAULT_WAAS_BASE_MPC_RELAY_API_URL as r, __getChainFromVerifiedCredentialChain_wrapped as s, InvalidParamError as t, __createApiClient_wrapped as u, MfaInvalidOtpError as v, instrumentFunction as w, APIError as x, LinkCredentialError as y, getCore as z };
1178
+ //# sourceMappingURL=InvalidParamError-BDHw6nr1.native.esm.js.map