Skip to content

Commit

Permalink
Schedule dehydration on reload
Browse files Browse the repository at this point in the history
  • Loading branch information
uhoreg committed Jan 17, 2025
1 parent e42ee72 commit df668b6
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 1 deletion.
11 changes: 10 additions & 1 deletion src/MatrixClientPeg.ts
Original file line number Diff line number Diff line change
Expand Up @@ -340,7 +340,16 @@ class MatrixClientPegClass implements IMatrixClientPeg {

setDeviceIsolationMode(this.matrixClient, SettingsStore.getValue("feature_exclude_insecure_devices"));

// TODO: device dehydration and whathaveyou
// Start dehydration. This code is only for the case where the client
// gets restarted, so we only do this if we already have the dehydration
// key cached, and we don't have to try to rehydrate a device. If this
// is a new login, we will start dehydration after Secret Storage is
// unlocked.
const crypto = this.matrixClient.getCrypto();
if (await crypto?.isDehydrationSupported()) {
await crypto.startDehydration({ onlyIfKeyCached: true, rehydrate: false });

Check failure on line 350 in src/MatrixClientPeg.ts

View workflow job for this annotation

GitHub Actions / Typescript Syntax Check

'crypto' is possibly 'undefined'.
}

return;
}

Expand Down
7 changes: 7 additions & 0 deletions test/unit-tests/MatrixClientPeg-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -80,10 +80,17 @@ describe("MatrixClientPeg", () => {

it("should initialise the rust crypto library by default", async () => {
const mockInitRustCrypto = jest.spyOn(testPeg.safeGet(), "initRustCrypto").mockResolvedValue(undefined);
const mockStartDehydration = jest.fn();
jest.spyOn(testPeg.safeGet(), "getCrypto").mockReturnValue({

Check failure on line 84 in test/unit-tests/MatrixClientPeg-test.ts

View workflow job for this annotation

GitHub Actions / Typescript Syntax Check

Argument of type '{ isDehydrationSupported: jest.Mock<any, any, any>; startDehydration: jest.Mock<any, any, any>; setDeviceIsolationMode: jest.Mock<any, any, any>; }' is not assignable to parameter of type 'CryptoApi'.
isDehydrationSupported: jest.fn().mockResolvedValue(true),
startDehydration: mockStartDehydration,
setDeviceIsolationMode: jest.fn(),
});

const cryptoStoreKey = new Uint8Array([1, 2, 3, 4]);
await testPeg.start({ rustCryptoStoreKey: cryptoStoreKey });
expect(mockInitRustCrypto).toHaveBeenCalledWith({ storageKey: cryptoStoreKey });
expect(mockStartDehydration).toHaveBeenCalledWith({ onlyIfKeyCached: true, rehydrate: false });
});

it("Should migrate existing login", async () => {
Expand Down
2 changes: 2 additions & 0 deletions test/unit-tests/components/structures/MatrixChat-test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -129,6 +129,7 @@ describe("<MatrixChat />", () => {
getCrypto: jest.fn().mockReturnValue({
getVerificationRequestsToDeviceInProgress: jest.fn().mockReturnValue([]),
isCrossSigningReady: jest.fn().mockReturnValue(false),
isDehydrationSupported: jest.fn().mockReturnValue(false),
getUserDeviceInfo: jest.fn().mockReturnValue(new Map()),
getUserVerificationStatus: jest.fn().mockResolvedValue(new UserVerificationStatus(false, false, false)),
getVersion: jest.fn().mockReturnValue("1"),
Expand Down Expand Up @@ -1006,6 +1007,7 @@ describe("<MatrixChat />", () => {
resetKeyBackup: jest.fn(),
isEncryptionEnabledInRoom: jest.fn().mockResolvedValue(false),
checkKeyBackupAndEnable: jest.fn().mockResolvedValue(null),
isDehydrationSupported: jest.fn().mockReturnValue(false),
};
loginClient.getCrypto.mockReturnValue(mockCrypto as any);
});
Expand Down

0 comments on commit df668b6

Please sign in to comment.