@ledgerhq/device-signer-kit-ethereum 0.0.0-signer-eth-plugin-fix-20250331141239 → 0.0.0-solana-signer-20251204160729
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 +112 -1
- package/lib/cjs/api/SignerEth.js +1 -1
- package/lib/cjs/api/SignerEth.js.map +1 -1
- package/lib/cjs/api/SignerEthBuilder.js +1 -1
- package/lib/cjs/api/SignerEthBuilder.js.map +3 -3
- package/lib/cjs/api/SignerEthBuilder.test.js +1 -1
- package/lib/cjs/api/SignerEthBuilder.test.js.map +3 -3
- package/lib/cjs/api/app-binder/SignDelegationAuthorizationTypes.js +2 -0
- package/lib/cjs/api/app-binder/SignDelegationAuthorizationTypes.js.map +7 -0
- package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js +1 -1
- package/lib/cjs/api/app-binder/SignTransactionDeviceActionTypes.js.map +2 -2
- package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -1
- package/lib/cjs/api/app-binder/SignTypedDataDeviceActionTypes.js.map +2 -2
- package/lib/cjs/api/app-binder/VerifySafeAddressDeviceActionTypes.js +2 -0
- package/lib/cjs/api/app-binder/VerifySafeAddressDeviceActionTypes.js.map +7 -0
- package/lib/cjs/api/index.js +1 -1
- package/lib/cjs/api/index.js.map +3 -3
- package/lib/cjs/api/model/AddressOptions.js +1 -1
- package/lib/cjs/api/model/AddressOptions.js.map +1 -1
- package/lib/cjs/api/model/ClearSigningType.js +2 -0
- package/lib/cjs/api/model/ClearSigningType.js.map +7 -0
- package/lib/cjs/api/model/MessageOptions.js +2 -0
- package/lib/cjs/api/model/MessageOptions.js.map +7 -0
- package/lib/cjs/api/model/SafeAddressOptions.js +2 -0
- package/lib/cjs/api/model/SafeAddressOptions.js.map +7 -0
- package/lib/cjs/api/model/TransactionOptions.js +1 -1
- package/lib/cjs/api/model/TransactionOptions.js.map +1 -1
- package/lib/cjs/api/model/TypedDataOptions.js +2 -0
- package/lib/cjs/api/model/TypedDataOptions.js.map +7 -0
- package/lib/cjs/internal/DefaultSignerEth.js +1 -1
- package/lib/cjs/internal/DefaultSignerEth.js.map +3 -3
- package/lib/cjs/internal/DefaultSignerEth.test.js +1 -1
- package/lib/cjs/internal/DefaultSignerEth.test.js.map +3 -3
- package/lib/cjs/internal/address/di/addressModule.js +1 -1
- package/lib/cjs/internal/address/di/addressModule.js.map +3 -3
- package/lib/cjs/internal/address/di/addressModule.test.js +1 -1
- package/lib/cjs/internal/address/di/addressModule.test.js.map +2 -2
- package/lib/cjs/internal/address/use-case/GetAddressUseCase.js +1 -1
- package/lib/cjs/internal/address/use-case/GetAddressUseCase.js.map +2 -2
- package/lib/cjs/internal/address/use-case/GetAddressUseCase.test.js +1 -1
- package/lib/cjs/internal/address/use-case/GetAddressUseCase.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/EthAppBinder.js +1 -1
- package/lib/cjs/internal/app-binder/EthAppBinder.js.map +3 -3
- package/lib/cjs/internal/app-binder/EthAppBinder.test.js +1 -1
- package/lib/cjs/internal/app-binder/EthAppBinder.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/GetAddressCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetAddressCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/GetAddressCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetAddressCommand.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetAppConfigurationCommand.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetChallengeCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/GetChallengeCommand.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideEnumCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideProxyInfoCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/ProvideSafeAccountCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/ProvideWeb3CheckCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.test.js +2 -2
- package/lib/cjs/internal/app-binder/command/SetExternalPluginCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/SetPluginCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/SetPluginCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/SetPluginCommand.test.js +2 -2
- package/lib/cjs/internal/app-binder/command/SetPluginCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.js +2 -0
- package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js +2 -0
- package/lib/cjs/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.js +1 -1
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/SignEIP712Command.test.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/SignTransactionCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/SignTransactionCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/StartTransactionCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/StartTransactionCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/StartTransactionCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/StartTransactionCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/StoreTransactionCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.js +1 -1
- package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.js.map +2 -2
- package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.test.js +1 -1
- package/lib/cjs/internal/app-binder/command/Web3CheckOptInCommand.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +3 -3
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +3 -3
- package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js +2 -0
- package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js.map +7 -0
- package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js +2 -0
- package/lib/cjs/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +1 -1
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +3 -3
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js +2 -0
- package/lib/cjs/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js.map +7 -0
- package/lib/cjs/internal/app-binder/di/appBinderModule.js +1 -1
- package/lib/cjs/internal/app-binder/di/appBinderModule.js.map +3 -3
- package/lib/cjs/internal/app-binder/task/BuildBaseContexts.js +2 -0
- package/lib/cjs/internal/app-binder/task/BuildBaseContexts.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/BuildBaseContexts.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/BuildBaseContexts.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js +1 -1
- package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.js.map +3 -3
- package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/BuildSafeAddressContextTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ParseTransactionTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/ParseTransactionTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ParseTransactionTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/ParseTransactionTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ProvideContextTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/ProvideContextTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ProvideContextTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/ProvideContextTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js +1 -1
- package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js.map +3 -3
- package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextsTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js +1 -1
- package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js.map +3 -3
- package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js +1 -1
- package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.js.map +3 -3
- package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js +1 -1
- package/lib/cjs/internal/app-binder/task/SendSignTransactionTask.test.js.map +3 -3
- package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.js +2 -0
- package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.js.map +7 -0
- package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.test.js +2 -0
- package/lib/cjs/internal/app-binder/task/SignTypedDataLegacyTask.test.js.map +7 -0
- package/lib/cjs/internal/di.js +1 -1
- package/lib/cjs/internal/di.js.map +3 -3
- package/lib/cjs/internal/eip7702/di/eip7702Module.js +2 -0
- package/lib/cjs/internal/eip7702/di/eip7702Module.js.map +7 -0
- package/lib/cjs/internal/eip7702/di/eip7702Module.test.js +2 -0
- package/lib/cjs/internal/eip7702/di/eip7702Module.test.js.map +7 -0
- package/lib/cjs/internal/eip7702/di/eip7702Types.js +2 -0
- package/lib/cjs/internal/eip7702/di/eip7702Types.js.map +7 -0
- package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js +2 -0
- package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js.map +7 -0
- package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js +2 -0
- package/lib/cjs/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js.map +7 -0
- package/lib/cjs/internal/message/di/messageModule.js +1 -1
- package/lib/cjs/internal/message/di/messageModule.js.map +3 -3
- package/lib/cjs/internal/message/di/messageModule.test.js +1 -1
- package/lib/cjs/internal/message/di/messageModule.test.js.map +2 -2
- package/lib/cjs/internal/message/use-case/SignMessageUseCase.js +1 -1
- package/lib/cjs/internal/message/use-case/SignMessageUseCase.js.map +3 -3
- package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js +1 -1
- package/lib/cjs/internal/message/use-case/SignMessageUseCase.test.js.map +2 -2
- package/lib/cjs/internal/safe/di/safeModule.js +2 -0
- package/lib/cjs/internal/safe/di/safeModule.js.map +7 -0
- package/lib/cjs/internal/safe/di/safeModule.test.js +2 -0
- package/lib/cjs/internal/safe/di/safeModule.test.js.map +7 -0
- package/lib/cjs/internal/safe/di/safeTypes.js +2 -0
- package/lib/cjs/internal/safe/di/safeTypes.js.map +7 -0
- package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.js +2 -0
- package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.js.map +7 -0
- package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.test.js +2 -0
- package/lib/cjs/internal/safe/use-case/VerifySafeAddressUseCase.test.js.map +7 -0
- package/lib/cjs/internal/shared/utils/ApplicationChecker.js +1 -1
- package/lib/cjs/internal/shared/utils/ApplicationChecker.js.map +3 -3
- package/lib/cjs/internal/shared/utils/ApplicationChecker.test.js +1 -1
- package/lib/cjs/internal/shared/utils/ApplicationChecker.test.js.map +2 -2
- package/lib/cjs/internal/transaction/di/transactionModule.js +1 -1
- package/lib/cjs/internal/transaction/di/transactionModule.js.map +3 -3
- package/lib/cjs/internal/transaction/di/transactionModule.test.js +1 -1
- package/lib/cjs/internal/transaction/di/transactionModule.test.js.map +2 -2
- package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.js +2 -0
- package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.js.map +7 -0
- package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.test.js +2 -0
- package/lib/cjs/internal/transaction/service/mapper/EthersTransactionMapperService.test.js.map +7 -0
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js +1 -1
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.js.map +3 -3
- package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js +1 -1
- package/lib/cjs/internal/transaction/service/parser/TransactionParserService.js.map +3 -3
- package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js +1 -1
- package/lib/cjs/internal/transaction/service/parser/TransactionParserService.test.js.map +3 -3
- package/lib/cjs/internal/typed-data/di/typedDataModule.js +1 -1
- package/lib/cjs/internal/typed-data/di/typedDataModule.js.map +3 -3
- package/lib/cjs/internal/typed-data/di/typedDataModule.test.js +1 -1
- package/lib/cjs/internal/typed-data/di/typedDataModule.test.js.map +2 -2
- package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js +1 -1
- package/lib/cjs/internal/typed-data/service/DefaultTypedDataParserService.js.map +2 -2
- package/lib/cjs/internal/typed-data/service/TypedDataParser.js +1 -1
- package/lib/cjs/internal/typed-data/service/TypedDataParser.js.map +3 -3
- package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js +1 -1
- package/lib/cjs/internal/typed-data/service/TypedDataParser.test.js.map +2 -2
- package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js +1 -1
- package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.js.map +3 -3
- package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js +1 -1
- package/lib/cjs/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +2 -2
- package/lib/cjs/package.json +43 -40
- package/lib/esm/api/SignerEthBuilder.js +1 -1
- package/lib/esm/api/SignerEthBuilder.js.map +3 -3
- package/lib/esm/api/SignerEthBuilder.test.js +1 -1
- package/lib/esm/api/SignerEthBuilder.test.js.map +3 -3
- package/lib/esm/api/app-binder/SignDelegationAuthorizationTypes.js +1 -0
- package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js +1 -1
- package/lib/esm/api/app-binder/SignTransactionDeviceActionTypes.js.map +2 -2
- package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js +1 -1
- package/lib/esm/api/app-binder/SignTypedDataDeviceActionTypes.js.map +2 -2
- package/lib/esm/api/app-binder/VerifySafeAddressDeviceActionTypes.js +2 -0
- package/lib/esm/api/app-binder/VerifySafeAddressDeviceActionTypes.js.map +7 -0
- package/lib/esm/api/index.js +1 -1
- package/lib/esm/api/index.js.map +2 -2
- package/lib/esm/api/model/ClearSigningType.js +2 -0
- package/lib/esm/api/model/ClearSigningType.js.map +7 -0
- package/lib/esm/api/model/MessageOptions.js +1 -0
- package/lib/esm/api/model/MessageOptions.js.map +7 -0
- package/lib/esm/api/model/SafeAddressOptions.js +1 -0
- package/lib/esm/api/model/SafeAddressOptions.js.map +7 -0
- package/lib/esm/api/model/TypedDataOptions.js +1 -0
- package/lib/esm/api/model/TypedDataOptions.js.map +7 -0
- package/lib/esm/internal/DefaultSignerEth.js +1 -1
- package/lib/esm/internal/DefaultSignerEth.js.map +3 -3
- package/lib/esm/internal/DefaultSignerEth.test.js +1 -1
- package/lib/esm/internal/DefaultSignerEth.test.js.map +3 -3
- package/lib/esm/internal/address/di/addressModule.js +1 -1
- package/lib/esm/internal/address/di/addressModule.js.map +3 -3
- package/lib/esm/internal/address/di/addressModule.test.js +1 -1
- package/lib/esm/internal/address/di/addressModule.test.js.map +2 -2
- package/lib/esm/internal/address/use-case/GetAddressUseCase.js +1 -1
- package/lib/esm/internal/address/use-case/GetAddressUseCase.js.map +2 -2
- package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js +1 -1
- package/lib/esm/internal/address/use-case/GetAddressUseCase.test.js.map +2 -2
- package/lib/esm/internal/app-binder/EthAppBinder.js +1 -1
- package/lib/esm/internal/app-binder/EthAppBinder.js.map +3 -3
- package/lib/esm/internal/app-binder/EthAppBinder.test.js +1 -1
- package/lib/esm/internal/app-binder/EthAppBinder.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/GetAddressCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/GetAddressCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/GetAddressCommand.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/GetAppConfigurationCommand.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/GetChallengeCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/GetChallengeCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/GetChallengeCommand.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideEnumCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideEnumCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideNFTInformationCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideProxyInfoCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/ProvideSafeAccountCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideTokenInformationCommand.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideTransactionInformationCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideTrustedNameCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/ProvideWeb3CheckCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.js.map +3 -3
- package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/SendEIP712FilteringCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/SendEIP712StructDefinitionCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/SendEIP712StructImplemCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js +2 -2
- package/lib/esm/internal/app-binder/command/SetExternalPluginCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/SetPluginCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/SetPluginCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js +2 -2
- package/lib/esm/internal/app-binder/command/SetPluginCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.js +2 -0
- package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.js.map +7 -0
- package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js +2 -0
- package/lib/esm/internal/app-binder/command/SignAuthorizationDelegationCommand.test.js.map +7 -0
- package/lib/esm/internal/app-binder/command/SignEIP712Command.js +1 -1
- package/lib/esm/internal/app-binder/command/SignEIP712Command.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js +1 -1
- package/lib/esm/internal/app-binder/command/SignEIP712Command.test.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/SignPersonalMessageCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/SignTransactionCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/SignTransactionCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/SignTransactionCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/StartTransactionCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/StartTransactionCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/StartTransactionCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/StoreTransactionCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/StoreTransactionCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.js +1 -1
- package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.js.map +2 -2
- package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.test.js +1 -1
- package/lib/esm/internal/app-binder/command/Web3CheckOptInCommand.test.js.map +3 -3
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +1 -1
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +3 -3
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
- package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +3 -3
- package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js +1 -1
- package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map +3 -3
- package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +1 -1
- package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +3 -3
- package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js +2 -0
- package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.js.map +7 -0
- package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js +2 -0
- package/lib/esm/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.js.map +7 -0
- package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js +1 -1
- package/lib/esm/internal/app-binder/device-action/__test-utils__/makeInternalApi.js.map +3 -3
- package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js +2 -0
- package/lib/esm/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.js.map +7 -0
- package/lib/esm/internal/app-binder/di/appBinderModule.js +1 -1
- package/lib/esm/internal/app-binder/di/appBinderModule.js.map +3 -3
- package/lib/esm/internal/app-binder/task/BuildBaseContexts.js +2 -0
- package/lib/esm/internal/app-binder/task/BuildBaseContexts.js.map +7 -0
- package/lib/esm/internal/app-binder/task/BuildBaseContexts.test.js +2 -0
- package/lib/esm/internal/app-binder/task/BuildBaseContexts.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js +1 -1
- package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.js.map +3 -3
- package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +3 -3
- package/lib/esm/internal/app-binder/task/BuildFullContextsTask.js +2 -0
- package/lib/esm/internal/app-binder/task/BuildFullContextsTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/BuildFullContextsTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/BuildFullContextsTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.js +2 -0
- package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/BuildSafeAddressContextTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.js +2 -0
- package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.js +2 -0
- package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ParseTransactionTask.js +2 -0
- package/lib/esm/internal/app-binder/task/ParseTransactionTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ParseTransactionTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/ParseTransactionTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ProvideContextTask.js +2 -0
- package/lib/esm/internal/app-binder/task/ProvideContextTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ProvideContextTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/ProvideContextTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js +1 -1
- package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js.map +3 -3
- package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +3 -3
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.js +2 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextsTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js +1 -1
- package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js.map +3 -3
- package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +3 -3
- package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.js +2 -0
- package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.js.map +7 -0
- package/lib/esm/internal/app-binder/task/SendSignTransactionTask.js +1 -1
- package/lib/esm/internal/app-binder/task/SendSignTransactionTask.js.map +3 -3
- package/lib/esm/internal/app-binder/task/SendSignTransactionTask.test.js +1 -1
- package/lib/esm/internal/app-binder/task/SendSignTransactionTask.test.js.map +3 -3
- package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.js +2 -0
- package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.js.map +7 -0
- package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.test.js +2 -0
- package/lib/esm/internal/app-binder/task/SignTypedDataLegacyTask.test.js.map +7 -0
- package/lib/esm/internal/di.js +1 -1
- package/lib/esm/internal/di.js.map +3 -3
- package/lib/esm/internal/eip7702/di/eip7702Module.js +2 -0
- package/lib/esm/internal/eip7702/di/eip7702Module.js.map +7 -0
- package/lib/esm/internal/eip7702/di/eip7702Module.test.js +2 -0
- package/lib/esm/internal/eip7702/di/eip7702Module.test.js.map +7 -0
- package/lib/esm/internal/eip7702/di/eip7702Types.js +2 -0
- package/lib/esm/internal/eip7702/di/eip7702Types.js.map +7 -0
- package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js +2 -0
- package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.js.map +7 -0
- package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js +2 -0
- package/lib/esm/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.js.map +7 -0
- package/lib/esm/internal/message/di/messageModule.js +1 -1
- package/lib/esm/internal/message/di/messageModule.js.map +3 -3
- package/lib/esm/internal/message/di/messageModule.test.js +1 -1
- package/lib/esm/internal/message/di/messageModule.test.js.map +2 -2
- package/lib/esm/internal/message/use-case/SignMessageUseCase.js +1 -1
- package/lib/esm/internal/message/use-case/SignMessageUseCase.js.map +3 -3
- package/lib/esm/internal/message/use-case/SignMessageUseCase.test.js +1 -1
- package/lib/esm/internal/message/use-case/SignMessageUseCase.test.js.map +2 -2
- package/lib/esm/internal/safe/di/safeModule.js +2 -0
- package/lib/esm/internal/safe/di/safeModule.js.map +7 -0
- package/lib/esm/internal/safe/di/safeModule.test.js +2 -0
- package/lib/esm/internal/safe/di/safeModule.test.js.map +7 -0
- package/lib/esm/internal/safe/di/safeTypes.js +2 -0
- package/lib/esm/internal/safe/di/safeTypes.js.map +7 -0
- package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.js +2 -0
- package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.js.map +7 -0
- package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.test.js +2 -0
- package/lib/esm/internal/safe/use-case/VerifySafeAddressUseCase.test.js.map +7 -0
- package/lib/esm/internal/shared/utils/ApplicationChecker.js +1 -1
- package/lib/esm/internal/shared/utils/ApplicationChecker.js.map +3 -3
- package/lib/esm/internal/shared/utils/ApplicationChecker.test.js +1 -1
- package/lib/esm/internal/shared/utils/ApplicationChecker.test.js.map +2 -2
- package/lib/esm/internal/transaction/di/transactionModule.js +1 -1
- package/lib/esm/internal/transaction/di/transactionModule.js.map +3 -3
- package/lib/esm/internal/transaction/di/transactionModule.test.js +1 -1
- package/lib/esm/internal/transaction/di/transactionModule.test.js.map +2 -2
- package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.js +2 -0
- package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.js.map +7 -0
- package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.test.js +2 -0
- package/lib/esm/internal/transaction/service/mapper/EthersTransactionMapperService.test.js.map +7 -0
- package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js +0 -1
- package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.js.map +4 -4
- package/lib/esm/internal/transaction/service/parser/TransactionParserService.js +1 -1
- package/lib/esm/internal/transaction/service/parser/TransactionParserService.js.map +3 -3
- package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js +1 -1
- package/lib/esm/internal/transaction/service/parser/TransactionParserService.test.js.map +3 -3
- package/lib/esm/internal/typed-data/di/typedDataModule.js +1 -1
- package/lib/esm/internal/typed-data/di/typedDataModule.js.map +3 -3
- package/lib/esm/internal/typed-data/di/typedDataModule.test.js +1 -1
- package/lib/esm/internal/typed-data/di/typedDataModule.test.js.map +2 -2
- package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js +1 -1
- package/lib/esm/internal/typed-data/service/DefaultTypedDataParserService.js.map +2 -2
- package/lib/esm/internal/typed-data/service/TypedDataParser.js +1 -1
- package/lib/esm/internal/typed-data/service/TypedDataParser.js.map +3 -3
- package/lib/esm/internal/typed-data/service/TypedDataParser.test.js +1 -1
- package/lib/esm/internal/typed-data/service/TypedDataParser.test.js.map +2 -2
- package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js +1 -1
- package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.js.map +3 -3
- package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js +1 -1
- package/lib/esm/internal/typed-data/use-case/SignTypedDataUseCase.test.js.map +2 -2
- package/lib/esm/package.json +43 -40
- package/lib/types/api/SignerEth.d.ts +11 -4
- package/lib/types/api/SignerEth.d.ts.map +1 -1
- package/lib/types/api/SignerEthBuilder.d.ts +4 -2
- package/lib/types/api/SignerEthBuilder.d.ts.map +1 -1
- package/lib/types/api/app-binder/SignDelegationAuthorizationTypes.d.ts +19 -0
- package/lib/types/api/app-binder/SignDelegationAuthorizationTypes.d.ts.map +1 -0
- package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts +18 -12
- package/lib/types/api/app-binder/SignTransactionDeviceActionTypes.d.ts.map +1 -1
- package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts +13 -1
- package/lib/types/api/app-binder/SignTypedDataDeviceActionTypes.d.ts.map +1 -1
- package/lib/types/api/app-binder/VerifySafeAddressDeviceActionTypes.d.ts +30 -0
- package/lib/types/api/app-binder/VerifySafeAddressDeviceActionTypes.d.ts.map +1 -0
- package/lib/types/api/index.d.ts +5 -4
- package/lib/types/api/index.d.ts.map +1 -1
- package/lib/types/api/model/AddressOptions.d.ts +1 -0
- package/lib/types/api/model/AddressOptions.d.ts.map +1 -1
- package/lib/types/api/model/ClearSigningType.d.ts +5 -0
- package/lib/types/api/model/ClearSigningType.d.ts.map +1 -0
- package/lib/types/api/model/MessageOptions.d.ts +4 -0
- package/lib/types/api/model/MessageOptions.d.ts.map +1 -0
- package/lib/types/api/model/SafeAddressOptions.d.ts +5 -0
- package/lib/types/api/model/SafeAddressOptions.d.ts.map +1 -0
- package/lib/types/api/model/TransactionOptions.d.ts +1 -0
- package/lib/types/api/model/TransactionOptions.d.ts.map +1 -1
- package/lib/types/api/model/TypedDataOptions.d.ts +4 -0
- package/lib/types/api/model/TypedDataOptions.d.ts.map +1 -0
- package/lib/types/internal/DefaultSignerEth.d.ts +10 -3
- package/lib/types/internal/DefaultSignerEth.d.ts.map +1 -1
- package/lib/types/internal/address/di/addressModule.d.ts.map +1 -1
- package/lib/types/internal/address/use-case/GetAddressUseCase.d.ts.map +1 -1
- package/lib/types/internal/app-binder/EthAppBinder.d.ts +19 -3
- package/lib/types/internal/app-binder/EthAppBinder.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/GetAddressCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/GetAddressCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/GetAppConfigurationCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/GetAppConfigurationCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/GetChallengeCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/ProvideEnumCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/ProvideNFTInformationCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.d.ts +29 -0
- package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.d.ts +21 -0
- package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/ProvideProxyInfoCommand.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.d.ts +35 -0
- package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/ProvideSafeAccountCommand.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/ProvideTokenInformationCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/ProvideTransactionFieldDescriptionCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/ProvideTransactionInformationCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/ProvideTrustedNameCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/ProvideWeb3CheckCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/ProvideWeb3CheckCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts +30 -1
- package/lib/types/internal/app-binder/command/SendEIP712FilteringCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/SendEIP712StructDefinitionCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/SendEIP712StructImplemCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/SetExternalPluginCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/SetExternalPluginCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/SetPluginCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/SetPluginCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.d.ts +30 -0
- package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.test.d.ts +2 -0
- package/lib/types/internal/app-binder/command/SignAuthorizationDelegationCommand.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/command/SignEIP712Command.d.ts +1 -0
- package/lib/types/internal/app-binder/command/SignEIP712Command.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/SignPersonalMessageCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/SignTransactionCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/StartTransactionCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/StoreTransactionCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/Web3CheckOptInCommand.d.ts +1 -0
- package/lib/types/internal/app-binder/command/Web3CheckOptInCommand.d.ts.map +1 -1
- package/lib/types/internal/app-binder/command/utils/ethAppErrors.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts +19 -36
- package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts +10 -2
- package/lib/types/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.d.ts +20 -0
- package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.d.ts.map +1 -0
- package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.d.ts +2 -0
- package/lib/types/internal/app-binder/device-action/VerifySafeAddress/VerifySafeAddress.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/device-action/__test-utils__/makeInternalApi.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock.d.ts.map +1 -1
- package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.d.ts +6 -0
- package/lib/types/internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep.d.ts.map +1 -0
- package/lib/types/internal/app-binder/di/appBinderModule.d.ts.map +1 -1
- package/lib/types/internal/app-binder/task/BuildBaseContexts.d.ts +47 -0
- package/lib/types/internal/app-binder/task/BuildBaseContexts.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/BuildBaseContexts.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/BuildBaseContexts.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.d.ts +10 -3
- package/lib/types/internal/app-binder/task/BuildEIP712ContextTask.d.ts.map +1 -1
- package/lib/types/internal/app-binder/task/BuildFullContextsTask.d.ts +39 -0
- package/lib/types/internal/app-binder/task/BuildFullContextsTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/BuildFullContextsTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/BuildFullContextsTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.d.ts +19 -0
- package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/BuildSafeAddressContextTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/BuildSubcontextsTask.d.ts +28 -0
- package/lib/types/internal/app-binder/task/BuildSubcontextsTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/BuildSubcontextsTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/BuildSubcontextsTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.d.ts +21 -0
- package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ParseTransactionTask.d.ts +17 -0
- package/lib/types/internal/app-binder/task/ParseTransactionTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ParseTransactionTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/ParseTransactionTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideContextTask.d.ts +22 -0
- package/lib/types/internal/app-binder/task/ProvideContextTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideContextTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/ProvideContextTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts +16 -7
- package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +1 -1
- package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.d.ts +36 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/ProvideTransactionContextsTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts +2 -2
- package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts.map +1 -1
- package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.d.ts +18 -0
- package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/SendSignAuthorizationDelegationTask.test.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts +2 -1
- package/lib/types/internal/app-binder/task/SendSignTransactionTask.d.ts.map +1 -1
- package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.d.ts +12 -0
- package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.d.ts.map +1 -0
- package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.test.d.ts +2 -0
- package/lib/types/internal/app-binder/task/SignTypedDataLegacyTask.test.d.ts.map +1 -0
- package/lib/types/internal/di.d.ts.map +1 -1
- package/lib/types/internal/eip7702/di/eip7702Module.d.ts +3 -0
- package/lib/types/internal/eip7702/di/eip7702Module.d.ts.map +1 -0
- package/lib/types/internal/eip7702/di/eip7702Module.test.d.ts +2 -0
- package/lib/types/internal/eip7702/di/eip7702Module.test.d.ts.map +1 -0
- package/lib/types/internal/eip7702/di/eip7702Types.d.ts +4 -0
- package/lib/types/internal/eip7702/di/eip7702Types.d.ts.map +1 -0
- package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.d.ts +8 -0
- package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.d.ts.map +1 -0
- package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.d.ts +2 -0
- package/lib/types/internal/eip7702/use-case/SignDelegationAuthorizationUseCase.test.d.ts.map +1 -0
- package/lib/types/internal/message/di/messageModule.d.ts.map +1 -1
- package/lib/types/internal/message/use-case/SignMessageUseCase.d.ts +2 -1
- package/lib/types/internal/message/use-case/SignMessageUseCase.d.ts.map +1 -1
- package/lib/types/internal/safe/di/safeModule.d.ts +3 -0
- package/lib/types/internal/safe/di/safeModule.d.ts.map +1 -0
- package/lib/types/internal/safe/di/safeModule.test.d.ts +2 -0
- package/lib/types/internal/safe/di/safeModule.test.d.ts.map +1 -0
- package/lib/types/internal/safe/di/safeTypes.d.ts +4 -0
- package/lib/types/internal/safe/di/safeTypes.d.ts.map +1 -0
- package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.d.ts +9 -0
- package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.d.ts.map +1 -0
- package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.test.d.ts +2 -0
- package/lib/types/internal/safe/use-case/VerifySafeAddressUseCase.test.d.ts.map +1 -0
- package/lib/types/internal/shared/utils/ApplicationChecker.d.ts.map +1 -1
- package/lib/types/internal/transaction/di/transactionModule.d.ts.map +1 -1
- package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.d.ts +8 -0
- package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.d.ts.map +1 -0
- package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.test.d.ts +2 -0
- package/lib/types/internal/transaction/service/mapper/EthersTransactionMapperService.test.d.ts.map +1 -0
- package/lib/types/internal/transaction/service/mapper/TransactionMapperService.d.ts +4 -7
- package/lib/types/internal/transaction/service/mapper/TransactionMapperService.d.ts.map +1 -1
- package/lib/types/internal/transaction/service/parser/TransactionParserService.d.ts +2 -2
- package/lib/types/internal/transaction/service/parser/TransactionParserService.d.ts.map +1 -1
- package/lib/types/internal/typed-data/di/typedDataModule.d.ts.map +1 -1
- package/lib/types/internal/typed-data/service/TypedDataParser.d.ts +4 -2
- package/lib/types/internal/typed-data/service/TypedDataParser.d.ts.map +1 -1
- package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.d.ts +2 -1
- package/lib/types/internal/typed-data/use-case/SignTypedDataUseCase.d.ts.map +1 -1
- package/lib/types/tsconfig.prod.tsbuildinfo +1 -1
- package/package.json +41 -38
- package/lib/cjs/internal/app-binder/constant/plugins.js +0 -2
- package/lib/cjs/internal/app-binder/constant/plugins.js.map +0 -7
- package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js +0 -2
- package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.js.map +0 -7
- package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js +0 -2
- package/lib/cjs/internal/app-binder/task/BuildTransactionContextTask.test.js.map +0 -7
- package/lib/cjs/internal/app-binder/task/GetWeb3CheckTask.js +0 -2
- package/lib/cjs/internal/app-binder/task/GetWeb3CheckTask.js.map +0 -7
- package/lib/cjs/internal/app-binder/task/GetWeb3CheckTask.test.js +0 -2
- package/lib/cjs/internal/app-binder/task/GetWeb3CheckTask.test.js.map +0 -7
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js +0 -2
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.js.map +0 -7
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js +0 -2
- package/lib/cjs/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +0 -7
- package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +0 -2
- package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +0 -7
- package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +0 -2
- package/lib/cjs/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +0 -7
- package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js +0 -2
- package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +0 -7
- package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +0 -2
- package/lib/cjs/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +0 -7
- package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.js +0 -2
- package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.js.map +0 -7
- package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js +0 -2
- package/lib/cjs/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js.map +0 -7
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js +0 -2
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapper.js.map +0 -7
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js +0 -2
- package/lib/cjs/internal/transaction/service/mapper/TransactionMapperService.test.js.map +0 -7
- package/lib/esm/internal/app-binder/constant/plugins.js +0 -2
- package/lib/esm/internal/app-binder/constant/plugins.js.map +0 -7
- package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js +0 -2
- package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.js.map +0 -7
- package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js +0 -2
- package/lib/esm/internal/app-binder/task/BuildTransactionContextTask.test.js.map +0 -7
- package/lib/esm/internal/app-binder/task/GetWeb3CheckTask.js +0 -2
- package/lib/esm/internal/app-binder/task/GetWeb3CheckTask.js.map +0 -7
- package/lib/esm/internal/app-binder/task/GetWeb3CheckTask.test.js +0 -2
- package/lib/esm/internal/app-binder/task/GetWeb3CheckTask.test.js.map +0 -7
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js +0 -2
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.js.map +0 -7
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js +0 -2
- package/lib/esm/internal/app-binder/task/ProvideTransactionContextTask.test.js.map +0 -7
- package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js +0 -2
- package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.js.map +0 -7
- package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js +0 -2
- package/lib/esm/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.js.map +0 -7
- package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.js +0 -2
- package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.js.map +0 -7
- package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js +0 -2
- package/lib/esm/internal/app-binder/task/ProvideTransactionGenericContextTask.test.js.map +0 -7
- package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.js +0 -2
- package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.js.map +0 -7
- package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js +0 -2
- package/lib/esm/internal/transaction/service/mapper/EthersRawTransactionMapper.test.js.map +0 -7
- package/lib/esm/internal/transaction/service/mapper/TransactionMapper.js +0 -1
- package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js +0 -2
- package/lib/esm/internal/transaction/service/mapper/TransactionMapperService.test.js.map +0 -7
- package/lib/types/internal/app-binder/constant/plugins.d.ts +0 -2
- package/lib/types/internal/app-binder/constant/plugins.d.ts.map +0 -1
- package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts +0 -32
- package/lib/types/internal/app-binder/task/BuildTransactionContextTask.d.ts.map +0 -1
- package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts +0 -2
- package/lib/types/internal/app-binder/task/BuildTransactionContextTask.test.d.ts.map +0 -1
- package/lib/types/internal/app-binder/task/GetWeb3CheckTask.d.ts +0 -30
- package/lib/types/internal/app-binder/task/GetWeb3CheckTask.d.ts.map +0 -1
- package/lib/types/internal/app-binder/task/GetWeb3CheckTask.test.d.ts +0 -2
- package/lib/types/internal/app-binder/task/GetWeb3CheckTask.test.d.ts.map +0 -1
- package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts +0 -38
- package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.d.ts.map +0 -1
- package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts +0 -2
- package/lib/types/internal/app-binder/task/ProvideTransactionContextTask.test.d.ts.map +0 -1
- package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts +0 -80
- package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.d.ts.map +0 -1
- package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts +0 -2
- package/lib/types/internal/app-binder/task/ProvideTransactionFieldDescriptionTask.test.d.ts.map +0 -1
- package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts +0 -28
- package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.d.ts.map +0 -1
- package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts +0 -2
- package/lib/types/internal/app-binder/task/ProvideTransactionGenericContextTask.test.d.ts.map +0 -1
- package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.d.ts +0 -7
- package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.d.ts.map +0 -1
- package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.test.d.ts +0 -2
- package/lib/types/internal/transaction/service/mapper/EthersRawTransactionMapper.test.d.ts.map +0 -1
- package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts +0 -6
- package/lib/types/internal/transaction/service/mapper/TransactionMapper.d.ts.map +0 -1
- package/lib/types/internal/transaction/service/mapper/TransactionMapperService.test.d.ts +0 -2
- package/lib/types/internal/transaction/service/mapper/TransactionMapperService.test.d.ts.map +0 -1
- /package/lib/esm/{internal/transaction/service/mapper/TransactionMapper.js.map → api/app-binder/SignDelegationAuthorizationTypes.js.map} +0 -0
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.ts"],
|
|
4
|
-
"sourcesContent": ["/* eslint @typescript-eslint/consistent-type-imports: 0 */\nimport {\n ClearSignContextType,\n type ContextModule,\n} from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n DeviceActionStatus,\n DeviceModelId,\n DeviceSessionStateType,\n DeviceStatus,\n hexaStringToBuffer,\n UnknownDAError,\n UserInteractionRequired,\n} from \"@ledgerhq/device-management-kit\";\nimport { InvalidStatusWordError } from \"@ledgerhq/device-management-kit\";\nimport { Transaction } from \"ethers\";\nimport { Just, Nothing } from \"purify-ts\";\n\nimport {\n type SignTransactionDAState,\n SignTransactionDAStep,\n} from \"@api/app-binder/SignTransactionDeviceActionTypes\";\nimport { TransactionType } from \"@api/model/TransactionType\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport { setupOpenAppDAMock } from \"@internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock\";\nimport { testDeviceActionStates } from \"@internal/app-binder/device-action/__test-utils__/testDeviceActionStates\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\n\nimport { SignTransactionDeviceAction } from \"./SignTransactionDeviceAction\";\n\nvi.mock(\"@ledgerhq/device-management-kit\", async (importOriginal) => {\n const original =\n await importOriginal<typeof import(\"@ledgerhq/device-management-kit\")>();\n return {\n ...original,\n OpenAppDeviceAction: vi.fn(() => ({\n makeStateMachine: vi.fn(),\n })),\n };\n});\n\ndescribe(\"SignTransactionDeviceAction\", () => {\n const contextModuleMock: ContextModule = {\n getContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n getWeb3Checks: vi.fn(),\n };\n const mapperMock: TransactionMapperService = {\n mapTransactionToSubset: vi.fn(),\n } as unknown as TransactionMapperService;\n const parserMock: TransactionParserService = {\n extractValue: vi.fn(),\n } as unknown as TransactionParserService;\n const getAppConfigMock = vi.fn();\n const web3CheckOptInMock = vi.fn();\n const buildContextMock = vi.fn();\n const provideContextMock = vi.fn();\n const provideGenericContextMock = vi.fn();\n const signTransactionMock = vi.fn();\n function extractDependenciesMock() {\n return {\n getAppConfig: getAppConfigMock,\n web3CheckOptIn: web3CheckOptInMock,\n buildContext: buildContextMock,\n provideContext: provideContextMock,\n provideGenericContext: provideGenericContextMock,\n signTransaction: signTransactionMock,\n };\n }\n const apiMock = makeDeviceActionInternalApiMock();\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\n function createAppConfig(\n version: string,\n web3ChecksEnabled: boolean,\n web3ChecksOptIn: boolean,\n ) {\n return {\n blindSigningEnabled: false,\n web3ChecksEnabled,\n web3ChecksOptIn,\n version,\n };\n }\n\n function setupAppConfig(\n version: string,\n web3ChecksEnabled: boolean,\n web3ChecksOptIn: boolean,\n ) {\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version },\n deviceModelId: DeviceModelId.FLEX,\n isSecureConnectionAllowed: false,\n });\n getAppConfigMock.mockResolvedValue(\n CommandResultFactory({\n data: createAppConfig(version, web3ChecksEnabled, web3ChecksOptIn),\n }),\n );\n }\n\n beforeEach(() => {\n vi.clearAllMocks();\n });\n\n describe(\"Happy path\", () => {\n it(\"should call external dependencies with the correct parameters\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n chainId: 1,\n transactionType: TransactionType.LEGACY,\n web3Check: null,\n });\n provideContextMock.mockResolvedValueOnce(Nothing);\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> BuildContext -> ProvideContext -> SignTransaction\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n step: SignTransactionDAStep.SIGN_TRANSACTION,\n },\n status: DeviceActionStatus.Pending,\n },\n // Final state\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onDone: () => {\n // Verify mocks calls parameters\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.15.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n\n expect(provideContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n web3Check: null,\n },\n }),\n );\n\n expect(signTransactionMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n isLegacy: true,\n chainId: 1,\n transactionType: TransactionType.LEGACY,\n },\n }),\n );\n resolve();\n },\n onError: reject,\n });\n }));\n\n it(\"should call external dependencies with the correct parameters with the generic parser\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: {\n transactionInfo: \"payload-1\",\n transactionFields: [\n {\n type: \"enum\",\n payload: \"payload-2\",\n },\n ],\n },\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n chainId: 7,\n transactionType: TransactionType.EIP1559,\n web3Check: null,\n });\n provideGenericContextMock.mockResolvedValueOnce(Nothing);\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> BuildContext -> ProvideGenericContext -> SignTransaction\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.PROVIDE_GENERIC_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n step: SignTransactionDAStep.SIGN_TRANSACTION,\n },\n status: DeviceActionStatus.Pending,\n },\n // Final state\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: () => {\n // Verify mocks calls parameters\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.15.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n\n expect(provideGenericContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n chainId: 7,\n context: {\n transactionInfo: \"payload-1\",\n transactionFields: [\n {\n type: \"enum\",\n payload: \"payload-2\",\n },\n ],\n },\n contextModule: contextModuleMock,\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n transactionParser: parserMock,\n web3Check: null,\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n isLegacy: false,\n chainId: 7,\n transactionType: TransactionType.EIP1559,\n },\n }),\n );\n resolve();\n },\n });\n }));\n\n it(\"should fallback to blind signing if provideContext return an error\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n chainId: 1,\n transactionType: TransactionType.LEGACY,\n web3Check: null,\n });\n provideContextMock.mockResolvedValueOnce(\n Just(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"provideContext error\"),\n }),\n ),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> BuildContext -> ProvideContext -> SignTransaction\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n step: SignTransactionDAStep.SIGN_TRANSACTION,\n },\n status: DeviceActionStatus.Pending,\n },\n // Final state\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: () => {\n // Verify mocks calls parameters\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.15.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n expect(provideContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n web3Check: null,\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n isLegacy: true,\n chainId: 1,\n transactionType: TransactionType.LEGACY,\n },\n }),\n );\n resolve();\n },\n });\n }));\n\n it(\"should fallback to blind signing if provideGenericContext return an error\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: {\n transactionInfo: \"payload-1\",\n transactionFields: [\n {\n type: \"enum\",\n payload: \"payload-2\",\n },\n ],\n },\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n chainId: 7,\n transactionType: TransactionType.EIP1559,\n web3Check: null,\n });\n\n provideGenericContextMock.mockResolvedValueOnce(\n Just(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"provideGenericContext error\"),\n }),\n ),\n );\n\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> BuildContext -> ProvideGenericContext -> SignTransaction\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.PROVIDE_GENERIC_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n step: SignTransactionDAStep.SIGN_TRANSACTION,\n },\n status: DeviceActionStatus.Pending,\n },\n // Final state\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: () => {\n // Verify mocks calls parameters\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.15.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n\n expect(provideGenericContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n chainId: 7,\n context: {\n transactionInfo: \"payload-1\",\n transactionFields: [\n {\n type: \"enum\",\n payload: \"payload-2\",\n },\n ],\n },\n contextModule: contextModuleMock,\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n transactionParser: parserMock,\n web3Check: null,\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n isLegacy: false,\n chainId: 7,\n transactionType: TransactionType.EIP1559,\n },\n }),\n );\n resolve();\n },\n });\n }));\n });\n\n describe(\"Web3Checks\", () => {\n it(\"should call external dependencies with web3Checks enabled and supported\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.16.0\", true, true);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n buildContextMock.mockRejectedValueOnce(\n new InvalidStatusWordError(\"buildContext error\"),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> GetAppConfig -> BuildContext\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext error\n {\n error: new InvalidStatusWordError(\"buildContext error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onDone: () => {\n // Verify mocks calls parameters\n expect(getAppConfigMock).toHaveBeenCalled();\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.16.0\", true, true),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n resolve();\n },\n onError: reject,\n });\n }));\n\n it(\"should call external dependencies with web3Checks supported but disabled\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.16.0\", false, true);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n buildContextMock.mockRejectedValueOnce(\n new InvalidStatusWordError(\"buildContext error\"),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> GetAppConfig -> BuildContext\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext error\n {\n error: new InvalidStatusWordError(\"buildContext error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onDone: () => {\n // Verify mocks calls parameters\n expect(getAppConfigMock).toHaveBeenCalled();\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.16.0\", false, true),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n resolve();\n },\n onError: reject,\n });\n }));\n\n it(\"should call external dependencies with web3Checks opt-in, then enabled\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.16.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n web3CheckOptInMock.mockResolvedValueOnce(\n CommandResultFactory({ data: { enabled: true } }),\n );\n buildContextMock.mockRejectedValueOnce(\n new InvalidStatusWordError(\"buildContext error\"),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> GetAppConfig -> Web3ChecksOptIn -> BuildContext\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // Web3ChecksOptIn state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.Web3ChecksOptIn,\n step: SignTransactionDAStep.WEB3_CHECKS_OPT_IN,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext error\n {\n error: new InvalidStatusWordError(\"buildContext error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onDone: () => {\n // Verify mocks calls parameters\n expect(getAppConfigMock).toHaveBeenCalled();\n expect(web3CheckOptInMock).toHaveBeenCalled();\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.16.0\", true, false),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n resolve();\n },\n onError: reject,\n });\n }));\n\n it(\"should call external dependencies with web3Checks opt-in, then disabled\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.16.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n web3CheckOptInMock.mockResolvedValueOnce(\n CommandResultFactory({ data: { enabled: false } }),\n );\n buildContextMock.mockRejectedValueOnce(\n new InvalidStatusWordError(\"buildContext error\"),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> GetAppConfig -> Web3ChecksOptIn -> BuildContext\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // Web3ChecksOptIn state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.Web3ChecksOptIn,\n step: SignTransactionDAStep.WEB3_CHECKS_OPT_IN,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext error\n {\n error: new InvalidStatusWordError(\"buildContext error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onDone: () => {\n // Verify mocks calls parameters\n expect(getAppConfigMock).toHaveBeenCalled();\n expect(web3CheckOptInMock).toHaveBeenCalled();\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.16.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n resolve();\n },\n onError: reject,\n });\n }));\n\n it(\"should provide web3Checks context if getWeb3Check return a value\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n // Mock the dependencies to return some sample data\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n chainId: 1,\n transactionType: TransactionType.LEGACY,\n web3Check: {\n type: ClearSignContextType.ENUM,\n id: 1,\n payload: \"0x01020304\",\n value: 1,\n certificate: undefined,\n },\n });\n provideContextMock.mockResolvedValueOnce(Nothing);\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n // Expected intermediate values for the following state sequence:\n // Initial -> OpenApp -> BuildContext -> ProvideContext -> SignTransaction\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n step: SignTransactionDAStep.SIGN_TRANSACTION,\n },\n status: DeviceActionStatus.Pending,\n },\n // Final state\n {\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n status: DeviceActionStatus.Completed,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: () => {\n // Verify mocks calls parameters\n expect(buildContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n mapper: mapperMock,\n options: defaultOptions,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.15.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n expect(provideContextMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n web3Check: {\n type: ClearSignContextType.ENUM,\n id: 1,\n payload: \"0x01020304\",\n value: 1,\n certificate: undefined,\n },\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenCalledWith(\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n isLegacy: true,\n chainId: 1,\n transactionType: TransactionType.LEGACY,\n },\n }),\n );\n resolve();\n },\n });\n }));\n });\n\n describe(\"OpenApp errors\", () => {\n it(\"should fail if OpenApp throw an error\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock(new UnknownDAError(\"OpenApp error\"));\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp error\n {\n error: new UnknownDAError(\"OpenApp error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: () => {\n resolve();\n },\n });\n }));\n });\n\n describe(\"BuildContext errors\", () => {\n it(\"should fail if buildContext throws an error\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n buildContextMock.mockRejectedValueOnce(\n new InvalidStatusWordError(\"buildContext error\"),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext error\n {\n error: new InvalidStatusWordError(\"buildContext error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n });\n\n describe(\"ProvideContext errors\", () => {\n it(\"should fail if provideContext throws an error\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n web3Check: null,\n });\n provideContextMock.mockRejectedValueOnce(\n new InvalidStatusWordError(\"provideContext error\"),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext error\n {\n error: new InvalidStatusWordError(\"provideContext error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n });\n\n describe(\"SignTransaction errors\", () => {\n it(\"should fail if signTransaction returns an error\", () =>\n new Promise<void>((resolve, reject) => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n buildContextMock.mockResolvedValueOnce({\n clearSignContexts: [\n {\n type: \"token\",\n payload: \"payload-1\",\n },\n ],\n serializedTransaction: new Uint8Array([0x01, 0x02, 0x03]),\n web3Check: null,\n });\n provideContextMock.mockResolvedValueOnce(Nothing);\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"signTransaction error\"),\n }),\n );\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n const expectedStates: Array<SignTransactionDAState> = [\n // Initial state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // OpenApp interaction\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.ConfirmOpenApp,\n step: SignTransactionDAStep.OPEN_APP,\n },\n status: DeviceActionStatus.Pending,\n },\n // GetAppConfig state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.GET_APP_CONFIG,\n },\n status: DeviceActionStatus.Pending,\n },\n // BuildContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.BUILD_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // ProvideContext state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTransactionDAStep.PROVIDE_CONTEXT,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction state\n {\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTransaction,\n step: SignTransactionDAStep.SIGN_TRANSACTION,\n },\n status: DeviceActionStatus.Pending,\n },\n // SignTransaction error\n {\n error: new InvalidStatusWordError(\"signTransaction error\"),\n status: DeviceActionStatus.Error,\n },\n ];\n\n testDeviceActionStates(deviceAction, expectedStates, apiMock, {\n onError: reject,\n onDone: resolve,\n });\n }));\n });\n});\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["ClearSignContextType", "CommandResultFactory", "DeviceActionStatus", "DeviceModelId", "DeviceSessionStateType", "DeviceStatus", "hexaStringToBuffer", "
|
|
4
|
+
"sourcesContent": ["/* eslint @typescript-eslint/consistent-type-imports: 0 */\nimport {\n ClearSignContextType,\n type ContextModule,\n TransactionSubset,\n} from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n DeviceActionState,\n DeviceActionStatus,\n DeviceModelId,\n DeviceSessionStateType,\n DeviceStatus,\n hexaStringToBuffer,\n InvalidStatusWordError,\n TransportDeviceModel,\n UserInteractionRequired,\n} from \"@ledgerhq/device-management-kit\";\nimport { Transaction } from \"ethers\";\nimport { Just } from \"purify-ts\";\nimport { lastValueFrom, Observable } from \"rxjs\";\n\nimport {\n SignTransactionDAError,\n SignTransactionDAIntermediateValue,\n type SignTransactionDAState,\n SignTransactionDAStep,\n} from \"@api/app-binder/SignTransactionDeviceActionTypes\";\nimport { Signature } from \"@api/index\";\nimport { ClearSigningType } from \"@api/model/ClearSigningType\";\nimport { TransactionType } from \"@api/model/TransactionType\";\nimport { makeDeviceActionInternalApiMock } from \"@internal/app-binder/device-action/__test-utils__/makeInternalApi\";\nimport { setupOpenAppDAMock } from \"@internal/app-binder/device-action/__test-utils__/setupOpenAppDAMock\";\nimport { executeUntilStep } from \"@internal/app-binder/device-action/__test-utils__/testDeviceActionUntilStep\";\nimport { ContextWithSubContexts } from \"@internal/app-binder/task/BuildFullContextsTask\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\n\nimport { SignTransactionDeviceAction } from \"./SignTransactionDeviceAction\";\n\nvi.mock(\"@ledgerhq/device-management-kit\", async (importOriginal) => {\n const original =\n await importOriginal<typeof import(\"@ledgerhq/device-management-kit\")>();\n return {\n ...original,\n OpenAppDeviceAction: vi.fn(() => ({\n makeStateMachine: vi.fn(),\n })),\n };\n});\n\ndescribe(\"SignTransactionDeviceAction\", () => {\n let observable: Observable<\n DeviceActionState<\n Signature,\n SignTransactionDAError,\n SignTransactionDAIntermediateValue\n >\n >;\n const contextModuleMock = {\n getFieldContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n };\n const mapperMock: TransactionMapperService = {\n mapTransactionToSubset: vi.fn(),\n } as unknown as TransactionMapperService;\n const parserMock: TransactionParserService = {\n extractValue: vi.fn(),\n } as unknown as TransactionParserService;\n const getAppConfigMock = vi.fn();\n const web3CheckOptInMock = vi.fn();\n const parseTransactionMock = vi.fn();\n const buildContextsMock = vi.fn();\n const provideContextsMock = vi.fn();\n const signTransactionMock = vi.fn();\n const getAddressMock = vi.fn();\n function extractDependenciesMock() {\n return {\n getAppConfig: getAppConfigMock,\n web3CheckOptIn: web3CheckOptInMock,\n parseTransaction: parseTransactionMock,\n buildContexts: buildContextsMock,\n provideContexts: provideContextsMock,\n signTransaction: signTransactionMock,\n getAddress: getAddressMock,\n };\n }\n const apiMock = makeDeviceActionInternalApiMock();\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 defaultSubset: TransactionSubset = {\n chainId: 1,\n data: \"0x\",\n selector: \"0x\",\n to: \"0x\",\n value: 0n,\n };\n const defaultAddress = \"0x8ceb23fd6bc0add59e62ac25578270cff1b9f619\";\n\n function createAppConfig(\n version: string,\n web3ChecksEnabled: boolean,\n web3ChecksOptIn: boolean,\n ) {\n return {\n blindSigningEnabled: false,\n web3ChecksEnabled,\n web3ChecksOptIn,\n version,\n };\n }\n\n function setupAppConfig(\n version: string,\n web3ChecksEnabled: boolean,\n web3ChecksOptIn: boolean,\n ) {\n apiMock.getDeviceSessionState.mockReturnValueOnce({\n sessionStateType: DeviceSessionStateType.ReadyWithoutSecureChannel,\n deviceStatus: DeviceStatus.CONNECTED,\n installedApps: [],\n currentApp: { name: \"Ethereum\", version },\n deviceModelId: DeviceModelId.FLEX,\n isSecureConnectionAllowed: false,\n });\n apiMock.getDeviceModel.mockReturnValueOnce({\n id: DeviceModelId.FLEX,\n } as unknown as TransportDeviceModel);\n getAppConfigMock.mockResolvedValue(\n CommandResultFactory({\n data: createAppConfig(version, web3ChecksEnabled, web3ChecksOptIn),\n }),\n );\n }\n\n const getStep = (s: Array<SignTransactionDAState>, index: number) => {\n if (s[index]?.status !== DeviceActionStatus.Pending) {\n throw new Error(\n `Step ${index} is not pending: ${JSON.stringify(s[index])}`,\n );\n }\n return s[index];\n };\n\n describe(\"Happy path\", () => {\n describe(\"should sign a transaction\", () => {\n const contexts: ContextWithSubContexts[] = [\n {\n context: {\n type: ClearSignContextType.TRANSACTION_INFO,\n payload: \"payload-1\",\n },\n subcontextCallbacks: [],\n },\n {\n context: {\n type: ClearSignContextType.TRANSACTION_FIELD_DESCRIPTION,\n payload: \"payload-2\",\n },\n subcontextCallbacks: [],\n },\n ];\n\n beforeEach(() => {\n vi.resetAllMocks();\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n\n // Mock the dependencies to return some sample data\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: contexts,\n clearSigningType: ClearSigningType.EIP7730,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n observable = deviceAction._execute(apiMock).observable;\n });\n\n it(\"should open the app\", async () => {\n const { steps } = await executeUntilStep(0, observable);\n expect(getStep(steps, 0).intermediateValue.step).toBe(\n SignTransactionDAStep.OPEN_APP,\n );\n });\n\n it(\"should confirm open app\", async () => {\n const { steps } = await executeUntilStep(1, observable);\n expect(\n getStep(steps, 1).intermediateValue.requiredUserInteraction,\n ).toBe(UserInteractionRequired.ConfirmOpenApp);\n });\n\n it(\"should get app config\", async () => {\n const { steps } = await executeUntilStep(2, observable);\n expect(getStep(steps, 2).intermediateValue.step).toBe(\n SignTransactionDAStep.GET_APP_CONFIG,\n );\n });\n\n it(\"should prebuild context\", async () => {\n const { steps } = await executeUntilStep(3, observable);\n expect(getStep(steps, 3).intermediateValue.step).toBe(\n SignTransactionDAStep.PARSE_TRANSACTION,\n );\n expect(parseTransactionMock).toHaveBeenCalledTimes(1);\n expect(parseTransactionMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n mapper: mapperMock,\n transaction: defaultTransaction,\n },\n }),\n );\n });\n\n it(\"should get address\", async () => {\n const { steps } = await executeUntilStep(4, observable);\n expect(getStep(steps, 4).intermediateValue.step).toBe(\n SignTransactionDAStep.GET_ADDRESS,\n );\n });\n\n it(\"should build context\", async () => {\n const { steps } = await executeUntilStep(5, observable);\n expect(getStep(steps, 5).intermediateValue.step).toBe(\n SignTransactionDAStep.BUILD_CONTEXTS,\n );\n expect(buildContextsMock).toHaveBeenCalledTimes(1);\n expect(buildContextsMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n contextModule: contextModuleMock,\n parser: parserMock,\n mapper: mapperMock,\n options: defaultOptions,\n subset: { ...defaultSubset, from: defaultAddress },\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.15.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n deviceModelId: DeviceModelId.FLEX,\n },\n }),\n );\n });\n\n it(\"should provide context\", async () => {\n const { steps } = await executeUntilStep(6, observable);\n expect(getStep(steps, 6).intermediateValue.step).toBe(\n SignTransactionDAStep.PROVIDE_CONTEXTS,\n );\n expect(provideContextsMock).toHaveBeenCalledTimes(1);\n expect(provideContextsMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n contexts: contexts,\n serializedTransaction: defaultTransaction,\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n });\n\n it(\"should sign transaction\", async () => {\n const { steps } = await executeUntilStep(7, observable);\n expect(getStep(steps, 7).intermediateValue.step).toBe(\n SignTransactionDAStep.SIGN_TRANSACTION,\n );\n expect(signTransactionMock).toHaveBeenCalledTimes(1);\n expect(signTransactionMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: defaultTransaction,\n chainId: 1,\n transactionType: TransactionType.EIP1559,\n clearSigningType: ClearSigningType.EIP7730,\n },\n }),\n );\n });\n\n it(\"should return the signature\", async () => {\n const result = await lastValueFrom(observable);\n expect(result).toEqual({\n status: DeviceActionStatus.Completed,\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n });\n });\n });\n\n describe(\"should skip open app\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: { ...defaultOptions, skipOpenApp: true },\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n observable = deviceAction._execute(apiMock).observable;\n });\n\n it(\"should skip open app and get app config directly\", async () => {\n const { steps } = await executeUntilStep(0, observable);\n\n expect(getStep(steps, 0).intermediateValue.step).toBe(\n SignTransactionDAStep.GET_APP_CONFIG,\n );\n });\n });\n\n describe(\"should opt in to web3 checks\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n setupOpenAppDAMock();\n setupAppConfig(\"1.16.0\", false, false);\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n web3CheckOptInMock.mockResolvedValueOnce(\n CommandResultFactory({ data: { enabled: true } }),\n );\n\n observable = deviceAction._execute(apiMock).observable;\n });\n\n it(\"should opt in to web3 checks if app config is supported and not already enabled\", async () => {\n const { steps } = await executeUntilStep(4, observable);\n\n expect(getStep(steps, 3).intermediateValue.step).toBe(\n SignTransactionDAStep.WEB3_CHECKS_OPT_IN,\n );\n expect(web3CheckOptInMock).toHaveBeenCalledTimes(1);\n\n expect(getStep(steps, 4).intermediateValue.step).toBe(\n SignTransactionDAStep.WEB3_CHECKS_OPT_IN_RESULT,\n );\n // @ts-expect-error - result is not typed\n expect(getStep(steps, 4).intermediateValue.result).toBe(true);\n });\n });\n\n describe(\"should not opt in to web3 checks\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n setupOpenAppDAMock();\n\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n\n observable = deviceAction._execute(apiMock).observable;\n });\n\n it(\"should not opt in to web3 checks if app config is not supported\", async () => {\n setupAppConfig(\"1.15.0\", false, false);\n await executeUntilStep(3, observable);\n expect(web3CheckOptInMock).not.toHaveBeenCalled();\n });\n\n it(\"should not opt in to web3 checks if already enabled\", async () => {\n setupAppConfig(\"1.16.0\", true, false);\n await executeUntilStep(3, observable);\n expect(web3CheckOptInMock).not.toHaveBeenCalled();\n });\n\n it(\"should not opt in to web3 checks if already opted out\", async () => {\n setupAppConfig(\"1.16.0\", false, true);\n await executeUntilStep(3, observable);\n expect(web3CheckOptInMock).not.toHaveBeenCalled();\n });\n });\n });\n\n describe(\"Error cases\", () => {\n beforeEach(() => {\n vi.resetAllMocks();\n });\n\n it(\"should return an error if the open app throw an error\", async () => {\n // GIVEN\n setupOpenAppDAMock(new Error(\"Open app failed\"));\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new Error(\"Open app failed\"),\n });\n });\n\n it(\"should return an error if the get app config return an error\", async () => {\n // GIVEN\n setupOpenAppDAMock();\n getAppConfigMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"Get app config failed\"),\n }),\n );\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new InvalidStatusWordError(\"Get app config failed\"),\n });\n });\n\n it(\"should return an error if the get app config throw an error\", async () => {\n // GIVEN\n setupOpenAppDAMock();\n getAppConfigMock.mockRejectedValueOnce(\n new Error(\"Get app config failed\"),\n );\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new Error(\"Get app config failed\"),\n });\n });\n\n it(\"should ignore the web3checks result if the command fails\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.16.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n web3CheckOptInMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"web3 check opt in failed\"),\n }),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Completed,\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n });\n });\n\n it(\"should return an error if the parse transaction throw an error\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockRejectedValueOnce(\n new Error(\"Parse transaction failed\"),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new Error(\"Parse transaction failed\"),\n });\n });\n\n it(\"should blind sign if the first sign transaction fails and the second sign transaction succeeds\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"Sign transaction failed\"),\n }),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Completed,\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n });\n });\n\n it(\"should blind sign if the first sign transaction throws an error and the second sign transaction succeeds\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.EIP7730,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockRejectedValueOnce(\n new Error(\"Sign transaction failed\"),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Completed,\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n });\n expect(signTransactionMock).toHaveBeenCalledTimes(2);\n expect(signTransactionMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: defaultTransaction,\n chainId: 1,\n transactionType: TransactionType.EIP1559,\n clearSigningType: ClearSigningType.EIP7730,\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenNthCalledWith(\n 2,\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: defaultTransaction,\n chainId: 1,\n transactionType: TransactionType.EIP1559,\n clearSigningType: ClearSigningType.BASIC, // fallback to basic\n },\n }),\n );\n });\n\n it(\"should return an error if the sign transaction return two times an error\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"Sign transaction failed\"),\n }),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"Blind sign transaction failed\"),\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new InvalidStatusWordError(\"Blind sign transaction failed\"),\n });\n });\n\n it(\"should return an error if the blind sign transaction fallback throws an error\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: new InvalidStatusWordError(\"Sign transaction failed\"),\n }),\n );\n signTransactionMock.mockRejectedValueOnce(\n new Error(\"Blind sign transaction fallback failed\"),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: new Error(\"Blind sign transaction fallback failed\"),\n });\n });\n\n it(\"should return an error without trying blind sign fallback when user refuses transaction (error code 6985)\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n\n // Create an error with the user refusal error code\n const userRefusalError = new InvalidStatusWordError(\n \"User refused transaction\",\n );\n (\n userRefusalError as InvalidStatusWordError & { errorCode: string }\n ).errorCode = \"6985\";\n\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: userRefusalError,\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Error,\n error: userRefusalError,\n });\n // Verify that signTransaction was only called once (no blind sign fallback attempt)\n expect(signTransactionMock).toHaveBeenCalledTimes(1);\n });\n\n it(\"should try blind sign fallback when error is not user refusal (different error code)\", async () => {\n setupOpenAppDAMock();\n setupAppConfig(\"1.15.0\", false, false);\n const deviceAction = new SignTransactionDeviceAction({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n transaction: defaultTransaction,\n options: defaultOptions,\n contextModule: contextModuleMock as unknown as ContextModule,\n mapper: mapperMock,\n parser: parserMock,\n },\n });\n vi.spyOn(deviceAction, \"extractDependencies\").mockReturnValue(\n extractDependenciesMock(),\n );\n parseTransactionMock.mockResolvedValueOnce({\n subset: defaultSubset,\n type: TransactionType.EIP1559,\n });\n getAddressMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: { address: defaultAddress },\n }),\n );\n buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.EIP7730,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n\n // Create an error with a different error code (not user refusal)\n const otherError = new InvalidStatusWordError(\"Some other error\");\n (otherError as InvalidStatusWordError & { errorCode: string }).errorCode =\n \"6A80\";\n\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n error: otherError,\n }),\n );\n signTransactionMock.mockResolvedValueOnce(\n CommandResultFactory({\n data: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n }),\n );\n observable = deviceAction._execute(apiMock).observable;\n\n // WHEN\n const result = await lastValueFrom(observable);\n\n // THEN\n expect(result).toEqual({\n status: DeviceActionStatus.Completed,\n output: {\n v: 0x1c,\n r: \"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad789\",\n s: \"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513\",\n },\n });\n // Verify that signTransaction was called twice (first attempt + blind sign fallback)\n expect(signTransactionMock).toHaveBeenCalledTimes(2);\n expect(signTransactionMock).toHaveBeenNthCalledWith(\n 1,\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: defaultTransaction,\n chainId: 1,\n transactionType: TransactionType.EIP1559,\n clearSigningType: ClearSigningType.EIP7730,\n },\n }),\n );\n expect(signTransactionMock).toHaveBeenNthCalledWith(\n 2,\n expect.objectContaining({\n input: {\n derivationPath: \"44'/60'/0'/0/0\",\n serializedTransaction: defaultTransaction,\n chainId: 1,\n transactionType: TransactionType.EIP1559,\n clearSigningType: ClearSigningType.BASIC, // fallback to basic\n },\n }),\n );\n });\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["ClearSignContextType", "CommandResultFactory", "DeviceActionStatus", "DeviceModelId", "DeviceSessionStateType", "DeviceStatus", "hexaStringToBuffer", "InvalidStatusWordError", "UserInteractionRequired", "Transaction", "Just", "lastValueFrom", "SignTransactionDAStep", "ClearSigningType", "TransactionType", "makeDeviceActionInternalApiMock", "setupOpenAppDAMock", "executeUntilStep", "SignTransactionDeviceAction", "importOriginal", "observable", "contextModuleMock", "mapperMock", "parserMock", "getAppConfigMock", "web3CheckOptInMock", "parseTransactionMock", "buildContextsMock", "provideContextsMock", "signTransactionMock", "getAddressMock", "extractDependenciesMock", "apiMock", "defaultOptions", "defaultTransaction", "defaultSubset", "defaultAddress", "createAppConfig", "version", "web3ChecksEnabled", "web3ChecksOptIn", "setupAppConfig", "getStep", "s", "index", "contexts", "deviceAction", "steps", "result", "userRefusalError", "otherError"]
|
|
7
7
|
}
|
package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{DeviceModelId as
|
|
1
|
+
import{DeviceModelId as s,isSuccessCommandResult as p,OpenAppDeviceAction as m,UnknownDAError as S,UserInteractionRequired as i,XStateDeviceAction as D}from"@ledgerhq/device-management-kit";import{Left as A,Nothing as T,Right as E}from"purify-ts";import{and as h,assign as n,fromPromise as o,setup as f}from"xstate";import{SignTypedDataDAStateStep as a}from"../../../../api/app-binder/SignTypedDataDeviceActionTypes";import{GetAddressCommand as v}from"../../../app-binder/command/GetAddressCommand";import{GetAppConfiguration as P}from"../../../app-binder/command/GetAppConfigurationCommand";import{SignEIP712Command as I}from"../../../app-binder/command/SignEIP712Command";import{Web3CheckOptInCommand as k}from"../../../app-binder/command/Web3CheckOptInCommand";import{BuildEIP712ContextTask as _}from"../../../app-binder/task/BuildEIP712ContextTask";import{ProvideEIP712ContextTask as x}from"../../../app-binder/task/ProvideEIP712ContextTask";import{SignTypedDataLegacyTask as O}from"../../../app-binder/task/SignTypedDataLegacyTask";import{ApplicationChecker as M}from"../../../shared/utils/ApplicationChecker";class Y extends D{makeStateMachine(r){const{getAddress:d,getAppConfig:u,web3CheckOptIn:g,buildContext:c,provideContext:l,signTypedData:y,signTypedDataLegacy:C}=this.extractDependencies(r);return f({types:{input:{},context:{},output:{}},actors:{openAppStateMachine:new m({input:{appName:"Ethereum"}}).makeStateMachine(r),getAddress:o(d),getAppConfig:o(u),web3CheckOptIn:o(g),buildContext:o(c),provideContext:o(l),signTypedData:o(y),signTypedDataLegacy:o(C)},guards:{noInternalError:({context:e})=>e._internalState.error===null,notRefusedByUser:({context:e})=>e._internalState.error!==null&&(!("errorCode"in e._internalState.error)||e._internalState.error.errorCode!=="6985"),isWeb3ChecksSupported:({context:e})=>new M(r.getDeviceSessionState(),e._internalState.appConfig).withMinVersionExclusive("1.15.0").excludeDeviceModel(s.NANO_S).excludeDeviceModel(s.NANO_SP).excludeDeviceModel(s.NANO_X).check(),shouldOptIn:({context:e})=>!e._internalState.appConfig.web3ChecksEnabled&&!e._internalState.appConfig.web3ChecksOptIn,skipOpenApp:({context:e})=>e.input.skipOpenApp},actions:{assignErrorFromEvent:n({_internalState:e=>({...e.context._internalState,error:e.event.error})})}}).createMachine({id:"SignTypedDataDeviceAction",initial:"InitialState",context:({input:e})=>({input:e,intermediateValue:{requiredUserInteraction:i.None,step:a.OPEN_APP},_internalState:{error:null,appConfig:null,from:null,typedDataContext:null,signature:null}}),states:{InitialState:{always:[{target:"GetAppConfig",guard:"skipOpenApp"},"OpenAppDeviceAction"]},OpenAppDeviceAction:{invoke:{id:"openAppStateMachine",input:{appName:"Ethereum"},src:"openAppStateMachine",onSnapshot:{actions:n({intermediateValue:e=>({...e.event.snapshot.context.intermediateValue,step:a.OPEN_APP})})},onDone:{actions:n({_internalState:e=>e.event.output.caseOf({Right:()=>e.context._internalState,Left:t=>({...e.context._internalState,error:t})})}),target:"CheckOpenAppDeviceActionResult"}}},CheckOpenAppDeviceActionResult:{always:[{target:"GetAppConfig",guard:"noInternalError"},"Error"]},GetAppConfig:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.GET_APP_CONFIG}}),invoke:{id:"getAppConfig",src:"getAppConfig",onDone:{target:"GetAppConfigResultCheck",actions:[n({_internalState:({event:e,context:t})=>p(e.output)?{...t._internalState,appConfig:e.output.data}:{...t._internalState,error:e.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},GetAppConfigResultCheck:{always:[{target:"Web3ChecksOptIn",guard:h(["noInternalError","isWeb3ChecksSupported","shouldOptIn"])},{target:"GetAddress",guard:"noInternalError"},{target:"Error"}]},Web3ChecksOptIn:{entry:n({intermediateValue:{requiredUserInteraction:i.Web3ChecksOptIn,step:a.WEB3_CHECKS_OPT_IN}}),invoke:{id:"web3CheckOptIn",src:"web3CheckOptIn",onDone:{target:"Web3ChecksOptInResult",actions:[n({_internalState:({event:e,context:t})=>p(e.output)?{...t._internalState,appConfig:{...t._internalState.appConfig,web3ChecksEnabled:e.output.data.enabled}}:t._internalState})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},Web3ChecksOptInResult:{entry:n(({context:e})=>({intermediateValue:{requiredUserInteraction:i.None,step:a.WEB3_CHECKS_OPT_IN_RESULT,result:e._internalState.appConfig.web3ChecksEnabled}})),after:{0:{target:"GetAddress"}}},GetAddress:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.GET_ADDRESS}}),invoke:{id:"getAddress",src:"getAddress",input:({context:e})=>({derivationPath:e.input.derivationPath}),onDone:{target:"BuildContext",actions:[n({_internalState:({event:e,context:t})=>p(e.output)?{...t._internalState,from:e.output.data.address}:{...t._internalState,error:e.output.error}})]},onError:{target:"Error"}}},BuildContext:{entry:n({intermediateValue:{requiredUserInteraction:i.None,step:a.BUILD_CONTEXT}}),invoke:{id:"buildContext",src:"buildContext",input:({context:e})=>({contextModule:e.input.contextModule,parser:e.input.parser,transactionParser:e.input.transactionParser,transactionMapper:e.input.transactionMapper,data:e.input.data,appConfig:e._internalState.appConfig,derivationPath:e.input.derivationPath,from:e._internalState.from}),onDone:{target:"ProvideContext",actions:[n({_internalState:({event:e,context:t})=>({...t._internalState,typedDataContext:e.output})})]},onError:{target:"SignTypedDataLegacy"}}},ProvideContext:{entry:n({intermediateValue:{requiredUserInteraction:i.SignTypedData,step:a.PROVIDE_CONTEXT}}),invoke:{id:"provideContext",src:"provideContext",input:({context:e})=>({contextModule:e.input.contextModule,taskArgs:e._internalState.typedDataContext}),onDone:{actions:n({_internalState:e=>p(e.event.output)?e.context._internalState:{...e.context._internalState,error:e.event.output.error}}),target:"ProvideContextResultCheck"},onError:{target:"Error",actions:"assignErrorFromEvent"}}},ProvideContextResultCheck:{always:[{guard:"noInternalError",target:"SignTypedData"},{guard:"notRefusedByUser",target:"SignTypedDataLegacy"},{target:"Error"}]},SignTypedData:{entry:n({intermediateValue:{requiredUserInteraction:i.SignTypedData,step:a.SIGN_TYPED_DATA}}),invoke:{id:"signTypedData",src:"signTypedData",input:({context:e})=>({derivationPath:e.input.derivationPath}),onDone:{target:"SignTypedDataResultCheck",actions:[n({_internalState:({event:e,context:t})=>p(e.output)?{...t._internalState,signature:e.output.data}:{...t._internalState,error:e.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},SignTypedDataResultCheck:{always:[{guard:"noInternalError",target:"Success"},{guard:"notRefusedByUser",target:"SignTypedDataLegacy"},{target:"Error"}]},SignTypedDataLegacy:{entry:n({intermediateValue:{requiredUserInteraction:i.SignTypedData,step:a.SIGN_TYPED_DATA_LEGACY}}),invoke:{id:"signTypedDataLegacy",src:"signTypedDataLegacy",input:({context:e})=>({derivationPath:e.input.derivationPath,data:e.input.data}),onDone:{target:"SignTypedDataLegacyResultCheck",actions:[n({_internalState:({event:e,context:t})=>p(e.output)?{...t._internalState,signature:e.output.data}:{...t._internalState,error:e.output.error}})]},onError:{target:"Error",actions:"assignErrorFromEvent"}}},SignTypedDataLegacyResultCheck:{always:[{guard:"noInternalError",target:"Success"},{target:"Error"}]},Success:{type:"final"},Error:{type:"final"}},output:({context:e})=>e._internalState.signature?E(e._internalState.signature):A(e._internalState.error||new S("No error in final state"))})}extractDependencies(r){return{getAddress:async e=>r.sendCommand(new v(e.input)),getAppConfig:async()=>r.sendCommand(new P),web3CheckOptIn:async()=>r.sendCommand(new k),buildContext:async e=>new _(r,e.input.contextModule,e.input.parser,e.input.transactionParser,e.input.transactionMapper,e.input.data,e.input.derivationPath,e.input.appConfig,e.input.from).run(),provideContext:async e=>new x(r,e.input.contextModule,e.input.taskArgs).run(),signTypedData:async e=>r.sendCommand(new I({derivationPath:e.input.derivationPath,legacyArgs:T})),signTypedDataLegacy:async e=>new O(r,e.input.data,e.input.derivationPath).run()}}}export{Y as SignTypedDataDeviceAction};
|
|
2
2
|
//# sourceMappingURL=SignTypedDataDeviceAction.js.map
|
package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.ts"],
|
|
4
|
-
"sourcesContent": ["import { type ContextModule } from \"@ledgerhq/context-module\";\nimport {\n type CommandResult,\n type DeviceActionStateMachine,\n DeviceModelId,\n type InternalApi,\n isSuccessCommandResult,\n OpenAppDeviceAction,\n type StateMachineTypes,\n UnknownDAError,\n UserInteractionRequired,\n XStateDeviceAction,\n} from \"@ledgerhq/device-management-kit\";\nimport { Just, Left, Nothing, Right } from \"purify-ts\";\nimport { and, assign, fromPromise, setup } from \"xstate\";\n\nimport { type GetConfigCommandResponse } from \"@api/app-binder/GetConfigCommandTypes\";\nimport {\n type SignTypedDataDAError,\n type SignTypedDataDAInput,\n type SignTypedDataDAIntermediateValue,\n type SignTypedDataDAInternalState,\n type SignTypedDataDAOutput,\n SignTypedDataDAStateStep,\n} from \"@api/app-binder/SignTypedDataDeviceActionTypes\";\nimport { type Signature } from \"@api/model/Signature\";\nimport { type TypedData } from \"@api/model/TypedData\";\nimport { GetAppConfiguration } from \"@internal/app-binder/command/GetAppConfigurationCommand\";\nimport { SignEIP712Command } from \"@internal/app-binder/command/SignEIP712Command\";\nimport { type EthErrorCodes } from \"@internal/app-binder/command/utils/ethAppErrors\";\nimport {\n Web3CheckOptInCommand,\n type Web3CheckOptInCommandResponse,\n} from \"@internal/app-binder/command/Web3CheckOptInCommand\";\nimport { ETHEREUM_PLUGINS } from \"@internal/app-binder/constant/plugins\";\nimport { BuildEIP712ContextTask } from \"@internal/app-binder/task/BuildEIP712ContextTask\";\nimport {\n ProvideEIP712ContextTask,\n type ProvideEIP712ContextTaskArgs,\n type ProvideEIP712ContextTaskReturnType,\n} from \"@internal/app-binder/task/ProvideEIP712ContextTask\";\nimport { ApplicationChecker } from \"@internal/shared/utils/ApplicationChecker\";\nimport { type TypedDataParserService } from \"@internal/typed-data/service/TypedDataParserService\";\n\nexport type MachineDependencies = {\n readonly getAppConfig: () => Promise<\n CommandResult<GetConfigCommandResponse, EthErrorCodes>\n >;\n readonly web3CheckOptIn: () => Promise<\n CommandResult<Web3CheckOptInCommandResponse, EthErrorCodes>\n >;\n readonly buildContext: (arg0: {\n input: {\n contextModule: ContextModule;\n parser: TypedDataParserService;\n data: TypedData;\n appConfig: GetConfigCommandResponse;\n derivationPath: string;\n };\n }) => Promise<ProvideEIP712ContextTaskArgs>;\n readonly provideContext: (arg0: {\n input: {\n contextModule: ContextModule;\n taskArgs: ProvideEIP712ContextTaskArgs;\n };\n }) => ProvideEIP712ContextTaskReturnType;\n readonly signTypedData: (arg0: {\n input: {\n derivationPath: string;\n };\n }) => Promise<CommandResult<Signature, EthErrorCodes>>;\n readonly signTypedDataLegacy: (arg0: {\n input: {\n derivationPath: string;\n domainHash: string;\n messageHash: string;\n };\n }) => Promise<CommandResult<Signature, EthErrorCodes>>;\n};\n\nexport class SignTypedDataDeviceAction extends XStateDeviceAction<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n> {\n makeStateMachine(\n internalApi: InternalApi,\n ): DeviceActionStateMachine<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n > {\n type types = StateMachineTypes<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n >;\n\n const {\n getAppConfig,\n web3CheckOptIn,\n buildContext,\n provideContext,\n signTypedData,\n signTypedDataLegacy,\n } = this.extractDependencies(internalApi);\n\n return setup({\n types: {\n input: {} as types[\"input\"],\n context: {} as types[\"context\"],\n output: {} as types[\"output\"],\n },\n actors: {\n openAppStateMachine: new OpenAppDeviceAction({\n input: { appName: \"Ethereum\" },\n }).makeStateMachine(internalApi),\n getAppConfig: fromPromise(getAppConfig),\n web3CheckOptIn: fromPromise(web3CheckOptIn),\n buildContext: fromPromise(buildContext),\n provideContext: fromPromise(provideContext),\n signTypedData: fromPromise(signTypedData),\n signTypedDataLegacy: fromPromise(signTypedDataLegacy),\n },\n guards: {\n noInternalError: ({ context }) => context._internalState.error === null,\n notRefusedByUser: ({ context }) =>\n context._internalState.error !== null &&\n (!(\"errorCode\" in context._internalState.error) ||\n context._internalState.error.errorCode !== \"6985\"),\n isWeb3ChecksSupported: ({ context }) =>\n new ApplicationChecker(\n internalApi.getDeviceSessionState(),\n context._internalState.appConfig!,\n )\n .withMinVersionExclusive(\"1.15.0\")\n .excludeDeviceModel(DeviceModelId.NANO_S)\n .check(),\n shouldOptIn: ({ context }) =>\n !context._internalState.appConfig!.web3ChecksEnabled &&\n !context._internalState.appConfig!.web3ChecksOptIn,\n },\n actions: {\n assignErrorFromEvent: assign({\n _internalState: (_) => ({\n ..._.context._internalState,\n error: _.event[\"error\"], // NOTE: it should never happen, the error is not typed anymore here\n }),\n }),\n },\n }).createMachine({\n id: \"SignTypedDataDeviceAction\",\n initial: \"OpenAppDeviceAction\",\n context: ({ input }) => {\n return {\n input,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n _internalState: {\n error: null,\n appConfig: null,\n typedDataContext: null,\n signature: null,\n },\n };\n },\n states: {\n OpenAppDeviceAction: {\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n }),\n invoke: {\n id: \"openAppStateMachine\",\n input: {\n appName: \"Ethereum\",\n compatibleAppNames: ETHEREUM_PLUGINS,\n },\n src: \"openAppStateMachine\",\n onSnapshot: {\n actions: assign({\n intermediateValue: (_) => ({\n ..._.event.snapshot.context.intermediateValue,\n step: SignTypedDataDAStateStep.OPEN_APP,\n }),\n }),\n },\n onDone: {\n actions: assign({\n _internalState: (_) => {\n return _.event.output.caseOf<SignTypedDataDAInternalState>({\n Right: () => _.context._internalState,\n Left: (error) => ({\n ..._.context._internalState,\n error,\n }),\n });\n },\n }),\n target: \"CheckOpenAppDeviceActionResult\",\n },\n },\n },\n CheckOpenAppDeviceActionResult: {\n always: [\n {\n target: \"GetAppConfig\",\n guard: \"noInternalError\",\n },\n \"Error\",\n ],\n },\n GetAppConfig: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n }),\n invoke: {\n id: \"getAppConfig\",\n src: \"getAppConfig\",\n onDone: {\n target: \"GetAppConfigResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n appConfig: event.output.data,\n };\n } else {\n return {\n ...context._internalState,\n error: event.output.error,\n };\n }\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n GetAppConfigResultCheck: {\n always: [\n {\n target: \"Web3ChecksOptIn\",\n guard: and([\n \"noInternalError\",\n \"isWeb3ChecksSupported\",\n \"shouldOptIn\",\n ]),\n },\n {\n target: \"BuildContext\",\n guard: \"noInternalError\",\n },\n {\n target: \"Error\",\n },\n ],\n },\n Web3ChecksOptIn: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.Web3ChecksOptIn,\n step: SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN,\n },\n }),\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN,\n },\n }),\n invoke: {\n id: \"web3CheckOptIn\",\n src: \"web3CheckOptIn\",\n onDone: {\n target: \"BuildContext\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n appConfig: {\n ...context._internalState.appConfig!,\n web3ChecksEnabled: event.output.data.enabled,\n },\n };\n } else {\n return context._internalState;\n }\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n BuildContext: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n }),\n invoke: {\n id: \"buildContext\",\n src: \"buildContext\",\n input: ({ context }) => ({\n contextModule: context.input.contextModule,\n parser: context.input.parser,\n data: context.input.data,\n appConfig: context._internalState.appConfig!,\n derivationPath: context.input.derivationPath,\n }),\n onDone: {\n target: \"ProvideContext\",\n actions: [\n assign({\n _internalState: ({ event, context }) => ({\n ...context._internalState,\n typedDataContext: event.output,\n }),\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n ProvideContext: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n }),\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n }),\n invoke: {\n id: \"provideContext\",\n src: \"provideContext\",\n input: ({ context }) => ({\n contextModule: context.input.contextModule,\n taskArgs: context._internalState.typedDataContext!,\n }),\n onDone: {\n actions: assign({\n _internalState: (_) => {\n if (isSuccessCommandResult(_.event.output)) {\n return _.context._internalState;\n }\n return {\n ..._.context._internalState,\n error: _.event.output.error,\n };\n },\n }),\n target: \"ProvideContextResultCheck\",\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n ProvideContextResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"SignTypedData\" },\n { guard: \"notRefusedByUser\", target: \"SignTypedDataLegacy\" },\n { target: \"Error\" },\n ],\n },\n SignTypedData: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA,\n },\n }),\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA,\n },\n }),\n invoke: {\n id: \"signTypedData\",\n src: \"signTypedData\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n }),\n onDone: {\n target: \"SignTypedDataResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n signature: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n SignTypedDataLegacy: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY,\n },\n }),\n exit: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY,\n },\n }),\n invoke: {\n id: \"signTypedDataLegacy\",\n src: \"signTypedDataLegacy\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n domainHash: context._internalState.typedDataContext!.domainHash,\n messageHash: context._internalState.typedDataContext!.messageHash,\n }),\n onDone: {\n target: \"SignTypedDataResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n signature: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n SignTypedDataResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"Success\" },\n { target: \"Error\" },\n ],\n },\n Success: {\n type: \"final\",\n },\n Error: {\n type: \"final\",\n },\n },\n output: ({ context }) =>\n context._internalState.signature\n ? Right(context._internalState.signature)\n : Left(\n context._internalState.error ||\n new UnknownDAError(\"No error in final state\"),\n ),\n });\n }\n\n extractDependencies(internalApi: InternalApi): MachineDependencies {\n const getAppConfig = async () =>\n internalApi.sendCommand(new GetAppConfiguration());\n const web3CheckOptIn = async () =>\n internalApi.sendCommand(new Web3CheckOptInCommand());\n const buildContext = async (arg0: {\n input: {\n contextModule: ContextModule;\n parser: TypedDataParserService;\n data: TypedData;\n appConfig: GetConfigCommandResponse;\n derivationPath: string;\n };\n }) =>\n new BuildEIP712ContextTask(\n internalApi,\n arg0.input.contextModule,\n arg0.input.parser,\n arg0.input.data,\n arg0.input.derivationPath,\n arg0.input.appConfig,\n ).run();\n\n const provideContext = async (arg0: {\n input: {\n contextModule: ContextModule;\n taskArgs: ProvideEIP712ContextTaskArgs;\n };\n }) =>\n new ProvideEIP712ContextTask(\n internalApi,\n arg0.input.contextModule,\n arg0.input.taskArgs,\n ).run();\n\n const signTypedData = async (arg0: {\n input: {\n derivationPath: string;\n };\n }): Promise<CommandResult<Signature, EthErrorCodes>> =>\n internalApi.sendCommand(\n new SignEIP712Command({\n derivationPath: arg0.input.derivationPath,\n legacyArgs: Nothing,\n }),\n );\n\n const signTypedDataLegacy = async (arg0: {\n input: {\n derivationPath: string;\n domainHash: string;\n messageHash: string;\n };\n }) =>\n internalApi.sendCommand(\n new SignEIP712Command({\n derivationPath: arg0.input.derivationPath,\n legacyArgs: Just({\n domainHash: arg0.input.domainHash,\n messageHash: arg0.input.messageHash,\n }),\n }),\n );\n\n return {\n getAppConfig,\n web3CheckOptIn,\n buildContext,\n provideContext,\n signTypedData,\n signTypedDataLegacy,\n };\n }\n}\n"],
|
|
5
|
-
"mappings": "AACA,OAGE,iBAAAA,EAEA,0BAAAC,EACA,uBAAAC,EAEA,kBAAAC,EACA,2BAAAC,EACA,sBAAAC,MACK,kCACP,OAAS,QAAAC,EAAM,
|
|
6
|
-
"names": ["DeviceModelId", "isSuccessCommandResult", "OpenAppDeviceAction", "UnknownDAError", "UserInteractionRequired", "XStateDeviceAction", "
|
|
4
|
+
"sourcesContent": ["import { type ContextModule } from \"@ledgerhq/context-module\";\nimport {\n type CommandResult,\n type DeviceActionStateMachine,\n DeviceModelId,\n type InternalApi,\n isSuccessCommandResult,\n OpenAppDeviceAction,\n type StateMachineTypes,\n UnknownDAError,\n UserInteractionRequired,\n XStateDeviceAction,\n} from \"@ledgerhq/device-management-kit\";\nimport { Left, Nothing, Right } from \"purify-ts\";\nimport { and, assign, fromPromise, setup } from \"xstate\";\n\nimport {\n type GetAddressCommandArgs,\n type GetAddressCommandResponse,\n} from \"@api/app-binder/GetAddressCommandTypes\";\nimport { type GetConfigCommandResponse } from \"@api/app-binder/GetConfigCommandTypes\";\nimport {\n type SignTypedDataDAError,\n type SignTypedDataDAInput,\n type SignTypedDataDAIntermediateValue,\n type SignTypedDataDAInternalState,\n type SignTypedDataDAOutput,\n SignTypedDataDAStateStep,\n} from \"@api/app-binder/SignTypedDataDeviceActionTypes\";\nimport { type Signature } from \"@api/model/Signature\";\nimport { type TypedData } from \"@api/model/TypedData\";\nimport { GetAddressCommand } from \"@internal/app-binder/command/GetAddressCommand\";\nimport { GetAppConfiguration } from \"@internal/app-binder/command/GetAppConfigurationCommand\";\nimport { SignEIP712Command } from \"@internal/app-binder/command/SignEIP712Command\";\nimport { type EthErrorCodes } from \"@internal/app-binder/command/utils/ethAppErrors\";\nimport {\n Web3CheckOptInCommand,\n type Web3CheckOptInCommandResponse,\n} from \"@internal/app-binder/command/Web3CheckOptInCommand\";\nimport { BuildEIP712ContextTask } from \"@internal/app-binder/task/BuildEIP712ContextTask\";\nimport {\n ProvideEIP712ContextTask,\n type ProvideEIP712ContextTaskArgs,\n type ProvideEIP712ContextTaskReturnType,\n} from \"@internal/app-binder/task/ProvideEIP712ContextTask\";\nimport { SignTypedDataLegacyTask } from \"@internal/app-binder/task/SignTypedDataLegacyTask\";\nimport { ApplicationChecker } from \"@internal/shared/utils/ApplicationChecker\";\nimport { type TransactionMapperService } from \"@internal/transaction/service/mapper/TransactionMapperService\";\nimport { type TransactionParserService } from \"@internal/transaction/service/parser/TransactionParserService\";\nimport { type TypedDataParserService } from \"@internal/typed-data/service/TypedDataParserService\";\n\nexport type MachineDependencies = {\n readonly getAddress: (arg0: {\n input: GetAddressCommandArgs;\n }) => Promise<CommandResult<GetAddressCommandResponse, EthErrorCodes>>;\n readonly getAppConfig: () => Promise<\n CommandResult<GetConfigCommandResponse, EthErrorCodes>\n >;\n readonly web3CheckOptIn: () => Promise<\n CommandResult<Web3CheckOptInCommandResponse, EthErrorCodes>\n >;\n readonly buildContext: (arg0: {\n input: {\n contextModule: ContextModule;\n parser: TypedDataParserService;\n data: TypedData;\n appConfig: GetConfigCommandResponse;\n derivationPath: string;\n transactionMapper: TransactionMapperService;\n transactionParser: TransactionParserService;\n from: string;\n };\n }) => Promise<ProvideEIP712ContextTaskArgs>;\n readonly provideContext: (arg0: {\n input: {\n contextModule: ContextModule;\n taskArgs: ProvideEIP712ContextTaskArgs;\n };\n }) => ProvideEIP712ContextTaskReturnType;\n readonly signTypedData: (arg0: {\n input: {\n derivationPath: string;\n };\n }) => Promise<CommandResult<Signature, EthErrorCodes>>;\n readonly signTypedDataLegacy: (arg0: {\n input: {\n derivationPath: string;\n data: TypedData;\n };\n }) => Promise<CommandResult<Signature, EthErrorCodes>>;\n};\n\nexport class SignTypedDataDeviceAction extends XStateDeviceAction<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n> {\n makeStateMachine(\n internalApi: InternalApi,\n ): DeviceActionStateMachine<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n > {\n type types = StateMachineTypes<\n SignTypedDataDAOutput,\n SignTypedDataDAInput,\n SignTypedDataDAError,\n SignTypedDataDAIntermediateValue,\n SignTypedDataDAInternalState\n >;\n\n const {\n getAddress,\n getAppConfig,\n web3CheckOptIn,\n buildContext,\n provideContext,\n signTypedData,\n signTypedDataLegacy,\n } = this.extractDependencies(internalApi);\n\n return setup({\n types: {\n input: {} as types[\"input\"],\n context: {} as types[\"context\"],\n output: {} as types[\"output\"],\n },\n actors: {\n openAppStateMachine: new OpenAppDeviceAction({\n input: { appName: \"Ethereum\" },\n }).makeStateMachine(internalApi),\n getAddress: fromPromise(getAddress),\n getAppConfig: fromPromise(getAppConfig),\n web3CheckOptIn: fromPromise(web3CheckOptIn),\n buildContext: fromPromise(buildContext),\n provideContext: fromPromise(provideContext),\n signTypedData: fromPromise(signTypedData),\n signTypedDataLegacy: fromPromise(signTypedDataLegacy),\n },\n guards: {\n noInternalError: ({ context }) => context._internalState.error === null,\n notRefusedByUser: ({ context }) =>\n context._internalState.error !== null &&\n (!(\"errorCode\" in context._internalState.error) ||\n context._internalState.error.errorCode !== \"6985\"),\n isWeb3ChecksSupported: ({ context }) =>\n new ApplicationChecker(\n internalApi.getDeviceSessionState(),\n context._internalState.appConfig!,\n )\n .withMinVersionExclusive(\"1.15.0\")\n .excludeDeviceModel(DeviceModelId.NANO_S)\n .excludeDeviceModel(DeviceModelId.NANO_SP)\n .excludeDeviceModel(DeviceModelId.NANO_X)\n .check(),\n shouldOptIn: ({ context }) =>\n !context._internalState.appConfig!.web3ChecksEnabled &&\n !context._internalState.appConfig!.web3ChecksOptIn,\n skipOpenApp: ({ context }) => context.input.skipOpenApp,\n },\n actions: {\n assignErrorFromEvent: assign({\n _internalState: (_) => ({\n ..._.context._internalState,\n error: _.event[\"error\"], // NOTE: it should never happen, the error is not typed anymore here\n }),\n }),\n },\n }).createMachine({\n id: \"SignTypedDataDeviceAction\",\n initial: \"InitialState\",\n context: ({ input }) => {\n return {\n input,\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.OPEN_APP,\n },\n _internalState: {\n error: null,\n appConfig: null,\n from: null,\n typedDataContext: null,\n signature: null,\n },\n };\n },\n states: {\n InitialState: {\n always: [\n {\n target: \"GetAppConfig\",\n guard: \"skipOpenApp\",\n },\n \"OpenAppDeviceAction\",\n ],\n },\n OpenAppDeviceAction: {\n invoke: {\n id: \"openAppStateMachine\",\n input: {\n appName: \"Ethereum\",\n },\n src: \"openAppStateMachine\",\n onSnapshot: {\n actions: assign({\n intermediateValue: (_) => ({\n ..._.event.snapshot.context.intermediateValue,\n step: SignTypedDataDAStateStep.OPEN_APP,\n }),\n }),\n },\n onDone: {\n actions: assign({\n _internalState: (_) => {\n return _.event.output.caseOf<SignTypedDataDAInternalState>({\n Right: () => _.context._internalState,\n Left: (error) => ({\n ..._.context._internalState,\n error,\n }),\n });\n },\n }),\n target: \"CheckOpenAppDeviceActionResult\",\n },\n },\n },\n CheckOpenAppDeviceActionResult: {\n always: [\n {\n target: \"GetAppConfig\",\n guard: \"noInternalError\",\n },\n \"Error\",\n ],\n },\n GetAppConfig: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_APP_CONFIG,\n },\n }),\n invoke: {\n id: \"getAppConfig\",\n src: \"getAppConfig\",\n onDone: {\n target: \"GetAppConfigResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n appConfig: event.output.data,\n };\n } else {\n return {\n ...context._internalState,\n error: event.output.error,\n };\n }\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n GetAppConfigResultCheck: {\n always: [\n {\n target: \"Web3ChecksOptIn\",\n guard: and([\n \"noInternalError\",\n \"isWeb3ChecksSupported\",\n \"shouldOptIn\",\n ]),\n },\n {\n target: \"GetAddress\",\n guard: \"noInternalError\",\n },\n {\n target: \"Error\",\n },\n ],\n },\n Web3ChecksOptIn: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.Web3ChecksOptIn,\n step: SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN,\n },\n }),\n invoke: {\n id: \"web3CheckOptIn\",\n src: \"web3CheckOptIn\",\n onDone: {\n target: \"Web3ChecksOptInResult\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n appConfig: {\n ...context._internalState.appConfig!,\n web3ChecksEnabled: event.output.data.enabled,\n },\n };\n } else {\n return context._internalState;\n }\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n Web3ChecksOptInResult: {\n entry: assign(({ context }) => ({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN_RESULT,\n result: context._internalState.appConfig!.web3ChecksEnabled,\n },\n })),\n // Using after transition to force a snapshot of the state after the entry action\n // This ensures the intermediateValue is captured before moving to BuildContext\n after: {\n 0: {\n target: \"GetAddress\",\n },\n },\n },\n GetAddress: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.GET_ADDRESS,\n },\n }),\n invoke: {\n id: \"getAddress\",\n src: \"getAddress\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n }),\n onDone: {\n target: \"BuildContext\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n from: event.output.data.address,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n },\n },\n },\n BuildContext: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.None,\n step: SignTypedDataDAStateStep.BUILD_CONTEXT,\n },\n }),\n invoke: {\n id: \"buildContext\",\n src: \"buildContext\",\n input: ({ context }) => ({\n contextModule: context.input.contextModule,\n parser: context.input.parser,\n transactionParser: context.input.transactionParser,\n transactionMapper: context.input.transactionMapper,\n data: context.input.data,\n appConfig: context._internalState.appConfig!,\n derivationPath: context.input.derivationPath,\n from: context._internalState.from!,\n }),\n onDone: {\n target: \"ProvideContext\",\n actions: [\n assign({\n _internalState: ({ event, context }) => ({\n ...context._internalState,\n typedDataContext: event.output,\n }),\n }),\n ],\n },\n onError: {\n target: \"SignTypedDataLegacy\",\n },\n },\n },\n ProvideContext: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.PROVIDE_CONTEXT,\n },\n }),\n invoke: {\n id: \"provideContext\",\n src: \"provideContext\",\n input: ({ context }) => ({\n contextModule: context.input.contextModule,\n taskArgs: context._internalState.typedDataContext!,\n }),\n onDone: {\n actions: assign({\n _internalState: (_) => {\n if (isSuccessCommandResult(_.event.output)) {\n return _.context._internalState;\n }\n return {\n ..._.context._internalState,\n error: _.event.output.error,\n };\n },\n }),\n target: \"ProvideContextResultCheck\",\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n ProvideContextResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"SignTypedData\" },\n { guard: \"notRefusedByUser\", target: \"SignTypedDataLegacy\" },\n { target: \"Error\" },\n ],\n },\n SignTypedData: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA,\n },\n }),\n invoke: {\n id: \"signTypedData\",\n src: \"signTypedData\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n }),\n onDone: {\n target: \"SignTypedDataResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n signature: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n SignTypedDataResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"Success\" },\n { guard: \"notRefusedByUser\", target: \"SignTypedDataLegacy\" },\n { target: \"Error\" },\n ],\n },\n SignTypedDataLegacy: {\n entry: assign({\n intermediateValue: {\n requiredUserInteraction: UserInteractionRequired.SignTypedData,\n step: SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY,\n },\n }),\n invoke: {\n id: \"signTypedDataLegacy\",\n src: \"signTypedDataLegacy\",\n input: ({ context }) => ({\n derivationPath: context.input.derivationPath,\n data: context.input.data,\n }),\n onDone: {\n target: \"SignTypedDataLegacyResultCheck\",\n actions: [\n assign({\n _internalState: ({ event, context }) => {\n if (isSuccessCommandResult(event.output)) {\n return {\n ...context._internalState,\n signature: event.output.data,\n };\n }\n return {\n ...context._internalState,\n error: event.output.error,\n };\n },\n }),\n ],\n },\n onError: {\n target: \"Error\",\n actions: \"assignErrorFromEvent\",\n },\n },\n },\n SignTypedDataLegacyResultCheck: {\n always: [\n { guard: \"noInternalError\", target: \"Success\" },\n { target: \"Error\" },\n ],\n },\n Success: {\n type: \"final\",\n },\n Error: {\n type: \"final\",\n },\n },\n output: ({ context }) =>\n context._internalState.signature\n ? Right(context._internalState.signature)\n : Left(\n context._internalState.error ||\n new UnknownDAError(\"No error in final state\"),\n ),\n });\n }\n\n extractDependencies(internalApi: InternalApi): MachineDependencies {\n const getAddress = async (arg0: { input: GetAddressCommandArgs }) =>\n internalApi.sendCommand(new GetAddressCommand(arg0.input));\n const getAppConfig = async () =>\n internalApi.sendCommand(new GetAppConfiguration());\n const web3CheckOptIn = async () =>\n internalApi.sendCommand(new Web3CheckOptInCommand());\n const buildContext = async (arg0: {\n input: {\n contextModule: ContextModule;\n parser: TypedDataParserService;\n data: TypedData;\n appConfig: GetConfigCommandResponse;\n derivationPath: string;\n transactionMapper: TransactionMapperService;\n transactionParser: TransactionParserService;\n from: string;\n };\n }) =>\n new BuildEIP712ContextTask(\n internalApi,\n arg0.input.contextModule,\n arg0.input.parser,\n arg0.input.transactionParser,\n arg0.input.transactionMapper,\n arg0.input.data,\n arg0.input.derivationPath,\n arg0.input.appConfig,\n arg0.input.from,\n ).run();\n\n const provideContext = async (arg0: {\n input: {\n contextModule: ContextModule;\n taskArgs: ProvideEIP712ContextTaskArgs;\n };\n }) =>\n new ProvideEIP712ContextTask(\n internalApi,\n arg0.input.contextModule,\n arg0.input.taskArgs,\n ).run();\n\n const signTypedData = async (arg0: {\n input: {\n derivationPath: string;\n };\n }): Promise<CommandResult<Signature, EthErrorCodes>> =>\n internalApi.sendCommand(\n new SignEIP712Command({\n derivationPath: arg0.input.derivationPath,\n legacyArgs: Nothing,\n }),\n );\n\n const signTypedDataLegacy = async (arg0: {\n input: {\n derivationPath: string;\n data: TypedData;\n };\n }) =>\n new SignTypedDataLegacyTask(\n internalApi,\n arg0.input.data,\n arg0.input.derivationPath,\n ).run();\n\n return {\n getAddress,\n getAppConfig,\n web3CheckOptIn,\n buildContext,\n provideContext,\n signTypedData,\n signTypedDataLegacy,\n };\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["DeviceModelId", "isSuccessCommandResult", "OpenAppDeviceAction", "UnknownDAError", "UserInteractionRequired", "XStateDeviceAction", "Left", "Nothing", "Right", "and", "assign", "fromPromise", "setup", "SignTypedDataDAStateStep", "GetAddressCommand", "GetAppConfiguration", "SignEIP712Command", "Web3CheckOptInCommand", "BuildEIP712ContextTask", "ProvideEIP712ContextTask", "SignTypedDataLegacyTask", "ApplicationChecker", "SignTypedDataDeviceAction", "internalApi", "getAddress", "getAppConfig", "web3CheckOptIn", "buildContext", "provideContext", "signTypedData", "signTypedDataLegacy", "context", "_", "input", "error", "event", "arg0"]
|
|
7
7
|
}
|