@ledgerhq/device-signer-kit-bitcoin 1.0.0 → 1.0.2
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/cjs/api/SignerBtc.js +1 -1
- package/lib/cjs/api/SignerBtc.js.map +1 -1
- package/lib/cjs/api/{SignerBtcBuiilder.test.js → SignerBtcBuilder.test.js} +1 -1
- package/lib/cjs/api/{SignerBtcBuiilder.test.js.map → SignerBtcBuilder.test.js.map} +1 -1
- package/lib/cjs/api/app-binder/GetExtendedPublicKeyDeviceActionTypes.js +1 -1
- package/lib/cjs/api/app-binder/GetExtendedPublicKeyDeviceActionTypes.js.map +1 -1
- package/lib/cjs/api/app-binder/GetWalletAddressDeviceActionTypes.js.map +1 -1
- package/lib/cjs/api/app-binder/SignMessageDeviceActionTypes.js +1 -1
- package/lib/cjs/api/app-binder/SignMessageDeviceActionTypes.js.map +1 -1
- package/lib/cjs/api/app-binder/SignPsbtDeviceActionTypes.js +1 -1
- package/lib/cjs/api/app-binder/SignPsbtDeviceActionTypes.js.map +1 -1
- package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js +1 -1
- package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js.map +1 -1
- package/lib/cjs/api/model/AddressOptions.js +1 -1
- package/lib/cjs/api/model/AddressOptions.js.map +1 -1
- package/lib/cjs/api/model/MessageOptions.js +2 -0
- package/lib/cjs/api/model/MessageOptions.js.map +7 -0
- package/lib/cjs/api/model/PsbtOptions.js +2 -0
- package/lib/cjs/api/model/PsbtOptions.js.map +7 -0
- package/lib/cjs/api/model/WalletAddressOptions.js +1 -1
- package/lib/cjs/api/model/WalletAddressOptions.js.map +1 -1
- package/lib/cjs/index.js.map +1 -1
- package/lib/cjs/internal/DefaultSignerBtc.js +1 -1
- package/lib/cjs/internal/DefaultSignerBtc.js.map +3 -3
- package/lib/cjs/internal/DefaultSignerBtc.test.js +1 -1
- package/lib/cjs/internal/DefaultSignerBtc.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/BtcAppBinder.js +1 -1
- package/lib/cjs/internal/app-binder/BtcAppBinder.js.map +3 -3
- package/lib/cjs/internal/app-binder/BtcAppBinder.test.js +1 -1
- package/lib/cjs/internal/app-binder/BtcAppBinder.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/ContinueCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/ContinueCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/ContinueCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/ContinueCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/GetExtendedPublicKeyCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetExtendedPublicKeyCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/GetExtendedPublicKeyCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetExtendedPublicKeyCommand.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/GetMasterFingerprintCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetMasterFingerprintCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/GetMasterFingerprintCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetMasterFingerprintCommand.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/GetWalletAddressCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetWalletAddressCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/GetWalletAddressCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetWalletAddressCommand.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/RegisterWalletAddressCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/RegisterWalletAddressCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/RegisterWalletAddressCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/RegisterWalletAddressCommand.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/SignMessageCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/SignMessageCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/SignMessageCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/SignMessageCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/SignPsbtCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/SignPsbtCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/SignPsbtCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/SignPsbtCommand.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/client-command-handlers/GetMerkleLeafIndexCommandHandler.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/client-command-handlers/GetMerkleLeafIndexCommandHandler.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/client-command-handlers/GetMerkleLeafProofCommandHandler.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/client-command-handlers/GetMerkleLeafProofCommandHandler.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/client-command-handlers/GetMoreElementsCommandHandler.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/client-command-handlers/GetMoreElementsCommandHandler.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/client-command-handlers/GetPreimageCommandHandler.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/client-command-handlers/GetPreimageCommandHandler.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/service/ClientCommandInterpreter.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/service/ClientCommandInterpreter.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/utils/bitcoinAppError.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/utils/bitcoinAppError.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.js.map +2 -2
- package/lib/cjs/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.test.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/device-action/SignPsbt/SignPsbtDeviceAction.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/SignPsbt/SignPsbtDeviceAction.js.map +2 -2
- package/lib/cjs/internal/app-binder/device-action/SignPsbt/SignPsbtDeviceAction.test.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/SignPsbt/SignPsbtDeviceAction.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +3 -3
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js.map +2 -2
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupSignPsbtDAMock.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupSignPsbtDAMock.js.map +2 -2
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js.map +3 -3
- package/lib/cjs/internal/app-binder/di/appBinderModule.js +1 -1
- package/lib/cjs/internal/app-binder/di/appBinderModule.js.map +3 -3
- package/lib/cjs/internal/app-binder/di/appBinderModule.test.js +1 -1
- package/lib/cjs/internal/app-binder/di/appBinderModule.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/di/appBinderTypes.js +1 -1
- package/lib/cjs/internal/app-binder/di/appBinderTypes.js.map +2 -2
- package/lib/cjs/internal/app-binder/task/BuildPsbtTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/BuildPsbtTask.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/task/ContinueTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/ContinueTask.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/task/GetWalletAddressTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/GetWalletAddressTask.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/task/PrepareWalletPolicyTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/PrepareWalletPolicyTask.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/task/SignMessageTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/SignMessageTask.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/task/SignPsbtTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/SignPsbtTask.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/task/UpdatePsbtTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/UpdatePsbtTask.test.js.map +2 -2
- package/lib/cjs/internal/data-store/di/dataStoreModule.js +1 -1
- package/lib/cjs/internal/data-store/di/dataStoreModule.js.map +3 -3
- package/lib/cjs/internal/data-store/di/dataStoreModule.test.js +1 -1
- package/lib/cjs/internal/data-store/di/dataStoreModule.test.js.map +2 -2
- package/lib/cjs/internal/data-store/model/DataStore.test.js +1 -1
- package/lib/cjs/internal/data-store/model/DataStore.test.js.map +2 -2
- package/lib/cjs/internal/data-store/service/DefaultDataStoreService.test.js +1 -1
- package/lib/cjs/internal/data-store/service/DefaultDataStoreService.test.js.map +2 -2
- package/lib/cjs/internal/di.js +1 -1
- package/lib/cjs/internal/di.js.map +2 -2
- package/lib/cjs/internal/merkle-tree/di/merkleTreeModule.js +1 -1
- package/lib/cjs/internal/merkle-tree/di/merkleTreeModule.js.map +3 -3
- package/lib/cjs/internal/merkle-tree/di/merkleTreeModule.test.js +1 -1
- package/lib/cjs/internal/merkle-tree/di/merkleTreeModule.test.js.map +2 -2
- package/lib/cjs/internal/merkle-tree/service/MerkleMapBuilder.test.js +1 -1
- package/lib/cjs/internal/merkle-tree/service/MerkleMapBuilder.test.js.map +2 -2
- package/lib/cjs/internal/merkle-tree/service/MerkleTreeBuilder.test.js +1 -1
- package/lib/cjs/internal/merkle-tree/service/MerkleTreeBuilder.test.js.map +2 -2
- package/lib/cjs/internal/psbt/di/psbtModule.js +1 -1
- package/lib/cjs/internal/psbt/di/psbtModule.js.map +3 -3
- package/lib/cjs/internal/psbt/di/psbtModule.test.js +1 -1
- package/lib/cjs/internal/psbt/di/psbtModule.test.js.map +2 -2
- package/lib/cjs/internal/psbt/model/Key.js +1 -1
- package/lib/cjs/internal/psbt/model/Key.js.map +2 -2
- package/lib/cjs/internal/psbt/service/psbt/DefaultPsbtMapper.test.js +1 -1
- package/lib/cjs/internal/psbt/service/psbt/DefaultPsbtMapper.test.js.map +2 -2
- package/lib/cjs/internal/psbt/service/psbt/DefaultPsbtSerializer.js +1 -1
- package/lib/cjs/internal/psbt/service/psbt/DefaultPsbtSerializer.js.map +2 -2
- package/lib/cjs/internal/psbt/service/psbt/DefaultPsbtV2Normalizer.js +1 -1
- package/lib/cjs/internal/psbt/service/psbt/DefaultPsbtV2Normalizer.js.map +2 -2
- package/lib/cjs/internal/use-cases/di/useCasesModule.js +1 -1
- package/lib/cjs/internal/use-cases/di/useCasesModule.js.map +3 -3
- package/lib/cjs/internal/use-cases/di/useCasesModule.test.js +1 -1
- package/lib/cjs/internal/use-cases/di/useCasesModule.test.js.map +2 -2
- package/lib/cjs/internal/use-cases/get-extended-public-key/GetExtendedPublicKeyUseCase.js +1 -1
- package/lib/cjs/internal/use-cases/get-extended-public-key/GetExtendedPublicKeyUseCase.js.map +2 -2
- package/lib/cjs/internal/use-cases/get-extended-public-key/GetExtendedPublicKeyUseCase.test.js +1 -1
- package/lib/cjs/internal/use-cases/get-extended-public-key/GetExtendedPublicKeyUseCase.test.js.map +2 -2
- package/lib/cjs/internal/use-cases/get-wallet-address/GetWalletAddressUseCase.js +1 -1
- package/lib/cjs/internal/use-cases/get-wallet-address/GetWalletAddressUseCase.js.map +3 -3
- package/lib/cjs/internal/use-cases/get-wallet-address/GetWalletAddressUseCase.test.js +1 -1
- package/lib/cjs/internal/use-cases/get-wallet-address/GetWalletAddressUseCase.test.js.map +3 -3
- package/lib/cjs/internal/use-cases/sign-message/SignMessageUseCase.js +1 -1
- package/lib/cjs/internal/use-cases/sign-message/SignMessageUseCase.js.map +3 -3
- package/lib/cjs/internal/use-cases/sign-message/SignMessageUseCase.test.js +1 -1
- package/lib/cjs/internal/use-cases/sign-message/SignMessageUseCase.test.js.map +2 -2
- package/lib/cjs/internal/use-cases/sign-psbt/SignPsbtUseCase.js +1 -1
- package/lib/cjs/internal/use-cases/sign-psbt/SignPsbtUseCase.js.map +3 -3
- package/lib/cjs/internal/use-cases/sign-psbt/SignPsbtUseCase.test.js +1 -1
- package/lib/cjs/internal/use-cases/sign-psbt/SignPsbtUseCase.test.js.map +3 -3
- package/lib/cjs/internal/use-cases/sign-transaction/SignTransactionUseCase.js +1 -1
- package/lib/cjs/internal/use-cases/sign-transaction/SignTransactionUseCase.js.map +3 -3
- package/lib/cjs/internal/use-cases/sign-transaction/SignTransactionUseCase.test.js +1 -1
- package/lib/cjs/internal/use-cases/sign-transaction/SignTransactionUseCase.test.js.map +3 -3
- package/lib/cjs/internal/wallet/di/walletModule.js +1 -1
- package/lib/cjs/internal/wallet/di/walletModule.js.map +3 -3
- package/lib/cjs/internal/wallet/di/walletModule.test.js +1 -1
- package/lib/cjs/internal/wallet/di/walletModule.test.js.map +2 -2
- package/lib/cjs/internal/wallet/service/DefaultWalletBuilder.js +1 -1
- package/lib/cjs/internal/wallet/service/DefaultWalletBuilder.js.map +2 -2
- package/lib/cjs/internal/wallet/service/DefaultWalletBuilder.test.js +1 -1
- package/lib/cjs/internal/wallet/service/DefaultWalletBuilder.test.js.map +2 -2
- package/lib/cjs/internal/wallet/service/DefaultWalletSerializer.test.js +1 -1
- package/lib/cjs/internal/wallet/service/DefaultWalletSerializer.test.js.map +2 -2
- package/lib/cjs/package.json +17 -17
- package/lib/esm/api/{SignerBtcBuiilder.test.js → SignerBtcBuilder.test.js} +1 -1
- package/lib/esm/api/{SignerBtcBuiilder.test.js.map → SignerBtcBuilder.test.js.map} +1 -1
- package/lib/esm/api/model/MessageOptions.js +1 -0
- package/lib/esm/api/model/MessageOptions.js.map +7 -0
- package/lib/esm/api/model/PsbtOptions.js +1 -0
- package/lib/esm/api/model/PsbtOptions.js.map +7 -0
- package/lib/esm/internal/DefaultSignerBtc.js +1 -1
- package/lib/esm/internal/DefaultSignerBtc.js.map +3 -3
- package/lib/esm/internal/DefaultSignerBtc.test.js +1 -1
- package/lib/esm/internal/DefaultSignerBtc.test.js.map +2 -2
- package/lib/esm/internal/app-binder/BtcAppBinder.js +1 -1
- package/lib/esm/internal/app-binder/BtcAppBinder.js.map +3 -3
- package/lib/esm/internal/app-binder/BtcAppBinder.test.js +1 -1
- package/lib/esm/internal/app-binder/BtcAppBinder.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/ContinueCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/ContinueCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/ContinueCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/ContinueCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/GetExtendedPublicKeyCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/GetExtendedPublicKeyCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/GetExtendedPublicKeyCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/GetExtendedPublicKeyCommand.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/GetMasterFingerprintCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/GetMasterFingerprintCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/GetMasterFingerprintCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/GetMasterFingerprintCommand.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/GetWalletAddressCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/GetWalletAddressCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/GetWalletAddressCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/GetWalletAddressCommand.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/RegisterWalletAddressCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/RegisterWalletAddressCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/RegisterWalletAddressCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/RegisterWalletAddressCommand.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SignMessageCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/SignMessageCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SignMessageCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/SignMessageCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/SignPsbtCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/SignPsbtCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SignPsbtCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/SignPsbtCommand.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/client-command-handlers/GetMerkleLeafIndexCommandHandler.test.js +1 -1
- package/lib/esm/internal/app-binder/command/client-command-handlers/GetMerkleLeafIndexCommandHandler.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/client-command-handlers/GetMerkleLeafProofCommandHandler.test.js +1 -1
- package/lib/esm/internal/app-binder/command/client-command-handlers/GetMerkleLeafProofCommandHandler.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/client-command-handlers/GetMoreElementsCommandHandler.test.js +1 -1
- package/lib/esm/internal/app-binder/command/client-command-handlers/GetMoreElementsCommandHandler.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/client-command-handlers/GetPreimageCommandHandler.test.js +1 -1
- package/lib/esm/internal/app-binder/command/client-command-handlers/GetPreimageCommandHandler.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/service/ClientCommandInterpreter.test.js +1 -1
- package/lib/esm/internal/app-binder/command/service/ClientCommandInterpreter.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/utils/bitcoinAppError.test.js +1 -1
- package/lib/esm/internal/app-binder/command/utils/bitcoinAppError.test.js.map +2 -2
- package/lib/esm/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.js +1 -1
- package/lib/esm/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.js.map +2 -2
- package/lib/esm/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.test.js +1 -1
- package/lib/esm/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.test.js.map +3 -3
- package/lib/esm/internal/app-binder/device-action/SignPsbt/SignPsbtDeviceAction.js +1 -1
- package/lib/esm/internal/app-binder/device-action/SignPsbt/SignPsbtDeviceAction.js.map +2 -2
- package/lib/esm/internal/app-binder/device-action/SignPsbt/SignPsbtDeviceAction.test.js +1 -1
- package/lib/esm/internal/app-binder/device-action/SignPsbt/SignPsbtDeviceAction.test.js.map +3 -3
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +3 -3
- package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +1 -1
- package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +3 -3
- package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js +1 -1
- package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js.map +2 -2
- package/lib/esm/internal/app-binder/device-action/__test-utils__/setupSignPsbtDAMock.js +1 -1
- package/lib/esm/internal/app-binder/device-action/__test-utils__/setupSignPsbtDAMock.js.map +2 -2
- package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js +1 -1
- package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js.map +3 -3
- package/lib/esm/internal/app-binder/di/appBinderModule.js +1 -1
- package/lib/esm/internal/app-binder/di/appBinderModule.js.map +3 -3
- package/lib/esm/internal/app-binder/di/appBinderModule.test.js +1 -1
- package/lib/esm/internal/app-binder/di/appBinderModule.test.js.map +2 -2
- package/lib/esm/internal/app-binder/di/appBinderTypes.js +1 -1
- package/lib/esm/internal/app-binder/di/appBinderTypes.js.map +2 -2
- package/lib/esm/internal/app-binder/task/BuildPsbtTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/BuildPsbtTask.test.js.map +2 -2
- package/lib/esm/internal/app-binder/task/ContinueTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/ContinueTask.test.js.map +2 -2
- package/lib/esm/internal/app-binder/task/GetWalletAddressTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/GetWalletAddressTask.test.js.map +2 -2
- package/lib/esm/internal/app-binder/task/PrepareWalletPolicyTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/PrepareWalletPolicyTask.test.js.map +2 -2
- package/lib/esm/internal/app-binder/task/SignMessageTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/SignMessageTask.test.js.map +2 -2
- package/lib/esm/internal/app-binder/task/SignPsbtTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/SignPsbtTask.test.js.map +2 -2
- package/lib/esm/internal/app-binder/task/UpdatePsbtTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/UpdatePsbtTask.test.js.map +2 -2
- package/lib/esm/internal/data-store/di/dataStoreModule.js +1 -1
- package/lib/esm/internal/data-store/di/dataStoreModule.js.map +3 -3
- package/lib/esm/internal/data-store/di/dataStoreModule.test.js +1 -1
- package/lib/esm/internal/data-store/di/dataStoreModule.test.js.map +2 -2
- package/lib/esm/internal/data-store/model/DataStore.test.js +1 -1
- package/lib/esm/internal/data-store/model/DataStore.test.js.map +2 -2
- package/lib/esm/internal/data-store/service/DefaultDataStoreService.test.js +1 -1
- package/lib/esm/internal/data-store/service/DefaultDataStoreService.test.js.map +2 -2
- package/lib/esm/internal/di.js +1 -1
- package/lib/esm/internal/di.js.map +2 -2
- package/lib/esm/internal/merkle-tree/di/merkleTreeModule.js +1 -1
- package/lib/esm/internal/merkle-tree/di/merkleTreeModule.js.map +3 -3
- package/lib/esm/internal/merkle-tree/di/merkleTreeModule.test.js +1 -1
- package/lib/esm/internal/merkle-tree/di/merkleTreeModule.test.js.map +2 -2
- package/lib/esm/internal/merkle-tree/service/MerkleMapBuilder.test.js +1 -1
- package/lib/esm/internal/merkle-tree/service/MerkleMapBuilder.test.js.map +2 -2
- package/lib/esm/internal/merkle-tree/service/MerkleTreeBuilder.test.js +1 -1
- package/lib/esm/internal/merkle-tree/service/MerkleTreeBuilder.test.js.map +2 -2
- package/lib/esm/internal/psbt/di/psbtModule.js +1 -1
- package/lib/esm/internal/psbt/di/psbtModule.js.map +3 -3
- package/lib/esm/internal/psbt/di/psbtModule.test.js +1 -1
- package/lib/esm/internal/psbt/di/psbtModule.test.js.map +2 -2
- package/lib/esm/internal/psbt/model/Key.js +1 -1
- package/lib/esm/internal/psbt/model/Key.js.map +2 -2
- package/lib/esm/internal/psbt/service/psbt/DefaultPsbtMapper.test.js +1 -1
- package/lib/esm/internal/psbt/service/psbt/DefaultPsbtMapper.test.js.map +2 -2
- package/lib/esm/internal/psbt/service/psbt/DefaultPsbtSerializer.js +1 -1
- package/lib/esm/internal/psbt/service/psbt/DefaultPsbtSerializer.js.map +2 -2
- package/lib/esm/internal/psbt/service/psbt/DefaultPsbtV2Normalizer.js +1 -1
- package/lib/esm/internal/psbt/service/psbt/DefaultPsbtV2Normalizer.js.map +2 -2
- package/lib/esm/internal/use-cases/di/useCasesModule.js +1 -1
- package/lib/esm/internal/use-cases/di/useCasesModule.js.map +3 -3
- package/lib/esm/internal/use-cases/di/useCasesModule.test.js +1 -1
- package/lib/esm/internal/use-cases/di/useCasesModule.test.js.map +2 -2
- package/lib/esm/internal/use-cases/get-extended-public-key/GetExtendedPublicKeyUseCase.js +1 -1
- package/lib/esm/internal/use-cases/get-extended-public-key/GetExtendedPublicKeyUseCase.js.map +2 -2
- package/lib/esm/internal/use-cases/get-extended-public-key/GetExtendedPublicKeyUseCase.test.js +1 -1
- package/lib/esm/internal/use-cases/get-extended-public-key/GetExtendedPublicKeyUseCase.test.js.map +2 -2
- package/lib/esm/internal/use-cases/get-wallet-address/GetWalletAddressUseCase.js +1 -1
- package/lib/esm/internal/use-cases/get-wallet-address/GetWalletAddressUseCase.js.map +3 -3
- package/lib/esm/internal/use-cases/get-wallet-address/GetWalletAddressUseCase.test.js +1 -1
- package/lib/esm/internal/use-cases/get-wallet-address/GetWalletAddressUseCase.test.js.map +3 -3
- package/lib/esm/internal/use-cases/sign-message/SignMessageUseCase.js +1 -1
- package/lib/esm/internal/use-cases/sign-message/SignMessageUseCase.js.map +3 -3
- package/lib/esm/internal/use-cases/sign-message/SignMessageUseCase.test.js +1 -1
- package/lib/esm/internal/use-cases/sign-message/SignMessageUseCase.test.js.map +2 -2
- package/lib/esm/internal/use-cases/sign-psbt/SignPsbtUseCase.js +1 -1
- package/lib/esm/internal/use-cases/sign-psbt/SignPsbtUseCase.js.map +3 -3
- package/lib/esm/internal/use-cases/sign-psbt/SignPsbtUseCase.test.js +1 -1
- package/lib/esm/internal/use-cases/sign-psbt/SignPsbtUseCase.test.js.map +3 -3
- package/lib/esm/internal/use-cases/sign-transaction/SignTransactionUseCase.js +1 -1
- package/lib/esm/internal/use-cases/sign-transaction/SignTransactionUseCase.js.map +3 -3
- package/lib/esm/internal/use-cases/sign-transaction/SignTransactionUseCase.test.js +1 -1
- package/lib/esm/internal/use-cases/sign-transaction/SignTransactionUseCase.test.js.map +3 -3
- package/lib/esm/internal/wallet/di/walletModule.js +1 -1
- package/lib/esm/internal/wallet/di/walletModule.js.map +3 -3
- package/lib/esm/internal/wallet/di/walletModule.test.js +1 -1
- package/lib/esm/internal/wallet/di/walletModule.test.js.map +2 -2
- package/lib/esm/internal/wallet/service/DefaultWalletBuilder.js +1 -1
- package/lib/esm/internal/wallet/service/DefaultWalletBuilder.js.map +2 -2
- package/lib/esm/internal/wallet/service/DefaultWalletBuilder.test.js +1 -1
- package/lib/esm/internal/wallet/service/DefaultWalletBuilder.test.js.map +2 -2
- package/lib/esm/internal/wallet/service/DefaultWalletSerializer.test.js +1 -1
- package/lib/esm/internal/wallet/service/DefaultWalletSerializer.test.js.map +2 -2
- package/lib/esm/package.json +17 -17
- package/lib/types/api/SignerBtc.d.ts +7 -5
- package/lib/types/api/SignerBtc.d.ts.map +1 -1
- package/lib/types/api/SignerBtcBuilder.test.d.ts +2 -0
- package/lib/types/api/SignerBtcBuilder.test.d.ts.map +1 -0
- package/lib/types/api/app-binder/GetExtendedPublicKeyDeviceActionTypes.d.ts +3 -1
- package/lib/types/api/app-binder/GetExtendedPublicKeyDeviceActionTypes.d.ts.map +1 -1
- package/lib/types/api/app-binder/GetWalletAddressDeviceActionTypes.d.ts +1 -0
- package/lib/types/api/app-binder/GetWalletAddressDeviceActionTypes.d.ts.map +1 -1
- package/lib/types/api/app-binder/SignMessageDeviceActionTypes.d.ts +1 -12
- package/lib/types/api/app-binder/SignMessageDeviceActionTypes.d.ts.map +1 -1
- package/lib/types/api/app-binder/SignPsbtDeviceActionTypes.d.ts +1 -0
- package/lib/types/api/app-binder/SignPsbtDeviceActionTypes.d.ts.map +1 -1
- package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts +1 -0
- package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +1 -1
- package/lib/types/api/model/AddressOptions.d.ts +1 -0
- package/lib/types/api/model/AddressOptions.d.ts.map +1 -1
- package/lib/types/api/model/MessageOptions.d.ts +4 -0
- package/lib/types/api/model/MessageOptions.d.ts.map +1 -0
- package/lib/types/api/model/PsbtOptions.d.ts +4 -0
- package/lib/types/api/model/PsbtOptions.d.ts.map +1 -0
- package/lib/types/api/model/Signature.d.ts.map +1 -1
- package/lib/types/api/model/WalletAddressOptions.d.ts +1 -0
- package/lib/types/api/model/WalletAddressOptions.d.ts.map +1 -1
- package/lib/types/internal/DefaultSignerBtc.d.ts +7 -5
- package/lib/types/internal/DefaultSignerBtc.d.ts.map +1 -1
- package/lib/types/internal/app-binder/BtcAppBinder.d.ts +4 -0
- package/lib/types/internal/app-binder/BtcAppBinder.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/ContinueCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/ContinueCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/GetExtendedPublicKeyCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/GetExtendedPublicKeyCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/GetMasterFingerprintCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/GetMasterFingerprintCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/GetWalletAddressCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/GetWalletAddressCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/RegisterWalletAddressCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/RegisterWalletAddressCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/SignMessageCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/SignMessageCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/SignPsbtCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/SignPsbtCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/utils/bitcoinAppErrors.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/SignPsbt/SignPsbtDeviceAction.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +2 -1
- package/lib/types/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/__test-utils__/setupSignPsbtDAMock.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts +5 -2
- package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +1 -1
- package/lib/types/internal/app-binder/di/appBinderModule.d.ts.map +1 -1
- package/lib/types/internal/app-binder/di/appBinderTypes.d.ts +0 -1
- package/lib/types/internal/app-binder/di/appBinderTypes.d.ts.map +1 -1
- package/lib/types/internal/app-binder/task/GetWalletAddressTask.d.ts.map +1 -1
- package/lib/types/internal/app-binder/task/SignMessageTask.d.ts.map +1 -1
- package/lib/types/internal/app-binder/task/SignPsbtTask.d.ts.map +1 -1
- package/lib/types/internal/data-store/di/dataStoreModule.d.ts.map +1 -1
- package/lib/types/internal/di.d.ts.map +1 -1
- package/lib/types/internal/merkle-tree/di/merkleTreeModule.d.ts.map +1 -1
- package/lib/types/internal/psbt/di/psbtModule.d.ts.map +1 -1
- package/lib/types/internal/use-cases/di/useCasesModule.d.ts.map +1 -1
- package/lib/types/internal/use-cases/get-extended-public-key/GetExtendedPublicKeyUseCase.d.ts +1 -0
- package/lib/types/internal/use-cases/get-extended-public-key/GetExtendedPublicKeyUseCase.d.ts.map +1 -1
- package/lib/types/internal/use-cases/get-wallet-address/GetWalletAddressUseCase.d.ts +1 -1
- package/lib/types/internal/use-cases/get-wallet-address/GetWalletAddressUseCase.d.ts.map +1 -1
- package/lib/types/internal/use-cases/sign-message/SignMessageUseCase.d.ts +1 -1
- package/lib/types/internal/use-cases/sign-message/SignMessageUseCase.d.ts.map +1 -1
- package/lib/types/internal/use-cases/sign-psbt/SignPsbtUseCase.d.ts +1 -1
- package/lib/types/internal/use-cases/sign-psbt/SignPsbtUseCase.d.ts.map +1 -1
- package/lib/types/internal/use-cases/sign-transaction/SignTransactionUseCase.d.ts +1 -1
- package/lib/types/internal/use-cases/sign-transaction/SignTransactionUseCase.d.ts.map +1 -1
- package/lib/types/internal/wallet/di/walletModule.d.ts.map +1 -1
- package/lib/types/tsconfig.prod.tsbuildinfo +1 -1
- package/package.json +18 -18
- package/lib/cjs/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.js +0 -2
- package/lib/cjs/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.js.map +0 -7
- package/lib/cjs/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.test.js +0 -2
- package/lib/cjs/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.test.js.map +0 -7
- package/lib/esm/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.js +0 -2
- package/lib/esm/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.js.map +0 -7
- package/lib/esm/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.test.js +0 -2
- package/lib/esm/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.test.js.map +0 -7
- package/lib/types/api/SignerBtcBuiilder.test.d.ts +0 -2
- package/lib/types/api/SignerBtcBuiilder.test.d.ts.map +0 -1
- package/lib/types/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.d.ts +0 -19
- package/lib/types/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.d.ts.map +0 -1
- package/lib/types/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.test.d.ts +0 -2
- package/lib/types/internal/app-binder/device-action/SignMessage/SignMessageDeviceAction.test.d.ts.map +0 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var d=require("purify-ts"),o=require("../../../app-binder/command/utils/constants"),h=require("../../../utils/Varint"),i=require("./GetMerkleLeafIndexCommandHandler");const x=o.ClientCommandCodes.GET_MERKLE_LEAF_INDEX;describe("GetMerkleLeafIndexCommandHandler",()=>{let s,r;beforeEach(()=>{
|
|
1
|
+
"use strict";var d=require("purify-ts"),o=require("../../../app-binder/command/utils/constants"),h=require("../../../utils/Varint"),i=require("./GetMerkleLeafIndexCommandHandler");const x=o.ClientCommandCodes.GET_MERKLE_LEAF_INDEX;describe("GetMerkleLeafIndexCommandHandler",()=>{let s,r;beforeEach(()=>{vi.clearAllMocks(),r={getMerkleLeafIndex:vi.fn()},s={dataStore:r,queue:[],yieldedResults:[]}});const u=(e,t,f)=>new Uint8Array([e,...t,...f]);it("should return the index when the Merkle leaf is found",()=>{const e=new Uint8Array(o.SHA256_SIZE).fill(170),t=new Uint8Array(o.SHA256_SIZE).fill(255),f=u(x,e,t),n=123456,l=(0,h.encodeVarint)(n).unsafeCoerce();r.getMerkleLeafIndex.mockReturnValue((0,d.Just)(n));const c=(0,i.GetMerkleLeafIndexCommandHandler)(f,s),a=new Uint8Array(1+l.length);a[0]=1,a.set(l,1),expect(r.getMerkleLeafIndex).toHaveBeenCalledWith(e,t),expect(c.isRight()).toBe(!0),expect(c.unsafeCoerce()).toEqual(a),expect(s.queue).toHaveLength(0)}),it("should return a failure response when the Merkle leaf is not found",()=>{const e=new Uint8Array(o.SHA256_SIZE).fill(170),t=new Uint8Array(o.SHA256_SIZE).fill(255),f=u(x,e,t);r.getMerkleLeafIndex.mockReturnValue(d.Nothing);const n=(0,i.GetMerkleLeafIndexCommandHandler)(f,s),l=Uint8Array.from([0]);expect(r.getMerkleLeafIndex).toHaveBeenCalledWith(e,t),expect(n.isRight()).toBe(!0),expect(n.unsafeCoerce()).toEqual(l),expect(s.queue).toHaveLength(0)}),it("should correctly handle a leaf index of zero",()=>{const e=new Uint8Array(o.SHA256_SIZE).fill(170),t=new Uint8Array(o.SHA256_SIZE).fill(255),f=u(x,e,t),n=0,l=(0,h.encodeVarint)(n).unsafeCoerce();r.getMerkleLeafIndex.mockReturnValue((0,d.Just)(n));const c=(0,i.GetMerkleLeafIndexCommandHandler)(f,s),a=new Uint8Array(1+l.length);a[0]=1,a.set(l,1),expect(r.getMerkleLeafIndex).toHaveBeenCalledWith(e,t),expect(c.isRight()).toBe(!0),expect(c.unsafeCoerce()).toEqual(a),expect(s.queue).toHaveLength(0)}),it("should correctly handle the maximum SHA256_SIZE-bit unsigned integer as a leaf index",()=>{const e=new Uint8Array(o.SHA256_SIZE).fill(170),t=new Uint8Array(o.SHA256_SIZE).fill(255),f=u(x,e,t),n=4294967295,l=(0,h.encodeVarint)(n).unsafeCoerce();r.getMerkleLeafIndex.mockReturnValue((0,d.Just)(n));const c=(0,i.GetMerkleLeafIndexCommandHandler)(f,s),a=new Uint8Array(1+l.length);a[0]=1,a.set(l,1),expect(r.getMerkleLeafIndex).toHaveBeenCalledWith(e,t),expect(c.isRight()).toBe(!0),expect(c.unsafeCoerce()).toEqual(a),expect(s.queue).toHaveLength(0)})});
|
|
2
2
|
//# sourceMappingURL=GetMerkleLeafIndexCommandHandler.test.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/internal/app-binder/command/client-command-handlers/GetMerkleLeafIndexCommandHandler.test.ts"],
|
|
4
|
-
"sourcesContent": ["import { Just, Nothing } from \"purify-ts\";\n\nimport {\n ClientCommandCodes,\n SHA256_SIZE,\n} from \"@internal/app-binder/command/utils/constants\";\nimport { type DataStore } from \"@internal/data-store/model/DataStore\";\nimport { encodeVarint } from \"@internal/utils/Varint\";\n\nimport { type CommandHandlerContext } from \"./ClientCommandHandlersTypes\";\nimport { GetMerkleLeafIndexCommandHandler } from \"./GetMerkleLeafIndexCommandHandler\";\n\nconst COMMAND_CODE = ClientCommandCodes.GET_MERKLE_LEAF_INDEX;\n\ndescribe(\"GetMerkleLeafIndexCommandHandler\", () => {\n let commandHandlerContext: CommandHandlerContext;\n let mockDataStore:
|
|
5
|
-
"mappings": "aAAA,IAAAA,EAA8B,
|
|
4
|
+
"sourcesContent": ["import { Just, Nothing } from \"purify-ts\";\nimport { type Mocked } from \"vitest\";\n\nimport {\n ClientCommandCodes,\n SHA256_SIZE,\n} from \"@internal/app-binder/command/utils/constants\";\nimport { type DataStore } from \"@internal/data-store/model/DataStore\";\nimport { encodeVarint } from \"@internal/utils/Varint\";\n\nimport { type CommandHandlerContext } from \"./ClientCommandHandlersTypes\";\nimport { GetMerkleLeafIndexCommandHandler } from \"./GetMerkleLeafIndexCommandHandler\";\n\nconst COMMAND_CODE = ClientCommandCodes.GET_MERKLE_LEAF_INDEX;\n\ndescribe(\"GetMerkleLeafIndexCommandHandler\", () => {\n let commandHandlerContext: CommandHandlerContext;\n let mockDataStore: Mocked<DataStore>;\n\n beforeEach(() => {\n vi.clearAllMocks();\n\n mockDataStore = {\n getMerkleLeafIndex: vi.fn(),\n } as unknown as Mocked<DataStore>;\n\n commandHandlerContext = {\n dataStore: mockDataStore,\n queue: [],\n yieldedResults: [],\n };\n });\n\n const createRequest = (\n commandCode: number,\n merkleRootHash: Uint8Array,\n leafNodeHash: Uint8Array,\n ): Uint8Array =>\n new Uint8Array([commandCode, ...merkleRootHash, ...leafNodeHash]);\n\n it(\"should return the index when the Merkle leaf is found\", () => {\n // given\n const merkleRootHash = new Uint8Array(SHA256_SIZE).fill(0xaa);\n const leafNodeHash = new Uint8Array(SHA256_SIZE).fill(0xff);\n const handlerRequest = createRequest(\n COMMAND_CODE,\n merkleRootHash,\n leafNodeHash,\n );\n const leafIndex = 123456;\n const encodedLeafIndexVarint = encodeVarint(leafIndex).unsafeCoerce();\n\n // when\n mockDataStore.getMerkleLeafIndex.mockReturnValue(Just(leafIndex));\n\n const handlerResponse = GetMerkleLeafIndexCommandHandler(\n handlerRequest,\n commandHandlerContext,\n );\n\n const expectedResponseBuffer = new Uint8Array(\n 1 + encodedLeafIndexVarint.length,\n );\n expectedResponseBuffer[0] = 1; // index found\n expectedResponseBuffer.set(encodedLeafIndexVarint, 1);\n\n // then\n expect(mockDataStore.getMerkleLeafIndex).toHaveBeenCalledWith(\n merkleRootHash,\n leafNodeHash,\n );\n expect(handlerResponse.isRight()).toBe(true);\n expect(handlerResponse.unsafeCoerce()).toEqual(expectedResponseBuffer);\n expect(commandHandlerContext.queue).toHaveLength(0);\n });\n\n it(\"should return a failure response when the Merkle leaf is not found\", () => {\n // given\n const merkleRootHash = new Uint8Array(SHA256_SIZE).fill(0xaa);\n const leafNodeHash = new Uint8Array(SHA256_SIZE).fill(0xff);\n const handlerRequest = createRequest(\n COMMAND_CODE,\n merkleRootHash,\n leafNodeHash,\n );\n\n // when\n mockDataStore.getMerkleLeafIndex.mockReturnValue(Nothing);\n\n const handlerResponse = GetMerkleLeafIndexCommandHandler(\n handlerRequest,\n commandHandlerContext,\n );\n\n const expectedFailureResponseBuffer = Uint8Array.from([0]);\n\n // then\n expect(mockDataStore.getMerkleLeafIndex).toHaveBeenCalledWith(\n merkleRootHash,\n leafNodeHash,\n );\n expect(handlerResponse.isRight()).toBe(true);\n expect(handlerResponse.unsafeCoerce()).toEqual(\n expectedFailureResponseBuffer,\n );\n expect(commandHandlerContext.queue).toHaveLength(0);\n });\n\n it(\"should correctly handle a leaf index of zero\", () => {\n // given\n const merkleRootHash = new Uint8Array(SHA256_SIZE).fill(0xaa);\n const leafNodeHash = new Uint8Array(SHA256_SIZE).fill(0xff);\n const handlerRequest = createRequest(\n COMMAND_CODE,\n merkleRootHash,\n leafNodeHash,\n );\n const leafIndex = 0;\n const encodedLeafIndexVarint = encodeVarint(leafIndex).unsafeCoerce();\n\n // when\n mockDataStore.getMerkleLeafIndex.mockReturnValue(Just(leafIndex));\n\n const handlerResponse = GetMerkleLeafIndexCommandHandler(\n handlerRequest,\n commandHandlerContext,\n );\n\n const expectedResponseBuffer = new Uint8Array(\n 1 + encodedLeafIndexVarint.length,\n );\n expectedResponseBuffer[0] = 1; // index found\n expectedResponseBuffer.set(encodedLeafIndexVarint, 1);\n\n // then\n expect(mockDataStore.getMerkleLeafIndex).toHaveBeenCalledWith(\n merkleRootHash,\n leafNodeHash,\n );\n expect(handlerResponse.isRight()).toBe(true);\n expect(handlerResponse.unsafeCoerce()).toEqual(expectedResponseBuffer);\n expect(commandHandlerContext.queue).toHaveLength(0);\n });\n\n it(\"should correctly handle the maximum SHA256_SIZE-bit unsigned integer as a leaf index\", () => {\n // given\n const merkleRootHash = new Uint8Array(SHA256_SIZE).fill(0xaa);\n const leafNodeHash = new Uint8Array(SHA256_SIZE).fill(0xff);\n const handlerRequest = createRequest(\n COMMAND_CODE,\n merkleRootHash,\n leafNodeHash,\n );\n const maximumLeafIndex = 0xffffffff; // maximum value of a SHA256_SIZE-bit unsigned integer\n const encodedLeafIndexVarint =\n encodeVarint(maximumLeafIndex).unsafeCoerce();\n\n // when\n mockDataStore.getMerkleLeafIndex.mockReturnValue(Just(maximumLeafIndex));\n\n const handlerResponse = GetMerkleLeafIndexCommandHandler(\n handlerRequest,\n commandHandlerContext,\n );\n\n const expectedResponseBuffer = new Uint8Array(\n 1 + encodedLeafIndexVarint.length,\n );\n expectedResponseBuffer[0] = 1; // index found\n expectedResponseBuffer.set(encodedLeafIndexVarint, 1);\n\n // then\n expect(mockDataStore.getMerkleLeafIndex).toHaveBeenCalledWith(\n merkleRootHash,\n leafNodeHash,\n );\n expect(handlerResponse.isRight()).toBe(true);\n expect(handlerResponse.unsafeCoerce()).toEqual(expectedResponseBuffer);\n expect(commandHandlerContext.queue).toHaveLength(0);\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["import_purify_ts", "import_constants", "import_Varint", "import_GetMerkleLeafIndexCommandHandler", "COMMAND_CODE", "commandHandlerContext", "mockDataStore", "createRequest", "commandCode", "merkleRootHash", "leafNodeHash", "handlerRequest", "leafIndex", "encodedLeafIndexVarint", "handlerResponse", "expectedResponseBuffer", "expectedFailureResponseBuffer", "maximumLeafIndex"]
|
|
7
7
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var E=require("@ledgerhq/device-management-kit"),h=require("purify-ts"),e=require("../../../app-binder/command/utils/constants"),M=require("../../../utils/Varint"),C=require("./Errors"),g=require("./GetMerkleLeafProofCommandHandler");const y=e.ClientCommandCodes.GET_MERKLE_LEAF_PROOF;describe("GetMerkleLeafProofCommandHandler",()=>{let l,m;beforeEach(()=>{vi.clearAllMocks(),m={getMerkleProof:vi.fn()},l={dataStore:m,queue:[],yieldedResults:[]}});const A=(n,u,r,d)=>new Uint8Array([n,...u,...(0,M.encodeVarint)(r).unsafeCoerce(),...(0,M.encodeVarint)(d).unsafeCoerce()]);it("should return the Merkle leaf and proof when found and proof length is less than or equal to the maximum allowed",()=>{const n=new Uint8Array(e.SHA256_SIZE).fill(1),u=1,r=2,d=A(y,n,u,r),i=new Uint8Array(e.SHA256_SIZE).fill(170),c=[new Uint8Array(e.SHA256_SIZE).fill(187),new Uint8Array(e.SHA256_SIZE).fill(204)];m.getMerkleProof.mockReturnValue((0,h.Just)({leafHash:i,proof:c}));const s=(0,g.GetMerkleLeafProofCommandHandler)(d,l),x=E.APDU_MAX_PAYLOAD-e.SHA256_SIZE-1-1,k=Math.floor(x/e.SHA256_SIZE),p=Math.min(c.length,k),o=new Uint8Array(e.SHA256_SIZE+1+1+e.SHA256_SIZE*p);let t=0;o.set(i,t),t+=e.SHA256_SIZE,o[t++]=c.length,o[t++]=p;for(let a=0;a<p;a++)o.set(c[a],t),t+=e.SHA256_SIZE;expect(m.getMerkleProof).toHaveBeenCalledWith(n,r),expect(s.isRight()).toBe(!0),expect(s.unsafeCoerce()).toEqual(o),expect(l.queue).toHaveLength(0)}),it("should handle proof longer than the maximum allowed by queuing the remaining proof elements",()=>{const n=new Uint8Array(e.SHA256_SIZE).fill(2),u=1,r=3,d=A(y,n,u,r),i=new Uint8Array(e.SHA256_SIZE).fill(221),s=Array.from({length:10},(f,H)=>new Uint8Array(e.SHA256_SIZE).fill(238+H));m.getMerkleProof.mockReturnValue((0,h.Just)({leafHash:i,proof:s}));const x=(0,g.GetMerkleLeafProofCommandHandler)(d,l),k=E.APDU_MAX_PAYLOAD-e.SHA256_SIZE-1-1,p=Math.floor(k/e.SHA256_SIZE),o=Math.min(s.length,p),t=new Uint8Array(e.SHA256_SIZE+1+1+e.SHA256_SIZE*o);let a=0;t.set(i,a),a+=e.SHA256_SIZE,t[a++]=s.length,t[a++]=o;for(let f=0;f<o;f++)t.set(s[f],a),a+=e.SHA256_SIZE;expect(m.getMerkleProof).toHaveBeenCalledWith(n,r),expect(x.isRight()).toBe(!0),expect(x.unsafeCoerce()).toEqual(t),expect(l.queue).toHaveLength(s.length-o);for(let f=0;f<l.queue.length;f++)expect(l.queue[f]).toEqual(s[o+f])}),it("should return an error when the Merkle proof is not found in the data store",()=>{const n=new Uint8Array(e.SHA256_SIZE).fill(4),u=1,r=5,d=A(y,n,u,r);m.getMerkleProof.mockReturnValue(h.Nothing);const i=(0,g.GetMerkleLeafProofCommandHandler)(d,l);expect(i.isLeft()).toBe(!0);const c=i.leftOrDefault(void 0);expect(c).toBeDefined(),expect(c instanceof C.ClientCommandHandlerError).toBe(!0),expect(m.getMerkleProof).toHaveBeenCalledWith(n,r),expect(l.queue).toHaveLength(0)})});
|
|
2
2
|
//# sourceMappingURL=GetMerkleLeafProofCommandHandler.test.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/internal/app-binder/command/client-command-handlers/GetMerkleLeafProofCommandHandler.test.ts"],
|
|
4
|
-
"sourcesContent": ["import { APDU_MAX_PAYLOAD } from \"@ledgerhq/device-management-kit\";\nimport { Just, Nothing } from \"purify-ts\";\n\nimport {\n ClientCommandCodes,\n SHA256_SIZE,\n} from \"@internal/app-binder/command/utils/constants\";\nimport { type DataStore } from \"@internal/data-store/model/DataStore\";\nimport { encodeVarint } from \"@internal/utils/Varint\";\n\nimport { type CommandHandlerContext } from \"./ClientCommandHandlersTypes\";\nimport { ClientCommandHandlerError } from \"./Errors\";\nimport { GetMerkleLeafProofCommandHandler } from \"./GetMerkleLeafProofCommandHandler\";\n\nconst COMMAND_CODE = ClientCommandCodes.GET_MERKLE_LEAF_PROOF;\n\ndescribe(\"GetMerkleLeafProofCommandHandler\", () => {\n let commandHandlerContext: CommandHandlerContext;\n let mockDataStore:
|
|
5
|
-
"mappings": "aAAA,IAAAA,EAAiC,2CACjCC,EAA8B,
|
|
6
|
-
"names": ["import_device_management_kit", "import_purify_ts", "import_constants", "import_Varint", "import_Errors", "import_GetMerkleLeafProofCommandHandler", "COMMAND_CODE", "commandHandlerContext", "mockDataStore", "createRequest", "commandCode", "merkleRootHash", "totalElements", "proofElementIndex", "request", "leafNodeHash", "proofElements", "handlerResponse", "maximumPayloadSize", "maximumProofElements", "proofElementsToInclude", "expectedResponse", "responseBufferOffset", "_", "proofIndex", "queuedProofIndex", "errorResponse"]
|
|
4
|
+
"sourcesContent": ["import { APDU_MAX_PAYLOAD } from \"@ledgerhq/device-management-kit\";\nimport { Just, Nothing } from \"purify-ts\";\nimport { type Mocked } from \"vitest\";\n\nimport {\n ClientCommandCodes,\n SHA256_SIZE,\n} from \"@internal/app-binder/command/utils/constants\";\nimport { type DataStore } from \"@internal/data-store/model/DataStore\";\nimport { encodeVarint } from \"@internal/utils/Varint\";\n\nimport { type CommandHandlerContext } from \"./ClientCommandHandlersTypes\";\nimport { ClientCommandHandlerError } from \"./Errors\";\nimport { GetMerkleLeafProofCommandHandler } from \"./GetMerkleLeafProofCommandHandler\";\n\nconst COMMAND_CODE = ClientCommandCodes.GET_MERKLE_LEAF_PROOF;\n\ndescribe(\"GetMerkleLeafProofCommandHandler\", () => {\n let commandHandlerContext: CommandHandlerContext;\n let mockDataStore: Mocked<DataStore>;\n\n beforeEach(() => {\n vi.clearAllMocks();\n\n mockDataStore = {\n getMerkleProof: vi.fn(),\n } as unknown as Mocked<DataStore>;\n\n commandHandlerContext = {\n dataStore: mockDataStore,\n queue: [],\n yieldedResults: [],\n };\n });\n\n const createRequest = (\n commandCode: number,\n merkleRootHash: Uint8Array,\n totalElements: number,\n proofElementIndex: number,\n ): Uint8Array =>\n new Uint8Array([\n commandCode,\n ...merkleRootHash,\n ...encodeVarint(totalElements).unsafeCoerce(),\n ...encodeVarint(proofElementIndex).unsafeCoerce(),\n ]);\n\n it(\"should return the Merkle leaf and proof when found and proof length is less than or equal to the maximum allowed\", () => {\n // given\n const merkleRootHash = new Uint8Array(SHA256_SIZE).fill(0x01);\n const totalElements = 1;\n const proofElementIndex = 2;\n const request = createRequest(\n COMMAND_CODE,\n merkleRootHash,\n totalElements,\n proofElementIndex,\n );\n const leafNodeHash = new Uint8Array(SHA256_SIZE).fill(0xaa);\n const proofElements = [\n new Uint8Array(SHA256_SIZE).fill(0xbb),\n new Uint8Array(SHA256_SIZE).fill(0xcc),\n ];\n\n // when\n mockDataStore.getMerkleProof.mockReturnValue(\n Just({ leafHash: leafNodeHash, proof: proofElements }),\n );\n\n const handlerResponse = GetMerkleLeafProofCommandHandler(\n request,\n commandHandlerContext,\n );\n\n const maximumPayloadSize = APDU_MAX_PAYLOAD - SHA256_SIZE - 1 - 1;\n const maximumProofElements = Math.floor(maximumPayloadSize / SHA256_SIZE);\n const proofElementsToInclude = Math.min(\n proofElements.length,\n maximumProofElements,\n );\n\n const expectedResponse = new Uint8Array(\n SHA256_SIZE + 1 + 1 + SHA256_SIZE * proofElementsToInclude,\n );\n let responseBufferOffset = 0;\n expectedResponse.set(leafNodeHash, responseBufferOffset); // leafHash\n responseBufferOffset += SHA256_SIZE;\n expectedResponse[responseBufferOffset++] = proofElements.length; // total proof length\n expectedResponse[responseBufferOffset++] = proofElementsToInclude;\n for (let index = 0; index < proofElementsToInclude; index++) {\n expectedResponse.set(\n proofElements[index] as Uint8Array,\n responseBufferOffset,\n );\n responseBufferOffset += SHA256_SIZE;\n }\n\n // then\n expect(mockDataStore.getMerkleProof).toHaveBeenCalledWith(\n merkleRootHash,\n proofElementIndex,\n );\n expect(handlerResponse.isRight()).toBe(true);\n expect(handlerResponse.unsafeCoerce()).toEqual(expectedResponse);\n expect(commandHandlerContext.queue).toHaveLength(0);\n });\n\n it(\"should handle proof longer than the maximum allowed by queuing the remaining proof elements\", () => {\n // given\n const merkleRootHash = new Uint8Array(SHA256_SIZE).fill(0x02);\n const totalElements = 1;\n const proofElementIndex = 3;\n const request = createRequest(\n COMMAND_CODE,\n merkleRootHash,\n totalElements,\n proofElementIndex,\n );\n const leafNodeHash = new Uint8Array(SHA256_SIZE).fill(0xdd);\n const totalProofLength = 10;\n const proofElements = Array.from(\n { length: totalProofLength },\n (_, proofIndex) => new Uint8Array(SHA256_SIZE).fill(0xee + proofIndex),\n );\n\n // when\n mockDataStore.getMerkleProof.mockReturnValue(\n Just({ leafHash: leafNodeHash, proof: proofElements }),\n );\n\n const handlerResponse = GetMerkleLeafProofCommandHandler(\n request,\n commandHandlerContext,\n );\n\n const maximumPayloadSize = APDU_MAX_PAYLOAD - SHA256_SIZE - 1 - 1;\n const maximumProofElements = Math.floor(maximumPayloadSize / SHA256_SIZE);\n const proofElementsToInclude = Math.min(\n proofElements.length,\n maximumProofElements,\n );\n\n const expectedResponse = new Uint8Array(\n SHA256_SIZE + 1 + 1 + SHA256_SIZE * proofElementsToInclude,\n );\n let responseBufferOffset = 0;\n expectedResponse.set(leafNodeHash, responseBufferOffset); // leafHash\n responseBufferOffset += SHA256_SIZE;\n expectedResponse[responseBufferOffset++] = proofElements.length; // total proof length\n expectedResponse[responseBufferOffset++] = proofElementsToInclude;\n for (let index = 0; index < proofElementsToInclude; index++) {\n expectedResponse.set(\n proofElements[index] as Uint8Array,\n responseBufferOffset,\n );\n responseBufferOffset += SHA256_SIZE;\n }\n\n // then\n expect(mockDataStore.getMerkleProof).toHaveBeenCalledWith(\n merkleRootHash,\n proofElementIndex,\n );\n expect(handlerResponse.isRight()).toBe(true);\n expect(handlerResponse.unsafeCoerce()).toEqual(expectedResponse);\n expect(commandHandlerContext.queue).toHaveLength(\n proofElements.length - proofElementsToInclude,\n );\n for (\n let queuedProofIndex = 0;\n queuedProofIndex < commandHandlerContext.queue.length;\n queuedProofIndex++\n ) {\n expect(commandHandlerContext.queue[queuedProofIndex]).toEqual(\n proofElements[proofElementsToInclude + queuedProofIndex],\n );\n }\n });\n\n it(\"should return an error when the Merkle proof is not found in the data store\", () => {\n // given\n const merkleRootHash = new Uint8Array(SHA256_SIZE).fill(0x04);\n const totalElements = 1;\n const proofElementIndex = 5;\n const request = createRequest(\n COMMAND_CODE,\n merkleRootHash,\n totalElements,\n proofElementIndex,\n );\n\n // when\n mockDataStore.getMerkleProof.mockReturnValue(Nothing);\n\n const handlerResponse = GetMerkleLeafProofCommandHandler(\n request,\n commandHandlerContext,\n );\n\n // then\n expect(handlerResponse.isLeft()).toBe(true);\n //@ts-expect-error purposedly use undefined insteal of a DMKError\n const errorResponse = handlerResponse.leftOrDefault(undefined);\n expect(errorResponse).toBeDefined();\n expect(errorResponse instanceof ClientCommandHandlerError).toBe(true);\n expect(mockDataStore.getMerkleProof).toHaveBeenCalledWith(\n merkleRootHash,\n proofElementIndex,\n );\n expect(commandHandlerContext.queue).toHaveLength(0);\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["import_device_management_kit", "import_purify_ts", "import_constants", "import_Varint", "import_Errors", "import_GetMerkleLeafProofCommandHandler", "COMMAND_CODE", "commandHandlerContext", "mockDataStore", "createRequest", "commandCode", "merkleRootHash", "totalElements", "proofElementIndex", "request", "leafNodeHash", "proofElements", "handlerResponse", "maximumPayloadSize", "maximumProofElements", "proofElementsToInclude", "expectedResponse", "responseBufferOffset", "index", "_", "proofIndex", "queuedProofIndex", "errorResponse"]
|
|
7
7
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var x=require("@ledgerhq/device-management-kit"),g=require("../../../app-binder/command/utils/constants"),f=require("./Errors"),m=require("./GetMoreElementsCommandHandler");const i=g.ClientCommandCodes.GET_MORE_ELEMENTS;describe("GetMoreElementsCommandHandler",()=>{let t,q;beforeEach(()=>{vi.clearAllMocks(),q={},t={dataStore:q,queue:[],yieldedResults:[]}});const l=o=>new Uint8Array([o]),p=(o,e)=>new Uint8Array(Array(o).fill(e));it("should retrieve the maximum number of elements within the payload size",()=>{const o=l(i),e=50,n=Math.floor((x.APDU_MAX_PAYLOAD-1-1)/e),s=Array.from({length:n},(a,u)=>p(e,16+u));t.queue=[...s];const r=(0,m.GetMoreElementsCommandHandler)(o,t),c=new Uint8Array(2+n*e);c[0]=n,c[1]=e;for(let a=0;a<n;a++)c.set(s[a],2+a*e);expect(r.isRight()).toBe(!0),expect(r.unsafeCoerce()).toEqual(c),expect(t.queue).toHaveLength(0)}),it("should retrieve the maximum number of elements allowed and queue the remainder",()=>{const o=l(i),e=30,n=Math.floor((x.APDU_MAX_PAYLOAD-1-1)/e),s=n+5,r=Array.from({length:s},(u,h)=>p(e,32+h));t.queue=[...r];const c=(0,m.GetMoreElementsCommandHandler)(o,t),a=new Uint8Array(2+n*e);a[0]=n,a[1]=e;for(let u=0;u<n;u++)a.set(r[u],2+u*e);expect(c.isRight()).toBe(!0),expect(c.unsafeCoerce()).toEqual(a),expect(t.queue).toHaveLength(s-n);for(let u=0;u<t.queue.length;u++)expect(t.queue[u]).toEqual(r[n+u])}),it("should return an error when queue is empty",()=>{const o=l(i);t.queue=[];const e=(0,m.GetMoreElementsCommandHandler)(o,t);expect(e.isLeft()).toBe(!0),e.caseOf({Left:n=>{expect(n).toBeInstanceOf(f.ClientCommandHandlerError),expect(t.queue).toHaveLength(0)},Right:n=>{throw new Error("Expected Left, got Right")}})}),it("should return an error when the first element is undefined",()=>{const o=l(i);t.queue=[void 0];const e=(0,m.GetMoreElementsCommandHandler)(o,t);expect(e.isLeft()).toBe(!0),e.caseOf({Left:n=>{expect(n).toBeInstanceOf(f.ClientCommandHandlerError),expect(t.queue).toHaveLength(1)},Right:n=>{throw new Error("Expected Left, got Right")}})}),it("should return an error when elements in queue have varying lengths",()=>{const o=l(i),e=p(40,48),n=p(50,49);t.queue=[e,n];const s=(0,m.GetMoreElementsCommandHandler)(o,t);expect(s.isLeft()).toBe(!0),s.caseOf({Left:r=>{expect(r).toBeInstanceOf(f.ClientCommandHandlerError),expect(t.queue).toHaveLength(2)},Right:r=>{throw new Error("Expected Left, got Right")}})}),it("should handle a single element that matches the maximum payload size",()=>{const o=l(i),e=253,n=[p(e,64)];t.queue=[...n];const s=(0,m.GetMoreElementsCommandHandler)(o,t),r=new Uint8Array(2+e);r[0]=1,r[1]=e,r.set(n[0],2),expect(s.isRight()).toBe(!0),expect(s.unsafeCoerce()).toEqual(r),expect(t.queue).toHaveLength(0)}),it("should handle a single element that exceeds the maximum payload size",()=>{const o=l(i),e=254,n=[p(e,80)];t.queue=[...n];const s=(0,m.GetMoreElementsCommandHandler)(o,t),r=new Uint8Array([0,e]);expect(s.isRight()).toBe(!0),expect(s.unsafeCoerce()).toEqual(r),expect(t.queue).toHaveLength(1)}),it("should handle multiple executions correctly",()=>{const o=l(i),e=60,n=Math.floor((x.APDU_MAX_PAYLOAD-1-1)/e),s=10,r=Array.from({length:s},(c,a)=>p(e,96+a));t.queue=[...r];for(let c=0;c<Math.ceil(s/n);c++){const a=t.queue.length,u=Math.min(n,a),h=new Uint8Array(2+u*e);h[0]=u,h[1]=e;for(let d=0;d<u;d++)h.set(t.queue[d],2+d*e);const E=(0,m.GetMoreElementsCommandHandler)(o,t);expect(E.isRight()).toBe(!0),expect(E.unsafeCoerce()).toEqual(h),expect(t.queue).toHaveLength(a-u)}expect(t.queue).toHaveLength(0)})});
|
|
2
2
|
//# sourceMappingURL=GetMoreElementsCommandHandler.test.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/internal/app-binder/command/client-command-handlers/GetMoreElementsCommandHandler.test.ts"],
|
|
4
|
-
"sourcesContent": ["import {\n APDU_MAX_PAYLOAD,\n type DmkError,\n} from \"@ledgerhq/device-management-kit\";\n\nimport { ClientCommandCodes } from \"@internal/app-binder/command/utils/constants\";\nimport { type DataStore } from \"@internal/data-store/model/DataStore\";\n\nimport { type CommandHandlerContext } from \"./ClientCommandHandlersTypes\";\nimport { ClientCommandHandlerError } from \"./Errors\";\nimport { GetMoreElementsCommandHandler } from \"./GetMoreElementsCommandHandler\";\n\nconst COMMAND_CODE = ClientCommandCodes.GET_MORE_ELEMENTS;\n\ndescribe(\"GetMoreElementsCommandHandler\", () => {\n let commandHandlerContext: CommandHandlerContext;\n let mockDataStore:
|
|
5
|
-
"mappings": "aAAA,IAAAA,EAGO,
|
|
4
|
+
"sourcesContent": ["import {\n APDU_MAX_PAYLOAD,\n type DmkError,\n} from \"@ledgerhq/device-management-kit\";\nimport { type Mocked } from \"vitest\";\n\nimport { ClientCommandCodes } from \"@internal/app-binder/command/utils/constants\";\nimport { type DataStore } from \"@internal/data-store/model/DataStore\";\n\nimport { type CommandHandlerContext } from \"./ClientCommandHandlersTypes\";\nimport { ClientCommandHandlerError } from \"./Errors\";\nimport { GetMoreElementsCommandHandler } from \"./GetMoreElementsCommandHandler\";\n\nconst COMMAND_CODE = ClientCommandCodes.GET_MORE_ELEMENTS;\n\ndescribe(\"GetMoreElementsCommandHandler\", () => {\n let commandHandlerContext: CommandHandlerContext;\n let mockDataStore: Mocked<DataStore>;\n\n beforeEach(() => {\n vi.clearAllMocks();\n\n mockDataStore = {} as unknown as Mocked<DataStore>;\n\n commandHandlerContext = {\n dataStore: mockDataStore,\n queue: [],\n yieldedResults: [],\n };\n });\n\n const buildRequest = (commandCode: number): Uint8Array =>\n new Uint8Array([commandCode]);\n\n const createElement = (elementSize: number, fillValue: number): Uint8Array =>\n new Uint8Array(Array(elementSize).fill(fillValue));\n\n it(\"should retrieve the maximum number of elements within the payload size\", () => {\n // given\n const request = buildRequest(COMMAND_CODE);\n const elementSize = 50;\n const maximumElements = Math.floor(\n (APDU_MAX_PAYLOAD - 1 - 1) / elementSize,\n );\n const elements = Array.from({ length: maximumElements }, (_, index) =>\n createElement(elementSize, 0x10 + index),\n );\n\n // when\n commandHandlerContext.queue = [...elements];\n\n const response = GetMoreElementsCommandHandler(\n request,\n commandHandlerContext,\n );\n\n const expectedResponse = new Uint8Array(\n 1 + 1 + maximumElements * elementSize,\n );\n expectedResponse[0] = maximumElements;\n expectedResponse[1] = elementSize;\n for (let elementIndex = 0; elementIndex < maximumElements; elementIndex++) {\n expectedResponse.set(\n elements[elementIndex] as Uint8Array,\n 2 + elementIndex * elementSize,\n );\n }\n\n // then\n expect(response.isRight()).toBe(true);\n expect(response.unsafeCoerce()).toEqual(expectedResponse);\n expect(commandHandlerContext.queue).toHaveLength(0);\n });\n\n it(\"should retrieve the maximum number of elements allowed and queue the remainder\", () => {\n // given\n const request = buildRequest(COMMAND_CODE);\n const elementSize = 30;\n const maximumElements = Math.floor(\n (APDU_MAX_PAYLOAD - 1 - 1) / elementSize,\n );\n const totalElements = maximumElements + 5;\n const elements = Array.from({ length: totalElements }, (_, index) =>\n createElement(elementSize, 0x20 + index),\n );\n\n // when\n commandHandlerContext.queue = [...elements];\n\n const response = GetMoreElementsCommandHandler(\n request,\n commandHandlerContext,\n );\n\n const expectedResponse = new Uint8Array(\n 1 + 1 + maximumElements * elementSize,\n );\n expectedResponse[0] = maximumElements;\n expectedResponse[1] = elementSize;\n for (let elementIndex = 0; elementIndex < maximumElements; elementIndex++) {\n expectedResponse.set(\n elements[elementIndex] as Uint8Array,\n 2 + elementIndex * elementSize,\n );\n }\n\n // then\n expect(response.isRight()).toBe(true);\n expect(response.unsafeCoerce()).toEqual(expectedResponse);\n expect(commandHandlerContext.queue).toHaveLength(\n totalElements - maximumElements,\n );\n for (\n let queuedElementIndex = 0;\n queuedElementIndex < commandHandlerContext.queue.length;\n queuedElementIndex++\n ) {\n expect(commandHandlerContext.queue[queuedElementIndex]).toEqual(\n elements[maximumElements + queuedElementIndex],\n );\n }\n });\n\n it(\"should return an error when queue is empty\", () => {\n // given\n const request = buildRequest(COMMAND_CODE);\n\n // when\n commandHandlerContext.queue = [];\n\n const response = GetMoreElementsCommandHandler(\n request,\n commandHandlerContext,\n );\n\n // then\n expect(response.isLeft()).toBe(true);\n response.caseOf({\n Left: (error: DmkError) => {\n expect(error).toBeInstanceOf(ClientCommandHandlerError);\n expect(commandHandlerContext.queue).toHaveLength(0);\n },\n Right: (_) => {\n throw new Error(\"Expected Left, got Right\");\n },\n });\n });\n\n it(\"should return an error when the first element is undefined\", () => {\n // given\n const request = buildRequest(COMMAND_CODE);\n\n // when\n commandHandlerContext.queue = [undefined as unknown as Uint8Array];\n\n const response = GetMoreElementsCommandHandler(\n request,\n commandHandlerContext,\n );\n\n // then\n expect(response.isLeft()).toBe(true);\n response.caseOf({\n Left: (error: DmkError) => {\n expect(error).toBeInstanceOf(ClientCommandHandlerError);\n expect(commandHandlerContext.queue).toHaveLength(1);\n },\n Right: (_) => {\n throw new Error(\"Expected Left, got Right\");\n },\n });\n });\n\n it(\"should return an error when elements in queue have varying lengths\", () => {\n // given\n const request = buildRequest(COMMAND_CODE);\n const firstElement = createElement(40, 0x30);\n const secondElement = createElement(50, 0x31);\n\n // when\n commandHandlerContext.queue = [firstElement, secondElement];\n\n const response = GetMoreElementsCommandHandler(\n request,\n commandHandlerContext,\n );\n\n // then\n expect(response.isLeft()).toBe(true);\n response.caseOf({\n Left: (error: DmkError) => {\n expect(error).toBeInstanceOf(ClientCommandHandlerError);\n expect(commandHandlerContext.queue).toHaveLength(2);\n },\n Right: (_) => {\n throw new Error(\"Expected Left, got Right\");\n },\n });\n });\n\n it(\"should handle a single element that matches the maximum payload size\", () => {\n // given\n const request = buildRequest(COMMAND_CODE);\n const elementSize = 253;\n const elements = [createElement(elementSize, 0x40)];\n\n // when\n commandHandlerContext.queue = [...elements];\n\n const response = GetMoreElementsCommandHandler(\n request,\n commandHandlerContext,\n );\n\n const expectedResponse = new Uint8Array(1 + 1 + elementSize);\n expectedResponse[0] = 1;\n expectedResponse[1] = elementSize;\n expectedResponse.set(elements[0] as Uint8Array, 2);\n\n // then\n expect(response.isRight()).toBe(true);\n expect(response.unsafeCoerce()).toEqual(expectedResponse);\n expect(commandHandlerContext.queue).toHaveLength(0);\n });\n\n it(\"should handle a single element that exceeds the maximum payload size\", () => {\n // given\n const request = buildRequest(COMMAND_CODE);\n const elementSize = 254;\n const elements = [createElement(elementSize, 0x50)];\n\n // when\n commandHandlerContext.queue = [...elements];\n\n const response = GetMoreElementsCommandHandler(\n request,\n commandHandlerContext,\n );\n\n const expectedResponse = new Uint8Array([0, elementSize]);\n\n // then\n expect(response.isRight()).toBe(true);\n expect(response.unsafeCoerce()).toEqual(expectedResponse);\n expect(commandHandlerContext.queue).toHaveLength(1); // still there\n });\n\n it(\"should handle multiple executions correctly\", () => {\n // given\n const request = buildRequest(COMMAND_CODE);\n const elementSize = 60;\n const maximumElements = Math.floor(\n (APDU_MAX_PAYLOAD - 1 - 1) / elementSize,\n );\n const totalElements = 10;\n const elements = Array.from({ length: totalElements }, (_, index) =>\n createElement(elementSize, 0x60 + index),\n );\n\n // when\n commandHandlerContext.queue = [...elements];\n\n // then\n for (\n let executionIndex = 0;\n executionIndex < Math.ceil(totalElements / maximumElements);\n executionIndex++\n ) {\n const previousQueueLength = commandHandlerContext.queue.length;\n const expectedNumberOfElements = Math.min(\n maximumElements,\n previousQueueLength,\n );\n const expectedResponse = new Uint8Array(\n 1 + 1 + expectedNumberOfElements * elementSize,\n );\n expectedResponse[0] = expectedNumberOfElements;\n expectedResponse[1] = elementSize;\n for (\n let elementIndex = 0;\n elementIndex < expectedNumberOfElements;\n elementIndex++\n ) {\n expectedResponse.set(\n commandHandlerContext.queue[elementIndex] as Uint8Array,\n 2 + elementIndex * elementSize,\n );\n }\n\n const response = GetMoreElementsCommandHandler(\n request,\n commandHandlerContext,\n );\n\n expect(response.isRight()).toBe(true);\n expect(response.unsafeCoerce()).toEqual(expectedResponse);\n expect(commandHandlerContext.queue).toHaveLength(\n previousQueueLength - expectedNumberOfElements,\n );\n }\n\n expect(commandHandlerContext.queue).toHaveLength(0);\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["import_device_management_kit", "import_constants", "import_Errors", "import_GetMoreElementsCommandHandler", "COMMAND_CODE", "commandHandlerContext", "mockDataStore", "buildRequest", "commandCode", "createElement", "elementSize", "fillValue", "request", "maximumElements", "elements", "_", "index", "response", "expectedResponse", "elementIndex", "totalElements", "queuedElementIndex", "error", "firstElement", "secondElement", "executionIndex", "previousQueueLength", "expectedNumberOfElements"]
|
|
7
7
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var c=require("purify-ts"),h=require("../../../app-binder/command/utils/constants"),m=require("../../../utils/Varint"),p=require("./Errors"),u=require("./GetPreimageCommandHandler");const x=h.ClientCommandCodes.GET_PREIMAGE;vi.mock("@internal/utils/Varint",()=>({encodeVarint:vi.fn()}));describe("GetPreimageCommandHandler",()=>{let t,o;beforeEach(()=>{vi.clearAllMocks(),o={getPreimage:vi.fn()},t={dataStore:o,queue:[],yieldedResults:[]}}),it("should return the preimage when it is found and its length is within the maximum payload size",()=>{const r=new Uint8Array(h.SHA256_SIZE).fill(1),e=new Uint8Array([170,187,204]),l=e.length;m.encodeVarint.mockReturnValue({unsafeCoerce:()=>new Uint8Array([3])}),o.getPreimage.mockReturnValue((0,c.Just)(e));const s=new Uint8Array([x,0,...r]),i=(0,u.GetPreimageCommandHandler)(s,t),a=new Uint8Array([3,3,170,187,204]);expect(o.getPreimage).toHaveBeenCalledWith(r),expect(m.encodeVarint).toHaveBeenCalledWith(l),i.caseOf({Left:n=>{throw new Error("Expected Right, got Left")},Right:n=>{expect(n).toEqual(a),expect(t.queue).toHaveLength(0)}})}),it("should handle a preimage longer than the maximum payload size by queuing the remaining bytes",()=>{const r=new Uint8Array(h.SHA256_SIZE).fill(2),e=new Uint8Array(300).fill(255),l=e.length;m.encodeVarint.mockReturnValue({unsafeCoerce:()=>new Uint8Array([172,2])}),o.getPreimage.mockReturnValue((0,c.Just)(e));const s=new Uint8Array([x,0,...r]),i=(0,u.GetPreimageCommandHandler)(s,t),a=new Uint8Array([172,2]),n=Math.min(255-a.length-1,e.length),g=new Uint8Array(a.length+1+n);g.set(a,0),g.set([n],a.length),g.set(e.slice(0,n),a.length+1),expect(o.getPreimage).toHaveBeenCalledWith(r),expect(m.encodeVarint).toHaveBeenCalledWith(l),i.caseOf({Left:d=>{throw new Error("Expected Right, got Left")},Right:d=>{expect(d).toEqual(g),expect(t.queue).toHaveLength(e.length-n),expect(t.queue[0]).toEqual(new Uint8Array([255])),expect(t.queue[t.queue.length-1]).toEqual(new Uint8Array([255]))}})}),it("should return an error when the preimage is not found",()=>{const r=new Uint8Array(h.SHA256_SIZE).fill(3);o.getPreimage.mockReturnValue(c.Nothing);const e=new Uint8Array([x,0,...r]),l=(0,u.GetPreimageCommandHandler)(e,t);expect(o.getPreimage).toHaveBeenCalledWith(r),expect(m.encodeVarint).not.toHaveBeenCalled(),expect(t.queue).toHaveLength(0),l.caseOf({Left:s=>{expect(s).toBeInstanceOf(p.ClientCommandHandlerError)},Right:s=>{throw new Error("Expected Left, got Right")}})}),it("should handle a preimage length where the maximum payload size exactly matches the preimage length",()=>{const r=new Uint8Array(h.SHA256_SIZE).fill(5),e=new Uint8Array(252);e.fill(119),m.encodeVarint.mockReturnValue({unsafeCoerce:()=>new Uint8Array([252])}),o.getPreimage.mockReturnValue((0,c.Just)(e));const l=new Uint8Array([x,0,...r]),s=(0,u.GetPreimageCommandHandler)(l,t),i=new Uint8Array([252]),a=Math.min(255-i.length-1,e.length),n=new Uint8Array(i.length+1+a);n.set(i,0),n.set([a],i.length),n.set(e,i.length+1),expect(s).toStrictEqual(c.Either.of(n)),expect(t.queue).toHaveLength(0)})});
|
|
2
2
|
//# sourceMappingURL=GetPreimageCommandHandler.test.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/internal/app-binder/command/client-command-handlers/GetPreimageCommandHandler.test.ts"],
|
|
4
|
-
"sourcesContent": ["import { type DmkError } from \"@ledgerhq/device-management-kit\";\nimport { Either, Just, Nothing } from \"purify-ts\";\n\nimport {\n ClientCommandCodes,\n SHA256_SIZE,\n} from \"@internal/app-binder/command/utils/constants\";\nimport { type DataStore } from \"@internal/data-store/model/DataStore\";\nimport { encodeVarint } from \"@internal/utils/Varint\";\n\nimport { type CommandHandlerContext } from \"./ClientCommandHandlersTypes\";\nimport { ClientCommandHandlerError } from \"./Errors\";\nimport { GetPreimageCommandHandler } from \"./GetPreimageCommandHandler\";\n\nconst COMMAND_CODE = ClientCommandCodes.GET_PREIMAGE;\n\
|
|
5
|
-
"mappings": "aACA,IAAAA,EAAsC,
|
|
4
|
+
"sourcesContent": ["import { type DmkError } from \"@ledgerhq/device-management-kit\";\nimport { Either, Just, Nothing } from \"purify-ts\";\nimport { type Mock, type Mocked } from \"vitest\";\n\nimport {\n ClientCommandCodes,\n SHA256_SIZE,\n} from \"@internal/app-binder/command/utils/constants\";\nimport { type DataStore } from \"@internal/data-store/model/DataStore\";\nimport { encodeVarint } from \"@internal/utils/Varint\";\n\nimport { type CommandHandlerContext } from \"./ClientCommandHandlersTypes\";\nimport { ClientCommandHandlerError } from \"./Errors\";\nimport { GetPreimageCommandHandler } from \"./GetPreimageCommandHandler\";\n\nconst COMMAND_CODE = ClientCommandCodes.GET_PREIMAGE;\n\nvi.mock(\"@internal/utils/Varint\", () => ({\n encodeVarint: vi.fn(),\n}));\n\ndescribe(\"GetPreimageCommandHandler\", () => {\n let commandHandlerContext: CommandHandlerContext;\n let mockDataStore: Mocked<DataStore>;\n\n beforeEach(() => {\n vi.clearAllMocks();\n\n mockDataStore = {\n getPreimage: vi.fn(),\n } as unknown as Mocked<DataStore>;\n\n commandHandlerContext = {\n dataStore: mockDataStore,\n queue: [],\n yieldedResults: [],\n };\n });\n\n it(\"should return the preimage when it is found and its length is within the maximum payload size\", () => {\n // given\n const requestHash = new Uint8Array(SHA256_SIZE).fill(0x01);\n const preimage = new Uint8Array([0xaa, 0xbb, 0xcc]);\n const preimageLength = preimage.length;\n\n // when\n (encodeVarint as Mock).mockReturnValue({\n unsafeCoerce: () => new Uint8Array([0x03]), // varint for 3\n });\n\n mockDataStore.getPreimage.mockReturnValue(Just(preimage));\n\n const request = new Uint8Array([COMMAND_CODE, 0x00, ...requestHash]);\n\n const handlerResult = GetPreimageCommandHandler(\n request,\n commandHandlerContext,\n );\n\n const expectedResponse = new Uint8Array([0x03, 0x03, 0xaa, 0xbb, 0xcc]);\n\n // then\n expect(mockDataStore.getPreimage).toHaveBeenCalledWith(requestHash);\n expect(encodeVarint).toHaveBeenCalledWith(preimageLength);\n handlerResult.caseOf({\n Left: (_) => {\n throw new Error(\"Expected Right, got Left\");\n },\n Right: (response) => {\n expect(response).toEqual(expectedResponse);\n expect(commandHandlerContext.queue).toHaveLength(0);\n },\n });\n });\n\n it(\"should handle a preimage longer than the maximum payload size by queuing the remaining bytes\", () => {\n // given\n const requestHash = new Uint8Array(SHA256_SIZE).fill(0x02);\n const preimage = new Uint8Array(300).fill(0xff);\n const preimageLength = preimage.length;\n\n // when\n (encodeVarint as Mock).mockReturnValue({\n unsafeCoerce: () => new Uint8Array([0xac, 0x02]),\n });\n\n mockDataStore.getPreimage.mockReturnValue(Just(preimage));\n\n const request = new Uint8Array([COMMAND_CODE, 0x00, ...requestHash]);\n\n const handlerResult = GetPreimageCommandHandler(\n request,\n commandHandlerContext,\n );\n\n const varintEncodedLength = new Uint8Array([0xac, 0x02]); // varint for 300\n const maximumBytesInResponse = Math.min(\n 255 - varintEncodedLength.length - 1,\n preimage.length,\n );\n const expectedResponse = new Uint8Array(\n varintEncodedLength.length + 1 + maximumBytesInResponse,\n );\n expectedResponse.set(varintEncodedLength, 0); // varint\n expectedResponse.set([maximumBytesInResponse], varintEncodedLength.length); // bytes in response\n expectedResponse.set(\n preimage.slice(0, maximumBytesInResponse),\n varintEncodedLength.length + 1,\n );\n\n // then\n expect(mockDataStore.getPreimage).toHaveBeenCalledWith(requestHash);\n expect(encodeVarint).toHaveBeenCalledWith(preimageLength);\n handlerResult.caseOf({\n Left: (_) => {\n throw new Error(\"Expected Right, got Left\");\n },\n Right: (response) => {\n expect(response).toEqual(expectedResponse);\n expect(commandHandlerContext.queue).toHaveLength(\n preimage.length - maximumBytesInResponse,\n );\n expect(commandHandlerContext.queue[0]).toEqual(new Uint8Array([0xff]));\n expect(\n commandHandlerContext.queue[commandHandlerContext.queue.length - 1],\n ).toEqual(new Uint8Array([0xff]));\n },\n });\n });\n\n it(\"should return an error when the preimage is not found\", () => {\n // given\n const requestHash = new Uint8Array(SHA256_SIZE).fill(0x03);\n\n // when\n mockDataStore.getPreimage.mockReturnValue(Nothing);\n\n const request = new Uint8Array([COMMAND_CODE, 0x00, ...requestHash]);\n\n const handlerResult = GetPreimageCommandHandler(\n request,\n commandHandlerContext,\n );\n\n // then\n expect(mockDataStore.getPreimage).toHaveBeenCalledWith(requestHash);\n expect(encodeVarint).not.toHaveBeenCalled();\n expect(commandHandlerContext.queue).toHaveLength(0);\n handlerResult.caseOf({\n Left: (error: DmkError) => {\n expect(error).toBeInstanceOf(ClientCommandHandlerError);\n },\n Right: (_) => {\n throw new Error(\"Expected Left, got Right\");\n },\n });\n });\n\n it(\"should handle a preimage length where the maximum payload size exactly matches the preimage length\", () => {\n // given\n const requestHash = new Uint8Array(SHA256_SIZE).fill(0x05);\n const preimage = new Uint8Array(252);\n preimage.fill(0x77);\n\n // when\n (encodeVarint as Mock).mockReturnValue({\n unsafeCoerce: () => new Uint8Array([0xfc]),\n });\n\n mockDataStore.getPreimage.mockReturnValue(Just(preimage));\n\n const request = new Uint8Array([COMMAND_CODE, 0x00, ...requestHash]);\n\n const handlerResult = GetPreimageCommandHandler(\n request,\n commandHandlerContext,\n );\n\n const varintEncodedLength = new Uint8Array([0xfc]);\n const maximumBytesInResponse = Math.min(\n 255 - varintEncodedLength.length - 1,\n preimage.length,\n );\n const expectedResponse = new Uint8Array(\n varintEncodedLength.length + 1 + maximumBytesInResponse,\n );\n expectedResponse.set(varintEncodedLength, 0);\n expectedResponse.set([maximumBytesInResponse], varintEncodedLength.length);\n expectedResponse.set(preimage, varintEncodedLength.length + 1);\n\n // then\n expect(handlerResult).toStrictEqual(Either.of(expectedResponse));\n expect(commandHandlerContext.queue).toHaveLength(0);\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["import_purify_ts", "import_constants", "import_Varint", "import_Errors", "import_GetPreimageCommandHandler", "COMMAND_CODE", "commandHandlerContext", "mockDataStore", "requestHash", "preimage", "preimageLength", "request", "handlerResult", "expectedResponse", "_", "response", "varintEncodedLength", "maximumBytesInResponse", "error"]
|
|
7
7
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var E=Object.create;var p=Object.defineProperty;var x=Object.getOwnPropertyDescriptor;var y=Object.getOwnPropertyNames;var H=Object.getPrototypeOf,M=Object.prototype.hasOwnProperty;var v=(n,t,o,l)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of y(t))!M.call(n,r)&&r!==o&&p(n,r,{get:()=>t[r],enumerable:!(l=x(t,r))||l.enumerable});return n};var C=(n,t,o)=>(o=n!=null?E(H(n)):{},v(t||!n||!n.__esModule?p(o,"default",{value:n,enumerable:!0}):o,n));var m=require("purify-ts"),u=require("../../../app-binder/command/client-command-handlers/Errors"),I=C(require("../../../app-binder/command/client-command-handlers/GetMerkleLeafIndexCommandHandler")),k=C(require("../../../app-binder/command/client-command-handlers/GetMerkleLeafProofCommandHandler")),L=C(require("../../../app-binder/command/client-command-handlers/GetMoreElementsCommandHandler")),g=C(require("../../../app-binder/command/client-command-handlers/GetPreimageCommandHandler")),A=C(require("../../../app-binder/command/client-command-handlers/YeldCommandHandler")),f=require("../../../app-binder/command/service/ClientCommandInterpreter"),i=require("../../../app-binder/command/utils/constants");describe("ClientCommandInterpreter",()=>{let n,t,o,l,r,s,c;beforeAll(()=>{o=vi.spyOn(A,"YieldCommandHandler").mockImplementation((e,a)=>(a.yieldedResults.push(e.slice(1)),(0,m.Right)(new Uint8Array([])))),l=vi.spyOn(g,"GetPreimageCommandHandler").mockImplementation((e,a)=>{const d=new Uint8Array([1,2,3]);return a.dataStore.getPreimage=vi.fn().mockReturnValue({isJust:()=>!0,extract:()=>d}),(0,m.Right)(d)}),r=vi.spyOn(k,"GetMerkleLeafProofCommandHandler").mockImplementation((e,a)=>(0,m.Right)(new Uint8Array([]))),s=vi.spyOn(I,"GetMerkleLeafIndexCommandHandler").mockImplementation((e,a)=>(a.dataStore.getMerkleLeafIndex=vi.fn().mockReturnValue({mapOrDefault:(d,B)=>d(42)}),(0,m.Right)(new Uint8Array([42])))),c=vi.spyOn(L,"GetMoreElementsCommandHandler").mockImplementation((e,a)=>a.queue.length===0?(0,m.Left)(new u.ClientCommandHandlerError("No more elements in queue")):(0,m.Right)(a.queue.shift()))}),beforeEach(()=>{n=new f.ClientCommandInterpreter,t={yieldedResults:[],dataStore:{getPreimage:vi.fn().mockReturnValue({isJust:()=>!1}),getMerkleLeafIndex:vi.fn()},queue:[new Uint8Array([1])]},vi.clearAllMocks()}),it("should call YieldCommandHandler when request code is YIELD",()=>{const e=new Uint8Array([i.ClientCommandCodes.YIELD]);n.getClientCommandPayload(e,t),expect(o).toHaveBeenCalledTimes(1),expect(o).toHaveBeenCalledWith(e,t)}),it("should call GetPreimageCommandHandler when request code is GET_PREIMAGE",()=>{const e=new Uint8Array([i.ClientCommandCodes.GET_PREIMAGE,0,...new Uint8Array(32)]);n.getClientCommandPayload(e,t),expect(l).toHaveBeenCalledTimes(1),expect(l).toHaveBeenCalledWith(e,t)}),it("should call GetMerkleLeafProofCommandHandler when request code is GET_MERKLE_LEAF_PROOF",()=>{const e=new Uint8Array([i.ClientCommandCodes.GET_MERKLE_LEAF_PROOF]);n.getClientCommandPayload(e,t),expect(r).toHaveBeenCalledTimes(1),expect(r).toHaveBeenCalledWith(e,t)}),it("should call GetMerkleLeafIndexCommandHandler when request code is GET_MERKLE_LEAF_INDEX",()=>{const e=new Uint8Array([i.ClientCommandCodes.GET_MERKLE_LEAF_INDEX,...new Uint8Array(64)]);n.getClientCommandPayload(e,t),expect(s).toHaveBeenCalledTimes(1),expect(s).toHaveBeenCalledWith(e,t)}),it("should call GetMoreElementsCommandHandler when request code is GET_MORE_ELEMENTS",()=>{const e=new Uint8Array([i.ClientCommandCodes.GET_MORE_ELEMENTS]);n.getClientCommandPayload(e,t),expect(c).toHaveBeenCalledTimes(1),expect(c).toHaveBeenCalledWith(e,t)}),it("should return an error for an unknown command code",()=>{const a=new Uint8Array([255]),d=n.getClientCommandPayload(a,t);expect(d.isLeft()).toBe(!0),expect(d.extract()).toBeInstanceOf(u.ClientCommandHandlerError),expect(o).not.toHaveBeenCalled(),expect(l).not.toHaveBeenCalled(),expect(r).not.toHaveBeenCalled(),expect(s).not.toHaveBeenCalled(),expect(c).not.toHaveBeenCalled()}),it("should return an error if no request code is present",()=>{const e=new Uint8Array([]),a=n.getClientCommandPayload(e,t);expect(a.isLeft()).toBe(!0),expect(a.extract()).toBeInstanceOf(u.ClientCommandHandlerError),expect(o).not.toHaveBeenCalled(),expect(l).not.toHaveBeenCalled(),expect(r).not.toHaveBeenCalled(),expect(s).not.toHaveBeenCalled(),expect(c).not.toHaveBeenCalled()})});
|
|
2
2
|
//# sourceMappingURL=ClientCommandInterpreter.test.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/internal/app-binder/command/service/ClientCommandInterpreter.test.ts"],
|
|
4
|
-
"sourcesContent": ["import { Left, Right } from \"purify-ts\";\n\nimport { type ClientCommandContext } from \"@internal/app-binder/command/client-command-handlers/ClientCommandHandlersTypes\";\nimport { ClientCommandHandlerError } from \"@internal/app-binder/command/client-command-handlers/Errors\";\nimport * as GetMerkleLeafIndexCommandHandlerModule from \"@internal/app-binder/command/client-command-handlers/GetMerkleLeafIndexCommandHandler\";\nimport * as GetMerkleLeafProofCommandHandlerModule from \"@internal/app-binder/command/client-command-handlers/GetMerkleLeafProofCommandHandler\";\nimport * as GetMoreElementsCommandHandlerModule from \"@internal/app-binder/command/client-command-handlers/GetMoreElementsCommandHandler\";\nimport * as GetPreimageCommandHandlerModule from \"@internal/app-binder/command/client-command-handlers/GetPreimageCommandHandler\";\nimport * as YieldCommandHandlerModule from \"@internal/app-binder/command/client-command-handlers/YeldCommandHandler\";\nimport { ClientCommandInterpreter } from \"@internal/app-binder/command/service/ClientCommandInterpreter\";\nimport { ClientCommandCodes } from \"@internal/app-binder/command/utils/constants\";\n\ndescribe(\"ClientCommandInterpreter\", () => {\n let interpreter: ClientCommandInterpreter;\n let context: ClientCommandContext;\n\n let yieldSpy:
|
|
5
|
-
"mappings": "wdAAA,IAAAA,EAA4B,
|
|
4
|
+
"sourcesContent": ["import { Left, Right } from \"purify-ts\";\nimport { type MockInstance } from \"vitest\";\n\nimport { type ClientCommandContext } from \"@internal/app-binder/command/client-command-handlers/ClientCommandHandlersTypes\";\nimport { ClientCommandHandlerError } from \"@internal/app-binder/command/client-command-handlers/Errors\";\nimport * as GetMerkleLeafIndexCommandHandlerModule from \"@internal/app-binder/command/client-command-handlers/GetMerkleLeafIndexCommandHandler\";\nimport * as GetMerkleLeafProofCommandHandlerModule from \"@internal/app-binder/command/client-command-handlers/GetMerkleLeafProofCommandHandler\";\nimport * as GetMoreElementsCommandHandlerModule from \"@internal/app-binder/command/client-command-handlers/GetMoreElementsCommandHandler\";\nimport * as GetPreimageCommandHandlerModule from \"@internal/app-binder/command/client-command-handlers/GetPreimageCommandHandler\";\nimport * as YieldCommandHandlerModule from \"@internal/app-binder/command/client-command-handlers/YeldCommandHandler\";\nimport { ClientCommandInterpreter } from \"@internal/app-binder/command/service/ClientCommandInterpreter\";\nimport { ClientCommandCodes } from \"@internal/app-binder/command/utils/constants\";\n\ndescribe(\"ClientCommandInterpreter\", () => {\n let interpreter: ClientCommandInterpreter;\n let context: ClientCommandContext;\n\n let yieldSpy: MockInstance;\n let getPreimageSpy: MockInstance;\n let getMerkleLeafProofSpy: MockInstance;\n let getMerkleLeafIndexSpy: MockInstance;\n let getMoreElementsSpy: MockInstance;\n\n beforeAll(() => {\n yieldSpy = vi\n .spyOn(YieldCommandHandlerModule, \"YieldCommandHandler\")\n .mockImplementation((request, ctx) => {\n ctx.yieldedResults.push(request.slice(1));\n return Right(new Uint8Array([]));\n });\n\n getPreimageSpy = vi\n .spyOn(GetPreimageCommandHandlerModule, \"GetPreimageCommandHandler\")\n .mockImplementation((_request, ctx) => {\n const preimage = new Uint8Array([1, 2, 3]);\n ctx.dataStore.getPreimage = vi\n .fn()\n .mockReturnValue({ isJust: () => true, extract: () => preimage });\n return Right(preimage);\n });\n\n getMerkleLeafProofSpy = vi\n .spyOn(\n GetMerkleLeafProofCommandHandlerModule,\n \"GetMerkleLeafProofCommandHandler\",\n )\n .mockImplementation((_request, _ctx) => {\n return Right(new Uint8Array([]));\n });\n\n getMerkleLeafIndexSpy = vi\n .spyOn(\n GetMerkleLeafIndexCommandHandlerModule,\n \"GetMerkleLeafIndexCommandHandler\",\n )\n .mockImplementation((_request, ctx) => {\n ctx.dataStore.getMerkleLeafIndex = vi.fn().mockReturnValue({\n mapOrDefault: (f: (idx: number) => Uint8Array, _def: Uint8Array) =>\n f(42),\n });\n return Right(new Uint8Array([42]));\n });\n\n getMoreElementsSpy = vi\n .spyOn(\n GetMoreElementsCommandHandlerModule,\n \"GetMoreElementsCommandHandler\",\n )\n .mockImplementation((_request, ctx) => {\n if (ctx.queue.length === 0) {\n return Left(\n new ClientCommandHandlerError(\"No more elements in queue\"),\n );\n }\n return Right(ctx.queue.shift()!);\n });\n });\n\n beforeEach(() => {\n interpreter = new ClientCommandInterpreter();\n context = {\n yieldedResults: [],\n dataStore: {\n getPreimage: vi.fn().mockReturnValue({ isJust: () => false }),\n getMerkleLeafIndex: vi.fn(),\n },\n queue: [new Uint8Array([0x01])],\n } as unknown as ClientCommandContext;\n\n vi.clearAllMocks();\n });\n\n it(\"should call YieldCommandHandler when request code is YIELD\", () => {\n //given\n const request = new Uint8Array([ClientCommandCodes.YIELD]);\n\n //when\n interpreter.getClientCommandPayload(request, context);\n\n //then\n expect(yieldSpy).toHaveBeenCalledTimes(1);\n expect(yieldSpy).toHaveBeenCalledWith(request, context);\n });\n\n it(\"should call GetPreimageCommandHandler when request code is GET_PREIMAGE\", () => {\n //given\n const request = new Uint8Array([\n ClientCommandCodes.GET_PREIMAGE,\n 0x00,\n ...new Uint8Array(32),\n ]);\n\n //when\n interpreter.getClientCommandPayload(request, context);\n\n //then\n expect(getPreimageSpy).toHaveBeenCalledTimes(1);\n expect(getPreimageSpy).toHaveBeenCalledWith(request, context);\n });\n\n it(\"should call GetMerkleLeafProofCommandHandler when request code is GET_MERKLE_LEAF_PROOF\", () => {\n //given\n const request = new Uint8Array([ClientCommandCodes.GET_MERKLE_LEAF_PROOF]);\n\n //when\n interpreter.getClientCommandPayload(request, context);\n\n //then\n expect(getMerkleLeafProofSpy).toHaveBeenCalledTimes(1);\n expect(getMerkleLeafProofSpy).toHaveBeenCalledWith(request, context);\n });\n\n it(\"should call GetMerkleLeafIndexCommandHandler when request code is GET_MERKLE_LEAF_INDEX\", () => {\n //given\n const request = new Uint8Array([\n ClientCommandCodes.GET_MERKLE_LEAF_INDEX,\n ...new Uint8Array(64),\n ]);\n\n //when\n interpreter.getClientCommandPayload(request, context);\n\n //then\n expect(getMerkleLeafIndexSpy).toHaveBeenCalledTimes(1);\n expect(getMerkleLeafIndexSpy).toHaveBeenCalledWith(request, context);\n });\n\n it(\"should call GetMoreElementsCommandHandler when request code is GET_MORE_ELEMENTS\", () => {\n //given\n const request = new Uint8Array([ClientCommandCodes.GET_MORE_ELEMENTS]);\n\n //when\n interpreter.getClientCommandPayload(request, context);\n\n //then\n expect(getMoreElementsSpy).toHaveBeenCalledTimes(1);\n expect(getMoreElementsSpy).toHaveBeenCalledWith(request, context);\n });\n\n it(\"should return an error for an unknown command code\", () => {\n //given\n const invalidCode = 0xff;\n const request = new Uint8Array([invalidCode]);\n\n //when\n const result = interpreter.getClientCommandPayload(request, context);\n\n //then\n expect(result.isLeft()).toBe(true);\n expect(result.extract()).toBeInstanceOf(ClientCommandHandlerError);\n expect(yieldSpy).not.toHaveBeenCalled();\n expect(getPreimageSpy).not.toHaveBeenCalled();\n expect(getMerkleLeafProofSpy).not.toHaveBeenCalled();\n expect(getMerkleLeafIndexSpy).not.toHaveBeenCalled();\n expect(getMoreElementsSpy).not.toHaveBeenCalled();\n });\n\n it(\"should return an error if no request code is present\", () => {\n //giuven\n const emptyRequest = new Uint8Array([]);\n\n //when\n const result = interpreter.getClientCommandPayload(emptyRequest, context);\n\n //then\n expect(result.isLeft()).toBe(true);\n expect(result.extract()).toBeInstanceOf(ClientCommandHandlerError);\n expect(yieldSpy).not.toHaveBeenCalled();\n expect(getPreimageSpy).not.toHaveBeenCalled();\n expect(getMerkleLeafProofSpy).not.toHaveBeenCalled();\n expect(getMerkleLeafIndexSpy).not.toHaveBeenCalled();\n expect(getMoreElementsSpy).not.toHaveBeenCalled();\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["import_purify_ts", "import_Errors", "GetMerkleLeafIndexCommandHandlerModule", "GetMerkleLeafProofCommandHandlerModule", "GetMoreElementsCommandHandlerModule", "GetPreimageCommandHandlerModule", "YieldCommandHandlerModule", "import_ClientCommandInterpreter", "import_constants", "interpreter", "context", "yieldSpy", "getPreimageSpy", "getMerkleLeafProofSpy", "getMerkleLeafIndexSpy", "getMoreElementsSpy", "request", "ctx", "_request", "preimage", "_ctx", "f", "_def", "result", "emptyRequest"]
|
|
7
7
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var t=require("@ledgerhq/device-management-kit"),r=require("./bitcoinAppErrors");describe("BtcAppCommandError",()=>{afterEach(()=>{
|
|
1
|
+
"use strict";var t=require("@ledgerhq/device-management-kit"),r=require("./bitcoinAppErrors");describe("BtcAppCommandError",()=>{afterEach(()=>{vi.resetAllMocks()}),afterAll(()=>{vi.resetModules()}),it("should be an instance of DeviceExchangeError",()=>{const e=new r.BtcAppCommandError({message:"Test error message",errorCode:"6985"});expect(e).toBeInstanceOf(t.DeviceExchangeError)}),it("should set the correct message when provided",()=>{const e="Custom error message",o=new r.BtcAppCommandError({message:e,errorCode:"6985"});expect(o.message).toBe(e)}),it("should set the correct customErrorCode",()=>{const e="6a86",o=new r.BtcAppCommandError({message:"Either P1 or P2 is incorrect",errorCode:e});expect(o.errorCode).toBe(e)}),it("should correlate error codes with messages from bitcoinAppErrors",()=>{const e="6e00",o=r.BTC_APP_ERRORS[e].message,s=new r.BtcAppCommandError({message:o,errorCode:e});expect(s.errorCode).toBe(e),expect(s.message).toBe(o),expect(s).toBeInstanceOf(t.DeviceExchangeError)})});
|
|
2
2
|
//# sourceMappingURL=bitcoinAppError.test.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/internal/app-binder/command/utils/bitcoinAppError.test.ts"],
|
|
4
|
-
"sourcesContent": ["import { DeviceExchangeError } from \"@ledgerhq/device-management-kit\";\n\nimport {\n BTC_APP_ERRORS,\n BtcAppCommandError,\n type BtcErrorCodes,\n} from \"./bitcoinAppErrors\";\n\ndescribe(\"BtcAppCommandError\", () => {\n afterEach(() => {\n
|
|
5
|
-
"mappings": "aAAA,IAAAA,EAAoC,2CAEpCC,EAIO,8BAEP,SAAS,qBAAsB,IAAM,CACnC,UAAU,IAAM,CACd,
|
|
4
|
+
"sourcesContent": ["import { DeviceExchangeError } from \"@ledgerhq/device-management-kit\";\n\nimport {\n BTC_APP_ERRORS,\n BtcAppCommandError,\n type BtcErrorCodes,\n} from \"./bitcoinAppErrors\";\n\ndescribe(\"BtcAppCommandError\", () => {\n afterEach(() => {\n vi.resetAllMocks();\n });\n\n afterAll(() => {\n vi.resetModules();\n });\n\n it(\"should be an instance of DeviceExchangeError\", () => {\n const error = new BtcAppCommandError({\n message: \"Test error message\",\n errorCode: \"6985\",\n });\n\n expect(error).toBeInstanceOf(DeviceExchangeError);\n });\n\n it(\"should set the correct message when provided\", () => {\n const customMessage = \"Custom error message\";\n const error = new BtcAppCommandError({\n message: customMessage,\n errorCode: \"6985\",\n });\n\n expect(error.message).toBe(customMessage);\n });\n\n it(\"should set the correct customErrorCode\", () => {\n const errorCode: BtcErrorCodes = \"6a86\";\n const error = new BtcAppCommandError({\n message: \"Either P1 or P2 is incorrect\",\n errorCode,\n });\n\n expect(error.errorCode).toBe(errorCode);\n });\n\n it(\"should correlate error codes with messages from bitcoinAppErrors\", () => {\n const errorCode: BtcErrorCodes = \"6e00\";\n const expectedMessage = BTC_APP_ERRORS[errorCode].message;\n\n const error = new BtcAppCommandError({\n message: expectedMessage,\n errorCode,\n });\n\n expect(error.errorCode).toBe(errorCode);\n expect(error.message).toBe(expectedMessage);\n\n expect(error).toBeInstanceOf(DeviceExchangeError);\n });\n});\n"],
|
|
5
|
+
"mappings": "aAAA,IAAAA,EAAoC,2CAEpCC,EAIO,8BAEP,SAAS,qBAAsB,IAAM,CACnC,UAAU,IAAM,CACd,GAAG,cAAc,CACnB,CAAC,EAED,SAAS,IAAM,CACb,GAAG,aAAa,CAClB,CAAC,EAED,GAAG,+CAAgD,IAAM,CACvD,MAAMC,EAAQ,IAAI,qBAAmB,CACnC,QAAS,qBACT,UAAW,MACb,CAAC,EAED,OAAOA,CAAK,EAAE,eAAe,qBAAmB,CAClD,CAAC,EAED,GAAG,+CAAgD,IAAM,CACvD,MAAMC,EAAgB,uBAChBD,EAAQ,IAAI,qBAAmB,CACnC,QAASC,EACT,UAAW,MACb,CAAC,EAED,OAAOD,EAAM,OAAO,EAAE,KAAKC,CAAa,CAC1C,CAAC,EAED,GAAG,yCAA0C,IAAM,CACjD,MAAMC,EAA2B,OAC3BF,EAAQ,IAAI,qBAAmB,CACnC,QAAS,+BACT,UAAAE,CACF,CAAC,EAED,OAAOF,EAAM,SAAS,EAAE,KAAKE,CAAS,CACxC,CAAC,EAED,GAAG,mEAAoE,IAAM,CAC3E,MAAMA,EAA2B,OAC3BC,EAAkB,iBAAeD,CAAS,EAAE,QAE5CF,EAAQ,IAAI,qBAAmB,CACnC,QAASG,EACT,UAAAD,CACF,CAAC,EAED,OAAOF,EAAM,SAAS,EAAE,KAAKE,CAAS,EACtC,OAAOF,EAAM,OAAO,EAAE,KAAKG,CAAe,EAE1C,OAAOH,CAAK,EAAE,eAAe,qBAAmB,CAClD,CAAC,CACH,CAAC",
|
|
6
6
|
"names": ["import_device_management_kit", "import_bitcoinAppErrors", "error", "customMessage", "errorCode", "expectedMessage"]
|
|
7
7
|
}
|
package/lib/cjs/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var p=Object.defineProperty;var
|
|
1
|
+
"use strict";var p=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var D=Object.getOwnPropertyNames;var w=Object.prototype.hasOwnProperty;var I=(n,t)=>{for(var i in t)p(n,i,{get:t[i],enumerable:!0})},g=(n,t,i,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let e of D(t))!w.call(n,e)&&e!==i&&p(n,e,{get:()=>t[e],enumerable:!(s=y(t,e))||s.enumerable});return n};var h=n=>g(p({},"__esModule",{value:!0}),n);var v={};I(v,{GetWalletAddressDeviceAction:()=>G});module.exports=h(v);var r=require("@ledgerhq/device-management-kit"),o=require("purify-ts"),a=require("xstate"),c=require("../../../app-binder/task/GetWalletAddressTask"),u=require("../../../app-binder/task/PrepareWalletPolicyTask");class G extends r.XStateDeviceAction{constructor(t){super(t)}makeStateMachine(t){const{getWalletAddress:i,prepareWalletPolicy:s}=this.extractDependencies(t);return(0,a.setup)({types:{input:{},context:{},output:{}},actors:{openAppStateMachine:new r.OpenAppDeviceAction({input:{appName:"Bitcoin"}}).makeStateMachine(t),prepareWalletPolicy:(0,a.fromPromise)(s),getWalletAddress:(0,a.fromPromise)(i)},guards:{noInternalError:({context:e})=>e._internalState.error===null,skipOpenApp:({context:e})=>e.input.skipOpenApp},actions:{assignErrorFromEvent:(0,a.assign)({_internalState:e=>({...e.context._internalState,error:e.event.error})})}}).createMachine({id:"GetWalletAddressDeviceAction",initial:"InitialState",context:({input:e})=>({input:e,intermediateValue:{requiredUserInteraction:r.UserInteractionRequired.None},_internalState:{error:null,wallet:null,walletAddress:null}}),states:{InitialState:{always:[{target:"PrepareWalletPolicy",guard:"skipOpenApp"},"OpenAppDeviceAction"]},OpenAppDeviceAction:{exit:(0,a.assign)({intermediateValue:{requiredUserInteraction:r.UserInteractionRequired.None}}),invoke:{id:"openAppStateMachine",input:{appName:"Bitcoin"},src:"openAppStateMachine",onSnapshot:{actions:(0,a.assign)({intermediateValue:e=>e.event.snapshot.context.intermediateValue})},onDone:{actions:(0,a.assign)({_internalState:e=>e.event.output.caseOf({Right:()=>e.context._internalState,Left:l=>({...e.context._internalState,error:l})})}),target:"CheckOpenAppDeviceActionResult"}}},CheckOpenAppDeviceActionResult:{always:[{target:"PrepareWalletPolicy",guard:"noInternalError"},"Error"]},PrepareWalletPolicy:{invoke:{id:"prepareWalletPolicy",src:"prepareWalletPolicy",input:({context:e})=>({wallet:e.input.wallet,walletBuilder:e.input.walletBuilder}),onDone:{target:"PrepareWalletPolicyResultCheck",actions:[(0,a.assign)({_internalState:({event:e,context:l})=>(0,r.isSuccessCommandResult)(e.output)?{...l._internalState,wallet:e.output.data}:{...l._internalState,error:e.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},PrepareWalletPolicyResultCheck:{always:[{guard:"noInternalError",target:"GetWalletAddress"},{target:"Error"}]},GetWalletAddress:{entry:(0,a.assign)(({context:e})=>({intermediateValue:{requiredUserInteraction:e.input.checkOnDevice?r.UserInteractionRequired.VerifyAddress:r.UserInteractionRequired.None}})),exit:(0,a.assign)({intermediateValue:{requiredUserInteraction:r.UserInteractionRequired.None}}),invoke:{id:"getWalletAddress",src:"getWalletAddress",input:({context:e})=>({checkOnDevice:e.input.checkOnDevice,wallet:e._internalState.wallet,change:e.input.change,addressIndex:e.input.addressIndex,dataStoreService:e.input.dataStoreService,walletSerializer:e.input.walletSerializer,walletBuilder:e.input.walletBuilder}),onDone:{target:"GetWalletAddressResultCheck",actions:[(0,a.assign)({_internalState:({event:e,context:l})=>(0,r.isSuccessCommandResult)(e.output)?{...l._internalState,walletAddress:e.output.data}:{...l._internalState,error:e.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},GetWalletAddressResultCheck:{always:[{guard:"noInternalError",target:"Success"},{target:"Error"}]},Success:{type:"final"},Error:{type:"final"}},output:({context:e})=>e._internalState.walletAddress?(0,o.Right)(e._internalState.walletAddress):(0,o.Left)(e._internalState.error||new r.UnknownDAError("No error in final state"))})}extractDependencies(t){return{getWalletAddress:async e=>{const{checkOnDevice:l,wallet:d,change:A,addressIndex:W,walletSerializer:m,dataStoreService:S}=e.input;return await new c.GetWalletAddressTask(t,{checkOnDevice:l,wallet:d,change:A,addressIndex:W},m,S).run()},prepareWalletPolicy:async e=>{const{input:{walletBuilder:l,wallet:d}}=e;return await new u.PrepareWalletPolicyTask(t,{wallet:d},l).run()}}}}0&&(module.exports={GetWalletAddressDeviceAction});
|
|
2
2
|
//# sourceMappingURL=GetWalletAddressDeviceAction.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/internal/app-binder/device-action/GetWalletAddress/GetWalletAddressDeviceAction.ts"],
|
|
4
|
-
"sourcesContent": ["import {\n type CommandResult,\n type DeviceActionStateMachine,\n type InternalApi,\n isSuccessCommandResult,\n OpenAppDeviceAction,\n type StateMachineTypes,\n UnknownDAError,\n UserInteractionRequired,\n XStateDeviceAction,\n} from \"@ledgerhq/device-management-kit\";\nimport { Left, Right } from \"purify-ts\";\nimport { assign, fromPromise, setup } from \"xstate\";\n\nimport {\n type GetWalletAddressDAError,\n type GetWalletAddressDAInput,\n type GetWalletAddressDAIntermediateValue,\n type GetWalletAddressDAInternalState,\n type GetWalletAddressDAOutput,\n} from \"@api/app-binder/GetWalletAddressDeviceActionTypes\";\nimport { type WalletAddress } from \"@api/model/Wallet\";\nimport { type Wallet as ApiWallet } from \"@api/model/Wallet\";\nimport { type BtcErrorCodes } from \"@internal/app-binder/command/utils/bitcoinAppErrors\";\nimport { GetWalletAddressTask } from \"@internal/app-binder/task/GetWalletAddressTask\";\nimport { PrepareWalletPolicyTask } from \"@internal/app-binder/task/PrepareWalletPolicyTask\";\nimport { type DataStoreService } from \"@internal/data-store/service/DataStoreService\";\nimport { type Wallet as InternalWallet } from \"@internal/wallet/model/Wallet\";\nimport { type WalletBuilder } from \"@internal/wallet/service/WalletBuilder\";\nimport { type WalletSerializer } from \"@internal/wallet/service/WalletSerializer\";\n\nexport type GetWalletAddressMachineDependencies = {\n readonly prepareWalletPolicy: (arg0: {\n input: {\n wallet: ApiWallet;\n walletBuilder: WalletBuilder;\n };\n }) => Promise<CommandResult<InternalWallet, BtcErrorCodes>>;\n readonly getWalletAddress: (arg0: {\n input: {\n checkOnDevice: boolean;\n change: boolean;\n addressIndex: number;\n wallet: InternalWallet;\n walletBuilder: WalletBuilder;\n walletSerializer: WalletSerializer;\n dataStoreService: DataStoreService;\n };\n }) => Promise<CommandResult<WalletAddress, BtcErrorCodes>>;\n};\n\nexport type ExtractGetWalletAddressMachineDependencies = (\n internalApi: InternalApi,\n) => GetWalletAddressMachineDependencies;\n\nexport class GetWalletAddressDeviceAction extends XStateDeviceAction<\n GetWalletAddressDAOutput,\n GetWalletAddressDAInput,\n GetWalletAddressDAError,\n GetWalletAddressDAIntermediateValue,\n GetWalletAddressDAInternalState\n> {\n constructor(args: { input: GetWalletAddressDAInput; inspect?: boolean }) {\n super(args);\n }\n\n makeStateMachine(\n internalApi: InternalApi,\n ): DeviceActionStateMachine<\n GetWalletAddressDAOutput,\n GetWalletAddressDAInput,\n GetWalletAddressDAError,\n GetWalletAddressDAIntermediateValue,\n GetWalletAddressDAInternalState\n > {\n type types = StateMachineTypes<\n GetWalletAddressDAOutput,\n GetWalletAddressDAInput,\n GetWalletAddressDAError,\n GetWalletAddressDAIntermediateValue,\n GetWalletAddressDAInternalState\n >;\n\n const { getWalletAddress, prepareWalletPolicy } =\n this.extractDependencies(internalApi);\n\n return setup({\n types: {\n input: {} as types[\"input\"],\n context: {} as types[\"context\"],\n output: {} as types[\"output\"],\n },\n\n actors: {\n openAppStateMachine: new OpenAppDeviceAction({\n input: { appName: \"Bitcoin\" },\n }).makeStateMachine(internalApi),\n prepareWalletPolicy: fromPromise(prepareWalletPolicy),\n getWalletAddress: fromPromise(getWalletAddress),\n },\n guards: {\n noInternalError: ({ context }) => context._internalState.error === null,\n },\n actions: {\n assignErrorFromEvent: assign({\n _internalState: (_) => ({\n ..._.context._internalState,\n error: _.event[\"error\"], // NOTE: it should never happen, the error is not typed anymore here\n }),\n }),\n },\n }).createMachine({\n /** @xstate-layout N4IgpgJg5mDOIC5QGUCWUB2AFMAnWA9hgIYA2AsnLMTACJgBuqAxmAILMAuqRAdAPIAHMBjaDB9Jqw7ciAYghEwvVBgYEA1soLDR45J2Kcw5YswAWqsAG0ADAF1EoQQVipZGJyAAeiACwAzADsvACcABwAjKGRtuG2AGyRSX4ANCAAnoiRAEwArLy2uX6RQUGRpeHhfgC+NelomDj4RGSUsNR0jCzsXDwYvADC5mDMGkIiYhLd0n1EAEpwAK6knHJ2jkggLm4eXr4IoRG8eTlFOaWhQX45QaHpWQiRN4UBfu8JeaE3obY5OXUGuhsHhCCQKFQaGBJD0ZP0hiMxhM9NMpL0PItYCs1tZIptnK53P19ogjuETmdcpdrrd7pl-M8wnkgvkgvFbH48n4EkFASBGiCWuD2p1oTN0fCBc0wW1ITAFEoVGpNMo3E1Qa0IR0oRsvDsiUQSU88tVeOEktEEuE8m8cjcHqScicgokTXk8rZygFQgD6vzgdLNSKoTDZh5eFKNcK5WA5HhcARcLxBKQjAAzRMAW14asFMq1ot1W31ey2B0iJr8ZotoStNpu9vpCDtoTNHr8PoizyKvL9kaFsu1XTRcL4-fzwZgmOxw1GGnWDj1hNLoAOFwCBWC5u5RySEQdT1sra+OSt1wCAQuzICfPHQZjoYlY4DUcHounq1nY3WeKXu2JZaIOum5sgkO61tE4QHhWBS2HkCT-G8R5wc8N58hgBAQHAXh3tGQ5iiOcyeMWy4AauiAALQJAeVGFLY9EMYxDG9kC6oDgWIbiqOAzIlMj7cX+BrEeRCCNo8sS2CcRz-B6zIsnBaGsXm974fxREInOvHiGpGLLKsgkrj4iBnrwFwVgkCHfEeCQBNB3K8IEpxBO6ySep8in+mxE4Plx6m4W+UIGWRRlPJEVRmncOTmhyLI2QeUS8GFQRvPBXZRLWt4vuxk4EbCflZd5+EfpwX4aEFhqAU84RRYUpyXmBATJBeQTQZEARhKEG5Ne69GUplXkqaKOmSkszCsB05XCSFOSXgUyVshUdoJLYF7QYkvAXkUER3H45q1qE-XKXhQ2+eGACiuAJrgk1GjN+S8PNUTFMtq1Nrckl-O6wTct6KF5HUdRAA */\n id: \"GetWalletAddressDeviceAction\",\n initial: \"OpenAppDeviceAction\",\n context: ({ input }) => {\n return {\n input,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n _internalState: {\n error: null,\n wallet: null,\n walletAddress: null,\n },\n };\n },\n states: {\n OpenAppDeviceAction: {\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n }),\n invoke: {\n id: \"openAppStateMachine\",\n input: { appName: \"Bitcoin\" },\n src: \"openAppStateMachine\",\n onSnapshot: {\n actions: assign({\n intermediateValue: (_) =>\n _.event.snapshot.context.intermediateValue,\n }),\n },\n onDone: {\n actions: assign({\n _internalState: (_) => {\n return _.event.output.caseOf<GetWalletAddressDAInternalState>(\n {\n Right: () => _.context._internalState,\n Left: (error) => ({\n ..._.context._internalState,\n error,\n }),\n },\n );\n },\n }),\n target: \"CheckOpenAppDeviceActionResult\",\n },\n },\n },\n CheckOpenAppDeviceActionResult: {\n always: [\n {\n target: \"PrepareWalletPolicy\",\n guard: \"noInternalError\",\n },\n \"Error\",\n ],\n },\n PrepareWalletPolicy: {\n invoke: {\n id: \"prepareWalletPolicy\",\n src: \"prepareWalletPolicy\",\n input: ({ context }) => ({\n wallet: context.input.wallet,\n walletBuilder: context.input.walletBuilder,\n }),\n onDone: {\n target: \"PrepareWalletPolicyResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n wallet: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n PrepareWalletPolicyResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"GetWalletAddress\" },\n { target: \"Error\" },\n ],\n },\n GetWalletAddress: {\n entry: assign(({ context }) => ({\n intermediateValue: {\n requiredUserInteraction: context.input.checkOnDevice\n ? UserInteractionRequired.VerifyAddress\n : UserInteractionRequired.None,\n },\n })),\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n }),\n invoke: {\n id: \"getWalletAddress\",\n src: \"getWalletAddress\",\n input: ({ context }) => ({\n checkOnDevice: context.input.checkOnDevice,\n wallet: context._internalState.wallet!,\n change: context.input.change,\n addressIndex: context.input.addressIndex,\n dataStoreService: context.input.dataStoreService,\n walletSerializer: context.input.walletSerializer,\n walletBuilder: context.input.walletBuilder,\n }),\n onDone: {\n target: \"GetWalletAddressResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n walletAddress: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n GetWalletAddressResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"Success\" },\n { target: \"Error\" },\n ],\n },\n Success: {\n type: \"final\",\n },\n Error: {\n type: \"final\",\n },\n },\n output: ({ context }) =>\n context._internalState.walletAddress\n ? Right(context._internalState.walletAddress)\n : Left(\n context._internalState.error ||\n new UnknownDAError(\"No error in final state\"),\n ),\n });\n }\n\n extractDependencies(\n internalApi: InternalApi,\n ): GetWalletAddressMachineDependencies {\n const prepareWalletPolicy = async (arg0: {\n input: { wallet: ApiWallet; walletBuilder: WalletBuilder };\n }): Promise<CommandResult<InternalWallet, BtcErrorCodes>> => {\n const {\n input: { walletBuilder, wallet },\n } = arg0;\n return await new PrepareWalletPolicyTask(\n internalApi,\n { wallet },\n walletBuilder,\n ).run();\n };\n const getWalletAddress = async (arg0: {\n input: {\n checkOnDevice: boolean;\n change: boolean;\n addressIndex: number;\n wallet: InternalWallet;\n walletBuilder: WalletBuilder;\n walletSerializer: WalletSerializer;\n dataStoreService: DataStoreService;\n };\n }): Promise<CommandResult<WalletAddress, BtcErrorCodes>> => {\n const {\n checkOnDevice,\n wallet,\n change,\n addressIndex,\n walletSerializer,\n dataStoreService,\n } = arg0.input;\n\n return await new GetWalletAddressTask(\n internalApi,\n {\n checkOnDevice,\n wallet,\n change,\n addressIndex,\n },\n walletSerializer,\n dataStoreService,\n ).run();\n };\n return {\n getWalletAddress,\n prepareWalletPolicy,\n };\n }\n}\n"],
|
|
5
|
-
"mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,kCAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAUO,2CACPC,EAA4B,qBAC5BC,EAA2C,kBAY3CC,EAAqC,0DACrCC,EAAwC,6DA8BjC,MAAMN,UAAqC,oBAMhD,CACA,YAAYO,EAA6D,CACvE,MAAMA,CAAI,CACZ,CAEA,iBACEC,EAOA,CASA,KAAM,CAAE,iBAAAC,EAAkB,oBAAAC,CAAoB,EAC5C,KAAK,oBAAoBF,CAAW,EAEtC,SAAO,SAAM,CACX,MAAO,CACL,MAAO,CAAC,EACR,QAAS,CAAC,EACV,OAAQ,CAAC,CACX,EAEA,OAAQ,CACN,oBAAqB,IAAI,sBAAoB,CAC3C,MAAO,CAAE,QAAS,SAAU,CAC9B,CAAC,EAAE,iBAAiBA,CAAW,EAC/B,uBAAqB,eAAYE,CAAmB,EACpD,oBAAkB,eAAYD,CAAgB,CAChD,EACA,OAAQ,CACN,gBAAiB,CAAC,CAAE,QAAAE,CAAQ,IAAMA,EAAQ,eAAe,QAAU,
|
|
4
|
+
"sourcesContent": ["import {\n type CommandResult,\n type DeviceActionStateMachine,\n type InternalApi,\n isSuccessCommandResult,\n OpenAppDeviceAction,\n type StateMachineTypes,\n UnknownDAError,\n UserInteractionRequired,\n XStateDeviceAction,\n} from \"@ledgerhq/device-management-kit\";\nimport { Left, Right } from \"purify-ts\";\nimport { assign, fromPromise, setup } from \"xstate\";\n\nimport {\n type GetWalletAddressDAError,\n type GetWalletAddressDAInput,\n type GetWalletAddressDAIntermediateValue,\n type GetWalletAddressDAInternalState,\n type GetWalletAddressDAOutput,\n} from \"@api/app-binder/GetWalletAddressDeviceActionTypes\";\nimport { type WalletAddress } from \"@api/model/Wallet\";\nimport { type Wallet as ApiWallet } from \"@api/model/Wallet\";\nimport { type BtcErrorCodes } from \"@internal/app-binder/command/utils/bitcoinAppErrors\";\nimport { GetWalletAddressTask } from \"@internal/app-binder/task/GetWalletAddressTask\";\nimport { PrepareWalletPolicyTask } from \"@internal/app-binder/task/PrepareWalletPolicyTask\";\nimport { type DataStoreService } from \"@internal/data-store/service/DataStoreService\";\nimport { type Wallet as InternalWallet } from \"@internal/wallet/model/Wallet\";\nimport { type WalletBuilder } from \"@internal/wallet/service/WalletBuilder\";\nimport { type WalletSerializer } from \"@internal/wallet/service/WalletSerializer\";\n\nexport type GetWalletAddressMachineDependencies = {\n readonly prepareWalletPolicy: (arg0: {\n input: {\n wallet: ApiWallet;\n walletBuilder: WalletBuilder;\n };\n }) => Promise<CommandResult<InternalWallet, BtcErrorCodes>>;\n readonly getWalletAddress: (arg0: {\n input: {\n checkOnDevice: boolean;\n change: boolean;\n addressIndex: number;\n wallet: InternalWallet;\n walletBuilder: WalletBuilder;\n walletSerializer: WalletSerializer;\n dataStoreService: DataStoreService;\n };\n }) => Promise<CommandResult<WalletAddress, BtcErrorCodes>>;\n};\n\nexport type ExtractGetWalletAddressMachineDependencies = (\n internalApi: InternalApi,\n) => GetWalletAddressMachineDependencies;\n\nexport class GetWalletAddressDeviceAction extends XStateDeviceAction<\n GetWalletAddressDAOutput,\n GetWalletAddressDAInput,\n GetWalletAddressDAError,\n GetWalletAddressDAIntermediateValue,\n GetWalletAddressDAInternalState\n> {\n constructor(args: { input: GetWalletAddressDAInput; inspect?: boolean }) {\n super(args);\n }\n\n makeStateMachine(\n internalApi: InternalApi,\n ): DeviceActionStateMachine<\n GetWalletAddressDAOutput,\n GetWalletAddressDAInput,\n GetWalletAddressDAError,\n GetWalletAddressDAIntermediateValue,\n GetWalletAddressDAInternalState\n > {\n type types = StateMachineTypes<\n GetWalletAddressDAOutput,\n GetWalletAddressDAInput,\n GetWalletAddressDAError,\n GetWalletAddressDAIntermediateValue,\n GetWalletAddressDAInternalState\n >;\n\n const { getWalletAddress, prepareWalletPolicy } =\n this.extractDependencies(internalApi);\n\n return setup({\n types: {\n input: {} as types[\"input\"],\n context: {} as types[\"context\"],\n output: {} as types[\"output\"],\n },\n\n actors: {\n openAppStateMachine: new OpenAppDeviceAction({\n input: { appName: \"Bitcoin\" },\n }).makeStateMachine(internalApi),\n prepareWalletPolicy: fromPromise(prepareWalletPolicy),\n getWalletAddress: fromPromise(getWalletAddress),\n },\n guards: {\n noInternalError: ({ context }) => context._internalState.error === null,\n skipOpenApp: ({ context }) => context.input.skipOpenApp,\n },\n actions: {\n assignErrorFromEvent: assign({\n _internalState: (_) => ({\n ..._.context._internalState,\n error: _.event[\"error\"], // NOTE: it should never happen, the error is not typed anymore here\n }),\n }),\n },\n }).createMachine({\n /** @xstate-layout N4IgpgJg5mDOIC5QGUCWUB2AFMAnWA9hgIYA2AsnLMTACJgBuqAxmAILMAuqRAdAPIAHMBjaDB9Jqw7ciAYghEwvVBgYEA1soLDR45J2Kcw5YswAWqsAG0ADAF1EoQQVipZGJyAAeiACwAzADsvACcABwAjKGRtuG2AGyRSX4ANCAAnoiRAEwArLy2uX6RQUGRpeHhfgC+NelomDj4RGSUsNR0jCzsXDwYvADC5mDMGkIiYhLd0n1EAEpwAK6knHJ2jkggLm4eXr4IoRG8eTlFOaWhQX45QaHpWQiRN4UBfu8JeaE3obY5OXUGuhsHhCCQKFQaGBJD0ZP0hiMxhM9NMpL0PItYCs1tZIptnK53P19ogjuETmdcpdrrd7pl-M8wnkgvkgvFbH48n4EkFASBGiCWuD2p1oTN0fCBc0wW1ITAFEoVGpNMo3E1Qa0IR0oRsvDsiUQSU88tVeOEktEEuE8m8cjcHqScicgokTXk8rZygFQgD6vzgdLNSKoTDZh5eFKNcK5WA5HhcARcLxBKQjAAzRMAW14asFMq1ot1W31ey2B0iJr8ZotoStNpu9vpCDtoTNHr8PoizyKvL9kaFsu1XTRcL4-fzwZgmOxw1GGnWDj1hNLoAOFwCBWC5u5RySEQdT1sra+OSt1wCAQuzICfPHQZjoYlY4DUcHounq1nY3WeKXu2JZaIOum5sgkO61tE4QHhWBS2HkCT-G8R5wc8N58hgBAQHAXh3tGQ5iiOcyeMWy4AauiAALQJAeVGFLY9EMYxDG9kC6oDgWIbiqOAzIlMj7cX+BrEeRCCNo8sS2CcRz-B6zIsnBaGsXm974fxREInOvHiGpGLLKsgkrj4iBnrwFwVgkCHfEeCQBNB3K8IEpxBO6ySep8in+mxE4Plx6m4W+UIGWRRlPJEVRmncOTmhyLI2QeUS8GFQRvPBXZRLWt4vuxk4EbCflZd5+EfpwX4aEFhqAU84RRYUpyXmBATJBeQTQZEARhKEG5Ne69GUplXkqaKOmSkszCsB05XCSFOSXgUyVshUdoJLYF7QYkvAXkUER3H45q1qE-XKXhQ2+eGACiuAJrgk1GjN+S8PNUTFMtq1Nrckl-O6wTct6KF5HUdRAA */\n id: \"GetWalletAddressDeviceAction\",\n initial: \"InitialState\",\n context: ({ input }) => {\n return {\n input,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n _internalState: {\n error: null,\n wallet: null,\n walletAddress: null,\n },\n };\n },\n states: {\n InitialState: {\n always: [\n {\n target: \"PrepareWalletPolicy\",\n guard: \"skipOpenApp\",\n },\n \"OpenAppDeviceAction\",\n ],\n },\n OpenAppDeviceAction: {\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n }),\n invoke: {\n id: \"openAppStateMachine\",\n input: { appName: \"Bitcoin\" },\n src: \"openAppStateMachine\",\n onSnapshot: {\n actions: assign({\n intermediateValue: (_) =>\n _.event.snapshot.context.intermediateValue,\n }),\n },\n onDone: {\n actions: assign({\n _internalState: (_) => {\n return _.event.output.caseOf<GetWalletAddressDAInternalState>(\n {\n Right: () => _.context._internalState,\n Left: (error) => ({\n ..._.context._internalState,\n error,\n }),\n },\n );\n },\n }),\n target: \"CheckOpenAppDeviceActionResult\",\n },\n },\n },\n CheckOpenAppDeviceActionResult: {\n always: [\n {\n target: \"PrepareWalletPolicy\",\n guard: \"noInternalError\",\n },\n \"Error\",\n ],\n },\n PrepareWalletPolicy: {\n invoke: {\n id: \"prepareWalletPolicy\",\n src: \"prepareWalletPolicy\",\n input: ({ context }) => ({\n wallet: context.input.wallet,\n walletBuilder: context.input.walletBuilder,\n }),\n onDone: {\n target: \"PrepareWalletPolicyResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n wallet: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n PrepareWalletPolicyResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"GetWalletAddress\" },\n { target: \"Error\" },\n ],\n },\n GetWalletAddress: {\n entry: assign(({ context }) => ({\n intermediateValue: {\n requiredUserInteraction: context.input.checkOnDevice\n ? UserInteractionRequired.VerifyAddress\n : UserInteractionRequired.None,\n },\n })),\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n },\n }),\n invoke: {\n id: \"getWalletAddress\",\n src: \"getWalletAddress\",\n input: ({ context }) => ({\n checkOnDevice: context.input.checkOnDevice,\n wallet: context._internalState.wallet!,\n change: context.input.change,\n addressIndex: context.input.addressIndex,\n dataStoreService: context.input.dataStoreService,\n walletSerializer: context.input.walletSerializer,\n walletBuilder: context.input.walletBuilder,\n }),\n onDone: {\n target: \"GetWalletAddressResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n walletAddress: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n GetWalletAddressResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"Success\" },\n { target: \"Error\" },\n ],\n },\n Success: {\n type: \"final\",\n },\n Error: {\n type: \"final\",\n },\n },\n output: ({ context }) =>\n context._internalState.walletAddress\n ? Right(context._internalState.walletAddress)\n : Left(\n context._internalState.error ||\n new UnknownDAError(\"No error in final state\"),\n ),\n });\n }\n\n extractDependencies(\n internalApi: InternalApi,\n ): GetWalletAddressMachineDependencies {\n const prepareWalletPolicy = async (arg0: {\n input: { wallet: ApiWallet; walletBuilder: WalletBuilder };\n }): Promise<CommandResult<InternalWallet, BtcErrorCodes>> => {\n const {\n input: { walletBuilder, wallet },\n } = arg0;\n return await new PrepareWalletPolicyTask(\n internalApi,\n { wallet },\n walletBuilder,\n ).run();\n };\n const getWalletAddress = async (arg0: {\n input: {\n checkOnDevice: boolean;\n change: boolean;\n addressIndex: number;\n wallet: InternalWallet;\n walletBuilder: WalletBuilder;\n walletSerializer: WalletSerializer;\n dataStoreService: DataStoreService;\n };\n }): Promise<CommandResult<WalletAddress, BtcErrorCodes>> => {\n const {\n checkOnDevice,\n wallet,\n change,\n addressIndex,\n walletSerializer,\n dataStoreService,\n } = arg0.input;\n\n return await new GetWalletAddressTask(\n internalApi,\n {\n checkOnDevice,\n wallet,\n change,\n addressIndex,\n },\n walletSerializer,\n dataStoreService,\n ).run();\n };\n return {\n getWalletAddress,\n prepareWalletPolicy,\n };\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["GetWalletAddressDeviceAction_exports", "__export", "GetWalletAddressDeviceAction", "__toCommonJS", "import_device_management_kit", "import_purify_ts", "import_xstate", "import_GetWalletAddressTask", "import_PrepareWalletPolicyTask", "args", "internalApi", "getWalletAddress", "prepareWalletPolicy", "context", "_", "input", "error", "event", "arg0", "checkOnDevice", "wallet", "change", "addressIndex", "walletSerializer", "dataStoreService", "walletBuilder"]
|
|
7
7
|
}
|