[secdir] secdir review of draft-cakulev-mikey-ibake-02

"Glen Zorn" <gwz@net-zen.net> Wed, 22 September 2010 09:27 UTC

Return-Path: <gwz@net-zen.net>
X-Original-To: secdir@core3.amsl.com
Delivered-To: secdir@core3.amsl.com
Received: from localhost (localhost [127.0.0.1]) by core3.amsl.com (Postfix) with ESMTP id 47B0B3A6AF6 for <secdir@core3.amsl.com>; Wed, 22 Sep 2010 02:27:41 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -102.104
X-Spam-Level:
X-Spam-Status: No, score=-102.104 tagged_above=-999 required=5 tests=[AWL=0.494, BAYES_00=-2.599, HTML_MESSAGE=0.001, USER_IN_WHITELIST=-100]
Received: from mail.ietf.org ([64.170.98.32]) by localhost (core3.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id ahoEY8lveyvF for <secdir@core3.amsl.com>; Wed, 22 Sep 2010 02:27:33 -0700 (PDT)
Received: from smtpout09.prod.mesa1.secureserver.net (smtpout09-01.prod.mesa1.secureserver.net [64.202.165.14]) by core3.amsl.com (Postfix) with SMTP id 509BE3A6AEB for <secdir@ietf.org>; Wed, 22 Sep 2010 02:27:33 -0700 (PDT)
Received: (qmail 5593 invoked from network); 22 Sep 2010 09:27:59 -0000
Received: from unknown (110.164.147.175) by smtpout09.prod.mesa1.secureserver.net (64.202.165.14) with ESMTP; 22 Sep 2010 09:27:50 -0000
From: Glen Zorn <gwz@net-zen.net>
To: iesg@ietf.org, secdir@ietf.org, violeta.cakulev@alcatel-lucent.com, ganesh.sundaram@alcatel-lucent.com, 'Tim Polk' <william.polk@nist.gov>
Date: Wed, 22 Sep 2010 16:27:11 +0700
Organization: Network Zen
Message-ID: <002801cb5a38$5db4f5c0$191ee140$@net>
MIME-Version: 1.0
Content-Type: multipart/alternative; boundary="----=_NextPart_000_0029_01CB5A73.0A13CDC0"
X-Mailer: Microsoft Office Outlook 12.0
Thread-Index: ActaOFVRLTmiVrU2Qw28WkPSr1be4A==
Content-Language: en-us
Subject: [secdir] secdir review of draft-cakulev-mikey-ibake-02
X-BeenThere: secdir@ietf.org
X-Mailman-Version: 2.1.9
Precedence: list
List-Id: Security Area Directorate <secdir.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/listinfo/secdir>, <mailto:secdir-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/secdir>
List-Post: <mailto:secdir@ietf.org>
List-Help: <mailto:secdir-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/secdir>, <mailto:secdir-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 22 Sep 2010 09:27:41 -0000

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.

 

Editorial Comments

 

General

.         Articles are missing in a large number of places (too many to
specify and correct one-by-one here).  For example, "The REQUEST_KEY_INIT
message includes Initiator's public identity" which should, presupposing
that "Initiator" is not a proper noun, read  "The REQUEST_KEY_INIT message
includes the Initiator's public identity".  Other examples are given below;
please correct.

 

Abstract

.         s/relies on trusted key management service/relies on a trusted key
management service/

 

Section 1

Paragraph 1

.         s/Multimedia Internet Keying (MIKEY) [RFC3830] specification/The
Multimedia Internet Keying (MIKEY) [RFC3830] specification/

.         The last sentence doesn't make a lot of sense to me; suggest
changing "Following MIKEY specification, multiple  extensions of MIKEY have
been specified such as [RFC4650] and  [RFC4738]." to "Multiple extensions of
MIKEY have been defined, such as HMAC-Authenticated Diffie-Hellman [RFC4650]
and MIKEY-RSA-R [RFC4738]."

Paragraph 2

.         s/key management services will have to be online/such key
management services would have to be online/

.         The statement that "In some applications, this architecture
creates a huge burden on operators to install, and manage these boxes."
seems to be unnecessarily evangelistic; suggest deleting it.

.         I don't know what "operational discomfort on the part of
end-users" means.

Paragraph 3

.         Suggest changing the first sentence to read "This document
describes a solution in which the KMS are provided by low availability."

.         s/identity based/identity-based/

.         s/in the date field, is/in the date field is/

.         Suggest changing "for a whole month (more generally subscription
cycle) at the beginning of a subscription cycle." to "for a whole
subscription cycle at the beginning of the cycle."

 

Section 2

.         It's not clear why "Definitions and Notation" and "Abbreviations"
are sub-sections of "Requirements notation".   Suggest that Section 2 be
re-titled as "Terminology", with "Requirements Language", "Definitions and
Notation" and "Abbreviations" as sub-sections.

.         s/IBE framework is defined in/The IBE framework is defined in/

.         I'm continually amazed by the apparent inability of people who
presumably work with objects and pointers thereto to distinguish between a
reference and the document to which it refers.  [RFC5091] is a pointer; it
does not define anything, let alone the IBE framework.

.         s/Identity Based/Identity-based/g

.         Add definitions of TGK and TEK to the list of abbreviations.

 

Section 3.2

.         It's not clear that "call" and "session" are the same thing.
Suggest changing "redirect the call to a different destination" to "redirect
the session to a different destination" for the sake of clarity and
consistency.

.         The acronym "IMS" is used w/o being previously defined; suggest
adding an entry for IMS to the "Abbreviations" section.

 

Section 4.1

.         In the second paragraph, "Key Management Services" is plural but
seems to generally referred to in the singular.  As an example, how should
one read "KMSs"? "Key Management Serviceses"?  Suggest s/Key Management
Services/Key Management Service/G

.         Correct grammar: Change "The Initiator and the Responder do not
share any credentials, however the Initiator knows Responder's public
identity.  Below, description of how private keys are obtained using MIKEY
messages is provided.  Alternative way" to "The Initiator and Responder do
not share any credentials; however, the Initiator knows the Responder's
public identity.  Below, a description of how private keys are obtained
using MIKEY messages is provided.  An alternative way" 

 

Section 4.2.1

.         In the first paragraph, s/the user have pre-shared credentials/the
user has pre-shared credentials

 

Section 4.2.1.1.1

.         s/[RFC3830] Section 4.1.4/Section 4.1.4 of RFC 3830/

 

Section 4.2.1.1.2

.         The first sentence makes no sense.

.         In the second paragraph, s/PKE payload/The PKE payload/

 

Section 4.2.1.2

.         The second sentence of the first paragraph says "In case of a
REQUEST_KEY_INIT_PKE message, the KMS MUST ensure that the IDcert is equal
to the identity specified in the certificate."  My guess is that IDcert
should actually be IDRi here, since IDcert occurs nowhere else in the draft.

 

Section 4.2.2

.         s/key mode ,/key mode,/

 

 

Technical Comments

 

General

.         The fourth paragraph of Section 4.1 (and elsewhere) says 'If the
Initiator is authorized to make the request' but the criteria for this
authorization decision don't seem to be specified anywhere in the document.
Since this decision is vital to the successful operation of the protocol, I
think it would be nice if the authors gave readers a clue as to how to go
about making it.  

 

Section 4.1

.         The first sentence of paragraph 4 contains rather confusing
notation.  It says "The Initiator next chooses a random x and computes xP
(i.e. adds P to itself x times), where P is a point on elliptic curve E
known to all users."  The notation "xP" is a conventional one for expressing
the multiplication of P by x, which is not the same as the addition of P to
itself x times.  If the latter interpretation is actually, I think that a
better notation should be chosen.

 

Section 4.2.1.1

.         The last sentence says "The KEMAC payload SHOULD be used only when
the user needs to use specific keys.  Otherwise, this payload SHALL not be
used."  This appears to be self-contradictory, since "SHOULD" allows the
usage under certain circumstances while "SHALL NOT" (note typo) absolutely
forbids it.

 

Section 4.2.1.2

.         The last paragraph says "If the KMS cannot correctly parse the
received message, or the user is not authorized to receive the requested
Private Keys, the KMS SHOULD send an appropriate Error message."  I'm
assuming that the term "Error message" here is referring to the Error
payload defined in section 6.12 of RFC 3830, but I don't see any Error no
values therein that seem appropriate for either of the listed conditions.