Network Working Group                                        J. Laganier
Internet-Draft                                          DoCoMo Euro-Labs
Expires: January 9, 2008                                   G. Montenegro
                                                   Microsoft Corporation
                                                                A. Kukec
                                                    University of Zagreb
                                                            July 8, 2007


       Using IKE with IPv6 Cryptographically Generated Addresses
                     draft-laganier-ike-ipv6-cga-02

Status of this Memo

   By submitting this Internet-Draft, each author represents that any
   applicable patent or other IPR claims of which he or she is aware
   have been or will be disclosed, and any of which he or she becomes
   aware will be disclosed, in accordance with Section 6 of BCP 79.

   Internet-Drafts are working documents of the Internet Engineering
   Task Force (IETF), its areas, and its working groups.  Note that
   other groups may also distribute working documents as Internet-
   Drafts.

   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."

   The list of current Internet-Drafts can be accessed at
   http://www.ietf.org/ietf/1id-abstracts.txt.

   The list of Internet-Draft Shadow Directories can be accessed at
   http://www.ietf.org/shadow.html.

   This Internet-Draft will expire on January 9, 2008.

Copyright Notice

   Copyright (C) The IETF Trust (2007).











Laganier, et al.         Expires January 9, 2008                [Page 1]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


Abstract

   This document describes IKEv2 peer authentication via IPv6
   Cryptographically Generated Addresses (CGA).  This techincque have
   been proposed to solve several security issues in the absence of any
   centralized trusted security infrastructure and without any pre-
   arrangements, to provide IPSec self-evident authentication mode
   between IPv6 nodes or security gateways.


Table of Contents

   1.  Introduction and Problem Statement . . . . . . . . . . . . . .  3
   2.  Terminology  . . . . . . . . . . . . . . . . . . . . . . . . .  4
   3.  Node Configuration and Requirements  . . . . . . . . . . . . .  5
   4.  Usage Scenarios  . . . . . . . . . . . . . . . . . . . . . . .  7
     4.1.  IPsec Transport Mode with self-evident authentication  . .  7
     4.2.  IPSec Tunnel Mode with self-evident authentication . . . .  8
   5.  IKEv2 Payload usage and requirements . . . . . . . . . . . . . 11
     5.1.  Identification Payload . . . . . . . . . . . . . . . . . . 11
     5.2.  Certificate Payload  . . . . . . . . . . . . . . . . . . . 11
     5.3.  Certificate Request Payload  . . . . . . . . . . . . . . . 11
     5.4.  Authentication Payload . . . . . . . . . . . . . . . . . . 12
     5.5.  Traffic Selector Payload . . . . . . . . . . . . . . . . . 12
   6.  IKE_AUTH validation  . . . . . . . . . . . . . . . . . . . . . 13
     6.1.  IPSec Transport Mode with self-evident authentication  . . 13
     6.2.  IPSec Tunnel Mode with self-evident authentication . . . . 14
   7.  Comparation with Better Than Nothing Security (BTNS) . . . . . 15
   8.  Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . 16
   9.  Security Considerations  . . . . . . . . . . . . . . . . . . . 17
   10. Open Issues  . . . . . . . . . . . . . . . . . . . . . . . . . 18
   11. Intellectual Property Rights Considerations  . . . . . . . . . 19
   12. References . . . . . . . . . . . . . . . . . . . . . . . . . . 20
     12.1. Normative References . . . . . . . . . . . . . . . . . . . 20
     12.2. Informative References . . . . . . . . . . . . . . . . . . 20
   Authors' Addresses . . . . . . . . . . . . . . . . . . . . . . . . 21
   Intellectual Property and Copyright Statements . . . . . . . . . . 22














Laganier, et al.         Expires January 9, 2008                [Page 2]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


1.  Introduction and Problem Statement

   This document describes how to use IKEv2 with IPv6 Cryptographically
   Generated Address (CGA).  The use of CGA provides authentication for
   IKEv2 based on the address-proof-of-ownership.  It requires only
   slight modification of IKEv2 protocol and provides self-evident
   authentication between previously unknown IPv6 nodes and/or gateways.

   CGAs have been proposed to solve several security issues in the
   absence of any centralized trusted security infrastructure and
   without any pre-arrangements, for example, securing Binding Updates
   in Mobile IPv6, securing Neighbor Discovery for IPv6, securing IPv6
   multihoming protocol - SHIM6, and securing Group Membership in
   Multicast and Anycast communications.

   Until now, the deployment of IPSec has been severely limited because
   it constrains IP nodes to have either a pre-shared key or a common
   trusted root (e.g., a PKI infrastructure).  Thus, the lack of a
   global, Internet-wide, trusted infrastructure has precluded a
   straightforward application of IPsec between any two previously
   unknown nodes.  CGA provides an alternative for Security Association
   establishment that does not require using a centralized
   infrastructure or prearrangements.  This approach is similar to [4].

   From the point of view of implementation effort, the fact that this
   approach only requires the addition of stand-alone CGA validation
   routines into existing IKEv2 daemons (e.g. racoon2, pluto, ikev2,
   etc) is another considerable advantage.

   This note is organized as follows: we will first describe related
   work and some usage scenarios for a CGA-enabled peer authentication
   within an IKEv2 exchange, then we will enumerate requirements for
   those IKEv2 payloads that need it, and finally, describe precisely
   how to perform the IKE_AUTH exchange.  Accordingly, this note
   presents an overview of how to use the Internet Key Exchange version
   2 protocol [1] while one or both peers authenticate themselves via
   CGA proof-of-ownership.  This document details the slight
   modifications needed.  Additionally, it aims at capturing the current
   thinking about how to achieve proof-of-ownership in IKEv2 via CGA in
   a standard manner, thus preventing subsequent conflicting
   definitions.  Currently, it has still some open aspects/issues.










Laganier, et al.         Expires January 9, 2008                [Page 3]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


2.  Terminology

   Cryptographically Generated Address (CGA): An adress which is
   generated in accordance with [2].  Any crypto address used must be
   generated as a CGA.

   CGA enabled Node: An IPv6 node that has one CGA configured as its
   IPv6 address and posseses related CGA Parameters structure, as well
   as the private key.  For such nodes we use terms initiator and
   responder.  CGA enabled Nodes are present both in the transport
   scenario and tunnel scenario.

   CGA enabled Security Gateway: An IPv6 enabled IPsec security gateway
   which applies tunnel mode CGA Security Policy (CGA SP), either in the
   net to net scenario or in the endpoint to net scenario.  It posseses
   CGA and related CGA Paramateres data structure.  We use mark GW_i for
   the initiator's CGA enabled Security Gateway and GW_r for the
   responder's CGA enabled Security Gateway.

   Self-evident authentication mode: It denotes the use of IPSec/IKEv2
   between previously unknown CGA enabled nodes and/or CGA enabled
   gateways.  The IKEv2 Security Association establishment in case of
   self-evident authentication mode of IPSec does not require any pre-
   arrangements nor trusted security infrastructure.

   CGA Security Policy (CGA SP): A CGA Security Policy is a Security
   Policy that specifies that traffic towards any outbound destination
   (i.e., ::0/0) SHOULD be protected by IPsec, either transport mode or
   tunnel mode (transport mode for securing end-to-end traffic between
   two nodes and tunnel mode for securing traffic between two CGA
   enabled Security Gateways, while in transit in the public internet).




















Laganier, et al.         Expires January 9, 2008                [Page 4]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


3.  Node Configuration and Requirements

   Each CGA enabled Node and CGA enabled Security Gateway MUST prove
   address ownership of its CGA.  CGA has to be generated and verified
   against CGA Parameters data structure as described in [2].  The CGA
   authentication procedure includes the following steps:

   1.  The verification of binding between the CGA and the proposed
       public key/CGA Parameters data structure.  Peer has to verify: a)
       the produced hash of the CGA Parameters data structure, b) the
       prefix of the CGA.  The lower 64 bits of the hash MUST match the
       iid of the CGA.  Also, the prefix contained in the CGA Parameters
       data structure MUST be the same as the prefix in the CGA.

   2.  The verification that the peer's private key corresponds to the
       public key from the CGA Parameters data structure.  For example,
       the responder MUST verify the challenge signed with the
       initiator's private key with the initiator's public key received
       in the CGA Parameters data structure.

   Succesfull verification denotes that the public key in the CGA
   parameters is the authentic public key used to generate CGA.  Both
   CGA enabled Nodes and CGA enabled Security Gateways use their CGA as
   IKEv2 identities.

   Thus, each CGA enabled Node and Security Gateway generate a RSA
   public (PK) - private (SK) key pair in accordance with Internet X.509
   certificate profile (rfc3280).  Usually, keys will be generated
   together with the self-signed X.509 certificate.

   The following requirements are related to tunnel mode scenarios and
   are actually open issues:

      Beside the check of the PK-CGA binding of peer GW's CGA, each CGA
      enabled Security Gateway SHOULD verify also the initiator's and
      responder's PK-CGA binding.  In that case, gateways need to
      exchange CGA Parameters related to initiator's and responder's
      CGA.  The PAD database could be used to store the initiator's/
      responder's CGA Parameters (TBD).  Those CGA Parameters could be
      exchanged in the IKE_AUTH exchange (TBD).

      Beside the address-proof-of ownership, gateways (GW_i and GW_r)
      SHOULD mutually prove themselves that they had been authorized to
      act as CGA enabled Security Gateways for the initiator's or
      responder's CGA (respectively).  This could be solved with the
      authorization certificates, eg. initiator could issue certificate
      to GW_i to allow GW_i to be its CGA enabled Security Gateway.
      However, authorization certificates SHOULD not be used for this



Laganier, et al.         Expires January 9, 2008                [Page 5]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


      purpose because of the incompliance with the IKEv2 spec and CGA
      spec.  Both specifications require use of the X.509 Certificate -
      Signature.  This issue SHOULD be rather solved with making use of
      PAD database to store additional authentication and authorization
      parameters (TBD).














































Laganier, et al.         Expires January 9, 2008                [Page 6]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


4.  Usage Scenarios

   CGA authentication within an IKEv2 exchange can be applied in several
   different usage scenarios.  The following sections describe some of
   these scenarios while emphasizing on easiness of Security Policy
   configuration.

   Self-evident authentication mode for IPSec bootstraps an IPsec
   Security Association between two previously unknown nodes.  Some
   schemes have been proposed to achieve this goal: FreeS/WAN
   Opportunistic IPsec uses the standard IKE protocol and DNS queries to
   retrieve IKE peers' public keys.  While these schemes certainly allow
   to bootstrap such an SA, we argue that it is not convenient to rely
   on upper layer infrastructure (e.g., DNS) to secure the network
   layer.  This causes cyclic dependencies that ends up in a chicken-
   and-egg problem: DNS is carried over {TCP|UDP}/IP and a related
   Security Policy should require that this traffic be protected as
   well, thus requiring Opportunistic negotiation to secure needed KEY
   RR lookups.  On the other hand, a CGA-based scheme achieves true
   independence because the security gateways can discover each other
   and verify authorization by relying solely on IP infrastructure.

   While the supported IKEv2 identites are IPv4 addresses, IPv6
   addresses, FQDN, email addresses, X.500 Distinguished Name, X.500
   General Name and vendor-specific identity, the self-evident
   authentication mode of IPSec provides the possibility to identify
   with IPv6 address or FQDN.  In case of FQDN identity, the DNBS would
   provide the binding between the FQDN and the IPv6 address and then
   the CGA would provide the binding between the IPv6 address and the
   crypto material.

   In the rest of the section, we describe the following three
   application scenarios: transport mode, tunnel mode gateway to gateway
   and tunnel mode node to gateway.

4.1.  IPsec Transport Mode with self-evident authentication

   IPSec Transport Mode with the self-evident authentication secures
   end-to-end communications between any two previously unknown CGA
   enabled Nodes and thus provides any-to-any trust relationships.  For
   instance, let's assume that initiator initially wants to send a data
   packet to responder.  Transport Mode CGA SP requires protection of
   this data packet.  As no trust relationship exists between initiator
   and responder prior to this, they needs to establish a Transport Mode
   IPsec Security Association.

   [initiator]<=i=p=s=e=c==t=r=a=n=s=p=o=r=t=>[responder]




Laganier, et al.         Expires January 9, 2008                [Page 7]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


   Bootstrapping an IPsec SA between two CGA enabled Nodes is
   straightforward: the two peers merely prove ownership of their CGA's
   while performing the IKEv2 exchange, and configure negotiated IPsec
   SA's.

   A typical Transport Mode CGA SP policy should look like that:

      INBOUND:

      ::0/0[ike] -> cga_addr/128[any] udp bypass

      ::0/0[any] -> cga_addr/128[ike] udp bypass

      ::0/0[any] -> cga_addr/128[any] any require (ipsec/ah/esp/
      transport)

      OUTBOUND:

      cga_addr/128[any] -> ::0/0[ike] udp bypass

      cga_addr/128[ike] -> ::0/0[any] udp bypass

      cga_addr/128[any] -> ::0/0[any] any require (ipsec/ah/esp/
      transport)

4.2.  IPSec Tunnel Mode with self-evident authentication

   IPSec Tunnel Mode with self-evident authentication is used to secure
   communications between two CGA enabled nodes (initiator and
   responder), while this traffic is in transit between their gateways
   (GW_i and GW_r).

   [initiator]<---[GW_i]<=i=p=s=e=c==t=u=n=n=e=l=>[GW_r]--->[responder]

   Bootstrapping a tunnel mode IPsec SA between two CGA enabled nodes is
   not as straightforward as it is for transport mode, because (1) the
   GW_r needs to be discovered by the GW_i, and (2) both GW_i and GW_r
   need to be authorized by the source and destination CGA's
   respectively of the data packet that initially triggered this
   exchange.  Thus, a Tunnel Mode CGA SP always contains an entry with
   the unspecified IPv6 address (i.e., ::0) as a placeholder for both
   tunnel endpoints (local and remote).  If we denote by NetworkPrefix/
   pflen the network prefix and associated length where initiator
   resides, a typical Tunnel Mode CGA SP should look like that on the
   interface of GW_i attached to the Internet:






Laganier, et al.         Expires January 9, 2008                [Page 8]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


      INBOUND:

      ::0/0[ike] -> GW_i/128[any] udp bypass

      ::0/0[any] -> GW_i/128[ike] udp bypass

      ::0/0[any] -> NetworkPrefix/pflen[any] any require (ipsec/ah/esp/
      tunnel=::0->::0)

      OUTBOUND:

      GW_i/128[any] -> ::0/0[ike] udp bypass

      GW_i/128[ike] -> ::0/0[any] udp bypass

      NetworkPrefix/pflen[any] -> ::0/0[any] any require (ipsec/ah/esp/
      tunnel=::0->::0)

   GW_i can discover GW_r by initiating the IKEv2 exchange towards a per
   network prefix anycast address allocated by IANA.  Others discovery
   means are also possible, for example, DNS queries to retrieve the CGA
   enabled Security Gateway associated with a given host.  Gateway's
   authorization during the IKE_AUTH exchange in case of the self-
   evident authentication mode of IPSec imply the verification of TS_i
   and TS_r payloads (initiator's and responder's CGA) against their CGA
   parameters.  Initiator's and responder's CGA parameters are stored in
   the GW_i's and GW_r PAD (respectively) and exchanged during the
   IKE_AUTH exchange in CERT payloads (TBD).

   When a packet from initiator to responder triggers an IKEv2 exchange,
   GW_i and GW_r merely prove ownership of their CGAs.  Additionally,
   they check the ownership of CGA for the initiator and responder.  In
   the same time, while GW_i and GW_r posses initiator's and responder's
   CGA Parameters (respectively) stored in their PAD, GW_i and GW_r
   prove that they are authorized to be the initiator's and responder's
   CGA enabled Security Gateway.  Following that, they negotiate and
   configure a pair of bidirectional SA's between the two gateways:

      GW_i -> GW_r spi=0x... ipsec tunnel ah/esp keys=...

      GW_i -> GW_r spi=0x... ipsec tunnel ah/esp keys=...

   And they finally add two news SPD entries specifying that subsequent
   communications between initiator and responder's CGA require IPsec
   protection:

      initiator_CGA/128[any] -> responder_CGA/128[any] any require
      (ipsec/ah/esp/tunnel=GW_i->GW_r)



Laganier, et al.         Expires January 9, 2008                [Page 9]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


      responder_CGA/128[any] -> initiator_CGA/128[any] any require
      (ipsec/ah/esp/tunnel=GW_i->GW_r)

















































Laganier, et al.         Expires January 9, 2008               [Page 10]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


5.  IKEv2 Payload usage and requirements

   A peer implementing the self-evident authentication mode of IPSec has
   to use IKEv2 payloads in a specific manner.  The following
   subsections describe usage and requirements of some of the IKEv2
   payloads while performing IKE_AUTH exchange.

5.1.  Identification Payload

   The Identification (ID) Payload of IKE contains the name of the
   entity to be authenticated with the Authentication (AUTH) Payload.
   When using CGA, the name of the node is its CGA (initiator's or
   responder's CGA in the transport mode, and GW_i's or GW_r's CGA in
   the tunnel mode).  CGA is embedded within the ID payload under the
   known IKEv2 type ID_IPV6_ADDR.  CGA enabled node or gateway MAY use
   also IKEv2 ID_FQDN type (TBD).  In that case the CGA technique is a
   natural complement of the DNSSec.

5.2.  Certificate Payload

   The name of the Certificate (CERT) payload is rather misleading and
   the CERT payload is not used to transport only certificates, but also
   different authentication material/credentials.  In case of the self-
   evident authentication mode of IPSec, the CERT payload is used to
   transmit the CGA Parameters data structure.

   Each CGA enabled Node or Security gateway wanting to prove CGA
   ownership MUST send to peer its CGA and CGA Parameters used when
   generating its CGA.  CGA Parameters data structure requires the new
   type of CERT payload.  That new type of CERT payload will trigger the
   CGA verification during the IKE_AUTH exchange.  In the tunnel mode,
   beside the CGA Parameters related to their CGA, GW_i and GW_r SHOULD
   exchange initiator's and responder's CGA Parameters (TBD).

5.3.  Certificate Request Payload

   The Certificate Request (CERTREQ) Payload is used by a peer to
   request preferred certificates to its correspondent.  A preference is
   the type of certificate requested as well as an acceptable
   certificate authority for this type.  A peer can include multiples
   preferences using several CERTREQ payload.  For CGA, certificates
   used would usually be self-signed, though this does not preclude one
   to generate its CGA using a CA-signed certificate.  The related
   CERTREQ payload MUST be set to the same type as the CERT payload.
   Thus, the same as for the CERT payload, we need the new type of the
   CERTREQ payload.





Laganier, et al.         Expires January 9, 2008               [Page 11]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


5.4.  Authentication Payload

   The Authentication (AUTH) Payload contains data used to authenticate
   the entity named in the ID payload (i.e., the CGA owner).  Since CGA
   are generated using public key cryptography, the AUTH payload has to
   contain a digital signature of the message computed using the public
   key contained in the CERT payload in the CGA Parameters data
   structure.  Currently specified digital signature algorithms includes
   RSA and DSA, but this scheme could be used with any public key
   cryptographic algorithm.

5.5.  Traffic Selector Payload

   The Traffic Selector (TS) Payload contains headers used to identify
   IP packet flows which need IPsec processing.  In the case of the
   self-evident authentication mode of IPSec, those flows will fly
   between two CGA's.  Both in the transport and tunnel mode, TS
   payloads will contain initiator's and responder's CGA.  Hence we
   require that the TS payloads used contains CGAs.  This imply that the
   TS Type is set to TS_IPV6_ADDR_RANGE.  In the transport mode, both
   the ID payload and the TS payloads contain initiator's and
   responder's CGAs.  In the tunnel mode, ID payload contains gateways'
   CGAs, while TS payloads contain initiator's and responder's CGA.
   Those CGA's from TS payloads will subsequently need to be validated
   against CGA Parameters exchanged in the CERT payload of new type.


























Laganier, et al.         Expires January 9, 2008               [Page 12]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


6.  IKE_AUTH validation

   [1] does not mandate that two peers exchanging keys use the same
   means of authenticating themselves.  Available means of
   authentication are Digital Signatures, Public Key Encryption and Pre-
   shared Secret.  It is explicitly stated that end-points are not
   required to use the same means of authenticating themselves.  One
   could use pre-shared secret, while the other could use a digital
   signature.  This note does not conflict with that, allowing one or
   both entities to prove CGA ownership, thus allowing one to possibly
   use another means of authenticating itself.

   CGA-aware IKE peers wanting to exchange traffic with CGA enabled
   Nodes (e.g. nodes or gateways) MUST verify CGA ownership.  CGA-aware
   IKEv2 implementation should thus be modified to handle CGA
   verification, which is very similar to how they currently handle
   self-signed certificates.  The implementation MUST verify that the
   public key contained in the received CGA Parameters generate the
   address used as IKEv2 identity.

6.1.  IPSec Transport Mode with self-evident authentication

   Validation of the IKE_AUTH only requires CGA-PK binding verification.
   The initial IKEv2 exchanges will be as follows:

       IKE_SA_INIT exchange:

       1. initiator -> responder:  HDR, SAi1, KEi, Ni
       2. responder -> initiator:  HDR, SAr1, KEr, Nr, CERTREQ=CGA_type

       IKE_AUTH exchange:

       3. initiator -> responder: HDR,
                                  SK {IDi=CGA_i,
                                      CERT=CGA_Parameters_i,
                                      CERTREQ=CGA_type,
                                      AUTH=dig_sig(CGA_Parameters_i_PK),
                                      SAi2,
                                      TSi=CGA_i, TSr=CGA_r}
       4. responder -> initiator: HDR,
                                  SK {IDr=CGA_r,
                                      CERT=CGA_Parameters_r,
                                      AUTH=dig_sig(CGA_Paramters_r_PK),
                                      SAr2,
                                      TSi=CGA_i, TSr=CGA_r}






Laganier, et al.         Expires January 9, 2008               [Page 13]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


6.2.  IPSec Tunnel Mode with self-evident authentication

   Tunnel mode requires the following:

      verification of binding between received gateway's CGA Parameters
      and its CGA/IKEv2 identity (MUST),

      verification of binding between received initiator's and
      responder's CGA in TS payloads (TBD),

      verification that the GW_i/GW_r is authorized to act as
      initiator's/responder's CGA gateway (TBD).

   Initial IKEv2 exchanges will be as follows (TBD):

       IKE_SA_INIT exchange:

       1. GW_i -> GW_r: HDR, SAi1, KEi, Ni
       2. GW_r -> GW_i: HDR, SAr1, KEr, Nr, CERTREQ=CGA_type

       IKE_AUTH exchange:

       3. GW_i -> GW_r: HDR, SK {IDi=CGA_GW_i,
                                 CERT=CGA_Parameters_GW_i,
                                 CERT=CGA_Parameters_i,
                                 CERTREQ=CGA_type,
                                 AUTH=dig_sig(CGA_Parameters_GW_i_PK),
                                 SAi2,
                                 TSi=CGA_i, TSr=CGA_r}
       4. GW_r -> GW_i: HDR, SK {IDr=CGA_GW_r,
                                 CERT=CGA_Parameters_GW_r,
                                 CERT=CGA_Parameters_r,
                                 AUTH=dig_sig(CGA_Paramters_GW_r_PK),
                                 SAr2,
                                 TSi=CGA_i, TSr=CGA_r}
















Laganier, et al.         Expires January 9, 2008               [Page 14]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


7.  Comparation with Better Than Nothing Security (BTNS)

   Differences between the IPSec self-evident verification mode and the
   BTNS are listed along the following lines.

   The IPSec self-evident verification mode, as a slight modification of
   the regular IKEv2, does not raise new security concerns to IPSec/
   IKEv2.  The BTNS lacks the authentication, and therefore raises some
   security concerns that are described below.

   Due to the lack of authentication, BTNS does not protect the key
   exchange itself.  Contrary to the regular IKEv2, first IKEv2 exhcange
   (IKE_SA_INIT) is not integrity protected.  This opens the possibility
   for the masquerader, MITM and DOS attacks.  An attacker can easily
   masquerade as a legitimate client and acquire a sensitive
   authentication information.  It can also establish two different
   Security Associations between endpoints and thus perform the MITM
   attack.  As described in [3] BTNS detectes mentioned attacks only
   after the session establishment, which can lead to the CPU exhaustion
   during the initial IKEv2 exchanges.

   The lack of authentication in BTNS constraints the IPSec usage only
   to services that use the anonymous access.

   While BTNS does not require the deployment of identities, the IPSec
   self-evident verification mode requires the use of either IPv6
   addresses or FQDNs as IKEv2 identities.  The reduced number of IKEv2
   identites does not constrain the IPSec deployment, if we take into
   account two assumptions: a) it is reasonable to expext that in IPv6
   (even with) adresses would be stable, b) it is also reasonable to
   expect that DNS mappings are up-to-date.




















Laganier, et al.         Expires January 9, 2008               [Page 15]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


8.  Conclusion

   This note presents an overview of how IKEv2 and CGA can be combined
   to achieve self-evident authentication mode of IPSec.  The CGA
   technique is sufficiently well understood and can use widely deployed
   and implemented mechanisms.  This proposal works in the absence of
   any previously established direct or indirect (via a broker, AAA
   roaming operator or trusted third party) security relationship.
   Because of this, these methods are a very practical and deployable
   means of using IPsec between previously unknown peers.









































Laganier, et al.         Expires January 9, 2008               [Page 16]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


9.  Security Considerations

   This document discusses possible use of IKEv2 as a means to prove CGA
   ownership and exchange keys to bootstrap IPsec SA's.  Because IKEv2
   has already been specified and this technique only slightly modifies
   it, we believe that this should not raise other security concerns
   that those incurred by CGA proof-of-ownership.  Though the
   cryptographic algorithm used are the same, CGA proof-of-ownership is
   very different in nature to authentication.  One must be especially
   careful when establishing the security policy, as this technique
   allows nodes that use their own IPv6 CGA to be successfully
   authenticated as their "owner".  This is similar in essence to IKE
   used with self-signed certificates, with the additional consideration
   that CGA binds the address to the public key.  A CGA may be
   considered as a verifiable self-generated address.

   The self-evident authentication mode of IPsec might be subject to
   Denial of Service (DoS) attacks.  There are two types of such
   attacks: fake/malicious initiator and fake/malicious destination.

   A rogue CGA enabled security gateway may attack from 'outside',
   trying to exhaust the gateway's resources by attempting to establish
   as many IPsec tunnels as it can towards machine of the protected
   network prefix.  This is done by initiating many IKEv2 exchanges.
   The fake initiator typically sends a lot of spoofed packets with
   random source addresses.  This does not cause much harm as the IKEv2
   exchange will not progress any further.  On the other hand, the
   malicious initiator sends regular packets to progress into the IKEv2
   exchange.  The process of mutual gateway's authorization (which is
   still marked as TBD) could solve this issue.





















Laganier, et al.         Expires January 9, 2008               [Page 17]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


10.  Open Issues

   This document introduce a new CERT/CERTREQ payload type (CGA
   Parameters) which, among other, triggers the CGA self-evident
   authentication mode within IPSec/IKEv2.














































Laganier, et al.         Expires January 9, 2008               [Page 18]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


11.  Intellectual Property Rights Considerations

   The IETF takes no position regarding the validity or scope of
   intellectual property or other rights that might be claimed pertain
   to the implementation or use of the technology described in this
   document or the extent to which any license under such rights might
   or might not be available; neither does it represent that it has made
   any effort to identify any such rights.  Information on the IETF's
   procedures with respect to rights in standards-track and standards-
   related documentation can be found in BCP-11.  Copies of claims of
   rights made available for publication and any assurances of licenses
   to be made available, or the result of an attempt made to obtain a
   general license or permission for the use of such proprietary rights
   by implementors or users of this specification can be obtained from
   the IETF Secretariat.

   The IETF invites any interested party to bring to its attention any
   copyrights, patents or patent applications, or other proprietary
   rights which may cover technology that may be required to practice
   this standard.  Please address the information to the IETF Executive
   Director.

   The IETF has been notified of intellectual property rights claimed in
   regard to some or all of the specification contained in this
   document.  For more information consult the online list of claimed
   rights.

























Laganier, et al.         Expires January 9, 2008               [Page 19]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


12.  References

12.1.  Normative References

   [1]  Kaufman, C., "The Internet Key Exchange version 2 (IKEv2)",
        RFC 4306, December 2005.

   [2]  Aura, T., "Cryptographically Generated Addresses (CGA)",
        RFC 3972, March 2005.

   [3]  Touch, J., Black, D., and Y. Wang, "Problem and Applicability
        Statement for Better Than Nothing Security (BTNS)",
        draft-ietf-btns-prob-and-applic-05 (work in progress),
        February 2007.

12.2.  Informative References

   [4]  Castelluccia, C., Montenegro, G., Laganier, J., and C. Neumann,
        "Hindering Eavsdropping via IPv6 Opportunistic Encryption",
        LNCS ESORICS 2004, September 2004.































Laganier, et al.         Expires January 9, 2008               [Page 20]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


Authors' Addresses

   Julien Laganier
   DoCoMo Euro-Labs
   Landsbergerstrasse 312
   D-80687 Muenchen
   Germany

   Email: julien.IETF@laposte.net


   Gabriel Montenegro
   Microsoft Corporation
   One Microsoft Way
   Redmonds, WA 98052
   USA

   Email: gabriel_montenegro_2000@yahoo.com


   Ana Kukec
   University of Zagreb
   Unska bb
   Zagreb
   Croatia

   Email: anchie@tel.fer.hr
























Laganier, et al.         Expires January 9, 2008               [Page 21]


Internet-Draft          Using IKE with IPv6 CGAs               July 2007


Full Copyright Statement

   Copyright (C) The IETF Trust (2007).

   This document is subject to the rights, licenses and restrictions
   contained in BCP 78, and except as set forth therein, the authors
   retain all their rights.

   This document and the information contained herein are provided on an
   "AS IS" basis and THE CONTRIBUTOR, THE ORGANIZATION HE/SHE REPRESENTS
   OR IS SPONSORED BY (IF ANY), THE INTERNET SOCIETY, THE IETF TRUST AND
   THE INTERNET ENGINEERING TASK FORCE DISCLAIM ALL WARRANTIES, EXPRESS
   OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF
   THE INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED
   WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.


Intellectual Property

   The IETF takes no position regarding the validity or scope of any
   Intellectual Property Rights or other rights that might be claimed to
   pertain to the implementation or use of the technology described in
   this document or the extent to which any license under such rights
   might or might not be available; nor does it represent that it has
   made any independent effort to identify any such rights.  Information
   on the procedures with respect to rights in RFC documents can be
   found in BCP 78 and BCP 79.

   Copies of IPR disclosures made to the IETF Secretariat and any
   assurances of licenses to be made available, or the result of an
   attempt made to obtain a general license or permission for the use of
   such proprietary rights by implementers or users of this
   specification can be obtained from the IETF on-line IPR repository at
   http://www.ietf.org/ipr.

   The IETF invites any interested party to bring to its attention any
   copyrights, patents or patent applications, or other proprietary
   rights that may cover technology that may be required to implement
   this standard.  Please address the information to the IETF at
   ietf-ipr@ietf.org.


Acknowledgment

   Funding for the RFC Editor function is provided by the IETF
   Administrative Support Activity (IASA).





Laganier, et al.         Expires January 9, 2008               [Page 22]