@ledgerhq/device-signer-kit-ethereum 1.0.0 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +19 -19
- package/lib/cjs/api/SignerEth.js +2 -0
- package/lib/cjs/api/SignerEth.js.map +7 -0
- package/lib/cjs/api/SignerEthBuilder.js +2 -0
- package/lib/cjs/api/SignerEthBuilder.js.map +7 -0
- package/lib/cjs/api/SignerEthBuilder.test.js +2 -0
- package/lib/cjs/api/SignerEthBuilder.test.js.map +7 -0
- package/lib/cjs/api/app-binder/GetAddressCommandTypes.js +2 -3
- package/lib/cjs/api/app-binder/GetAddressCommandTypes.js.map +7 -1
- package/lib/cjs/api/app-binder/GetAddressDeviceActionTypes.js +2 -3
- package/lib/cjs/api/app-binder/GetAddressDeviceActionTypes.js.map +7 -1
- package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.js +2 -3
- package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.js.map +7 -1
- package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js +2 -3
- package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js.map +7 -1
- package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js +2 -3
- package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js.map +7 -1
- package/lib/cjs/api/index.js +2 -26
- package/lib/cjs/api/index.js.map +7 -1
- package/lib/cjs/api/model/Address.js +2 -3
- package/lib/cjs/api/model/Address.js.map +7 -1
- package/lib/cjs/api/model/AddressOptions.js +2 -3
- package/lib/cjs/api/model/AddressOptions.js.map +7 -1
- package/lib/cjs/api/model/Signature.js +2 -3
- package/lib/cjs/api/model/Signature.js.map +7 -1
- package/lib/cjs/api/model/Transaction.js +2 -3
- package/lib/cjs/api/model/Transaction.js.map +7 -1
- package/lib/cjs/api/model/TransactionOptions.js +2 -3
- package/lib/cjs/api/model/TransactionOptions.js.map +7 -1
- package/lib/cjs/api/model/TypedData.js +2 -4
- package/lib/cjs/api/model/TypedData.js.map +7 -1
- package/lib/cjs/index.js +2 -20
- package/lib/cjs/index.js.map +7 -1
- package/lib/cjs/internal/DefaultSignerEth.js +2 -0
- package/lib/cjs/internal/DefaultSignerEth.js.map +7 -0
- package/lib/cjs/internal/DefaultSignerEth.test.js +2 -0
- package/lib/cjs/internal/DefaultSignerEth.test.js.map +7 -0
- package/lib/cjs/internal/address/di/addressModule.js +2 -11
- package/lib/cjs/internal/address/di/addressModule.js.map +7 -1
- package/lib/cjs/internal/address/di/addressModule.test.js +2 -0
- package/lib/cjs/internal/address/di/addressModule.test.js.map +7 -0
- package/lib/cjs/internal/address/di/addressTypes.js +2 -7
- package/lib/cjs/internal/address/di/addressTypes.js.map +7 -1
- package/lib/cjs/internal/address/use-case/GetAddressUseCase.js +2 -38
- package/lib/cjs/internal/address/use-case/GetAddressUseCase.js.map +7 -1
- package/lib/cjs/internal/address/use-case/GetAddressUseCase.test.js +2 -0
- package/lib/cjs/internal/address/use-case/GetAddressUseCase.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/EthAppBinder.js +2 -100
- package/lib/cjs/internal/app-binder/EthAppBinder.js.map +7 -1
- package/lib/cjs/internal/app-binder/EthAppBinder.test.js +2 -0
- package/lib/cjs/internal/app-binder/EthAppBinder.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/GetAddressCommand.js +2 -88
- package/lib/cjs/internal/app-binder/command/GetAddressCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/GetAddressCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/GetAddressCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js +2 -39
- package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.js +2 -50
- package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.js +2 -34
- package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js +2 -69
- package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +2 -131
- package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.js +2 -51
- package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.js +2 -57
- package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.test.js +7 -0
- package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/SetPluginCommand.js +2 -52
- package/lib/cjs/internal/app-binder/command/SetPluginCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/SetPluginCommand.test.js +6 -0
- package/lib/cjs/internal/app-binder/command/SetPluginCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.js +2 -69
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.js +2 -60
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js +2 -59
- package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js.map +7 -1
- package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/StartTransactionCommand.js +2 -0
- package/lib/cjs/internal/app-binder/command/StartTransactionCommand.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/StartTransactionCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/StartTransactionCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.js +2 -0
- package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js +2 -161
- package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js.map +7 -1
- package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js +2 -0
- package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +2 -285
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +7 -1
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +2 -0
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +2 -245
- package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +7 -1
- package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +2 -0
- package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +2 -18
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +7 -1
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js +2 -31
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js.map +7 -1
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js +2 -35
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js.map +7 -1
- package/lib/cjs/internal/app-binder/di/appBinderModule.js +2 -11
- package/lib/cjs/internal/app-binder/di/appBinderModule.js.map +7 -1
- package/lib/cjs/internal/app-binder/di/appBinderTypes.js +2 -7
- package/lib/cjs/internal/app-binder/di/appBinderTypes.js.map +7 -1
- package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js +2 -72
- package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js.map +7 -1
- package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js +2 -31
- package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js.map +7 -1
- package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js +2 -188
- package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js.map +7 -1
- package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js +2 -112
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js.map +7 -1
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/SendCommandInChunksTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/SendCommandInChunksTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.js +2 -42
- package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.js.map +7 -1
- package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.js +2 -53
- package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.js.map +7 -1
- package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js +2 -53
- package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js.map +7 -1
- package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js.map +7 -0
- package/lib/cjs/internal/di.js +2 -27
- package/lib/cjs/internal/di.js.map +7 -1
- package/lib/cjs/internal/externalTypes.js +2 -9
- package/lib/cjs/internal/externalTypes.js.map +7 -1
- package/lib/cjs/internal/message/di/messageModule.js +2 -11
- package/lib/cjs/internal/message/di/messageModule.js.map +7 -1
- package/lib/cjs/internal/message/di/messageModule.test.js +2 -0
- package/lib/cjs/internal/message/di/messageModule.test.js.map +7 -0
- package/lib/cjs/internal/message/di/messageTypes.js +2 -7
- package/lib/cjs/internal/message/di/messageTypes.js.map +7 -1
- package/lib/cjs/internal/message/use-case/SignMessageUseCase.js +2 -38
- package/lib/cjs/internal/message/use-case/SignMessageUseCase.js.map +7 -1
- package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js +2 -0
- package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js.map +7 -0
- package/lib/cjs/internal/shared/utils/PayloadUtils.js +2 -0
- package/lib/cjs/internal/shared/utils/PayloadUtils.js.map +7 -0
- package/lib/cjs/internal/shared/utils/PayloadUtils.test.js +2 -0
- package/lib/cjs/internal/shared/utils/PayloadUtils.test.js.map +7 -0
- package/lib/cjs/internal/transaction/di/transactionModule.js +2 -17
- package/lib/cjs/internal/transaction/di/transactionModule.js.map +7 -1
- package/lib/cjs/internal/transaction/di/transactionModule.test.js +2 -0
- package/lib/cjs/internal/transaction/di/transactionModule.test.js.map +7 -0
- package/lib/cjs/internal/transaction/di/transactionTypes.js +2 -9
- package/lib/cjs/internal/transaction/di/transactionTypes.js.map +7 -1
- package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.js +2 -60
- package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.js.map +7 -1
- package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.test.js +2 -0
- package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.test.js.map +7 -0
- package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.js +2 -36
- package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.js.map +7 -1
- package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.test.js +2 -0
- package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.test.js.map +7 -0
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js +2 -3
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js.map +7 -1
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js +2 -41
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js.map +7 -1
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js +2 -0
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js.map +7 -0
- package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.js +2 -3
- package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.js.map +7 -1
- package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js +2 -0
- package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js.map +7 -0
- package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js +2 -0
- package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js.map +7 -0
- package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.js +2 -38
- package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.js.map +7 -1
- package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.test.js +2 -0
- package/lib/cjs/internal/transaction/use-case/SignTransactionUseCase.test.js.map +7 -0
- package/lib/cjs/internal/typed-data/di/typedDataModule.js +2 -13
- package/lib/cjs/internal/typed-data/di/typedDataModule.js.map +7 -1
- package/lib/cjs/internal/typed-data/di/typedDataModule.test.js +2 -0
- package/lib/cjs/internal/typed-data/di/typedDataModule.test.js.map +7 -0
- package/lib/cjs/internal/typed-data/di/typedDataTypes.js +2 -8
- package/lib/cjs/internal/typed-data/di/typedDataTypes.js.map +7 -1
- package/lib/cjs/internal/typed-data/model/Types.js +2 -64
- package/lib/cjs/internal/typed-data/model/Types.js.map +7 -1
- package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js +2 -29
- package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js.map +7 -1
- package/lib/cjs/internal/typed-data/service/TypedDataEncoder.js +2 -101
- package/lib/cjs/internal/typed-data/service/TypedDataEncoder.js.map +7 -1
- package/lib/cjs/internal/typed-data/service/TypedDataEncoder.test.js +2 -0
- package/lib/cjs/internal/typed-data/service/TypedDataEncoder.test.js.map +7 -0
- package/lib/cjs/internal/typed-data/service/TypedDataParser.js +2 -211
- package/lib/cjs/internal/typed-data/service/TypedDataParser.js.map +7 -1
- package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js +2 -0
- package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js.map +7 -0
- package/lib/cjs/internal/typed-data/service/TypedDataParserService.js +2 -3
- package/lib/cjs/internal/typed-data/service/TypedDataParserService.js.map +7 -1
- package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js +2 -42
- package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js.map +7 -1
- package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js +2 -0
- package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +7 -0
- package/lib/cjs/package.json +63 -0
- package/lib/esm/api/SignerEth.js +1 -0
- package/lib/esm/api/SignerEth.js.map +7 -0
- package/lib/esm/api/SignerEthBuilder.js +2 -0
- package/lib/esm/api/SignerEthBuilder.js.map +7 -0
- package/lib/esm/api/SignerEthBuilder.test.js +2 -0
- package/lib/esm/api/SignerEthBuilder.test.js.map +7 -0
- package/lib/esm/api/app-binder/GetAddressCommandTypes.js +1 -2
- package/lib/esm/api/app-binder/GetAddressCommandTypes.js.map +7 -1
- package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.js +1 -2
- package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.js.map +7 -1
- package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.js +1 -2
- package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.js.map +7 -1
- package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js +1 -2
- package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js.map +7 -1
- package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -2
- package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js.map +7 -1
- package/lib/esm/api/index.js +2 -10
- package/lib/esm/api/index.js.map +7 -1
- package/lib/esm/api/model/Address.js +1 -2
- package/lib/esm/api/model/Address.js.map +7 -1
- package/lib/esm/api/model/AddressOptions.js +1 -2
- package/lib/esm/api/model/AddressOptions.js.map +7 -1
- package/lib/esm/api/model/Signature.js +1 -2
- package/lib/esm/api/model/Signature.js.map +7 -1
- package/lib/esm/api/model/Transaction.js +2 -2
- package/lib/esm/api/model/Transaction.js.map +7 -1
- package/lib/esm/api/model/TransactionOptions.js +1 -2
- package/lib/esm/api/model/TransactionOptions.js.map +7 -1
- package/lib/esm/api/model/TypedData.js +1 -3
- package/lib/esm/api/model/TypedData.js.map +7 -1
- package/lib/esm/index.js +2 -4
- package/lib/esm/index.js.map +7 -1
- package/lib/esm/internal/DefaultSignerEth.js +2 -0
- package/lib/esm/internal/DefaultSignerEth.js.map +7 -0
- package/lib/esm/internal/DefaultSignerEth.test.js +2 -0
- package/lib/esm/internal/DefaultSignerEth.test.js.map +7 -0
- package/lib/esm/internal/address/di/addressModule.js +2 -7
- package/lib/esm/internal/address/di/addressModule.js.map +7 -1
- package/lib/esm/internal/address/di/addressModule.test.js +2 -0
- package/lib/esm/internal/address/di/addressModule.test.js.map +7 -0
- package/lib/esm/internal/address/di/addressTypes.js +2 -4
- package/lib/esm/internal/address/di/addressTypes.js.map +7 -1
- package/lib/esm/internal/address/use-case/GetAddressUseCase.js +2 -35
- package/lib/esm/internal/address/use-case/GetAddressUseCase.js.map +7 -1
- package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js +2 -0
- package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js.map +7 -0
- package/lib/esm/internal/app-binder/EthAppBinder.js +2 -97
- package/lib/esm/internal/app-binder/EthAppBinder.js.map +7 -1
- package/lib/esm/internal/app-binder/EthAppBinder.test.js +2 -0
- package/lib/esm/internal/app-binder/EthAppBinder.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/GetAddressCommand.js +2 -84
- package/lib/esm/internal/app-binder/command/GetAddressCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/GetChallengeCommand.js +2 -35
- package/lib/esm/internal/app-binder/command/GetChallengeCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js +2 -46
- package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js +2 -30
- package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js +2 -65
- package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +2 -127
- package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js +2 -47
- package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js +2 -52
- package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js +7 -0
- package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/SetPluginCommand.js +2 -47
- package/lib/esm/internal/app-binder/command/SetPluginCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js +6 -0
- package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/SignEIP712Command.js +2 -65
- package/lib/esm/internal/app-binder/command/SignEIP712Command.js.map +7 -1
- package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js +2 -0
- package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js +2 -56
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/SignTransactionCommand.js +2 -55
- package/lib/esm/internal/app-binder/command/SignTransactionCommand.js.map +7 -1
- package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/StartTransactionCommand.js +2 -0
- package/lib/esm/internal/app-binder/command/StartTransactionCommand.js.map +7 -0
- package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js +2 -0
- package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js.map +7 -0
- package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js +2 -157
- package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js.map +7 -1
- package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js +2 -0
- package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.js.map +7 -0
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +2 -281
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +7 -1
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +2 -0
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +7 -0
- package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +2 -241
- package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +7 -1
- package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +2 -0
- package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +7 -0
- package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +2 -15
- package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +7 -1
- package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js +2 -27
- package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.js.map +7 -1
- package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js +2 -32
- package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.js.map +7 -1
- package/lib/esm/internal/app-binder/di/appBinderModule.js +2 -7
- package/lib/esm/internal/app-binder/di/appBinderModule.js.map +7 -1
- package/lib/esm/internal/app-binder/di/appBinderTypes.js +2 -4
- package/lib/esm/internal/app-binder/di/appBinderTypes.js.map +7 -1
- package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js +2 -68
- package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js.map +7 -1
- package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js +2 -27
- package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js.map +7 -1
- package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js +2 -184
- package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js.map +7 -1
- package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js +2 -107
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js.map +7 -1
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +2 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.js +2 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/SendCommandInChunksTask.js +2 -0
- package/lib/esm/internal/app-binder/task/SendCommandInChunksTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.js +2 -38
- package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.js.map +7 -1
- package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js +2 -0
- package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.js +2 -49
- package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.js.map +7 -1
- package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/SendSignTransactionTask.js +2 -49
- package/lib/esm/internal/app-binder/task/SendSignTransactionTask.js.map +7 -1
- package/lib/esm/internal/app-binder/task/SendSignTransactionTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/SendSignTransactionTask.test.js.map +7 -0
- package/lib/esm/internal/di.js +2 -23
- package/lib/esm/internal/di.js.map +7 -1
- package/lib/esm/internal/externalTypes.js +2 -6
- package/lib/esm/internal/externalTypes.js.map +7 -1
- package/lib/esm/internal/message/di/messageModule.js +2 -7
- package/lib/esm/internal/message/di/messageModule.js.map +7 -1
- package/lib/esm/internal/message/di/messageModule.test.js +2 -0
- package/lib/esm/internal/message/di/messageModule.test.js.map +7 -0
- package/lib/esm/internal/message/di/messageTypes.js +2 -4
- package/lib/esm/internal/message/di/messageTypes.js.map +7 -1
- package/lib/esm/internal/message/use-case/SignMessageUseCase.js +2 -35
- package/lib/esm/internal/message/use-case/SignMessageUseCase.js.map +7 -1
- package/lib/esm/internal/message/use-case/SignMessageUseCase.test.js +2 -0
- package/lib/esm/internal/message/use-case/SignMessageUseCase.test.js.map +7 -0
- package/lib/esm/internal/shared/utils/PayloadUtils.js +2 -0
- package/lib/esm/internal/shared/utils/PayloadUtils.js.map +7 -0
- package/lib/esm/internal/shared/utils/PayloadUtils.test.js +2 -0
- package/lib/esm/internal/shared/utils/PayloadUtils.test.js.map +7 -0
- package/lib/esm/internal/transaction/di/transactionModule.js +2 -13
- package/lib/esm/internal/transaction/di/transactionModule.js.map +7 -1
- package/lib/esm/internal/transaction/di/transactionModule.test.js +2 -0
- package/lib/esm/internal/transaction/di/transactionModule.test.js.map +7 -0
- package/lib/esm/internal/transaction/di/transactionTypes.js +2 -6
- package/lib/esm/internal/transaction/di/transactionTypes.js.map +7 -1
- package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.js +2 -57
- package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.js.map +7 -1
- package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.test.js +2 -0
- package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.test.js.map +7 -0
- package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.js +2 -33
- package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.js.map +7 -1
- package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.test.js +2 -0
- package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.test.js.map +7 -0
- package/lib/esm/internal/transaction/service/mapper/TransactionMapper.js +1 -2
- package/lib/esm/internal/transaction/service/mapper/TransactionMapper.js.map +7 -1
- package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js +2 -38
- package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js.map +7 -1
- package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js +2 -0
- package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js.map +7 -0
- package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.js +1 -2
- package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.js.map +7 -1
- package/lib/esm/internal/transaction/service/parser/TransactionParserService.js +2 -0
- package/lib/esm/internal/transaction/service/parser/TransactionParserService.js.map +7 -0
- package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js +2 -0
- package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js.map +7 -0
- package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.js +2 -35
- package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.js.map +7 -1
- package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.test.js +2 -0
- package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.test.js.map +7 -0
- package/lib/esm/internal/typed-data/di/typedDataModule.js +2 -9
- package/lib/esm/internal/typed-data/di/typedDataModule.js.map +7 -1
- package/lib/esm/internal/typed-data/di/typedDataModule.test.js +2 -0
- package/lib/esm/internal/typed-data/di/typedDataModule.test.js.map +7 -0
- package/lib/esm/internal/typed-data/di/typedDataTypes.js +2 -5
- package/lib/esm/internal/typed-data/di/typedDataTypes.js.map +7 -1
- package/lib/esm/internal/typed-data/model/Types.js +2 -55
- package/lib/esm/internal/typed-data/model/Types.js.map +7 -1
- package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js +2 -26
- package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js.map +7 -1
- package/lib/esm/internal/typed-data/service/TypedDataEncoder.js +2 -98
- package/lib/esm/internal/typed-data/service/TypedDataEncoder.js.map +7 -1
- package/lib/esm/internal/typed-data/service/TypedDataEncoder.test.js +2 -0
- package/lib/esm/internal/typed-data/service/TypedDataEncoder.test.js.map +7 -0
- package/lib/esm/internal/typed-data/service/TypedDataParser.js +2 -207
- package/lib/esm/internal/typed-data/service/TypedDataParser.js.map +7 -1
- package/lib/esm/internal/typed-data/service/TypedDataParser.test.js +2 -0
- package/lib/esm/internal/typed-data/service/TypedDataParser.test.js.map +7 -0
- package/lib/esm/internal/typed-data/service/TypedDataParserService.js +1 -2
- package/lib/esm/internal/typed-data/service/TypedDataParserService.js.map +7 -1
- package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js +2 -39
- package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js.map +7 -1
- package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js +2 -0
- package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +7 -0
- package/lib/esm/package.json +63 -0
- package/lib/types/api/SignerEth.d.ts +15 -0
- package/lib/types/api/SignerEth.d.ts.map +1 -0
- package/lib/types/api/SignerEthBuilder.d.ts +37 -0
- package/lib/types/api/SignerEthBuilder.d.ts.map +1 -0
- package/lib/types/api/SignerEthBuilder.test.d.ts +2 -0
- package/lib/types/api/SignerEthBuilder.test.d.ts.map +1 -0
- package/lib/{cjs → types}/api/app-binder/GetAddressDeviceActionTypes.d.ts +1 -1
- package/lib/types/api/app-binder/GetAddressDeviceActionTypes.d.ts.map +1 -0
- package/lib/{esm → types}/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts +3 -3
- package/lib/types/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts.map +1 -0
- package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts +37 -0
- package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +1 -0
- package/lib/{cjs → types}/api/app-binder/SignTypedDataDeviceActionTypes.d.ts +5 -5
- package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +1 -0
- package/lib/{cjs → types}/api/index.d.ts +2 -2
- package/lib/{cjs → types}/api/index.d.ts.map +1 -1
- package/lib/types/api/model/Address.d.ts +7 -0
- package/lib/types/api/model/Address.d.ts.map +1 -0
- package/lib/types/api/model/Signature.d.ts +7 -0
- package/lib/types/api/model/Signature.d.ts.map +1 -0
- package/lib/types/api/model/Transaction.d.ts +14 -0
- package/lib/types/api/model/Transaction.d.ts.map +1 -0
- package/lib/types/internal/DefaultSignerEth.d.ts +26 -0
- package/lib/types/internal/DefaultSignerEth.d.ts.map +1 -0
- package/lib/types/internal/DefaultSignerEth.test.d.ts +2 -0
- package/lib/types/internal/DefaultSignerEth.test.d.ts.map +1 -0
- package/lib/types/internal/address/di/addressModule.test.d.ts +2 -0
- package/lib/types/internal/address/di/addressModule.test.d.ts.map +1 -0
- package/lib/types/internal/address/use-case/GetAddressUseCase.test.d.ts +2 -0
- package/lib/types/internal/address/use-case/GetAddressUseCase.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/app-binder/EthAppBinder.d.ts +6 -4
- package/lib/types/internal/app-binder/EthAppBinder.d.ts.map +1 -0
- package/lib/types/internal/app-binder/EthAppBinder.test.d.ts +2 -0
- package/lib/types/internal/app-binder/EthAppBinder.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/app-binder/command/GetAddressCommand.d.ts +2 -2
- package/lib/types/internal/app-binder/command/GetAddressCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/GetAddressCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/GetAddressCommand.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/app-binder/command/GetChallengeCommand.d.ts +1 -1
- package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/GetChallengeCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/GetChallengeCommand.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts +18 -0
- package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideEnumCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/ProvideEnumCommand.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +1 -1
- package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/app-binder/command/ProvideTokenInformationCommand.d.ts +1 -1
- package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts +18 -0
- package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts +18 -0
- package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts +19 -0
- package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +9 -1
- package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts +1 -1
- package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts +1 -1
- package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/app-binder/command/SetExternalPluginCommand.d.ts +1 -1
- package/lib/types/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/SetExternalPluginCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/SetExternalPluginCommand.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/app-binder/command/SetPluginCommand.d.ts +1 -1
- package/lib/types/internal/app-binder/command/SetPluginCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/SetPluginCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/SetPluginCommand.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/app-binder/command/SignEIP712Command.d.ts +2 -2
- package/lib/types/internal/app-binder/command/SignEIP712Command.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/SignEIP712Command.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/SignEIP712Command.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/app-binder/command/SignPersonalMessageCommand.d.ts +3 -3
- package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/app-binder/command/SignTransactionCommand.d.ts +2 -2
- package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/SignTransactionCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/SignTransactionCommand.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts +12 -0
- package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/StartTransactionCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/StartTransactionCommand.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts +23 -0
- package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/StoreTransactionCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/StoreTransactionCommand.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts +4 -4
- package/lib/types/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts.map +1 -0
- package/lib/types/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.d.ts +2 -0
- package/lib/types/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +54 -0
- package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +1 -0
- package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.d.ts +2 -0
- package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +6 -6
- package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +1 -0
- package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.d.ts +2 -0
- package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +3 -0
- package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts.map +1 -1
- package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts +2 -2
- package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/app-binder/task/BuildEIP712ContextTask.d.ts.map +1 -1
- package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts +27 -0
- package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +28 -0
- package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/app-binder/task/ProvideTransactionContextTask.d.ts +7 -24
- package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts +38 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts +27 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SendCommandInChunksTask.d.ts +16 -0
- package/lib/types/internal/app-binder/task/SendCommandInChunksTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SendEIP712StructImplemTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/SendEIP712StructImplemTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts +14 -0
- package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/app-binder/task/SendSignPersonalMessageTask.d.ts +3 -3
- package/lib/types/internal/app-binder/task/SendSignPersonalMessageTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SendSignPersonalMessageTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/SendSignPersonalMessageTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts +20 -0
- package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SendSignTransactionTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/SendSignTransactionTask.test.d.ts.map +1 -0
- package/lib/types/internal/di.d.ts +10 -0
- package/lib/types/internal/di.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/externalTypes.d.ts +1 -1
- package/lib/types/internal/message/di/messageModule.test.d.ts +2 -0
- package/lib/types/internal/message/di/messageModule.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/message/use-case/SignMessageUseCase.d.ts +2 -2
- package/lib/{cjs → types}/internal/message/use-case/SignMessageUseCase.d.ts.map +1 -1
- package/lib/types/internal/message/use-case/SignMessageUseCase.test.d.ts +2 -0
- package/lib/types/internal/message/use-case/SignMessageUseCase.test.d.ts.map +1 -0
- package/lib/types/internal/shared/utils/PayloadUtils.d.ts +5 -0
- package/lib/types/internal/shared/utils/PayloadUtils.d.ts.map +1 -0
- package/lib/types/internal/shared/utils/PayloadUtils.test.d.ts +2 -0
- package/lib/types/internal/shared/utils/PayloadUtils.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/transaction/di/transactionModule.d.ts.map +1 -1
- package/lib/types/internal/transaction/di/transactionModule.test.d.ts +2 -0
- package/lib/types/internal/transaction/di/transactionModule.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/transaction/di/transactionTypes.d.ts +1 -0
- package/lib/{cjs → types}/internal/transaction/di/transactionTypes.d.ts.map +1 -1
- package/lib/{cjs → types}/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts.map +1 -1
- package/lib/types/internal/transaction/service/mapper/EthersV5TransactionMapper.test.d.ts +2 -0
- package/lib/types/internal/transaction/service/mapper/EthersV5TransactionMapper.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts +1 -1
- package/lib/types/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts.map +1 -0
- package/lib/types/internal/transaction/service/mapper/EthersV6TransactionMapper.test.d.ts +2 -0
- package/lib/types/internal/transaction/service/mapper/EthersV6TransactionMapper.test.d.ts.map +1 -0
- package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts +7 -0
- package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts.map +1 -0
- package/lib/types/internal/transaction/service/mapper/TransactionMapperService.test.d.ts +2 -0
- package/lib/types/internal/transaction/service/mapper/TransactionMapperService.test.d.ts.map +1 -0
- package/lib/types/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts +18 -0
- package/lib/types/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts.map +1 -0
- package/lib/types/internal/transaction/service/parser/TransactionParserService.d.ts +11 -0
- package/lib/types/internal/transaction/service/parser/TransactionParserService.d.ts.map +1 -0
- package/lib/types/internal/transaction/service/parser/TransactionParserService.test.d.ts +2 -0
- package/lib/types/internal/transaction/service/parser/TransactionParserService.test.d.ts.map +1 -0
- package/lib/types/internal/transaction/use-case/SignTransactionUseCase.test.d.ts +2 -0
- package/lib/types/internal/transaction/use-case/SignTransactionUseCase.test.d.ts.map +1 -0
- package/lib/types/internal/typed-data/di/typedDataModule.test.d.ts +2 -0
- package/lib/types/internal/typed-data/di/typedDataModule.test.d.ts.map +1 -0
- package/lib/{cjs → types}/internal/typed-data/model/Types.d.ts +1 -1
- package/lib/types/internal/typed-data/model/Types.d.ts.map +1 -0
- package/lib/{esm → types}/internal/typed-data/service/TypedDataEncoder.d.ts +1 -1
- package/lib/{cjs → types}/internal/typed-data/service/TypedDataEncoder.d.ts.map +1 -1
- package/lib/types/internal/typed-data/service/TypedDataEncoder.test.d.ts +2 -0
- package/lib/types/internal/typed-data/service/TypedDataEncoder.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/typed-data/service/TypedDataParser.d.ts +3 -3
- package/lib/types/internal/typed-data/service/TypedDataParser.d.ts.map +1 -0
- package/lib/types/internal/typed-data/service/TypedDataParser.test.d.ts +2 -0
- package/lib/types/internal/typed-data/service/TypedDataParser.test.d.ts.map +1 -0
- package/lib/{esm → types}/internal/typed-data/service/TypedDataParserService.d.ts +3 -3
- package/lib/types/internal/typed-data/service/TypedDataParserService.d.ts.map +1 -0
- package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.test.d.ts +2 -0
- package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.test.d.ts.map +1 -0
- package/lib/types/tsconfig.prod.tsbuildinfo +1 -0
- package/package.json +28 -32
- package/lib/cjs/api/KeyringEth.d.ts +0 -15
- package/lib/cjs/api/KeyringEth.d.ts.map +0 -1
- package/lib/cjs/api/KeyringEth.js +0 -3
- package/lib/cjs/api/KeyringEth.js.map +0 -1
- package/lib/cjs/api/KeyringEthBuilder.d.ts +0 -38
- package/lib/cjs/api/KeyringEthBuilder.d.ts.map +0 -1
- package/lib/cjs/api/KeyringEthBuilder.js +0 -49
- package/lib/cjs/api/KeyringEthBuilder.js.map +0 -1
- package/lib/cjs/api/app-binder/GetAddressDeviceActionTypes.d.ts.map +0 -1
- package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts +0 -20
- package/lib/cjs/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts.map +0 -1
- package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.d.ts +0 -31
- package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +0 -1
- package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +0 -1
- package/lib/cjs/api/model/Address.d.ts +0 -7
- package/lib/cjs/api/model/Address.d.ts.map +0 -1
- package/lib/cjs/api/model/Signature.d.ts +0 -7
- package/lib/cjs/api/model/Signature.d.ts.map +0 -1
- package/lib/cjs/api/model/Transaction.d.ts +0 -4
- package/lib/cjs/api/model/Transaction.d.ts.map +0 -1
- package/lib/cjs/internal/DefaultKeyringEth.d.ts +0 -26
- package/lib/cjs/internal/DefaultKeyringEth.d.ts.map +0 -1
- package/lib/cjs/internal/DefaultKeyringEth.js +0 -36
- package/lib/cjs/internal/DefaultKeyringEth.js.map +0 -1
- package/lib/cjs/internal/app-binder/EthAppBinder.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/GetAddressCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/GetChallengeCommand.d.ts +0 -10
- package/lib/cjs/internal/app-binder/command/GetChallengeCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.d.ts +0 -19
- package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.js +0 -41
- package/lib/cjs/internal/app-binder/command/ProvideDomainNameCommand.js.map +0 -1
- package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts +0 -25
- package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts +0 -30
- package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.d.ts +0 -17
- package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/SetPluginCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.d.ts +0 -25
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/SignTransactionCommand.d.ts +0 -24
- package/lib/cjs/internal/app-binder/command/SignTransactionCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts +0 -17
- package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +0 -39
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +0 -3
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.d.ts +0 -21
- package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +0 -21
- package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.d.ts +0 -57
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.d.ts +0 -14
- package/lib/cjs/internal/app-binder/task/SendSignPersonalMessageTask.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.d.ts +0 -14
- package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.d.ts.map +0 -1
- package/lib/cjs/internal/di.d.ts +0 -10
- package/lib/cjs/internal/di.d.ts.map +0 -1
- package/lib/cjs/internal/message/use-case/SignMessageUseCase.d.ts +0 -8
- package/lib/cjs/internal/shared/utils/DerivationPathUtils.d.ts +0 -5
- package/lib/cjs/internal/shared/utils/DerivationPathUtils.d.ts.map +0 -1
- package/lib/cjs/internal/shared/utils/DerivationPathUtils.js +0 -24
- package/lib/cjs/internal/shared/utils/DerivationPathUtils.js.map +0 -1
- package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts +0 -9
- package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts.map +0 -1
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.d.ts +0 -7
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.d.ts.map +0 -1
- package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts +0 -12
- package/lib/cjs/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts.map +0 -1
- package/lib/cjs/internal/typed-data/model/Types.d.ts.map +0 -1
- package/lib/cjs/internal/typed-data/service/TypedDataEncoder.d.ts +0 -10
- package/lib/cjs/internal/typed-data/service/TypedDataParser.d.ts +0 -73
- package/lib/cjs/internal/typed-data/service/TypedDataParser.d.ts.map +0 -1
- package/lib/cjs/internal/typed-data/service/TypedDataParserService.d.ts +0 -12
- package/lib/cjs/internal/typed-data/service/TypedDataParserService.d.ts.map +0 -1
- package/lib/esm/api/KeyringEth.d.ts +0 -15
- package/lib/esm/api/KeyringEth.d.ts.map +0 -1
- package/lib/esm/api/KeyringEth.js +0 -2
- package/lib/esm/api/KeyringEth.js.map +0 -1
- package/lib/esm/api/KeyringEthBuilder.d.ts +0 -38
- package/lib/esm/api/KeyringEthBuilder.d.ts.map +0 -1
- package/lib/esm/api/KeyringEthBuilder.js +0 -45
- package/lib/esm/api/KeyringEthBuilder.js.map +0 -1
- package/lib/esm/api/app-binder/GetAddressCommandTypes.d.ts +0 -11
- package/lib/esm/api/app-binder/GetAddressCommandTypes.d.ts.map +0 -1
- package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.d.ts +0 -9
- package/lib/esm/api/app-binder/GetAddressDeviceActionTypes.d.ts.map +0 -1
- package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts.map +0 -1
- package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.d.ts +0 -31
- package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +0 -1
- package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.d.ts +0 -27
- package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +0 -1
- package/lib/esm/api/index.d.ts +0 -13
- package/lib/esm/api/index.d.ts.map +0 -1
- package/lib/esm/api/model/Address.d.ts +0 -7
- package/lib/esm/api/model/Address.d.ts.map +0 -1
- package/lib/esm/api/model/AddressOptions.d.ts +0 -5
- package/lib/esm/api/model/AddressOptions.d.ts.map +0 -1
- package/lib/esm/api/model/Signature.d.ts +0 -7
- package/lib/esm/api/model/Signature.d.ts.map +0 -1
- package/lib/esm/api/model/Transaction.d.ts +0 -4
- package/lib/esm/api/model/Transaction.d.ts.map +0 -1
- package/lib/esm/api/model/TransactionOptions.d.ts +0 -4
- package/lib/esm/api/model/TransactionOptions.d.ts.map +0 -1
- package/lib/esm/api/model/TypedData.d.ts +0 -18
- package/lib/esm/api/model/TypedData.d.ts.map +0 -1
- package/lib/esm/index.d.ts +0 -3
- package/lib/esm/index.d.ts.map +0 -1
- package/lib/esm/internal/DefaultKeyringEth.d.ts +0 -26
- package/lib/esm/internal/DefaultKeyringEth.d.ts.map +0 -1
- package/lib/esm/internal/DefaultKeyringEth.js +0 -32
- package/lib/esm/internal/DefaultKeyringEth.js.map +0 -1
- package/lib/esm/internal/address/di/addressModule.d.ts +0 -3
- package/lib/esm/internal/address/di/addressModule.d.ts.map +0 -1
- package/lib/esm/internal/address/di/addressTypes.d.ts +0 -4
- package/lib/esm/internal/address/di/addressTypes.d.ts.map +0 -1
- package/lib/esm/internal/address/use-case/GetAddressUseCase.d.ts +0 -9
- package/lib/esm/internal/address/use-case/GetAddressUseCase.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/EthAppBinder.d.ts +0 -38
- package/lib/esm/internal/app-binder/EthAppBinder.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/GetAddressCommand.d.ts +0 -9
- package/lib/esm/internal/app-binder/command/GetAddressCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/GetChallengeCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.d.ts +0 -19
- package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.js +0 -37
- package/lib/esm/internal/app-binder/command/ProvideDomainNameCommand.js.map +0 -1
- package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +0 -15
- package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.d.ts +0 -14
- package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +0 -41
- package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SetPluginCommand.d.ts +0 -18
- package/lib/esm/internal/app-binder/command/SetPluginCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SignEIP712Command.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.d.ts +0 -21
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SignTransactionCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +0 -39
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +0 -31
- package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts +0 -3
- package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts +0 -2
- package/lib/esm/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts +0 -12
- package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/di/appBinderModule.d.ts +0 -3
- package/lib/esm/internal/app-binder/di/appBinderModule.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/di/appBinderTypes.d.ts +0 -4
- package/lib/esm/internal/app-binder/di/appBinderTypes.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.d.ts +0 -16
- package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.d.ts +0 -21
- package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +0 -21
- package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.d.ts +0 -19
- package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/task/SendSignTransactionTask.d.ts +0 -14
- package/lib/esm/internal/app-binder/task/SendSignTransactionTask.d.ts.map +0 -1
- package/lib/esm/internal/di.d.ts +0 -10
- package/lib/esm/internal/di.d.ts.map +0 -1
- package/lib/esm/internal/externalTypes.d.ts +0 -6
- package/lib/esm/internal/externalTypes.d.ts.map +0 -1
- package/lib/esm/internal/message/di/messageModule.d.ts +0 -3
- package/lib/esm/internal/message/di/messageModule.d.ts.map +0 -1
- package/lib/esm/internal/message/di/messageTypes.d.ts +0 -4
- package/lib/esm/internal/message/di/messageTypes.d.ts.map +0 -1
- package/lib/esm/internal/message/use-case/SignMessageUseCase.d.ts.map +0 -1
- package/lib/esm/internal/shared/utils/DerivationPathUtils.d.ts +0 -5
- package/lib/esm/internal/shared/utils/DerivationPathUtils.d.ts.map +0 -1
- package/lib/esm/internal/shared/utils/DerivationPathUtils.js +0 -20
- package/lib/esm/internal/shared/utils/DerivationPathUtils.js.map +0 -1
- package/lib/esm/internal/transaction/di/transactionModule.d.ts +0 -3
- package/lib/esm/internal/transaction/di/transactionModule.d.ts.map +0 -1
- package/lib/esm/internal/transaction/di/transactionTypes.d.ts +0 -6
- package/lib/esm/internal/transaction/di/transactionTypes.d.ts.map +0 -1
- package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts +0 -10
- package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts.map +0 -1
- package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts.map +0 -1
- package/lib/esm/internal/transaction/service/mapper/TransactionMapper.d.ts +0 -7
- package/lib/esm/internal/transaction/service/mapper/TransactionMapper.d.ts.map +0 -1
- package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.d.ts +0 -10
- package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.d.ts.map +0 -1
- package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts +0 -12
- package/lib/esm/internal/transaction/service/mapper/model/TransactionMapperResult.d.ts.map +0 -1
- package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.d.ts +0 -10
- package/lib/esm/internal/transaction/use-case/SignTransactionUseCase.d.ts.map +0 -1
- package/lib/esm/internal/typed-data/di/typedDataModule.d.ts +0 -3
- package/lib/esm/internal/typed-data/di/typedDataModule.d.ts.map +0 -1
- package/lib/esm/internal/typed-data/di/typedDataTypes.d.ts +0 -5
- package/lib/esm/internal/typed-data/di/typedDataTypes.d.ts.map +0 -1
- package/lib/esm/internal/typed-data/model/Types.d.ts +0 -41
- package/lib/esm/internal/typed-data/model/Types.d.ts.map +0 -1
- package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.d.ts +0 -7
- package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.d.ts.map +0 -1
- package/lib/esm/internal/typed-data/service/TypedDataEncoder.d.ts.map +0 -1
- package/lib/esm/internal/typed-data/service/TypedDataParser.d.ts.map +0 -1
- package/lib/esm/internal/typed-data/service/TypedDataParserService.d.ts.map +0 -1
- package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.d.ts +0 -11
- package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.d.ts.map +0 -1
- /package/lib/{cjs → types}/api/app-binder/GetAddressCommandTypes.d.ts +0 -0
- /package/lib/{cjs → types}/api/app-binder/GetAddressCommandTypes.d.ts.map +0 -0
- /package/lib/{cjs → types}/api/model/AddressOptions.d.ts +0 -0
- /package/lib/{cjs → types}/api/model/AddressOptions.d.ts.map +0 -0
- /package/lib/{cjs → types}/api/model/TransactionOptions.d.ts +0 -0
- /package/lib/{cjs → types}/api/model/TransactionOptions.d.ts.map +0 -0
- /package/lib/{cjs → types}/api/model/TypedData.d.ts +0 -0
- /package/lib/{cjs → types}/api/model/TypedData.d.ts.map +0 -0
- /package/lib/{cjs → types}/index.d.ts +0 -0
- /package/lib/{cjs → types}/index.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/address/di/addressModule.d.ts +0 -0
- /package/lib/{cjs → types}/internal/address/di/addressModule.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/address/di/addressTypes.d.ts +0 -0
- /package/lib/{cjs → types}/internal/address/di/addressTypes.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/address/use-case/GetAddressUseCase.d.ts +0 -0
- /package/lib/{cjs → types}/internal/address/use-case/GetAddressUseCase.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts +0 -0
- /package/lib/{cjs → types}/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/app-binder/di/appBinderModule.d.ts +0 -0
- /package/lib/{cjs → types}/internal/app-binder/di/appBinderModule.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/app-binder/di/appBinderTypes.d.ts +0 -0
- /package/lib/{cjs → types}/internal/app-binder/di/appBinderTypes.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/app-binder/task/BuildEIP712ContextTask.d.ts +0 -0
- /package/lib/{cjs → types}/internal/app-binder/task/SendEIP712StructImplemTask.d.ts +0 -0
- /package/lib/{cjs → types}/internal/app-binder/task/SendEIP712StructImplemTask.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/externalTypes.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/message/di/messageModule.d.ts +0 -0
- /package/lib/{cjs → types}/internal/message/di/messageModule.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/message/di/messageTypes.d.ts +0 -0
- /package/lib/{cjs → types}/internal/message/di/messageTypes.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/transaction/di/transactionModule.d.ts +0 -0
- /package/lib/{cjs → types}/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts +0 -0
- /package/lib/{cjs → types}/internal/transaction/service/mapper/TransactionMapperService.d.ts +0 -0
- /package/lib/{cjs → types}/internal/transaction/service/mapper/TransactionMapperService.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/transaction/use-case/SignTransactionUseCase.d.ts +0 -0
- /package/lib/{cjs → types}/internal/transaction/use-case/SignTransactionUseCase.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/typed-data/di/typedDataModule.d.ts +0 -0
- /package/lib/{cjs → types}/internal/typed-data/di/typedDataModule.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/typed-data/di/typedDataTypes.d.ts +0 -0
- /package/lib/{cjs → types}/internal/typed-data/di/typedDataTypes.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/typed-data/service/DefaultTypedDataParserService.d.ts +0 -0
- /package/lib/{cjs → types}/internal/typed-data/service/DefaultTypedDataParserService.d.ts.map +0 -0
- /package/lib/{cjs → types}/internal/typed-data/use-case/SignTypedDataUseCase.d.ts +0 -0
- /package/lib/{cjs → types}/internal/typed-data/use-case/SignTypedDataUseCase.d.ts.map +0 -0
|
@@ -1,188 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
exports.ProvideEIP712ContextTask = void 0;
|
|
4
|
-
const context_module_1 = require("@ledgerhq/context-module");
|
|
5
|
-
const device_management_kit_1 = require("@ledgerhq/device-management-kit");
|
|
6
|
-
const purify_ts_1 = require("purify-ts");
|
|
7
|
-
const ProvideTokenInformationCommand_1 = require("../../app-binder/command/ProvideTokenInformationCommand");
|
|
8
|
-
const SendEIP712FilteringCommand_1 = require("../../app-binder/command/SendEIP712FilteringCommand");
|
|
9
|
-
const SendEIP712StructDefinitionCommand_1 = require("../../app-binder/command/SendEIP712StructDefinitionCommand");
|
|
10
|
-
const SendEIP712StructImplemCommand_1 = require("../../app-binder/command/SendEIP712StructImplemCommand");
|
|
11
|
-
const SendEIP712StructImplemTask_1 = require("../../app-binder/task/SendEIP712StructImplemTask");
|
|
12
|
-
const Types_1 = require("../../typed-data/model/Types");
|
|
13
|
-
class ProvideEIP712ContextTask {
|
|
14
|
-
api;
|
|
15
|
-
args;
|
|
16
|
-
constructor(api, args) {
|
|
17
|
-
this.api = api;
|
|
18
|
-
this.args = args;
|
|
19
|
-
}
|
|
20
|
-
async run() {
|
|
21
|
-
let result = (0, device_management_kit_1.CommandResultFactory)({ data: undefined });
|
|
22
|
-
// Provide the structure definitions.
|
|
23
|
-
// Should be sent before struct implementations, as described here:
|
|
24
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-send-struct-definition
|
|
25
|
-
// Note that those types are used to compute the schema hash, in the device and in ClearSignContexts, as described here:
|
|
26
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-filtering
|
|
27
|
-
// Therefore it should be normalized on both sides: sorted per keys
|
|
28
|
-
const types = Object.entries(this.args.types).sort(([aKey], [bKey]) => aKey.localeCompare(bKey));
|
|
29
|
-
for (const [structName, fields] of types) {
|
|
30
|
-
result = await this.api.sendCommand(new SendEIP712StructDefinitionCommand_1.SendEIP712StructDefinitionCommand({
|
|
31
|
-
command: SendEIP712StructDefinitionCommand_1.StructDefinitionCommand.Name,
|
|
32
|
-
name: structName,
|
|
33
|
-
}));
|
|
34
|
-
if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
|
|
35
|
-
return result;
|
|
36
|
-
}
|
|
37
|
-
for (const [fieldName, fieldType] of Object.entries(fields)) {
|
|
38
|
-
result = await this.api.sendCommand(new SendEIP712StructDefinitionCommand_1.SendEIP712StructDefinitionCommand({
|
|
39
|
-
command: SendEIP712StructDefinitionCommand_1.StructDefinitionCommand.Field,
|
|
40
|
-
name: fieldName,
|
|
41
|
-
type: fieldType,
|
|
42
|
-
}));
|
|
43
|
-
if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
|
|
44
|
-
return result;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
if (this.args.clearSignContext.isJust()) {
|
|
49
|
-
// Activate the filtering, before sending domain and message implementations, as described here:
|
|
50
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#activation
|
|
51
|
-
result = await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({ type: SendEIP712FilteringCommand_1.Eip712FilterType.Activation }));
|
|
52
|
-
if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
|
|
53
|
-
return result;
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
// Send domain implementation values.
|
|
57
|
-
for (const value of this.args.domain) {
|
|
58
|
-
await this.getImplementationTask(value).run();
|
|
59
|
-
}
|
|
60
|
-
if (this.args.clearSignContext.isJust()) {
|
|
61
|
-
// Send MessageInformation filter.
|
|
62
|
-
// Should be sent between Domain and Message implementations, as described here:
|
|
63
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#message-info
|
|
64
|
-
result = await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({
|
|
65
|
-
type: SendEIP712FilteringCommand_1.Eip712FilterType.MessageInfo,
|
|
66
|
-
displayName: this.args.clearSignContext.extract().messageInfo.displayName,
|
|
67
|
-
filtersCount: this.args.clearSignContext.extract().messageInfo.filtersCount,
|
|
68
|
-
signature: this.args.clearSignContext.extract().messageInfo.signature,
|
|
69
|
-
}));
|
|
70
|
-
if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
|
|
71
|
-
return result;
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
// Send message implementation values
|
|
75
|
-
const tokensIndexes = {};
|
|
76
|
-
for (const value of this.args.message) {
|
|
77
|
-
// Provide the descriptors of tokens referenced by the message, if any.
|
|
78
|
-
// Keep a map of all device indexes for those provided tokens.
|
|
79
|
-
const maybeError = await this.provideTokenInformation(value, tokensIndexes);
|
|
80
|
-
if (maybeError.isJust()) {
|
|
81
|
-
return maybeError.extract();
|
|
82
|
-
}
|
|
83
|
-
// If there is a filter, it should be sent just before the corresponding implementation:
|
|
84
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-token
|
|
85
|
-
const maybeResult = await this.provideFiltering(value, tokensIndexes);
|
|
86
|
-
if (maybeResult.isJust() &&
|
|
87
|
-
!(0, device_management_kit_1.isSuccessCommandResult)(maybeResult.extract())) {
|
|
88
|
-
return maybeResult.extract();
|
|
89
|
-
}
|
|
90
|
-
// Provide message value implementation
|
|
91
|
-
result = await this.getImplementationTask(value).run();
|
|
92
|
-
if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
|
|
93
|
-
return result;
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
return result;
|
|
97
|
-
}
|
|
98
|
-
getImplementationTask(value) {
|
|
99
|
-
if (value.value instanceof Types_1.TypedDataValueRoot) {
|
|
100
|
-
return new SendEIP712StructImplemTask_1.SendEIP712StructImplemTask(this.api, {
|
|
101
|
-
type: SendEIP712StructImplemCommand_1.StructImplemType.ROOT,
|
|
102
|
-
value: value.value.root,
|
|
103
|
-
});
|
|
104
|
-
}
|
|
105
|
-
else if (value.value instanceof Types_1.TypedDataValueArray) {
|
|
106
|
-
return new SendEIP712StructImplemTask_1.SendEIP712StructImplemTask(this.api, {
|
|
107
|
-
type: SendEIP712StructImplemCommand_1.StructImplemType.ARRAY,
|
|
108
|
-
value: value.value.length,
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
else {
|
|
112
|
-
return new SendEIP712StructImplemTask_1.SendEIP712StructImplemTask(this.api, {
|
|
113
|
-
type: SendEIP712StructImplemCommand_1.StructImplemType.FIELD,
|
|
114
|
-
value: value.value.data,
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
async provideTokenInformation(value, tokensIndexes) {
|
|
119
|
-
if (this.args.clearSignContext.isJust()) {
|
|
120
|
-
const filter = this.args.clearSignContext.extract().filters[value.path];
|
|
121
|
-
// Tokens descriptors only needed when a tokenIndex is available in filter.
|
|
122
|
-
// It should be sent to the device only 1 time so tokensIndexes has to be checked.
|
|
123
|
-
if (filter !== undefined &&
|
|
124
|
-
(filter.type === "amount" || filter.type === "token") &&
|
|
125
|
-
tokensIndexes[filter.tokenIndex] === undefined) {
|
|
126
|
-
const descriptorIndex = filter.tokenIndex;
|
|
127
|
-
const tokens = this.args.clearSignContext.extract().tokens;
|
|
128
|
-
const token = tokens[descriptorIndex];
|
|
129
|
-
if (token === undefined) {
|
|
130
|
-
return purify_ts_1.Nothing;
|
|
131
|
-
}
|
|
132
|
-
const provideTokenInfoResult = await this.api.sendCommand(new ProvideTokenInformationCommand_1.ProvideTokenInformationCommand({ payload: token }));
|
|
133
|
-
if (!(0, device_management_kit_1.isSuccessCommandResult)(provideTokenInfoResult)) {
|
|
134
|
-
return purify_ts_1.Maybe.of(provideTokenInfoResult);
|
|
135
|
-
}
|
|
136
|
-
let { tokenIndex: deviceIndex } = provideTokenInfoResult.data;
|
|
137
|
-
// The token corresponding to the Verifying Contract of message domain has a special index value, as described here:
|
|
138
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-value
|
|
139
|
-
if (Number(descriptorIndex) === context_module_1.VERIFYING_CONTRACT_TOKEN_INDEX) {
|
|
140
|
-
deviceIndex = context_module_1.VERIFYING_CONTRACT_TOKEN_INDEX;
|
|
141
|
-
}
|
|
142
|
-
// Save the token index in the device slots. That index will be used by later filtering commands.
|
|
143
|
-
tokensIndexes[Number(descriptorIndex)] = deviceIndex;
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
return purify_ts_1.Nothing;
|
|
147
|
-
}
|
|
148
|
-
async provideFiltering(value, tokensIndexes) {
|
|
149
|
-
if (this.args.clearSignContext.isJust()) {
|
|
150
|
-
const filter = this.args.clearSignContext.extract().filters[value.path];
|
|
151
|
-
if (filter === undefined ||
|
|
152
|
-
((filter.type === "amount" || filter.type === "token") &&
|
|
153
|
-
tokensIndexes[filter.tokenIndex] === undefined)) {
|
|
154
|
-
return purify_ts_1.Nothing;
|
|
155
|
-
}
|
|
156
|
-
switch (filter.type) {
|
|
157
|
-
case "datetime":
|
|
158
|
-
return purify_ts_1.Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({
|
|
159
|
-
type: SendEIP712FilteringCommand_1.Eip712FilterType.Datetime,
|
|
160
|
-
displayName: filter.displayName,
|
|
161
|
-
signature: filter.signature,
|
|
162
|
-
})));
|
|
163
|
-
case "raw":
|
|
164
|
-
return purify_ts_1.Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({
|
|
165
|
-
type: SendEIP712FilteringCommand_1.Eip712FilterType.Raw,
|
|
166
|
-
displayName: filter.displayName,
|
|
167
|
-
signature: filter.signature,
|
|
168
|
-
})));
|
|
169
|
-
case "token":
|
|
170
|
-
return purify_ts_1.Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({
|
|
171
|
-
type: SendEIP712FilteringCommand_1.Eip712FilterType.Token,
|
|
172
|
-
tokenIndex: tokensIndexes[filter.tokenIndex],
|
|
173
|
-
signature: filter.signature,
|
|
174
|
-
})));
|
|
175
|
-
case "amount":
|
|
176
|
-
return purify_ts_1.Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand_1.SendEIP712FilteringCommand({
|
|
177
|
-
type: SendEIP712FilteringCommand_1.Eip712FilterType.Amount,
|
|
178
|
-
displayName: filter.displayName,
|
|
179
|
-
tokenIndex: tokensIndexes[filter.tokenIndex],
|
|
180
|
-
signature: filter.signature,
|
|
181
|
-
})));
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
return purify_ts_1.Nothing;
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
exports.ProvideEIP712ContextTask = ProvideEIP712ContextTask;
|
|
188
|
-
//# sourceMappingURL=ProvideEIP712ContextTask.js.map
|
|
1
|
+
"use strict";var g=Object.defineProperty;var w=Object.getOwnPropertyDescriptor;var S=Object.getOwnPropertyNames;var k=Object.prototype.hasOwnProperty;var D=(r,e)=>{for(var t in e)g(r,t,{get:e[t],enumerable:!0})},v=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of S(e))!k.call(r,a)&&a!==t&&g(r,a,{get:()=>e[a],enumerable:!(n=w(e,a))||n.enumerable});return r};var N=r=>v(g({},"__esModule",{value:!0}),r);var R={};D(R,{ProvideEIP712ContextTask:()=>A});module.exports=N(R);var C=require("@ledgerhq/context-module"),s=require("@ledgerhq/device-management-kit"),m=require("purify-ts"),T=require("../../app-binder/command/ProvideTokenInformationCommand"),i=require("../../app-binder/command/SendEIP712FilteringCommand"),u=require("../../app-binder/command/SendEIP712StructDefinitionCommand"),f=require("../../app-binder/command/SendEIP712StructImplemCommand"),x=require("../../app-binder/task/SendEIP712StructImplemTask"),y=require("../../typed-data/model/Types");const I=5;class A{constructor(e,t){this.api=e;this.args=t}async run(){let e=(0,s.CommandResultFactory)({data:void 0});const t=Object.entries(this.args.types).sort(([a],[d])=>a.localeCompare(d));for(const[a,d]of t){if(e=await this.api.sendCommand(new u.SendEIP712StructDefinitionCommand({command:u.StructDefinitionCommand.Name,name:a})),!(0,s.isSuccessCommandResult)(e))return e;for(const[o,p]of Object.entries(d))if(e=await this.api.sendCommand(new u.SendEIP712StructDefinitionCommand({command:u.StructDefinitionCommand.Field,name:o,type:p})),!(0,s.isSuccessCommandResult)(e))return e}if(this.args.clearSignContext.isJust()&&(e=await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.Activation})),!(0,s.isSuccessCommandResult)(e)))return e;for(const a of this.args.domain)if(e=await this.getImplementationTask(a).run(),!(0,s.isSuccessCommandResult)(e))return e;if(this.args.clearSignContext.isJust()&&(e=await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.MessageInfo,displayName:this.args.clearSignContext.extract().messageInfo.displayName,filtersCount:this.args.clearSignContext.extract().messageInfo.filtersCount,signature:this.args.clearSignContext.extract().messageInfo.signature})),!(0,s.isSuccessCommandResult)(e)))return e;const n={indexes:{},nextIndex:0};for(const a of this.args.message){const d=await this.provideTokenInformation(a,n);if(d.isJust())return d.extract();const o=await this.filterValue(a,n);if(o.isJust()&&!(0,s.isSuccessCommandResult)(o.extract()))return o.extract();if(e=await this.getImplementationTask(a).run(),!(0,s.isSuccessCommandResult)(e))return e;if(this.args.clearSignContext.isJust()&&a.value instanceof y.TypedDataValueArray&&a.value.length===0){const l=Object.entries(this.args.clearSignContext.extract().filters).filter(([c,h])=>c.startsWith(`${a.path}.[]`)).map(([c,h])=>h);for(const c of l)if(e=await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.DiscardedPath,path:c.path})),!(0,s.isSuccessCommandResult)(e)||(e=await this.provideFiltering(c,n,!0),!(0,s.isSuccessCommandResult)(e)))return e}}return e}getImplementationTask(e){return e.value instanceof y.TypedDataValueRoot?new x.SendEIP712StructImplemTask(this.api,{type:f.StructImplemType.ROOT,value:e.value.root}):e.value instanceof y.TypedDataValueArray?new x.SendEIP712StructImplemTask(this.api,{type:f.StructImplemType.ARRAY,value:e.value.length}):new x.SendEIP712StructImplemTask(this.api,{type:f.StructImplemType.FIELD,value:e.value.data})}async provideTokenInformation(e,t){if(this.args.clearSignContext.isJust()){const n=this.args.clearSignContext.extract().filters[e.path];if(n!==void 0&&(n.type==="amount"||n.type==="token")&&t.indexes[n.tokenIndex]===void 0){const a=n.tokenIndex,o=this.args.clearSignContext.extract().tokens[a];if(o===void 0)return m.Nothing;const p=await this.api.sendCommand(new T.ProvideTokenInformationCommand({payload:o}));if(!(0,s.isSuccessCommandResult)(p))return m.Maybe.of(p);let{tokenIndex:l}=p.data;t.nextIndex=(l+1)%I,Number(a)===C.VERIFYING_CONTRACT_TOKEN_INDEX&&(l=C.VERIFYING_CONTRACT_TOKEN_INDEX),t.indexes[Number(a)]=l}}return m.Nothing}async filterValue(e,t){if(this.args.clearSignContext.isJust()){const n=this.args.clearSignContext.extract().filters[e.path];return n===void 0?m.Nothing:m.Maybe.of(await this.provideFiltering(n,t,!1))}return m.Nothing}async provideFiltering(e,t,n){switch(e.type){case"datetime":return await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.Datetime,discarded:n,displayName:e.displayName,signature:e.signature}));case"raw":return await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.Raw,discarded:n,displayName:e.displayName,signature:e.signature}));case"token":return this.sanitizeDeviceIndex(e.tokenIndex,t),await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.Token,discarded:n,tokenIndex:t.indexes[e.tokenIndex],signature:e.signature}));case"amount":return this.sanitizeDeviceIndex(e.tokenIndex,t),await this.api.sendCommand(new i.SendEIP712FilteringCommand({type:i.Eip712FilterType.Amount,discarded:n,displayName:e.displayName,tokenIndex:t.indexes[e.tokenIndex],signature:e.signature}))}}sanitizeDeviceIndex(e,t){t.indexes[e]===void 0&&(t.indexes[e]=t.nextIndex,t.nextIndex=(t.nextIndex+1)%I)}}0&&(module.exports={ProvideEIP712ContextTask});
|
|
2
|
+
//# sourceMappingURL=ProvideEIP712ContextTask.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../../src/internal/app-binder/task/ProvideEIP712ContextTask.ts"],
|
|
4
|
+
"sourcesContent": ["import {\n type TypedDataClearSignContextSuccess,\n type TypedDataFilter,\n type TypedDataTokenIndex,\n VERIFYING_CONTRACT_TOKEN_INDEX,\n} from \"@ledgerhq/context-module\";\nimport {\n type CommandErrorResult,\n type CommandResult,\n CommandResultFactory,\n type InternalApi,\n isSuccessCommandResult,\n} from \"@ledgerhq/device-management-kit\";\nimport { Maybe, Nothing } from \"purify-ts\";\n\nimport { ProvideTokenInformationCommand } from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\nimport {\n Eip712FilterType,\n SendEIP712FilteringCommand,\n} from \"@internal/app-binder/command/SendEIP712FilteringCommand\";\nimport {\n SendEIP712StructDefinitionCommand,\n StructDefinitionCommand,\n} from \"@internal/app-binder/command/SendEIP712StructDefinitionCommand\";\nimport { StructImplemType } from \"@internal/app-binder/command/SendEIP712StructImplemCommand\";\nimport { SendEIP712StructImplemTask } from \"@internal/app-binder/task/SendEIP712StructImplemTask\";\nimport {\n type FieldName,\n type FieldType,\n type StructName,\n type TypedDataValue,\n TypedDataValueArray,\n TypedDataValueRoot,\n} from \"@internal/typed-data/model/Types\";\n\nexport type ProvideEIP712ContextTaskArgs = {\n types: Record<StructName, Record<FieldName, FieldType>>;\n domain: Array<TypedDataValue>;\n message: Array<TypedDataValue>;\n clearSignContext: Maybe<TypedDataClearSignContextSuccess>;\n};\n\nconst DEVICE_ASSETS_MAX = 5;\n\ntype DeviceAssetIndexes = {\n indexes: Record<TypedDataTokenIndex, number>;\n nextIndex: number;\n};\n\nexport class ProvideEIP712ContextTask {\n constructor(\n private api: InternalApi,\n private args: ProvideEIP712ContextTaskArgs,\n ) {}\n\n async run(): Promise<CommandResult<void>> {\n let result = CommandResultFactory<void, void>({ data: undefined });\n // Provide the structure definitions.\n // Should be sent before struct implementations, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-send-struct-definition\n // Note that those types are used to compute the schema hash, in the device and in ClearSignContexts, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-filtering\n // Therefore it should be normalized on both sides: sorted per keys\n const types = Object.entries(this.args.types).sort(([aKey], [bKey]) =>\n aKey.localeCompare(bKey),\n );\n for (const [structName, fields] of types) {\n result = await this.api.sendCommand(\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Name,\n name: structName,\n }),\n );\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n for (const [fieldName, fieldType] of Object.entries(fields)) {\n result = await this.api.sendCommand(\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Field,\n name: fieldName,\n type: fieldType,\n }),\n );\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n }\n }\n\n if (this.args.clearSignContext.isJust()) {\n // Activate the filtering, before sending domain and message implementations, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#activation\n result = await this.api.sendCommand(\n new SendEIP712FilteringCommand({ type: Eip712FilterType.Activation }),\n );\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n }\n\n // Send domain implementation values.\n for (const value of this.args.domain) {\n result = await this.getImplementationTask(value).run();\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n }\n\n if (this.args.clearSignContext.isJust()) {\n // Send MessageInformation filter.\n // Should be sent between Domain and Message implementations, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#message-info\n result = await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.MessageInfo,\n displayName:\n this.args.clearSignContext.extract().messageInfo.displayName,\n filtersCount:\n this.args.clearSignContext.extract().messageInfo.filtersCount,\n signature: this.args.clearSignContext.extract().messageInfo.signature,\n }),\n );\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n }\n\n // Send message implementation values\n const deviceIndexes: DeviceAssetIndexes = { indexes: {}, nextIndex: 0 };\n for (const value of this.args.message) {\n // Provide the descriptors of tokens referenced by the message, if any.\n // Keep a map of all device indexes for those provided tokens.\n const maybeError = await this.provideTokenInformation(\n value,\n deviceIndexes,\n );\n if (maybeError.isJust()) {\n return maybeError.extract();\n }\n // If there is a filter, it should be sent just before the corresponding implementation:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-token\n const maybeResult = await this.filterValue(value, deviceIndexes);\n if (\n maybeResult.isJust() &&\n !isSuccessCommandResult(maybeResult.extract())\n ) {\n return maybeResult.extract();\n }\n // Provide message value implementation\n result = await this.getImplementationTask(value).run();\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n\n // If the value is an empty array, we should discard all sub-filters since\n // there will be no according sub-values in the message\n if (\n this.args.clearSignContext.isJust() &&\n value.value instanceof TypedDataValueArray &&\n value.value.length === 0\n ) {\n const filters = Object.entries(\n this.args.clearSignContext.extract().filters,\n );\n const discardedFilters = filters\n .filter(([path, _]) => path.startsWith(`${value.path}.[]`))\n .map(([_, filter]) => filter);\n for (const filter of discardedFilters) {\n result = await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.DiscardedPath,\n path: filter.path,\n }),\n );\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n result = await this.provideFiltering(filter, deviceIndexes, true);\n if (!isSuccessCommandResult(result)) {\n return result;\n }\n }\n }\n }\n return result;\n }\n\n getImplementationTask(value: TypedDataValue): SendEIP712StructImplemTask {\n if (value.value instanceof TypedDataValueRoot) {\n return new SendEIP712StructImplemTask(this.api, {\n type: StructImplemType.ROOT,\n value: value.value.root,\n });\n } else if (value.value instanceof TypedDataValueArray) {\n return new SendEIP712StructImplemTask(this.api, {\n type: StructImplemType.ARRAY,\n value: value.value.length,\n });\n } else {\n return new SendEIP712StructImplemTask(this.api, {\n type: StructImplemType.FIELD,\n value: value.value.data,\n });\n }\n }\n\n async provideTokenInformation(\n value: TypedDataValue,\n deviceIndexes: DeviceAssetIndexes,\n ): Promise<Maybe<CommandErrorResult>> {\n if (this.args.clearSignContext.isJust()) {\n const filter = this.args.clearSignContext.extract().filters[value.path];\n // Tokens descriptors only needed when a tokenIndex is available in filter.\n // It should be sent to the device only 1 time so deviceIndexes has to be checked.\n if (\n filter !== undefined &&\n (filter.type === \"amount\" || filter.type === \"token\") &&\n deviceIndexes.indexes[filter.tokenIndex] === undefined\n ) {\n const descriptorIndex = filter.tokenIndex;\n const tokens = this.args.clearSignContext.extract().tokens;\n const token = tokens[descriptorIndex];\n if (token === undefined) {\n return Nothing;\n }\n\n const provideTokenInfoResult = await this.api.sendCommand(\n new ProvideTokenInformationCommand({ payload: token }),\n );\n if (!isSuccessCommandResult(provideTokenInfoResult)) {\n return Maybe.of(provideTokenInfoResult);\n }\n let { tokenIndex: deviceIndex } = provideTokenInfoResult.data;\n deviceIndexes.nextIndex = (deviceIndex + 1) % DEVICE_ASSETS_MAX;\n\n // The token corresponding to the Verifying Contract of message domain has a special index value, as described here:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-value\n if (Number(descriptorIndex) === VERIFYING_CONTRACT_TOKEN_INDEX) {\n deviceIndex = VERIFYING_CONTRACT_TOKEN_INDEX;\n }\n\n // Save the token index in the device slots. That index will be used by later filtering commands.\n deviceIndexes.indexes[Number(descriptorIndex)] = deviceIndex;\n }\n }\n return Nothing;\n }\n\n async filterValue(\n value: TypedDataValue,\n deviceIndexes: DeviceAssetIndexes,\n ): Promise<Maybe<CommandResult<void>>> {\n if (this.args.clearSignContext.isJust()) {\n const filter = this.args.clearSignContext.extract().filters[value.path];\n if (filter === undefined) {\n return Nothing;\n }\n return Maybe.of(\n await this.provideFiltering(filter, deviceIndexes, false),\n );\n }\n return Nothing;\n }\n\n async provideFiltering(\n filter: TypedDataFilter,\n deviceIndexes: DeviceAssetIndexes,\n discarded: boolean,\n ): Promise<CommandResult<void>> {\n switch (filter.type) {\n case \"datetime\":\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Datetime,\n discarded,\n displayName: filter.displayName,\n signature: filter.signature,\n }),\n );\n case \"raw\":\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Raw,\n discarded,\n displayName: filter.displayName,\n signature: filter.signature,\n }),\n );\n case \"token\":\n this.sanitizeDeviceIndex(filter.tokenIndex, deviceIndexes);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded,\n tokenIndex: deviceIndexes.indexes[filter.tokenIndex]!,\n signature: filter.signature,\n }),\n );\n case \"amount\":\n this.sanitizeDeviceIndex(filter.tokenIndex, deviceIndexes);\n return await this.api.sendCommand(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded,\n displayName: filter.displayName,\n tokenIndex: deviceIndexes.indexes[filter.tokenIndex]!,\n signature: filter.signature,\n }),\n );\n }\n }\n\n private sanitizeDeviceIndex(\n descriptorIndex: number,\n deviceIndexes: DeviceAssetIndexes,\n ) {\n // If a token is missing, the device will replace it with a placeholder and use the next available index\n if (deviceIndexes.indexes[descriptorIndex] === undefined) {\n deviceIndexes.indexes[descriptorIndex] = deviceIndexes.nextIndex;\n deviceIndexes.nextIndex =\n (deviceIndexes.nextIndex + 1) % DEVICE_ASSETS_MAX;\n }\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["ProvideEIP712ContextTask_exports", "__export", "ProvideEIP712ContextTask", "__toCommonJS", "import_context_module", "import_device_management_kit", "import_purify_ts", "import_ProvideTokenInformationCommand", "import_SendEIP712FilteringCommand", "import_SendEIP712StructDefinitionCommand", "import_SendEIP712StructImplemCommand", "import_SendEIP712StructImplemTask", "import_Types", "DEVICE_ASSETS_MAX", "api", "args", "result", "types", "aKey", "bKey", "structName", "fields", "fieldName", "fieldType", "value", "deviceIndexes", "maybeError", "maybeResult", "discardedFilters", "path", "_", "filter", "descriptorIndex", "token", "provideTokenInfoResult", "deviceIndex", "discarded"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";var a=require("@ledgerhq/device-management-kit"),c=require("purify-ts"),y=require("../../app-binder/command/ProvideTokenInformationCommand"),t=require("../../app-binder/command/SendEIP712FilteringCommand"),k=require("../../app-binder/command/SendEIP712StructDefinitionCommand"),x=require("../../app-binder/command/SendEIP712StructImplemCommand"),I=require("../../app-binder/device-action/__test-utils__/makeInternalApi"),n=require("../../typed-data/model/Types"),l=require("./ProvideEIP712ContextTask");describe("ProvideEIP712ContextTask",()=>{const e=(0,I.makeDeviceActionInternalApiMock)(),m={EIP712Domain:{name:new n.PrimitiveType("string","string",c.Nothing),chainId:new n.PrimitiveType("uint256","uint",(0,c.Just)(32)),verifyingContract:new n.PrimitiveType("address","address",c.Nothing)},PermitSingle:{details:new n.StructType("PermitDetails"),spender:new n.PrimitiveType("address","address",c.Nothing),sigDeadline:new n.PrimitiveType("uint256","uint",(0,c.Just)(32))},PermitDetails:{token:new n.PrimitiveType("address","address",c.Nothing),amount:new n.PrimitiveType("uint160","uint",(0,c.Just)(20)),expiration:new n.PrimitiveType("uint48","uint",(0,c.Just)(6)),nonce:new n.PrimitiveType("uint48","uint",(0,c.Just)(6))}},r=[{path:"",type:"",value:new n.TypedDataValueRoot("EIP712Domain")},{path:"name",type:"string",value:new n.TypedDataValueField(new TextEncoder().encode("Permit2"))},{path:"chainId",type:"uint256",value:new n.TypedDataValueField(Uint8Array.from([137]))},{path:"verifyingContract",type:"address",value:new n.TypedDataValueField((0,a.hexaStringToBuffer)("0x000000000022d473030f116ddee9f6b43ac78ba3"))}],f=[{path:"",type:"",value:new n.TypedDataValueRoot("PermitSingle")},{path:"details.token",type:"address",value:new n.TypedDataValueField((0,a.hexaStringToBuffer)("0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"))},{path:"details.amount",type:"uint160",value:new n.TypedDataValueField(Uint8Array.from([18]))},{path:"details.expiration",type:"uint48",value:new n.TypedDataValueField(Uint8Array.from([18]))},{path:"details.nonce",type:"uint48",value:new n.TypedDataValueField(Uint8Array.from([0]))},{path:"spender",type:"address",value:new n.TypedDataValueField((0,a.hexaStringToBuffer)("0xec7be89e9d109e7e3fec59c222cf297125fefda2"))},{path:"sigDeadline",type:"uint256",value:new n.TypedDataValueField(Uint8Array.from([18]))}],i={type:"success",messageInfo:{displayName:"Permit2",filtersCount:4,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"},tokens:{0:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619",255:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"},filters:{"details.amount":{displayName:"Amount allowance",path:"details.amount",signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",tokenIndex:255,type:"amount"},"details.expiration":{displayName:"Approval expire",path:"details.expiration",signature:"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b",type:"datetime"},"details.token":{displayName:"Amount allowance",path:"details.token",signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733",tokenIndex:0,type:"token"},spender:{displayName:"Approve to spender",path:"spender",signature:"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb",type:"raw"}}},p=new n.PrimitiveType("address","address",c.Nothing),E=new n.PrimitiveType("string","string",c.Nothing),C=new n.PrimitiveType("uint256","uint",(0,c.Just)(32)),v=new n.PrimitiveType("uint160","uint",(0,c.Just)(20)),S=new n.PrimitiveType("uint48","uint",(0,c.Just)(6)),w=d=>new n.StructType(d),b=d=>new k.SendEIP712StructDefinitionCommand({command:k.StructDefinitionCommand.Name,name:d}),o=(d,u)=>new k.SendEIP712StructDefinitionCommand({command:k.StructDefinitionCommand.Field,name:d,type:u}),g=d=>new x.SendEIP712StructImplemCommand({type:x.StructImplemType.ROOT,value:d}),q=d=>new x.SendEIP712StructImplemCommand({type:x.StructImplemType.ARRAY,value:d}),s=d=>new x.SendEIP712StructImplemCommand({type:x.StructImplemType.FIELD,value:{data:d,isLastChunk:!0}});beforeEach(()=>{jest.resetAllMocks()}),it("Send context with no clear signing context",async()=>{const d={types:m,domain:r,message:f,clearSignContext:c.Nothing};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new l.ProvideEIP712ContextTask(e,d).run(),expect(e.sendCommand.mock.calls).toHaveLength(24),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(b("EIP712Domain")),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(o("name",E)),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(o("chainId",C)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(o("verifyingContract",p)),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(b("PermitDetails")),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(o("token",p)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(o("amount",v)),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(o("expiration",S)),expect(e.sendCommand.mock.calls[8][0]).toStrictEqual(o("nonce",S)),expect(e.sendCommand.mock.calls[9][0]).toStrictEqual(b("PermitSingle")),expect(e.sendCommand.mock.calls[10][0]).toStrictEqual(o("details",w("PermitDetails"))),expect(e.sendCommand.mock.calls[11][0]).toStrictEqual(o("spender",p)),expect(e.sendCommand.mock.calls[12][0]).toStrictEqual(o("sigDeadline",C)),expect(e.sendCommand.mock.calls[13][0]).toStrictEqual(g("EIP712Domain")),expect(e.sendCommand.mock.calls[14][0]).toStrictEqual(s(Uint8Array.from([0,7,80,101,114,109,105,116,50]))),expect(e.sendCommand.mock.calls[15][0]).toStrictEqual(s(Uint8Array.from([0,1,137]))),expect(e.sendCommand.mock.calls[16][0]).toStrictEqual(s(Uint8Array.from([0,20,0,0,0,0,0,34,212,115,3,15,17,109,222,233,246,180,58,199,139,163]))),expect(e.sendCommand.mock.calls[17][0]).toStrictEqual(g("PermitSingle")),expect(e.sendCommand.mock.calls[18][0]).toStrictEqual(s(Uint8Array.from([0,20,124,235,35,253,107,192,173,213,158,98,172,37,87,130,112,207,241,185,246,25]))),expect(e.sendCommand.mock.calls[19][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[20][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[21][0]).toStrictEqual(s(Uint8Array.from([0,1,0]))),expect(e.sendCommand.mock.calls[22][0]).toStrictEqual(s(Uint8Array.from([0,20,236,123,232,158,157,16,158,126,63,236,89,194,34,207,41,113,37,254,253,162]))),expect(e.sendCommand.mock.calls[23][0]).toStrictEqual(s(Uint8Array.from([0,1,18])))}),it("Send context with clear signing",async()=>{const d={types:m,domain:r,message:f,clearSignContext:(0,c.Just)(i)};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:4}})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:5}})),e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new l.ProvideEIP712ContextTask(e,d).run(),expect(e.sendCommand.mock.calls).toHaveLength(32),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(b("EIP712Domain")),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(o("name",E)),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(o("chainId",C)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(o("verifyingContract",p)),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(b("PermitDetails")),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(o("token",p)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(o("amount",v)),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(o("expiration",S)),expect(e.sendCommand.mock.calls[8][0]).toStrictEqual(o("nonce",S)),expect(e.sendCommand.mock.calls[9][0]).toStrictEqual(b("PermitSingle")),expect(e.sendCommand.mock.calls[10][0]).toStrictEqual(o("details",w("PermitDetails"))),expect(e.sendCommand.mock.calls[11][0]).toStrictEqual(o("spender",p)),expect(e.sendCommand.mock.calls[12][0]).toStrictEqual(o("sigDeadline",C)),expect(e.sendCommand.mock.calls[13][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Activation})),expect(e.sendCommand.mock.calls[14][0]).toStrictEqual(g("EIP712Domain")),expect(e.sendCommand.mock.calls[15][0]).toStrictEqual(s(Uint8Array.from([0,7,80,101,114,109,105,116,50]))),expect(e.sendCommand.mock.calls[16][0]).toStrictEqual(s(Uint8Array.from([0,1,137]))),expect(e.sendCommand.mock.calls[17][0]).toStrictEqual(s(Uint8Array.from([0,20,0,0,0,0,0,34,212,115,3,15,17,109,222,233,246,180,58,199,139,163]))),expect(e.sendCommand.mock.calls[18][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.MessageInfo,displayName:"Permit2",filtersCount:4,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"})),expect(e.sendCommand.mock.calls[19][0]).toStrictEqual(g("PermitSingle")),expect(e.sendCommand.mock.calls[20][0]).toStrictEqual(new y.ProvideTokenInformationCommand({payload:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"})),expect(e.sendCommand.mock.calls[21][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:4,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand.mock.calls[22][0]).toStrictEqual(s(Uint8Array.from([0,20,124,235,35,253,107,192,173,213,158,98,172,37,87,130,112,207,241,185,246,25]))),expect(e.sendCommand.mock.calls[23][0]).toStrictEqual(new y.ProvideTokenInformationCommand({payload:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"})),expect(e.sendCommand.mock.calls[24][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:255,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"})),expect(e.sendCommand.mock.calls[25][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[26][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Datetime,discarded:!1,displayName:"Approval expire",signature:"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b"})),expect(e.sendCommand.mock.calls[27][0]).toStrictEqual(s(Uint8Array.from([0,1,18]))),expect(e.sendCommand.mock.calls[28][0]).toStrictEqual(s(Uint8Array.from([0,1,0]))),expect(e.sendCommand.mock.calls[29][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Raw,discarded:!1,displayName:"Approve to spender",signature:"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb"})),expect(e.sendCommand.mock.calls[30][0]).toStrictEqual(s(Uint8Array.from([0,20,236,123,232,158,157,16,158,126,63,236,89,194,34,207,41,113,37,254,253,162]))),expect(e.sendCommand.mock.calls[31][0]).toStrictEqual(s(Uint8Array.from([0,1,18])))}),it("Both tokens unavailable",async()=>{const d={types:m,domain:r,message:f,clearSignContext:(0,c.Just)({type:"success",messageInfo:i.messageInfo,filters:i.filters,tokens:{}})};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new l.ProvideEIP712ContextTask(e,d).run(),expect(e.sendCommand).not.toHaveBeenCalledWith(new y.ProvideTokenInformationCommand({payload:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"})),expect(e.sendCommand).not.toHaveBeenCalledWith(new y.ProvideTokenInformationCommand({payload:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:0,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:1,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("First token unavailable",async()=>{const d={types:m,domain:r,message:f,clearSignContext:(0,c.Just)({type:"success",messageInfo:i.messageInfo,filters:i.filters,tokens:{255:"payload-0x000000000022d473030f116ddee9f6b43ac78ba3"}})};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:{tokenIndex:4}})),await new l.ProvideEIP712ContextTask(e,d).run(),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:0,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:255,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("Second token unavailable",async()=>{const d={types:m,domain:r,message:f,clearSignContext:(0,c.Just)({type:"success",messageInfo:i.messageInfo,filters:i.filters,tokens:{0:"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"}})};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:{tokenIndex:4}})),await new l.ProvideEIP712ContextTask(e,d).run(),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Token,discarded:!1,tokenIndex:4,signature:"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733"})),expect(e.sendCommand).toHaveBeenCalledWith(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Amount,discarded:!1,displayName:"Amount allowance",tokenIndex:0,signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3"}))}),it("Error when providing tokens",async()=>{const d={types:m,domain:r,message:f,clearSignContext:(0,c.Just)(i)};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}));const u=new l.ProvideEIP712ContextTask(e,d).run();await expect(u).resolves.toStrictEqual((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}))}),it("Error when sending struct definitions",async()=>{const d={types:m,domain:r,message:f,clearSignContext:(0,c.Just)(i)};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:4}})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:{tokenIndex:5}})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}));const u=new l.ProvideEIP712ContextTask(e,d).run();await expect(u).resolves.toStrictEqual((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}))}),it("Error when sending struct implementations",async()=>{const d={types:m,domain:r,message:f,clearSignContext:c.Nothing};e.sendCommand.mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({data:void 0})).mockResolvedValueOnce((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")})).mockResolvedValue((0,a.CommandResultFactory)({data:void 0}));const u=new l.ProvideEIP712ContextTask(e,d).run();await expect(u).resolves.toStrictEqual((0,a.CommandResultFactory)({error:new a.UnknownDeviceExchangeError("error")}))}),it("Send struct array",async()=>{const d={types:{},domain:[],message:[{path:"spenders",type:"address[]",value:new n.TypedDataValueArray(1)},{path:"spenders.[]",type:"address",value:new n.TypedDataValueField((0,a.hexaStringToBuffer)("0x7ceb23fd6bc0add59e62ac25578270cff1b9f619"))},{path:"beneficiaries",type:"address[]",value:new n.TypedDataValueArray(0)}],clearSignContext:(0,c.Just)({type:"success",messageInfo:{displayName:"Permit2",filtersCount:2,signature:"sig"},tokens:{},filters:{"spenders.[]":{displayName:"Spender",path:"spenders.[]",signature:"sig",type:"raw"},"beneficiaries.[]":{displayName:"Beneficiary",path:"beneficiaries.[]",signature:"sig",type:"raw"}}})};e.sendCommand.mockResolvedValue((0,a.CommandResultFactory)({data:void 0})),await new l.ProvideEIP712ContextTask(e,d).run(),expect(e.sendCommand.mock.calls[0][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Activation})),expect(e.sendCommand.mock.calls[1][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.MessageInfo,displayName:"Permit2",filtersCount:2,signature:"sig"})),expect(e.sendCommand.mock.calls[2][0]).toStrictEqual(q(1)),expect(e.sendCommand.mock.calls[3][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Raw,discarded:!1,displayName:"Spender",signature:"sig"})),expect(e.sendCommand.mock.calls[4][0]).toStrictEqual(s(Uint8Array.from([0,20,124,235,35,253,107,192,173,213,158,98,172,37,87,130,112,207,241,185,246,25]))),expect(e.sendCommand.mock.calls[5][0]).toStrictEqual(q(0)),expect(e.sendCommand.mock.calls[6][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.DiscardedPath,path:"beneficiaries.[]"})),expect(e.sendCommand.mock.calls[7][0]).toStrictEqual(new t.SendEIP712FilteringCommand({type:t.Eip712FilterType.Raw,discarded:!0,displayName:"Beneficiary",signature:"sig"}))})});
|
|
2
|
+
//# sourceMappingURL=ProvideEIP712ContextTask.test.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../../src/internal/app-binder/task/ProvideEIP712ContextTask.test.ts"],
|
|
4
|
+
"sourcesContent": ["import { type TypedDataClearSignContextSuccess } from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n hexaStringToBuffer,\n UnknownDeviceExchangeError,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, Nothing } from \"purify-ts\";\n\nimport { ProvideTokenInformationCommand } from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\nimport {\n Eip712FilterType,\n SendEIP712FilteringCommand,\n} from \"@internal/app-binder/command/SendEIP712FilteringCommand\";\nimport {\n SendEIP712StructDefinitionCommand,\n StructDefinitionCommand,\n} from \"@internal/app-binder/command/SendEIP712StructDefinitionCommand\";\nimport {\n SendEIP712StructImplemCommand,\n StructImplemType,\n} from \"@internal/app-binder/command/SendEIP712StructImplemCommand\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport {\n type FieldType,\n PrimitiveType,\n StructType,\n TypedDataValueArray,\n TypedDataValueField,\n TypedDataValueRoot,\n} from \"@internal/typed-data/model/Types\";\n\nimport {\n ProvideEIP712ContextTask,\n type ProvideEIP712ContextTaskArgs,\n} from \"./ProvideEIP712ContextTask\";\n\ndescribe(\"ProvideEIP712ContextTask\", () => {\n const apiMock = makeDeviceActionInternalApiMock();\n\n const TEST_TYPES = {\n EIP712Domain: {\n name: new PrimitiveType(\"string\", \"string\", Nothing),\n chainId: new PrimitiveType(\"uint256\", \"uint\", Just(32)),\n verifyingContract: new PrimitiveType(\"address\", \"address\", Nothing),\n },\n PermitSingle: {\n details: new StructType(\"PermitDetails\"),\n spender: new PrimitiveType(\"address\", \"address\", Nothing),\n sigDeadline: new PrimitiveType(\"uint256\", \"uint\", Just(32)),\n },\n PermitDetails: {\n token: new PrimitiveType(\"address\", \"address\", Nothing),\n amount: new PrimitiveType(\"uint160\", \"uint\", Just(20)),\n expiration: new PrimitiveType(\"uint48\", \"uint\", Just(6)),\n nonce: new PrimitiveType(\"uint48\", \"uint\", Just(6)),\n },\n };\n const TEST_DOMAIN_VALUES = [\n {\n path: \"\",\n type: \"\",\n value: new TypedDataValueRoot(\"EIP712Domain\"),\n },\n {\n path: \"name\",\n type: \"string\",\n value: new TypedDataValueField(new TextEncoder().encode(\"Permit2\")),\n },\n {\n path: \"chainId\",\n type: \"uint256\",\n value: new TypedDataValueField(Uint8Array.from([137])),\n },\n {\n path: \"verifyingContract\",\n type: \"address\",\n value: new TypedDataValueField(\n hexaStringToBuffer(\"0x000000000022d473030f116ddee9f6b43ac78ba3\")!,\n ),\n },\n ];\n const TEST_MESSAGE_VALUES = [\n {\n path: \"\",\n type: \"\",\n value: new TypedDataValueRoot(\"PermitSingle\"),\n },\n {\n path: \"details.token\",\n type: \"address\",\n value: new TypedDataValueField(\n hexaStringToBuffer(\"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\")!,\n ),\n },\n {\n path: \"details.amount\",\n type: \"uint160\",\n value: new TypedDataValueField(Uint8Array.from([0x12])),\n },\n {\n path: \"details.expiration\",\n type: \"uint48\",\n value: new TypedDataValueField(Uint8Array.from([0x12])),\n },\n {\n path: \"details.nonce\",\n type: \"uint48\",\n value: new TypedDataValueField(Uint8Array.from([0x00])),\n },\n {\n path: \"spender\",\n type: \"address\",\n value: new TypedDataValueField(\n hexaStringToBuffer(\"0xec7be89e9d109e7e3fec59c222cf297125fefda2\")!,\n ),\n },\n {\n path: \"sigDeadline\",\n type: \"uint256\",\n value: new TypedDataValueField(Uint8Array.from([0x12])),\n },\n ];\n const TEST_CLEAR_SIGN_CONTEXT: TypedDataClearSignContextSuccess = {\n type: \"success\",\n messageInfo: {\n displayName: \"Permit2\",\n filtersCount: 4,\n signature:\n \"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3\",\n },\n tokens: {\n 0: \"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\",\n 255: \"payload-0x000000000022d473030f116ddee9f6b43ac78ba3\",\n },\n filters: {\n \"details.amount\": {\n displayName: \"Amount allowance\",\n path: \"details.amount\",\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n tokenIndex: 255,\n type: \"amount\",\n },\n \"details.expiration\": {\n displayName: \"Approval expire\",\n path: \"details.expiration\",\n signature:\n \"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b\",\n type: \"datetime\",\n },\n \"details.token\": {\n displayName: \"Amount allowance\",\n path: \"details.token\",\n signature:\n \"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733\",\n tokenIndex: 0,\n type: \"token\",\n },\n spender: {\n displayName: \"Approve to spender\",\n path: \"spender\",\n signature:\n \"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb\",\n type: \"raw\",\n },\n },\n };\n\n const ADDRESS = new PrimitiveType(\"address\", \"address\", Nothing);\n const STRING = new PrimitiveType(\"string\", \"string\", Nothing);\n const UINT256 = new PrimitiveType(\"uint256\", \"uint\", Just(32));\n const UINT160 = new PrimitiveType(\"uint160\", \"uint\", Just(20));\n const UINT48 = new PrimitiveType(\"uint48\", \"uint\", Just(6));\n const CUSTOM = (name: string) => new StructType(name);\n\n const sendStructDefName = (name: string) =>\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Name,\n name,\n });\n const sendStructDefField = (name: string, type: FieldType) =>\n new SendEIP712StructDefinitionCommand({\n command: StructDefinitionCommand.Field,\n name,\n type,\n });\n const sendStructImplRoot = (value: string) =>\n new SendEIP712StructImplemCommand({\n type: StructImplemType.ROOT,\n value,\n });\n const sendStructImplArray = (value: number) =>\n new SendEIP712StructImplemCommand({\n type: StructImplemType.ARRAY,\n value,\n });\n const sendStructImplField = (data: Uint8Array) =>\n new SendEIP712StructImplemCommand({\n type: StructImplemType.FIELD,\n value: {\n data,\n isLastChunk: true,\n },\n });\n\n beforeEach(() => {\n jest.resetAllMocks();\n });\n\n it(\"Send context with no clear signing context\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Nothing,\n };\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: undefined }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n expect(apiMock.sendCommand.mock.calls).toHaveLength(24);\n // Send Struct definitions\n expect(apiMock.sendCommand.mock.calls[0]![0]).toStrictEqual(\n sendStructDefName(\"EIP712Domain\"),\n );\n expect(apiMock.sendCommand.mock.calls[1]![0]).toStrictEqual(\n sendStructDefField(\"name\", STRING),\n );\n expect(apiMock.sendCommand.mock.calls[2]![0]).toStrictEqual(\n sendStructDefField(\"chainId\", UINT256),\n );\n expect(apiMock.sendCommand.mock.calls[3]![0]).toStrictEqual(\n sendStructDefField(\"verifyingContract\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[4]![0]).toStrictEqual(\n sendStructDefName(\"PermitDetails\"),\n );\n expect(apiMock.sendCommand.mock.calls[5]![0]).toStrictEqual(\n sendStructDefField(\"token\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[6]![0]).toStrictEqual(\n sendStructDefField(\"amount\", UINT160),\n );\n expect(apiMock.sendCommand.mock.calls[7]![0]).toStrictEqual(\n sendStructDefField(\"expiration\", UINT48),\n );\n expect(apiMock.sendCommand.mock.calls[8]![0]).toStrictEqual(\n sendStructDefField(\"nonce\", UINT48),\n );\n expect(apiMock.sendCommand.mock.calls[9]![0]).toStrictEqual(\n sendStructDefName(\"PermitSingle\"),\n );\n expect(apiMock.sendCommand.mock.calls[10]![0]).toStrictEqual(\n sendStructDefField(\"details\", CUSTOM(\"PermitDetails\")),\n );\n expect(apiMock.sendCommand.mock.calls[11]![0]).toStrictEqual(\n sendStructDefField(\"spender\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[12]![0]).toStrictEqual(\n sendStructDefField(\"sigDeadline\", UINT256),\n );\n // Send the domain values\n expect(apiMock.sendCommand.mock.calls[13]![0]).toStrictEqual(\n sendStructImplRoot(\"EIP712Domain\"),\n );\n expect(apiMock.sendCommand.mock.calls[14]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([0x00, 0x07, 0x50, 0x65, 0x72, 0x6d, 0x69, 0x74, 0x32]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[15]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x89])),\n );\n expect(apiMock.sendCommand.mock.calls[16]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0x00, 0x00, 0x00, 0x00, 0x00, 0x22, 0xd4, 0x73, 0x03,\n 0x0f, 0x11, 0x6d, 0xde, 0xe9, 0xf6, 0xb4, 0x3a, 0xc7, 0x8b, 0xa3,\n ]),\n ),\n );\n // Send the message values\n expect(apiMock.sendCommand.mock.calls[17]![0]).toStrictEqual(\n sendStructImplRoot(\"PermitSingle\"),\n );\n expect(apiMock.sendCommand.mock.calls[18]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0x7c, 0xeb, 0x23, 0xfd, 0x6b, 0xc0, 0xad, 0xd5, 0x9e,\n 0x62, 0xac, 0x25, 0x57, 0x82, 0x70, 0xcf, 0xf1, 0xb9, 0xf6, 0x19,\n ]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[19]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n expect(apiMock.sendCommand.mock.calls[20]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n expect(apiMock.sendCommand.mock.calls[21]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x00])),\n );\n expect(apiMock.sendCommand.mock.calls[22]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0xec, 0x7b, 0xe8, 0x9e, 0x9d, 0x10, 0x9e, 0x7e, 0x3f,\n 0xec, 0x59, 0xc2, 0x22, 0xcf, 0x29, 0x71, 0x25, 0xfe, 0xfd, 0xa2,\n ]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[23]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n });\n\n it(\"Send context with clear signing\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just(TEST_CLEAR_SIGN_CONTEXT),\n };\n apiMock.sendCommand\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: { tokenIndex: 4 } })) // First token provided\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: { tokenIndex: 5 } })); // Second token provided\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: undefined }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n expect(apiMock.sendCommand.mock.calls).toHaveLength(32);\n // Send Struct definitions\n expect(apiMock.sendCommand.mock.calls[0]![0]).toStrictEqual(\n sendStructDefName(\"EIP712Domain\"),\n );\n expect(apiMock.sendCommand.mock.calls[1]![0]).toStrictEqual(\n sendStructDefField(\"name\", STRING),\n );\n expect(apiMock.sendCommand.mock.calls[2]![0]).toStrictEqual(\n sendStructDefField(\"chainId\", UINT256),\n );\n expect(apiMock.sendCommand.mock.calls[3]![0]).toStrictEqual(\n sendStructDefField(\"verifyingContract\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[4]![0]).toStrictEqual(\n sendStructDefName(\"PermitDetails\"),\n );\n expect(apiMock.sendCommand.mock.calls[5]![0]).toStrictEqual(\n sendStructDefField(\"token\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[6]![0]).toStrictEqual(\n sendStructDefField(\"amount\", UINT160),\n );\n expect(apiMock.sendCommand.mock.calls[7]![0]).toStrictEqual(\n sendStructDefField(\"expiration\", UINT48),\n );\n expect(apiMock.sendCommand.mock.calls[8]![0]).toStrictEqual(\n sendStructDefField(\"nonce\", UINT48),\n );\n expect(apiMock.sendCommand.mock.calls[9]![0]).toStrictEqual(\n sendStructDefName(\"PermitSingle\"),\n );\n expect(apiMock.sendCommand.mock.calls[10]![0]).toStrictEqual(\n sendStructDefField(\"details\", CUSTOM(\"PermitDetails\")),\n );\n expect(apiMock.sendCommand.mock.calls[11]![0]).toStrictEqual(\n sendStructDefField(\"spender\", ADDRESS),\n );\n expect(apiMock.sendCommand.mock.calls[12]![0]).toStrictEqual(\n sendStructDefField(\"sigDeadline\", UINT256),\n );\n // Activate the filtering\n expect(apiMock.sendCommand.mock.calls[13]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({ type: Eip712FilterType.Activation }),\n );\n // Send the domain values\n expect(apiMock.sendCommand.mock.calls[14]![0]).toStrictEqual(\n sendStructImplRoot(\"EIP712Domain\"),\n );\n expect(apiMock.sendCommand.mock.calls[15]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([0x00, 0x07, 0x50, 0x65, 0x72, 0x6d, 0x69, 0x74, 0x32]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[16]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x89])),\n );\n expect(apiMock.sendCommand.mock.calls[17]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0x00, 0x00, 0x00, 0x00, 0x00, 0x22, 0xd4, 0x73, 0x03,\n 0x0f, 0x11, 0x6d, 0xde, 0xe9, 0xf6, 0xb4, 0x3a, 0xc7, 0x8b, 0xa3,\n ]),\n ),\n );\n // Send the message information filter\n expect(apiMock.sendCommand.mock.calls[18]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.MessageInfo,\n displayName: \"Permit2\",\n filtersCount: 4,\n signature:\n \"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3\",\n }),\n );\n // Send the message values with corresponding filters\n expect(apiMock.sendCommand.mock.calls[19]![0]).toStrictEqual(\n sendStructImplRoot(\"PermitSingle\"),\n );\n expect(apiMock.sendCommand.mock.calls[20]![0]).toStrictEqual(\n new ProvideTokenInformationCommand({\n payload: \"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[21]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded: false,\n tokenIndex: 4,\n signature:\n \"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[22]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0x7c, 0xeb, 0x23, 0xfd, 0x6b, 0xc0, 0xad, 0xd5, 0x9e,\n 0x62, 0xac, 0x25, 0x57, 0x82, 0x70, 0xcf, 0xf1, 0xb9, 0xf6, 0x19,\n ]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[23]![0]).toStrictEqual(\n new ProvideTokenInformationCommand({\n payload: \"payload-0x000000000022d473030f116ddee9f6b43ac78ba3\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[24]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded: false,\n displayName: \"Amount allowance\",\n tokenIndex: 255,\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[25]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n expect(apiMock.sendCommand.mock.calls[26]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Datetime,\n discarded: false,\n displayName: \"Approval expire\",\n signature:\n \"3044022056b3381e4540629ad73bc434ec49d80523234b82f62340fbb77157fb0eb21a680220459fe9cf6ca309f9c7dfc6d4711fea1848dba661563c57f77b3c2dc480b3a63b\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[27]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n expect(apiMock.sendCommand.mock.calls[28]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x00])),\n );\n expect(apiMock.sendCommand.mock.calls[29]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Raw,\n discarded: false,\n displayName: \"Approve to spender\",\n signature:\n \"3044022033e5713d9cb9bc375b56a9fb53b736c81ea3c4ac5cfb2d3ca7f8b8f0558fe2430220543ca4fef6d6f725f29e343f167fe9dd582aa856ecb5797259050eb990a1befb\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[30]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0xec, 0x7b, 0xe8, 0x9e, 0x9d, 0x10, 0x9e, 0x7e, 0x3f,\n 0xec, 0x59, 0xc2, 0x22, 0xcf, 0x29, 0x71, 0x25, 0xfe, 0xfd, 0xa2,\n ]),\n ),\n );\n expect(apiMock.sendCommand.mock.calls[31]![0]).toStrictEqual(\n sendStructImplField(Uint8Array.from([0x00, 0x01, 0x12])),\n );\n });\n\n it(\"Both tokens unavailable\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just({\n type: \"success\",\n messageInfo: TEST_CLEAR_SIGN_CONTEXT.messageInfo,\n filters: TEST_CLEAR_SIGN_CONTEXT.filters,\n tokens: {},\n }),\n };\n\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: undefined }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n expect(apiMock.sendCommand).not.toHaveBeenCalledWith(\n new ProvideTokenInformationCommand({\n payload: \"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\",\n }),\n );\n expect(apiMock.sendCommand).not.toHaveBeenCalledWith(\n new ProvideTokenInformationCommand({\n payload: \"payload-0x000000000022d473030f116ddee9f6b43ac78ba3\",\n }),\n );\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded: false,\n tokenIndex: 0,\n signature:\n \"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733\",\n }),\n );\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded: false,\n displayName: \"Amount allowance\",\n tokenIndex: 1,\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n }),\n );\n });\n\n it(\"First token unavailable\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just({\n type: \"success\",\n messageInfo: TEST_CLEAR_SIGN_CONTEXT.messageInfo,\n filters: TEST_CLEAR_SIGN_CONTEXT.filters,\n tokens: { 255: \"payload-0x000000000022d473030f116ddee9f6b43ac78ba3\" },\n }),\n };\n\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: { tokenIndex: 4 } }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded: false,\n tokenIndex: 0,\n signature:\n \"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733\",\n }),\n );\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded: false,\n displayName: \"Amount allowance\",\n tokenIndex: 255,\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n }),\n );\n });\n\n it(\"Second token unavailable\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just({\n type: \"success\",\n messageInfo: TEST_CLEAR_SIGN_CONTEXT.messageInfo,\n filters: TEST_CLEAR_SIGN_CONTEXT.filters,\n tokens: { 0: \"payload-0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\" },\n }),\n };\n\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: { tokenIndex: 4 } }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Token,\n discarded: false,\n tokenIndex: 4,\n signature:\n \"3044022075103b38995e031d1ebbfe38ac6603bec32854b5146a664e49b4cc4f460c1da6022029f4b0fd1f3b7995ffff1627d4b57f27888a2dcc9b3a4e85c37c67571092c733\",\n }),\n );\n expect(apiMock.sendCommand).toHaveBeenCalledWith(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Amount,\n discarded: false,\n displayName: \"Amount allowance\",\n tokenIndex: 0,\n signature:\n \"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3\",\n }),\n );\n });\n\n it(\"Error when providing tokens\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just(TEST_CLEAR_SIGN_CONTEXT),\n };\n apiMock.sendCommand.mockResolvedValueOnce(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError(\"error\"),\n }),\n );\n // WHEN\n const promise = new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n await expect(promise).resolves.toStrictEqual(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError(\"error\"),\n }),\n );\n });\n\n it(\"Error when sending struct definitions\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just(TEST_CLEAR_SIGN_CONTEXT),\n };\n apiMock.sendCommand\n .mockResolvedValueOnce(CommandResultFactory({ data: { tokenIndex: 4 } }))\n .mockResolvedValueOnce(CommandResultFactory({ data: { tokenIndex: 5 } }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError(\"error\"),\n }),\n );\n // WHEN\n const promise = new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n await expect(promise).resolves.toStrictEqual(\n CommandResultFactory({ error: new UnknownDeviceExchangeError(\"error\") }),\n );\n });\n\n it(\"Error when sending struct implementations\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Nothing,\n };\n // WHEN\n apiMock.sendCommand\n // Struct definitions\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n .mockResolvedValueOnce(CommandResultFactory({ data: undefined }))\n // Struct implementations\n .mockResolvedValueOnce(\n CommandResultFactory({\n error: new UnknownDeviceExchangeError(\"error\"),\n }),\n )\n .mockResolvedValue(CommandResultFactory({ data: undefined }));\n const promise = new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n await expect(promise).resolves.toStrictEqual(\n CommandResultFactory({ error: new UnknownDeviceExchangeError(\"error\") }),\n );\n });\n\n it(\"Send struct array\", async () => {\n // GIVEN\n const args: ProvideEIP712ContextTaskArgs = {\n types: {},\n domain: [],\n message: [\n // Array containing an element\n {\n path: \"spenders\",\n type: \"address[]\",\n value: new TypedDataValueArray(1),\n },\n {\n path: \"spenders.[]\",\n type: \"address\",\n value: new TypedDataValueField(\n hexaStringToBuffer(\"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\")!,\n ),\n },\n // Empty array\n {\n path: \"beneficiaries\",\n type: \"address[]\",\n value: new TypedDataValueArray(0),\n },\n ],\n clearSignContext: Just({\n type: \"success\",\n messageInfo: {\n displayName: \"Permit2\",\n filtersCount: 2,\n signature: \"sig\",\n },\n tokens: {},\n filters: {\n \"spenders.[]\": {\n displayName: \"Spender\",\n path: \"spenders.[]\",\n signature: \"sig\",\n type: \"raw\",\n },\n \"beneficiaries.[]\": {\n displayName: \"Beneficiary\",\n path: \"beneficiaries.[]\",\n signature: \"sig\",\n type: \"raw\",\n },\n },\n }),\n };\n // WHEN\n apiMock.sendCommand.mockResolvedValue(\n CommandResultFactory({ data: undefined }),\n );\n await new ProvideEIP712ContextTask(apiMock, args).run();\n\n // THEN\n // Activate the filtering\n expect(apiMock.sendCommand.mock.calls[0]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({ type: Eip712FilterType.Activation }),\n );\n // Send the message information filter\n expect(apiMock.sendCommand.mock.calls[1]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.MessageInfo,\n displayName: \"Permit2\",\n filtersCount: 2,\n signature: \"sig\",\n }),\n );\n // Send first array containing 1 element\n expect(apiMock.sendCommand.mock.calls[2]![0]).toStrictEqual(\n sendStructImplArray(1),\n );\n expect(apiMock.sendCommand.mock.calls[3]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Raw,\n discarded: false,\n displayName: \"Spender\",\n signature: \"sig\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[4]![0]).toStrictEqual(\n sendStructImplField(\n Uint8Array.from([\n 0x00, 0x14, 0x7c, 0xeb, 0x23, 0xfd, 0x6b, 0xc0, 0xad, 0xd5, 0x9e,\n 0x62, 0xac, 0x25, 0x57, 0x82, 0x70, 0xcf, 0xf1, 0xb9, 0xf6, 0x19,\n ]),\n ),\n );\n // Send second empty array, with discarded filter\n expect(apiMock.sendCommand.mock.calls[5]![0]).toStrictEqual(\n sendStructImplArray(0),\n );\n expect(apiMock.sendCommand.mock.calls[6]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.DiscardedPath,\n path: \"beneficiaries.[]\",\n }),\n );\n expect(apiMock.sendCommand.mock.calls[7]![0]).toStrictEqual(\n new SendEIP712FilteringCommand({\n type: Eip712FilterType.Raw,\n discarded: true,\n displayName: \"Beneficiary\",\n signature: \"sig\",\n }),\n );\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["import_device_management_kit", "import_purify_ts", "import_ProvideTokenInformationCommand", "import_SendEIP712FilteringCommand", "import_SendEIP712StructDefinitionCommand", "import_SendEIP712StructImplemCommand", "import_makeInternalApi", "import_Types", "import_ProvideEIP712ContextTask", "apiMock", "TEST_TYPES", "TEST_DOMAIN_VALUES", "TEST_MESSAGE_VALUES", "TEST_CLEAR_SIGN_CONTEXT", "ADDRESS", "STRING", "UINT256", "UINT160", "UINT48", "CUSTOM", "name", "sendStructDefName", "sendStructDefField", "type", "sendStructImplRoot", "value", "sendStructImplArray", "sendStructImplField", "data", "args", "promise"]
|
|
7
|
+
}
|
|
@@ -1,112 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
exports.ProvideTransactionContextTask = exports.ProvideTransactionContextTaskError = void 0;
|
|
4
|
-
const context_module_1 = require("@ledgerhq/context-module");
|
|
5
|
-
const device_management_kit_1 = require("@ledgerhq/device-management-kit");
|
|
6
|
-
const AppBuilderError_js_1 = require("@ledgerhq/device-management-kit/src/api/apdu/utils/AppBuilderError.js");
|
|
7
|
-
const purify_ts_1 = require("purify-ts");
|
|
8
|
-
const ProvideDomainNameCommand_1 = require("../../app-binder/command/ProvideDomainNameCommand");
|
|
9
|
-
const ProvideNFTInformationCommand_1 = require("../../app-binder/command/ProvideNFTInformationCommand");
|
|
10
|
-
const ProvideTokenInformationCommand_1 = require("../../app-binder/command/ProvideTokenInformationCommand");
|
|
11
|
-
const SetExternalPluginCommand_1 = require("../../app-binder/command/SetExternalPluginCommand");
|
|
12
|
-
const SetPluginCommand_1 = require("../../app-binder/command/SetPluginCommand");
|
|
13
|
-
/**
|
|
14
|
-
* Temporary error type to be used in the `ProvideTransactionContextTask` in order to not forget to handle the error cases.
|
|
15
|
-
*/
|
|
16
|
-
class ProvideTransactionContextTaskError {
|
|
17
|
-
_tag = "ProvideTransactionContextTaskError";
|
|
18
|
-
originalError;
|
|
19
|
-
constructor(message) {
|
|
20
|
-
this.originalError = new Error(message ?? "Unknow error in ProvideTransactionContextTaskError");
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
exports.ProvideTransactionContextTaskError = ProvideTransactionContextTaskError;
|
|
24
|
-
/**
|
|
25
|
-
* This task is responsible for providing the transaction context to the device.
|
|
26
|
-
* It will send the 5 necessary commands:
|
|
27
|
-
* - `SetPluginCommand` (single command)
|
|
28
|
-
* - `SetExternalPluginCommand` (single command)
|
|
29
|
-
* - `ProvideNFTInformationCommand` (single command)
|
|
30
|
-
* - `ProvideTokenInformationCommand` (single command)
|
|
31
|
-
* - `ProvideDomainNameCommand` (__mulpitle commands__)
|
|
32
|
-
*
|
|
33
|
-
* The method `provideDomainNameTask` is dedicated to send the multiple `ProvideDomainNameCommand`.
|
|
34
|
-
*/
|
|
35
|
-
class ProvideTransactionContextTask {
|
|
36
|
-
api;
|
|
37
|
-
args;
|
|
38
|
-
constructor(api, args) {
|
|
39
|
-
this.api = api;
|
|
40
|
-
this.args = args;
|
|
41
|
-
}
|
|
42
|
-
async run() {
|
|
43
|
-
for (const context of this.args.clearSignContexts) {
|
|
44
|
-
const res = await this.provideContext(context);
|
|
45
|
-
if (!(0, device_management_kit_1.isSuccessCommandResult)(res)) {
|
|
46
|
-
return (0, purify_ts_1.Just)(res);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
return purify_ts_1.Nothing;
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* This method will send a command according to the clear sign context type and return the command result if only one command
|
|
53
|
-
* is sent, otherwise it will return the result of the `provideDomainNameTask`.
|
|
54
|
-
*
|
|
55
|
-
* @param context The clear sign context to provide.
|
|
56
|
-
* @returns A promise that resolves when the command is sent or result of the `provideDomainNameTask`.
|
|
57
|
-
*/
|
|
58
|
-
async provideContext({ type, payload, }) {
|
|
59
|
-
switch (type) {
|
|
60
|
-
case context_module_1.ClearSignContextType.PLUGIN: {
|
|
61
|
-
return await this.api.sendCommand(new SetPluginCommand_1.SetPluginCommand({ payload }));
|
|
62
|
-
}
|
|
63
|
-
case context_module_1.ClearSignContextType.EXTERNAL_PLUGIN: {
|
|
64
|
-
return await this.api.sendCommand(new SetExternalPluginCommand_1.SetExternalPluginCommand({ payload }));
|
|
65
|
-
}
|
|
66
|
-
case context_module_1.ClearSignContextType.NFT: {
|
|
67
|
-
return await this.api.sendCommand(new ProvideNFTInformationCommand_1.ProvideNFTInformationCommand({ payload }));
|
|
68
|
-
}
|
|
69
|
-
case context_module_1.ClearSignContextType.TOKEN: {
|
|
70
|
-
return await this.api.sendCommand(new ProvideTokenInformationCommand_1.ProvideTokenInformationCommand({ payload }));
|
|
71
|
-
}
|
|
72
|
-
case context_module_1.ClearSignContextType.DOMAIN_NAME: {
|
|
73
|
-
return await this.provideDomainNameTask(payload);
|
|
74
|
-
}
|
|
75
|
-
default: {
|
|
76
|
-
const uncoveredType = type;
|
|
77
|
-
throw new ProvideTransactionContextTaskError(`The context type [${uncoveredType}] is not covered`);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
/**
|
|
82
|
-
* This method is responsible for chunking the domain name if necessary and sending `ProvideDomainNameCommand` to the device.
|
|
83
|
-
* It will return the result of the last command sent if all the commands are successful, otherwise it will return the first
|
|
84
|
-
* error result encountered.
|
|
85
|
-
*
|
|
86
|
-
* @param domainName Hexa representation of the domain name.
|
|
87
|
-
* @returns A promise that resolves when the command is sent.
|
|
88
|
-
*/
|
|
89
|
-
async provideDomainNameTask(domainName) {
|
|
90
|
-
const buffer = (0, device_management_kit_1.hexaStringToBuffer)(domainName);
|
|
91
|
-
if (buffer === null || buffer.length === 0) {
|
|
92
|
-
throw new AppBuilderError_js_1.HexaStringEncodeError("provideDomainNameTask");
|
|
93
|
-
}
|
|
94
|
-
const data = new device_management_kit_1.ByteArrayBuilder(buffer.length + ProvideDomainNameCommand_1.PAYLOAD_LENGTH_BYTES)
|
|
95
|
-
.add16BitUIntToData(buffer.length)
|
|
96
|
-
.addBufferToData(buffer)
|
|
97
|
-
.build();
|
|
98
|
-
let result = (0, device_management_kit_1.CommandResultFactory)({ data: undefined });
|
|
99
|
-
for (let i = 0; i < data.length; i += device_management_kit_1.APDU_MAX_PAYLOAD) {
|
|
100
|
-
result = await this.api.sendCommand(new ProvideDomainNameCommand_1.ProvideDomainNameCommand({
|
|
101
|
-
data: data.slice(i, i + device_management_kit_1.APDU_MAX_PAYLOAD),
|
|
102
|
-
isFirstChunk: i === 0,
|
|
103
|
-
}));
|
|
104
|
-
if (!(0, device_management_kit_1.isSuccessCommandResult)(result)) {
|
|
105
|
-
return result;
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
return result;
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
exports.ProvideTransactionContextTask = ProvideTransactionContextTask;
|
|
112
|
-
//# sourceMappingURL=ProvideTransactionContextTask.js.map
|
|
1
|
+
"use strict";var m=Object.defineProperty;var P=Object.getOwnPropertyDescriptor;var E=Object.getOwnPropertyNames;var l=Object.prototype.hasOwnProperty;var v=(n,e)=>{for(var r in e)m(n,r,{get:e[r],enumerable:!0})},x=(n,e,r,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of E(e))!l.call(n,s)&&s!==r&&m(n,s,{get:()=>e[s],enumerable:!(a=P(e,s))||a.enumerable});return n};var S=n=>x(m({},"__esModule",{value:!0}),n);var f={};v(f,{ProvideTransactionContextTask:()=>N});module.exports=S(f);var o=require("@ledgerhq/context-module"),t=require("@ledgerhq/device-management-kit"),i=require("purify-ts"),d=require("../../app-binder/command/ProvideNFTInformationCommand"),C=require("../../app-binder/command/ProvideTokenInformationCommand"),c=require("../../app-binder/command/ProvideTrustedNameCommand"),u=require("../../app-binder/command/SetExternalPluginCommand"),p=require("../../app-binder/command/SetPluginCommand"),T=require("./SendPayloadInChunksTask");class N{constructor(e,r){this.api=e;this.args=r}async run(){for(const e of this.args.clearSignContexts){const r=await this.provideContext(e);if(!(0,t.isSuccessCommandResult)(r))return(0,i.Just)(r)}return i.Nothing}async provideContext({type:e,payload:r}){switch(e){case o.ClearSignContextType.PLUGIN:return await this.api.sendCommand(new p.SetPluginCommand({payload:r}));case o.ClearSignContextType.EXTERNAL_PLUGIN:return await this.api.sendCommand(new u.SetExternalPluginCommand({payload:r}));case o.ClearSignContextType.NFT:return await this.api.sendCommand(new d.ProvideNFTInformationCommand({payload:r}));case o.ClearSignContextType.TOKEN:return await this.api.sendCommand(new C.ProvideTokenInformationCommand({payload:r}));case o.ClearSignContextType.TRUSTED_NAME:return new T.SendPayloadInChunksTask(this.api,{payload:r,commandFactory:a=>new c.ProvideTrustedNameCommand({data:a.chunkedData,isFirstChunk:a.isFirstChunk})}).run();case o.ClearSignContextType.ENUM:case o.ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION:case o.ClearSignContextType.TRANSACTION_INFO:return(0,t.CommandResultFactory)({error:new t.InvalidStatusWordError("The context type [EXTERNAL_PLUGIN] is not valid here")});default:{const a=e;return(0,t.CommandResultFactory)({error:new t.InvalidStatusWordError(`The context type [${a}] is not covered`)})}}}}0&&(module.exports={ProvideTransactionContextTask});
|
|
2
|
+
//# sourceMappingURL=ProvideTransactionContextTask.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../../src/internal/app-binder/task/ProvideTransactionContextTask.ts"],
|
|
4
|
+
"sourcesContent": ["import {\n type ClearSignContextSuccess,\n ClearSignContextType,\n} from \"@ledgerhq/context-module\";\nimport {\n type CommandErrorResult,\n type CommandResult,\n CommandResultFactory,\n type InternalApi,\n InvalidStatusWordError,\n isSuccessCommandResult,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, type Maybe, Nothing } from \"purify-ts\";\n\nimport {\n ProvideNFTInformationCommand,\n type ProvideNFTInformationCommandErrorCodes,\n} from \"@internal/app-binder/command/ProvideNFTInformationCommand\";\nimport {\n ProvideTokenInformationCommand,\n type ProvideTokenInformationCommandResponse,\n} from \"@internal/app-binder/command/ProvideTokenInformationCommand\";\nimport { ProvideTrustedNameCommand } from \"@internal/app-binder/command/ProvideTrustedNameCommand\";\nimport {\n SetExternalPluginCommand,\n type SetExternalPluginCommandErrorCodes,\n} from \"@internal/app-binder/command/SetExternalPluginCommand\";\nimport {\n SetPluginCommand,\n type SetPluginCommandErrorCodes,\n} from \"@internal/app-binder/command/SetPluginCommand\";\n\nimport { SendPayloadInChunksTask } from \"./SendPayloadInChunksTask\";\n\nexport type ProvideTransactionContextTaskArgs = {\n /**\n * The valid clear sign contexts offerred by the `BuildTrancationContextTask`.\n */\n clearSignContexts: ClearSignContextSuccess[];\n};\n\nexport type ProvideTransactionContextTaskErrorCodes =\n | void\n | SetExternalPluginCommandErrorCodes\n | SetPluginCommandErrorCodes\n | ProvideNFTInformationCommandErrorCodes;\n\n/**\n * This task is responsible for providing the transaction context to the device.\n * It will send the 5 necessary commands:\n * - `SetPluginCommand` (single command)\n * - `SetExternalPluginCommand` (single command)\n * - `ProvideNFTInformationCommand` (single command)\n * - `ProvideTokenInformationCommand` (single command)\n * - `ProvideTrustedNameCommand` (__mulpitle commands__)\n *\n * The method `provideTrustedNameTask` is dedicated to send the multiple `ProvideTrustedNameCommand`.\n */\nexport class ProvideTransactionContextTask {\n constructor(\n private api: InternalApi,\n private args: ProvideTransactionContextTaskArgs,\n ) {}\n\n async run(): Promise<\n Maybe<CommandErrorResult<ProvideTransactionContextTaskErrorCodes>>\n > {\n for (const context of this.args.clearSignContexts) {\n const res = await this.provideContext(context);\n if (!isSuccessCommandResult(res)) {\n return Just(res);\n }\n }\n return Nothing;\n }\n\n /**\n * This method will send a command according to the clear sign context type and return the command result if only one command\n * is sent, otherwise it will return the result of the `provideTrustedNameTask`.\n *\n * @param context The clear sign context to provide.\n * @returns A promise that resolves when the command is sent or result of the `provideTrustedNameTask`.\n */\n async provideContext({\n type,\n payload,\n }: ClearSignContextSuccess): Promise<\n CommandResult<\n void | ProvideTokenInformationCommandResponse,\n ProvideTransactionContextTaskErrorCodes\n >\n > {\n switch (type) {\n case ClearSignContextType.PLUGIN: {\n return await this.api.sendCommand(new SetPluginCommand({ payload }));\n }\n case ClearSignContextType.EXTERNAL_PLUGIN: {\n return await this.api.sendCommand(\n new SetExternalPluginCommand({ payload }),\n );\n }\n case ClearSignContextType.NFT: {\n return await this.api.sendCommand(\n new ProvideNFTInformationCommand({ payload }),\n );\n }\n case ClearSignContextType.TOKEN: {\n return await this.api.sendCommand(\n new ProvideTokenInformationCommand({ payload }),\n );\n }\n case ClearSignContextType.TRUSTED_NAME: {\n return new SendPayloadInChunksTask(this.api, {\n payload,\n commandFactory: (args) =>\n new ProvideTrustedNameCommand({\n data: args.chunkedData,\n isFirstChunk: args.isFirstChunk,\n }),\n }).run();\n }\n case ClearSignContextType.ENUM:\n case ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION:\n case ClearSignContextType.TRANSACTION_INFO: {\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n \"The context type [EXTERNAL_PLUGIN] is not valid here\",\n ),\n });\n }\n default: {\n const uncoveredType: never = type;\n return CommandResultFactory({\n error: new InvalidStatusWordError(\n `The context type [${uncoveredType}] is not covered`,\n ),\n });\n }\n }\n }\n}\n"],
|
|
5
|
+
"mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,mCAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAGO,oCACPC,EAOO,2CACPC,EAA0C,qBAE1CC,EAGO,qEACPC,EAGO,uEACPC,EAA0C,kEAC1CC,EAGO,iEACPC,EAGO,yDAEPC,EAAwC,qCA0BjC,MAAMV,CAA8B,CACzC,YACUW,EACAC,EACR,CAFQ,SAAAD,EACA,UAAAC,CACP,CAEH,MAAM,KAEJ,CACA,UAAWC,KAAW,KAAK,KAAK,kBAAmB,CACjD,MAAMC,EAAM,MAAM,KAAK,eAAeD,CAAO,EAC7C,GAAI,IAAC,0BAAuBC,CAAG,EAC7B,SAAO,QAAKA,CAAG,CAEnB,CACA,OAAO,SACT,CASA,MAAM,eAAe,CACnB,KAAAC,EACA,QAAAC,CACF,EAKE,CACA,OAAQD,EAAM,CACZ,KAAK,uBAAqB,OACxB,OAAO,MAAM,KAAK,IAAI,YAAY,IAAI,mBAAiB,CAAE,QAAAC,CAAQ,CAAC,CAAC,EAErE,KAAK,uBAAqB,gBACxB,OAAO,MAAM,KAAK,IAAI,YACpB,IAAI,2BAAyB,CAAE,QAAAA,CAAQ,CAAC,CAC1C,EAEF,KAAK,uBAAqB,IACxB,OAAO,MAAM,KAAK,IAAI,YACpB,IAAI,+BAA6B,CAAE,QAAAA,CAAQ,CAAC,CAC9C,EAEF,KAAK,uBAAqB,MACxB,OAAO,MAAM,KAAK,IAAI,YACpB,IAAI,iCAA+B,CAAE,QAAAA,CAAQ,CAAC,CAChD,EAEF,KAAK,uBAAqB,aACxB,OAAO,IAAI,0BAAwB,KAAK,IAAK,CAC3C,QAAAA,EACA,eAAiBJ,GACf,IAAI,4BAA0B,CAC5B,KAAMA,EAAK,YACX,aAAcA,EAAK,YACrB,CAAC,CACL,CAAC,EAAE,IAAI,EAET,KAAK,uBAAqB,KAC1B,KAAK,uBAAqB,8BAC1B,KAAK,uBAAqB,iBACxB,SAAO,wBAAqB,CAC1B,MAAO,IAAI,yBACT,sDACF,CACF,CAAC,EAEH,QAAS,CACP,MAAMK,EAAuBF,EAC7B,SAAO,wBAAqB,CAC1B,MAAO,IAAI,yBACT,qBAAqBE,CAAa,kBACpC,CACF,CAAC,CACH,CACF,CACF,CACF",
|
|
6
|
+
"names": ["ProvideTransactionContextTask_exports", "__export", "ProvideTransactionContextTask", "__toCommonJS", "import_context_module", "import_device_management_kit", "import_purify_ts", "import_ProvideNFTInformationCommand", "import_ProvideTokenInformationCommand", "import_ProvideTrustedNameCommand", "import_SetExternalPluginCommand", "import_SetPluginCommand", "import_SendPayloadInChunksTask", "api", "args", "context", "res", "type", "payload", "uncoveredType"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";var n=require("@ledgerhq/context-module"),a=require("@ledgerhq/device-management-kit"),d=require("../../app-binder/command/ProvideNFTInformationCommand"),i=require("../../app-binder/command/ProvideTokenInformationCommand"),c=require("../../app-binder/command/SetExternalPluginCommand"),m=require("../../app-binder/command/SetPluginCommand"),l=require("../../app-binder/device-action/__test-utils__/makeInternalApi"),r=require("./ProvideTransactionContextTask");describe("ProvideTransactionContextTask",()=>{const e=(0,l.makeDeviceActionInternalApiMock)(),p=(0,a.CommandResultFactory)({data:void 0}),s=(0,a.CommandResultFactory)({data:void 0,error:{}});beforeEach(()=>{jest.resetAllMocks()}),describe("run",()=>{const o={clearSignContexts:[{type:n.ClearSignContextType.PLUGIN,payload:"706c7567696e"},{type:n.ClearSignContextType.EXTERNAL_PLUGIN,payload:"65787465726e616c506c7567696e"},{type:n.ClearSignContextType.NFT,payload:"6e6674"},{type:n.ClearSignContextType.TOKEN,payload:"746f6b656e"}]};afterEach(()=>{jest.restoreAllMocks()}),it("should send relative commands when receiving ClearSignContexts of type not trustedName",async()=>{e.sendCommand.mockResolvedValue(p),await new r.ProvideTransactionContextTask(e,o).run(),expect(e.sendCommand).toHaveBeenCalledTimes(4),expect(e.sendCommand).toHaveBeenNthCalledWith(o.clearSignContexts.findIndex(t=>t.type===n.ClearSignContextType.PLUGIN)+1,expect.objectContaining(new m.SetPluginCommand({payload:"706c7567696e"}))),expect(e.sendCommand).toHaveBeenNthCalledWith(o.clearSignContexts.findIndex(t=>t.type===n.ClearSignContextType.EXTERNAL_PLUGIN)+1,expect.objectContaining(new c.SetExternalPluginCommand({payload:"65787465726e616c506c7567696e"}))),expect(e.sendCommand).toHaveBeenNthCalledWith(o.clearSignContexts.findIndex(t=>t.type===n.ClearSignContextType.NFT)+1,expect.objectContaining(new d.ProvideNFTInformationCommand({payload:"6e6674"}))),expect(e.sendCommand).toHaveBeenNthCalledWith(o.clearSignContexts.findIndex(t=>t.type===n.ClearSignContextType.TOKEN)+1,expect.objectContaining(new i.ProvideTokenInformationCommand({payload:"746f6b656e"})))}),it("should return the command error result and stop when the command fails",async()=>{e.sendCommand.mockReset(),e.sendCommand.mockResolvedValueOnce(s);const t=await new r.ProvideTransactionContextTask(e,o).run();expect(e.sendCommand).toHaveBeenCalledTimes(1),expect(t.isJust()).toBe(!0),expect(t.extract()).toStrictEqual(s)})})});
|
|
2
|
+
//# sourceMappingURL=ProvideTransactionContextTask.test.js.map
|