Last Call Review of draft-ietf-lamps-x509-policy-graph-03
review-ietf-lamps-x509-policy-graph-03-artart-lc-thomson-2024-01-11-00
Request | Review of | draft-ietf-lamps-x509-policy-graph |
---|---|---|
Requested revision | No specific revision (document currently at 05) | |
Type | Last Call Review | |
Team | ART Area Review Team (artart) | |
Deadline | 2024-01-22 | |
Requested | 2024-01-08 | |
Authors | David Benjamin | |
I-D last updated | 2024-01-11 | |
Completed reviews |
Artart Last Call review of -03
by Martin Thomson
(diff)
|
|
Assignment | Reviewer | Martin Thomson |
State | Completed | |
Request | Last Call review on draft-ietf-lamps-x509-policy-graph by ART Area Review Team Assigned | |
Posted at | https://mailarchive.ietf.org/arch/msg/art/bskZp76k4VtHqThOqLYapIGxAxc | |
Reviewed revision | 03 (document currently at 05) | |
Result | Ready w/nits | |
Completed | 2024-01-11 |
review-ietf-lamps-x509-policy-graph-03-artart-lc-thomson-2024-01-11-00
This document describes an alternative *implementation* strategy for gathering policy information from a certification path. The intent is to avoid gross inefficiencies in the suggested approach in RFC 5280, which can be exploited for DoS attacks. Overall, the algorithm changes are very clearly explained, with helpful diagrams. I found the introductory material lacking though. This is a very hard document to process. And I have a fair bit of relevant context already. Let me start with a misapprehension I had when reading this... The intent is to produce the same outcome as the original algorithm. However, it was not initially clear to me that the output of this algorithm is identical. The policy mappings appear to be fine, but the way in which qualifier propagate does not appear to be entirely consistent. The main difference between the graph and tree representation is that the graph consolidates nodes. In a graph, upward paths from leafs to the root will traverse the same intermediate nodes, causing the set of qualifiers to be consistent. A tree structure appears to allow for paths through different nodes, which perform the same policy mappings, but might have different qualifiers. Now, I believe that this is an impossible outcome. The tree version will have the same qualifiers on nodes with the same mapping, because they come from the same place (the single certificate at that depth). The graph version avoids replicating these nodes (another minor source of inefficiency). However, because there is a lot of talk about different paths, it is easy to get confused and think that maybe nodes come from different certificates. That is, I think. Because it seems possible for a certificate to contain multiple mappings for the same OIDs, with different qualifiers for each mapping. I don't think that changes the outcome either, but it is a bit of a mind-bender, head-scratcher if you don't have a lot of time or context. This problem is, I think, something that could be helper with better introductory material. The amount of assumed knowledge is very high, particularly given the nature of RFC 5280, which is one of the most arcane and unwelcoming documents the IETF has ever produced. A *tiny* bit more context would help make this document far more comprehensible. (OK, a lot more, because what is there is extremely scant.) Things that I think would help: * A clearer explanation of what the goal of algorithm is. Section 1.1 says that this doesn't change anything, but even RFC 5280 doesn't set out its goals. * A recognition that this algorithm is applied to a single certification path, or chain of certificates, from a trust anchor to an end-entity certificate. * An explanation that in this context "policy" is an concept that is represented by an OID, with effect that is defined by understanding the OID. * A note about qualifiers and the intended effect: that they are specified by each CA certificate and that the final policy is affected by all qualifiers in the certification path. * A disclaimer that this doesn't help a verifier select between certification paths. (By the way, there is a bunch of fairly troubling text about picking and choosing paths, which caused my security senses to go on alert, but I assume that this is a pre-existing RFC 5280 thing.) Nits: The introduction says "This cost asymmetry", but it really isn't clear what the cost asymmetry it refers to is. I've opened pull requests for a few very minor things.