@ledgerhq/device-signer-kit-ethereum 1.0.0 → 1.2.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 +173 -382
- 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/TransactionOptions.js +2 -3
- package/lib/cjs/api/model/TransactionOptions.js.map +7 -1
- package/lib/cjs/api/model/TransactionType.js +2 -0
- package/lib/cjs/api/model/TransactionType.js.map +7 -0
- 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/command/utils/ethAppErrors.js +2 -0
- package/lib/cjs/internal/app-binder/command/utils/ethAppErrors.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/utils/ethAppErrors.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/utils/ethAppErrors.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/constant/plugins.js +2 -0
- package/lib/cjs/internal/app-binder/constant/plugins.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/EthersRawTransactionMapper.js +2 -0
- package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.js.map +7 -0
- package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js +2 -0
- package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.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/TransactionOptions.js +1 -2
- package/lib/esm/api/model/TransactionOptions.js.map +7 -1
- package/lib/esm/api/model/TransactionType.js +2 -0
- package/lib/esm/api/model/TransactionType.js.map +7 -0
- 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/command/utils/ethAppErrors.js +2 -0
- package/lib/esm/internal/app-binder/command/utils/ethAppErrors.js.map +7 -0
- package/lib/esm/internal/app-binder/command/utils/ethAppErrors.test.js +2 -0
- package/lib/esm/internal/app-binder/command/utils/ethAppErrors.test.js.map +7 -0
- package/lib/esm/internal/app-binder/constant/plugins.js +2 -0
- package/lib/esm/internal/app-binder/constant/plugins.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/EthersRawTransactionMapper.js +2 -0
- package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.js.map +7 -0
- package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js +2 -0
- package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.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 +14 -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/{esm → types}/api/app-binder/GetAddressDeviceActionTypes.d.ts +3 -2
- package/lib/types/api/app-binder/GetAddressDeviceActionTypes.d.ts.map +1 -0
- package/lib/types/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts +12 -0
- 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 +8 -7
- package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +1 -0
- package/lib/{cjs → types}/api/index.d.ts +4 -4
- package/lib/types/api/index.d.ts.map +1 -0
- 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/TransactionType.d.ts +11 -0
- package/lib/types/api/model/TransactionType.d.ts.map +1 -0
- package/lib/types/internal/DefaultSignerEth.d.ts +25 -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 +7 -6
- 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/types/internal/app-binder/command/GetAddressCommand.d.ts +11 -0
- 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/types/internal/app-binder/command/GetChallengeCommand.d.ts +12 -0
- 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 +20 -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/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +16 -0
- 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 +5 -3
- 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 +20 -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 +20 -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 +21 -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/{esm → types}/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +13 -3
- 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 +5 -3
- 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/{cjs → types}/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts +5 -3
- 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/types/internal/app-binder/command/SetExternalPluginCommand.d.ts +15 -0
- 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/types/internal/app-binder/command/SetPluginCommand.d.ts +16 -0
- 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/{cjs → types}/internal/app-binder/command/SignEIP712Command.d.ts +5 -3
- 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/{esm → types}/internal/app-binder/command/SignPersonalMessageCommand.d.ts +6 -4
- 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/{cjs → types}/internal/app-binder/command/SignTransactionCommand.d.ts +5 -3
- 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 +14 -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 +25 -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/types/internal/app-binder/command/utils/ethAppErrors.d.ts +8 -0
- package/lib/types/internal/app-binder/command/utils/ethAppErrors.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/utils/ethAppErrors.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/utils/ethAppErrors.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/constant/plugins.d.ts +2 -0
- package/lib/types/internal/app-binder/constant/plugins.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/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +39 -0
- 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 +4 -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__/setupOpenAppDAMock.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionStates.d.ts +15 -0
- 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 +35 -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/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts +37 -0
- 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 +80 -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 +17 -0
- package/lib/types/internal/app-binder/task/SendCommandInChunksTask.d.ts.map +1 -0
- package/lib/{esm → types}/internal/app-binder/task/SendEIP712StructImplemTask.d.ts +2 -1
- package/lib/types/internal/app-binder/task/SendEIP712StructImplemTask.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 +15 -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/types/internal/app-binder/task/SendSignPersonalMessageTask.d.ts +15 -0
- 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 +21 -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/types/internal/transaction/service/mapper/EthersRawTransactionMapper.d.ts +7 -0
- package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.d.ts.map +1 -0
- package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.test.d.ts +2 -0
- package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.test.d.ts.map +1 -0
- package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts +6 -0
- package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts.map +1 -0
- package/lib/{esm → types}/internal/transaction/service/mapper/TransactionMapperService.d.ts +1 -2
- package/lib/types/internal/transaction/service/mapper/TransactionMapperService.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/{cjs → types}/internal/transaction/use-case/SignTransactionUseCase.d.ts +1 -2
- package/lib/types/internal/transaction/use-case/SignTransactionUseCase.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 +30 -34
- 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 +0 -9
- 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/index.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/api/model/Transaction.js +0 -3
- package/lib/cjs/api/model/Transaction.js.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 +0 -9
- 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 +0 -15
- 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 +0 -41
- 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.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 +0 -18
- package/lib/cjs/internal/app-binder/command/SetPluginCommand.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.d.ts.map +0 -1
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.d.ts +0 -21
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +0 -1
- 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/SignPersonalMessage/SignPersonalMessageDeviceAction.js +0 -161
- package/lib/cjs/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js.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 +0 -31
- 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 +0 -12
- 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/SendEIP712StructImplemTask.d.ts +0 -19
- package/lib/cjs/internal/app-binder/task/SendEIP712StructImplemTask.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/EthersV5TransactionMapper.d.ts +0 -10
- package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.d.ts.map +0 -1
- package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.js +0 -60
- package/lib/cjs/internal/transaction/service/mapper/EthersV5TransactionMapper.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/EthersV6TransactionMapper.js +0 -36
- package/lib/cjs/internal/transaction/service/mapper/EthersV6TransactionMapper.js.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/TransactionMapperService.d.ts +0 -10
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.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/transaction/use-case/SignTransactionUseCase.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.map +0 -1
- package/lib/esm/api/app-binder/SignPersonalMessageDeviceActionTypes.d.ts +0 -20
- 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/Transaction.js +0 -2
- package/lib/esm/api/model/Transaction.js.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 +0 -10
- 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.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 +0 -30
- package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.d.ts +0 -17
- 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 +0 -25
- package/lib/esm/internal/app-binder/command/SignEIP712Command.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/command/SignTransactionCommand.d.ts +0 -24
- 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 +0 -17
- package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js +0 -157
- package/lib/esm/internal/app-binder/device-action/SignPersonalMessage/SignPersonalMessageDeviceAction.js.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 +0 -57
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/task/SendEIP712StructImplemTask.d.ts.map +0 -1
- package/lib/esm/internal/app-binder/task/SendSignPersonalMessageTask.d.ts +0 -14
- 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/EthersV5TransactionMapper.js +0 -57
- package/lib/esm/internal/transaction/service/mapper/EthersV5TransactionMapper.js.map +0 -1
- package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts +0 -9
- package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.d.ts.map +0 -1
- package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.js +0 -33
- package/lib/esm/internal/transaction/service/mapper/EthersV6TransactionMapper.js.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.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/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/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/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,68 +1,2 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
import { TypedDataValueField } from "../../typed-data/model/Types";
|
|
4
|
-
export const ZERO_ADDRESS = "0x0000000000000000000000000000000000000000";
|
|
5
|
-
export class BuildEIP712ContextTask {
|
|
6
|
-
api;
|
|
7
|
-
contextModule;
|
|
8
|
-
parser;
|
|
9
|
-
data;
|
|
10
|
-
constructor(api, contextModule, parser, data) {
|
|
11
|
-
this.api = api;
|
|
12
|
-
this.contextModule = contextModule;
|
|
13
|
-
this.parser = parser;
|
|
14
|
-
this.data = data;
|
|
15
|
-
}
|
|
16
|
-
async run() {
|
|
17
|
-
// Parse the message types and values
|
|
18
|
-
const parsed = this.parser.parse(this.data);
|
|
19
|
-
if (parsed.isLeft()) {
|
|
20
|
-
throw parsed.extract();
|
|
21
|
-
}
|
|
22
|
-
const { types, domain, message } = parsed.unsafeCoerce();
|
|
23
|
-
// Get clear signing context, if any
|
|
24
|
-
let clearSignContext = Nothing;
|
|
25
|
-
const version = this.getClearSignVersion();
|
|
26
|
-
if (version.isJust()) {
|
|
27
|
-
const verifyingContract = this.data.domain.verifyingContract?.toLowerCase() || ZERO_ADDRESS;
|
|
28
|
-
const chainId = this.data.domain.chainId || 0;
|
|
29
|
-
const fieldsValues = message
|
|
30
|
-
.filter((v) => v.value instanceof TypedDataValueField)
|
|
31
|
-
.map((v) => ({
|
|
32
|
-
path: v.path,
|
|
33
|
-
value: v.value.data,
|
|
34
|
-
}));
|
|
35
|
-
const filters = await this.contextModule.getTypedDataFilters({
|
|
36
|
-
verifyingContract,
|
|
37
|
-
chainId,
|
|
38
|
-
version: version.extract(),
|
|
39
|
-
schema: this.data.types,
|
|
40
|
-
fieldsValues,
|
|
41
|
-
});
|
|
42
|
-
if (filters.type === "success") {
|
|
43
|
-
clearSignContext = Just(filters);
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
// Return the args for provide context task
|
|
47
|
-
const provideTaskArgs = {
|
|
48
|
-
types,
|
|
49
|
-
domain,
|
|
50
|
-
message,
|
|
51
|
-
clearSignContext,
|
|
52
|
-
};
|
|
53
|
-
return provideTaskArgs;
|
|
54
|
-
}
|
|
55
|
-
getClearSignVersion() {
|
|
56
|
-
const deviceState = this.api.getDeviceSessionState();
|
|
57
|
-
if (deviceState.sessionStateType === DeviceSessionStateType.Connected) {
|
|
58
|
-
return Nothing;
|
|
59
|
-
}
|
|
60
|
-
if (deviceState.currentApp.name !== "Ethereum") {
|
|
61
|
-
return Nothing;
|
|
62
|
-
}
|
|
63
|
-
// TODO add currentAppVersion to session state
|
|
64
|
-
// const shouldUseV2Filters = semver.gte(deviceState.currentAppVersion!, "1.11.1-0");
|
|
65
|
-
return Just("v2");
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
//# sourceMappingURL=BuildEIP712ContextTask.js.map
|
|
1
|
+
import{DeviceSessionStateType as g}from"@ledgerhq/device-management-kit";import{TypedDataEncoder as y}from"ethers";import{Just as r,Nothing as i}from"purify-ts";import{gte as C}from"semver";import{TypedDataValueField as D}from"../../typed-data/model/Types";const S="0x0000000000000000000000000000000000000000";class V{constructor(t,a,m,o){this.api=t;this.contextModule=a;this.parser=m;this.data=o}async run(){const t=y.hashDomain(this.data.domain);if(!this.data.types[this.data.primaryType])throw new Error(`Primary type "${this.data.primaryType}" is not defined in the types.`);const a=this.data.types,{EIP712Domain:m,...o}=a,h=y.hashStruct(this.data.primaryType,o,this.data.message),s=this.parser.parse(this.data);if(s.isLeft())throw s.extract();const{types:l,domain:u,message:n}=s.unsafeCoerce();let p=i;const d=this.getClearSignVersion();if(d.isJust()){const v=this.data.domain.verifyingContract?.toLowerCase()||S,f=this.data.domain.chainId||0,T=n.filter(e=>e.value instanceof D).map(e=>({path:e.path,value:e.value.data})),c=await this.contextModule.getTypedDataFilters({verifyingContract:v,chainId:f,version:d.extract(),schema:this.data.types,fieldsValues:T});c.type==="success"&&(p=r(c))}return{types:l,domain:u,message:n,clearSignContext:p,domainHash:t,messageHash:h}}getClearSignVersion(){const t=this.api.getDeviceSessionState();return t.sessionStateType===g.Connected?i:t.currentApp.name!=="Ethereum"?i:C(t.currentApp.version,"1.12.0")?r("v2"):r("v1")}}export{V as BuildEIP712ContextTask,S as ZERO_ADDRESS};
|
|
2
|
+
//# sourceMappingURL=BuildEIP712ContextTask.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../../src/internal/app-binder/task/BuildEIP712ContextTask.ts"],
|
|
4
|
+
"sourcesContent": ["import {\n type ContextModule,\n type TypedDataClearSignContextSuccess,\n} from \"@ledgerhq/context-module\";\nimport {\n DeviceSessionStateType,\n type InternalApi,\n} from \"@ledgerhq/device-management-kit\";\nimport { TypedDataEncoder, type TypedDataField } from \"ethers\";\nimport { Just, type Maybe, Nothing } from \"purify-ts\";\nimport { gte } from \"semver\";\n\nimport { type TypedData } from \"@api/model/TypedData\";\nimport { type ProvideEIP712ContextTaskArgs } from \"@internal/app-binder/task/ProvideEIP712ContextTask\";\nimport { TypedDataValueField } from \"@internal/typed-data/model/Types\";\nimport { type TypedDataParserService } from \"@internal/typed-data/service/TypedDataParserService\";\n\nexport const ZERO_ADDRESS = \"0x0000000000000000000000000000000000000000\";\n\nexport class BuildEIP712ContextTask {\n constructor(\n private api: InternalApi,\n private contextModule: ContextModule,\n private parser: TypedDataParserService,\n private data: TypedData,\n ) {}\n\n async run(): Promise<ProvideEIP712ContextTaskArgs> {\n // Legacy blind signing context\n const domainHash = TypedDataEncoder.hashDomain(this.data.domain);\n\n if (!this.data.types[this.data.primaryType]) {\n throw new Error(\n `Primary type \"${this.data.primaryType}\" is not defined in the types.`,\n );\n }\n\n const typesRecord: Record<string, TypedDataField[]> = this.data.types;\n const { EIP712Domain, ...rest } = typesRecord;\n const messageHash = TypedDataEncoder.hashStruct(\n this.data.primaryType,\n rest,\n this.data.message,\n );\n\n // Clear signing context\n // Parse the message types and values\n const parsed = this.parser.parse(this.data);\n if (parsed.isLeft()) {\n throw parsed.extract();\n }\n const { types, domain, message } = parsed.unsafeCoerce();\n\n // Get clear signing context, if any\n let clearSignContext: Maybe<TypedDataClearSignContextSuccess> = Nothing;\n const version = this.getClearSignVersion();\n if (version.isJust()) {\n const verifyingContract =\n this.data.domain.verifyingContract?.toLowerCase() || ZERO_ADDRESS;\n const chainId = this.data.domain.chainId || 0;\n const fieldsValues = message\n .filter((v) => v.value instanceof TypedDataValueField)\n .map((v) => ({\n path: v.path,\n value: (v.value as TypedDataValueField).data,\n }));\n const filters = await this.contextModule.getTypedDataFilters({\n verifyingContract,\n chainId,\n version: version.extract(),\n schema: this.data.types,\n fieldsValues,\n });\n if (filters.type === \"success\") {\n clearSignContext = Just(filters);\n }\n }\n\n // Return the args for provide context task\n const provideTaskArgs: ProvideEIP712ContextTaskArgs = {\n types,\n domain,\n message,\n clearSignContext,\n domainHash,\n messageHash,\n };\n return provideTaskArgs;\n }\n\n private getClearSignVersion(): Maybe<\"v1\" | \"v2\"> {\n const deviceState = this.api.getDeviceSessionState();\n if (deviceState.sessionStateType === DeviceSessionStateType.Connected) {\n return Nothing;\n }\n if (deviceState.currentApp.name !== \"Ethereum\") {\n return Nothing;\n }\n // EIP712 v2 (amount & datetime filters) supported since 1.11.0:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#1110-1\n // But some issues were still present until 1.12.0 among which:\n // * V2 descriptor with missing token not supported by the app\n // * Empty arrays with filters not correctly handled\n // * Trusted name filters not yet released\n // Therefore it's safer and easier to use V1 filters before 1.12.0:\n // https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#1120\n const shouldUseV2Filters = gte(deviceState.currentApp.version, \"1.12.0\");\n return shouldUseV2Filters ? Just(\"v2\") : Just(\"v1\");\n }\n}\n"],
|
|
5
|
+
"mappings": "AAIA,OACE,0BAAAA,MAEK,kCACP,OAAS,oBAAAC,MAA6C,SACtD,OAAS,QAAAC,EAAkB,WAAAC,MAAe,YAC1C,OAAS,OAAAC,MAAW,SAIpB,OAAS,uBAAAC,MAA2B,mCAG7B,MAAMC,EAAe,6CAErB,MAAMC,CAAuB,CAClC,YACUC,EACAC,EACAC,EACAC,EACR,CAJQ,SAAAH,EACA,mBAAAC,EACA,YAAAC,EACA,UAAAC,CACP,CAEH,MAAM,KAA6C,CAEjD,MAAMC,EAAaX,EAAiB,WAAW,KAAK,KAAK,MAAM,EAE/D,GAAI,CAAC,KAAK,KAAK,MAAM,KAAK,KAAK,WAAW,EACxC,MAAM,IAAI,MACR,iBAAiB,KAAK,KAAK,WAAW,gCACxC,EAGF,MAAMY,EAAgD,KAAK,KAAK,MAC1D,CAAE,aAAAC,EAAc,GAAGC,CAAK,EAAIF,EAC5BG,EAAcf,EAAiB,WACnC,KAAK,KAAK,YACVc,EACA,KAAK,KAAK,OACZ,EAIME,EAAS,KAAK,OAAO,MAAM,KAAK,IAAI,EAC1C,GAAIA,EAAO,OAAO,EAChB,MAAMA,EAAO,QAAQ,EAEvB,KAAM,CAAE,MAAAC,EAAO,OAAAC,EAAQ,QAAAC,CAAQ,EAAIH,EAAO,aAAa,EAGvD,IAAII,EAA4DlB,EAChE,MAAMmB,EAAU,KAAK,oBAAoB,EACzC,GAAIA,EAAQ,OAAO,EAAG,CACpB,MAAMC,EACJ,KAAK,KAAK,OAAO,mBAAmB,YAAY,GAAKjB,EACjDkB,EAAU,KAAK,KAAK,OAAO,SAAW,EACtCC,EAAeL,EAClB,OAAQM,GAAMA,EAAE,iBAAiBrB,CAAmB,EACpD,IAAKqB,IAAO,CACX,KAAMA,EAAE,KACR,MAAQA,EAAE,MAA8B,IAC1C,EAAE,EACEC,EAAU,MAAM,KAAK,cAAc,oBAAoB,CAC3D,kBAAAJ,EACA,QAAAC,EACA,QAASF,EAAQ,QAAQ,EACzB,OAAQ,KAAK,KAAK,MAClB,aAAAG,CACF,CAAC,EACGE,EAAQ,OAAS,YACnBN,EAAmBnB,EAAKyB,CAAO,EAEnC,CAWA,MARsD,CACpD,MAAAT,EACA,OAAAC,EACA,QAAAC,EACA,iBAAAC,EACA,WAAAT,EACA,YAAAI,CACF,CAEF,CAEQ,qBAA0C,CAChD,MAAMY,EAAc,KAAK,IAAI,sBAAsB,EACnD,OAAIA,EAAY,mBAAqB5B,EAAuB,UACnDG,EAELyB,EAAY,WAAW,OAAS,WAC3BzB,EAUkBC,EAAIwB,EAAY,WAAW,QAAS,QAAQ,EAC3C1B,EAAK,IAAI,EAAIA,EAAK,IAAI,CACpD,CACF",
|
|
6
|
+
"names": ["DeviceSessionStateType", "TypedDataEncoder", "Just", "Nothing", "gte", "TypedDataValueField", "ZERO_ADDRESS", "BuildEIP712ContextTask", "api", "contextModule", "parser", "data", "domainHash", "typesRecord", "EIP712Domain", "rest", "messageHash", "parsed", "types", "domain", "message", "clearSignContext", "version", "verifyingContract", "chainId", "fieldsValues", "v", "filters", "deviceState"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{DeviceModelId as m,DeviceSessionStateType as f,DeviceStatus as y}from"@ledgerhq/device-management-kit";import{Just as l,Left as S,Nothing as b,Right as u}from"purify-ts";import{makeDeviceActionInternalApiMock as v}from"../../app-binder/device-action/__test-utils__/makeInternalApi";import{PrimitiveType as d,StructType as T,TypedDataValueField as x,TypedDataValueRoot as h}from"../../typed-data/model/Types";import{BuildEIP712ContextTask as p}from"./BuildEIP712ContextTask";describe("BuildEIP712ContextTask",()=>{const i=v(),t={getContext:vi.fn(),getContexts:vi.fn(),getTypedDataFilters:vi.fn()},e={parse:vi.fn()},s={domain:{name:"Permit2",chainId:137,verifyingContract:"0x000000000022d473030f116ddee9f6b43ac78ba3"},primaryType:"PermitSingle",message:{details:{token:"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619",amount:"69420000000000000000",expiration:"1718184249",nonce:"0"},spender:"0xec7be89e9d109e7e3fec59c222cf297125fefda2",sigDeadline:"1715594049"},types:{PermitSingle:[{name:"details",type:"PermitDetails"},{name:"spender",type:"address"},{name:"sigDeadline",type:"uint256"}],PermitDetails:[{name:"token",type:"address"},{name:"amount",type:"uint"},{name:"expiration",type:"uint"},{name:"nonce",type:"uint"}]}},r={PermitSingle:{details:new T("PermitDetails"),spender:new d("address","address",b),sigDeadline:new d("uint256","uint",l(32))},PermitDetails:{token:new d("address","address",b),amount:new d("uint160","uint",l(20)),expiration:new d("uint48","uint",l(6)),nonce:new d("uint48","uint",l(6))}},o=[{path:"",type:"",value:new h("EIP712Domain")},{path:"chainId",type:"uint256",value:new x(Uint8Array.from([137]))}],c=[{path:"",type:"",value:new h("PermitSingle")},{path:"details.amount",type:"uint160",value:new x(Uint8Array.from([18]))},{path:"details.expiration",type:"uint48",value:new x(Uint8Array.from([19]))}],g={type:"success",messageInfo:{displayName:"Permit2",filtersCount:1,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"},tokens:{},filters:{"details.amount":{displayName:"Amount allowance",path:"details.amount",signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",tokenIndex:255,type:"amount"}}};beforeEach(()=>{vi.resetAllMocks()}),it("Build context with clear signing context not supported by the device",async()=>{const a=new p(i,t,e,s);e.parse.mockReturnValueOnce(u({types:r,domain:o,message:c})),i.getDeviceSessionState.mockReturnValueOnce({sessionStateType:f.ReadyWithoutSecureChannel,deviceStatus:y.CONNECTED,installedApps:[],currentApp:{name:"Bitcoin",version:"1.0"},deviceModelId:m.FLEX});const n=await a.run();expect(n).toStrictEqual({types:r,domain:o,message:c,clearSignContext:b,domainHash:"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca",messageHash:"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a"})}),it("Build context with no clear signing context",async()=>{const a=new p(i,t,e,s);e.parse.mockReturnValueOnce(u({types:r,domain:o,message:c})),i.getDeviceSessionState.mockReturnValueOnce({sessionStateType:f.ReadyWithoutSecureChannel,deviceStatus:y.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:m.FLEX}),t.getTypedDataFilters.mockResolvedValueOnce({type:"error",error:new Error("no filter")});const n=await a.run();expect(n).toStrictEqual({types:r,domain:o,message:c,clearSignContext:b,domainHash:"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca",messageHash:"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a"})}),it("Build context with clear signing context",async()=>{const a=new p(i,t,e,s);e.parse.mockReturnValueOnce(u({types:r,domain:o,message:c})),i.getDeviceSessionState.mockReturnValueOnce({sessionStateType:f.ReadyWithoutSecureChannel,deviceStatus:y.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:m.FLEX}),t.getTypedDataFilters.mockResolvedValueOnce(g);const n=await a.run();expect(n).toStrictEqual({types:r,domain:o,message:c,clearSignContext:l(g),domainHash:"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca",messageHash:"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a"}),expect(e.parse).toHaveBeenCalledWith(s),expect(t.getTypedDataFilters).toHaveBeenCalledWith({verifyingContract:"0x000000000022d473030f116ddee9f6b43ac78ba3",chainId:137,version:"v2",schema:s.types,fieldsValues:[{path:"details.amount",value:Uint8Array.from([18])},{path:"details.expiration",value:Uint8Array.from([19])}]})}),it("Build context with clear signing context V1",async()=>{const a=new p(i,t,e,s);e.parse.mockReturnValueOnce(u({types:r,domain:o,message:c})),i.getDeviceSessionState.mockReturnValueOnce({sessionStateType:f.ReadyWithoutSecureChannel,deviceStatus:y.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.11.0"},deviceModelId:m.FLEX}),t.getTypedDataFilters.mockResolvedValueOnce(g),await a.run(),expect(t.getTypedDataFilters).toHaveBeenCalledWith({verifyingContract:"0x000000000022d473030f116ddee9f6b43ac78ba3",chainId:137,version:"v1",schema:s.types,fieldsValues:[{path:"details.amount",value:Uint8Array.from([18])},{path:"details.expiration",value:Uint8Array.from([19])}]})}),it("Should throw error if no primary type",async()=>{const a=new p(i,t,e,{...s,primaryType:""});e.parse.mockReturnValueOnce(u({types:r,domain:o,message:c}));try{await a.run()}catch(n){expect(n).toBeInstanceOf(Error),expect(n.message).toBe('Primary type "" is not defined in the types.')}}),it("Should throw an error if parsing fails",async()=>{const a=new p(i,t,e,s);e.parse.mockReturnValueOnce(S(new Error("Parsing error")));try{await a.run()}catch(n){expect(n).toBeInstanceOf(Error),expect(n.message).toBe("Parsing error")}})});
|
|
2
|
+
//# sourceMappingURL=BuildEIP712ContextTask.test.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../../src/internal/app-binder/task/BuildEIP712ContextTask.test.ts"],
|
|
4
|
+
"sourcesContent": ["import { type TypedDataClearSignContextSuccess } from \"@ledgerhq/context-module\";\nimport {\n DeviceModelId,\n DeviceSessionStateType,\n DeviceStatus,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, Left, Nothing, Right } from \"purify-ts\";\n\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport {\n PrimitiveType,\n StructType,\n TypedDataValueField,\n TypedDataValueRoot,\n} from \"@internal/typed-data/model/Types\";\n\nimport { BuildEIP712ContextTask } from \"./BuildEIP712ContextTask\";\n\ndescribe(\"BuildEIP712ContextTask\", () => {\n const apiMock = makeDeviceActionInternalApiMock();\n const contextMouleMock = {\n getContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n };\n const parserMock = {\n parse: vi.fn(),\n };\n\n const TEST_DATA = {\n domain: {\n name: \"Permit2\",\n chainId: 137,\n verifyingContract: \"0x000000000022d473030f116ddee9f6b43ac78ba3\",\n },\n primaryType: \"PermitSingle\",\n message: {\n details: {\n token: \"0x7ceb23fd6bc0add59e62ac25578270cff1b9f619\",\n amount: \"69420000000000000000\",\n expiration: \"1718184249\",\n nonce: \"0\",\n },\n spender: \"0xec7be89e9d109e7e3fec59c222cf297125fefda2\",\n sigDeadline: \"1715594049\",\n },\n types: {\n PermitSingle: [\n {\n name: \"details\",\n type: \"PermitDetails\",\n },\n {\n name: \"spender\",\n type: \"address\",\n },\n {\n name: \"sigDeadline\",\n type: \"uint256\",\n },\n ],\n PermitDetails: [\n { name: \"token\", type: \"address\" },\n { name: \"amount\", type: \"uint\" },\n { name: \"expiration\", type: \"uint\" },\n { name: \"nonce\", type: \"uint\" },\n ],\n },\n };\n\n const TEST_TYPES = {\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: \"chainId\",\n type: \"uint256\",\n value: new TypedDataValueField(Uint8Array.from([137])),\n },\n ];\n const TEST_MESSAGE_VALUES = [\n {\n path: \"\",\n type: \"\",\n value: new TypedDataValueRoot(\"PermitSingle\"),\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([0x13])),\n },\n ];\n const TEST_CLEAR_SIGN_CONTEXT: TypedDataClearSignContextSuccess = {\n type: \"success\",\n messageInfo: {\n displayName: \"Permit2\",\n filtersCount: 1,\n signature:\n \"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3\",\n },\n tokens: {},\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 },\n };\n\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n it(\"Build context with clear signing context not supported by the device\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n TEST_DATA,\n );\n parserMock.parse.mockReturnValueOnce(\n Right({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n }),\n );\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Bitcoin\", version: \"1.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n // WHEN\n const builtContext = await task.run();\n // THEN\n expect(builtContext).toStrictEqual({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Nothing,\n domainHash:\n \"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca\",\n messageHash:\n \"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a\",\n });\n });\n\n it(\"Build context with no clear signing context\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n TEST_DATA,\n );\n parserMock.parse.mockReturnValueOnce(\n Right({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n }),\n );\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n contextMouleMock.getTypedDataFilters.mockResolvedValueOnce({\n type: \"error\",\n error: new Error(\"no filter\"),\n });\n // WHEN\n const builtContext = await task.run();\n // THEN\n expect(builtContext).toStrictEqual({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Nothing,\n domainHash:\n \"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca\",\n messageHash:\n \"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a\",\n });\n });\n\n it(\"Build context with clear signing context\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n TEST_DATA,\n );\n parserMock.parse.mockReturnValueOnce(\n Right({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n }),\n );\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n contextMouleMock.getTypedDataFilters.mockResolvedValueOnce(\n TEST_CLEAR_SIGN_CONTEXT,\n );\n // WHEN\n const builtContext = await task.run();\n // THEN\n expect(builtContext).toStrictEqual({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n clearSignContext: Just(TEST_CLEAR_SIGN_CONTEXT),\n domainHash:\n \"0xf033048cb2764f596bc4d98e089fa38bb84b4be3d5da2e77f9bfac0e4d6c68ca\",\n messageHash:\n \"0x1087495b5e10337738059920fe1de8216235299745e8c97e21b409009a4c362a\",\n });\n expect(parserMock.parse).toHaveBeenCalledWith(TEST_DATA);\n expect(contextMouleMock.getTypedDataFilters).toHaveBeenCalledWith({\n verifyingContract: \"0x000000000022d473030f116ddee9f6b43ac78ba3\",\n chainId: 137,\n version: \"v2\",\n schema: TEST_DATA[\"types\"],\n fieldsValues: [\n {\n path: \"details.amount\",\n value: Uint8Array.from([0x12]),\n },\n {\n path: \"details.expiration\",\n value: Uint8Array.from([0x13]),\n },\n ],\n });\n });\n\n it(\"Build context with clear signing context V1\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n TEST_DATA,\n );\n parserMock.parse.mockReturnValueOnce(\n Right({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n }),\n );\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.11.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n contextMouleMock.getTypedDataFilters.mockResolvedValueOnce(\n TEST_CLEAR_SIGN_CONTEXT,\n );\n // WHEN\n await task.run();\n // THEN\n expect(contextMouleMock.getTypedDataFilters).toHaveBeenCalledWith({\n verifyingContract: \"0x000000000022d473030f116ddee9f6b43ac78ba3\",\n chainId: 137,\n version: \"v1\",\n schema: TEST_DATA[\"types\"],\n fieldsValues: [\n {\n path: \"details.amount\",\n value: Uint8Array.from([0x12]),\n },\n {\n path: \"details.expiration\",\n value: Uint8Array.from([0x13]),\n },\n ],\n });\n });\n\n it(\"Should throw error if no primary type\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n {\n ...TEST_DATA,\n primaryType: \"\",\n },\n );\n parserMock.parse.mockReturnValueOnce(\n Right({\n types: TEST_TYPES,\n domain: TEST_DOMAIN_VALUES,\n message: TEST_MESSAGE_VALUES,\n }),\n );\n // WHEN\n try {\n await task.run();\n } catch (e) {\n // THEN\n expect(e).toBeInstanceOf(Error);\n // @ts-expect-error\n expect(e.message).toBe('Primary type \"\" is not defined in the types.');\n }\n });\n\n it(\"Should throw an error if parsing fails\", async () => {\n // GIVEN\n const task = new BuildEIP712ContextTask(\n apiMock,\n contextMouleMock,\n parserMock,\n TEST_DATA,\n );\n parserMock.parse.mockReturnValueOnce(Left(new Error(\"Parsing error\")));\n // WHEN\n try {\n await task.run();\n } catch (e) {\n // THEN\n expect(e).toBeInstanceOf(Error);\n // @ts-expect-error\n expect(e.message).toBe(\"Parsing error\");\n }\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["DeviceModelId", "DeviceSessionStateType", "DeviceStatus", "Just", "Left", "Nothing", "Right", "makeDeviceActionInternalApiMock", "PrimitiveType", "StructType", "TypedDataValueField", "TypedDataValueRoot", "BuildEIP712ContextTask", "apiMock", "contextMouleMock", "parserMock", "TEST_DATA", "TEST_TYPES", "TEST_DOMAIN_VALUES", "TEST_MESSAGE_VALUES", "TEST_CLEAR_SIGN_CONTEXT", "task", "builtContext", "e"]
|
|
7
|
+
}
|
|
@@ -1,27 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
constructor(args) {
|
|
4
|
-
this.args = args;
|
|
5
|
-
}
|
|
6
|
-
async run() {
|
|
7
|
-
const { contextModule, mapper, transaction, options, challenge } = this.args;
|
|
8
|
-
const parsed = mapper.mapTransactionToSubset(transaction);
|
|
9
|
-
parsed.ifLeft((err) => {
|
|
10
|
-
throw err;
|
|
11
|
-
});
|
|
12
|
-
const { subset, serializedTransaction } = parsed.unsafeCoerce();
|
|
13
|
-
const clearSignContexts = await contextModule.getContexts({
|
|
14
|
-
challenge,
|
|
15
|
-
domain: options.domain,
|
|
16
|
-
...subset,
|
|
17
|
-
});
|
|
18
|
-
// TODO: for now we ignore the error contexts
|
|
19
|
-
// as we consider that they are warnings and not blocking
|
|
20
|
-
const clearSignContextsSuccess = clearSignContexts.filter((context) => context.type !== "error");
|
|
21
|
-
return {
|
|
22
|
-
clearSignContexts: clearSignContextsSuccess,
|
|
23
|
-
serializedTransaction,
|
|
24
|
-
};
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
//# sourceMappingURL=BuildTransactionContextTask.js.map
|
|
1
|
+
import{ClearSignContextType as n}from"@ledgerhq/context-module";import{DeviceModelId as m,DeviceSessionStateType as x}from"@ledgerhq/device-management-kit";import{gte as g}from"semver";import{ETHEREUM_PLUGINS as I}from"../../app-binder/constant/plugins";class O{constructor(t,i){this.api=t;this.args=i}async run(){const{contextModule:t,mapper:i,transaction:d,options:y,challenge:C}=this.args,s=this.api.getDeviceSessionState(),c=i.mapTransactionToSubset(d);c.ifLeft(e=>{throw e});const{subset:p,serializedTransaction:T,type:u}=c.unsafeCoerce(),l=await t.getContexts({challenge:C??void 0,domain:y.domain,deviceModelId:s.deviceModelId,...p}),o=l.filter(e=>e.type!==n.ERROR&&e.type!==n.ENUM),S=l.filter(e=>e.type===n.ENUM);let a=[];const r=o.find(e=>e.type===n.TRANSACTION_INFO);if(r&&!r.certificate)throw new Error("Transaction info certificate is missing");if(!this.supportsGenericParser(s)||r===void 0)a=o.filter(e=>e.type!==n.TRANSACTION_INFO&&e.type!==n.TRANSACTION_FIELD_DESCRIPTION);else{const e=o.filter(f=>f.type===n.TRANSACTION_FIELD_DESCRIPTION);a={transactionInfo:r.payload,transactionInfoCertificate:r.certificate,transactionFields:e,transactionEnums:S}}return{clearSignContexts:a,serializedTransaction:T,chainId:p.chainId,transactionType:u}}supportsGenericParser(t){if(t.sessionStateType===x.Connected)return!1;if(t.currentApp.name!=="Ethereum"&&!I.includes(t.currentApp.name))throw new Error("Unsupported app");return t.deviceModelId===m.NANO_S?!1:g(t.currentApp.version,"1.15.0")}}export{O as BuildTransactionContextTask};
|
|
2
|
+
//# sourceMappingURL=BuildTransactionContextTask.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../../src/internal/app-binder/task/BuildTransactionContextTask.ts"],
|
|
4
|
+
"sourcesContent": ["import {\n type ClearSignContextSuccess,\n type ClearSignContextSuccessType,\n ClearSignContextType,\n type ContextModule,\n} from \"@ledgerhq/context-module\";\nimport {\n DeviceModelId,\n type DeviceSessionState,\n DeviceSessionStateType,\n type InternalApi,\n} from \"@ledgerhq/device-management-kit\";\nimport { gte } from \"semver\";\n\nimport { type TransactionOptions } from \"@api/model/TransactionOptions\";\nimport { type TransactionType } from \"@api/model/TransactionType\";\nimport { ETHEREUM_PLUGINS } from \"@internal/app-binder/constant/plugins\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\n\nimport { type GenericContext } from \"./ProvideTransactionGenericContextTask\";\n\nexport type BuildTransactionTaskResult = {\n readonly clearSignContexts: ClearSignContextSuccess[] | GenericContext;\n readonly serializedTransaction: Uint8Array;\n readonly chainId: number;\n readonly transactionType: TransactionType;\n};\n\nexport type BuildTransactionContextTaskArgs = {\n readonly contextModule: ContextModule;\n readonly mapper: TransactionMapperService;\n readonly transaction: Uint8Array;\n readonly options: TransactionOptions;\n readonly challenge: string | null;\n};\n\nexport class BuildTransactionContextTask {\n constructor(\n private readonly api: InternalApi,\n private readonly args: BuildTransactionContextTaskArgs,\n ) {}\n\n async run(): Promise<BuildTransactionTaskResult> {\n const { contextModule, mapper, transaction, options, challenge } =\n this.args;\n const deviceState = this.api.getDeviceSessionState();\n\n const parsed = mapper.mapTransactionToSubset(transaction);\n parsed.ifLeft((err) => {\n throw err;\n });\n const { subset, serializedTransaction, type } = parsed.unsafeCoerce();\n\n const clearSignContexts = await contextModule.getContexts({\n challenge: challenge ?? undefined,\n domain: options.domain,\n deviceModelId: deviceState.deviceModelId,\n ...subset,\n });\n\n // NOTE: we need to filter out the ENUM and ERROR types\n // ENUM are handled differently\n // ERROR are not handled at all for now\n const clearSignContextsSuccess: ClearSignContextSuccess<\n Exclude<ClearSignContextSuccessType, ClearSignContextType.ENUM>\n >[] = clearSignContexts.filter(\n (context) =>\n context.type !== ClearSignContextType.ERROR &&\n context.type !== ClearSignContextType.ENUM,\n );\n\n // Retrieve all ENUM contexts\n const transactionEnums: ClearSignContextSuccess<ClearSignContextType.ENUM>[] =\n clearSignContexts.filter(\n (context) => context.type === ClearSignContextType.ENUM,\n );\n\n let filteredContexts: ClearSignContextSuccess[] | GenericContext = [];\n const transactionInfo = clearSignContextsSuccess.find(\n (ctx) => ctx.type === ClearSignContextType.TRANSACTION_INFO,\n );\n\n if (transactionInfo && !transactionInfo.certificate) {\n throw new Error(\"Transaction info certificate is missing\");\n }\n\n // If the device does not support the generic parser,\n // we need to filter out the transaction info and transaction field description\n // as they are not supported by the device\n if (\n !this.supportsGenericParser(deviceState) ||\n transactionInfo === undefined\n ) {\n filteredContexts = clearSignContextsSuccess.filter(\n (ctx) =>\n ctx.type !== ClearSignContextType.TRANSACTION_INFO &&\n ctx.type !== ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n );\n } else {\n const transactionFields = clearSignContextsSuccess.filter(\n (ctx) =>\n ctx.type === ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n );\n filteredContexts = {\n transactionInfo: transactionInfo.payload,\n transactionInfoCertificate: transactionInfo.certificate!,\n transactionFields,\n transactionEnums,\n };\n }\n\n return {\n clearSignContexts: filteredContexts,\n serializedTransaction,\n chainId: subset.chainId,\n transactionType: type,\n };\n }\n\n private supportsGenericParser(deviceState: DeviceSessionState): boolean {\n if (deviceState.sessionStateType === DeviceSessionStateType.Connected) {\n return false;\n }\n\n if (\n deviceState.currentApp.name !== \"Ethereum\" &&\n !ETHEREUM_PLUGINS.includes(deviceState.currentApp.name)\n ) {\n // Sanity check, should never happen as open app is called before this task\n throw new Error(\"Unsupported app\");\n }\n\n if (deviceState.deviceModelId === DeviceModelId.NANO_S) {\n return false;\n }\n return gte(deviceState.currentApp.version, \"1.15.0\");\n }\n}\n"],
|
|
5
|
+
"mappings": "AAAA,OAGE,wBAAAA,MAEK,2BACP,OACE,iBAAAC,EAEA,0BAAAC,MAEK,kCACP,OAAS,OAAAC,MAAW,SAIpB,OAAS,oBAAAC,MAAwB,wCAoB1B,MAAMC,CAA4B,CACvC,YACmBC,EACAC,EACjB,CAFiB,SAAAD,EACA,UAAAC,CAChB,CAEH,MAAM,KAA2C,CAC/C,KAAM,CAAE,cAAAC,EAAe,OAAAC,EAAQ,YAAAC,EAAa,QAAAC,EAAS,UAAAC,CAAU,EAC7D,KAAK,KACDC,EAAc,KAAK,IAAI,sBAAsB,EAE7CC,EAASL,EAAO,uBAAuBC,CAAW,EACxDI,EAAO,OAAQC,GAAQ,CACrB,MAAMA,CACR,CAAC,EACD,KAAM,CAAE,OAAAC,EAAQ,sBAAAC,EAAuB,KAAAC,CAAK,EAAIJ,EAAO,aAAa,EAE9DK,EAAoB,MAAMX,EAAc,YAAY,CACxD,UAAWI,GAAa,OACxB,OAAQD,EAAQ,OAChB,cAAeE,EAAY,cAC3B,GAAGG,CACL,CAAC,EAKKI,EAEAD,EAAkB,OACrBE,GACCA,EAAQ,OAASrB,EAAqB,OACtCqB,EAAQ,OAASrB,EAAqB,IAC1C,EAGMsB,EACJH,EAAkB,OACfE,GAAYA,EAAQ,OAASrB,EAAqB,IACrD,EAEF,IAAIuB,EAA+D,CAAC,EACpE,MAAMC,EAAkBJ,EAAyB,KAC9CK,GAAQA,EAAI,OAASzB,EAAqB,gBAC7C,EAEA,GAAIwB,GAAmB,CAACA,EAAgB,YACtC,MAAM,IAAI,MAAM,yCAAyC,EAM3D,GACE,CAAC,KAAK,sBAAsBX,CAAW,GACvCW,IAAoB,OAEpBD,EAAmBH,EAAyB,OACzCK,GACCA,EAAI,OAASzB,EAAqB,kBAClCyB,EAAI,OAASzB,EAAqB,6BACtC,MACK,CACL,MAAM0B,EAAoBN,EAAyB,OAChDK,GACCA,EAAI,OAASzB,EAAqB,6BACtC,EACAuB,EAAmB,CACjB,gBAAiBC,EAAgB,QACjC,2BAA4BA,EAAgB,YAC5C,kBAAAE,EACA,iBAAAJ,CACF,CACF,CAEA,MAAO,CACL,kBAAmBC,EACnB,sBAAAN,EACA,QAASD,EAAO,QAChB,gBAAiBE,CACnB,CACF,CAEQ,sBAAsBL,EAA0C,CACtE,GAAIA,EAAY,mBAAqBX,EAAuB,UAC1D,MAAO,GAGT,GACEW,EAAY,WAAW,OAAS,YAChC,CAACT,EAAiB,SAASS,EAAY,WAAW,IAAI,EAGtD,MAAM,IAAI,MAAM,iBAAiB,EAGnC,OAAIA,EAAY,gBAAkBZ,EAAc,OACvC,GAEFE,EAAIU,EAAY,WAAW,QAAS,QAAQ,CACrD,CACF",
|
|
6
|
+
"names": ["ClearSignContextType", "DeviceModelId", "DeviceSessionStateType", "gte", "ETHEREUM_PLUGINS", "BuildTransactionContextTask", "api", "args", "contextModule", "mapper", "transaction", "options", "challenge", "deviceState", "parsed", "err", "subset", "serializedTransaction", "type", "clearSignContexts", "clearSignContextsSuccess", "context", "transactionEnums", "filteredContexts", "transactionInfo", "ctx", "transactionFields"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{ClearSignContextType as t}from"@ledgerhq/context-module";import{DeviceModelId as p,DeviceSessionStateType as d,DeviceStatus as u,hexaStringToBuffer as x}from"@ledgerhq/device-management-kit";import{Transaction as m}from"ethers";import{Left as R,Right as T}from"purify-ts";import{ETHEREUM_PLUGINS as h}from"../../app-binder/constant/plugins";import{makeDeviceActionInternalApiMock as E}from"../../app-binder/device-action/__test-utils__/makeInternalApi";import{BuildTransactionContextTask as y}from"./BuildTransactionContextTask";describe("BuildTransactionContextTask",()=>{const r={getContext:vi.fn(),getContexts:vi.fn(),getTypedDataFilters:vi.fn()},c={mapTransactionToSubset:vi.fn()},C={domain:"domain-name.eth"},S=x(m.from({chainId:1n,nonce:0,data:"0x"}).unsignedSerialized),i={keyUsageNumber:1,payload:new Uint8Array([1,2,3])};let l;const n=E();beforeEach(()=>{vi.resetAllMocks(),l={contextModule:r,mapper:c,transaction:S,options:C,challenge:"challenge"}}),it("should build the transaction context without clear sign contexts",async()=>{const a=new Uint8Array([1,2,3]),e=[],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:0};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:p.FLEX});const s=await new y(n,l).run();expect(s).toEqual({clearSignContexts:e,serializedTransaction:a,chainId:1,transactionType:0})}),it("should build the transaction context with clear sign contexts",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TOKEN,payload:"payload-1"},{type:t.NFT,payload:"payload-2"}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:2};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:p.FLEX});const s=await new y(n,l).run();expect(s).toEqual({clearSignContexts:e,serializedTransaction:a,chainId:1,transactionType:2})}),it("should build the transaction context with generic-parser context",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TRANSACTION_INFO,payload:"payload-1",certificate:i},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-2"},{type:t.ENUM,payload:"payload-3",id:1,value:2,certificate:i},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-4"}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:2};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.15.0"},deviceModelId:p.FLEX});const s=await new y(n,l).run();expect(s).toEqual({clearSignContexts:{transactionInfo:"payload-1",transactionInfoCertificate:i,transactionFields:[e[1],e[3]],transactionEnums:[e[2]]},serializedTransaction:a,chainId:1,transactionType:2})}),it("should build the transaction context with generic-parser context and a plugin instead of Ethereum app",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TRANSACTION_INFO,payload:"payload-1",certificate:i},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-2"},{type:t.ENUM,payload:"payload-3",id:1,value:2,certificate:i},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-4"}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:2};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:h[0],version:"1.15.0"},deviceModelId:p.FLEX});const s=await new y(n,l).run();expect(s).toEqual({clearSignContexts:{transactionInfo:"payload-1",transactionInfoCertificate:i,transactionFields:[e[1],e[3]],transactionEnums:[e[2]]},serializedTransaction:a,chainId:1,transactionType:2})}),it("should call the mapper with the transaction",async()=>{const a=new Uint8Array([1,2,3]),e=[],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:0};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:p.FLEX}),await new y(n,l).run(),expect(c.mapTransactionToSubset).toHaveBeenCalledWith(S)}),it("should call the context module with the correct parameters",async()=>{const a=new Uint8Array([1,2,3]),e=[],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:0};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:p.FLEX}),await new y(n,l).run(),expect(r.getContexts).toHaveBeenCalledWith({deviceModelId:p.FLEX,challenge:"challenge",domain:"domain-name.eth",...o.subset})}),it("should throw an error if the mapper returns an error",async()=>{const a=new Error("error");c.mapTransactionToSubset.mockReturnValueOnce(R(a)),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:p.FLEX});const e=new y(n,l);await expect(e.run()).rejects.toThrow(a)}),it("should exclude error contexts from the result",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.ERROR,error:new Error("error")},{type:t.TOKEN,payload:"payload-1"},{type:t.ERROR,error:new Error("error")},{type:t.NFT,payload:"payload-2"}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:0};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:p.FLEX});const s=await new y(n,l).run();expect(s).toEqual({clearSignContexts:[e[1],e[3]],serializedTransaction:a,chainId:1,transactionType:0})}),it("should exclude generic-parser contexts from the result on old apps",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TRANSACTION_INFO,payload:"transaction_info",certificate:i},{type:t.TOKEN,payload:"payload-1"},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"transaction_field"},{type:t.NFT,payload:"payload-2"},{type:t.ENUM,payload:"enum",id:1,value:2,certificate:i}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:0};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:p.FLEX});const s=await new y(n,l).run();expect(s).toEqual({clearSignContexts:[e[1],e[3]],serializedTransaction:a,chainId:1,transactionType:0})}),it("should exclude generic-parser contexts from the result if no transaction_info was found",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"transaction_field"},{type:t.TOKEN,payload:"payload-1"},{type:t.ENUM,payload:"enum",id:1,value:2},{type:t.NFT,payload:"payload-2"}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:0};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.14.0"},deviceModelId:p.FLEX});const s=await new y(n,l).run();expect(s).toEqual({clearSignContexts:[e[1],e[3]],serializedTransaction:a,chainId:1,transactionType:0})}),it("should exclude legacy contexts from the result for generic-parser transactions",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TOKEN,payload:"payload-1"},{type:t.TRANSACTION_INFO,payload:"payload-2",certificate:i},{type:t.EXTERNAL_PLUGIN,payload:"payload-3"},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-4"},{type:t.ENUM,payload:"payload-5",id:1,value:2,certificate:i}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:2};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.15.0"},deviceModelId:p.FLEX});const s=await new y(n,l).run();expect(s).toEqual({clearSignContexts:{transactionInfo:"payload-2",transactionInfoCertificate:i,transactionFields:[e[3]],transactionEnums:[e[4]]},serializedTransaction:a,chainId:1,transactionType:2})}),it("should exclude generic-parser contexts with a nano s device",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TOKEN,payload:"payload-1"},{type:t.TRANSACTION_INFO,payload:"payload-2",certificate:i},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-3"},{type:t.ENUM,payload:"payload-4",id:1,value:2,certificate:i}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:2};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.14.0"},deviceModelId:p.NANO_S});const s=await new y(n,{...l,challenge:null}).run();expect(s).toEqual({clearSignContexts:[e[0]],serializedTransaction:a,chainId:1,transactionType:2})}),it("should exclude generic-parser contexts with an old app version",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TOKEN,payload:"payload-1"},{type:t.TRANSACTION_INFO,payload:"payload-2",certificate:i},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-3"},{type:t.ENUM,payload:"payload-4",id:1,value:2,certificate:i}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:2};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.12.0"},deviceModelId:p.FLEX});const s=await new y(n,{...l,challenge:null}).run();expect(s).toEqual({clearSignContexts:[e[0]],serializedTransaction:a,chainId:1,transactionType:2})}),it("should exclude generic-parser contexts with a non ready device",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TOKEN,payload:"payload-1"},{type:t.TRANSACTION_INFO,payload:"payload-2",certificate:i},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-3"},{type:t.ENUM,payload:"payload-4",id:1,value:2,certificate:i}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:2};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.Connected,deviceStatus:u.NOT_CONNECTED,deviceModelId:p.FLEX});const s=await new y(n,{...l,challenge:null}).run();expect(s).toEqual({clearSignContexts:[e[0]],serializedTransaction:a,chainId:1,transactionType:2})}),it("should throw an error if the app is not ethereum compatible",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TRANSACTION_INFO,payload:"payload-1",certificate:i},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-2"},{type:t.ENUM,payload:"payload-3",id:1,value:2,certificate:i}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:2};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Not Ethereum Compatible",version:"1.14.0"},deviceModelId:p.FLEX});const s=new y(n,l);await expect(s.run()).rejects.toThrow("Unsupported app")}),it("should return an error if the transaction info certificate is missing",async()=>{const a=new Uint8Array([1,2,3]),e=[{type:t.TRANSACTION_INFO,payload:"payload-1"},{type:t.TRANSACTION_FIELD_DESCRIPTION,payload:"payload-2"},{type:t.ENUM,payload:"payload-3",id:1,value:2}],o={subset:{chainId:1,to:void 0,data:"0x"},serializedTransaction:a,type:2};c.mapTransactionToSubset.mockReturnValueOnce(T(o)),r.getContexts.mockResolvedValueOnce(e),n.getDeviceSessionState.mockReturnValueOnce({sessionStateType:d.ReadyWithoutSecureChannel,deviceStatus:u.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:"1.14.0"},deviceModelId:p.FLEX});const s=new y(n,l);await expect(s.run()).rejects.toThrow("Transaction info certificate is missing")})});
|
|
2
|
+
//# sourceMappingURL=BuildTransactionContextTask.test.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../../src/internal/app-binder/task/BuildTransactionContextTask.test.ts"],
|
|
4
|
+
"sourcesContent": ["import {\n type ClearSignContext,\n ClearSignContextType,\n type PkiCertificate,\n} from \"@ledgerhq/context-module\";\nimport {\n DeviceModelId,\n DeviceSessionStateType,\n DeviceStatus,\n hexaStringToBuffer,\n} from \"@ledgerhq/device-management-kit\";\nimport { Transaction } from \"ethers\";\nimport { Left, Right } from \"purify-ts\";\n\nimport { ETHEREUM_PLUGINS } from \"@internal/app-binder/constant/plugins\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport { type TransactionMapperResult } from \"@internal/transaction/service/mapper/model/TransactionMapperResult\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\n\nimport {\n BuildTransactionContextTask,\n type BuildTransactionContextTaskArgs,\n} from \"./BuildTransactionContextTask\";\n\ndescribe(\"BuildTransactionContextTask\", () => {\n const contextModuleMock = {\n getContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n };\n const mapperMock = {\n mapTransactionToSubset: vi.fn(),\n };\n const defaultOptions = {\n domain: \"domain-name.eth\",\n };\n const defaultTransaction: Uint8Array = hexaStringToBuffer(\n Transaction.from({\n chainId: 1n,\n nonce: 0,\n data: \"0x\",\n }).unsignedSerialized,\n )!;\n const defaultCertificate: PkiCertificate = {\n keyUsageNumber: 1,\n payload: new Uint8Array([0x01, 0x02, 0x03]),\n };\n\n let defaultArgs: BuildTransactionContextTaskArgs;\n const apiMock = makeDeviceActionInternalApiMock();\n\n beforeEach(() => {\n vi.resetAllMocks();\n\n defaultArgs = {\n contextModule: contextModuleMock,\n mapper: mapperMock as unknown as TransactionMapperService,\n transaction: defaultTransaction,\n options: defaultOptions,\n challenge: \"challenge\",\n };\n });\n\n it(\"should build the transaction context without clear sign contexts\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts,\n serializedTransaction,\n chainId: 1,\n transactionType: 0,\n });\n });\n\n it(\"should build the transaction context with clear sign contexts\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.NFT,\n payload: \"payload-2\",\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts,\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should build the transaction context with generic-parser context\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-3\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-4\",\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.15.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: {\n transactionInfo: \"payload-1\",\n transactionInfoCertificate: defaultCertificate,\n transactionFields: [clearSignContexts[1], clearSignContexts[3]],\n transactionEnums: [clearSignContexts[2]],\n },\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should build the transaction context with generic-parser context and a plugin instead of Ethereum app\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-3\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-4\",\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: ETHEREUM_PLUGINS[0]!, version: \"1.15.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: {\n transactionInfo: \"payload-1\",\n transactionInfoCertificate: defaultCertificate,\n transactionFields: [clearSignContexts[1], clearSignContexts[3]],\n transactionEnums: [clearSignContexts[2]],\n },\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should call the mapper with the transaction\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n await new BuildTransactionContextTask(apiMock, defaultArgs).run();\n\n // THEN\n expect(mapperMock.mapTransactionToSubset).toHaveBeenCalledWith(\n defaultTransaction,\n );\n });\n\n it(\"should call the context module with the correct parameters\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n await new BuildTransactionContextTask(apiMock, defaultArgs).run();\n\n // THEN\n expect(contextModuleMock.getContexts).toHaveBeenCalledWith({\n deviceModelId: DeviceModelId.FLEX,\n challenge: \"challenge\",\n domain: \"domain-name.eth\",\n ...mapperResult.subset,\n });\n });\n\n it(\"should throw an error if the mapper returns an error\", async () => {\n // GIVEN\n const error = new Error(\"error\");\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Left(error));\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n\n // THEN\n await expect(task.run()).rejects.toThrow(error);\n });\n\n it(\"should exclude error contexts from the result\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.ERROR,\n error: new Error(\"error\"),\n },\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.ERROR,\n error: new Error(\"error\"),\n },\n {\n type: ClearSignContextType.NFT,\n payload: \"payload-2\",\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[1], clearSignContexts[3]],\n serializedTransaction,\n chainId: 1,\n transactionType: 0,\n });\n });\n\n it(\"should exclude generic-parser contexts from the result on old apps\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"transaction_info\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"transaction_field\",\n },\n {\n type: ClearSignContextType.NFT,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"enum\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[1], clearSignContexts[3]],\n serializedTransaction,\n chainId: 1,\n transactionType: 0,\n });\n });\n\n it(\"should exclude generic-parser contexts from the result if no transaction_info was found\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"transaction_field\",\n },\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"enum\",\n id: 1,\n value: 2,\n },\n {\n type: ClearSignContextType.NFT,\n payload: \"payload-2\",\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 0,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.14.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[1], clearSignContexts[3]],\n serializedTransaction,\n chainId: 1,\n transactionType: 0,\n });\n });\n\n it(\"should exclude legacy contexts from the result for generic-parser transactions\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-2\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.EXTERNAL_PLUGIN,\n payload: \"payload-3\",\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-4\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-5\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.15.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(\n apiMock,\n defaultArgs,\n ).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: {\n transactionInfo: \"payload-2\",\n transactionInfoCertificate: defaultCertificate,\n transactionFields: [clearSignContexts[3]],\n transactionEnums: [clearSignContexts[4]],\n },\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should exclude generic-parser contexts with a nano s device\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-2\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-3\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-4\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.14.0\" },\n deviceModelId: DeviceModelId.NANO_S,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(apiMock, {\n ...defaultArgs,\n challenge: null,\n }).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[0]],\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should exclude generic-parser contexts with an old app version\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-2\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-3\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-4\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.12.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(apiMock, {\n ...defaultArgs,\n challenge: null,\n }).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[0]],\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should exclude generic-parser contexts with a non ready device\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TOKEN,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-2\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-3\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-4\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.Connected,\n deviceStatus: DeviceStatus.NOT_CONNECTED,\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const result = await new BuildTransactionContextTask(apiMock, {\n ...defaultArgs,\n challenge: null,\n }).run();\n\n // THEN\n expect(result).toEqual({\n clearSignContexts: [clearSignContexts[0]],\n serializedTransaction,\n chainId: 1,\n transactionType: 2,\n });\n });\n\n it(\"should throw an error if the app is not ethereum compatible\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n certificate: defaultCertificate,\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-3\",\n id: 1,\n value: 2,\n certificate: defaultCertificate,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Not Ethereum Compatible\", version: \"1.14.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\"Unsupported app\");\n });\n\n it(\"should return an error if the transaction info certificate is missing\", async () => {\n // GIVEN\n const serializedTransaction = new Uint8Array([0x01, 0x02, 0x03]);\n const clearSignContexts: ClearSignContext[] = [\n {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n },\n {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n {\n type: ClearSignContextType.ENUM,\n payload: \"payload-3\",\n id: 1,\n value: 2,\n },\n ];\n const mapperResult: TransactionMapperResult = {\n subset: { chainId: 1, to: undefined, data: \"0x\" },\n serializedTransaction,\n type: 2,\n };\n mapperMock.mapTransactionToSubset.mockReturnValueOnce(Right(mapperResult));\n contextModuleMock.getContexts.mockResolvedValueOnce(clearSignContexts);\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version: \"1.14.0\" },\n deviceModelId: DeviceModelId.FLEX,\n });\n\n // WHEN\n const task = new BuildTransactionContextTask(apiMock, defaultArgs);\n\n // THEN\n await expect(task.run()).rejects.toThrow(\n \"Transaction info certificate is missing\",\n );\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["ClearSignContextType", "DeviceModelId", "DeviceSessionStateType", "DeviceStatus", "hexaStringToBuffer", "Transaction", "Left", "Right", "ETHEREUM_PLUGINS", "makeDeviceActionInternalApiMock", "BuildTransactionContextTask", "contextModuleMock", "mapperMock", "defaultOptions", "defaultTransaction", "defaultCertificate", "defaultArgs", "apiMock", "serializedTransaction", "clearSignContexts", "mapperResult", "result", "error", "task"]
|
|
7
|
+
}
|
|
@@ -1,184 +1,2 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
import { Maybe, Nothing } from "purify-ts";
|
|
4
|
-
import { ProvideTokenInformationCommand } from "../../app-binder/command/ProvideTokenInformationCommand";
|
|
5
|
-
import { Eip712FilterType, SendEIP712FilteringCommand, } from "../../app-binder/command/SendEIP712FilteringCommand";
|
|
6
|
-
import { SendEIP712StructDefinitionCommand, StructDefinitionCommand, } from "../../app-binder/command/SendEIP712StructDefinitionCommand";
|
|
7
|
-
import { StructImplemType } from "../../app-binder/command/SendEIP712StructImplemCommand";
|
|
8
|
-
import { SendEIP712StructImplemTask } from "../../app-binder/task/SendEIP712StructImplemTask";
|
|
9
|
-
import { TypedDataValueArray, TypedDataValueRoot, } from "../../typed-data/model/Types";
|
|
10
|
-
export class ProvideEIP712ContextTask {
|
|
11
|
-
api;
|
|
12
|
-
args;
|
|
13
|
-
constructor(api, args) {
|
|
14
|
-
this.api = api;
|
|
15
|
-
this.args = args;
|
|
16
|
-
}
|
|
17
|
-
async run() {
|
|
18
|
-
let result = CommandResultFactory({ data: undefined });
|
|
19
|
-
// Provide the structure definitions.
|
|
20
|
-
// Should be sent before struct implementations, as described here:
|
|
21
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-send-struct-definition
|
|
22
|
-
// Note that those types are used to compute the schema hash, in the device and in ClearSignContexts, as described here:
|
|
23
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#eip712-filtering
|
|
24
|
-
// Therefore it should be normalized on both sides: sorted per keys
|
|
25
|
-
const types = Object.entries(this.args.types).sort(([aKey], [bKey]) => aKey.localeCompare(bKey));
|
|
26
|
-
for (const [structName, fields] of types) {
|
|
27
|
-
result = await this.api.sendCommand(new SendEIP712StructDefinitionCommand({
|
|
28
|
-
command: StructDefinitionCommand.Name,
|
|
29
|
-
name: structName,
|
|
30
|
-
}));
|
|
31
|
-
if (!isSuccessCommandResult(result)) {
|
|
32
|
-
return result;
|
|
33
|
-
}
|
|
34
|
-
for (const [fieldName, fieldType] of Object.entries(fields)) {
|
|
35
|
-
result = await this.api.sendCommand(new SendEIP712StructDefinitionCommand({
|
|
36
|
-
command: StructDefinitionCommand.Field,
|
|
37
|
-
name: fieldName,
|
|
38
|
-
type: fieldType,
|
|
39
|
-
}));
|
|
40
|
-
if (!isSuccessCommandResult(result)) {
|
|
41
|
-
return result;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
if (this.args.clearSignContext.isJust()) {
|
|
46
|
-
// Activate the filtering, before sending domain and message implementations, as described here:
|
|
47
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#activation
|
|
48
|
-
result = await this.api.sendCommand(new SendEIP712FilteringCommand({ type: Eip712FilterType.Activation }));
|
|
49
|
-
if (!isSuccessCommandResult(result)) {
|
|
50
|
-
return result;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
// Send domain implementation values.
|
|
54
|
-
for (const value of this.args.domain) {
|
|
55
|
-
await this.getImplementationTask(value).run();
|
|
56
|
-
}
|
|
57
|
-
if (this.args.clearSignContext.isJust()) {
|
|
58
|
-
// Send MessageInformation filter.
|
|
59
|
-
// Should be sent between Domain and Message implementations, as described here:
|
|
60
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#message-info
|
|
61
|
-
result = await this.api.sendCommand(new SendEIP712FilteringCommand({
|
|
62
|
-
type: Eip712FilterType.MessageInfo,
|
|
63
|
-
displayName: this.args.clearSignContext.extract().messageInfo.displayName,
|
|
64
|
-
filtersCount: this.args.clearSignContext.extract().messageInfo.filtersCount,
|
|
65
|
-
signature: this.args.clearSignContext.extract().messageInfo.signature,
|
|
66
|
-
}));
|
|
67
|
-
if (!isSuccessCommandResult(result)) {
|
|
68
|
-
return result;
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
// Send message implementation values
|
|
72
|
-
const tokensIndexes = {};
|
|
73
|
-
for (const value of this.args.message) {
|
|
74
|
-
// Provide the descriptors of tokens referenced by the message, if any.
|
|
75
|
-
// Keep a map of all device indexes for those provided tokens.
|
|
76
|
-
const maybeError = await this.provideTokenInformation(value, tokensIndexes);
|
|
77
|
-
if (maybeError.isJust()) {
|
|
78
|
-
return maybeError.extract();
|
|
79
|
-
}
|
|
80
|
-
// If there is a filter, it should be sent just before the corresponding implementation:
|
|
81
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-token
|
|
82
|
-
const maybeResult = await this.provideFiltering(value, tokensIndexes);
|
|
83
|
-
if (maybeResult.isJust() &&
|
|
84
|
-
!isSuccessCommandResult(maybeResult.extract())) {
|
|
85
|
-
return maybeResult.extract();
|
|
86
|
-
}
|
|
87
|
-
// Provide message value implementation
|
|
88
|
-
result = await this.getImplementationTask(value).run();
|
|
89
|
-
if (!isSuccessCommandResult(result)) {
|
|
90
|
-
return result;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
return result;
|
|
94
|
-
}
|
|
95
|
-
getImplementationTask(value) {
|
|
96
|
-
if (value.value instanceof TypedDataValueRoot) {
|
|
97
|
-
return new SendEIP712StructImplemTask(this.api, {
|
|
98
|
-
type: StructImplemType.ROOT,
|
|
99
|
-
value: value.value.root,
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
else if (value.value instanceof TypedDataValueArray) {
|
|
103
|
-
return new SendEIP712StructImplemTask(this.api, {
|
|
104
|
-
type: StructImplemType.ARRAY,
|
|
105
|
-
value: value.value.length,
|
|
106
|
-
});
|
|
107
|
-
}
|
|
108
|
-
else {
|
|
109
|
-
return new SendEIP712StructImplemTask(this.api, {
|
|
110
|
-
type: StructImplemType.FIELD,
|
|
111
|
-
value: value.value.data,
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
async provideTokenInformation(value, tokensIndexes) {
|
|
116
|
-
if (this.args.clearSignContext.isJust()) {
|
|
117
|
-
const filter = this.args.clearSignContext.extract().filters[value.path];
|
|
118
|
-
// Tokens descriptors only needed when a tokenIndex is available in filter.
|
|
119
|
-
// It should be sent to the device only 1 time so tokensIndexes has to be checked.
|
|
120
|
-
if (filter !== undefined &&
|
|
121
|
-
(filter.type === "amount" || filter.type === "token") &&
|
|
122
|
-
tokensIndexes[filter.tokenIndex] === undefined) {
|
|
123
|
-
const descriptorIndex = filter.tokenIndex;
|
|
124
|
-
const tokens = this.args.clearSignContext.extract().tokens;
|
|
125
|
-
const token = tokens[descriptorIndex];
|
|
126
|
-
if (token === undefined) {
|
|
127
|
-
return Nothing;
|
|
128
|
-
}
|
|
129
|
-
const provideTokenInfoResult = await this.api.sendCommand(new ProvideTokenInformationCommand({ payload: token }));
|
|
130
|
-
if (!isSuccessCommandResult(provideTokenInfoResult)) {
|
|
131
|
-
return Maybe.of(provideTokenInfoResult);
|
|
132
|
-
}
|
|
133
|
-
let { tokenIndex: deviceIndex } = provideTokenInfoResult.data;
|
|
134
|
-
// The token corresponding to the Verifying Contract of message domain has a special index value, as described here:
|
|
135
|
-
// https://github.com/LedgerHQ/app-ethereum/blob/develop/doc/ethapp.adoc#amount-join-value
|
|
136
|
-
if (Number(descriptorIndex) === VERIFYING_CONTRACT_TOKEN_INDEX) {
|
|
137
|
-
deviceIndex = VERIFYING_CONTRACT_TOKEN_INDEX;
|
|
138
|
-
}
|
|
139
|
-
// Save the token index in the device slots. That index will be used by later filtering commands.
|
|
140
|
-
tokensIndexes[Number(descriptorIndex)] = deviceIndex;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
return Nothing;
|
|
144
|
-
}
|
|
145
|
-
async provideFiltering(value, tokensIndexes) {
|
|
146
|
-
if (this.args.clearSignContext.isJust()) {
|
|
147
|
-
const filter = this.args.clearSignContext.extract().filters[value.path];
|
|
148
|
-
if (filter === undefined ||
|
|
149
|
-
((filter.type === "amount" || filter.type === "token") &&
|
|
150
|
-
tokensIndexes[filter.tokenIndex] === undefined)) {
|
|
151
|
-
return Nothing;
|
|
152
|
-
}
|
|
153
|
-
switch (filter.type) {
|
|
154
|
-
case "datetime":
|
|
155
|
-
return Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand({
|
|
156
|
-
type: Eip712FilterType.Datetime,
|
|
157
|
-
displayName: filter.displayName,
|
|
158
|
-
signature: filter.signature,
|
|
159
|
-
})));
|
|
160
|
-
case "raw":
|
|
161
|
-
return Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand({
|
|
162
|
-
type: Eip712FilterType.Raw,
|
|
163
|
-
displayName: filter.displayName,
|
|
164
|
-
signature: filter.signature,
|
|
165
|
-
})));
|
|
166
|
-
case "token":
|
|
167
|
-
return Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand({
|
|
168
|
-
type: Eip712FilterType.Token,
|
|
169
|
-
tokenIndex: tokensIndexes[filter.tokenIndex],
|
|
170
|
-
signature: filter.signature,
|
|
171
|
-
})));
|
|
172
|
-
case "amount":
|
|
173
|
-
return Maybe.of(await this.api.sendCommand(new SendEIP712FilteringCommand({
|
|
174
|
-
type: Eip712FilterType.Amount,
|
|
175
|
-
displayName: filter.displayName,
|
|
176
|
-
tokenIndex: tokensIndexes[filter.tokenIndex],
|
|
177
|
-
signature: filter.signature,
|
|
178
|
-
})));
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
return Nothing;
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
//# sourceMappingURL=ProvideEIP712ContextTask.js.map
|
|
1
|
+
import{VERIFYING_CONTRACT_TOKEN_INDEX as I}from"@ledgerhq/context-module";import{CommandResultFactory as h,InvalidStatusWordError as w,isSuccessCommandResult as r}from"@ledgerhq/device-management-kit";import{Maybe as C,Nothing as u}from"purify-ts";import{ProvideTokenInformationCommand as R}from"../../app-binder/command/ProvideTokenInformationCommand";import{Eip712FilterType as d,SendEIP712FilteringCommand as m}from"../../app-binder/command/SendEIP712FilteringCommand";import{SendEIP712StructDefinitionCommand as T,StructDefinitionCommand as S}from"../../app-binder/command/SendEIP712StructDefinitionCommand";import{StructImplemType as y}from"../../app-binder/command/SendEIP712StructImplemCommand";import{SendEIP712StructImplemTask as f}from"../../app-binder/task/SendEIP712StructImplemTask";import{TypedDataValueArray as k,TypedDataValueRoot as D}from"../../typed-data/model/Types";const E=5;class j{constructor(e,n){this.api=e;this.args=n}async run(){const e=h({data:void 0}),n=Object.entries(this.args.types).sort(([t],[i])=>t.localeCompare(i));for(const[t,i]of n){const s=await this.api.sendCommand(new T({command:S.Name,name:t}));if(!r(s))return s;for(const[l,o]of Object.entries(i)){const c=await this.api.sendCommand(new T({command:S.Field,name:l,type:o}));if(!r(c))return c}}if(this.args.clearSignContext.isJust()){const t=await this.api.sendCommand(new m({type:d.Activation}));if(!r(t))return t}for(const t of this.args.domain){const s=await this.getImplementationTask(t).run();if(!r(s))return s}if(this.args.clearSignContext.isJust()){const t=this.args.clearSignContext.extract(),i=await this.api.sendCommand(new m({type:d.MessageInfo,displayName:t.messageInfo.displayName,filtersCount:t.messageInfo.filtersCount,signature:t.messageInfo.signature}));if(!r(i))return i}const a={indexes:{},nextIndex:0};for(const t of this.args.message){const i=await this.provideTokenInformation(t,a);if(i.isJust())return i.extract();const s=await this.filterValue(t,a);if(s.isJust()&&!r(s.extract()))return s.extract();const o=await this.getImplementationTask(t).run();if(!r(o))return o;if(this.args.clearSignContext.isJust()&&t.value instanceof k&&t.value.length===0){const v=Object.entries(this.args.clearSignContext.extract().filters).filter(([p])=>p.startsWith(`${t.path}.[]`)).map(([,p])=>p);for(const p of v){const g=await this.api.sendCommand(new m({type:d.DiscardedPath,path:p.path}));if(!r(g))return g;const x=await this.provideFiltering(p,a,!0);if(!r(x))return x}}}return e}getImplementationTask(e){return e.value instanceof D?new f(this.api,{type:y.ROOT,value:e.value.root}):e.value instanceof k?new f(this.api,{type:y.ARRAY,value:e.value.length}):new f(this.api,{type:y.FIELD,value:e.value.data})}async provideTokenInformation(e,n){if(this.args.clearSignContext.isJust()){const a=this.args.clearSignContext.extract().filters[e.path];if(a!==void 0&&(a.type==="amount"||a.type==="token")&&n.indexes[a.tokenIndex]===void 0){const t=a.tokenIndex,s=this.args.clearSignContext.extract().tokens[t];if(s===void 0)return u;const l=await this.api.sendCommand(new R({payload:s}));if(!r(l))return C.of(l);let{tokenIndex:o}=l.data;n.nextIndex=(o+1)%E,Number(t)===I&&(o=I),n.indexes[Number(t)]=o}}return u}async filterValue(e,n){if(this.args.clearSignContext.isJust()){const a=this.args.clearSignContext.extract().filters[e.path];if(a===void 0)return u;const t=await this.provideFiltering(a,n,!1);return C.of(t)}return u}async provideFiltering(e,n,a){switch(e.type){case"datetime":return await this.api.sendCommand(new m({type:d.Datetime,discarded:a,displayName:e.displayName,signature:e.signature}));case"raw":return await this.api.sendCommand(new m({type:d.Raw,discarded:a,displayName:e.displayName,signature:e.signature}));case"token":return this.sanitizeDeviceIndex(e.tokenIndex,n),await this.api.sendCommand(new m({type:d.Token,discarded:a,tokenIndex:n.indexes[e.tokenIndex],signature:e.signature}));case"amount":return this.sanitizeDeviceIndex(e.tokenIndex,n),await this.api.sendCommand(new m({type:d.Amount,discarded:a,displayName:e.displayName,tokenIndex:n.indexes[e.tokenIndex],signature:e.signature}));default:return h({error:new w("ProvideEIP712ContextTask/provideFiltering - Unhandled filter type")})}}sanitizeDeviceIndex(e,n){n.indexes[e]===void 0&&(n.indexes[e]=n.nextIndex,n.nextIndex=(n.nextIndex+1)%E)}}export{j as ProvideEIP712ContextTask};
|
|
2
|
+
//# sourceMappingURL=ProvideEIP712ContextTask.js.map
|