[IPFIX] review of draft-trammell-ipfix-ie-doctors-00

Paul Aitken <paitken@cisco.com> Tue, 09 November 2010 22:15 UTC

Return-Path: <paitken@cisco.com>
X-Original-To: ipfix@core3.amsl.com
Delivered-To: ipfix@core3.amsl.com
Received: from localhost (localhost [127.0.0.1]) by core3.amsl.com (Postfix) with ESMTP id A5BAC3A692E for <ipfix@core3.amsl.com>; Tue, 9 Nov 2010 14:15:25 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -9.248
X-Spam-Level:
X-Spam-Status: No, score=-9.248 tagged_above=-999 required=5 tests=[AWL=-1.351, BAYES_00=-2.599, GB_I_LETTER=-2, HTML_MESSAGE=0.001, J_CHICKENPOX_39=0.6, J_CHICKENPOX_43=0.6, J_CHICKENPOX_62=0.6, J_CHICKENPOX_83=0.6, MANGLED_PENIS=2.3, RCVD_IN_DNSWL_HI=-8]
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 b+DPd16FAqGi for <ipfix@core3.amsl.com>; Tue, 9 Nov 2010 14:15:17 -0800 (PST)
Received: from rtp-iport-2.cisco.com (rtp-iport-2.cisco.com [64.102.122.149]) by core3.amsl.com (Postfix) with ESMTP id 5B5B93A696C for <ipfix@ietf.org>; Tue, 9 Nov 2010 14:15:15 -0800 (PST)
Authentication-Results: rtp-iport-2.cisco.com; dkim=neutral (message not signed) header.i=none
X-IronPort-AV: E=Sophos; i="4.59,175,1288569600"; d="scan'208,217"; a="180375925"
Received: from rtp-core-1.cisco.com ([64.102.124.12]) by rtp-iport-2.cisco.com with ESMTP; 09 Nov 2010 22:15:40 +0000
Received: from cisco.com (mrwint.cisco.com [64.103.71.48]) by rtp-core-1.cisco.com (8.13.8/8.14.3) with ESMTP id oA9MFcEZ019469; Tue, 9 Nov 2010 22:15:39 GMT
Received: from [10.61.95.154] (ams3-vpn-dhcp8091.cisco.com [10.61.95.154]) by cisco.com (8.11.7p3+Sun/8.8.8) with ESMTP id oA9MFX827151; Tue, 9 Nov 2010 22:15:34 GMT
Message-ID: <4CD9C807.7060205@cisco.com>
Date: Tue, 09 Nov 2010 22:15:35 +0000
From: Paul Aitken <paitken@cisco.com>
User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.1.15) Gecko/20101027 Thunderbird/3.0.10
MIME-Version: 1.0
To: "Benoit Claise (bclaise)" <bclaise@cisco.com>, Brian Trammell <trammell@tik.ee.ethz.ch>, IETF IPFIX Working Group <ipfix@ietf.org>
Content-Type: multipart/alternative; boundary="------------060403050408050604060603"
Subject: [IPFIX] review of draft-trammell-ipfix-ie-doctors-00
X-BeenThere: ipfix@ietf.org
X-Mailman-Version: 2.1.9
Precedence: list
List-Id: IPFIX WG discussion list <ipfix.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/listinfo/ipfix>, <mailto:ipfix-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/ipfix>
List-Post: <mailto:ipfix@ietf.org>
List-Help: <mailto:ipfix-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/ipfix>, <mailto:ipfix-request@ietf.org?subject=subscribe>
X-List-Received-Date: Tue, 09 Nov 2010 22:15:25 -0000

Brian, Benoit,

Please find review comments inline.

Thanks,
P.

> IPFIX Working Group                                          B. Trammell
> Internet-Draft                                                ETH Zurich
> Intended status: BCP                                           B. Claise
> Expires: April 4, 2011                                     Cisco Systems
>                                                           October 1, 2010
>
>
>     Guidelines for Authors and Reviewers of IPFIX Information Elements
>                   draft-trammell-ipfix-ie-doctors-00.txt
>
> Abstract
>
>     This document provides guidelines for the definition of IPFIX
>     Information Elements for addition to the IANA IPFIX Information
>     Element registry, in order to extend the applicability of the IPFIX
>     protocol to new operations and management areas.
>
> 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 athttp://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 April 4, 2011.
>
> Copyright Notice
>
>     Copyright (c) 2010 IETF Trust and the persons identified as the
>     document authors.  All rights reserved.
>
>     This document is subject to BCP 78 and the IETF Trust's Legal
>     Provisions Relating to IETF Documents
>     (http://trustee.ietf.org/license-info) in effect on the date of
>     publication of this document.  Please review these documents
>     carefully, as they describe your rights and restrictions with respect
>     to this document.  Code Components extracted from this document must
>     include Simplified BSD License text as described in Section 4.e of
>     the Trust Legal Provisions and are provided without warranty as
>     described in the Simplified BSD License.
>
>
>
> Trammell&  Claise         Expires April 4, 2011                 [Page 1]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
> Table of Contents
>
>     1.  Introduction . . . . . . . . . . . . . . . . . . . . . . . . .  3
>       1.1.  Intended Audience and Usage  . . . . . . . . . . . . . . .  3
>       1.2.  Overview of relevant IPFIX documents . . . . . . . . . . .  4
>     2.  Terminology  . . . . . . . . . . . . . . . . . . . . . . . . .  4
>     3.  How to apply IPFIX . . . . . . . . . . . . . . . . . . . . . .  5
>     4.  Defining new Information Elements  . . . . . . . . . . . . . .  6
>       4.1.  Information Element naming . . . . . . . . . . . . . . . .  6
>       4.2.  Information Element data types . . . . . . . . . . . . . .  7
>       4.3.  Ancillary Information Element properties . . . . . . . . .  7
>       4.4.  Internal structure in Information Elements . . . . . . . .  8
>       4.5.  Enumerated Values and Subregistries  . . . . . . . . . . .  9
>       4.6.  Reversibility as per RFC 5103  . . . . . . . . . . . . . .  9
>     5.  The Information Element Lifecycle: Revision and Deprecation  . 10
>     6.  When not to define new Information Elements  . . . . . . . . . 12
>       6.1.  Maximizing reuse of existing Information Elements  . . . . 12
>       6.2.  Applying enterprise-specific Information Elements  . . . . 13
>     7.  Applying IPFIX to non-Flow Applications  . . . . . . . . . . . 14
>     8.  Defining Recommended Templates . . . . . . . . . . . . . . . . 14
>     9.  A Textual Format for Specifying Information Elements and
>         Templates  . . . . . . . . . . . . . . . . . . . . . . . . . . 15
>       9.1.  Information Element Specifiers . . . . . . . . . . . . . . 16
>       9.2.  Specifying Templates . . . . . . . . . . . . . . . . . . . 18
>       9.3.  Specifying IPFIX Structured Data . . . . . . . . . . . . . 18
>     10. Security Considerations  . . . . . . . . . . . . . . . . . . . 19
>     11. IANA Considerations  . . . . . . . . . . . . . . . . . . . . . 20
>     12. Acknowledgements . . . . . . . . . . . . . . . . . . . . . . . 20
>     13. Open Issues  . . . . . . . . . . . . . . . . . . . . . . . . . 20
>     14. References . . . . . . . . . . . . . . . . . . . . . . . . . . 20
>       14.1. Normative References . . . . . . . . . . . . . . . . . . . 20
>       14.2. Informative References . . . . . . . . . . . . . . . . . . 21
>     Authors' Addresses . . . . . . . . . . . . . . . . . . . . . . . . 22
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
> Trammell&  Claise         Expires April 4, 2011                 [Page 2]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
> 1.  Introduction
>
>     This document provides guidelines for the extension of the
>     applicability of the IP Flow Information Export (IPFIX) protocol to
>     network operations and management purposes outside the initial scope
>     defined in "IPFIX Applicability Statement" [RFC5472].  These new
>     applications areis  largely defined through the definition of new
>    

Remove "is".

>     Information Elements beyond those defined in the IPFIX Information
>     Model [RFC5102] or already added to the IANA IPFIX Information
>     Element Registry [iana-ipfix-assignments].  New applications may be
>     further specified through additional RFCs defining and describing
>     their  usage.
>    

Ambiguous "their": seems like new applications, rather than Information 
Elements.

>     We intend this document to enable the expansion of the applicability
>     of IPFIX to new areas by experts in the working group or area
>     directorate concerned with the technical details of the protocol or
>     application to be measured or managed using IPFIX.  This expansion
>     would occur with the consultation of IPFIX experts informally called
>     'IE-Doctors'.  It provides guidelines both for those defining new
>     Information Elements as well as the IE-Doctors reviewingthem.
>    

Ambiguous "them": seems like "those defining new Information Elements".

> 1.1.  Intended Audience and Usage
>
>     This document is meant for two separate audiences.  For IETF
>     contributors extending the applicability of IPFIX, it provides a set
>     of guidelines and best practices to be used in deciding which
>     Information Elements are necessary for a given application, defining
>     these Information Elements, and deciding whether an RFC should be
>     published to further describe the application.  For the IPFIX experts
>     appointed as IE-Doctors, and for IANA personnel changing the
>     Information Element registry, it defines a set of acceptance criteria
>     against which these proposed Information Elements should be
>     evaluated.
>
>     This document is not intended to guide the extension of the IPFIX
>     protocol itself, e.g. through new export mechanisms, data types, or
>     the like; these activities should be pursued through the publication
>     of standards-track RFCs by the IPFIX Working Group.
>
>     This document specifies additional practices beyond those appearing
>     in the IANA Considerations sections of existing IPFIX documents,
>     especially the Information Model [RFC5102].  The practices outlined
>     in this document are intended to guide experts when making changes to
>     the IANA registry under Expert Review as defined in [RFC5226].
>
>
>
>
>
>
>
> Trammell&  Claise         Expires April 4, 2011                 [Page 3]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
> 1.2.  Overview of relevant IPFIX documents
>
>     [RFC5101] defines the IPFIX Protocol, the IPFIX-specific terminology
>     used by this document,and the data type encodings  for each of the
>     data types supported by IPFIX.
>    

Not entirely true; it defines the initial set of data types as an 
extensible registry. There are already drafts proposing new IPFIX data 
types beyond RFC5101. Therefore the IANA IPFIX registry is the master, 
rather than any of the IPFIX RFCs.

>     [RFC5102] defines the initial IPFIX Information Model, as well as
>     procedures for extending the Information Model.  It states that new
>     Information Elements may be added to the Information Model on Expert
>     Review basis, and delegates the appointment of experts to an IESG
>     Area Director.  This document is intended to further codify the best
>     practices to be followed by these experts, in order to improve the
>     efficiency of this process.
>
>     [RFC5103] defines a method for exporting bidirectional flow
>     information using IPFIX; this document should be followed when
>     extending IPFIX to represent information about bidirectional network
>     interactions in general.  Additionally, new Information Elements
>     should be annotated  for their reversibility or lack thereof as per
>     this document.
>    

Where is this annotation to be recorded? AFAIK there's currently nowhere 
to do this in the IANA registry, yet there's no requirement to create 
any other document before creating new IEs.

>     [RFC5610] defines a method for exporting information about
>     Information Elements inline within IPFIX.  In doing so, it explicitly
>     defines a set of implicit restrictions on the use of data types and
>     semantics; these restrictions MUST be observed in the definition of
>     new Information Elements, as inSection 4.3.
>    

Ambiguous "Section 4.3". 5610 doesn't have a section 4.3. Say "Section 
4.3 below.". Throughout the document, please makes it clear whether 
you're referring to sections in this doc or in other RFCs.

> 2.  Terminology
>
>     Capitalized terms used in this document that are defined in the
>     Terminology section of [RFC5101] are to be interpreted as defined
>     there.
>
>     An "application", as used in this document, refers to a candidate
>     protocol, task, or domain to which IPFIX export, collection, and/or
>     storage is applied, beyond those within the IPFIX Applicability
>     statement [RFC5472].  By this definition, PSAMP [RFC5476] was the
>     first new IPFIX application after the publication of the IPFIX
>     protocol [RFC5101].
>
>     The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
>     "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
>     document are to be interpreted as described in [RFC2119].
>
>
>
>
>
>
>
> Trammell&  Claise         Expires April 4, 2011                 [Page 4]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
> 3.  How to apply IPFIX
>
>     Though originally specified for the export of IP flow information,
>     the message format, template mechanism, and data model specified by
>     IPFIX lead to it being applicable to a wide variety of network
>     management situations.  In addition to flow information export, for
>     which it was designed, and packet information export as specified by
>     PSAMP [RFC5476], any application with the following characteristics
>     is a good candidate for an IPFIX application:
>
>     o  The application's data flow is fundamentally unidirectional.
>        IPFIX is a "push" protocol, supporting only the export of
>        information from a sender (an Exporting Process) to a receiver (a
>        Collecting Process).  Request-response interactions are not
>        supported by IPFIX.
>
>     o  The application handles discrete event information, or information
>        to be periodically reported.  IPFIX is particularly well suited to
>        representing events, which can be scoped in time.
>
>     oThe application handles information about network entities.
>        IPFIX's information model is network-oriented, so network
>        management applications have many opportunities for information
>        model reuse.
>    

No; this is contrary to the Abstract. I can export anything over IPFIX 
that I can define an IE for. With suitable IEs, it would even be 
possible to tunnel other protocols over IPFIX!

>     o  The application requires a small number of arrangements of data
>        structures relative to the number of records it handles.  The
>        template-driven self-description mechanism used by IPFIX excels at
>        handling large volumes of identically structured data, compared to
>        representations which define structure inline with data (such as
>        XML).
>
>     Most applications meeting these criteria can be supported over IPFIX.
>     Onceit's  been determined that IPFIX is a good fit, the next step is
>    

"it's" = "it is", not "it has".

>     determining which Information Elements are necessary to represent the
>     information required by the application.  Especially for network-
>     centric applications, the IPFIX Information Element registry may
>     already contain all the necessary Information Elements (see
>     Section 6.1 for guidelines on maximizing Information Element reuse).
>    
>     In this case, no additional work within the IETF is necessary: simply
>     define Templates and start exporting.
>
>     It is expected, however, that most applications will be able to reuse
>     some existing Information Elements, but must define some additional
>     Information Elements to support all their requirements; in this case,
>     see Section 4 for best practices to be followed in defining
>     Information Elements.
>    
>
>
> Trammell&  Claise         Expires April 4, 2011                 [Page 5]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     Optionally, a Working Group or individual contributor may choose to
>    

You should detail "Optionally". New IEs don't need an RFC, but some 
applications may require changes to the IPFIX protocol which do require 
an RFC.

>     publish an RFC detailing the new IPFIX application.  Such an RFC
>     should contain discussion of the new application, the Information
>     Element definitions as in Section 4, as well assuggested Templates

Good grief, I can't believe I just read that!

Perhaps the fields may be specified, but that's about as far as I'd go. 
Suggesting templates is something for the implementer to do in his 
software design, and not something to be specified in, or slavishly copy 
from, RFCs. More on this below.

>     and examples of the use of those Templates within the new application
>     as in Section 8.  Section 9 defines a compact textual Information
>     Element notation to be used in describing these suggested Templates
>     and/or the use of IPFIX Structured Data
>     [I-D.ietf-ipfix-structured-data] within the new application.
>    

This last line seems jammed in without reference to the foregoing text. 
A new paragraph might be better.

> 4.  Defining new Information Elements
>
>     In many cases, a new application will require nothing more than a new
>     Information Element or set of Information Elements to be exportable
>     using IPFIX.  An Information Element meeting the following criteria,
>     as evaluated by appointed IPFIX experts, is eligible for inclusion in
>     theInformation Element registry:
>    

Xref with [IANA] URL.

>     o  The Information Element MUST be sufficiently unique within the
>        registry.  A proposed Information Elements  which is a substantial
>    

Typo.

>        duplicate of an exiting Information Element is to be represented
>        using the existing Element.
>    

Yes and no:

If a new element simply adds a new value to an existing element, then it 
can be considered as extending the value registry for that element, 
which is considerably better than creating a new element for each new 
value. However, how are implementers to track when new values are added? 
An exporter and collector may interoperate just fine until the exporter 
is updated to a newer version of the IPFIX info model, where a certain 
IE now includes an additional value which the collector doesn't 
understand. Since both have previously implemented this field and 
interoperated successfully, how are we to know that this potential 
failure now exists - other than exhaustively testing every field / value 
combination?

Again, if a new element extends the functionality of an existing element 
in a small way - while substantially duplicating all the existing 
functionality of the existing element - then again the new element 
introduces a lack of interoperability.

Potentially these issues may be solved with clear version tracking.

>     o  The Information Element SHOULD contain minimal internal structure;
>        complex information should be represented with multiple simple
>        Information Elements to be exported in parallel, as in
>        Section 4.4.
>    

Or be represented with structured data, if the elements form a structure 
or other composite unit of data.

>     o  The Information Element SHOULD be generally applicable to the
>        application at hand,

Meaning, don't request irrelevant elements? Why would anyone do that?

>   which SHOULD be of general interest to the
>        community.  Information Elements representing information about
>        proprietary or nonstandard applications SHOULD be represented
>        using enterprise-specific Information Elements as detailed in
>        section 6.2 of [RFC5101].
>
>     The definition of new Information Elements requires a descriptive
>     name, a specification of the data type as one from the IPFIX Data
>     Type Registry, and a human-readable description written in English.
>    

Also semantics, units, range (which are all eventually discussed below), 
and reference and requester info.

The reference is especially important to allow others to clarify any 
ambiguity with the new IE.

Ideally the requester should be a generic or team email address (rather 
than a single personal address) where relevant experts can still be 
reached even if the original requester isn't available or has moved on.

>     This section provides guidelines on each of these components of an
>     Information Element definition, referring to existing documentation
>     such as [RFC5102] as appropriate.
>
> 4.1.  Information Element naming
>
>     Information Element Names should be defined in accordance with
>     section 2.3 of [RFC5102]; the most important naming conventions are
>     repeated here for convenience.
>
>
>
> Trammell&  Claise         Expires April 4, 2011                 [Page 6]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     o  Names of Information Elements should be descriptive.
>
>     o  Names of Information Elements MUST be unique within the IPFIX
>        information model.
>
>     o  Names of Information Elements start with non-capitalized letters.
>
>     o  Composed names use capital letters for the first letter of each
>        component (except for the first one).  All other letters are non-
>        capitalized, even for acronyms.  Exceptions are made for acronyms
>        containing non-capitalized letter, such as 'IPv4' and 'IPv6'.
>        Examples are sourceMacAddress and destinationIPv4Address.
>
>     In addition, new Information Elements pertaining to a specific
>     protocol SHOULD name the protocol in the first word in order to ease
>     searching by name (e.g. "sipMethod" for a SIP method, as would be
>     used in a logging format for SIP based on IPFIX).  Similarly, new
>     Information Elements pertaining to a specific application SHOULD name
>     the application in the first word.
>
> 4.2.  Information Element data types
>
>     IPFIX provides a set of data types covering most primitives used in
>     network measurement and management applications.  The most
>     appropriate data type should be chosen for the Information Element
>     type.
>
>     Because IPFIX provides reduced-length encoding for Information
>     Elements, unless an integral Information Element is derived from a
>     fixed-width field in a measured protocol (e.g., tcpSequenceNumber,
>     which is an unsigned32), it should be defined with the maximum
>     possible  width, generally signed64 or unsigned64.  Applications can
>    

Then all new elements would be defined as 64-bits. Perhaps "maximum 
foreseeable" or "maximum likely" would be better?

>     then choose to use reduced-size encoding as defined in Section 6.2 of
>     [RFC5101] in cases where fewer than 2^64 values are necessary.
>    

So why don't we just do away with the size specification and specify 
only the type (signed, unsigned, ...)? Collectors can presume to 
allocate 64 bit fields, while the actual size being exported is encoded 
in the IPFIX template.

>     Information Elements representing time values should be exported with
>     appropriate precision.  For example, a Information Element for a time
>     measured at second-level precision should be defined as having a
>     dateTimeSeconds data type, instead of dateTimeMilliseconds.
>
> 4.3.  Ancillary Information Element properties
>
>     Information Elements with numeric types and special semantics SHOULD
>     define these semantics with one of the values in the Information
>     Element Semantics registry, as described in Section 3.2 of [RFC5102],
>     subject to the restrictions given in Section 3.10 of [RFC5610];
>     essentially, the semantics and the type must be consistent.
>
>
>
>
> Trammell&  Claise         Expires April 4, 2011                 [Page 7]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     When defining Information Elements representing a dimensioned
>     quantity or entity count, the units of that quantity SHOULD be
>     defined in the units field.This field takes its values from the
>     IANA Information Element Units registry.  If an Information Element
>     expresses a quantity in units not yet in this registry, then the unit
>     must be added to the Units registry at the same time the Information
>     Element is added to the Information Element registry.
>    

Similar text for both data types and semantics, please.

>     Additionally, when the range of values an Information Element can
>     take is smaller than the range implied by its data type, the range
>     SHOULD be definedwithin the Information Element registry.
>    

More exactly, as part of the IE definition.

> 4.4.  Internal structure in Information Elements
>
>     Unless defining an Information Element which is a direct copy of a
>     bitfield or other structured entity (e.g., the tcpControlBits
>     Information Element for the Flags byte from the TCP header)in a
>     measured protocol, the definition of Information Elements with
>    

I think it would read better with this text before the parenthesised 
example.
ie, give the example *after* the explanation.

>     internal structure with the structure defined in the Description
>     field is discouraged.  In this case, the field SHOULD be decomposed
>     into multiple primitive Information Elements to be used in parallel.
>    

There's a danger here, when there are multiple instances of the field. 
So instead of exporting multiple instances of a single structured field, 
"X:Y" like so:

      { X:Y, X:Y, X:Y }

we prefer to export multiple instances of the broken down fields:

     { X, Y, X, Y, X, Y }

- which may make sense, if the collector knows to relate the first X and 
Y together, the second X with the second Y etc...

However, the following is also quite legitimate:

     { X, X, X, Y, Y, Y }

Again it follows the same rule: first X relates to first Y etc. However, 
now it's a lot less clear that X and Y are related. Yet it's not any 
less valid.

>     For more complicated semantics, where the structuremay not haveuse
>     the IPFIX Structured Data [I-D.ietf-ipfix-structured-data] extension
>     instead.
>    

Missing text? Where the structure may not have... what?

>     As an example of information element decomposition, consider an
>     application-level identifier called an "endpoint", which represents a
>     {host, port, protocol} tuple.  Instead of allocating an opaque,
>     structured "source endpoint" Information Element, the source endpoint
>     should be represented by three separate Information Elements: "source
>     address", "source port", "transport protocol".  Indeed, in this
>     example, the required information elements already exist in the
>     Information Element registry: sourceIPv4Address or sourceIPv6Address,
>     sourceTransportPort, protocolIdentifier.  Indeed, as well as being
>     good practice, this normalization down to non-structured Information
>     Elements also increases opportunities for reuse as in Section 6.1.
>    

This example is perfect for structured data.

>     The decomposition of data with internal structure SHOULD avoid the
>     definition of Information Elements with a meaning too specific to be
>     generally useful, or that would result in either the export of
>     meaningless data or a multitude of templates to handle different
>     multiplicities.  A specific example of this within the IANA registry
>     is the following list of assigned IPFIX Information Elements:
>     mplsTopLabelStackSection, mplsLabelStackSection2,
>     mplsLabelStackSection3, mplsLabelStackSection4,
>     mplsLabelStackSection5, mplsLabelStackSection6
>     mplsLabelStackSection7, mplsLabelStackSection8,
>     mplsLabelStackSection9, and mplsLabelStackSection10.  The only
>
>
>
> Trammell&  Claise         Expires April 4, 2011                 [Page 8]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     distinction between those almost-identical Information Elements is
>     the position within the MPLS stack.  This Information Element design
>     pattern met an early requirement of the definition of IPFIX which was
>     not carried forward into the final specification -- namely, that no
>     semantic dependency was allowed between Information Elements in the
>     same Record -- and as such SHOULD NOT be followed in the definition
>     of new Information Elements.  In this case, since the size of the
>     MPLS stack will vary from flow to flow, it should be exported using
>     IPFIX Structured Data [I-D.ietf-ipfix-structured-data] where
>     supported, as a basicList of MPLS label entries.
>
>     Note that a Template may contain multiple instances of the same
>     Information Element; in this case,the  each of the Information
>    

Typo.

>     Elements in the Template are semantically indistinguishable, and
>     appear in their "natural" order, where natural order is defined
>     according to application; PSAMP uses this for exporting selectors.
>     Multiple IEs used in this way are preferable to IEs with internal
>     structure, but only when there is some natural order, and no semantic
>     interdependence among the elements.
>
> 4.5.  Enumerated Values and Subregistries
>
>     When defining an Information Element that takes an enumerated value
>     from a set of values which may change in the future, this enumeration
>     MUST be defined by an IANA registry or subregistry.  For situations
>     where an existing registry defines the enumeration (e.g., the IANA
>     Protocol Numbers registry for the protocolIdentifier Information
>     Element), that registry MUST be used.  Otherwise, a new IPFIX
>     subregistry must be defined for the enumerated value, to be modified
>     subject to Expert Review [RFC5226].
>    

There's some ongoing discussion with Nevil as to whether sub-registries 
should be used, or whether the values can be recorded directly in the 
element description.

Again, the version control issue...

> 4.6.  Reversibility as per RFC 5103
>
>     [TODO: fix this para][RFC5103] defines a method for exporting
>     bidirectional flows using a special Private Enterprise Number to
>     define reverse-direction variants of IANA Information Elements, and a
>     set of criteria for determining whether an Information Element may be
>     reversed using this method.  Section 6.1 of [RFC5103] states that CPs
>     should use the set of criteria therein to determine reversibility.
>     Since almost all Information Elements are reversible, these criteria
>     are expressed as to determine the exceptions, i.e. which Information
>     Elements are NOT reversible.
>
>     To ease the determination of reversibility, future Information
>     Elements which are NOT reversible SHOULD note this fact in the
>     description at the time of definition.
>    

Can you include some examples of non-reversible elements?

>
>
>
> Trammell&  Claise         Expires April 4, 2011                 [Page 9]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
> 5.  The Information Element Lifecycle: Revision and Deprecation
>
>     The Information Element status field in the Information Element
>     Registry is defined in [RFC5102] to allow Information Elements to be
>     'deprecated' or 'obsolete'.  No Information Elements are as of this
>     writing deprecated,and but provides no further explanation of these
>     statuses, [RFC5102] does not define any policy for using them.
>    

This doesn't make sense.

>     Additionally, no policy is defined for revising Information Element
>     registry entries or addressing errors therein.  To be certain,
>     changes and deprecations within the Information Element registry are
>     not encouraged, and should be avoided to the extent possible.
>    

Clarify whether addition of new values is a change.

>     However, in recognition that change is inevitable, this section is
>     intended to remedy this situation.
>
>     The primary requirement in the definition of a policy for managing
>     changes to existing Information Elements is avoidance of
>     interoperability problems; IPFIX experts appointed to review changes
>     to the Information Element Registry MUST work to maintain
>     interoperability above all else.  Changes to Information Elements
>     already in use may only be done in an interoperable way; necessary
>     changes which cannot be done in a way to allow interoperability with
>     unchanged implementations MUST result in deprecation.
>
>     A change to an Information Element is held to be interoperable only
>     when:
>
>     o  it involves the correction of an error which is obviously only
>        editorial; or
>
>     o  it corrects an ambiguity in the Information Element's definition,
>        which itself leads to non-interoperability (e.g., a prior change
>        to ipv6ExtensionHeaders); or
>    

Cite the errata for this:

http://www.rfc-editor.org/errata_search.php?eid=1738

>     o  it expands the Information Element's data type without changing
>        how it is represented (e.g., changing unsigned32 to unsigned64, as
>        with a prior change to selectorId); or
>    

http://www.rfc-editor.org/errata_search.php?eid=2052

>     o  it defines a previously undefined or reserved enumerated value, or
>        one or more previously reserved bits in an Information Element
>        with flag semantics; or
>
>     o  it expands the set of permissible values in the Information
>        Element's range; or
>    

These two changes may NOT be interoperable.

eg, an exporter reporting an additional (new) value to a collector which 
hasn't been updated to understand that new value (though the collector 
was 100% IPFIX compliant at the time of implementation).

Somewhere in here you should discuss version control of the IANA 
registry, so every change is clearly called out. Find out how other 
protocols deal with change.

>     o  it harmonizes with an external reference which was itself
>        corrected.
>    

This is a potentially dangerous change. The correct route may be to 
deprecate the wrongly defined IE and create a new IE with the correct 
definition.

>     A non-interoperable Information Element change may also be made if it
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 10]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     can be reasonably assumedin the eyes of the appointed experts  that
>     no unchanged implementation of the Information Element exists; this
>    

A subjective opinion is NOT sufficient. They should query the IPFIX 
community as widely as possible.

>     can be held to happen if a non-interoperable change to an Information
>     Element defined shortly before is proposed to the IPFIX mailing list
>     by the original proposer of the Information Element, and no objection
>     is raised within a reasonable amount of time, to be defined by the
>     expert reviewers.
>    

Is this by way of an example, or is it by way of limitation? If the 
former, state "for example". If the latter, state "this can only be held 
to happen".

>     If a change ispermissible, it is sent to IANA, which passes it to
>    

Who determines whether a change is permissible? This reads as if the 
change submitter self-determines? I'd have expected change requests to 
be sent to IANA which forwards them to the expert(s) who determine 
permissibility.

>     the appointed experts for review; if there is no objection to the
>     change from any appointed expert, IANA makes the change in the
>     Information Element Registry.Changes that are not permissible MUST
>     be handled by deprecation.
>    

They can also be rejected outright. Else, by the MUST, a determined 
individual can completely deprecate the existing info model by 
requesting a sufficient number of changes.

>     An Information Element MAY be deprecated and replaced when:
>
>     o  the Information Element definition has an error or shortcoming
>        which cannot be permissibly changed as above; or
>
>     o  the deprecation harmonizes with an external reference which was
>        itself deprecated through that reference's accepted deprecation
>        method; or
>    

Depending on the external action, the IE may be deprecated and not replaced.

>     o  changes in the IPFIX Protocol or its extensions, or in community
>        understanding thereof, allow the information represented by the
>        Information Element to be represented in a more efficient or
>        convenient way.  Deprecation in this circumstance additionally
>        requires the assent of the IPFIX Working Group, and should be
>        specified in the Internet Draft(s) defining the protocol change.
>
>     A request for deprecation is sent to IANA, which passes it to the
>     appointed expertsand a responsible Operations Area Director  for
>    

This is new.

>     review; if there is no objection to the change from any appointed
>     expert, IANA makes the change in the Information Element Registry
>     according to its internal procedures.  When deprecating an
>     Information Element, the Information Element description MUST be
>     updated to explain the deprecation, as well as to refer to any new
>     Information Elements created to replace the deprecated Information
>     Element.
>
>     Deprecated Information Elements SHOULD continue to be supported by
>     Collecting Processes, but SHOULD NOT be exported by Exporting
>     Processes.  The use of deprecated Information Elements SHOULD result
>     in a log entry or human-readable warning at theExporting  and
>    

That's crazy! You're saying that the EP should be updated to report that 
it's still sending deprecated fields? LOL. If you're going to update it 
to know that it's sending an obsolete field, your time would clearly be 
better spent updating it not to export that field any more.

>     Collecting Processes.After  a period of time determined in the eyes
>    

Split to a new paragraph at "After".

>     of the appointed experts to be reasonable in order to allow deployed
>     Exporting Processes to be updated to account for the deprecation, a
>     deprecated Information Element may be made obsolete.  Obsolete
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 11]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     Information Elements MUST NOT be supported by either Exporting or
>     Collecting Processes.  The receipt of obsolete Information Elements
>     SHOULD be logged by the Collecting Process.
>    

...and? Should the fields and/or records be discarded or processed?
(Clue: "Be strict in what you send, but generous in what you receive.")

>     Names of deprecated Information Elements MUST NOT be reused.  Names
>     of obsolete Information Elements MAY be reused, but this is NOT
>     RECOMMENDED, as it may cause confusion among users.
>    

Be consistent: if names are the primary reference (rather than the ID 
numbers, strangely), then don't allow names to be reused at all.

>
> 6.  When not to define new Information Elements
>
>     Also important in defining new applications is avoiding redundancy
>     and clutter in the Information Element registry.  Here we provide
>     guidelines for reuse of existing Information Elements, as well as
>     guidelines on using enterprise-specific Information Elements instead
>     of adding Information Elementsin  the registry.
>    

"to"

> 6.1.  Maximizing reuse of existing Information Elements
>
>     Whenever possible, new applications should prefer usage of existing
>     IPFIX Information Elements to the creation of new Information
>     Elements.  IPFIX already provides Information Elements for every
>     common Layer 4 and Layer 3 packet header field in the IETF protocol
>     suite, basic Layer 2 information, basic counters, timestamps and time
>     ranges, and so on.  When defining a new Information Element similar
>     to an existing one,reviewers shall  ensure that the existing one is
>     not applicable.
>    

"... the expert reviewers MUST ..." ?

>     Simply changing the context in which an Information Element will be
>     used is insufficient reason for the definition of a new Information
>     Element.  For example, an extension of IPFIX to log detailed
>     information about HTTP transactions alongside network-level
>     information should not define httpClientAddress and httpServerAddress
>     Information Elements, preferring instead the use of
>     sourceIPv[46]Address and destinationIPv[46]Address.
>    

I've got http through a tunnel, proxy or NAT, such that there are two 
source addresses and two destination addresses.
One src/dst pair is for http, the other belongs to the tunnel, proxy or 
NAT. What do you propose?

>     Applications dealing with bidirectional interactions should use
>     Bidirectional Flow Support for IPFIX [RFC5103] to represent these
>     interactions.
>
>     Specifically, existing timestamp and time range Information Elements
>     should be reused for any situation requiring simple timestamping of
>     an event: for single observations, the observationTime* Information
>     Elements from PSAMP are provided, and for events with a duration, the
>     flowStart* and flowEnd* Information Elements suffice.  This
>     arrangement allows minimal generic time handling by existing
>     Collecting Processes and analysis workflows.  New timestamp
>     Information Elements should ONLY be defined for semantically distinct
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 12]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     timing information (e.g., an IPFIX-exported record containing
>     information about an event to be scheduled in the future).
>
>     In all cases the use of absolute timestamp Information Elements (e.g.
>     flowStartMilliseconds) is RECOMMENDED, as these Information Elements
>     allow for maximum flexibility in processing with minimal overhead.
>     Timestamps based on the export time header in the enclosing IPFIX
>     Message (e.g. flowStartTimeDeltaMicroseconds) MAY be used if high-
>     precision timing is important, export bandwidth or storage space is
>     limited, timestamps comprise a relatively large fraction of record
>     size, and the application naturally groups records into Messages.
>     Timestamps based on information which must be exported in a separate
>     Options Template (e.g. flowStartSysUpTime) MAY be used only in the
>     context of an existing practice of using runtime-defined epochs for
>     the given application.
>
>     The best practice in Information Element creation is a conservative
>     one: don't create a new Information Element unlessyou  really need
>     it.
>    

Of course you really need it. However, does the wider IPFIX community 
really need it?

> 6.2.  Applying enterprise-specific Information Elements
>
>     IPFIX provides a mechanism for defining enterprise-specific
>     Infomation Elements, as in Section 3.2 of [RFC5101].  These are
>     scoped to a vendor's or organization's Structure of Management
>     Information (SMI)Private Enterprise Number, and are under complete
>     control of the organization assigning them.
>    

Cite xref.

>     For situations in which interoperability is unimportant, new
>     information SHOULD be exported using enterprise-specific Information
>     Elements instead of adding new Information Elements to the registry.
>     These situations include:
>
>     o  export of implementation-specific information, or
>
>     o  export of information derived in a commercially-sensitive or
>        proprietary method, or
>
>     o  export of information or meta-information specific to a
>        commercially-sensitive or proprietary application.
>
>     While work within the IETF generally does not fall into these
>     categories, enterprise-specific Information Elements are also useful
>     for pre-standardization testing of a new IPFIX application.  While
>     performing initial development and interoperability testing of a new
>     application, the Information Elements used by the application SHOULD
>     NOT be submitted to IANA for inclusion in the registry.  Instead,
>     these experimental Information Elements SHOULD be represented as
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 13]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     enterprise-specific until their definitions are finalized, then
>     transitioned from enterprise-specific to IANA-defined upon
>     finalization.
>
>
> 7.  Applying IPFIX to non-Flow Applications
>
>     At the core of IPFIX is its definition of a Flow, a set of packets
>     sharing some common properties crossing an observation point within a
>     certain time window.  However, the reliance on this definition does
>     not preclude the application of IPFIX to domains which are not
>     obviously handling flow dataaccording to it.  Most network
>    

According to what? Perhaps just drop these words?

>     management data collection tasks, those to which IPFIX is most
>     applicable, have at their core the movement of packets from one place
>     to another; by a liberal interpretation of the common properties
>     defining the flow, then, almost any event handled by these can be
>     held to concern data records conforming to the IPFIX definition of a
>     Flow.
>    

Is it strictly necessary to convince oneself that a flow exists in order 
to use IPFIX?

>     Non-flow information defining associations or key-value pairs, on the
>     other hand, are handled by IPFIX Options.  Here, the Information
>     Elements within an Options Template are split into Scope IEs which
>     define the key, and non-scope IEs which define the values associated
>     with that key.  Unlike Flows, Options are not necessarily scoped in
>     time; an Option is generally held to be in effect until a new set of
>     values for a specific set of keys is exported.  While Options are
>     often used by IPFIX to export metadata about the collection
>     infrastructure, they are applicable to any association information.
>    

IIRC, there was some discussion about time-scoping IPFIX options and 
templates some years ago. eg, we can export a template, indicating that 
it will be valid from 6pm until midnight. Or pre-export an option, 
indicating that a new selectorAlgorithm will be in force from 6am.

>     An IPFIX application can mix Flow Records and Options in an IPFIX
>     Message or Message stream, and exploit relationships among the Flow
>     Keys, values, and Scopes to create interrelated data structures.  See
>     [RFC5473] for an example application of this.
>
>
> 8.  Defining Recommended Templates
>
>     New IPFIX applications SHOULD NOT, in the general case, define fixed
>     templates for export, as this throws away much of the flexibility
>     afforded by IPFIX.  However, fixed template export is permissible in
>     the case that the export implementation must operate in a resource
>     constrained environment, and/or that the application is replacing an
>     existing fixed-format binary export format in a maximally compatible
>     way.In any case, Collecting Processes for such applications SHOULD
>     support reordered Templates or Templates with additional Information
>     Elements.
>
>     An Internet-Draft clarifying the use of new Information Elements
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 14]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     SHOULD include any recommended Templates or Options Templates
>     necessary for supporting the application, as well as examples of
>    

No it shouldn't, because implementers will blindly follow these and 
system specifiers will expect exactly these templates / options an no 
others, in order to be 100% compliant with the RFC / definition.

Rather, the ID MUST specify which fields are required in the option / 
template, if any, and MAY give example options and templates, clearly 
labelling them as such.

>     records exported using these Templates.  In defining these Templates,
>     such Internet-Drafts SHOULD mention, subject to rare exceptions as
>     above:
>
>     o  that the order of Information Elements within a Template is not
>        significant;
>
>     o  that Templates on the wire for the application may also contain
>        additional Information Elements beyond those specified in the
>        recommended Template;
>
>     o  that a stream of IPFIX Messages supporting the application may
>        also contain Data Records not described by the recommended
>        Templates; and
>
>     o  that any reader of IPFIX Messages supporting the application MUST
>        accept these conditions.
>
>     Definitions of recommended Templates for flow-like information, where
>     the Flow Key is well-defined, SHOULD indicate which of the
>     Information Elements in the recommended Template are Flow Keys.
>    

There's a flowKeyIndicator for that, if it's needed.

>     Recommended Templates are defined, for example, in [RFC5476] for
>     PSAMP packet reports (section 6.4) and extended packet reports
>     (section 6.5).  Recommended Options Templates are defined extensively
>     throughout the IPFIX documents, including in the protocol document
>     itself [RFC5101] for exporting export statistics; in the file format
>     [RFC5655] for exporting file metadata; and in Mediator intermediate
>     process definitions such as [I-D.ietf-ipfix-anon] for intermediate
>     process metadata.  The discussion in these examples is a good model
>     for recommended template definitions.
>    

In your experience (or a quick poll?) do current IPFIX systems implement 
these exactly as specified, or does anyone implement them with the 
caveats described above (eg, in a different order, or with additional 
fields) ?

>     However, the bitmap diagrams of these Templates are illustrative but
>     not particularly readable for more complicated recommended Templates,
>     provide no support for rapid implementation of new Templates, and do
>     not adequately convey the optional nature of ordering and additional
>     Information Elements as above.  Therefore, we have defined
>     RECOMMENDED textual format for specifying Information Elements and
>     Templates in Internet-Drafts in Section 9.
>
>
> 9.  A Textual Format for Specifying Information Elements and Templates
>
>     The  extension of IPFIXwill  generate a fair amount of documentation
>    

"Any extension of IPFIX may be expected to generate..."

>     and discussion covering the definition of new Information Elements.
>     Here we define a simple textual syntax for describing IPFIX
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 15]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     Information Elements and IPFIX Templates, with human readability,
>     human writability, compactness, and ease of parser/generator
>     implementation without requiring external XML support as design
>     goals.  It is intended both for use in human communication (e.g., in
>     new Internet-Drafts containing higher-level descriptions of IPFIX
>     Templates, or describing sets of new IPFIX Information Elements for
>     supporting new applications of the protocol) as well as at runtime by
>     IPFIX implementations.
>
> 9.1.  Information Element Specifiers
>
>     The basis of this format is the textual Information Element
>     Specifier, or IESpec.  An IESpec contains each of the four important
>     aspects of an Information Element: itsname, its number, its type,
>     and its size,separated by simple markup based on various types of
>    

No semantics, units, range?

>     brackets.  Fully-qualified IESpecs may be used to specify existing or
>     new Information Elements within an Information Model, while either
>     fully-qualified or partial IESpecs may be used to define fields in a
>     Template.
>
>     Bare words are used for Information Element names, and each aspect of
>     information associated with an Information Element is associated with
>     a type of brackets:
>
>     o  () parentheses for Information Element numbers,
>
>     o<>  angles for Information Element data types, and
>
>     o  [] square brackets for Information Element sizes.
>
>     o  {} curly braces contain an optional space-separated list of
>        context identifiers to be associated with an Information Element,
>        as described in more detail in Section 9.2
>
>     The symbol + is reserved for Information Element nesting within
>     structured data elements; these are described in and Section 9.3,
>     respectively.
>
>     Whitespace in IESpecs is insignificant; spaces can be added after
>     each element in order, e.g., to align columns for better readability.
>
>     The basic form of a fully-qualified IESpec for an IANA-registered
>     Information Element is as follows:
>
>     name(number)<type>[size]
>    

As long as all the information is present, is the order important? eg, 
using the example from below, one might prefer to write:

          [8] (152) flowStartMilliseconds<dateTimeMilliseconds>
          [8] (153) flowEndMilliseconds<dateTimeMilliseconds>
          [8]   (1) octetDeltaCount<unsigned64>
          [8]   (2) packetDeltaCount<unsigned64>
    {key} [4]   (8) sourceIPv4Address<ipv4Address>
    {key} [4]  (12) destinationIPv4Address<ipv4Address>
    {key} [2]   (7) sourceTransportPort<unsigned16>
    {key} [2]  (11) destinationTransportPort<unsigned16>
    {key} [1]   (4) protocolIdentifier<unsigned8>


>     where 'name' is the name of the Information Element in UTF-8,
>     'number' is the Information Element as a decimal integer, 'type' is
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 16]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     the name of the data type as in the IANA informationElementDataTypes
>     registry, and 'size' is the length of the Information Element in
>     octets as a decimal integer, where 65535 or the string 'v' signifies
>     a variable-length Information Element. [size] may be omitted; in this
>     case, the data type's native or default size is assumed.
>
>     The basic form of a fully-qualified IESpec for an enterprise-specific
>     Information Element is as follows:
>
>     name(pen/number)<type>[size]
>
>     where 'pen' is the Private Enterprise Number as a decimal integer.
>
>     A fully-qualified IESpec is intended to express enough information
>     about an Information Element to decode and display Data Records
>     defined by Templates containing that Information Element.  Range,
>     unit, semantic, and description information, as in [RFC5610], is not
>     supported by this syntax.
>
>     Example fully-qualified IESpecs follow:
>
>        octetDeltaCount(1)<unsigned64>[8]
>
>        octetDeltaCount(1)<unsigned64>  (unsigned64 is natively 8 octets
>        long)
>
>        sourceIPv4Address(8)<ipv4Address>
>
>        wlanSSID(146)<string>[v]
>    

It's 147.

>        sipRequestURI(35566/403)<string>[65535]
>
>     A partial IESpec is any IESpec that is not fully-qualified; these are
>     useful when defining templates.  A partial IESpec is assumed to take
>     missing values from its canonical definition, for example, the IANA
>     registry.  At minimum, a partial IESpec must contain a name, or a
>     number.  Any name, number, or type information given with a partial
>     IESpec must match the values given in the Information Model; however,
>     size information in a partial IESpec overrides size information in
>     the Information Model; in this way, IESpecs can be used to express
>     reduced-length encoding for Information Elements.
>
>     Example partial IESpecs follow:
>
>     o  octetDeltaCount
>
>     o  octetDeltaCount[4] (reduced-length encoding)
>
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 17]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     o  (1)
>
>     o  (1)[4] (reduced length encoding; note that this is exactly
>        equivalent to an Information Element specifier in a Template)
>
> 9.2.  Specifying Templates
>
>     A Template can then be defined simply as an ordered, newline-
>     separated sequence of IESpecs.  IESpecs in example Templates
>     illustrating a new application of IPFIX SHOULD be fully-qualified.
>     Flow Keys may be optionally annotated by appending the {key} context
>     to the end of each Flow Key specifier.  A template counting packets
>     and octets per five-tuple with millisecond precision in IESpec syntax
>     is shown below.
>
>     flowStartMilliseconds(152)<dateTimeMilliseconds>[8]
>     flowEndMilliseconds(153)<dateTimeMilliseconds>[8]
>     octetDeltaCount(1)<unsigned64>[8]
>     packetDeltaCount(2)<unsigned64>[8]
>     sourceIPv4Address(8)<ipv4Address>[4]{key}
>     destinationIPv4Address(12)<ipv4Address>[4]{key}
>     sourceTransportPort(7)<unsigned16>[2]{key}
>     destinationTransportPort(11)<unsigned16>[2]{key}
>     protocolIdentifier(4)<unsigned8>[1]{key}
>
>     An Options Template is specified similarly.  Scope is specified
>    

"specified by"

>     appending the {scope} contextto the end  of each IESpec for a Scope
>    

See earlier about ordering.

>     IE.Due to the way Information Elements are represented in Options
>     Templates, all {scope} IESpecs must appear before any non-scope
>     IESpec.  The Flow Key Options Template defined in section 4.4 of
>     [RFC5101] in IESpec syntax is shown below:
>    

Nonsense! That's only true when the IEs are being exported in an option 
on the wire, because that's how the protocol works.
However, when writing them down, they can be any way around that you like.

eg, specifications written by people who are unfamiliar with the exact 
details of the export protocols, but who simply want to use our 
exporter, sometimes list fields in alphabetical or numerical order. As 
long as {scope} is clearly indicated at the relevant place, it's up to 
us as protocol experts to deal with the ordering detail.

>     templateId(145)<unsigned16>[2]{scope}
>     flowKeyIndicator(173)<unsigned64>[8]
>
> 9.3.  Specifying IPFIX Structured Data
>
>     IESpecs can also be used to illustrate the structure of the
>     information exported using the IPFIX Structured Data extension
>     [I-D.ietf-ipfix-structured-data].  Here, the semantics of the
>     structured data elements are specified using contexts, and the
>     information elements within each structured data element follow the
>     structured data element, prefixed with + to show they are contained
>     therein.  Arbitrary nesting of structured data elements is possible
>     by using multiple + signs in the prefix.  For example, a basic list
>     of IP addresses with "one or more" semantics would be expressed using
>     parially  qualified IESpecs as follows:
>    

Typo, "partially".

>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 18]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     basicList{oneOrMoreOf}
>     +sourceIPv4Address(8)[4]
>
>     And an example subTemplateList itself containing a basicList is shown
>     below:
>
>     subTemplateList{allOf}
>     +basicList{oneOrMoreOf}
>     ++sourceIPv4Address(8)[4]
>     +destinationIPv4Address(12)[4]
>
>     This describes a subTemplateMultilist containing all of the expressed
>     set of source-destination pairs, where the source address itself
>     could be one of any number in a basicList (e.g., in the case of SCTP
>     multihoming).
>
>     The contexts associable with structured data Information Elements are
>     the semantics, as defined in section 4.4 of
>     [I-D.ietf-ipfix-structured-data]; a structured data Information
>     Element without any context is taken to have undefined semantics.
>     More information on the application of structured data is available
>     in [I-D.ietf-ipfix-structured-data].
>
>
> 10.  Security Considerations
>
>     The security aspects of new Information Elements must be considered
>     in order not to give a potential attacker too much information.  For
>     example, the "A Framework for Packet Selection and Reporting"
>     [RFC5474] concluded in section 12.3.2 that the hash functions private
>     parameters should not exported within IPFIX.
>
>     If some security considerations are specific to an Information
>     Element, they MUST be mentioned in the Information Element
>     description.  For example, the ipHeaderPacketSection in the IPFIX
>     registry mentions: "This Information Element, which may have a
>     variable length, carries a series of octets from the start of the IP
>     header of a sampled packet.  With sufficient length, this element
>     also reports octets from the IP payload, subject to [RFC2804].See
>     the Security Considerations section."
>    

Crucially, the relevant RFC containing the Security Considerations is 
cited in the registry 'Requester" column. Without that, this text 
wouldn't make sense.

>     These security considerations MAY also be stressed in a separate
>     draft.  For example, the "Packet Sampling (PSAMP) Protocols
>     Specification" [RFC5476] specifies: "In the basic Packet Report, a
>     PSAMP Device exports some number of contiguous bytes from the start
>     of the packet, including the packet header (which includes link
>     layer, network layer and other encapsulation headers) and some
>     subsequent bytes of the packet payload.  The PSAMP Device SHOULD NOT
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 19]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     export the full payload of conversations, as this would mean
>     wiretapping [RFC2804].  The PSAMP Device MUST respect local privacy
>     laws."
>
>
> 11.  IANA Considerations
>
>     [TODO - collect IANA considerations from the document once we have
>     them.]
>
>
> 12.  Acknowledgements
>
>     [TODO]
>    

TIA ;-)

>
> 13.  Open Issues
>
>     o  add examples everywhere (including sipclf)
>
>     o  explain the range 0-127.
>
>     o  explain thatexisting  draft should use temporary IE identifier
>    

Not just existing, but new drafts too.

>        such as XXX, YYY, and ZZZ both in the text and in the examples,
>        and a note to IANA: "to be replaced by IANA when the IE identifier
>        is assigned"
>
>     o  TBD (in WG): Do we want the IE-Doctors to be a formal directorate
>        under the OPS area?  What can we take from the experience of PMOL?
>
>
> 14.  References
>
> 14.1.  Normative References
>
>     [RFC5101]  Claise, B., "Specification of the IP Flow Information
>                Export (IPFIX) Protocol for the Exchange of IP Traffic
>                Flow Information", RFC 5101, January 2008.
>
>     [RFC5102]  Quittek, J., Bryant, S., Claise, B., Aitken, P., and J.
>                Meyer, "Information Model for IP Flow Information Export",
>                RFC 5102, January 2008.
>
>     [RFC5103]  Trammell, B. and E. Boschi, "Bidirectional Flow Export
>                Using IP Flow Information Export (IPFIX)", RFC 5103,
>                January 2008.
>
>     [RFC5610]  Boschi, E., Trammell, B., Mark, L., and T. Zseby,
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 20]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>                "Exporting Type Information for IP Flow Information Export
>                (IPFIX) Information Elements", RFC 5610, July 2009.
>
>     [RFC2119]  Bradner, S., "Key words for use in RFCs to Indicate
>                Requirement Levels", BCP 14, RFC 2119, March 1997.
>
>     [RFC5226]  Narten, T. and H. Alvestrand, "Guidelines for Writing an
>                IANA Considerations Section in RFCs", BCP 26, RFC 5226,
>                May 2008.
>
> 14.2.  Informative References
>
>     [RFC2804]  IAB and IESG, "IETF Policy on Wiretapping", RFC 2804,
>                May 2000.
>
>     [RFC3917]  Quittek, J., Zseby, T., Claise, B., and S. Zander,
>                "Requirements for IP Flow Information Export (IPFIX)",
>                RFC 3917, October 2004.
>
>     [RFC4181]  Heard, C., "Guidelines for Authors and Reviewers of MIB
>                Documents", BCP 111, RFC 4181, September 2005.
>
>     [RFC5153]  Boschi, E., Mark, L., Quittek, J., Stiemerling, M., and P.
>                Aitken, "IP Flow Information Export (IPFIX) Implementation
>                Guidelines", RFC 5153, April 2008.
>
>     [RFC5470]  Sadasivan, G., Brownlee, N., Claise, B., and J. Quittek,
>                "Architecture for IP Flow Information Export", RFC 5470,
>                March 2009.
>
>     [RFC5471]  Schmoll, C., Aitken, P., and B. Claise, "Guidelines for IP
>                Flow Information Export (IPFIX) Testing", RFC 5471,
>                March 2009.
>
>     [RFC5472]  Zseby, T., Boschi, E., Brownlee, N., and B. Claise, "IP
>                Flow Information Export (IPFIX) Applicability", RFC 5472,
>                March 2009.
>
>     [RFC5473]  Boschi, E., Mark, L., and B. Claise, "Reducing Redundancy
>                in IP Flow Information Export (IPFIX) and Packet Sampling
>                (PSAMP) Reports", RFC 5473, March 2009.
>
>     [RFC5474]  Duffield, N., Chiou, D., Claise, B., Greenberg, A.,
>                Grossglauser, M., and J. Rexford, "A Framework for Packet
>                Selection and Reporting", RFC 5474, March 2009.
>
>     [RFC5476]  Claise, B., Johnson, A., and J. Quittek, "Packet Sampling
>                (PSAMP) Protocol Specifications", RFC 5476, March 2009.
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 21]
> 
> Internet-Draft              IPFIX IE-DOCTORS                October 2010
>
>
>     [RFC5655]  Trammell, B., Boschi, E., Mark, L., Zseby, T., and A.
>                Wagner, "Specification of the IP Flow Information Export
>                (IPFIX) File Format", RFC 5655, October 2009.
>
>     [I-D.ietf-ipfix-structured-data]
>                Claise, B., Dhandapani, G., Yates, S., and P. Aitken,
>                "Export of Structured Data in IPFIX",
>                draft-ietf-ipfix-structured-data-02 (work in progress),
>                July 2010.
>
>     [I-D.ietf-ipfix-anon]
>                Boschi, E. and B. Trammell, "IP Flow Anonymisation
>                Support", draft-ietf-ipfix-anon-03 (work in progress),
>                April 2010.
>
>     [iana-ipfix-assignments]
>                Internet Assigned Numbers Authority, "IP Flow Information
>                Export Information Elements
>                (http://www.iana.org/assignments/ipfix/ipfix.xml)".
>
>
> Authors' Addresses
>
>     Brian Trammell
>     Swiss Federal Institute of Technology Zurich
>     Gloriastrasse 35
>     8092 Zurich
>     Switzerland
>
>     Phone: +41 44 632 70 13
>     Email:trammell@tik.ee.ethz.ch
>
>
>     Benoit Claise
>     Cisco Systems, Inc.
>     De Kleetlaan 6a b1
>     1831 Diagem
>     Belgium
>
>     Phone: +32 2 704 5622
>     Email:bclaise@cisco.com
>
>
>
>
>
>
>
>
>
>
> Trammell&  Claise         Expires April 4, 2011                [Page 22]
> 
>
>