-
Notifications
You must be signed in to change notification settings - Fork 264
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow room keys for inbound group sessions to be updated when we receive a "better" copy #3703
Comments
Scenario 3: Backup faster than keyBob's receives a message before the keys, then queries the backup. The key was already uploaded to backup (by a session that was online at that time). This scenario seems to be more common with simplified sliding sync. |
Now that we have the diff --git a/crates/matrix-sdk-crypto/src/olm/group_sessions/inbound.rs b/crates/matrix-sdk-crypto/src/olm/group_sessions/inbound.rs
index f43e013e4..58c0579c7 100644
--- a/crates/matrix-sdk-crypto/src/olm/group_sessions/inbound.rs
+++ b/crates/matrix-sdk-crypto/src/olm/group_sessions/inbound.rs
@@ -13,6 +13,7 @@
// limitations under the License.
use std::{
+ cmp::Ordering,
fmt,
ops::Deref,
sync::{
@@ -389,8 +390,18 @@ impl InboundGroupSession {
{
SessionOrdering::Unconnected
} else {
- let mut other = other.inner.lock().await;
- self.inner.lock().await.compare(&mut other)
+ let mut other_inner = other.inner.lock().await;
+
+ match self.inner.lock().await.compare(&mut other_inner) {
+ SessionOrdering::Equal => {
+ match self.sender_data.compare_trust_level(&other.sender_data) {
+ Ordering::Less => SessionOrdering::Worse,
+ Ordering::Equal => SessionOrdering::Equal,
+ Ordering::Greater => SessionOrdering::Better,
+ }
+ }
+ result => result,
+ }
}
} |
filed at app layer in element-hq/element-x-ios#3352 |
There is another scenario were this occurs, and counter intuitively the late key is received before getting the response from the backup: First the fail to decrypt: Then query to key storage: Just after the late key arrives: Then got the backup response: And that key is imported also via And for some reason this last import is the one persisted (has gray shield because of warning) Possible scenario: The The room key from sync calls |
Created a specific issue for the race that allows to by-pass the check #4227 |
When we receive a Megolm key (session) with a particular session ID from somewhere, we need to store it into the local store. The key is flagged with
imported
if it was not received directly from am.room_key
(file import, backup, ..)Messages decrypted with an
imported
key should have a warning (authenticity cannot be guaranteed on this device
a.k.a gray shield)It is possible to receive the same key from different sources (and at different ratchet index) at different times.
Some scenario where it creates unwanted shields:
Scenario 1: ratcheted key after root downloaded from backup
Alice create a new login, get access to key backup.
The key
s0
(owned by bob) is in backup at index 0. There are 3 messages encrypted with that index.If bob sends now a new message, the ratcheted key
s0
will be distributed to Alice's new login via am.room_key
As per the current algorithm
matrix-rust-sdk/crates/matrix-sdk-crypto/src/machine.rs
Lines 839 to 846 in 62137e5
=> the ratcheted key will be discarded and we keep the
better
one, but it is stillimported=true
(the ratcheted key isimported=false
)Scenario 2: Better key downloaded from backup replaces a ratcheted key received as a
m.room_key
matrix-rust-sdk/crates/matrix-sdk-crypto/src/store/mod.rs
Lines 1702 to 1704 in 62137e5
The backup key will replace the existing non imported key
See element-hq/element-web#26526
Solution
Implement proper megolm key updating.
When receiving a
m.room_key
, If we have an existing better key that is mark asimported
, we could keep the existing better key and update theimported
flag (if the key connects properly)See legacy implementation https://github.com/element-hq/element-android/blob/7073b1647c3897b5a30c4886db5975a26f16c6a1/matrix-sdk-android/src/kotlinCrypto/java/org/matrix/android/sdk/internal/crypto/MXOlmDevice.kt#L667
See full algorithm details here https://docs.google.com/document/d/1IJkeUn5rNehDapKY75xQ9rutoElVjQHeSdw8dQpb_O0/edit
The text was updated successfully, but these errors were encountered: