<?xml version="1.0" encoding="US-ASCII"?>
<!DOCTYPE rfc SYSTEM "rfc2629.dtd">
<?rfc toc="yes"?>
<?rfc tocompact="yes"?>
<?rfc tocdepth="4"?>
<?rfc tocindent="yes"?>
<?rfc symrefs="yes"?>
<?rfc sortrefs="yes"?>
<?rfc comments="yes"?>
<?rfc inline="yes"?>
<?rfc compact="yes"?>
<?rfc subcompact="no"?>
<rfc category="info" docName="draft-ccm-ideas-identity-use-cases-02" ipr="trust200902">

  <!-- ***** FRONT MATTER ***** -->

  <front>
    <title>Identity Use Cases in IDEAS</title>

    <!-- add 'role="editor"' below for the editors if appropriate -->

    
    <author fullname="Uma Chunduri" initials="U.C." surname="Chunduri" role="editor">
      <organization>Huawei</organization>
      <address>
      <postal>
      <street>2330 Central Expressway</street>
      <city>Santa Clara</city>
      <region>CA</region>
      <code>95050</code>
      <country>USA</country>
      </postal>
      <email>uma.chunduri@huawei.com</email>
      </address>
    </author>
    
    <author fullname="Alexander Clemm" initials="A.C." surname="Clemm">
      <organization>Huawei</organization>
      <address>
      <postal>
      <street>2330 Central Expressway</street>
      <city>Santa Clara</city>
      <region>CA</region>
      <code>95050</code>
      <country>USA</country>
      </postal>
      <email>ludwig@clemm.org</email>
      </address>
    </author>
    
    <author fullname="Michael Menth" initials="M.M." surname="Menth">
      <organization>University of Tuebingen</organization>
      <address>
      <postal>
      <street></street>
      <city></city>
      <region></region>
      <code></code>
      <country>Germany</country>
      </postal>
      <email>menth@uni-tuebingen.de</email>
      </address>
    </author>
    
    <date year="2017"/>
     
    <area>Routing</area>

    <workgroup>Network Working Group</workgroup>

    <keyword>LISP</keyword>
    <keyword>HIP</keyword>
    <keyword>Identifiers</keyword>
    <keyword>Identity</keyword>

    <abstract>
	    <t>IDentity-EnAbled networkS (IDEAS) introduce the concept of Identity (IDy) into networking.
		An IDy represents a high-level identifier representing a collection of identifiers of a device, node, or process used for communication purposes.  It is used for authentication purposes and never revealed in data plane packets.  This document summarizes some conceptual use cases to illustrate the usefulness of IDEAS.
    </t>
    </abstract>

    <note title="Requirements Language">
      <t>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 <xref
      target="RFC2119">RFC2119</xref>.</t>
    </note>
  </front>

  <middle>
	  <section title="Introduction">

		  <t> An Internet Protocol (IP) <xref target="RFC0791"></xref> address signifies both a Communications Entity's (<xref target="ACRO"> </xref>) Location 
		  and its Identification.  
		      Location and Identification separation protocols, for example  
			  <xref target="RFC7401">HIP</xref> and <xref target="RFC6830">LISP</xref>, introduced the concept of Identifier and 
		      separated this information from the Locator (IP address in this case). </t>  

		<t>The Location/Identifier split separates Location and Identification function for a specific networking device, i.e., the Identifier denotes a device while the Locator denotes a routable network interface. 
			With Location/Identifier split, multiple benefits in networking can be realized, e.g., 
			in the areas of mobility, network virtualization, traffic engineering, security, software-defined networking, and others.
	            	</t>

			<t> IDEAS goes one step further and makes a distinction between IDy and Identifier, and introduces an IDy/Identifier split. 
			The abstraction of an IDy
			and the corresponding split from Identifiers can bring additional 
				benefits that can be combined with Location/Identifier separation. 
				The abstraction applies at the network layer, like Locator/Identifier, 
				and is not related to transport or application Identities.  
			  Any use of identifiers in the data plane is governed by the respective 
				ID/Locator protocols, such as LISP and HIP.  
			</t>
			<t>
			An IDy serves as a collection of identifiers that are associated with the same 
			endpoint.  
			It is used to identify and authenticate the communications entity, but not
			revealed in packet headers.  It is not to be confused with a personal identity, 
			does not represent human-identifiable information, 
			and does not imply an exclusive nor long-lived binding with an endpoint.  
	        Its potential benefits are in the areas of privacy
			  i.e., the ability to have 
		      multiple identifiers for the same communications entity which can be used for anonymous communication,  
			  access controls at the Mapping System (MS) to expose mapping information only to authorized
			  requestors,
		      and application of various policies uniformly across Identifiers pertaining to the same
			  IDy.  IDy also enables easier and more efficient management of various 
			  aspects at the mapping system, as related Identifiers can be referred to in groups.  
			 			  
			  </t>
    </section>   
	      
	      
 	<section anchor="ACRO" title="Acronyms">
        <t><list hangIndent="7" style="hanging">
		<t> Communications Entity: A device, node, or software process used for IP-based (in some case Layer-2 based) data communication</t>
		<t> GRIDS: GeneRic Identity Services - a mapping and Identity services system that will be defined in the context of IDEAS.  This goes beyond traditional mapping of Location/Identifier and can include Identity based services(e.g. policy/metadata/grouping service). </t>
		<t> HIP: Host Identity Protocol</t>
		<t> IDf: Identifier - denotes information to unambiguously identify a communications entity within a given scope. Examples  HIP HIT <xref target="RFC7401"></xref> and LISP EID <xref target="RFC6830"></xref>.
                    There is no constraint on the format, obfuscation or routability of an Identifier.   
	            	</t>
					<t> IDy: Identity - an identifier for a communications entity that MAY be assigned by the GRIDS-provider  and that 
						is used by the provider to identify and authenticate the communications entity, but that is not revealed in the packet headers. 
						 </t>
	    <t> LOC: Locator, for example, IPv4/IPv6 based </t>
		<t> LISP: The Locator/ID Separation Protocol</t>
		<t> Metadata: Metadata is network-related data about an IDy.  The metadata may contain information such as the type of the communications entity. </t>
		<t> MS:  Traditional Mapping Server for LOC/IDf protocols (e.g. HIP RVS, LISP-DDT) 	</t> 
        </list></t>
        </section>
 	<section anchor="NEED_FOR_IDY" title="Uses for IDy">
		<t>
A communications entity can use multiple Identifiers for anonymous communication in the data plane 
<xref target="I-D.ietf-lisp-eid-anonymity"></xref> or for other reasons, 
for example to representing different locators simultaneously. 
When multiple Identifiers are in use, the notion of Layer-3 IDy helps in the following ways.

			</t>
<t><list style="letters">
		<t>
			IDy representing the communications entity enables authentication (AUTH) with the mapping and Identity services infrastructure. While it is possible to do AUTH on Identifiers those are NOT permanently  associated to the communications entity. Moreover, AUTH operation is a relatively expensive and inefficient procedure (compared to LOC resolution for example) and can cause excessive startup delays for many applications.
	            	</t>
			
		<t>
	Data plane anonymization allows entities to communicate anonymously from the outside observers. IDy provides de-anonymization for various data plane ephemeral Identifiers, if required,  and enables resolution of which communications entity is behind these identifiers for legitimate users (entities itself in some cases).
	            	</t>
		<t>
	IDy enables managing access restriction policies and metadata in simplified and more efficient manner. 
	An example of metadata is the type of communications entity, 
	such as whether it is an IoT device, a connected vehicle, a server, an end user device.  
	Managing the association between metadata or policy on the basis of IDy (that represents a collection of 
	identifiers used by the communications entity) is greatly simplified and reduces the chances of error and 
	inconsistencies compared to having to enumerate 
	each identifier individually and having to update policies and metadata whenever identifiers are changed.  
	It also allows certain policies (e.g. metadata-based policies) to be applied 
	regardless of which of an IDy's Identifiers happens to be used in data plane communication by the communications entity. 
	Without IDy, any access restrictions kept on Identifiers would be easily defeated 
	if the peer communications entity simply changes the Identifier.  

	            	</t>
        </list></t>
		<t>
	   The above requirements for having a stable network layer IDy is further detailed in <xref target="USE_CASES"></xref>. <xref target="USE_CASES"></xref> also shows how
   another abstraction of IDy from Identifiers help to enable
   various services in the data communication with in IDEAS.
	            	</t>
		</section>

    <section anchor="IDENTITY" title="IDy in IDEAS">

	    <t> An IDy identifies a Communications Entity.  IDy
		    MAY be unicoded or an ASCII string, which MAY have a partial structure (depends on the authentication method selected) and MAY be given by the provider of the  IDy services.   
		    Typically, an IDy SHOULD NOT be revealed unencrypted on the wire or shared with other entities to make IDy a private enclave. 
	    </t>

  	    <t> IDy is used for authentication of the Communications Entity 
		and it MAY be represented by multiple Identifiers (IDf's) in the data plane.
		    IDy can be seen as a 'first order Identifier' of a communications entity 
			with certain properties (for example not used in data plane) and 
		    with certain additional attributes which are common to all Identifiers of a communications entity.
			In that sense, an IDf can be seen as a 'second order identifier' that is anchored in, and refers to, a first-order identifier.  
	    </t>
	    <t>
		Access to the [IDy, IDf] mapping information may be restricted to a defined set of communication entities. 
		Even when access is authorized, IDy information is not exposed directly but information about the collection 
		of IDfs grouped under the same IDy.  For example, given an IDf, a requestor that is authorized to do so 
		(for example, a communications peer) may look up a designated well-known IDf that belongs to the same communications entity.  Likewise, using the mapping, given an IDf, policies and metadata associated with IDf's IDy can be accessed.   
		   These communication patterns leverage GeneRic ID Services (GRIDS), in which locator/identifier mappings are maintained along with IDf, IDy, and locator associations, and which provide various services associated with those mappings.   
		   In the following (<xref target="USE_CASES"> </xref>) various IDy use cases point out benefits of IDy in IDEAS.
	    </t>

	    <t> The following diagram <xref target="IDENTITY_IDENTIFIER"></xref> illustrates a simplified relation of Identity , Identifier, and Locator [IDy, IDf, LOC].
	    </t>


      <figure anchor="IDENTITY_IDENTIFIER" 
	      title="Identity, Identifier, Locator Relationship">
	      <preamble></preamble>
	      <artwork align="left">
   +---------------------------------------------------------------+
   | Identity (IDy)       | Policy           | Metadata |   MI     |
   +---------------------------------------------------------------+
            |
            +---------------------+--------------------+
            |                  	  |	               |
            V                     V                    V 
   +------------------------+ +--------------+   +-------------------+
   |Identifier(IDf)-1 | LOC1| | IDf-2 | LOC2 |...| IDf-n| LOC1..LOCm |  
   |(long-lived)            | | (ephemeral)  |   |                   |
   +------------------------+ +--------------+   +-------------------+

	MI -  Management and Security Information
	      </artwork>
	      <postamble></postamble>
      </figure>
    </section>     

    <section anchor="USE_CASES" title="IDy Use Cases">
	    <t>
               The uses for the IDy concept can be described by a few simple use cases, 
			   as specified below.
	        
	    </t>
	    <section anchor="PRIVACY" title="Privacy">
		    
		    <t> To communicate with a device on a network, a LOC is needed. 
			In current [IDf, LOC] protocols, a Mapping Server (MS) stores the [IDf,LOC] mapping. The resolution request or lookup of an IDf to the MS will return the LOC. 
	    </t>

	    <t> Generally, a communications entity with a certain IDy may use various
   Identifiers for communication.  Only the Identifier is
   visible on the wire.  Changing the IDf frequently makes it
   hard to track the communications entity by outside observers and thus improves privacy of the communication entities.
	    </t>
   
	    <t>While it may be desirable to change the IDf every now and then for
   privacy purposes, the notion of IDy in addition to IDf can be 
   important for several reasons.  For example, it allows to apply the 
   same policy for a communications entity of a given IDy regardless 
   which of IDfs that are associated with the IDy are used.  
   It allows senders to use anonymized and fast-changing identifiers over the wire 
   that make tracking difficult, 
   while still allowing a receiver to look up a known or long-lived identifier or metadata of the same communications entity, 
   if authorized by the sender.  
   </t>
   <t>It should be noted that a communications entity will never be allowed to look up another 
   communication entity's IDy.  However, depending on authorization policy, 
   it may be able to look up another IDf that is designated as a "well known" IDf and 
   associated with the same IDy.  This allows a communications entity to reveal "who it is" to the receiver if it 
   chooses to do so, while obfuscating this information to observers.    
	    </t>
	    

        </section>
    	<section anchor="POLICY" title="Unified Policies">
		<t>
		
		Networks today treat traffic differently depending on properties such as source or destination. E.g., certain traffic may access the network directly, other traffic may need to pass a firewall, 
		or other traffic is entirely blocked.  Likewise, some traffic may be treated with different Quality of Service.   
	    </t>
        <t>
		Similarly, the use of alternative IDfs for the same system may allow for different treatment 
		of traffic for the same system depending on how the system is referred to, whereas  
        in other cases, the same policy should be applied regardless which of a set of IDfs (related through 
        a common IDy) is used. 
		This can be leveraged by combining the enforcement of network policies with policies 
		that guide selective mapping responses. E.g., some requesting groups may receive an 
		empty response from GRIDS Infrastructure 
	    for IDfs referring to a certain IDy, others receive an IDf resulting in 
		strict security treatment of future traffic, and trusted groups receive an IDf resulting in rather loose security treatment.
		</t>
    			<section anchor="ACCESS_CONTROL" title="Access Restriction Policies">
			<t>
				A communications entity may define that it wants to communicate only with certain other entities. 
				To achieve this, a communications entity MAY define a rule regarding who can request and obtain its IDf. 
				The GRIDS Infrastructure will send a negative or empty response when it detects that the combination of resolution query and its initiator does not pass the rule 
				validation test. One example of this policy is, restriction of LOC resolution and hence allowing data traffic from only from the dealer/manufacturer of a vehicular node.
			</t>
			<t>
			Moreover, network-based access control may filter based on IDfs which are visible in the traffic, but this can be done simply through an association related to the IDy, 
			which allows to check (proper authorization assumed) whether an IDf is associated with the same IDy
			as another, well-known IDf.  (The IDy itself is never revealed.)  
			By basing access control on the notion of IDy, respectively an IDy's collection of IDfs, enforcement and maintainability of access control 
			rules is greatly simplified as there is no need to track IDf changes or the introduction of new IDfs for the same IDy.
			</t>
        		</section>
        </section>
    	<section anchor="META" title="Uses of Metadata">
		<t>
			The GRIDS Infrastructure is envisioned to store Metadata (<xref target="ACRO"> </xref>) 
			and provide some search functionality. 
			The GRIDS Infrastructure with may be a means to find a set of communications entities 
			with certain associated metadata, provided 
		that they have agreed to be searchable (allow discovery of a designated well-known IDf). 
		E.g., it may be possible to find out 
		current well-known IDfs of a set of deployed devices of particular type. 
		This allows to locate them via 	[IDf, LOC] mappings and possibly manage them.  
		</t>
		<t>IDy also allows to have associated metadata applied, regardless of which IDf is used to refer to the 
		communications entity.  
		This association makes the management of metadata easier, because it does not need to be maintained separately and redundantly for every IDf.
		</t>
        </section>
    	<section anchor="MANAGEMENT" title="Access Security and Manageability">
		<t>  
			As secure registration between a commmunications entity and GRIDS would be an expensive operation, this SHOULD be restricted to IDy and (ephemeral) IDfs can be generated and can be given rather securely using the same secure channel.  
		</t> 
	        <t> IDy allows separation  of lifecycle of IDy to be different from Identifiers, which enables to extend the "right-to-be-forgotten" concerning personal 
			data to 
			network identifier data, if required. 
			There are various possible scenarios on why a long-lived IDfs by a communications entity has to be withdrawn.  Common cases involved lost/stolen device or misused Identifiers for example.
		</t> 
        </section>
    	<section anchor="DELAY_TOLERANT_NW" title="Delay-Tolerant Networking (DTN)">
		<t>
		Entities may be only temporarily reachable. When they are not reachable, proxies may be used to receive their traffic. To that end, using an IDy, a communications entity MAY register one of the IDfs of its proxy with 
		the GRIDS Infrastructure that this node can, e.g., receive traffic for that node and later forward to it when the node is again online. A major application field may be in the IoT with mobile 
		and intermittently connected devices
		</t>
        </section>

    </section>

    <section anchor="Acknowledgements" title="Acknowledgements">
      <t>Thanks to Padma Pillay-Esnault for so many conversations around IDy and its potential uses in IDEAS. The authors would like to thank detailed reviews and suggestions from Dino Farinacci, Joel Halpern,  Jeff Tantsura, Jim Guichard, Christian Huitema, Dave Meyers, Robert Moskowitz, Georgios Karagiannis, Liu Bingyang and Yangfei. 
	  We also acknowledge the constructive and useful feedback from the IDEAS BOF and mailing 
	  list.</t>
    </section>

    <section anchor="IANA" title="IANA Considerations">
      <t>This document has no actions for IANA.</t>
    </section>

    <section anchor="Security" title="Security Considerations">
	    <t>This document further abstracts IDy from the Identifier in current Identifier/Locator protocols. This abstraction gives significant security benefits and enables networks to facilitate anonymization  of communications on the wire and to allow communications entities to control access to their locator information, as specified in  <xref target="I-D.padma-ideas-problem-statement"></xref>.  
		The IDy concept and data stored in GRIDS are intended for routing and forwarding purposes only.  
		They are in no way indended and must not 
		be used to store human-identifiable information, personal identifiers, and the like.  
		A separate threat analysis detailing security and privacy aspects of the IDy concept 
		and data maintained in GRIDS will be done in a separate document under the IDEAS charter.</t>
    </section>
  </middle>

  <!-- *****BACK MATTER ***** -->

  <back>
    <references title="Normative References">
      <?rfc include="http://xml.resource.org/public/rfc/bibxml/reference.RFC.2119.xml"?>
      <?rfc include="http://xml.resource.org/public/rfc/bibxml/reference.RFC.0791.xml"?>
    </references>

    <references title="Informative References">
      <?rfc include="http://xml.resource.org/public/rfc/bibxml/reference.RFC.6830.xml"?>
      <?rfc include="http://xml.resource.org/public/rfc/bibxml/reference.RFC.7401.xml"?>
      <?rfc include="reference.I-D.padma-ideas-problem-statement"?>
      <?rfc include="reference.I-D.ietf-lisp-eid-anonymity"?>
    </references>
  </back>
</rfc>
