Last Call Review of draft-ietf-lamps-cms-kemri-06
review-ietf-lamps-cms-kemri-06-secdir-lc-weis-2023-10-24-00
Request | Review of | draft-ietf-lamps-cms-kemri |
---|---|---|
Requested revision | No specific revision (document currently at 08) | |
Type | Last Call Review | |
Team | Security Area Directorate (secdir) | |
Deadline | 2023-10-25 | |
Requested | 2023-10-11 | |
Authors | Russ Housley , John Gray , Tomofumi Okubo | |
I-D last updated | 2023-10-24 | |
Completed reviews |
Opsdir Last Call review of -06
by Linda Dunbar
(diff)
Genart Last Call review of -06 by Gyan Mishra (diff) Secdir Last Call review of -06 by Brian Weis (diff) Artart Last Call review of -07 by Sean Turner (diff) |
|
Assignment | Reviewer | Brian Weis |
State | Completed | |
Request | Last Call review on draft-ietf-lamps-cms-kemri by Security Area Directorate Assigned | |
Posted at | https://mailarchive.ietf.org/arch/msg/secdir/Vkua4cJCZNMFyo_lSePzf9w7R3s | |
Reviewed revision | 06 (document currently at 08) | |
Result | Has nits | |
Completed | 2023-10-24 |
review-ietf-lamps-cms-kemri-06-secdir-lc-weis-2023-10-24-00
I have reviewed this document as part of the security directorate's ongoing effort to review all IETF documents being processed by the IESG. These comments were written primarily for the benefit of the security area directors. Document editors and WG chairs should treat these comments just like any other last call comments. The summary of the review is Has Nits. This document defines the usage of Key Encapsulation Mechanism (KEM) algorithms for CMS. In particular a content encryption key (CEK) used to protect CMS content is protected by a key encryption key (KEK), which is itself derived from a shared secret (ss). The shared secret is generated using KEM public key cryptography algorithms. Some clarification would improve the document. 1. There are three symmetric keys defined here, which are not always referred to by the same words. It would help the reader if they were used consistently. I think the easiest way to resolve this is to include the acronym after first use (e.g., "content-encryption-key (CEK)" and then use the acronym each time afterwords. Here are some cases where an inconsistent key name is used. -- "originator-generated content-encryption key" -> "CEK" -- "pairwise shared secret" in Section 2 is apparently "ss" in Section 1. 2. Section 1.3 essentially states that CMS version numbers are unreliable, and as long as the CMS can be evaluated the version number is irrelevant. I assume this is a generic CMS issue unrelated to this document and is current practice. If so, that might be worth mentioning. 3. Section 2 states "The originator randomly generates the content-encryption key, and then all recipients obtain that key." This is the first reference to the content-encryption key, and it isn't clear yet how it's distributed (e.g., is it out of band, within CMS, etc.). It would be nice to be more clear in that sentence, for example by appending it with something like "... as an encrypted object within the KEM CMS object." 4. Section 2 list item 2 for the originator and recipient both mention "data that is sent in the clear". Is this the "ukm" in the KEMRecipientInfo structure? If so, instead of "sent in the clear" text such as "included in the CMS structure". Otherwise, one wonders whether the cleartext is integrity protected and could be changed by a man-in-the-middle. 5. Section 3, "rid" definition. The text is long, and it would be helpful if it also include an object definition defined showing the two alternative (such as is done in Section 4). 6. Section 5 says "An acceptable KDF MUST accept an IKM, L, and info as inputs." The order of providing them to the KDF is critical for interoperability. Is there intended to be a defined order in this document, or is the KDF definition expected to define the order? 7. Security Considerations states many SHOULDs involving security levels being "at least the security level" of another part of KEM. It would have have been more conventional to specify MUSTs in order to achieve a consistent security level. I assume there is some rationale for specifying SHOULDs (e.g., operational considerations of algorithm deployment), which should be stated. 8. As quantum-secure KEM algorithms using the KeyGen()/Encapsulate()/Decapsulate() model are less well-known that typical public-key encryption algorithms it would be helpful to provide a reference to at least one algorithm.