diff options
Diffstat (limited to 'includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js.map')
-rw-r--r-- | includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js.map | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js.map b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js.map new file mode 100644 index 0000000..9b80af9 --- /dev/null +++ b/includes/external/matrix/node_modules/matrix-js-sdk/lib/crypto/EncryptionSetup.js.map @@ -0,0 +1 @@ +{"version":3,"file":"EncryptionSetup.js","names":["_logger","require","_event","_CrossSigning","_indexeddbCryptoStore","_httpApi","_client","_typedEventEmitter","EncryptionSetupBuilder","constructor","accountData","delegateCryptoCallbacks","_defineProperty2","default","accountDataClientAdapter","AccountDataClientAdapter","crossSigningCallbacks","CrossSigningCallbacks","ssssCryptoCallbacks","SSSSCryptoCallbacks","addCrossSigningKeys","authUpload","keys","crossSigningKeys","addSessionBackup","keyBackupInfo","addSessionBackupPrivateKeyToCache","privateKey","sessionBackupPrivateKey","addKeySignature","userId","deviceId","signature","keySignatures","userSignatures","setAccountData","type","content","buildOperation","values","EncryptionSetupOperation","persist","crypto","cacheCallbacks","createCryptoStoreCacheCallbacks","cryptoStore","olmDevice","_cacheCallbacks$store","logger","log","privateKeys","get","storeCrossSigningKeyCache","call","doTxn","IndexedDBCryptoStore","STORE_ACCOUNT","txn","storeCrossSigningKeys","storeSessionBackupPrivateKey","exports","apply","baseApis","_this$crossSigningKey","_this$crossSigningKey2","name","key","Object","entries","authDict","uploadDeviceSigningKeys","crossSigningInfo","setKeys","uploadKeySignatures","version","http","authedRequest","Method","Put","undefined","algorithm","auth_data","prefix","ClientPrefix","V3","Post","TypedEventEmitter","existingValues","Map","getAccountDataFromServer","Promise","resolve","getAccountData","modifiedValue","existingValue","getContent","lastEvent","set","then","event","MatrixEvent","emit","ClientEvent","AccountData","getCrossSigningKeyCache","expectedPublicKey","getCrossSigningKey","expectedPubkey","_this$privateKeys$get","saveCrossSigningKeys","getSecretStorageKey","_this$delegateCryptoC","keyId","result","addPrivateKey","keyInfo","privKey","_this$delegateCryptoC2","_this$delegateCryptoC3","cacheSecretStorageKey"],"sources":["../../src/crypto/EncryptionSetup.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { logger } from \"../logger\";\nimport { IContent, MatrixEvent } from \"../models/event\";\nimport { createCryptoStoreCacheCallbacks, ICacheCallbacks } from \"./CrossSigning\";\nimport { IndexedDBCryptoStore } from \"./store/indexeddb-crypto-store\";\nimport { Method, ClientPrefix } from \"../http-api\";\nimport { Crypto, ICryptoCallbacks, IBootstrapCrossSigningOpts } from \"./index\";\nimport {\n ClientEvent,\n ClientEventHandlerMap,\n CrossSigningKeys,\n ICrossSigningKey,\n ISignedKey,\n KeySignatures,\n} from \"../client\";\nimport { IKeyBackupInfo } from \"./keybackup\";\nimport { TypedEventEmitter } from \"../models/typed-event-emitter\";\nimport { IAccountDataClient } from \"./SecretStorage\";\nimport { SecretStorageKeyDescription } from \"../secret-storage\";\n\ninterface ICrossSigningKeys {\n authUpload: IBootstrapCrossSigningOpts[\"authUploadDeviceSigningKeys\"];\n keys: Record<\"master\" | \"self_signing\" | \"user_signing\", ICrossSigningKey>;\n}\n\n/**\n * Builds an EncryptionSetupOperation by calling any of the add.. methods.\n * Once done, `buildOperation()` can be called which allows to apply to operation.\n *\n * This is used as a helper by Crypto to keep track of all the network requests\n * and other side-effects of bootstrapping, so it can be applied in one go (and retried in the future)\n * Also keeps track of all the private keys created during bootstrapping, so we don't need to prompt for them\n * more than once.\n */\nexport class EncryptionSetupBuilder {\n public readonly accountDataClientAdapter: AccountDataClientAdapter;\n public readonly crossSigningCallbacks: CrossSigningCallbacks;\n public readonly ssssCryptoCallbacks: SSSSCryptoCallbacks;\n\n private crossSigningKeys?: ICrossSigningKeys;\n private keySignatures?: KeySignatures;\n private keyBackupInfo?: IKeyBackupInfo;\n private sessionBackupPrivateKey?: Uint8Array;\n\n /**\n * @param accountData - pre-existing account data, will only be read, not written.\n * @param delegateCryptoCallbacks - crypto callbacks to delegate to if the key isn't in cache yet\n */\n public constructor(accountData: Map<string, MatrixEvent>, delegateCryptoCallbacks?: ICryptoCallbacks) {\n this.accountDataClientAdapter = new AccountDataClientAdapter(accountData);\n this.crossSigningCallbacks = new CrossSigningCallbacks();\n this.ssssCryptoCallbacks = new SSSSCryptoCallbacks(delegateCryptoCallbacks);\n }\n\n /**\n * Adds new cross-signing public keys\n *\n * @param authUpload - Function called to await an interactive auth\n * flow when uploading device signing keys.\n * Args:\n * A function that makes the request requiring auth. Receives\n * the auth data as an object. Can be called multiple times, first with\n * an empty authDict, to obtain the flows.\n * @param keys - the new keys\n */\n public addCrossSigningKeys(authUpload: ICrossSigningKeys[\"authUpload\"], keys: ICrossSigningKeys[\"keys\"]): void {\n this.crossSigningKeys = { authUpload, keys };\n }\n\n /**\n * Adds the key backup info to be updated on the server\n *\n * Used either to create a new key backup, or add signatures\n * from the new MSK.\n *\n * @param keyBackupInfo - as received from/sent to the server\n */\n public addSessionBackup(keyBackupInfo: IKeyBackupInfo): void {\n this.keyBackupInfo = keyBackupInfo;\n }\n\n /**\n * Adds the session backup private key to be updated in the local cache\n *\n * Used after fixing the format of the key\n *\n */\n public addSessionBackupPrivateKeyToCache(privateKey: Uint8Array): void {\n this.sessionBackupPrivateKey = privateKey;\n }\n\n /**\n * Add signatures from a given user and device/x-sign key\n * Used to sign the new cross-signing key with the device key\n *\n */\n public addKeySignature(userId: string, deviceId: string, signature: ISignedKey): void {\n if (!this.keySignatures) {\n this.keySignatures = {};\n }\n const userSignatures = this.keySignatures[userId] || {};\n this.keySignatures[userId] = userSignatures;\n userSignatures[deviceId] = signature;\n }\n\n public async setAccountData(type: string, content: object): Promise<void> {\n await this.accountDataClientAdapter.setAccountData(type, content);\n }\n\n /**\n * builds the operation containing all the parts that have been added to the builder\n */\n public buildOperation(): EncryptionSetupOperation {\n const accountData = this.accountDataClientAdapter.values;\n return new EncryptionSetupOperation(accountData, this.crossSigningKeys, this.keyBackupInfo, this.keySignatures);\n }\n\n /**\n * Stores the created keys locally.\n *\n * This does not yet store the operation in a way that it can be restored,\n * but that is the idea in the future.\n */\n public async persist(crypto: Crypto): Promise<void> {\n // store private keys in cache\n if (this.crossSigningKeys) {\n const cacheCallbacks = createCryptoStoreCacheCallbacks(crypto.cryptoStore, crypto.olmDevice);\n for (const type of [\"master\", \"self_signing\", \"user_signing\"]) {\n logger.log(`Cache ${type} cross-signing private key locally`);\n const privateKey = this.crossSigningCallbacks.privateKeys.get(type);\n await cacheCallbacks.storeCrossSigningKeyCache?.(type, privateKey);\n }\n // store own cross-sign pubkeys as trusted\n await crypto.cryptoStore.doTxn(\"readwrite\", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {\n crypto.cryptoStore.storeCrossSigningKeys(txn, this.crossSigningKeys!.keys);\n });\n }\n // store session backup key in cache\n if (this.sessionBackupPrivateKey) {\n await crypto.storeSessionBackupPrivateKey(this.sessionBackupPrivateKey);\n }\n }\n}\n\n/**\n * Can be created from EncryptionSetupBuilder, or\n * (in a follow-up PR, not implemented yet) restored from storage, to retry.\n *\n * It does not have knowledge of any private keys, unlike the builder.\n */\nexport class EncryptionSetupOperation {\n /**\n */\n public constructor(\n private readonly accountData: Map<string, object>,\n private readonly crossSigningKeys?: ICrossSigningKeys,\n private readonly keyBackupInfo?: IKeyBackupInfo,\n private readonly keySignatures?: KeySignatures,\n ) {}\n\n /**\n * Runs the (remaining part of, in the future) operation by sending requests to the server.\n */\n public async apply(crypto: Crypto): Promise<void> {\n const baseApis = crypto.baseApis;\n // upload cross-signing keys\n if (this.crossSigningKeys) {\n const keys: Partial<CrossSigningKeys> = {};\n for (const [name, key] of Object.entries(this.crossSigningKeys.keys)) {\n keys[((name as keyof ICrossSigningKeys[\"keys\"]) + \"_key\") as keyof CrossSigningKeys] = key;\n }\n\n // We must only call `uploadDeviceSigningKeys` from inside this auth\n // helper to ensure we properly handle auth errors.\n await this.crossSigningKeys.authUpload?.((authDict) => {\n return baseApis.uploadDeviceSigningKeys(authDict, keys as CrossSigningKeys);\n });\n\n // pass the new keys to the main instance of our own CrossSigningInfo.\n crypto.crossSigningInfo.setKeys(this.crossSigningKeys.keys);\n }\n // set account data\n if (this.accountData) {\n for (const [type, content] of this.accountData) {\n await baseApis.setAccountData(type, content);\n }\n }\n // upload first cross-signing signatures with the new key\n // (e.g. signing our own device)\n if (this.keySignatures) {\n await baseApis.uploadKeySignatures(this.keySignatures);\n }\n // need to create/update key backup info\n if (this.keyBackupInfo) {\n if (this.keyBackupInfo.version) {\n // session backup signature\n // The backup is trusted because the user provided the private key.\n // Sign the backup with the cross signing key so the key backup can\n // be trusted via cross-signing.\n await baseApis.http.authedRequest(\n Method.Put,\n \"/room_keys/version/\" + this.keyBackupInfo.version,\n undefined,\n {\n algorithm: this.keyBackupInfo.algorithm,\n auth_data: this.keyBackupInfo.auth_data,\n },\n { prefix: ClientPrefix.V3 },\n );\n } else {\n // add new key backup\n await baseApis.http.authedRequest(Method.Post, \"/room_keys/version\", undefined, this.keyBackupInfo, {\n prefix: ClientPrefix.V3,\n });\n }\n }\n }\n}\n\n/**\n * Catches account data set by SecretStorage during bootstrapping by\n * implementing the methods related to account data in MatrixClient\n */\nclass AccountDataClientAdapter\n extends TypedEventEmitter<ClientEvent.AccountData, ClientEventHandlerMap>\n implements IAccountDataClient\n{\n //\n public readonly values = new Map<string, MatrixEvent>();\n\n /**\n * @param existingValues - existing account data\n */\n public constructor(private readonly existingValues: Map<string, MatrixEvent>) {\n super();\n }\n\n /**\n * @returns the content of the account data\n */\n public getAccountDataFromServer<T extends { [k: string]: any }>(type: string): Promise<T> {\n return Promise.resolve(this.getAccountData(type) as T);\n }\n\n /**\n * @returns the content of the account data\n */\n public getAccountData(type: string): IContent | null {\n const modifiedValue = this.values.get(type);\n if (modifiedValue) {\n return modifiedValue;\n }\n const existingValue = this.existingValues.get(type);\n if (existingValue) {\n return existingValue.getContent();\n }\n return null;\n }\n\n public setAccountData(type: string, content: any): Promise<{}> {\n const lastEvent = this.values.get(type);\n this.values.set(type, content);\n // ensure accountData is emitted on the next tick,\n // as SecretStorage listens for it while calling this method\n // and it seems to rely on this.\n return Promise.resolve().then(() => {\n const event = new MatrixEvent({ type, content });\n this.emit(ClientEvent.AccountData, event, lastEvent);\n return {};\n });\n }\n}\n\n/**\n * Catches the private cross-signing keys set during bootstrapping\n * by both cache callbacks (see createCryptoStoreCacheCallbacks) as non-cache callbacks.\n * See CrossSigningInfo constructor\n */\nclass CrossSigningCallbacks implements ICryptoCallbacks, ICacheCallbacks {\n public readonly privateKeys = new Map<string, Uint8Array>();\n\n // cache callbacks\n public getCrossSigningKeyCache(type: string, expectedPublicKey: string): Promise<Uint8Array | null> {\n return this.getCrossSigningKey(type, expectedPublicKey);\n }\n\n public storeCrossSigningKeyCache(type: string, key: Uint8Array): Promise<void> {\n this.privateKeys.set(type, key);\n return Promise.resolve();\n }\n\n // non-cache callbacks\n public getCrossSigningKey(type: string, expectedPubkey: string): Promise<Uint8Array | null> {\n return Promise.resolve(this.privateKeys.get(type) ?? null);\n }\n\n public saveCrossSigningKeys(privateKeys: Record<string, Uint8Array>): void {\n for (const [type, privateKey] of Object.entries(privateKeys)) {\n this.privateKeys.set(type, privateKey);\n }\n }\n}\n\n/**\n * Catches the 4S private key set during bootstrapping by implementing\n * the SecretStorage crypto callbacks\n */\nclass SSSSCryptoCallbacks {\n private readonly privateKeys = new Map<string, Uint8Array>();\n\n public constructor(private readonly delegateCryptoCallbacks?: ICryptoCallbacks) {}\n\n public async getSecretStorageKey(\n { keys }: { keys: Record<string, SecretStorageKeyDescription> },\n name: string,\n ): Promise<[string, Uint8Array] | null> {\n for (const keyId of Object.keys(keys)) {\n const privateKey = this.privateKeys.get(keyId);\n if (privateKey) {\n return [keyId, privateKey];\n }\n }\n // if we don't have the key cached yet, ask\n // for it to the general crypto callbacks and cache it\n if (this?.delegateCryptoCallbacks?.getSecretStorageKey) {\n const result = await this.delegateCryptoCallbacks.getSecretStorageKey({ keys }, name);\n if (result) {\n const [keyId, privateKey] = result;\n this.privateKeys.set(keyId, privateKey);\n }\n return result;\n }\n return null;\n }\n\n public addPrivateKey(keyId: string, keyInfo: SecretStorageKeyDescription, privKey: Uint8Array): void {\n this.privateKeys.set(keyId, privKey);\n // Also pass along to application to cache if it wishes\n this.delegateCryptoCallbacks?.cacheSecretStorageKey?.(keyId, keyInfo, privKey);\n }\n}\n"],"mappings":"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"}
\ No newline at end of file |