Adding supplementary specification of the Face management protocol

Specification is based fully on the existing one, adapted for NDN-TLV
format encoding.

git-svn-id: svn+ssh://dyadis.cs.arizona.edu/NDN-spec/spec-sphinx@192 c5937c81-b952-4fd9-96ba-3036b240b622
diff --git a/face-registration.rst b/face-registration.rst
new file mode 100644
index 0000000..5453cb5
--- /dev/null
+++ b/face-registration.rst
@@ -0,0 +1,293 @@
+.. _Face Registration:
+
+Face Management and Registration Protocol
+-----------------------------------------
+
+Face Management Protocol
+^^^^^^^^^^^^^^^^^^^^^^^^
+
+The Face Management Protocol provides a method for an entity such as ndndc to control
+the faces maintained by ndnd, which are subsequently used in the Registration Protocol.
+
+The FMP supports ``newface``, ``destroyface``, and ``queryface`` operations.
+
+A request operation is represented as a NDN Interest with
+a NDN Data in NDN-TLV encoding, while the majority of the request parameters embedded
+as a component of the Interest name.
+A response is represented as a Data for which the name matches the Interest,
+and the content encodes any necessary response data.
+
+For the Face Management Protocol, the content of the Data packet is FaceInstance object
+as defined below.
+
+For example, the following steps necessary to create a new face:
+
+- Create NDN-TLV encoded FaceInstance object, containing action ``newface`` and other
+  necessary fields to set up the face (e.g., ``IPProto``, ``Host``, ``Port``).
+
+- Create NDN-TLV encoded Data packet (``<NFBLOB>``), whose content is the encoded
+  FaceInstance object
+
+- Express an Interest ``/ndnx/<NDNDID>/newface/<NFBLOB>``, where
+
+  * ``<NDNDID>`` is the SHA256 of the public key of the forwarding daemon.
+
+  * ``<NFBLOB>`` is encoded Data packet with encoded FaceInstance object as content.
+
+The verb, ``newface`` occurs redundantly in both the Interest prefix and in the ``NFBLOB``.
+Its presence in the prefix is for dispatching the request.
+It is also in the ``NFBLOB``, so that it is signed.
+
+The forwarding daemon creates the new face and answers with a FaceInstance containing
+at least the ``FaceID``.
+
+FaceInstance
+^^^^^^^^^^^^
+
+::
+
+    FaceInstance ::= FACE-INSTANCE-TYPE TLV-LENGTH
+                       Action?
+                       FaceID?
+                       IPProto?
+                       Host?
+                       Port?
+                       MulticastInterface?
+                       MulticastTTL?
+                       FreshnessPeriod?
+
+    Action             ::= ACTION-TYPE TLV-LENGTH
+                            ("newface" | "destroyface" | "queryface")
+
+    FaceID             ::= FACEID-TYPE TLV-LENGTH
+                             nonNegativeInteger
+
+    IPProto            ::= FACEID-TYPE TLV-LENGTH
+                             nonNegativeInteger
+                       (*IANA protocol number; 6=TCP, 17=UDP*)
+
+    Host               ::= HOST-TYPE TLV-LENGTH
+                             <textual representation of numeric IPv4 or IPv6 address>
+
+    Port               ::= PORT-TYPE TLV-LENGTH
+                             nonNegativeInteger
+                       (* from the range [1..65535] *)
+
+    MulticastInterface ::= MULTICAST-INTERFACE-TYPE TLV-LENGTH
+                             <textual representation of numeric IPv4 or IPv6 address>
+
+    MulticastTTL       ::= MULTICAST-TTL-TYPE TLV-LENGTH
+                             nonNegativeInteger
+                       (* from the range [1..255] *)
+
+See :ref:`Data packet's meta info description <MetaInfo>` for definition of ``FreshnessPeriod``.
+
+Action
+++++++
+
+When FaceInstance is used as a request, the Action must be specified.
+It will not be present in a response.
+
++-----------------+----------------------------------------------------------------------+
+| Action          | Description                                                          |
++=================+======================================================================+
+| ``newface``     | If a face matching the parameters does not already exist, an attempt |
+|                 | is made to create it.                                                |
+|                 |                                                                      |
+|                 | Then if the face exists (whether new or old) the full description is |
+|                 | returned as a FaceInstance.                                          |
++-----------------+----------------------------------------------------------------------+
+| ``destroyface`` | At least the FaceID must be present.                                 |
+|                 | If permitted, the face is destroyed.                                 |
++-----------------+----------------------------------------------------------------------+
+| ``queryface``   | TBD                                                                  |
++-----------------+----------------------------------------------------------------------+
+
+FaceID
+++++++
+
+FaceID is not present in a `newface` request, but must be specified in
+a `destroyface` or `queryface` request.
+FaceID is always present in a response.
+
+Host
+++++
+
+Identifies the IPv4 or IPv6 numeric address of the remote ndnd for this
+FaceInstance.
+
+Port
+++++
+
+Port identifies the port on the remote ndnd, or the port for the multicast group.
+
+MulticastInterface
+++++++++++++++++++
+
+If the Host is a multicast address, and there are multiple
+interfaces present, MulticastInterface will identify the unicast
+numeric address of the interface to which the multicast address will be
+attached.
+
+MulticastTTL
+++++++++++++
+
+Specifies the TTL to be used for multicast operations.  The default value is 1.
+
+FreshnessPeriod
+++++++++++++++++
+
+FreshnessPeriod is optional in a request, but is treated as a hint by the forwarding daemon.
+In a response, FreshnessPeriod specifies the remaining lifetime in milliseconds of the
+face.
+
+Prefix Registration Protocol
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+The prefix registration protocol uses the ForwardingEntry element type
+to represent both requests and responses.
+
+::
+
+    ForwardingEntry ::= FORWARDING-ENTRY TLV-LENGTH
+                          Action?
+                          Name?
+                          FaceID?
+                          ForwardingFlags?
+                          FreshnessPeriod?
+
+    Action          ::= ACTION-TYPE TLV-LENGTH
+                          ("prefixreg" | "selfreg" | "unreg")
+
+    FaceID          ::= FACEID-TYPE TLV-LENGTH
+                          nonNegativeInteger
+
+    ForwardingFlags ::= FORWARDING-FLAGS TLV-LENGTH
+                          nonNegativeInteger
+
+See :ref:`Name section <Name>` for definition of ``Name`` and 
+:ref:`Data packet's meta info description <MetaInfo>` for definition of ``FreshnessPeriod``.
+
+
+Action
+++++++
+
+When ForwardingEntry is used as a request, the Action must be specified.
+It will not be present in a response.
+
+- `prefixreg` - Register (or re-register) the prefix on the specified face.
+- `selfreg` - Register (or re-register) the prefix on the current face; the
+  FaceID need not be present in the request, but if present it must match
+  the current face.
+- `unreg` - Remove the prefix registration for the specified face.
+
+FaceID
+++++++
+
+FaceID is required in `prefixreg` and `unreg` requests.
+FaceID is always present in a response.
+
+Name
+++++
+
+This is the name prefix to be acted on.
+
+ForwardingFlags
++++++++++++++++
+
+This integer holds the inclusive OR of the following bit fields:
+
++----------------------------+---------------+-----------------------------------------------------------------------------+
+| Flag mnemonic              | Bit (decimal) | Description                                                                 |
++============================+===============+=============================================================================+
+| ``NDN_FORW_ACTIVE``        | 1             | Indicates that the entry is active;                                         |
+|                            |               | interests will not be sent for inactive entries (but see note below).       |
++----------------------------+---------------+-----------------------------------------------------------------------------+
+| ``NDN_FORW_CHILD_INHERIT`` | 2             | Denotes that this entry may be used even if there is a longer match         |
+|                            |               | available.  In the absence of this bit, the presence of a longer matching   |
+|                            |               | prefix that has an active entry will prevent this entry from being used.    |
++----------------------------+---------------+-----------------------------------------------------------------------------+
+| ``NDN_FORW_ADVERTISE``     | 4             | Indicates that the prefix may be advertised to other nodes.                 |
++----------------------------+---------------+-----------------------------------------------------------------------------+
+| ``NDN_FORW_LAST``          | 8             | Indicates that this entry should be used last, if nothing else worked.      |
+|                            |               | This is intended to be used by ndndc and similar programs to monitor        |
+|                            |               | unanswered interests.                                                       |
+|                            |               |                                                                             |
+|                            |               | The presence of this flag on any entry causes the associated face to be     |
+|                            |               | considered non-local, as far as interest forwarding is concerned.           |
+|                            |               | Thus it will not receive interests with Scope=1, nor will it receive        |
+|                            |               | interests in namespaces that are marked local.  However, the ability of     |
+|                            |               | the face to change prefix registrations is not affected.                    |
++----------------------------+---------------+-----------------------------------------------------------------------------+
+| ``NDN_FORW_CAPTURE``       | 16            | Says that no shorter prefix may be used, overriding child-inherit bits that |
+|                            |               | would otherwise make the shorter entries usable.                            |
+|                            |               |                                                                             |
+|                            |               | For a child-inherit bit to be overridden, the ``NDN_FORW_CAPTURE_OK`` must  |
+|                            |               | be set in the same forwarding entry that has ``NDN_FORW_CHILD_INHERIT``     |
+|                            |               | set.  Note that this means that using ``NDN_FORW_CAPTURE`` will have no     |
+|                            |               | effect if the ``NDN_FORW_CAPTURE_OK`` flag is not used.                     |
++----------------------------+---------------+-----------------------------------------------------------------------------+
+| ``NDN_FORW_LOCAL``         | 32            | Restricts the namespace to use by applications on the local machine.        |
+|                            |               |                                                                             |
++----------------------------+---------------+-----------------------------------------------------------------------------+
+| ``NDN_FORW_TAP``           | 64            | Causes the entry to be used right away.  This is intended for debugging     |
+|                            |               | and monitoring purposes.  It is likely that there will be no response as    |
+|                            |               | a result, so no intentional delay is added before any further forwarding    |
+|                            |               | of this interest.                                                           |
++----------------------------+---------------+-----------------------------------------------------------------------------+
+| ``NDN_FORW_CAPTURE_OK``    | 128           | used in conjunction with ``NDN_FORW_CHILD_INHERIT`` allows a                |
+|                            |               | ``NDN_FORW_CAPTURE`` flag on a longer prefix to override the effect of      |
+|                            |               | the child-inherit bit.                                                      |
++----------------------------+---------------+-----------------------------------------------------------------------------+
+
+The flags ``NDN_FORW_ADVERTISE``, ``NDN_FORW_CAPTURE`` and ``NDN_FORW_LOCAL`` affect
+the prefix as a whole, rather than the individual registrations.
+Their effects take place whether or not the ``NDN_FORW_ACTIVE`` bit is set.
+
+FreshnessPeriod
++++++++++++++++
+
+FreshnessPeriod is optional in a request, but is treated as a hint by the forwarding daemon.
+In a response, FreshnessPeriod specifies the remaining lifetime in milliseconds of the registration.
+
+
+Type code assignment
+^^^^^^^^^^^^^^^^^^^^
+
+Face management and registration protocol uses the following type codes, which are assigned
+from the :ref:`application range (128-252) <type reservations>`.
+
+Some codes (e.g., `Name`, `FreshnessPeriod`), re-use code assignment from the NDN-TLV specification.
+
++---------------------------------------------+-------------------+----------------+
+| Type                                        | Assigned value    | Assigned value |
+|                                             | (decimal)         | (hexadecimal)  |
++=============================================+===================+================+
+| **Application-specific definitions**                                             |
++---------------------------------------------+-------------------+----------------+
+| FaceInstance                                | 128               | 0x80           |
++---------------------------------------------+-------------------+----------------+
+| ForwardingEntry                             | 129               | 0x81           |
++---------------------------------------------+-------------------+----------------+
+| Action                                      | 130               | 0x82           |
++---------------------------------------------+-------------------+----------------+
+| FaceID                                      | 131               | 0x83           |
++---------------------------------------------+-------------------+----------------+
+| IPProto                                     | 132               | 0x84           |
++---------------------------------------------+-------------------+----------------+
+| Host                                        | 133               | 0x85           |
++---------------------------------------------+-------------------+----------------+
+| Port                                        | 134               | 0x86           |
++---------------------------------------------+-------------------+----------------+
+| MulticastInterface                          | 135               | 0x87           |
++---------------------------------------------+-------------------+----------------+
+| MulticastTTL                                | 136               | 0x88           |
++---------------------------------------------+-------------------+----------------+
+| ForwardingFlags                             | 137               | 0x89           |
++---------------------------------------------+-------------------+----------------+
+| **Re-used definitions**                                                          |
++---------------------------------------------+-------------------+----------------+
+| FreshnessPeriod                             | 20                | 0x14           |
++---------------------------------------------+-------------------+----------------+
+| Name                                        | 2                 | 0x02           |
++---------------------------------------------+-------------------+----------------+