mirror of
				https://github.com/vector-im/element-web.git
				synced 2025-10-25 14:21:45 +02:00 
			
		
		
		
	Merge pull request #4275 from matrix-org/foldleft/12704-key-sharing
Respond to backup key sharing requests
This commit is contained in:
		
						commit
						6e8cfc2272
					
				| @ -145,18 +145,33 @@ const onSecretRequested = async function({ | |||||||
|         console.log(`CrossSigningManager: Ignoring request from untrusted device ${deviceId}`); |         console.log(`CrossSigningManager: Ignoring request from untrusted device ${deviceId}`); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |     if (name.startsWith("m.cross_signing")) { | ||||||
|         const callbacks = client.getCrossSigningCacheCallbacks(); |         const callbacks = client.getCrossSigningCacheCallbacks(); | ||||||
|         if (!callbacks.getCrossSigningKeyCache) return; |         if (!callbacks.getCrossSigningKeyCache) return; | ||||||
|  |         /* Explicit enumeration here is deliberate – never share the master key! */ | ||||||
|         if (name === "m.cross_signing.self_signing") { |         if (name === "m.cross_signing.self_signing") { | ||||||
|             const key = await callbacks.getCrossSigningKeyCache("self_signing"); |             const key = await callbacks.getCrossSigningKeyCache("self_signing"); | ||||||
|             if (!key) { |             if (!key) { | ||||||
|             console.log(`self_signing requested by ${deviceId}, but not found in cache`); |                 console.log( | ||||||
|  |                     `self_signing requested by ${deviceId}, but not found in cache`, | ||||||
|  |                 ); | ||||||
|             } |             } | ||||||
|             return key && encodeBase64(key); |             return key && encodeBase64(key); | ||||||
|         } else if (name === "m.cross_signing.user_signing") { |         } else if (name === "m.cross_signing.user_signing") { | ||||||
|             const key = await callbacks.getCrossSigningKeyCache("user_signing"); |             const key = await callbacks.getCrossSigningKeyCache("user_signing"); | ||||||
|             if (!key) { |             if (!key) { | ||||||
|             console.log(`user_signing requested by ${deviceId}, but not found in cache`); |                 console.log( | ||||||
|  |                     `user_signing requested by ${deviceId}, but not found in cache`, | ||||||
|  |                 ); | ||||||
|  |             } | ||||||
|  |             return key && encodeBase64(key); | ||||||
|  |         } | ||||||
|  |     } else if (name === "m.megolm_backup.v1") { | ||||||
|  |         const key = await client._crypto.getSessionBackupPrivateKey(); | ||||||
|  |         if (!key) { | ||||||
|  |             console.log( | ||||||
|  |                 `session backup key requested by ${deviceId}, but not found in cache`, | ||||||
|  |             ); | ||||||
|         } |         } | ||||||
|         return key && encodeBase64(key); |         return key && encodeBase64(key); | ||||||
|     } |     } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user