From 0f6bf758096675fdff672328e11606af74b14893 Mon Sep 17 00:00:00 2001 From: Brendan McMillion Date: Wed, 5 Jun 2024 13:55:46 -0700 Subject: [PATCH 1/2] #252: Discuss Welcome/Commit coupling --- draft-ietf-mls-architecture.md | 34 ++++++++++++++++++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/draft-ietf-mls-architecture.md b/draft-ietf-mls-architecture.md index 3a36bd6..11e3b80 100644 --- a/draft-ietf-mls-architecture.md +++ b/draft-ietf-mls-architecture.md @@ -795,6 +795,36 @@ If the Commit references an unknown proposal, group members may need to solicit the Delivery Service or other group members individually for the contents of the proposal. +### Welcome Messages + +Whenever a commit adds new members to a group, MLS requires the committer to +send a Welcome message to the new members. Applications should ensure that +Welcome messages are coupled with the tie-breaking logic for commits, discussed +in {{strongly-consistent}} and {{eventually-consistent}}. That is, when multiple +commits are sent for the same epoch, applications need to ensure that only +Welcome messages corresponding to the commit that "succeeded" are processed by +new members. + +This is particularly important when groups are being reinitialized. When a group +is reinitialized, it is restarted with a different protocol version and/or +ciphersuite but identical membership. Whenever an authorized member sends and +commits a ReInit proposal, this immediately freezes the existing group and +triggers the creation of a new group with a new `group_id`. + +Ideally, the new group would be created by the same member that committed the +`ReInit` proposal (including sending Welcome messages for the new group to all +of the previous group's members). However this operation is not always atomic, +so it's possible for a member to go offline after committing a ReInit proposal +but before creating the new group. When this happens, it's necessary for another +member to continue the reinitialization by creating the new group and sending +out Welcome messages. + +This has the potential to create a race condition, where multiple members try to +continue the reinitialization at the same time, and members receive multiple +Welcome messages for each attempt at reinitializing the same group. Ensuring +that all members agree on which reinitialization attempt is "correct" is key to +prevent this from causing forks. + # Functional Requirements MLS is designed as a large-scale group messaging protocol and hence aims to @@ -1099,8 +1129,8 @@ order for two different deployments based on them to interoperate. - In cases where group operations are not encrypted, the DS has the ability to observe and maintain a copy of the public group state. In particular, this is useful for clients that do not have the ability to send the full public - state in a Welcome message when inviting auser or for client that need to - recover from a loss of their state. Such public state can contain privacy + state in a Welcome message when inviting a user, or for a client that needs to + recover from losing their state. Such public state can contain privacy sensitive information such as group members' credentials and related public keys, hence services need to be carefully evaluate the privacy impact of storing this data on the DS. From 6f9105609701235b07f7ee6c9d66c1fa5168d5dc Mon Sep 17 00:00:00 2001 From: Brendan McMillion Date: Mon, 10 Jun 2024 11:43:11 -0700 Subject: [PATCH 2/2] Update draft-ietf-mls-architecture.md Co-authored-by: Rohan Mahy --- draft-ietf-mls-architecture.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/draft-ietf-mls-architecture.md b/draft-ietf-mls-architecture.md index 11e3b80..0a172aa 100644 --- a/draft-ietf-mls-architecture.md +++ b/draft-ietf-mls-architecture.md @@ -815,7 +815,7 @@ Ideally, the new group would be created by the same member that committed the `ReInit` proposal (including sending Welcome messages for the new group to all of the previous group's members). However this operation is not always atomic, so it's possible for a member to go offline after committing a ReInit proposal -but before creating the new group. When this happens, it's necessary for another +but before creating the new group. If this happens, it's necessary for another member to continue the reinitialization by creating the new group and sending out Welcome messages.