@ledgerhq/live-common 34.54.0 → 34.55.0-nightly.20251210100832
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/__tests__/test-helpers/bridge.js +1 -1
- package/lib/__tests__/test-helpers/bridge.js.map +1 -1
- package/lib/__tests__/test-helpers/environment.js +3 -0
- package/lib/__tests__/test-helpers/environment.js.map +1 -1
- package/lib/account/index.d.ts +1 -0
- package/lib/account/index.d.ts.map +1 -1
- package/lib/account/index.js +4 -1
- package/lib/account/index.js.map +1 -1
- package/lib/account/recentAddresses.d.ts +10 -0
- package/lib/account/recentAddresses.d.ts.map +1 -0
- package/lib/account/recentAddresses.js +60 -0
- package/lib/account/recentAddresses.js.map +1 -0
- package/lib/account/serialization.js +1 -1
- package/lib/account/serialization.js.map +1 -1
- package/lib/account/support.js +1 -1
- package/lib/account/support.js.map +1 -1
- package/lib/bridge/generic-alpaca/accountBridge.d.ts +1 -1
- package/lib/bridge/generic-alpaca/accountBridge.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/accountBridge.js +2 -1
- package/lib/bridge/generic-alpaca/accountBridge.js.map +1 -1
- package/lib/bridge/generic-alpaca/broadcast.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/broadcast.js +3 -3
- package/lib/bridge/generic-alpaca/broadcast.js.map +1 -1
- package/lib/bridge/generic-alpaca/currencyBridge.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/currencyBridge.js +3 -3
- package/lib/bridge/generic-alpaca/currencyBridge.js.map +1 -1
- package/lib/bridge/generic-alpaca/estimateMaxSpendable.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/estimateMaxSpendable.js +2 -1
- package/lib/bridge/generic-alpaca/estimateMaxSpendable.js.map +1 -1
- package/lib/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/getAccountShape.js +24 -8
- package/lib/bridge/generic-alpaca/getAccountShape.js.map +1 -1
- package/lib/bridge/generic-alpaca/getTransactionStatus.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/getTransactionStatus.js +16 -1
- package/lib/bridge/generic-alpaca/getTransactionStatus.js.map +1 -1
- package/lib/bridge/generic-alpaca/postSync.d.ts +16 -0
- package/lib/bridge/generic-alpaca/postSync.d.ts.map +1 -0
- package/lib/bridge/generic-alpaca/postSync.js +44 -0
- package/lib/bridge/generic-alpaca/postSync.js.map +1 -0
- package/lib/bridge/generic-alpaca/prepareTransaction.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/prepareTransaction.js +45 -4
- package/lib/bridge/generic-alpaca/prepareTransaction.js.map +1 -1
- package/lib/bridge/generic-alpaca/signOperation.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/signOperation.js +18 -2
- package/lib/bridge/generic-alpaca/signOperation.js.map +1 -1
- package/lib/bridge/generic-alpaca/signer/Eth.d.ts +2 -0
- package/lib/bridge/generic-alpaca/signer/Eth.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/signer/Eth.js +8 -1
- package/lib/bridge/generic-alpaca/signer/Eth.js.map +1 -1
- package/lib/bridge/generic-alpaca/signer/index.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/signer/index.js +7 -0
- package/lib/bridge/generic-alpaca/signer/index.js.map +1 -1
- package/lib/bridge/generic-alpaca/types.d.ts +4 -0
- package/lib/bridge/generic-alpaca/types.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/utils.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/utils.js +12 -3
- package/lib/bridge/generic-alpaca/utils.js.map +1 -1
- package/lib/bridge/impl.d.ts.map +1 -1
- package/lib/bridge/impl.js +14 -3
- package/lib/bridge/impl.js.map +1 -1
- package/lib/currencies/helpers.d.ts +1 -0
- package/lib/currencies/helpers.d.ts.map +1 -1
- package/lib/currencies/helpers.js +7 -1
- package/lib/currencies/helpers.js.map +1 -1
- package/lib/domain/getTokensWithFunds.d.ts +7 -1
- package/lib/domain/getTokensWithFunds.d.ts.map +1 -1
- package/lib/domain/getTokensWithFunds.js +15 -4
- package/lib/domain/getTokensWithFunds.js.map +1 -1
- package/lib/domain/getTotalStakeableAssets.d.ts +10 -0
- package/lib/domain/getTotalStakeableAssets.d.ts.map +1 -0
- package/lib/domain/getTotalStakeableAssets.js +35 -0
- package/lib/domain/getTotalStakeableAssets.js.map +1 -0
- package/lib/e2e/data/deviceLabelsData.d.ts.map +1 -1
- package/lib/e2e/data/deviceLabelsData.js +1 -0
- package/lib/e2e/data/deviceLabelsData.js.map +1 -1
- package/lib/e2e/data/regexes.d.ts +2 -0
- package/lib/e2e/data/regexes.d.ts.map +1 -0
- package/lib/e2e/data/regexes.js +5 -0
- package/lib/e2e/data/regexes.js.map +1 -0
- package/lib/e2e/enum/Device.d.ts +1 -0
- package/lib/e2e/enum/Device.d.ts.map +1 -1
- package/lib/e2e/enum/Device.js +1 -0
- package/lib/e2e/enum/Device.js.map +1 -1
- package/lib/e2e/families/cardano.d.ts.map +1 -1
- package/lib/e2e/families/cardano.js +29 -14
- package/lib/e2e/families/cardano.js.map +1 -1
- package/lib/e2e/index.d.ts +35 -3
- package/lib/e2e/index.d.ts.map +1 -1
- package/lib/e2e/index.js +21 -1
- package/lib/e2e/index.js.map +1 -1
- package/lib/e2e/speculos.d.ts.map +1 -1
- package/lib/e2e/speculos.js +31 -4
- package/lib/e2e/speculos.js.map +1 -1
- package/lib/e2e/speculosAppVersion.d.ts.map +1 -1
- package/lib/e2e/speculosAppVersion.js +6 -2
- package/lib/e2e/speculosAppVersion.js.map +1 -1
- package/lib/e2e/swap.d.ts.map +1 -1
- package/lib/e2e/swap.js +7 -6
- package/lib/e2e/swap.js.map +1 -1
- package/lib/env.react.d.ts +1 -1
- package/lib/env.react.d.ts.map +1 -1
- package/lib/exchange/swap/api/v5/fetchCurrencyFrom.js +1 -1
- package/lib/exchange/swap/api/v5/fetchCurrencyFrom.js.map +1 -1
- package/lib/exchange/swap/getIncompatibleCurrencyKeys.d.ts.map +1 -1
- package/lib/exchange/swap/getIncompatibleCurrencyKeys.js +4 -0
- package/lib/exchange/swap/getIncompatibleCurrencyKeys.js.map +1 -1
- package/lib/exchange/swap/postSwapState.d.ts.map +1 -1
- package/lib/exchange/swap/postSwapState.js +10 -6
- package/lib/exchange/swap/postSwapState.js.map +1 -1
- package/lib/exchange/swap/transactionStrategies.d.ts +3 -2
- package/lib/exchange/swap/transactionStrategies.d.ts.map +1 -1
- package/lib/exchange/swap/transactionStrategies.js +26 -7
- package/lib/exchange/swap/transactionStrategies.js.map +1 -1
- package/lib/exchange/swap/types.d.ts +3 -1
- package/lib/exchange/swap/types.d.ts.map +1 -1
- package/lib/families/bitcoin/walletApiAdapter.d.ts.map +1 -1
- package/lib/families/bitcoin/walletApiAdapter.js +3 -0
- package/lib/families/bitcoin/walletApiAdapter.js.map +1 -1
- package/lib/families/canton/config.d.ts.map +1 -1
- package/lib/families/canton/config.js +4 -4
- package/lib/families/canton/config.js.map +1 -1
- package/lib/families/canton/react.d.ts +2 -0
- package/lib/families/canton/react.d.ts.map +1 -1
- package/lib/families/canton/react.js +40 -1
- package/lib/families/canton/react.js.map +1 -1
- package/lib/families/celo/setup.d.ts.map +1 -1
- package/lib/families/celo/setup.js +11 -0
- package/lib/families/celo/setup.js.map +1 -1
- package/lib/families/evm/bridge/mock.d.ts +1 -0
- package/lib/families/evm/bridge/mock.d.ts.map +1 -1
- package/lib/families/evm/bridge/mock.js +12 -0
- package/lib/families/evm/bridge/mock.js.map +1 -1
- package/lib/families/evm/setup.d.ts +1 -4
- package/lib/families/evm/setup.d.ts.map +1 -1
- package/lib/families/evm/setup.js +1 -8
- package/lib/families/evm/setup.js.map +1 -1
- package/lib/families/evm/walletApiAdapter.d.ts +7 -0
- package/lib/families/evm/walletApiAdapter.d.ts.map +1 -1
- package/lib/families/evm/walletApiAdapter.js +36 -2
- package/lib/families/evm/walletApiAdapter.js.map +1 -1
- package/lib/families/hedera/react.d.ts +6 -0
- package/lib/families/hedera/react.d.ts.map +1 -0
- package/lib/families/hedera/react.js +50 -0
- package/lib/families/hedera/react.js.map +1 -0
- package/lib/families/polkadot/config.js +1 -1
- package/lib/families/polkadot/config.js.map +1 -1
- package/lib/families/stacks/constants.d.ts +1 -1
- package/lib/families/stacks/constants.d.ts.map +1 -1
- package/lib/families/stacks/constants.js +1 -1
- package/lib/families/stacks/constants.js.map +1 -1
- package/lib/featureFlags/defaultFeatures.d.ts +2 -0
- package/lib/featureFlags/defaultFeatures.d.ts.map +1 -1
- package/lib/featureFlags/defaultFeatures.js +22 -1
- package/lib/featureFlags/defaultFeatures.js.map +1 -1
- package/lib/featureFlags/firebaseFeatureFlags.js +1 -1
- package/lib/featureFlags/firebaseFeatureFlags.js.map +1 -1
- package/lib/featureFlags/stakePrograms/index.js +4 -4
- package/lib/featureFlags/stakePrograms/index.js.map +1 -1
- package/lib/featureFlags/useFeature.d.ts +1 -1
- package/lib/featureFlags/useFeature.d.ts.map +1 -1
- package/lib/featureFlags/useHasOverriddenFeatureFlags.js +1 -1
- package/lib/featureFlags/useHasOverriddenFeatureFlags.js.map +1 -1
- package/lib/generated/bridge/js.d.ts +0 -1
- package/lib/generated/bridge/js.d.ts.map +1 -1
- package/lib/generated/bridge/js.js +30 -32
- package/lib/generated/bridge/js.js.map +1 -1
- package/lib/generated/bridge/mock.d.ts +1 -0
- package/lib/generated/bridge/mock.d.ts.map +1 -1
- package/lib/helpers/cryptoIconSize.d.ts +3 -0
- package/lib/helpers/cryptoIconSize.d.ts.map +1 -0
- package/lib/helpers/cryptoIconSize.js +40 -0
- package/lib/helpers/cryptoIconSize.js.map +1 -0
- package/lib/helpers.d.ts +1 -0
- package/lib/helpers.d.ts.map +1 -1
- package/lib/helpers.js +15 -0
- package/lib/helpers.js.map +1 -1
- package/lib/hooks/useHtmlLinkSegments.d.ts +19 -0
- package/lib/hooks/useHtmlLinkSegments.d.ts.map +1 -0
- package/lib/hooks/useHtmlLinkSegments.js +128 -0
- package/lib/hooks/useHtmlLinkSegments.js.map +1 -0
- package/lib/hw/getAppAndVersion.d.ts +3 -1
- package/lib/hw/getAppAndVersion.d.ts.map +1 -1
- package/lib/hw/getAppAndVersion.js +2 -2
- package/lib/hw/getAppAndVersion.js.map +1 -1
- package/lib/hw/getBitcoinLikeInfo.js +1 -1
- package/lib/hw/getBitcoinLikeInfo.js.map +1 -1
- package/lib/load/speculos.d.ts.map +1 -1
- package/lib/load/speculos.js +1 -0
- package/lib/load/speculos.js.map +1 -1
- package/lib/mock/account.js +1 -1
- package/lib/mock/account.js.map +1 -1
- package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.d.ts.map +1 -1
- package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js +6 -0
- package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js.map +1 -1
- package/lib/operation.d.ts.map +1 -1
- package/lib/operation.js +7 -2
- package/lib/operation.js.map +1 -1
- package/lib/postOnboarding/reducer.d.ts +2 -0
- package/lib/postOnboarding/reducer.d.ts.map +1 -1
- package/lib/wallet-api/Exchange/SwapError.d.ts +93 -0
- package/lib/wallet-api/Exchange/SwapError.d.ts.map +1 -0
- package/lib/wallet-api/Exchange/SwapError.js +142 -0
- package/lib/wallet-api/Exchange/SwapError.js.map +1 -0
- package/lib/wallet-api/Exchange/handleSwapErrors.d.ts +40 -0
- package/lib/wallet-api/Exchange/handleSwapErrors.d.ts.map +1 -0
- package/lib/wallet-api/Exchange/handleSwapErrors.js +112 -0
- package/lib/wallet-api/Exchange/handleSwapErrors.js.map +1 -0
- package/lib/wallet-api/Exchange/index.d.ts +4 -0
- package/lib/wallet-api/Exchange/index.d.ts.map +1 -0
- package/lib/wallet-api/Exchange/index.js +27 -0
- package/lib/wallet-api/Exchange/index.js.map +1 -0
- package/lib/wallet-api/Exchange/parser.d.ts +46 -0
- package/lib/wallet-api/Exchange/parser.d.ts.map +1 -0
- package/lib/wallet-api/Exchange/parser.js +97 -0
- package/lib/wallet-api/Exchange/parser.js.map +1 -0
- package/lib/wallet-api/Exchange/server.d.ts.map +1 -1
- package/lib/wallet-api/Exchange/server.js +227 -174
- package/lib/wallet-api/Exchange/server.js.map +1 -1
- package/lib/wallet-api/Exchange/tracking.d.ts +7 -6
- package/lib/wallet-api/Exchange/tracking.d.ts.map +1 -1
- package/lib/wallet-api/Exchange/tracking.js +52 -13
- package/lib/wallet-api/Exchange/tracking.js.map +1 -1
- package/lib/wallet-api/constants.d.ts +1 -1
- package/lib/wallet-api/logic.d.ts +1 -1
- package/lib/wallet-api/logic.d.ts.map +1 -1
- package/lib/wallet-api/logic.js +5 -5
- package/lib/wallet-api/logic.js.map +1 -1
- package/lib/wallet-api/react.d.ts.map +1 -1
- package/lib/wallet-api/react.js +9 -6
- package/lib/wallet-api/react.js.map +1 -1
- package/lib/wallet-api/tracking.d.ts +5 -5
- package/lib/wallet-api/tracking.d.ts.map +1 -1
- package/lib/wallet-api/tracking.js +30 -10
- package/lib/wallet-api/tracking.js.map +1 -1
- package/lib/wallet-api/useDappLogic.d.ts.map +1 -1
- package/lib/wallet-api/useDappLogic.js +31 -20
- package/lib/wallet-api/useDappLogic.js.map +1 -1
- package/lib/wallet-api/utils/extractDappURLFromManifest.js +3 -3
- package/lib/wallet-api/utils/extractDappURLFromManifest.js.map +1 -1
- package/lib/wallet-api/utils/extractURLFromManifest.js +1 -1
- package/lib/wallet-api/utils/extractURLFromManifest.js.map +1 -1
- package/lib/walletSync/getEnvironmentParams.js +6 -6
- package/lib/walletSync/getEnvironmentParams.js.map +1 -1
- package/lib-es/__tests__/test-helpers/bridge.js +1 -1
- package/lib-es/__tests__/test-helpers/bridge.js.map +1 -1
- package/lib-es/__tests__/test-helpers/environment.js +3 -0
- package/lib-es/__tests__/test-helpers/environment.js.map +1 -1
- package/lib-es/account/index.d.ts +1 -0
- package/lib-es/account/index.d.ts.map +1 -1
- package/lib-es/account/index.js +1 -0
- package/lib-es/account/index.js.map +1 -1
- package/lib-es/account/recentAddresses.d.ts +10 -0
- package/lib-es/account/recentAddresses.d.ts.map +1 -0
- package/lib-es/account/recentAddresses.js +55 -0
- package/lib-es/account/recentAddresses.js.map +1 -0
- package/lib-es/account/serialization.js +1 -1
- package/lib-es/account/serialization.js.map +1 -1
- package/lib-es/account/support.js +1 -1
- package/lib-es/account/support.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/accountBridge.d.ts +1 -1
- package/lib-es/bridge/generic-alpaca/accountBridge.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/accountBridge.js +2 -1
- package/lib-es/bridge/generic-alpaca/accountBridge.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/broadcast.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/broadcast.js +3 -3
- package/lib-es/bridge/generic-alpaca/broadcast.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/currencyBridge.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/currencyBridge.js +3 -3
- package/lib-es/bridge/generic-alpaca/currencyBridge.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.js +2 -1
- package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/getAccountShape.js +24 -8
- package/lib-es/bridge/generic-alpaca/getAccountShape.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/getTransactionStatus.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/getTransactionStatus.js +16 -1
- package/lib-es/bridge/generic-alpaca/getTransactionStatus.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/postSync.d.ts +16 -0
- package/lib-es/bridge/generic-alpaca/postSync.d.ts.map +1 -0
- package/lib-es/bridge/generic-alpaca/postSync.js +37 -0
- package/lib-es/bridge/generic-alpaca/postSync.js.map +1 -0
- package/lib-es/bridge/generic-alpaca/prepareTransaction.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/prepareTransaction.js +45 -4
- package/lib-es/bridge/generic-alpaca/prepareTransaction.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/signOperation.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/signOperation.js +18 -2
- package/lib-es/bridge/generic-alpaca/signOperation.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/signer/Eth.d.ts +2 -0
- package/lib-es/bridge/generic-alpaca/signer/Eth.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/signer/Eth.js +4 -0
- package/lib-es/bridge/generic-alpaca/signer/Eth.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/signer/index.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/signer/index.js +7 -0
- package/lib-es/bridge/generic-alpaca/signer/index.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/types.d.ts +4 -0
- package/lib-es/bridge/generic-alpaca/types.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/utils.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/utils.js +12 -3
- package/lib-es/bridge/generic-alpaca/utils.js.map +1 -1
- package/lib-es/bridge/impl.d.ts.map +1 -1
- package/lib-es/bridge/impl.js +14 -3
- package/lib-es/bridge/impl.js.map +1 -1
- package/lib-es/currencies/helpers.d.ts +1 -0
- package/lib-es/currencies/helpers.d.ts.map +1 -1
- package/lib-es/currencies/helpers.js +5 -0
- package/lib-es/currencies/helpers.js.map +1 -1
- package/lib-es/domain/getTokensWithFunds.d.ts +7 -1
- package/lib-es/domain/getTokensWithFunds.d.ts.map +1 -1
- package/lib-es/domain/getTokensWithFunds.js +13 -3
- package/lib-es/domain/getTokensWithFunds.js.map +1 -1
- package/lib-es/domain/getTotalStakeableAssets.d.ts +10 -0
- package/lib-es/domain/getTotalStakeableAssets.d.ts.map +1 -0
- package/lib-es/domain/getTotalStakeableAssets.js +31 -0
- package/lib-es/domain/getTotalStakeableAssets.js.map +1 -0
- package/lib-es/e2e/data/deviceLabelsData.d.ts.map +1 -1
- package/lib-es/e2e/data/deviceLabelsData.js +1 -0
- package/lib-es/e2e/data/deviceLabelsData.js.map +1 -1
- package/lib-es/e2e/data/regexes.d.ts +2 -0
- package/lib-es/e2e/data/regexes.d.ts.map +1 -0
- package/lib-es/e2e/data/regexes.js +2 -0
- package/lib-es/e2e/data/regexes.js.map +1 -0
- package/lib-es/e2e/enum/Device.d.ts +1 -0
- package/lib-es/e2e/enum/Device.d.ts.map +1 -1
- package/lib-es/e2e/enum/Device.js +1 -0
- package/lib-es/e2e/enum/Device.js.map +1 -1
- package/lib-es/e2e/families/cardano.d.ts.map +1 -1
- package/lib-es/e2e/families/cardano.js +29 -14
- package/lib-es/e2e/families/cardano.js.map +1 -1
- package/lib-es/e2e/index.d.ts +35 -3
- package/lib-es/e2e/index.d.ts.map +1 -1
- package/lib-es/e2e/index.js +16 -0
- package/lib-es/e2e/index.js.map +1 -1
- package/lib-es/e2e/speculos.d.ts.map +1 -1
- package/lib-es/e2e/speculos.js +31 -4
- package/lib-es/e2e/speculos.js.map +1 -1
- package/lib-es/e2e/speculosAppVersion.d.ts.map +1 -1
- package/lib-es/e2e/speculosAppVersion.js +6 -2
- package/lib-es/e2e/speculosAppVersion.js.map +1 -1
- package/lib-es/e2e/swap.d.ts.map +1 -1
- package/lib-es/e2e/swap.js +7 -6
- package/lib-es/e2e/swap.js.map +1 -1
- package/lib-es/env.react.d.ts +1 -1
- package/lib-es/env.react.d.ts.map +1 -1
- package/lib-es/exchange/swap/api/v5/fetchCurrencyFrom.js +1 -1
- package/lib-es/exchange/swap/api/v5/fetchCurrencyFrom.js.map +1 -1
- package/lib-es/exchange/swap/getIncompatibleCurrencyKeys.d.ts.map +1 -1
- package/lib-es/exchange/swap/getIncompatibleCurrencyKeys.js +4 -0
- package/lib-es/exchange/swap/getIncompatibleCurrencyKeys.js.map +1 -1
- package/lib-es/exchange/swap/postSwapState.d.ts.map +1 -1
- package/lib-es/exchange/swap/postSwapState.js +10 -6
- package/lib-es/exchange/swap/postSwapState.js.map +1 -1
- package/lib-es/exchange/swap/transactionStrategies.d.ts +3 -2
- package/lib-es/exchange/swap/transactionStrategies.d.ts.map +1 -1
- package/lib-es/exchange/swap/transactionStrategies.js +26 -7
- package/lib-es/exchange/swap/transactionStrategies.js.map +1 -1
- package/lib-es/exchange/swap/types.d.ts +3 -1
- package/lib-es/exchange/swap/types.d.ts.map +1 -1
- package/lib-es/families/bitcoin/walletApiAdapter.d.ts.map +1 -1
- package/lib-es/families/bitcoin/walletApiAdapter.js +3 -0
- package/lib-es/families/bitcoin/walletApiAdapter.js.map +1 -1
- package/lib-es/families/canton/config.d.ts.map +1 -1
- package/lib-es/families/canton/config.js +4 -4
- package/lib-es/families/canton/config.js.map +1 -1
- package/lib-es/families/canton/react.d.ts +2 -0
- package/lib-es/families/canton/react.d.ts.map +1 -1
- package/lib-es/families/canton/react.js +38 -1
- package/lib-es/families/canton/react.js.map +1 -1
- package/lib-es/families/celo/setup.d.ts.map +1 -1
- package/lib-es/families/celo/setup.js +11 -0
- package/lib-es/families/celo/setup.js.map +1 -1
- package/lib-es/families/evm/bridge/mock.d.ts +1 -0
- package/lib-es/families/evm/bridge/mock.d.ts.map +1 -1
- package/lib-es/families/evm/bridge/mock.js +12 -0
- package/lib-es/families/evm/bridge/mock.js.map +1 -1
- package/lib-es/families/evm/setup.d.ts +1 -4
- package/lib-es/families/evm/setup.d.ts.map +1 -1
- package/lib-es/families/evm/setup.js +2 -8
- package/lib-es/families/evm/setup.js.map +1 -1
- package/lib-es/families/evm/walletApiAdapter.d.ts +7 -0
- package/lib-es/families/evm/walletApiAdapter.d.ts.map +1 -1
- package/lib-es/families/evm/walletApiAdapter.js +30 -1
- package/lib-es/families/evm/walletApiAdapter.js.map +1 -1
- package/lib-es/families/hedera/react.d.ts +6 -0
- package/lib-es/families/hedera/react.d.ts.map +1 -0
- package/lib-es/families/hedera/react.js +41 -0
- package/lib-es/families/hedera/react.js.map +1 -0
- package/lib-es/families/polkadot/config.js +1 -1
- package/lib-es/families/polkadot/config.js.map +1 -1
- package/lib-es/families/stacks/constants.d.ts +1 -1
- package/lib-es/families/stacks/constants.d.ts.map +1 -1
- package/lib-es/families/stacks/constants.js +1 -1
- package/lib-es/families/stacks/constants.js.map +1 -1
- package/lib-es/featureFlags/defaultFeatures.d.ts +2 -0
- package/lib-es/featureFlags/defaultFeatures.d.ts.map +1 -1
- package/lib-es/featureFlags/defaultFeatures.js +22 -1
- package/lib-es/featureFlags/defaultFeatures.js.map +1 -1
- package/lib-es/featureFlags/firebaseFeatureFlags.js +1 -1
- package/lib-es/featureFlags/firebaseFeatureFlags.js.map +1 -1
- package/lib-es/featureFlags/stakePrograms/index.js +4 -4
- package/lib-es/featureFlags/stakePrograms/index.js.map +1 -1
- package/lib-es/featureFlags/useFeature.d.ts +1 -1
- package/lib-es/featureFlags/useFeature.d.ts.map +1 -1
- package/lib-es/featureFlags/useHasOverriddenFeatureFlags.js +1 -1
- package/lib-es/featureFlags/useHasOverriddenFeatureFlags.js.map +1 -1
- package/lib-es/generated/bridge/js.d.ts +0 -1
- package/lib-es/generated/bridge/js.d.ts.map +1 -1
- package/lib-es/generated/bridge/js.js +0 -2
- package/lib-es/generated/bridge/js.js.map +1 -1
- package/lib-es/generated/bridge/mock.d.ts +1 -0
- package/lib-es/generated/bridge/mock.d.ts.map +1 -1
- package/lib-es/helpers/cryptoIconSize.d.ts +3 -0
- package/lib-es/helpers/cryptoIconSize.d.ts.map +1 -0
- package/lib-es/helpers/cryptoIconSize.js +35 -0
- package/lib-es/helpers/cryptoIconSize.js.map +1 -0
- package/lib-es/helpers.d.ts +1 -0
- package/lib-es/helpers.d.ts.map +1 -1
- package/lib-es/helpers.js +1 -0
- package/lib-es/helpers.js.map +1 -1
- package/lib-es/hooks/useHtmlLinkSegments.d.ts +19 -0
- package/lib-es/hooks/useHtmlLinkSegments.d.ts.map +1 -0
- package/lib-es/hooks/useHtmlLinkSegments.js +121 -0
- package/lib-es/hooks/useHtmlLinkSegments.js.map +1 -0
- package/lib-es/hw/getAppAndVersion.d.ts +3 -1
- package/lib-es/hw/getAppAndVersion.d.ts.map +1 -1
- package/lib-es/hw/getAppAndVersion.js +2 -2
- package/lib-es/hw/getAppAndVersion.js.map +1 -1
- package/lib-es/hw/getBitcoinLikeInfo.js +1 -1
- package/lib-es/hw/getBitcoinLikeInfo.js.map +1 -1
- package/lib-es/load/speculos.d.ts.map +1 -1
- package/lib-es/load/speculos.js +1 -0
- package/lib-es/load/speculos.js.map +1 -1
- package/lib-es/mock/account.js +1 -1
- package/lib-es/mock/account.js.map +1 -1
- package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.d.ts.map +1 -1
- package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js +6 -0
- package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js.map +1 -1
- package/lib-es/operation.d.ts.map +1 -1
- package/lib-es/operation.js +7 -2
- package/lib-es/operation.js.map +1 -1
- package/lib-es/postOnboarding/reducer.d.ts +2 -0
- package/lib-es/postOnboarding/reducer.d.ts.map +1 -1
- package/lib-es/wallet-api/Exchange/SwapError.d.ts +93 -0
- package/lib-es/wallet-api/Exchange/SwapError.d.ts.map +1 -0
- package/lib-es/wallet-api/Exchange/SwapError.js +128 -0
- package/lib-es/wallet-api/Exchange/SwapError.js.map +1 -0
- package/lib-es/wallet-api/Exchange/handleSwapErrors.d.ts +40 -0
- package/lib-es/wallet-api/Exchange/handleSwapErrors.d.ts.map +1 -0
- package/lib-es/wallet-api/Exchange/handleSwapErrors.js +106 -0
- package/lib-es/wallet-api/Exchange/handleSwapErrors.js.map +1 -0
- package/lib-es/wallet-api/Exchange/index.d.ts +4 -0
- package/lib-es/wallet-api/Exchange/index.d.ts.map +1 -0
- package/lib-es/wallet-api/Exchange/index.js +7 -0
- package/lib-es/wallet-api/Exchange/index.js.map +1 -0
- package/lib-es/wallet-api/Exchange/parser.d.ts +46 -0
- package/lib-es/wallet-api/Exchange/parser.d.ts.map +1 -0
- package/lib-es/wallet-api/Exchange/parser.js +90 -0
- package/lib-es/wallet-api/Exchange/parser.js.map +1 -0
- package/lib-es/wallet-api/Exchange/server.d.ts.map +1 -1
- package/lib-es/wallet-api/Exchange/server.js +224 -174
- package/lib-es/wallet-api/Exchange/server.js.map +1 -1
- package/lib-es/wallet-api/Exchange/tracking.d.ts +7 -6
- package/lib-es/wallet-api/Exchange/tracking.d.ts.map +1 -1
- package/lib-es/wallet-api/Exchange/tracking.js +52 -13
- package/lib-es/wallet-api/Exchange/tracking.js.map +1 -1
- package/lib-es/wallet-api/constants.d.ts +1 -1
- package/lib-es/wallet-api/logic.d.ts +1 -1
- package/lib-es/wallet-api/logic.d.ts.map +1 -1
- package/lib-es/wallet-api/logic.js +5 -5
- package/lib-es/wallet-api/logic.js.map +1 -1
- package/lib-es/wallet-api/react.d.ts.map +1 -1
- package/lib-es/wallet-api/react.js +9 -6
- package/lib-es/wallet-api/react.js.map +1 -1
- package/lib-es/wallet-api/tracking.d.ts +5 -5
- package/lib-es/wallet-api/tracking.d.ts.map +1 -1
- package/lib-es/wallet-api/tracking.js +30 -10
- package/lib-es/wallet-api/tracking.js.map +1 -1
- package/lib-es/wallet-api/useDappLogic.d.ts.map +1 -1
- package/lib-es/wallet-api/useDappLogic.js +31 -20
- package/lib-es/wallet-api/useDappLogic.js.map +1 -1
- package/lib-es/wallet-api/utils/extractDappURLFromManifest.js +3 -3
- package/lib-es/wallet-api/utils/extractDappURLFromManifest.js.map +1 -1
- package/lib-es/wallet-api/utils/extractURLFromManifest.js +1 -1
- package/lib-es/wallet-api/utils/extractURLFromManifest.js.map +1 -1
- package/lib-es/walletSync/getEnvironmentParams.js +6 -6
- package/lib-es/walletSync/getEnvironmentParams.js.map +1 -1
- package/package.json +82 -90
- package/src/__tests__/test-helpers/bridge.ts +1 -1
- package/src/__tests__/test-helpers/environment.ts +3 -0
- package/src/account/index.ts +6 -0
- package/src/account/recentAddresses.test.ts +104 -0
- package/src/account/recentAddresses.ts +84 -0
- package/src/account/serialization.ts +1 -1
- package/src/account/support.ts +1 -1
- package/src/bridge/generic-alpaca/accountBridge.ts +3 -2
- package/src/bridge/generic-alpaca/broadcast.ts +6 -3
- package/src/bridge/generic-alpaca/currencyBridge.ts +3 -3
- package/src/bridge/generic-alpaca/estimateMaxSpendable.ts +2 -1
- package/src/bridge/generic-alpaca/getAccountShape.ts +36 -13
- package/src/bridge/generic-alpaca/getTransactionStatus.ts +16 -1
- package/src/bridge/generic-alpaca/postSync.test.ts +97 -0
- package/src/bridge/generic-alpaca/postSync.ts +42 -0
- package/src/bridge/generic-alpaca/prepareTransaction.ts +51 -10
- package/src/bridge/generic-alpaca/signOperation.ts +18 -2
- package/src/bridge/generic-alpaca/signer/Eth.ts +5 -1
- package/src/bridge/generic-alpaca/signer/index.ts +7 -0
- package/src/bridge/generic-alpaca/tests/getAccountShape.test.ts +43 -10
- package/src/bridge/generic-alpaca/tests/prepareTransaction.test.ts +74 -0
- package/src/bridge/generic-alpaca/types.ts +4 -0
- package/src/bridge/generic-alpaca/utils.test.ts +4 -0
- package/src/bridge/generic-alpaca/utils.ts +15 -3
- package/src/bridge/impl.ts +16 -3
- package/src/currencies/helpers.test.ts +10 -1
- package/src/currencies/helpers.ts +6 -0
- package/src/domain/getTokensWithFunds.ts +18 -5
- package/src/domain/getTotalStakeableAssets.test.ts +267 -0
- package/src/domain/getTotalStakeableAssets.ts +47 -0
- package/src/e2e/data/deviceLabelsData.ts +1 -0
- package/src/e2e/data/regexes.ts +1 -0
- package/src/e2e/enum/Device.ts +1 -0
- package/src/e2e/families/cardano.ts +32 -14
- package/src/e2e/index.ts +20 -0
- package/src/e2e/speculos.ts +35 -4
- package/src/e2e/speculosAppVersion.ts +8 -2
- package/src/e2e/swap.ts +8 -7
- package/src/exchange/swap/api/v5/fetchCurrencyFrom.ts +1 -1
- package/src/exchange/swap/getIncompatibleCurrencyKeys.ts +4 -0
- package/src/exchange/swap/postSwapState.ts +10 -5
- package/src/exchange/swap/transactionStrategies.ts +30 -7
- package/src/exchange/swap/types.ts +3 -1
- package/src/families/bitcoin/walletApiAdapter.test.ts +36 -0
- package/src/families/bitcoin/walletApiAdapter.ts +4 -0
- package/src/families/canton/config.ts +5 -4
- package/src/families/canton/react.test.ts +147 -0
- package/src/families/canton/react.ts +45 -1
- package/src/families/celo/setup.ts +12 -0
- package/src/families/cosmos/datasets/__snapshots__/cosmos.integration.test.ts.snap +73 -4
- package/src/families/cosmos/datasets/__snapshots__/cryptoOrg.integration.test.ts.snap +2 -2
- package/src/families/cosmos/datasets/__snapshots__/injective.integration.test.ts.snap +2 -2
- package/src/families/cosmos/datasets/__snapshots__/mantra.integration.test.ts.snap +2 -2
- package/src/families/cosmos/datasets/__snapshots__/osmosis.integration.test.ts.snap +2 -2
- package/src/families/cosmos/datasets/__snapshots__/persistence.integration.test.ts.snap +4 -4
- package/src/families/cosmos/datasets/__snapshots__/stargaze.integration.test.ts.snap +2 -2
- package/src/families/evm/bridge/mock.ts +14 -0
- package/src/families/evm/setup.ts +3 -22
- package/src/families/evm/walletApiAdapter.ts +33 -1
- package/src/families/hedera/__snapshots__/bridge.integration.test.ts.snap +278 -17
- package/src/families/hedera/react.test.ts +272 -0
- package/src/families/hedera/react.ts +63 -0
- package/src/families/polkadot/__snapshots__/bridge.integration.test.ts.snap +6 -3653
- package/src/families/polkadot/config.ts +1 -1
- package/src/families/stacks/__snapshots__/bridge.integration.test.ts.snap +1537 -18
- package/src/families/stacks/__tests__/sync.integration.test.ts +2 -2
- package/src/families/stacks/constants.ts +1 -1
- package/src/families/stellar/__snapshots__/bridge.integration.test.ts.snap +9 -9
- package/src/featureFlags/defaultFeatures.ts +22 -1
- package/src/featureFlags/firebaseFeatureFlags.ts +1 -1
- package/src/featureFlags/stakePrograms/index.ts +4 -4
- package/src/featureFlags/useHasOverriddenFeatureFlags.ts +1 -1
- package/src/generated/bridge/js.ts +0 -2
- package/src/helpers/cryptoIconSize.ts +25 -0
- package/src/helpers.ts +2 -0
- package/src/hooks/__tests__/useHtmlLinkSegments.test.ts +105 -0
- package/src/hooks/useHtmlLinkSegments.ts +158 -0
- package/src/hw/getAppAndVersion.ts +2 -1
- package/src/hw/getBitcoinLikeInfo.ts +1 -1
- package/src/load/speculos.ts +1 -0
- package/src/mock/account.ts +1 -1
- package/src/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.ts +6 -0
- package/src/operation.ts +10 -2
- package/src/wallet-api/Exchange/SwapError.test.ts +126 -0
- package/src/wallet-api/Exchange/SwapError.ts +159 -0
- package/src/wallet-api/Exchange/handleSwapErrors.test.ts +46 -0
- package/src/wallet-api/Exchange/handleSwapErrors.ts +161 -0
- package/src/wallet-api/Exchange/index.ts +26 -0
- package/src/wallet-api/Exchange/parser.test.ts +86 -0
- package/src/wallet-api/Exchange/parser.ts +119 -0
- package/src/wallet-api/Exchange/server.ts +289 -232
- package/src/wallet-api/Exchange/tracking.ts +56 -13
- package/src/wallet-api/logic.ts +5 -4
- package/src/wallet-api/react.ts +10 -5
- package/src/wallet-api/tracking.ts +30 -10
- package/src/wallet-api/useDappLogic.ts +32 -20
- package/src/wallet-api/utils/extractDappURLFromManifest.ts +3 -3
- package/src/wallet-api/utils/extractURLFromManifest.ts +1 -1
- package/src/walletSync/getEnvironmentParams.ts +6 -6
- package/lib/currencies/cryptoIcons.d.ts +0 -3
- package/lib/currencies/cryptoIcons.d.ts.map +0 -1
- package/lib/currencies/cryptoIcons.js +0 -24
- package/lib/currencies/cryptoIcons.js.map +0 -1
- package/lib/react.d.ts +0 -16
- package/lib/react.d.ts.map +0 -1
- package/lib/react.js +0 -64
- package/lib/react.js.map +0 -1
- package/lib/reactNative.d.ts +0 -16
- package/lib/reactNative.d.ts.map +0 -1
- package/lib/reactNative.js +0 -43
- package/lib/reactNative.js.map +0 -1
- package/lib-es/currencies/cryptoIcons.d.ts +0 -3
- package/lib-es/currencies/cryptoIcons.d.ts.map +0 -1
- package/lib-es/currencies/cryptoIcons.js +0 -20
- package/lib-es/currencies/cryptoIcons.js.map +0 -1
- package/lib-es/react.d.ts +0 -16
- package/lib-es/react.d.ts.map +0 -1
- package/lib-es/react.js +0 -33
- package/lib-es/react.js.map +0 -1
- package/lib-es/reactNative.d.ts +0 -16
- package/lib-es/reactNative.d.ts.map +0 -1
- package/lib-es/reactNative.js +0 -15
- package/lib-es/reactNative.js.map +0 -1
- package/react.js +0 -1
- package/reactNative.js +0 -1
- package/src/currencies/cryptoIcons.test.ts +0 -54
- package/src/currencies/cryptoIcons.ts +0 -21
- package/src/react.tsx +0 -43
- package/src/reactNative.ts +0 -23
- package/src/reactNativeSvg.d.ts +0 -19
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
/* eslint-env jest */
|
|
2
|
+
import {
|
|
3
|
+
IgnoredSignatureStepError,
|
|
4
|
+
ListAccountError,
|
|
5
|
+
ListCurrencyError,
|
|
6
|
+
NonceStepError,
|
|
7
|
+
NotEnoughFunds,
|
|
8
|
+
PayloadStepError,
|
|
9
|
+
PayinExtraIdError,
|
|
10
|
+
SignatureStepError,
|
|
11
|
+
SwapError,
|
|
12
|
+
UnknownAccountError,
|
|
13
|
+
} from "./SwapError";
|
|
14
|
+
|
|
15
|
+
describe("SwapError", () => {
|
|
16
|
+
it("captures nested error metadata", () => {
|
|
17
|
+
const nested = new Error("payload failed");
|
|
18
|
+
Object.assign(nested, { code: "E500" });
|
|
19
|
+
|
|
20
|
+
const error = new SwapError("swap999", nested);
|
|
21
|
+
|
|
22
|
+
expect(error).toBeInstanceOf(SwapError);
|
|
23
|
+
expect(error.cause.swapCode).toBe("swap999");
|
|
24
|
+
expect(error.cause.message).toBe(String(nested));
|
|
25
|
+
expect(error.cause.code).toBe("E500");
|
|
26
|
+
expect(error.message).toBe("payload failed");
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
it("defaults to swap000 when no code provided", () => {
|
|
30
|
+
const error = new SwapError();
|
|
31
|
+
|
|
32
|
+
expect(error.cause.swapCode).toBe("swap000");
|
|
33
|
+
expect(error.message).toBe("undefined");
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
type DerivedErrorCase = {
|
|
38
|
+
label: string;
|
|
39
|
+
create: (nested?: Error) => SwapError;
|
|
40
|
+
swapCode: string;
|
|
41
|
+
name: string;
|
|
42
|
+
propagatesMessage?: boolean;
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
const DERIVED_ERROR_CASES: DerivedErrorCase[] = [
|
|
46
|
+
{
|
|
47
|
+
label: "NonceStepError",
|
|
48
|
+
create: nested => new NonceStepError(nested),
|
|
49
|
+
swapCode: "swap001",
|
|
50
|
+
name: "NonceStepError",
|
|
51
|
+
propagatesMessage: true,
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
label: "PayloadStepError",
|
|
55
|
+
create: nested => new PayloadStepError(nested),
|
|
56
|
+
swapCode: "swap002",
|
|
57
|
+
name: "PayloadStepError",
|
|
58
|
+
propagatesMessage: true,
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
label: "SignatureStepError",
|
|
62
|
+
create: nested => new SignatureStepError(nested),
|
|
63
|
+
swapCode: "swap003",
|
|
64
|
+
name: "SignatureStepError",
|
|
65
|
+
propagatesMessage: true,
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
label: "IgnoredSignatureStepError",
|
|
69
|
+
create: nested => new IgnoredSignatureStepError(nested),
|
|
70
|
+
swapCode: "swap003Ignored",
|
|
71
|
+
name: "SignatureStepError",
|
|
72
|
+
propagatesMessage: true,
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
label: "NotEnoughFunds",
|
|
76
|
+
create: () => new NotEnoughFunds(),
|
|
77
|
+
swapCode: "swap004",
|
|
78
|
+
name: "NotEnoughFunds",
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
label: "ListAccountError",
|
|
82
|
+
create: nested => new ListAccountError(nested),
|
|
83
|
+
swapCode: "swap005",
|
|
84
|
+
name: "ListAccountError",
|
|
85
|
+
propagatesMessage: true,
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
label: "ListCurrencyError",
|
|
89
|
+
create: nested => new ListCurrencyError(nested),
|
|
90
|
+
swapCode: "swap006",
|
|
91
|
+
name: "ListCurrencyError",
|
|
92
|
+
propagatesMessage: true,
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
label: "UnknownAccountError",
|
|
96
|
+
create: nested => new UnknownAccountError(nested),
|
|
97
|
+
swapCode: "swap007",
|
|
98
|
+
name: "UnknownAccountError",
|
|
99
|
+
propagatesMessage: true,
|
|
100
|
+
},
|
|
101
|
+
{
|
|
102
|
+
label: "PayinExtraIdError",
|
|
103
|
+
create: nested => new PayinExtraIdError(nested),
|
|
104
|
+
swapCode: "swap010",
|
|
105
|
+
name: "PayinExtraIdError",
|
|
106
|
+
propagatesMessage: true,
|
|
107
|
+
},
|
|
108
|
+
];
|
|
109
|
+
|
|
110
|
+
describe.each(DERIVED_ERROR_CASES)(
|
|
111
|
+
"Derived $label",
|
|
112
|
+
({ create, swapCode, name, propagatesMessage }) => {
|
|
113
|
+
it("inherits SwapError defaults", () => {
|
|
114
|
+
const nested = new Error("step failure");
|
|
115
|
+
const error = create(propagatesMessage ? nested : undefined);
|
|
116
|
+
|
|
117
|
+
expect(error).toBeInstanceOf(SwapError);
|
|
118
|
+
expect(error.name).toBe(name);
|
|
119
|
+
expect(error.cause.swapCode).toBe(swapCode);
|
|
120
|
+
|
|
121
|
+
if (propagatesMessage) {
|
|
122
|
+
expect(error.message).toBe("step failure");
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
},
|
|
126
|
+
);
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Simplified Swap Error System
|
|
3
|
+
* Base error class and specific error types for swap transaction flows
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Base error class for all swap-related errors
|
|
8
|
+
* Contains error code and nested error information
|
|
9
|
+
*/
|
|
10
|
+
export class SwapError extends Error {
|
|
11
|
+
cause: {
|
|
12
|
+
swapCode: string;
|
|
13
|
+
[key: string]: string | Error | unknown | undefined;
|
|
14
|
+
};
|
|
15
|
+
message: string;
|
|
16
|
+
|
|
17
|
+
constructor(code = "swap000", nestedError?: Error) {
|
|
18
|
+
super();
|
|
19
|
+
this.name = "SwapError";
|
|
20
|
+
|
|
21
|
+
// Preserve nested error information
|
|
22
|
+
this.cause = {
|
|
23
|
+
swapCode: code,
|
|
24
|
+
...(nestedError?.constructor !== Object && nestedError?.constructor !== Array
|
|
25
|
+
? { message: `${nestedError}` }
|
|
26
|
+
: {}),
|
|
27
|
+
...nestedError,
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
this.message = nestedError?.message ? nestedError.message : `${nestedError}`;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Error during nonce/deviceTransactionId generation step
|
|
36
|
+
* Typically occurs when calling startSwap()
|
|
37
|
+
*/
|
|
38
|
+
export class NonceStepError extends SwapError {
|
|
39
|
+
constructor(nestedError?: Error) {
|
|
40
|
+
super("swap001", nestedError);
|
|
41
|
+
this.name = "NonceStepError";
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Error during payload retrieval step
|
|
47
|
+
* Occurs when communicating with backend to get transaction payload
|
|
48
|
+
*/
|
|
49
|
+
export class PayloadStepError extends SwapError {
|
|
50
|
+
constructor(nestedError?: Error) {
|
|
51
|
+
super("swap002", nestedError);
|
|
52
|
+
this.name = "PayloadStepError";
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* Error during transaction signature step
|
|
58
|
+
* Occurs when user rejects or device fails during completeSwap()
|
|
59
|
+
*/
|
|
60
|
+
export class SignatureStepError extends SwapError {
|
|
61
|
+
constructor(nestedError?: Error) {
|
|
62
|
+
super("swap003", nestedError);
|
|
63
|
+
this.name = "SignatureStepError";
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Special case: signature error that should be ignored/handled silently
|
|
69
|
+
* Used for expected user cancellations
|
|
70
|
+
*/
|
|
71
|
+
export class IgnoredSignatureStepError extends SwapError {
|
|
72
|
+
constructor(nestedError?: Error) {
|
|
73
|
+
super("swap003Ignored", nestedError);
|
|
74
|
+
this.name = "SignatureStepError";
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Error when user doesn't have sufficient funds
|
|
80
|
+
* Thrown during balance validation
|
|
81
|
+
*/
|
|
82
|
+
export class NotEnoughFunds extends SwapError {
|
|
83
|
+
constructor() {
|
|
84
|
+
super("swap004");
|
|
85
|
+
this.name = "NotEnoughFunds";
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* Error when unable to retrieve account list
|
|
91
|
+
* Occurs during account lookup phase
|
|
92
|
+
*/
|
|
93
|
+
export class ListAccountError extends SwapError {
|
|
94
|
+
constructor(nestedError?: Error) {
|
|
95
|
+
super("swap005", nestedError);
|
|
96
|
+
this.name = "ListAccountError";
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
/**
|
|
101
|
+
* Error when unable to retrieve currency information
|
|
102
|
+
* Occurs during currency lookup phase
|
|
103
|
+
*/
|
|
104
|
+
export class ListCurrencyError extends SwapError {
|
|
105
|
+
constructor(nestedError?: Error) {
|
|
106
|
+
super("swap006", nestedError);
|
|
107
|
+
this.name = "ListCurrencyError";
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
/**
|
|
112
|
+
* Error when specified account ID cannot be found
|
|
113
|
+
* Thrown when fromAccountId or toAccountId is invalid
|
|
114
|
+
*/
|
|
115
|
+
export class UnknownAccountError extends SwapError {
|
|
116
|
+
constructor(nestedError?: Error) {
|
|
117
|
+
super("swap007", nestedError);
|
|
118
|
+
this.name = "UnknownAccountError";
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* Error when extra identifier is required but missing
|
|
124
|
+
* Some chains require payinExtraId (e.g., XLM memo, XRP tag)
|
|
125
|
+
*/
|
|
126
|
+
export class PayinExtraIdError extends SwapError {
|
|
127
|
+
constructor(nestedError?: Error) {
|
|
128
|
+
super("swap010", nestedError);
|
|
129
|
+
this.name = "PayinExtraIdError";
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
/**
|
|
134
|
+
* CompleteSwap/CompleteExchange step information
|
|
135
|
+
* Tracks which hardware wallet step failed
|
|
136
|
+
*/
|
|
137
|
+
export type CompleteExchangeStep =
|
|
138
|
+
| "INIT"
|
|
139
|
+
| "SET_PARTNER_KEY"
|
|
140
|
+
| "CHECK_PARTNER"
|
|
141
|
+
| "PROCESS_TRANSACTION"
|
|
142
|
+
| "CHECK_TRANSACTION_SIGNATURE"
|
|
143
|
+
| "CHECK_PAYOUT_ADDRESS"
|
|
144
|
+
| "CHECK_REFUND_ADDRESS"
|
|
145
|
+
| "SIGN_COIN_TRANSACTION";
|
|
146
|
+
|
|
147
|
+
/**
|
|
148
|
+
* Error that occurs during completeSwap with step tracking
|
|
149
|
+
* Useful for debugging hardware wallet interactions
|
|
150
|
+
*/
|
|
151
|
+
export class CompleteExchangeError extends Error {
|
|
152
|
+
step: CompleteExchangeStep;
|
|
153
|
+
|
|
154
|
+
constructor(step: CompleteExchangeStep, message?: string) {
|
|
155
|
+
super(message);
|
|
156
|
+
this.name = "CompleteExchangeError";
|
|
157
|
+
this.step = step;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/* eslint-env jest */
|
|
2
|
+
import { handleErrors, isHandledError } from "./handleSwapErrors";
|
|
3
|
+
import { IgnoredSignatureStepError, SignatureStepError } from "./SwapError";
|
|
4
|
+
|
|
5
|
+
describe("handleErrors", () => {
|
|
6
|
+
it("marks default ignored message errors as handled and rethrows", async () => {
|
|
7
|
+
const error = new Error("User refused");
|
|
8
|
+
|
|
9
|
+
expect(() => handleErrors(error)).toThrow(error);
|
|
10
|
+
expect(isHandledError(error)).toBe(true);
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
it("marks default ignored error names as handled and rethrows", async () => {
|
|
14
|
+
const nestedError = new Error("Device mismatch");
|
|
15
|
+
nestedError.name = "WrongDeviceForAccount";
|
|
16
|
+
const error = new SignatureStepError(nestedError);
|
|
17
|
+
|
|
18
|
+
expect(() => handleErrors(error)).toThrow(error);
|
|
19
|
+
expect(isHandledError(error)).toBe(true);
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
it("invokes onDisplayError for swap errors that should be surfaced", async () => {
|
|
23
|
+
const error = new SignatureStepError(new Error("Unexpected failure"));
|
|
24
|
+
const onDisplayError = jest.fn().mockResolvedValue(undefined);
|
|
25
|
+
|
|
26
|
+
await expect(handleErrors(error, { onDisplayError })).resolves.toBeUndefined();
|
|
27
|
+
expect(onDisplayError).toHaveBeenCalledWith(error);
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
it("skips onDisplayError for swap003Ignored errors and marks them handled", async () => {
|
|
31
|
+
const error = new IgnoredSignatureStepError(new Error("User rejected"));
|
|
32
|
+
const onDisplayError = jest.fn();
|
|
33
|
+
|
|
34
|
+
expect(() => handleErrors(error, { onDisplayError })).toThrow(error);
|
|
35
|
+
expect(onDisplayError).not.toHaveBeenCalled();
|
|
36
|
+
expect(isHandledError(error)).toBe(true);
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
it("respects custom ignored error names", async () => {
|
|
40
|
+
const error = new Error("Rate limited");
|
|
41
|
+
Object.assign(error, { cause: { name: "RateLimitedError" } });
|
|
42
|
+
|
|
43
|
+
expect(() => handleErrors(error, { ignoredErrorNames: ["RateLimitedError"] })).toThrow(error);
|
|
44
|
+
expect(isHandledError(error)).toBe(true);
|
|
45
|
+
});
|
|
46
|
+
});
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Error Handler
|
|
3
|
+
* Decides how to handle errors - display to user, mark as handled, or throw
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { SwapError } from "./SwapError";
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Interface for error handler options
|
|
10
|
+
*/
|
|
11
|
+
export interface ErrorHandlerOptions {
|
|
12
|
+
/**
|
|
13
|
+
* Callback to display error to user (optional)
|
|
14
|
+
* If not provided, errors are simply thrown
|
|
15
|
+
*/
|
|
16
|
+
onDisplayError?: (error: SwapError) => Promise<void>;
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Additional error names to ignore (won't be displayed)
|
|
20
|
+
*/
|
|
21
|
+
ignoredErrorNames?: string[];
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Additional error messages to ignore (won't be displayed)
|
|
25
|
+
*/
|
|
26
|
+
ignoredMessages?: string[];
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Default error names that should be marked as "handled"
|
|
31
|
+
* These are typically user input errors that can be retried
|
|
32
|
+
*/
|
|
33
|
+
const DEFAULT_IGNORED_ERROR_NAMES = new Set([
|
|
34
|
+
"WrongDeviceForAccount",
|
|
35
|
+
"WrongDeviceForAccountPayout",
|
|
36
|
+
"WrongDeviceForAccountRefund",
|
|
37
|
+
"UserRefusedOnDevice",
|
|
38
|
+
]);
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Default error messages that should be marked as "handled"
|
|
42
|
+
*/
|
|
43
|
+
const DEFAULT_IGNORED_MESSAGES = new Set(["User refused", "User rejected"]);
|
|
44
|
+
|
|
45
|
+
type SwapErrorCauseDetails = {
|
|
46
|
+
swapCode?: string;
|
|
47
|
+
name?: string;
|
|
48
|
+
message?: string;
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
type ErrorWithCause = Error & { cause?: unknown };
|
|
52
|
+
function isRecord(value: unknown): value is Record<string, unknown> {
|
|
53
|
+
return typeof value === "object" && value !== null;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
function hasCause(value: Error): value is ErrorWithCause {
|
|
57
|
+
return "cause" in value;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
function toCauseDetails(rawCause: unknown): SwapErrorCauseDetails | undefined {
|
|
61
|
+
if (!isRecord(rawCause)) {
|
|
62
|
+
return undefined;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
const swapCode = typeof rawCause.swapCode === "string" ? rawCause.swapCode : undefined;
|
|
66
|
+
const name = typeof rawCause.name === "string" ? rawCause.name : undefined;
|
|
67
|
+
const message = typeof rawCause.message === "string" ? rawCause.message : undefined;
|
|
68
|
+
|
|
69
|
+
if (swapCode || name || message) {
|
|
70
|
+
return { swapCode, name, message };
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
return undefined;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
function extractErrorDetails(value: unknown): {
|
|
77
|
+
message: string;
|
|
78
|
+
cause?: SwapErrorCauseDetails;
|
|
79
|
+
} {
|
|
80
|
+
if (value instanceof SwapError) {
|
|
81
|
+
return { message: value.message, cause: value.cause };
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
if (value instanceof Error) {
|
|
85
|
+
return {
|
|
86
|
+
message: value.message,
|
|
87
|
+
cause: hasCause(value) ? toCauseDetails(value.cause) : undefined,
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
if (isRecord(value) && typeof value.message === "string") {
|
|
92
|
+
const rawCause = "cause" in value ? value.cause : undefined;
|
|
93
|
+
const cause = toCauseDetails(rawCause);
|
|
94
|
+
return { message: value.message, cause };
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
return { message: typeof value === "string" ? value : JSON.stringify(value ?? "Unknown error") };
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
function markErrorAsHandled<T>(error: T): T {
|
|
101
|
+
if (isRecord(error)) {
|
|
102
|
+
Object.assign(error, { handled: true });
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
return error;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
/**
|
|
109
|
+
* Handles errors by deciding whether to display them or mark as handled
|
|
110
|
+
*
|
|
111
|
+
* @param error - The error to handle
|
|
112
|
+
* @param options - Configuration options
|
|
113
|
+
* @throws Enhanced error with `handled` flag if applicable
|
|
114
|
+
*/
|
|
115
|
+
export function handleErrors(error: unknown, options: ErrorHandlerOptions = {}): Promise<void> {
|
|
116
|
+
const { onDisplayError, ignoredErrorNames = [], ignoredMessages = [] } = options;
|
|
117
|
+
|
|
118
|
+
// Merge default and custom ignored values
|
|
119
|
+
const allIgnoredNames = new Set([...DEFAULT_IGNORED_ERROR_NAMES, ...ignoredErrorNames]);
|
|
120
|
+
|
|
121
|
+
const allIgnoredMessages = new Set([...DEFAULT_IGNORED_MESSAGES, ...ignoredMessages]);
|
|
122
|
+
|
|
123
|
+
const { message, cause } = extractErrorDetails(error);
|
|
124
|
+
|
|
125
|
+
// Check if error should be marked as handled (retry-ready)
|
|
126
|
+
const isIgnoredMessage = allIgnoredMessages.has(message);
|
|
127
|
+
const isIgnoredName = typeof cause?.name === "string" && allIgnoredNames.has(cause.name);
|
|
128
|
+
const isIgnoredSwapCode = cause?.swapCode === "swap003Ignored";
|
|
129
|
+
|
|
130
|
+
if (isIgnoredMessage || isIgnoredName || isIgnoredSwapCode) {
|
|
131
|
+
throw markErrorAsHandled(error);
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
// Display error to user if handler provided
|
|
135
|
+
if (error instanceof SwapError && onDisplayError) {
|
|
136
|
+
// Skip displaying "swap003Ignored" errors
|
|
137
|
+
if (cause?.swapCode !== "swap003Ignored") {
|
|
138
|
+
return onDisplayError(error);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
// Always throw the error so caller can handle it
|
|
143
|
+
throw error;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
/**
|
|
147
|
+
* Type guard to check if an error is marked as handled
|
|
148
|
+
*/
|
|
149
|
+
export function isHandledError(error: unknown): boolean {
|
|
150
|
+
return isRecord(error) && error.handled === true;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
/**
|
|
154
|
+
* Extracts swap code from error if available
|
|
155
|
+
*/
|
|
156
|
+
export function getSwapCode(error: unknown): string | undefined {
|
|
157
|
+
if (error instanceof SwapError) {
|
|
158
|
+
return error.cause.swapCode;
|
|
159
|
+
}
|
|
160
|
+
return undefined;
|
|
161
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
// Export all error classes
|
|
2
|
+
export {
|
|
3
|
+
SwapError,
|
|
4
|
+
NonceStepError,
|
|
5
|
+
PayloadStepError,
|
|
6
|
+
SignatureStepError,
|
|
7
|
+
IgnoredSignatureStepError,
|
|
8
|
+
NotEnoughFunds,
|
|
9
|
+
ListAccountError,
|
|
10
|
+
ListCurrencyError,
|
|
11
|
+
UnknownAccountError,
|
|
12
|
+
PayinExtraIdError,
|
|
13
|
+
CompleteExchangeError,
|
|
14
|
+
type CompleteExchangeStep,
|
|
15
|
+
} from "./SwapError";
|
|
16
|
+
|
|
17
|
+
// Export parser utilities
|
|
18
|
+
export { createStepError, StepError, CustomErrorType, type ParseError } from "./parser";
|
|
19
|
+
|
|
20
|
+
// Export error handler
|
|
21
|
+
export {
|
|
22
|
+
handleErrors,
|
|
23
|
+
isHandledError,
|
|
24
|
+
getSwapCode,
|
|
25
|
+
type ErrorHandlerOptions,
|
|
26
|
+
} from "./handleSwapErrors";
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { createStepError, CustomErrorType, parseError, StepError } from "./parser";
|
|
2
|
+
import {
|
|
3
|
+
IgnoredSignatureStepError,
|
|
4
|
+
ListAccountError,
|
|
5
|
+
ListCurrencyError,
|
|
6
|
+
NonceStepError,
|
|
7
|
+
NotEnoughFunds,
|
|
8
|
+
PayloadStepError,
|
|
9
|
+
PayinExtraIdError,
|
|
10
|
+
SignatureStepError,
|
|
11
|
+
SwapError,
|
|
12
|
+
UnknownAccountError,
|
|
13
|
+
} from "./SwapError";
|
|
14
|
+
|
|
15
|
+
type StepExpectation = {
|
|
16
|
+
step: StepError;
|
|
17
|
+
ExpectedError: new (err?: Error) => SwapError;
|
|
18
|
+
swapCode: string;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
const STEP_EXPECTATIONS: StepExpectation[] = [
|
|
22
|
+
{ step: StepError.NONCE, ExpectedError: NonceStepError, swapCode: "swap001" },
|
|
23
|
+
{ step: StepError.PAYLOAD, ExpectedError: PayloadStepError, swapCode: "swap002" },
|
|
24
|
+
{ step: StepError.SIGNATURE, ExpectedError: SignatureStepError, swapCode: "swap003" },
|
|
25
|
+
{
|
|
26
|
+
step: StepError.IGNORED_SIGNATURE,
|
|
27
|
+
ExpectedError: IgnoredSignatureStepError,
|
|
28
|
+
swapCode: "swap003Ignored",
|
|
29
|
+
},
|
|
30
|
+
{ step: StepError.CHECK_FUNDS, ExpectedError: NotEnoughFunds, swapCode: "swap004" },
|
|
31
|
+
{ step: StepError.LIST_ACCOUNT, ExpectedError: ListAccountError, swapCode: "swap005" },
|
|
32
|
+
{ step: StepError.LIST_CURRENCY, ExpectedError: ListCurrencyError, swapCode: "swap006" },
|
|
33
|
+
{ step: StepError.UNKNOWN_ACCOUNT, ExpectedError: UnknownAccountError, swapCode: "swap007" },
|
|
34
|
+
{ step: StepError.PAYIN_EXTRA_ID, ExpectedError: PayinExtraIdError, swapCode: "swap010" },
|
|
35
|
+
];
|
|
36
|
+
|
|
37
|
+
const mockDownstreamError = new Error("error message");
|
|
38
|
+
|
|
39
|
+
describe("parseError", () => {
|
|
40
|
+
it.each(STEP_EXPECTATIONS)(
|
|
41
|
+
"$step - returns generic error when customErrorType is not passed in",
|
|
42
|
+
({ step }) => {
|
|
43
|
+
const typedStep = step as StepError;
|
|
44
|
+
|
|
45
|
+
const error = parseError({
|
|
46
|
+
error: mockDownstreamError,
|
|
47
|
+
step: typedStep,
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
expect(error).toBe(mockDownstreamError);
|
|
51
|
+
},
|
|
52
|
+
);
|
|
53
|
+
|
|
54
|
+
it.each(STEP_EXPECTATIONS)(
|
|
55
|
+
"$step - returns specific swap error when customErrorType is 'swap'",
|
|
56
|
+
({ step, ExpectedError, swapCode }) => {
|
|
57
|
+
const typedStep = step as StepError;
|
|
58
|
+
|
|
59
|
+
const error = parseError({
|
|
60
|
+
error: mockDownstreamError,
|
|
61
|
+
step: typedStep,
|
|
62
|
+
customErrorType: CustomErrorType.SWAP,
|
|
63
|
+
}) as SwapError;
|
|
64
|
+
|
|
65
|
+
expect(error).toBeInstanceOf(ExpectedError);
|
|
66
|
+
expect(error.cause.swapCode).toBe(swapCode);
|
|
67
|
+
},
|
|
68
|
+
);
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
describe("createStepError", () => {
|
|
72
|
+
it("returns downstream error when no step is supplied", () => {
|
|
73
|
+
expect(createStepError({ error: mockDownstreamError })).toBe(mockDownstreamError);
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
it.each(STEP_EXPECTATIONS)(
|
|
77
|
+
"$step - wraps downstream error with appropriate swap error",
|
|
78
|
+
({ step, ExpectedError, swapCode }) => {
|
|
79
|
+
const typedStep = step as StepError;
|
|
80
|
+
const wrapped = createStepError({ error: mockDownstreamError, step: typedStep }) as SwapError;
|
|
81
|
+
|
|
82
|
+
expect(wrapped).toBeInstanceOf(ExpectedError);
|
|
83
|
+
expect(wrapped.cause.swapCode).toBe(swapCode);
|
|
84
|
+
},
|
|
85
|
+
);
|
|
86
|
+
});
|