@ledgerhq/device-core 0.6.6-nightly.5 → 0.6.6-nightly.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +1 -1
- package/CHANGELOG.md +8 -0
- package/package.json +3 -3
- package/lib/capabilities/isCustomLockScreenSupported.test.d.ts +0 -2
- package/lib/capabilities/isCustomLockScreenSupported.test.d.ts.map +0 -1
- package/lib/capabilities/isCustomLockScreenSupported.test.js +0 -26
- package/lib/capabilities/isCustomLockScreenSupported.test.js.map +0 -1
- package/lib/capabilities/isEditDeviceNameSupported.test.d.ts +0 -2
- package/lib/capabilities/isEditDeviceNameSupported.test.d.ts.map +0 -1
- package/lib/capabilities/isEditDeviceNameSupported.test.js +0 -25
- package/lib/capabilities/isEditDeviceNameSupported.test.js.map +0 -1
- package/lib/capabilities/isSyncOnboardingSupported.test.d.ts +0 -2
- package/lib/capabilities/isSyncOnboardingSupported.test.d.ts.map +0 -1
- package/lib/capabilities/isSyncOnboardingSupported.test.js +0 -18
- package/lib/capabilities/isSyncOnboardingSupported.test.js.map +0 -1
- package/lib/commands/entities/AppStorageInfo.test.d.ts +0 -2
- package/lib/commands/entities/AppStorageInfo.test.d.ts.map +0 -1
- package/lib/commands/entities/AppStorageInfo.test.js +0 -48
- package/lib/commands/entities/AppStorageInfo.test.js.map +0 -1
- package/lib/commands/use-cases/app-backup/backupAppStorage.test.d.ts +0 -2
- package/lib/commands/use-cases/app-backup/backupAppStorage.test.d.ts.map +0 -1
- package/lib/commands/use-cases/app-backup/backupAppStorage.test.js +0 -47
- package/lib/commands/use-cases/app-backup/backupAppStorage.test.js.map +0 -1
- package/lib/commands/use-cases/app-backup/getAppStorageInfo.test.d.ts +0 -2
- package/lib/commands/use-cases/app-backup/getAppStorageInfo.test.d.ts.map +0 -1
- package/lib/commands/use-cases/app-backup/getAppStorageInfo.test.js +0 -58
- package/lib/commands/use-cases/app-backup/getAppStorageInfo.test.js.map +0 -1
- package/lib/commands/use-cases/app-backup/restoreAppStorage.test.d.ts +0 -2
- package/lib/commands/use-cases/app-backup/restoreAppStorage.test.d.ts.map +0 -1
- package/lib/commands/use-cases/app-backup/restoreAppStorage.test.js +0 -51
- package/lib/commands/use-cases/app-backup/restoreAppStorage.test.js.map +0 -1
- package/lib/commands/use-cases/app-backup/restoreAppStorageCommit.test.d.ts +0 -2
- package/lib/commands/use-cases/app-backup/restoreAppStorageCommit.test.d.ts.map +0 -1
- package/lib/commands/use-cases/app-backup/restoreAppStorageCommit.test.js +0 -40
- package/lib/commands/use-cases/app-backup/restoreAppStorageCommit.test.js.map +0 -1
- package/lib/commands/use-cases/app-backup/restoreAppStorageInit.test.d.ts +0 -2
- package/lib/commands/use-cases/app-backup/restoreAppStorageInit.test.d.ts.map +0 -1
- package/lib/commands/use-cases/app-backup/restoreAppStorageInit.test.js +0 -55
- package/lib/commands/use-cases/app-backup/restoreAppStorageInit.test.js.map +0 -1
- package/lib/commands/use-cases/consent/reinstallConfigurationConsent.test.d.ts +0 -2
- package/lib/commands/use-cases/consent/reinstallConfigurationConsent.test.d.ts.map +0 -1
- package/lib/commands/use-cases/consent/reinstallConfigurationConsent.test.js +0 -39
- package/lib/commands/use-cases/consent/reinstallConfigurationConsent.test.js.map +0 -1
- package/lib/commands/use-cases/isBootloaderVersionSupported.test.d.ts +0 -2
- package/lib/commands/use-cases/isBootloaderVersionSupported.test.d.ts.map +0 -1
- package/lib/commands/use-cases/isBootloaderVersionSupported.test.js +0 -63
- package/lib/commands/use-cases/isBootloaderVersionSupported.test.js.map +0 -1
- package/lib/commands/use-cases/isCharonSupported.test.d.ts +0 -2
- package/lib/commands/use-cases/isCharonSupported.test.d.ts.map +0 -1
- package/lib/commands/use-cases/isCharonSupported.test.js +0 -46
- package/lib/commands/use-cases/isCharonSupported.test.js.map +0 -1
- package/lib/commands/use-cases/isDeviceLocalizationSupported.test.d.ts +0 -2
- package/lib/commands/use-cases/isDeviceLocalizationSupported.test.d.ts.map +0 -1
- package/lib/commands/use-cases/isDeviceLocalizationSupported.test.js +0 -55
- package/lib/commands/use-cases/isDeviceLocalizationSupported.test.js.map +0 -1
- package/lib/commands/use-cases/isHardwareVersionSupported.test.d.ts +0 -2
- package/lib/commands/use-cases/isHardwareVersionSupported.test.d.ts.map +0 -1
- package/lib/commands/use-cases/isHardwareVersionSupported.test.js +0 -36
- package/lib/commands/use-cases/isHardwareVersionSupported.test.js.map +0 -1
- package/lib/commands/use-cases/isRecoverSupported.test.d.ts +0 -2
- package/lib/commands/use-cases/isRecoverSupported.test.d.ts.map +0 -1
- package/lib/commands/use-cases/isRecoverSupported.test.js +0 -54
- package/lib/commands/use-cases/isRecoverSupported.test.js.map +0 -1
- package/lib/commands/use-cases/parseGetDeviceNameResponse.test.d.ts +0 -2
- package/lib/commands/use-cases/parseGetDeviceNameResponse.test.d.ts.map +0 -1
- package/lib/commands/use-cases/parseGetDeviceNameResponse.test.js +0 -27
- package/lib/commands/use-cases/parseGetDeviceNameResponse.test.js.map +0 -1
- package/lib/commands/use-cases/parseGetVersionResponse.test.d.ts +0 -2
- package/lib/commands/use-cases/parseGetVersionResponse.test.d.ts.map +0 -1
- package/lib/commands/use-cases/parseGetVersionResponse.test.js +0 -145
- package/lib/commands/use-cases/parseGetVersionResponse.test.js.map +0 -1
- package/lib/firmwareUpdate/shouldForceFirmwareUpdate.test.d.ts +0 -2
- package/lib/firmwareUpdate/shouldForceFirmwareUpdate.test.d.ts.map +0 -1
- package/lib/firmwareUpdate/shouldForceFirmwareUpdate.test.js +0 -69
- package/lib/firmwareUpdate/shouldForceFirmwareUpdate.test.js.map +0 -1
- package/lib/managerApi/repositories/HttpManagerApiRepository.test.d.ts +0 -2
- package/lib/managerApi/repositories/HttpManagerApiRepository.test.d.ts.map +0 -1
- package/lib/managerApi/repositories/HttpManagerApiRepository.test.js +0 -390
- package/lib/managerApi/repositories/HttpManagerApiRepository.test.js.map +0 -1
- package/lib/managerApi/use-cases/getLatestFirmwareForDevice.test.d.ts +0 -2
- package/lib/managerApi/use-cases/getLatestFirmwareForDevice.test.d.ts.map +0 -1
- package/lib/managerApi/use-cases/getLatestFirmwareForDevice.test.js +0 -169
- package/lib/managerApi/use-cases/getLatestFirmwareForDevice.test.js.map +0 -1
- package/lib-es/capabilities/isCustomLockScreenSupported.test.d.ts +0 -2
- package/lib-es/capabilities/isCustomLockScreenSupported.test.d.ts.map +0 -1
- package/lib-es/capabilities/isCustomLockScreenSupported.test.js +0 -24
- package/lib-es/capabilities/isCustomLockScreenSupported.test.js.map +0 -1
- package/lib-es/capabilities/isEditDeviceNameSupported.test.d.ts +0 -2
- package/lib-es/capabilities/isEditDeviceNameSupported.test.d.ts.map +0 -1
- package/lib-es/capabilities/isEditDeviceNameSupported.test.js +0 -23
- package/lib-es/capabilities/isEditDeviceNameSupported.test.js.map +0 -1
- package/lib-es/capabilities/isSyncOnboardingSupported.test.d.ts +0 -2
- package/lib-es/capabilities/isSyncOnboardingSupported.test.d.ts.map +0 -1
- package/lib-es/capabilities/isSyncOnboardingSupported.test.js +0 -16
- package/lib-es/capabilities/isSyncOnboardingSupported.test.js.map +0 -1
- package/lib-es/commands/entities/AppStorageInfo.test.d.ts +0 -2
- package/lib-es/commands/entities/AppStorageInfo.test.d.ts.map +0 -1
- package/lib-es/commands/entities/AppStorageInfo.test.js +0 -46
- package/lib-es/commands/entities/AppStorageInfo.test.js.map +0 -1
- package/lib-es/commands/use-cases/app-backup/backupAppStorage.test.d.ts +0 -2
- package/lib-es/commands/use-cases/app-backup/backupAppStorage.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/app-backup/backupAppStorage.test.js +0 -45
- package/lib-es/commands/use-cases/app-backup/backupAppStorage.test.js.map +0 -1
- package/lib-es/commands/use-cases/app-backup/getAppStorageInfo.test.d.ts +0 -2
- package/lib-es/commands/use-cases/app-backup/getAppStorageInfo.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/app-backup/getAppStorageInfo.test.js +0 -56
- package/lib-es/commands/use-cases/app-backup/getAppStorageInfo.test.js.map +0 -1
- package/lib-es/commands/use-cases/app-backup/restoreAppStorage.test.d.ts +0 -2
- package/lib-es/commands/use-cases/app-backup/restoreAppStorage.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/app-backup/restoreAppStorage.test.js +0 -49
- package/lib-es/commands/use-cases/app-backup/restoreAppStorage.test.js.map +0 -1
- package/lib-es/commands/use-cases/app-backup/restoreAppStorageCommit.test.d.ts +0 -2
- package/lib-es/commands/use-cases/app-backup/restoreAppStorageCommit.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/app-backup/restoreAppStorageCommit.test.js +0 -38
- package/lib-es/commands/use-cases/app-backup/restoreAppStorageCommit.test.js.map +0 -1
- package/lib-es/commands/use-cases/app-backup/restoreAppStorageInit.test.d.ts +0 -2
- package/lib-es/commands/use-cases/app-backup/restoreAppStorageInit.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/app-backup/restoreAppStorageInit.test.js +0 -53
- package/lib-es/commands/use-cases/app-backup/restoreAppStorageInit.test.js.map +0 -1
- package/lib-es/commands/use-cases/consent/reinstallConfigurationConsent.test.d.ts +0 -2
- package/lib-es/commands/use-cases/consent/reinstallConfigurationConsent.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/consent/reinstallConfigurationConsent.test.js +0 -37
- package/lib-es/commands/use-cases/consent/reinstallConfigurationConsent.test.js.map +0 -1
- package/lib-es/commands/use-cases/isBootloaderVersionSupported.test.d.ts +0 -2
- package/lib-es/commands/use-cases/isBootloaderVersionSupported.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/isBootloaderVersionSupported.test.js +0 -61
- package/lib-es/commands/use-cases/isBootloaderVersionSupported.test.js.map +0 -1
- package/lib-es/commands/use-cases/isCharonSupported.test.d.ts +0 -2
- package/lib-es/commands/use-cases/isCharonSupported.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/isCharonSupported.test.js +0 -44
- package/lib-es/commands/use-cases/isCharonSupported.test.js.map +0 -1
- package/lib-es/commands/use-cases/isDeviceLocalizationSupported.test.d.ts +0 -2
- package/lib-es/commands/use-cases/isDeviceLocalizationSupported.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/isDeviceLocalizationSupported.test.js +0 -53
- package/lib-es/commands/use-cases/isDeviceLocalizationSupported.test.js.map +0 -1
- package/lib-es/commands/use-cases/isHardwareVersionSupported.test.d.ts +0 -2
- package/lib-es/commands/use-cases/isHardwareVersionSupported.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/isHardwareVersionSupported.test.js +0 -34
- package/lib-es/commands/use-cases/isHardwareVersionSupported.test.js.map +0 -1
- package/lib-es/commands/use-cases/isRecoverSupported.test.d.ts +0 -2
- package/lib-es/commands/use-cases/isRecoverSupported.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/isRecoverSupported.test.js +0 -52
- package/lib-es/commands/use-cases/isRecoverSupported.test.js.map +0 -1
- package/lib-es/commands/use-cases/parseGetDeviceNameResponse.test.d.ts +0 -2
- package/lib-es/commands/use-cases/parseGetDeviceNameResponse.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/parseGetDeviceNameResponse.test.js +0 -25
- package/lib-es/commands/use-cases/parseGetDeviceNameResponse.test.js.map +0 -1
- package/lib-es/commands/use-cases/parseGetVersionResponse.test.d.ts +0 -2
- package/lib-es/commands/use-cases/parseGetVersionResponse.test.d.ts.map +0 -1
- package/lib-es/commands/use-cases/parseGetVersionResponse.test.js +0 -143
- package/lib-es/commands/use-cases/parseGetVersionResponse.test.js.map +0 -1
- package/lib-es/firmwareUpdate/shouldForceFirmwareUpdate.test.d.ts +0 -2
- package/lib-es/firmwareUpdate/shouldForceFirmwareUpdate.test.d.ts.map +0 -1
- package/lib-es/firmwareUpdate/shouldForceFirmwareUpdate.test.js +0 -67
- package/lib-es/firmwareUpdate/shouldForceFirmwareUpdate.test.js.map +0 -1
- package/lib-es/managerApi/repositories/HttpManagerApiRepository.test.d.ts +0 -2
- package/lib-es/managerApi/repositories/HttpManagerApiRepository.test.d.ts.map +0 -1
- package/lib-es/managerApi/repositories/HttpManagerApiRepository.test.js +0 -388
- package/lib-es/managerApi/repositories/HttpManagerApiRepository.test.js.map +0 -1
- package/lib-es/managerApi/use-cases/getLatestFirmwareForDevice.test.d.ts +0 -2
- package/lib-es/managerApi/use-cases/getLatestFirmwareForDevice.test.d.ts.map +0 -1
- package/lib-es/managerApi/use-cases/getLatestFirmwareForDevice.test.js +0 -167
- package/lib-es/managerApi/use-cases/getLatestFirmwareForDevice.test.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"isEditDeviceNameSupported.test.d.ts","sourceRoot":"","sources":["../../src/capabilities/isEditDeviceNameSupported.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { DeviceModelId } from "@ledgerhq/devices";
|
|
2
|
-
import { isEditDeviceNameSupported } from "./isEditDeviceNameSupported";
|
|
3
|
-
const supportedDevices = [
|
|
4
|
-
DeviceModelId.stax,
|
|
5
|
-
DeviceModelId.nanoX,
|
|
6
|
-
DeviceModelId.europa,
|
|
7
|
-
DeviceModelId.nanoSP,
|
|
8
|
-
DeviceModelId.apex,
|
|
9
|
-
];
|
|
10
|
-
const unsupportedDevices = [DeviceModelId.blue];
|
|
11
|
-
describe("isEditDeviceNameSupported", () => {
|
|
12
|
-
it("should return true for supported devices", () => {
|
|
13
|
-
supportedDevices.forEach((deviceModelId) => {
|
|
14
|
-
expect(isEditDeviceNameSupported(deviceModelId)).toBe(true);
|
|
15
|
-
});
|
|
16
|
-
});
|
|
17
|
-
it("should return false for unsupported devices", () => {
|
|
18
|
-
unsupportedDevices.forEach((deviceModelId) => {
|
|
19
|
-
expect(isEditDeviceNameSupported(deviceModelId)).toBe(false);
|
|
20
|
-
});
|
|
21
|
-
});
|
|
22
|
-
});
|
|
23
|
-
//# sourceMappingURL=isEditDeviceNameSupported.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"isEditDeviceNameSupported.test.js","sourceRoot":"","sources":["../../src/capabilities/isEditDeviceNameSupported.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AAExE,MAAM,gBAAgB,GAAG;IACvB,aAAa,CAAC,IAAI;IAClB,aAAa,CAAC,KAAK;IACnB,aAAa,CAAC,MAAM;IACpB,aAAa,CAAC,MAAM;IACpB,aAAa,CAAC,IAAI;CACnB,CAAC;AACF,MAAM,kBAAkB,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;AAEhD,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,gBAAgB,CAAC,OAAO,CAAC,CAAC,aAA4B,EAAE,EAAE;YACxD,MAAM,CAAC,yBAAyB,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,kBAAkB,CAAC,OAAO,CAAC,CAAC,aAA4B,EAAE,EAAE;YAC1D,MAAM,CAAC,yBAAyB,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"isSyncOnboardingSupported.test.d.ts","sourceRoot":"","sources":["../../src/capabilities/isSyncOnboardingSupported.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { DeviceModelId } from "@ledgerhq/devices";
|
|
2
|
-
import { isSyncOnboardingSupported } from "./isSyncOnboardingSupported";
|
|
3
|
-
describe("isSyncOnboardingSupported", () => {
|
|
4
|
-
it("should return true if sync onboarding is supported", () => {
|
|
5
|
-
expect(isSyncOnboardingSupported(DeviceModelId.stax)).toBe(true);
|
|
6
|
-
expect(isSyncOnboardingSupported(DeviceModelId.europa)).toBe(true);
|
|
7
|
-
expect(isSyncOnboardingSupported(DeviceModelId.apex)).toBe(true);
|
|
8
|
-
});
|
|
9
|
-
it("should return false if sync onboarding is not supported", () => {
|
|
10
|
-
expect(isSyncOnboardingSupported(DeviceModelId.nanoS)).toBe(false);
|
|
11
|
-
expect(isSyncOnboardingSupported(DeviceModelId.nanoSP)).toBe(false);
|
|
12
|
-
expect(isSyncOnboardingSupported(DeviceModelId.nanoX)).toBe(false);
|
|
13
|
-
expect(isSyncOnboardingSupported(DeviceModelId.blue)).toBe(false);
|
|
14
|
-
});
|
|
15
|
-
});
|
|
16
|
-
//# sourceMappingURL=isSyncOnboardingSupported.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"isSyncOnboardingSupported.test.js","sourceRoot":"","sources":["../../src/capabilities/isSyncOnboardingSupported.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AAExE,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,CAAC,yBAAyB,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjE,MAAM,CAAC,yBAAyB,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnE,MAAM,CAAC,yBAAyB,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yDAAyD,EAAE,GAAG,EAAE;QACjE,MAAM,CAAC,yBAAyB,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnE,MAAM,CAAC,yBAAyB,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpE,MAAM,CAAC,yBAAyB,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnE,MAAM,CAAC,yBAAyB,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AppStorageInfo.test.d.ts","sourceRoot":"","sources":["../../../src/commands/entities/AppStorageInfo.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { isAppStorageInfo } from "./AppStorageInfo";
|
|
2
|
-
describe("isAppStorageInfo", () => {
|
|
3
|
-
it("should return true for valid AppStorageInfo object", () => {
|
|
4
|
-
const data = {
|
|
5
|
-
size: 1024,
|
|
6
|
-
dataVersion: "1.0.0",
|
|
7
|
-
hasSettings: true,
|
|
8
|
-
hasData: true,
|
|
9
|
-
hash: "abcd1234",
|
|
10
|
-
};
|
|
11
|
-
expect(isAppStorageInfo(data)).toBe(true);
|
|
12
|
-
});
|
|
13
|
-
it("should return false for non-object input", () => {
|
|
14
|
-
const data = "invalid";
|
|
15
|
-
expect(isAppStorageInfo(data)).toBe(false);
|
|
16
|
-
});
|
|
17
|
-
it("should return false for null input", () => {
|
|
18
|
-
const data = null;
|
|
19
|
-
expect(isAppStorageInfo(data)).toBe(false);
|
|
20
|
-
});
|
|
21
|
-
it("should return false for undefined input", () => {
|
|
22
|
-
const data = undefined;
|
|
23
|
-
expect(isAppStorageInfo(data)).toBe(false);
|
|
24
|
-
});
|
|
25
|
-
it("should return false if missing property", () => {
|
|
26
|
-
const data = {
|
|
27
|
-
// Missing size property
|
|
28
|
-
dataVersion: "1.0.0",
|
|
29
|
-
hasSettings: true,
|
|
30
|
-
hasData: true,
|
|
31
|
-
hash: "abcd1234",
|
|
32
|
-
};
|
|
33
|
-
expect(isAppStorageInfo(data)).toBe(false);
|
|
34
|
-
});
|
|
35
|
-
it("should return false if property type not correct", () => {
|
|
36
|
-
const data = {
|
|
37
|
-
size: 1024,
|
|
38
|
-
dataVersion: "1.0.0",
|
|
39
|
-
hasSettings: "Yes",
|
|
40
|
-
hasData: true,
|
|
41
|
-
hash: "abcd1234",
|
|
42
|
-
};
|
|
43
|
-
expect(isAppStorageInfo(data)).toBe(false);
|
|
44
|
-
});
|
|
45
|
-
});
|
|
46
|
-
//# sourceMappingURL=AppStorageInfo.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AppStorageInfo.test.js","sourceRoot":"","sources":["../../../src/commands/entities/AppStorageInfo.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAkB,MAAM,kBAAkB,CAAC;AAEpE,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,IAAI,GAAmB;YAC3B,IAAI,EAAE,IAAI;YACV,WAAW,EAAE,OAAO;YACpB,WAAW,EAAE,IAAI;YACjB,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,UAAU;SACjB,CAAC;QAEF,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,MAAM,IAAI,GAAY,SAAS,CAAC;QAEhC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,IAAI,GAAY,IAAI,CAAC;QAE3B,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,IAAI,GAAY,SAAS,CAAC;QAEhC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,IAAI,GAAY;YACpB,wBAAwB;YACxB,WAAW,EAAE,OAAO;YACpB,WAAW,EAAE,IAAI;YACjB,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,UAAU;SACjB,CAAC;QAEF,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,MAAM,IAAI,GAAY;YACpB,IAAI,EAAE,IAAI;YACV,WAAW,EAAE,OAAO;YACpB,WAAW,EAAE,KAAK;YAClB,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,UAAU;SACjB,CAAC;QAEF,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"backupAppStorage.test.d.ts","sourceRoot":"","sources":["../../../../src/commands/use-cases/app-backup/backupAppStorage.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import { StatusCodes } from "@ledgerhq/hw-transport";
|
|
2
|
-
import { backupAppStorage, parseResponse } from "./backupAppStorage";
|
|
3
|
-
import { InternalComputeAesCmacFailed } from "../../../errors";
|
|
4
|
-
jest.mock("@ledgerhq/hw-transport");
|
|
5
|
-
describe("backupAppStorage", () => {
|
|
6
|
-
let transport;
|
|
7
|
-
const response = Buffer.from([
|
|
8
|
-
0x31, 0x30, 0x36, 0x52, 0x75, 0x65, 0x64, 0x75, 0x54, 0x65, 0x6d, 0x70, 0x6c, 0x65, 0x90, 0x00,
|
|
9
|
-
]);
|
|
10
|
-
beforeEach(() => {
|
|
11
|
-
transport = {
|
|
12
|
-
send: jest.fn().mockResolvedValue(response),
|
|
13
|
-
getTraceContext: jest.fn().mockResolvedValue(undefined),
|
|
14
|
-
};
|
|
15
|
-
});
|
|
16
|
-
afterEach(() => {
|
|
17
|
-
jest.clearAllMocks();
|
|
18
|
-
});
|
|
19
|
-
it("should call the send function with correct parameters", async () => {
|
|
20
|
-
await backupAppStorage(transport);
|
|
21
|
-
expect(transport.send).toHaveBeenCalledWith(0xe0, 0x6b, 0x00, 0x00, Buffer.from([]), [
|
|
22
|
-
StatusCodes.OK,
|
|
23
|
-
StatusCodes.APP_NOT_FOUND_OR_INVALID_CONTEXT,
|
|
24
|
-
StatusCodes.GEN_AES_KEY_FAILED,
|
|
25
|
-
StatusCodes.INTERNAL_CRYPTO_OPERATION_FAILED,
|
|
26
|
-
StatusCodes.INTERNAL_COMPUTE_AES_CMAC_FAILED,
|
|
27
|
-
StatusCodes.ENCRYPT_APP_STORAGE_FAILED,
|
|
28
|
-
StatusCodes.DEVICE_IN_RECOVERY_MODE,
|
|
29
|
-
StatusCodes.INVALID_BACKUP_STATE,
|
|
30
|
-
]);
|
|
31
|
-
});
|
|
32
|
-
describe("parseResponse", () => {
|
|
33
|
-
it("should parse the response data correctly", () => {
|
|
34
|
-
const expected = Buffer.from([
|
|
35
|
-
0x31, 0x30, 0x36, 0x52, 0x75, 0x65, 0x64, 0x75, 0x54, 0x65, 0x6d, 0x70, 0x6c, 0x65,
|
|
36
|
-
]);
|
|
37
|
-
expect(parseResponse(response)).toStrictEqual(expected);
|
|
38
|
-
});
|
|
39
|
-
it("should throw TransportStatusError if the response status is invalid", () => {
|
|
40
|
-
const data = Buffer.from([0x54, 0x1b]);
|
|
41
|
-
expect(() => parseResponse(data)).toThrow(new InternalComputeAesCmacFailed("Internal error, failed to compute AES CMAC."));
|
|
42
|
-
});
|
|
43
|
-
});
|
|
44
|
-
});
|
|
45
|
-
//# sourceMappingURL=backupAppStorage.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"backupAppStorage.test.js","sourceRoot":"","sources":["../../../../src/commands/use-cases/app-backup/backupAppStorage.test.ts"],"names":[],"mappings":"AAAA,OAAkB,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACrE,OAAO,EAAE,4BAA4B,EAAE,MAAM,iBAAiB,CAAC;AAE/D,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;AAEpC,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,IAAI,SAAoB,CAAC;IACzB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC;QAC3B,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;KAC/F,CAAC,CAAC;IAEH,UAAU,CAAC,GAAG,EAAE;QACd,SAAS,GAAG;YACV,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC;YAC3C,eAAe,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC;SAChC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,KAAK,IAAI,EAAE;QACrE,MAAM,gBAAgB,CAAC,SAAS,CAAC,CAAC;QAClC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,oBAAoB,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;YACnF,WAAW,CAAC,EAAE;YACd,WAAW,CAAC,gCAAgC;YAC5C,WAAW,CAAC,kBAAkB;YAC9B,WAAW,CAAC,gCAAgC;YAC5C,WAAW,CAAC,gCAAgC;YAC5C,WAAW,CAAC,0BAA0B;YACtC,WAAW,CAAC,uBAAuB;YACnC,WAAW,CAAC,oBAAoB;SACjC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;QAC7B,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YAClD,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC;gBAC3B,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;aACnF,CAAC,CAAC;YACH,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,qEAAqE,EAAE,GAAG,EAAE;YAC7E,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;YACvC,MAAM,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CACvC,IAAI,4BAA4B,CAAC,6CAA6C,CAAC,CAChF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getAppStorageInfo.test.d.ts","sourceRoot":"","sources":["../../../../src/commands/use-cases/app-backup/getAppStorageInfo.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import { StatusCodes } from "@ledgerhq/hw-transport";
|
|
2
|
-
import { getAppStorageInfo, parseResponse } from "./getAppStorageInfo";
|
|
3
|
-
import { InvalidAppNameLength } from "../../../errors";
|
|
4
|
-
jest.mock("@ledgerhq/hw-transport");
|
|
5
|
-
describe("getAppStorageInfo", () => {
|
|
6
|
-
let transport;
|
|
7
|
-
const response = Buffer.from([
|
|
8
|
-
// Status code 1234
|
|
9
|
-
0x00, 0x00, 0x04, 0xd2,
|
|
10
|
-
// Data version 1.01
|
|
11
|
-
0x31, 0x2e, 0x30, 0x31,
|
|
12
|
-
// Has settings and data
|
|
13
|
-
0x00, 0x03,
|
|
14
|
-
// Hash hashhash1234hashhashhashhashhash
|
|
15
|
-
0x68, 0x61, 0x73, 0x68, 0x68, 0x61, 0x73, 0x68, 0x31, 0x32, 0x33, 0x34, 0x68, 0x61, 0x73, 0x68,
|
|
16
|
-
0x68, 0x61, 0x73, 0x68, 0x68, 0x61, 0x73, 0x68, 0x68, 0x61, 0x73, 0x68, 0x68, 0x61, 0x73, 0x68,
|
|
17
|
-
// Status word
|
|
18
|
-
0x90, 0x00,
|
|
19
|
-
]);
|
|
20
|
-
beforeEach(() => {
|
|
21
|
-
transport = {
|
|
22
|
-
send: jest.fn().mockResolvedValue(response),
|
|
23
|
-
getTraceContext: jest.fn().mockResolvedValue(undefined),
|
|
24
|
-
};
|
|
25
|
-
});
|
|
26
|
-
afterEach(() => {
|
|
27
|
-
jest.clearAllMocks();
|
|
28
|
-
});
|
|
29
|
-
it("should call the send function with correct parameters", async () => {
|
|
30
|
-
const appName = "MyApp";
|
|
31
|
-
await getAppStorageInfo(transport, appName);
|
|
32
|
-
expect(transport.send).toHaveBeenCalledWith(0xe0, 0x6a, 0x00, 0x00, Buffer.from(appName, "ascii"), [
|
|
33
|
-
StatusCodes.OK,
|
|
34
|
-
StatusCodes.APP_NOT_FOUND_OR_INVALID_CONTEXT,
|
|
35
|
-
StatusCodes.DEVICE_IN_RECOVERY_MODE,
|
|
36
|
-
StatusCodes.INVALID_APP_NAME_LENGTH,
|
|
37
|
-
]);
|
|
38
|
-
});
|
|
39
|
-
describe("parseResponse", () => {
|
|
40
|
-
it("should parse the response data correctly", () => {
|
|
41
|
-
const expected = {
|
|
42
|
-
size: 1234,
|
|
43
|
-
dataVersion: Buffer.from("1.01").toString("hex"),
|
|
44
|
-
hasSettings: true,
|
|
45
|
-
hasData: true,
|
|
46
|
-
hash: Buffer.from("hashhash1234hashhashhashhashhash").toString("hex"),
|
|
47
|
-
};
|
|
48
|
-
expect(parseResponse(response)).toStrictEqual(expected);
|
|
49
|
-
});
|
|
50
|
-
it("should throw TransportStatusError if the response status is invalid", () => {
|
|
51
|
-
const data = Buffer.from([0x67, 0x0a]);
|
|
52
|
-
expect(() => parseResponse(data)).toThrow(new InvalidAppNameLength("Invalid application name length, two chars minimum."));
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
});
|
|
56
|
-
//# sourceMappingURL=getAppStorageInfo.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getAppStorageInfo.test.js","sourceRoot":"","sources":["../../../../src/commands/use-cases/app-backup/getAppStorageInfo.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"restoreAppStorage.test.d.ts","sourceRoot":"","sources":["../../../../src/commands/use-cases/app-backup/restoreAppStorage.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { StatusCodes } from "@ledgerhq/hw-transport";
|
|
2
|
-
import { restoreAppStorage, parseResponse } from "./restoreAppStorage";
|
|
3
|
-
import { InvalidRestoreState } from "../../../errors";
|
|
4
|
-
jest.mock("@ledgerhq/hw-transport");
|
|
5
|
-
describe("restoreAppStorage", () => {
|
|
6
|
-
let transport;
|
|
7
|
-
const response = Buffer.from([0x90, 0x00]);
|
|
8
|
-
beforeEach(() => {
|
|
9
|
-
transport = {
|
|
10
|
-
send: jest.fn().mockResolvedValue(response),
|
|
11
|
-
getTraceContext: jest.fn().mockResolvedValue(undefined),
|
|
12
|
-
};
|
|
13
|
-
});
|
|
14
|
-
afterEach(() => {
|
|
15
|
-
jest.clearAllMocks();
|
|
16
|
-
});
|
|
17
|
-
it("should call the send function with correct parameters", async () => {
|
|
18
|
-
const chunk = Buffer.from("106RueduTemple");
|
|
19
|
-
const args = [
|
|
20
|
-
0xe0,
|
|
21
|
-
0x6d,
|
|
22
|
-
0x00,
|
|
23
|
-
0x00,
|
|
24
|
-
chunk,
|
|
25
|
-
[
|
|
26
|
-
StatusCodes.OK,
|
|
27
|
-
StatusCodes.APP_NOT_FOUND_OR_INVALID_CONTEXT,
|
|
28
|
-
StatusCodes.GEN_AES_KEY_FAILED,
|
|
29
|
-
StatusCodes.INTERNAL_CRYPTO_OPERATION_FAILED,
|
|
30
|
-
StatusCodes.DEVICE_IN_RECOVERY_MODE,
|
|
31
|
-
StatusCodes.INVALID_RESTORE_STATE,
|
|
32
|
-
StatusCodes.INVALID_CHUNK_LENGTH,
|
|
33
|
-
StatusCodes.INVALID_BACKUP_HEADER,
|
|
34
|
-
],
|
|
35
|
-
];
|
|
36
|
-
await restoreAppStorage(transport, chunk);
|
|
37
|
-
expect(transport.send).toHaveBeenCalledWith(...args);
|
|
38
|
-
});
|
|
39
|
-
describe("parseResponse", () => {
|
|
40
|
-
it("should parse the response data correctly", () => {
|
|
41
|
-
expect(() => parseResponse(response)).not.toThrow();
|
|
42
|
-
});
|
|
43
|
-
it("should throw TransportStatusError if the response status is invalid", () => {
|
|
44
|
-
const data = Buffer.from([0x66, 0x43]);
|
|
45
|
-
expect(() => parseResponse(data)).toThrow(new InvalidRestoreState("Invalid restore state, restore already performed."));
|
|
46
|
-
});
|
|
47
|
-
});
|
|
48
|
-
});
|
|
49
|
-
//# sourceMappingURL=restoreAppStorage.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"restoreAppStorage.test.js","sourceRoot":"","sources":["../../../../src/commands/use-cases/app-backup/restoreAppStorage.test.ts"],"names":[],"mappings":"AAAA,OAAkB,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACvE,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAEtD,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;AAEpC,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,IAAI,SAAoB,CAAC;IACzB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IAE3C,UAAU,CAAC,GAAG,EAAE;QACd,SAAS,GAAG;YACV,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC;YAC3C,eAAe,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC;SAChC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,KAAK,IAAI,EAAE;QACrE,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC5C,MAAM,IAAI,GAAG;YACX,IAAI;YACJ,IAAI;YACJ,IAAI;YACJ,IAAI;YACJ,KAAK;YACL;gBACE,WAAW,CAAC,EAAE;gBACd,WAAW,CAAC,gCAAgC;gBAC5C,WAAW,CAAC,kBAAkB;gBAC9B,WAAW,CAAC,gCAAgC;gBAC5C,WAAW,CAAC,uBAAuB;gBACnC,WAAW,CAAC,qBAAqB;gBACjC,WAAW,CAAC,oBAAoB;gBAChC,WAAW,CAAC,qBAAqB;aAClC;SACF,CAAC;QAEF,MAAM,iBAAiB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QAC1C,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,oBAAoB,CAAC,GAAG,IAAI,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;QAC7B,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YAClD,MAAM,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACtD,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,qEAAqE,EAAE,GAAG,EAAE;YAC7E,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;YACvC,MAAM,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CACvC,IAAI,mBAAmB,CAAC,mDAAmD,CAAC,CAC7E,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"restoreAppStorageCommit.test.d.ts","sourceRoot":"","sources":["../../../../src/commands/use-cases/app-backup/restoreAppStorageCommit.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import { StatusCodes } from "@ledgerhq/hw-transport";
|
|
2
|
-
import { restoreAppStorageCommit, parseResponse } from "./restoreAppStorageCommit";
|
|
3
|
-
import { InvalidChunkLength } from "../../../errors";
|
|
4
|
-
jest.mock("@ledgerhq/hw-transport");
|
|
5
|
-
describe("restoreAppStorageCommit", () => {
|
|
6
|
-
let transport;
|
|
7
|
-
const response = Buffer.from([0x90, 0x00]);
|
|
8
|
-
beforeEach(() => {
|
|
9
|
-
transport = {
|
|
10
|
-
send: jest.fn().mockResolvedValue(response),
|
|
11
|
-
getTraceContext: jest.fn().mockResolvedValue(undefined),
|
|
12
|
-
};
|
|
13
|
-
});
|
|
14
|
-
afterEach(() => {
|
|
15
|
-
jest.clearAllMocks();
|
|
16
|
-
});
|
|
17
|
-
it("should call the send function with correct parameters", async () => {
|
|
18
|
-
await restoreAppStorageCommit(transport);
|
|
19
|
-
expect(transport.send).toHaveBeenCalledWith(0xe0, 0x6e, 0x00, 0x00, Buffer.from([]), [
|
|
20
|
-
StatusCodes.OK,
|
|
21
|
-
StatusCodes.APP_NOT_FOUND_OR_INVALID_CONTEXT,
|
|
22
|
-
StatusCodes.GEN_AES_KEY_FAILED,
|
|
23
|
-
StatusCodes.INTERNAL_COMPUTE_AES_CMAC_FAILED,
|
|
24
|
-
StatusCodes.DEVICE_IN_RECOVERY_MODE,
|
|
25
|
-
StatusCodes.INVALID_CHUNK_LENGTH,
|
|
26
|
-
]);
|
|
27
|
-
});
|
|
28
|
-
describe("parseResponse", () => {
|
|
29
|
-
it("should parse the response data correctly", () => {
|
|
30
|
-
expect(() => parseResponse(response)).not.toThrow();
|
|
31
|
-
});
|
|
32
|
-
it("should throw TransportStatusError if the response status is invalid", () => {
|
|
33
|
-
const data = Buffer.from([0x67, 0x34]);
|
|
34
|
-
expect(() => parseResponse(data)).toThrow(new InvalidChunkLength("Invalid size of the restored app storage."));
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
//# sourceMappingURL=restoreAppStorageCommit.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"restoreAppStorageCommit.test.js","sourceRoot":"","sources":["../../../../src/commands/use-cases/app-backup/restoreAppStorageCommit.test.ts"],"names":[],"mappings":"AAAA,OAAkB,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,uBAAuB,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AACnF,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAErD,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;AAEpC,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,IAAI,SAAoB,CAAC;IACzB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IAE3C,UAAU,CAAC,GAAG,EAAE;QACd,SAAS,GAAG;YACV,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC;YAC3C,eAAe,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC;SAChC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,KAAK,IAAI,EAAE;QACrE,MAAM,uBAAuB,CAAC,SAAS,CAAC,CAAC;QACzC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,oBAAoB,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;YACnF,WAAW,CAAC,EAAE;YACd,WAAW,CAAC,gCAAgC;YAC5C,WAAW,CAAC,kBAAkB;YAC9B,WAAW,CAAC,gCAAgC;YAC5C,WAAW,CAAC,uBAAuB;YACnC,WAAW,CAAC,oBAAoB;SACjC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;QAC7B,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YAClD,MAAM,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACtD,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,qEAAqE,EAAE,GAAG,EAAE;YAC7E,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;YACvC,MAAM,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CACvC,IAAI,kBAAkB,CAAC,2CAA2C,CAAC,CACpE,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"restoreAppStorageInit.test.d.ts","sourceRoot":"","sources":["../../../../src/commands/use-cases/app-backup/restoreAppStorageInit.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { StatusCodes } from "@ledgerhq/hw-transport";
|
|
2
|
-
import { restoreAppStorageInit, parseResponse } from "./restoreAppStorageInit";
|
|
3
|
-
import { InvalidAppNameLength } from "../../../errors";
|
|
4
|
-
jest.mock("@ledgerhq/hw-transport");
|
|
5
|
-
describe("restoreAppStorageInit", () => {
|
|
6
|
-
let transport;
|
|
7
|
-
const response = Buffer.from([0x90, 0x00]);
|
|
8
|
-
beforeEach(() => {
|
|
9
|
-
transport = {
|
|
10
|
-
send: jest.fn().mockResolvedValue(response),
|
|
11
|
-
getTraceContext: jest.fn().mockResolvedValue(undefined),
|
|
12
|
-
};
|
|
13
|
-
});
|
|
14
|
-
afterEach(() => {
|
|
15
|
-
jest.clearAllMocks();
|
|
16
|
-
});
|
|
17
|
-
it("should call the send function with correct parameters", async () => {
|
|
18
|
-
const appName = "MyApp";
|
|
19
|
-
const backupSize = 1234;
|
|
20
|
-
await restoreAppStorageInit(transport, appName, backupSize);
|
|
21
|
-
const data = Buffer.concat([
|
|
22
|
-
Buffer.from(backupSize.toString(16).padStart(8, "0"), "hex"), // BACKUP_LEN
|
|
23
|
-
Buffer.from(appName, "ascii"), // APP_NAME
|
|
24
|
-
]);
|
|
25
|
-
const args = [
|
|
26
|
-
0xe0,
|
|
27
|
-
0x6c,
|
|
28
|
-
0x00,
|
|
29
|
-
0x00,
|
|
30
|
-
data,
|
|
31
|
-
[
|
|
32
|
-
StatusCodes.OK,
|
|
33
|
-
StatusCodes.APP_NOT_FOUND_OR_INVALID_CONTEXT,
|
|
34
|
-
StatusCodes.DEVICE_IN_RECOVERY_MODE,
|
|
35
|
-
StatusCodes.USER_REFUSED_ON_DEVICE,
|
|
36
|
-
StatusCodes.PIN_NOT_SET,
|
|
37
|
-
StatusCodes.INVALID_APP_NAME_LENGTH,
|
|
38
|
-
StatusCodes.INVALID_BACKUP_LENGTH,
|
|
39
|
-
],
|
|
40
|
-
];
|
|
41
|
-
expect(transport.send).toHaveBeenCalledWith(...args);
|
|
42
|
-
});
|
|
43
|
-
describe("parseResponse", () => {
|
|
44
|
-
it("should parse the response data correctly", () => {
|
|
45
|
-
expect(() => parseResponse(response)).not.toThrow();
|
|
46
|
-
});
|
|
47
|
-
it("should throw TransportStatusError if the response status is invalid", () => {
|
|
48
|
-
const data = Buffer.from([0x67, 0x0a]);
|
|
49
|
-
expect(() => parseResponse(data)).toThrow(new InvalidAppNameLength("Invalid application name length, two chars minimum."));
|
|
50
|
-
});
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
//# sourceMappingURL=restoreAppStorageInit.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"restoreAppStorageInit.test.js","sourceRoot":"","sources":["../../../../src/commands/use-cases/app-backup/restoreAppStorageInit.test.ts"],"names":[],"mappings":"AAAA,OAAkB,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC/E,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AAEvD,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;AAEpC,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,IAAI,SAAoB,CAAC;IACzB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IAE3C,UAAU,CAAC,GAAG,EAAE;QACd,SAAS,GAAG;YACV,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC;YAC3C,eAAe,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC;SAChC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,KAAK,IAAI,EAAE;QACrE,MAAM,OAAO,GAAG,OAAO,CAAC;QACxB,MAAM,UAAU,GAAG,IAAI,CAAC;QACxB,MAAM,qBAAqB,CAAC,SAAS,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;QAE5D,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC;YACzB,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,KAAK,CAAC,EAAE,aAAa;YAC3E,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,WAAW;SAC3C,CAAC,CAAC;QAEH,MAAM,IAAI,GAAG;YACX,IAAI;YACJ,IAAI;YACJ,IAAI;YACJ,IAAI;YACJ,IAAI;YACJ;gBACE,WAAW,CAAC,EAAE;gBACd,WAAW,CAAC,gCAAgC;gBAC5C,WAAW,CAAC,uBAAuB;gBACnC,WAAW,CAAC,sBAAsB;gBAClC,WAAW,CAAC,WAAW;gBACvB,WAAW,CAAC,uBAAuB;gBACnC,WAAW,CAAC,qBAAqB;aAClC;SACF,CAAC;QAEF,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,oBAAoB,CAAC,GAAG,IAAI,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;QAC7B,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YAClD,MAAM,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACtD,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,qEAAqE,EAAE,GAAG,EAAE;YAC7E,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;YACvC,MAAM,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CACvC,IAAI,oBAAoB,CAAC,qDAAqD,CAAC,CAChF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"reinstallConfigurationConsent.test.d.ts","sourceRoot":"","sources":["../../../../src/commands/use-cases/consent/reinstallConfigurationConsent.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { StatusCodes, TransportStatusError } from "@ledgerhq/hw-transport";
|
|
2
|
-
import { reinstallConfigurationConsent } from "./reinstallConfigurationConsent";
|
|
3
|
-
import { PinNotSet, UserRefusedOnDevice } from "@ledgerhq/errors";
|
|
4
|
-
describe("reinstallConfigurationConsent", () => {
|
|
5
|
-
let transport;
|
|
6
|
-
beforeEach(() => {
|
|
7
|
-
transport = {
|
|
8
|
-
send: jest.fn().mockResolvedValue(Buffer.from([])),
|
|
9
|
-
getTraceContext: jest.fn().mockResolvedValue(undefined),
|
|
10
|
-
};
|
|
11
|
-
});
|
|
12
|
-
afterEach(() => {
|
|
13
|
-
jest.clearAllMocks();
|
|
14
|
-
});
|
|
15
|
-
describe("success cases", () => {
|
|
16
|
-
it("should call the send function with correct parameters", async () => {
|
|
17
|
-
transport.send = jest.fn().mockResolvedValue(Buffer.from([0x90, 0x00]));
|
|
18
|
-
await reinstallConfigurationConsent(transport, [0x00, 0x00, 0x00, 0x00]);
|
|
19
|
-
expect(transport.send).toHaveBeenCalledWith(0xe0, 0x6f, 0x00, 0x00, Buffer.from([0x00, 0x00, 0x00, 0x00]), [StatusCodes.OK, StatusCodes.USER_REFUSED_ON_DEVICE, StatusCodes.PIN_NOT_SET]);
|
|
20
|
-
});
|
|
21
|
-
});
|
|
22
|
-
describe("error cases", () => {
|
|
23
|
-
it("should throw UserRefusedOnDevice if the user refused on device", async () => {
|
|
24
|
-
transport.send = jest.fn().mockResolvedValue(Buffer.from([0x55, 0x01]));
|
|
25
|
-
await expect(reinstallConfigurationConsent(transport, [0x00, 0x00, 0x00, 0x00])).rejects.toThrow(new UserRefusedOnDevice("User refused on device"));
|
|
26
|
-
});
|
|
27
|
-
it("should throw PINNotSet if the PIN is not set", async () => {
|
|
28
|
-
transport.send = jest.fn().mockResolvedValue(Buffer.from([0x55, 0x02]));
|
|
29
|
-
await expect(reinstallConfigurationConsent(transport, [0x00, 0x00, 0x00, 0x00])).rejects.toThrow(new PinNotSet("PIN not set"));
|
|
30
|
-
});
|
|
31
|
-
it("should throw TransportStatusError if the response status is invalid", async () => {
|
|
32
|
-
transport.send = jest.fn().mockResolvedValue(Buffer.from([0x6f, 0x00]));
|
|
33
|
-
await expect(reinstallConfigurationConsent(transport, [0x00, 0x00, 0x00, 0x00])).rejects.toThrow(new TransportStatusError(0x6f00));
|
|
34
|
-
});
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
//# sourceMappingURL=reinstallConfigurationConsent.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"reinstallConfigurationConsent.test.js","sourceRoot":"","sources":["../../../../src/commands/use-cases/consent/reinstallConfigurationConsent.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"isBootloaderVersionSupported.test.d.ts","sourceRoot":"","sources":["../../../src/commands/use-cases/isBootloaderVersionSupported.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import { DeviceModelId } from "@ledgerhq/devices";
|
|
2
|
-
import { isBootloaderVersionSupported } from "./isBootloaderVersionSupported";
|
|
3
|
-
const { nanoS, nanoSP, nanoX, stax, europa, apex } = DeviceModelId;
|
|
4
|
-
test("isBootloaderVersionSupported", () => {
|
|
5
|
-
/**
|
|
6
|
-
* Nano S
|
|
7
|
-
* */
|
|
8
|
-
expect(isBootloaderVersionSupported("1.9.0", nanoS)).toBe(false);
|
|
9
|
-
expect(isBootloaderVersionSupported("1.9.0-whatever0", nanoS)).toBe(false);
|
|
10
|
-
expect(isBootloaderVersionSupported("2.0.0", nanoS)).toBe(true);
|
|
11
|
-
expect(isBootloaderVersionSupported("2.0.0-rc1", nanoS)).toBe(true);
|
|
12
|
-
expect(isBootloaderVersionSupported("2.0.1", nanoS)).toBe(true);
|
|
13
|
-
expect(isBootloaderVersionSupported("2.0.1-whatever0", nanoS)).toBe(true);
|
|
14
|
-
expect(isBootloaderVersionSupported("2.1.0", nanoS)).toBe(true);
|
|
15
|
-
expect(isBootloaderVersionSupported("2.1.0-whatever0", nanoS)).toBe(true);
|
|
16
|
-
expect(isBootloaderVersionSupported("3.0.0", nanoS)).toBe(true);
|
|
17
|
-
expect(isBootloaderVersionSupported("3.0.0-whatever0", nanoS)).toBe(true);
|
|
18
|
-
/**
|
|
19
|
-
* Nano X
|
|
20
|
-
* */
|
|
21
|
-
expect(isBootloaderVersionSupported("1.9.0", nanoX)).toBe(false);
|
|
22
|
-
expect(isBootloaderVersionSupported("1.9.0-whatever0", nanoX)).toBe(false);
|
|
23
|
-
expect(isBootloaderVersionSupported("2.0.0", nanoX)).toBe(true);
|
|
24
|
-
expect(isBootloaderVersionSupported("2.0.0-rc1", nanoX)).toBe(true);
|
|
25
|
-
expect(isBootloaderVersionSupported("2.0.1", nanoX)).toBe(true);
|
|
26
|
-
expect(isBootloaderVersionSupported("2.0.1-whatever0", nanoX)).toBe(true);
|
|
27
|
-
expect(isBootloaderVersionSupported("2.1.0", nanoX)).toBe(true);
|
|
28
|
-
expect(isBootloaderVersionSupported("2.1.0-whatever0", nanoX)).toBe(true);
|
|
29
|
-
expect(isBootloaderVersionSupported("3.0.0", nanoX)).toBe(true);
|
|
30
|
-
expect(isBootloaderVersionSupported("3.0.0-whatever0", nanoX)).toBe(true);
|
|
31
|
-
/**
|
|
32
|
-
* Nano SP
|
|
33
|
-
* */
|
|
34
|
-
expect(isBootloaderVersionSupported("0.9.0", nanoSP)).toBe(false);
|
|
35
|
-
expect(isBootloaderVersionSupported("0.9.0-whatever0", nanoSP)).toBe(false);
|
|
36
|
-
expect(isBootloaderVersionSupported("1.0.0", nanoSP)).toBe(true);
|
|
37
|
-
expect(isBootloaderVersionSupported("1.0.0-rc1", nanoSP)).toBe(true);
|
|
38
|
-
expect(isBootloaderVersionSupported("1.0.1", nanoSP)).toBe(true);
|
|
39
|
-
expect(isBootloaderVersionSupported("1.0.1-whatever0", nanoSP)).toBe(true);
|
|
40
|
-
expect(isBootloaderVersionSupported("1.1.0", nanoSP)).toBe(true);
|
|
41
|
-
expect(isBootloaderVersionSupported("1.1.0-whatever0", nanoSP)).toBe(true);
|
|
42
|
-
expect(isBootloaderVersionSupported("1.0.0", nanoSP)).toBe(true);
|
|
43
|
-
expect(isBootloaderVersionSupported("1.0.0-whatever0", nanoSP)).toBe(true);
|
|
44
|
-
/**
|
|
45
|
-
* Stax
|
|
46
|
-
* */
|
|
47
|
-
expect(isBootloaderVersionSupported("0.9.0", stax)).toBe(false);
|
|
48
|
-
expect(isBootloaderVersionSupported("1.0.0", stax)).toBe(true);
|
|
49
|
-
expect(isBootloaderVersionSupported("1.0.0-whatever0", stax)).toBe(true);
|
|
50
|
-
/**
|
|
51
|
-
* Europa
|
|
52
|
-
*/
|
|
53
|
-
expect(isBootloaderVersionSupported("0.1.0", europa)).toBe(true);
|
|
54
|
-
expect(isBootloaderVersionSupported("0.1.0-whatever0", europa)).toBe(true);
|
|
55
|
-
/**
|
|
56
|
-
* Apex
|
|
57
|
-
*/
|
|
58
|
-
expect(isBootloaderVersionSupported("0.1.0", apex)).toBe(true);
|
|
59
|
-
expect(isBootloaderVersionSupported("0.1.0-whatever0", apex)).toBe(true);
|
|
60
|
-
});
|
|
61
|
-
//# sourceMappingURL=isBootloaderVersionSupported.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"isBootloaderVersionSupported.test.js","sourceRoot":"","sources":["../../../src/commands/use-cases/isBootloaderVersionSupported.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"isCharonSupported.test.d.ts","sourceRoot":"","sources":["../../../src/commands/use-cases/isCharonSupported.test.ts"],"names":[],"mappings":""}
|