Internet-Draft LOI September 2025
Kohbrok Expires 2 April 2026 [Page]
Workgroup:
Messaging Layer Security
Internet-Draft:
draft-kohbrok-mls-leaf-operation-intents-latest
Published:
Intended Status:
Informational
Expires:
Author:
K. Kohbrok
Phoenix R&D

Leaf Operation Intents

Abstract

The Messaging Layer Security (MLS) protocol defined in [RFC9420] is an asynchronous secure group messaging protocol, which allows group members to propose their removal from a group.

However, in some cases MLS clients can't reliably use regular Remove or SelfRemove proposals to leave a group because they don't have an up-to-date group state.

This document specifies a LeafOperationIntent, which does not need an up-to-date group state but which retains sufficient binding to the client's current state to avoid replay attacks.

About This Document

This note is to be removed before publishing as an RFC.

The latest revision of this draft can be found at https://kkohbrok.github.io/draft-kohbrok-mls-leaf-operation-intents/draft-kohbrok-mls-leaf-operation-intents.html. Status information for this document may be found at https://datatracker.ietf.org/doc/draft-kohbrok-mls-leaf-operation-intents/.

Discussion of this document takes place on the Messaging Layer Security Working Group mailing list (mailto:mls@ietf.org), which is archived at https://mailarchive.ietf.org/arch/browse/mls/. Subscribe at https://www.ietf.org/mailman/listinfo/mls/.

Source for this draft and an issue tracker can be found at https://github.com/kkohbrok/draft-kohbrok-mls-leaf-operation-intents.

Status of This Memo

This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.

Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet-Drafts is at https://datatracker.ietf.org/drafts/current/.

Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."

This Internet-Draft will expire on 2 April 2026.

Table of Contents

1. Introduction

To leave an MLS group, a member cannot create a commit, but rather has to propose its own removal. This can create difficulties, some of which have been solved by the introduction of the SelfRemove proposal, which may be included in external commits.

One drawback of Remove and SelfRemove proposals is that they (like other proposals) are bound to a specific group epoch. This means that authors of such proposals must have an up-to-date group state to send such a proposal and continue to keep track of that group state both to re-send the proposal if necessary.

This can be a problem if an application wants to cleanly leave a group and immediately delete the associated group state, e.g., to erase the associated metadata. The deletion of the group state makes it impossible for the client to re-send the proposal in case it's not covered by the next commit. Similarly, the client might be offline at the time and the group state might not be up-to-date.

The LeafOperationIntent specified in this document allows a client to bind an intent to leave a group to the leaf's current state. That intent can then be proposed by any party (e.g. an external sender) in any subsequent epoch, provided the leaf remains unchanged

As users often have more than one client that needs to be removed from the group as part of the user leaving, the intent allows expanding the leaf operation to associated leaves.

2. LeafOperationIntent

A LeafOperationIntent can be created by clients and distributed either to other group members or to one or more external senders.

HashReference LeafNodeRef;

MakeLeafNodeRef(value)
  = RefHash("MLS 1.0 LeafNode Reference", value)

enum {
  reserved(0),
  sender_removal_only(1),
  remove_associated_members(2),
  (255)
} RemovalMode

struct {
  opaque group_id<V>;
  uint32 sender_index;
  LeafNodeRef sender_leaf_ref;
  RemovalMode removal_mode;
} LeafOperationIntentTBS

struct {
  opaque group_id<V>;
  uint32 sender_index;
  LeafNodeRef sender_leaf_ref;
  RemovalMode removal_mode;
  /* SignWithLabel(., "LeafOperationIntentTBS", LeafOperationIntentTBS) */
  opaque signature<V>;
} LeafOperationIntent

struct {
  LeafOperationIntent intent;
} LeafOperationProposal

RefHash and SignWithLabel are as defined in [RFC9420].

The purpose of the removal_mode is to allow the sender to signal that other members associated with the sender should be removed as part of this operation. This can be useful if the sender is part of a group of associated devices, e.g., multiple devices belonging to the same user, to facilitate the leaving of the entire user as opposed to just the sending client.

2.1. Creating and proposing a LeafOperationIntent

A group member creates a LeafOperationIntent by populating the group_id, sender_index and sender_leaf_ref according to the current state of the group and the sender's leaf.

If the sender wants to signal the removal of any associated members, it can set the removal_mode accordingly.

Finally the sender creates the signature by calling SignWithLabel on the LeafOperationIntentTBS populated as described above with "LeafOperationIntentTBS" as label.

Recipients of a LeafOperationIntent can include it in a LeafOperationProposal.

2.2. Processing a LeafOperationProposal

Recipients of a LeafOperationProposal MUST perform the following steps on the intent contained in the proposal.

  • Verify that the group_id matches the group in which the proposal was sent

  • Verify that the sender_leaf_ref is the LeafRef of the leaf at the sender_index

  • Verify the signature over the intent using the signature public key in the leaf at the sender_index

  • If removal_mode is remove_associated_members, check with the authentication service (AS, see [RFC9750]) whether any other members of the group are associated with the sender

If any of the validation steps fail, the recipient MUST consider the proposal invalid.

After that, the proposal MUST be validated and processed as if it were a Remove proposal targeting the sender's leaf.

If removal_mode is remove_associated_members, the proposal MUST additionally be validated and processed as if it were a set of Remove proposals targeting the members identified as associated clients by the AS.

All Remove proposals MUST be treated as if they originated from the sender of the intent (not the sender of the LeafOperationProposal).

External commits may include one or more LeafOperationProposals. Any Removes validated as described above MUST thus be considered valid in this context.

Open questions:

  • Do we want to have an MLS wire format for LeafOperationIntent?

2.3. Additional AS role

When using LeafOperationIntents, the AS gains the additional role of having to identify other members in a group that are associated with the sender of a LeafOperationIntent.

The association could, for example, be that multiple clients belong to the same user. In most cases, the association will be determined by Credentials of the individual group members.

3. Security Considerations

In contrast to proposals, LeafOperationIntents are not bound to an epoch and thus remain valid as long as the creator's leaf doesn't change its state.

Each LeafOperationIntent can thus be proposed and committed to until the sender is either removed from the group or updates its own leaf.

This allows scenarios, where, for example, members get added to or removed from a group in the time between the creation and the proposal of the intent.

If a tighter bound to the epoch, i.e. the current group state is required, clients should use regular Remove or SelfRemove proposals instead.

Epoch independence incurs a certain risk of replay attacks. The bound of the intent to the hash of the sender's LeafNode limits that risk significantly. However, a replay is possible, for example, if the sender's leaf still contains the LeafNode from a KeyPackage. In that case, if the sender is later added again with the same KeyPackage, the intent can be replayed.

4. IANA Considerations

This document requests the addition of a new Proposal Type under the heading of "Messaging Layer Security".

The leaf_operation_intent MLS Proposal Type is used to allow members or external senders to convey the intent of a leaf owner to perform an operation on their leaf.

5. Normative References

[RFC9420]
Barnes, R., Beurdouche, B., Robert, R., Millican, J., Omara, E., and K. Cohn-Gordon, "The Messaging Layer Security (MLS) Protocol", RFC 9420, DOI 10.17487/RFC9420, , <https://www.rfc-editor.org/rfc/rfc9420>.
[RFC9750]
Beurdouche, B., Rescorla, E., Omara, E., Inguva, S., and A. Duric, "The Messaging Layer Security (MLS) Architecture", RFC 9750, DOI 10.17487/RFC9750, , <https://www.rfc-editor.org/rfc/rfc9750>.

Acknowledgments

TODO acknowledge.

Contributors

Raphael Robert
Phoenix R&D

Author's Address

Konrad Kohbrok
Phoenix R&D