@ledgerhq/device-signer-kit-ethereum 0.0.0-multisig-20250822145545 → 0.0.0-multisig-20250905101831

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.
Files changed (99) hide show
  1. package/lib/cjs/api/SignerEthBuilder.test.js +1 -1
  2. package/lib/cjs/api/SignerEthBuilder.test.js.map +1 -1
  3. package/lib/cjs/internal/app-binder/EthAppBinder.test.js +1 -1
  4. package/lib/cjs/internal/app-binder/EthAppBinder.test.js.map +2 -2
  5. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.js +2 -0
  6. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.js.map +7 -0
  7. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js +2 -0
  8. package/lib/cjs/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js.map +7 -0
  9. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +1 -1
  10. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +2 -2
  11. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
  12. package/lib/cjs/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +2 -2
  13. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +1 -1
  14. package/lib/cjs/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +2 -2
  15. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.js +1 -1
  16. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.js.map +3 -3
  17. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.test.js +1 -1
  18. package/lib/cjs/internal/app-binder/task/BuildBaseContexts.test.js.map +2 -2
  19. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js +1 -1
  20. package/lib/cjs/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +2 -2
  21. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.js +1 -1
  22. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.js.map +2 -2
  23. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.test.js +1 -1
  24. package/lib/cjs/internal/app-binder/task/BuildFullContextsTask.test.js.map +3 -3
  25. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.js +1 -1
  26. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.js.map +3 -3
  27. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.test.js +1 -1
  28. package/lib/cjs/internal/app-binder/task/BuildSubcontextsTask.test.js.map +3 -3
  29. package/lib/cjs/internal/app-binder/task/ParseNestedTransactionTask.js.map +2 -2
  30. package/lib/cjs/internal/app-binder/task/ProvideContextsTask.js +1 -1
  31. package/lib/cjs/internal/app-binder/task/ProvideContextsTask.js.map +3 -3
  32. package/lib/cjs/internal/app-binder/task/ProvideContextsTask.test.js +1 -1
  33. package/lib/cjs/internal/app-binder/task/ProvideContextsTask.test.js.map +3 -3
  34. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js +1 -1
  35. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.js.map +3 -3
  36. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js +1 -1
  37. package/lib/cjs/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +3 -3
  38. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js +1 -1
  39. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.js.map +3 -3
  40. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js +1 -1
  41. package/lib/cjs/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +3 -3
  42. package/lib/esm/api/SignerEthBuilder.test.js +1 -1
  43. package/lib/esm/api/SignerEthBuilder.test.js.map +1 -1
  44. package/lib/esm/internal/app-binder/EthAppBinder.test.js +1 -1
  45. package/lib/esm/internal/app-binder/EthAppBinder.test.js.map +2 -2
  46. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.js +2 -0
  47. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.js.map +7 -0
  48. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js +2 -0
  49. package/lib/esm/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.js.map +7 -0
  50. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js +1 -1
  51. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.js.map +2 -2
  52. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js +1 -1
  53. package/lib/esm/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.test.js.map +2 -2
  54. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js +1 -1
  55. package/lib/esm/internal/app-binder/device-action/SignTypedData/SignTypedDataDeviceAction.test.js.map +2 -2
  56. package/lib/esm/internal/app-binder/task/BuildBaseContexts.js +1 -1
  57. package/lib/esm/internal/app-binder/task/BuildBaseContexts.js.map +3 -3
  58. package/lib/esm/internal/app-binder/task/BuildBaseContexts.test.js +1 -1
  59. package/lib/esm/internal/app-binder/task/BuildBaseContexts.test.js.map +2 -2
  60. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js +1 -1
  61. package/lib/esm/internal/app-binder/task/BuildEIP712ContextTask.test.js.map +2 -2
  62. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.js +1 -1
  63. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.js.map +2 -2
  64. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.test.js +1 -1
  65. package/lib/esm/internal/app-binder/task/BuildFullContextsTask.test.js.map +3 -3
  66. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.js +1 -1
  67. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.js.map +3 -3
  68. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.test.js +1 -1
  69. package/lib/esm/internal/app-binder/task/BuildSubcontextsTask.test.js.map +3 -3
  70. package/lib/esm/internal/app-binder/task/ParseNestedTransactionTask.js.map +2 -2
  71. package/lib/esm/internal/app-binder/task/ProvideContextsTask.js +1 -1
  72. package/lib/esm/internal/app-binder/task/ProvideContextsTask.js.map +3 -3
  73. package/lib/esm/internal/app-binder/task/ProvideContextsTask.test.js +1 -1
  74. package/lib/esm/internal/app-binder/task/ProvideContextsTask.test.js.map +3 -3
  75. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js +1 -1
  76. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.js.map +3 -3
  77. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js +1 -1
  78. package/lib/esm/internal/app-binder/task/ProvideEIP712ContextTask.test.js.map +3 -3
  79. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js +1 -1
  80. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.js.map +3 -3
  81. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js +1 -1
  82. package/lib/esm/internal/app-binder/task/SendPayloadInChunksTask.test.js.map +3 -3
  83. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.d.ts +28 -0
  84. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.d.ts.map +1 -0
  85. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.d.ts +2 -0
  86. package/lib/types/internal/app-binder/command/ProvideNetworkConfigurationCommand.test.d.ts.map +1 -0
  87. package/lib/types/internal/app-binder/device-action/SignTransaction/SignTransactionDeviceAction.d.ts.map +1 -1
  88. package/lib/types/internal/app-binder/task/BuildBaseContexts.d.ts.map +1 -1
  89. package/lib/types/internal/app-binder/task/BuildFullContextsTask.d.ts +2 -1
  90. package/lib/types/internal/app-binder/task/BuildFullContextsTask.d.ts.map +1 -1
  91. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.d.ts +10 -2
  92. package/lib/types/internal/app-binder/task/BuildSubcontextsTask.d.ts.map +1 -1
  93. package/lib/types/internal/app-binder/task/ParseNestedTransactionTask.d.ts.map +1 -1
  94. package/lib/types/internal/app-binder/task/ProvideContextsTask.d.ts.map +1 -1
  95. package/lib/types/internal/app-binder/task/ProvideEIP712ContextTask.d.ts.map +1 -1
  96. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts +1 -0
  97. package/lib/types/internal/app-binder/task/SendPayloadInChunksTask.d.ts.map +1 -1
  98. package/lib/types/tsconfig.prod.tsbuildinfo +1 -1
  99. package/package.json +9 -9
@@ -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 TransactionSubset,\n} from \"@ledgerhq/context-module\";\nimport {\n CommandResultFactory,\n DeviceActionState,\n DeviceActionStatus,\n DeviceModelId,\n DeviceSessionStateType,\n DeviceStatus,\n hexaStringToBuffer,\n InvalidStatusWordError,\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: ContextModule = {\n getContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n getWeb3Checks: vi.fn(),\n getSolanaContext: 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 function extractDependenciesMock() {\n return {\n getAppConfig: getAppConfigMock,\n web3CheckOptIn: web3CheckOptInMock,\n parseTransaction: parseTransactionMock,\n buildContexts: buildContextsMock,\n provideContexts: provideContextsMock,\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 const defaultSubset: TransactionSubset = {\n chainId: 1,\n data: \"0x\",\n selector: \"0x\",\n to: \"0x\",\n value: 0n,\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 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\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,\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 build context\", async () => {\n const { steps } = await executeUntilStep(4, observable);\n expect(getStep(steps, 4).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,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.15.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n });\n\n it(\"should provide context\", async () => {\n const { steps } = await executeUntilStep(5, observable);\n expect(getStep(steps, 5).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(6, observable);\n expect(getStep(steps, 6).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\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,\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,\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,\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,\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,\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,\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,\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 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,\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 build contexts fails\", async () => {\n // TODO: implement this test\n });\n\n it(\"should blind sign if the provide contexts fails\", async () => {\n // TODO: implement this test\n });\n\n it(\"should return an error if the sign transaction fails\", 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,\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 buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockRejectedValueOnce(\n new Error(\"Sign 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(\"Sign transaction failed\"),\n });\n });\n\n it(\"should return an error if the sign transaction return 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,\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 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 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(\"Sign transaction failed\"),\n });\n });\n });\n});\n"],
5
- "mappings": "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",
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 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: ContextModule = {\n getFieldContext: vi.fn(),\n getContexts: vi.fn(),\n getTypedDataFilters: vi.fn(),\n getWeb3Checks: vi.fn(),\n getSolanaContext: vi.fn(),\n getProxyDelegateCall: 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 function extractDependenciesMock() {\n return {\n getAppConfig: getAppConfigMock,\n web3CheckOptIn: web3CheckOptInMock,\n parseTransaction: parseTransactionMock,\n buildContexts: buildContextsMock,\n provideContexts: provideContextsMock,\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 const defaultSubset: TransactionSubset = {\n chainId: 1,\n data: \"0x\",\n selector: \"0x\",\n to: \"0x\",\n value: 0n,\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 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\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,\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 build context\", async () => {\n const { steps } = await executeUntilStep(4, observable);\n expect(getStep(steps, 4).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,\n transaction: defaultTransaction,\n appConfig: createAppConfig(\"1.15.0\", false, false),\n derivationPath: \"44'/60'/0'/0/0\",\n },\n }),\n );\n });\n\n it(\"should provide context\", async () => {\n const { steps } = await executeUntilStep(5, observable);\n expect(getStep(steps, 5).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(6, observable);\n expect(getStep(steps, 6).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\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,\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,\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,\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,\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,\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,\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,\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 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,\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 build contexts fails\", async () => {\n // TODO: implement this test\n });\n\n it(\"should blind sign if the provide contexts fails\", async () => {\n // TODO: implement this test\n });\n\n it(\"should return an error if the sign transaction fails\", 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,\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 buildContextsMock.mockResolvedValueOnce({\n clearSignContexts: [],\n clearSignContextsOptional: [],\n clearSigningType: ClearSigningType.BASIC,\n });\n provideContextsMock.mockResolvedValueOnce(Just(void 0));\n signTransactionMock.mockRejectedValueOnce(\n new Error(\"Sign 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(\"Sign transaction failed\"),\n });\n });\n\n it(\"should return an error if the sign transaction return 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,\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 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 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(\"Sign transaction failed\"),\n });\n });\n });\n});\n"],
5
+ "mappings": "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",
6
6
  "names": ["import_context_module", "import_device_management_kit", "import_ethers", "import_purify_ts", "import_rxjs", "import_SignTransactionDeviceActionTypes", "import_ClearSigningType", "import_TransactionType", "import_makeInternalApi", "import_setupOpenAppDAMock", "import_testDeviceActionUntilStep", "import_SignTransactionDeviceAction", "importOriginal", "observable", "contextModuleMock", "mapperMock", "parserMock", "getAppConfigMock", "web3CheckOptInMock", "parseTransactionMock", "buildContextsMock", "provideContextsMock", "signTransactionMock", "extractDependenciesMock", "apiMock", "defaultOptions", "defaultTransaction", "defaultSubset", "createAppConfig", "version", "web3ChecksEnabled", "web3ChecksOptIn", "setupAppConfig", "getStep", "s", "index", "contexts", "deviceAction", "steps", "result"]
7
7
  }
@@ -1,2 +1,2 @@
1
- "use strict";var e=require("@ledgerhq/device-management-kit"),I=require("purify-ts"),t=require("../../../../api/app-binder/SignTypedDataDeviceActionTypes"),x=require("../../../app-binder/command/utils/ethAppErrors"),b=require("../../../app-binder/device-action/__test-utils__/makeInternalApi"),u=require("../../../app-binder/device-action/__test-utils__/setupOpenAppDAMock"),l=require("../../../app-binder/device-action/__test-utils__/testDeviceActionStates"),D=require("../../../typed-data/model/Types"),P=require("./SignTypedDataDeviceAction");vi.mock("@ledgerhq/device-management-kit",async s=>({...await s(),OpenAppDeviceAction:vi.fn(()=>({makeStateMachine:vi.fn()}))}));describe("SignTypedDataDeviceAction",()=>{const s={domain:{},message:{},primaryType:"TestMessage",types:{}},g={web3Check:null,types:{PermitSingle:{details:new D.StructType("PermitDetails"),spender:new D.PrimitiveType("address","address",I.Nothing),sigDeadline:new D.PrimitiveType("uint256","uint",(0,I.Just)(32))}},domain:[{path:"chainId",type:"uint256",value:new D.TypedDataValueField(Uint8Array.from([137]))}],message:[{path:"details.expiration",type:"uint48",value:new D.TypedDataValueField(Uint8Array.from([19]))}],clearSignContext:(0,I.Just)({type:"success",messageInfo:{displayName:"Permit2",filtersCount:1,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"},trustedNamesAddresses:{},tokens:{},filters:{"details.amount":{displayName:"Amount allowance",path:"details.amount",signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",tokenIndex:255,type:"amount"}}})},o={parse:vi.fn()},d={getContext:vi.fn(),getContexts:vi.fn(),getTypedDataFilters:vi.fn(),getWeb3Checks:vi.fn(),getSolanaContext:vi.fn()},p=(0,b.makeDeviceActionInternalApiMock)(),O=vi.fn(),E=vi.fn(),c=vi.fn(),A=vi.fn(),C=vi.fn(),v=vi.fn();function m(){return{getAppConfig:O,web3CheckOptIn:E,buildContext:c,provideContext:A,signTypedData:C,signTypedDataLegacy:v}}function T(a,r,n){return{blindSigningEnabled:!1,web3ChecksEnabled:r,web3ChecksOptIn:n,version:a}}function f(a,r,n){p.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:a},deviceModelId:e.DeviceModelId.FLEX,isSecureConnectionAllowed:!1}),O.mockResolvedValue((0,e.CommandResultFactory)({data:T(a,r,n)}))}beforeEach(()=>{vi.resetAllMocks()}),describe("Success case",()=>{it("should call external dependencies with the correct parameters",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(g),A.mockResolvedValueOnce((0,e.CommandResultFactory)({data:void 0})),C.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA},status:e.DeviceActionStatus.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.DeviceActionStatus.Completed}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:()=>{expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,parser:o,data:s,appConfig:T("1.15.0",!1,!1),derivationPath:"44'/60'/0'/0/0"}})),expect(A).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,taskArgs:g}})),expect(C).toHaveBeenCalledWith(expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0"}})),a()}})})),it("should be successful whlie skipping OpenApp",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!0}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(g),A.mockResolvedValueOnce((0,e.CommandResultFactory)({data:void 0})),C.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA},status:e.DeviceActionStatus.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.DeviceActionStatus.Completed}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})})),it("should fallback to legacy signing if the new one fails",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(g),A.mockResolvedValueOnce((0,e.CommandResultFactory)({error:(0,x.EthAppCommandErrorFactory)({errorCode:"6a80",message:""})})),v.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.DeviceActionStatus.Completed}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})})),it("should fallback to legacy signing BuildContext fails",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockRejectedValueOnce(new e.UnknownDAError("Error")),v.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.DeviceActionStatus.Completed}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})})),it("should not fallback to legacy signing if rejected by the user during streaming",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(g),A.mockResolvedValueOnce((0,e.CommandResultFactory)({error:(0,x.EthAppCommandErrorFactory)({errorCode:"6985",message:""})})),v.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{error:(0,x.EthAppCommandErrorFactory)({errorCode:"6985",message:""}),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})}))}),describe("Web3Checks",()=>{it("should call external dependencies with web3Checks enabled and supported",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.16.0",!0,!0);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockRejectedValueOnce(new e.InvalidStatusWordError("buildContext error")),v.mockRejectedValueOnce(new e.InvalidStatusWordError("signTypedDataLegacy error"));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{error:new e.InvalidStatusWordError("signTypedDataLegacy error"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:()=>{expect(O).toHaveBeenCalled(),expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,parser:o,data:s,appConfig:T("1.16.0",!0,!0),derivationPath:"44'/60'/0'/0/0"}})),a()}})})),it("should call external dependencies with web3Checks supported but disabled",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.16.0",!1,!0);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockRejectedValueOnce(new e.InvalidStatusWordError("buildContext error")),v.mockRejectedValueOnce(new e.InvalidStatusWordError("signTypedDataLegacy error"));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{error:new e.InvalidStatusWordError("signTypedDataLegacy error"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:()=>{expect(O).toHaveBeenCalled(),expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,parser:o,data:s,appConfig:T("1.16.0",!1,!0),derivationPath:"44'/60'/0'/0/0"}})),a()}})})),it("should call external dependencies with web3Checks opt-in, then enabled",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.16.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),E.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{enabled:!0}})),c.mockRejectedValueOnce(new e.InvalidStatusWordError("buildContext error")),v.mockRejectedValueOnce(new e.InvalidStatusWordError("signTypedDataLegacy error"));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.Web3ChecksOptIn,step:t.SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN_RESULT,result:!0},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{error:new e.InvalidStatusWordError("signTypedDataLegacy error"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:()=>{expect(O).toHaveBeenCalled(),expect(E).toHaveBeenCalled(),expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,parser:o,data:s,appConfig:T("1.16.0",!0,!1),derivationPath:"44'/60'/0'/0/0"}})),a()}})})),it("should call external dependencies with web3Checks opt-in, then disabled",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.16.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),E.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{enabled:!1}})),c.mockRejectedValueOnce(new e.InvalidStatusWordError("buildContext error")),v.mockRejectedValueOnce(new e.InvalidStatusWordError("signTypedDataLegacy error"));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.Web3ChecksOptIn,step:t.SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN_RESULT,result:!1},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{error:new e.InvalidStatusWordError("signTypedDataLegacy error"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:()=>{expect(O).toHaveBeenCalled(),expect(E).toHaveBeenCalled(),expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,parser:o,data:s,appConfig:T("1.16.0",!1,!1),derivationPath:"44'/60'/0'/0/0"}})),a()}})}))}),describe("error cases",()=>{it("Error if the open app fails",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(new e.UnknownDAError("Mocked error"));const n=[{status:e.DeviceActionStatus.Pending,intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP}},{status:e.DeviceActionStatus.Pending,intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP}},{status:e.DeviceActionStatus.Error,error:new e.UnknownDAError("Mocked error")}],i=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});(0,l.testDeviceActionStates)(i,n,p,{onError:r,onDone:a})})),it("Error thrown while providing context",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(g),A.mockRejectedValueOnce(new e.UnknownDAError("Error"));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{error:new e.UnknownDAError("Error"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})})),it("Error while signing",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),f("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(g),A.mockResolvedValueOnce((0,e.CommandResultFactory)({data:void 0})),C.mockResolvedValueOnce((0,e.CommandResultFactory)({error:new e.UnknownDeviceExchangeError("Error while signing the typed data")}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA},status:e.DeviceActionStatus.Pending},{error:new e.UnknownDeviceExchangeError("Error while signing the typed data"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})}))})});
1
+ "use strict";var e=require("@ledgerhq/device-management-kit"),I=require("purify-ts"),t=require("../../../../api/app-binder/SignTypedDataDeviceActionTypes"),x=require("../../../app-binder/command/utils/ethAppErrors"),b=require("../../../app-binder/device-action/__test-utils__/makeInternalApi"),u=require("../../../app-binder/device-action/__test-utils__/setupOpenAppDAMock"),l=require("../../../app-binder/device-action/__test-utils__/testDeviceActionStates"),D=require("../../../typed-data/model/Types"),P=require("./SignTypedDataDeviceAction");vi.mock("@ledgerhq/device-management-kit",async s=>({...await s(),OpenAppDeviceAction:vi.fn(()=>({makeStateMachine:vi.fn()}))}));describe("SignTypedDataDeviceAction",()=>{const s={domain:{},message:{},primaryType:"TestMessage",types:{}},f={web3Check:null,types:{PermitSingle:{details:new D.StructType("PermitDetails"),spender:new D.PrimitiveType("address","address",I.Nothing),sigDeadline:new D.PrimitiveType("uint256","uint",(0,I.Just)(32))}},domain:[{path:"chainId",type:"uint256",value:new D.TypedDataValueField(Uint8Array.from([137]))}],message:[{path:"details.expiration",type:"uint48",value:new D.TypedDataValueField(Uint8Array.from([19]))}],clearSignContext:(0,I.Just)({type:"success",messageInfo:{displayName:"Permit2",filtersCount:1,signature:"3045022100e3c597d13d28a87a88b0239404c668373cf5063362f2a81d09eed4582941dfe802207669aabb504fd5b95b2734057f6b8bbf51f14a69a5f9bdf658a5952cefbf44d3"},trustedNamesAddresses:{},tokens:{},filters:{"details.amount":{displayName:"Amount allowance",path:"details.amount",signature:"304402201a46e6b4ef89eaf9fcf4945d053bfc5616a826400fd758312fbbe976bafc07ec022025a9b408722baf983ee053f90179c75b0c55bb0668f437d55493e36069bbd5a3",tokenIndex:255,type:"amount"}}})},o={parse:vi.fn()},d={getFieldContext:vi.fn(),getContexts:vi.fn(),getTypedDataFilters:vi.fn(),getWeb3Checks:vi.fn(),getSolanaContext:vi.fn(),getProxyDelegateCall:vi.fn()},p=(0,b.makeDeviceActionInternalApiMock)(),O=vi.fn(),E=vi.fn(),c=vi.fn(),A=vi.fn(),C=vi.fn(),v=vi.fn();function m(){return{getAppConfig:O,web3CheckOptIn:E,buildContext:c,provideContext:A,signTypedData:C,signTypedDataLegacy:v}}function T(a,r,n){return{blindSigningEnabled:!1,web3ChecksEnabled:r,web3ChecksOptIn:n,version:a}}function g(a,r,n){p.getDeviceSessionState.mockReturnValueOnce({sessionStateType:e.DeviceSessionStateType.ReadyWithoutSecureChannel,deviceStatus:e.DeviceStatus.CONNECTED,installedApps:[],currentApp:{name:"Ethereum",version:a},deviceModelId:e.DeviceModelId.FLEX,isSecureConnectionAllowed:!1}),O.mockResolvedValue((0,e.CommandResultFactory)({data:T(a,r,n)}))}beforeEach(()=>{vi.resetAllMocks()}),describe("Success case",()=>{it("should call external dependencies with the correct parameters",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(f),A.mockResolvedValueOnce((0,e.CommandResultFactory)({data:void 0})),C.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA},status:e.DeviceActionStatus.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.DeviceActionStatus.Completed}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:()=>{expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,parser:o,data:s,appConfig:T("1.15.0",!1,!1),derivationPath:"44'/60'/0'/0/0"}})),expect(A).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,taskArgs:f}})),expect(C).toHaveBeenCalledWith(expect.objectContaining({input:{derivationPath:"44'/60'/0'/0/0"}})),a()}})})),it("should be successful whlie skipping OpenApp",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!0}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(f),A.mockResolvedValueOnce((0,e.CommandResultFactory)({data:void 0})),C.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA},status:e.DeviceActionStatus.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.DeviceActionStatus.Completed}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})})),it("should fallback to legacy signing if the new one fails",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(f),A.mockResolvedValueOnce((0,e.CommandResultFactory)({error:(0,x.EthAppCommandErrorFactory)({errorCode:"6a80",message:""})})),v.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.DeviceActionStatus.Completed}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})})),it("should fallback to legacy signing BuildContext fails",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockRejectedValueOnce(new e.UnknownDAError("Error")),v.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{output:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"},status:e.DeviceActionStatus.Completed}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})})),it("should not fallback to legacy signing if rejected by the user during streaming",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(f),A.mockResolvedValueOnce((0,e.CommandResultFactory)({error:(0,x.EthAppCommandErrorFactory)({errorCode:"6985",message:""})})),v.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{v:28,r:"0x8a540510e13b0f2b11a451275716d29e08caad07e89a1c84964782fb5e1ad788",s:"0x64a0de235b270fbe81e8e40688f4a9f9ad9d283d690552c9331d7773ceafa513"}}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{error:(0,x.EthAppCommandErrorFactory)({errorCode:"6985",message:""}),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})}))}),describe("Web3Checks",()=>{it("should call external dependencies with web3Checks enabled and supported",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.16.0",!0,!0);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockRejectedValueOnce(new e.InvalidStatusWordError("buildContext error")),v.mockRejectedValueOnce(new e.InvalidStatusWordError("signTypedDataLegacy error"));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{error:new e.InvalidStatusWordError("signTypedDataLegacy error"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:()=>{expect(O).toHaveBeenCalled(),expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,parser:o,data:s,appConfig:T("1.16.0",!0,!0),derivationPath:"44'/60'/0'/0/0"}})),a()}})})),it("should call external dependencies with web3Checks supported but disabled",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.16.0",!1,!0);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockRejectedValueOnce(new e.InvalidStatusWordError("buildContext error")),v.mockRejectedValueOnce(new e.InvalidStatusWordError("signTypedDataLegacy error"));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{error:new e.InvalidStatusWordError("signTypedDataLegacy error"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:()=>{expect(O).toHaveBeenCalled(),expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,parser:o,data:s,appConfig:T("1.16.0",!1,!0),derivationPath:"44'/60'/0'/0/0"}})),a()}})})),it("should call external dependencies with web3Checks opt-in, then enabled",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.16.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),E.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{enabled:!0}})),c.mockRejectedValueOnce(new e.InvalidStatusWordError("buildContext error")),v.mockRejectedValueOnce(new e.InvalidStatusWordError("signTypedDataLegacy error"));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.Web3ChecksOptIn,step:t.SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN_RESULT,result:!0},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{error:new e.InvalidStatusWordError("signTypedDataLegacy error"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:()=>{expect(O).toHaveBeenCalled(),expect(E).toHaveBeenCalled(),expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,parser:o,data:s,appConfig:T("1.16.0",!0,!1),derivationPath:"44'/60'/0'/0/0"}})),a()}})})),it("should call external dependencies with web3Checks opt-in, then disabled",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.16.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),E.mockResolvedValueOnce((0,e.CommandResultFactory)({data:{enabled:!1}})),c.mockRejectedValueOnce(new e.InvalidStatusWordError("buildContext error")),v.mockRejectedValueOnce(new e.InvalidStatusWordError("signTypedDataLegacy error"));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.Web3ChecksOptIn,step:t.SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.WEB3_CHECKS_OPT_IN_RESULT,result:!1},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA_LEGACY},status:e.DeviceActionStatus.Pending},{error:new e.InvalidStatusWordError("signTypedDataLegacy error"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:()=>{expect(O).toHaveBeenCalled(),expect(E).toHaveBeenCalled(),expect(c).toHaveBeenCalledWith(expect.objectContaining({input:{contextModule:d,parser:o,data:s,appConfig:T("1.16.0",!1,!1),derivationPath:"44'/60'/0'/0/0"}})),a()}})}))}),describe("error cases",()=>{it("Error if the open app fails",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(new e.UnknownDAError("Mocked error"));const n=[{status:e.DeviceActionStatus.Pending,intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP}},{status:e.DeviceActionStatus.Pending,intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP}},{status:e.DeviceActionStatus.Error,error:new e.UnknownDAError("Mocked error")}],i=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});(0,l.testDeviceActionStates)(i,n,p,{onError:r,onDone:a})})),it("Error thrown while providing context",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(f),A.mockRejectedValueOnce(new e.UnknownDAError("Error"));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{error:new e.UnknownDAError("Error"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})})),it("Error while signing",()=>new Promise((a,r)=>{(0,u.setupOpenAppDAMock)(),g("1.15.0",!1,!1);const n=new P.SignTypedDataDeviceAction({input:{derivationPath:"44'/60'/0'/0/0",data:s,contextModule:d,parser:o,skipOpenApp:!1}});vi.spyOn(n,"extractDependencies").mockReturnValue(m()),c.mockResolvedValueOnce(f),A.mockResolvedValueOnce((0,e.CommandResultFactory)({data:void 0})),C.mockResolvedValueOnce((0,e.CommandResultFactory)({error:new e.UnknownDeviceExchangeError("Error while signing the typed data")}));const i=[{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.ConfirmOpenApp,step:t.SignTypedDataDAStateStep.OPEN_APP},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.GET_APP_CONFIG},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.None,step:t.SignTypedDataDAStateStep.BUILD_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.PROVIDE_CONTEXT},status:e.DeviceActionStatus.Pending},{intermediateValue:{requiredUserInteraction:e.UserInteractionRequired.SignTypedData,step:t.SignTypedDataDAStateStep.SIGN_TYPED_DATA},status:e.DeviceActionStatus.Pending},{error:new e.UnknownDeviceExchangeError("Error while signing the typed data"),status:e.DeviceActionStatus.Error}];(0,l.testDeviceActionStates)(n,i,p,{onError:r,onDone:a})}))})});
2
2
  //# sourceMappingURL=SignTypedDataDeviceAction.test.js.map