From 25aac4b7c0f074e92a4d3ebd1632d60186e744b3 Mon Sep 17 00:00:00 2001 From: Bruno Windels <274386+bwindels@users.noreply.github.com> Date: Thu, 30 Mar 2023 17:43:52 +0200 Subject: [PATCH] WIP --- src/matrix/Session.js | 16 +++++++++++----- src/matrix/ssss/SecretStorage.ts | 11 +++++++++++ 2 files changed, 22 insertions(+), 5 deletions(-) diff --git a/src/matrix/Session.js b/src/matrix/Session.js index 23c9cce6..6d3d55bc 100644 --- a/src/matrix/Session.js +++ b/src/matrix/Session.js @@ -89,6 +89,7 @@ export class Session { this._megolmDecryption = null; this._getSyncToken = () => this.syncToken; this._olmWorker = olmWorker; + this._secretStorage = undefined; this._keyBackup = new ObservableValue(undefined); this._crossSigning = new ObservableValue(undefined); this._observedRoomStatus = new Map(); @@ -332,13 +333,14 @@ export class Session { const isValid = await secretStorage.hasValidKeyForAnyAccountData(); log.set("isValid", isValid); if (isValid) { - await this._loadSecretStorageServices(secretStorage, log); + this._secretStorage = secretStorage; + await this._loadSecretStorageService(log); } return isValid; }); } - async _loadSecretStorageServices(secretStorage, log) { + async _loadSecretStorageServices(log) { try { await log.wrap("enable key backup", async log => { const keyBackup = new KeyBackup( @@ -348,7 +350,7 @@ export class Session { this._storage, this._platform, ); - if (await keyBackup.load(secretStorage, log)) { + if (await keyBackup.load(this._secretStorage, log)) { for (const room of this._rooms.values()) { if (room.isEncrypted) { room.enableKeyBackup(keyBackup); @@ -364,7 +366,7 @@ export class Session { await log.wrap("enable cross-signing", async log => { const crossSigning = new CrossSigning({ storage: this._storage, - secretStorage, + secretStorage: this._secretStorage, platform: this._platform, olm: this._olm, olmUtil: this._olmUtil, @@ -775,12 +777,13 @@ export class Session { txn.accountData.set(event); } } + changes.accountData = accountData.events; } return changes; } /** @internal */ - afterSync({syncInfo, e2eeAccountChanges}) { + afterSync({syncInfo, e2eeAccountChanges, accountData}) { if (syncInfo) { // sync transaction succeeded, modify object state now this._syncInfo = syncInfo; @@ -788,6 +791,9 @@ export class Session { if (this._e2eeAccount) { this._e2eeAccount.afterSync(e2eeAccountChanges); } + if (accountData && this._secretStorage) { + this._secretStorage.afterSync(accountData); + } } /** @internal */ diff --git a/src/matrix/ssss/SecretStorage.ts b/src/matrix/ssss/SecretStorage.ts index 4c767bbb..a5e15768 100644 --- a/src/matrix/ssss/SecretStorage.ts +++ b/src/matrix/ssss/SecretStorage.ts @@ -41,6 +41,7 @@ export class SecretStorage { private readonly _key: Key; private readonly _platform: Platform; private readonly _storage: Storage; + private observedSecrets constructor({key, platform, storage}: {key: Key, platform: Platform, storage: Storage}) { this._key = key; @@ -48,6 +49,12 @@ export class SecretStorage { this._storage = storage; } + afterSync(accountData: ReadonlyArray<{type: string, content: Record}>): void { + for(const event of accountData) { + if (type === ) + } + } + /** this method will auto-commit any indexeddb transaction because of its use of the webcrypto api */ async hasValidKeyForAnyAccountData() { const txn = await this._storage.readTxn([ @@ -69,6 +76,10 @@ export class SecretStorage { return false; } + observeSecret(name: string): BaseObservableValue { + + } + /** this method will auto-commit any indexeddb transaction because of its use of the webcrypto api */ async readSecret(name: string): Promise { const txn = await this._storage.readTxn([