From 4956e8322815e9927ff5af568b4a7a4dcf9ae2c7 Mon Sep 17 00:00:00 2001 From: "J. Ryan Stinnett" Date: Tue, 10 Dec 2019 16:53:15 +0000 Subject: [PATCH] Remove secret storage key cache for now --- src/CrossSigningManager.js | 17 ----------------- 1 file changed, 17 deletions(-) diff --git a/src/CrossSigningManager.js b/src/CrossSigningManager.js index b158f0dfaf..5dc709bd10 100644 --- a/src/CrossSigningManager.js +++ b/src/CrossSigningManager.js @@ -20,25 +20,12 @@ import MatrixClientPeg from './MatrixClientPeg'; import { deriveKey } from 'matrix-js-sdk/lib/crypto/key_passphrase'; import { decodeRecoveryKey } from 'matrix-js-sdk/lib/crypto/recoverykey'; -// This stores the secret storage private keys in memory for the JS SDK. This is -// only meant to act as a cache to avoid prompting the user multiple times -// during the same session. It is considered unsafe to persist this to normal -// web storage. For platforms with a secure enclave, we will store this key -// there. -const secretStorageKeys = {}; - export const getSecretStorageKey = async ({ keys: keyInfos }) => { const keyInfoEntries = Object.entries(keyInfos); if (keyInfoEntries.length > 1) { throw new Error("Multiple storage key requests not implemented"); } const [name, info] = keyInfoEntries[0]; - - // Check the in-memory cache - if (secretStorageKeys[name]) { - return [name, secretStorageKeys[name]]; - } - const inputToKey = async ({ passphrase, recoveryKey }) => { if (passphrase) { return deriveKey( @@ -67,9 +54,5 @@ export const getSecretStorageKey = async ({ keys: keyInfos }) => { throw new Error("Secret storage access canceled"); } const key = await inputToKey(input); - - // Save to cache to avoid future prompts in the current session - secretStorageKeys[name] = key; - return [name, key]; };