From c1c8f11bf774179b7bb29d6f2b7e723a47693fe9 Mon Sep 17 00:00:00 2001 From: Bruno Windels Date: Fri, 5 Mar 2021 11:50:54 +0100 Subject: [PATCH] fix TypeError when syncing a new e2ee room with keys at the same time --- src/matrix/room/Room.js | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/matrix/room/Room.js b/src/matrix/room/Room.js index 5bab0a40..88552ca0 100644 --- a/src/matrix/room/Room.js +++ b/src/matrix/room/Room.js @@ -55,8 +55,8 @@ export class Room extends EventEmitter { this._observedEvents = null; } - async _getRetryDecryptEntriesForKey(roomKey, txn) { - const retryEventIds = await this._roomEncryption.getEventIdsForMissingKey(roomKey, txn); + async _getRetryDecryptEntriesForKey(roomKey, roomEncryption, txn) { + const retryEventIds = await roomEncryption.getEventIdsForMissingKey(roomKey, txn); const retryEntries = []; if (retryEventIds) { for (const eventId of retryEventIds) { @@ -83,7 +83,7 @@ export class Room extends EventEmitter { this._storage.storeNames.timelineEvents, this._storage.storeNames.inboundGroupSessions, ]); - const retryEntries = await this._getRetryDecryptEntriesForKey(roomKey, txn); + const retryEntries = await this._getRetryDecryptEntriesForKey(roomKey, this._roomEncryption, txn); if (retryEntries.length) { const decryptRequest = this._decryptEntries(DecryptionSource.Retry, retryEntries, txn); // this will close txn while awaiting decryption @@ -156,8 +156,8 @@ export class Room extends EventEmitter { return request; } - async _getSyncRetryDecryptEntries(newKeys, txn) { - const entriesPerKey = await Promise.all(newKeys.map(key => this._getRetryDecryptEntriesForKey(key, txn))); + async _getSyncRetryDecryptEntries(newKeys, roomEncryption, txn) { + const entriesPerKey = await Promise.all(newKeys.map(key => this._getRetryDecryptEntriesForKey(key, roomEncryption, txn))); let retryEntries = entriesPerKey.reduce((allEntries, entries) => allEntries.concat(entries), []); // If we have the timeline open, see if there are more entries for the new keys // as we only store missing session information for synced events, not backfilled. @@ -195,7 +195,7 @@ export class Room extends EventEmitter { let eventsToDecrypt = roomResponse?.timeline?.events || []; // when new keys arrive, also see if any older events can now be retried to decrypt if (newKeys) { - retryEntries = await this._getSyncRetryDecryptEntries(newKeys, txn); + retryEntries = await this._getSyncRetryDecryptEntries(newKeys, roomEncryption, txn); if (retryEntries.length) { log.set("retry", retryEntries.length); eventsToDecrypt = eventsToDecrypt.concat(retryEntries.map(entry => entry.event));