Internet Engineering Task Force (IETF)                   P. Wouters, Ed.
Request for Comments: 9395                                         Aiven
Updates: 8221, 8247                                           April 2023
Category: Standards Track
ISSN: 2070-1721

Deprecation of the Internet Key Exchange Protocol Version 1 (IKEv1) Protocol and
                          Obsoleted Algorithms

Abstract

   Internet Key Exchange Version 1 (IKEv1) has been deprecated, and RFCs
   2407, 2408, and 2409 have been moved to Historic status.  This
   document updates RFCs 8221 and 8247 to reflect the usage guidelines
   of old algorithms that are associated with IKEv1 and are not
   specified or commonly implemented for IKEv2.  This document further
   updates the IANA registries for IKEv2 "Transform Type Values" by
   adding a "Status" column where the deprecation status can be listed.

Status of This Memo

   This is an Internet Standards Track document.

   This document is a product of the Internet Engineering Task Force
   (IETF).  It represents the consensus of the IETF community.  It has
   received public review and has been approved for publication by the
   Internet Engineering Steering Group (IESG).  Further information on
   Internet Standards is available in Section 2 of RFC 7841.

   Information about the current status of this document, any errata,
   and how to provide feedback on it may be obtained at
   https://www.rfc-editor.org/info/rfc9395.

Copyright Notice

   Copyright (c) 2023 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
   (https://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 Revised BSD License text as described in Section 4.e of the
   Trust Legal Provisions and are provided without warranty as described
   in the Revised BSD License.

Table of Contents

   1.  Introduction
   2.  Requirements Language
   3.  RFCs 2407, 2408, and 2409 Are Historic
   4.  IKEv1 Feature Equivalents for IKEv2
     4.1.  IKEv2 Post-Quantum Support
     4.2.  IKEv2 Labeled IPsec Support
     4.3.  IKEv2 Group SA and Multicast Support
   5.  Deprecating Obsolete Algorithms
   6.  Security Considerations
   7.  IANA Considerations
   8.  References
     8.1.  Normative References
     8.2.  Informative References
   Author's Address

1.  Introduction

   IKEv1 has been moved to Historic status.  IKEv1 [RFC2409] and its
   related documents for the Internet Security Association and Key
   Management Protocol (ISAKMP) [RFC2408] and IPsec DOI [RFC2407] were
   obsoleted by IKEv2 [RFC4306] in December 2005.  The latest version of
   IKEv2 at the time of writing was published in 2014 [RFC7296].  Since
   IKEv2 replaced IKEv1 over 15 years ago, IKEv2 has now seen wide
   deployment, and it provides a full replacement for all IKEv1
   functionality.  No new modifications or new algorithms have been
   accepted for IKEv1 for at least a decade.  IKEv2 addresses various
   issues present in IKEv1, such as IKEv1 being vulnerable to
   amplification attacks.

   Algorithm implementation requirements and usage guidelines for IKEv2
   [RFC8247] and Encapsulating Security Payload (ESP) and Authentication
   Header (AH) [RFC8221] gives guidance to implementors but limits that
   guidance to avoid broken or weak algorithms.  These two RFCs do not
   deprecate algorithms that have aged and are not in use.  Instead,
   they leave these algorithms in a state of "MAY be used" by not
   mentioning them.  This document deprecates those unmentioned
   algorithms that are no longer advised but for which there are no
   known attacks resulting in their earlier deprecation.

2.  Requirements Language

   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
   "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and
   "OPTIONAL" in this document are to be interpreted as described in
   BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all
   capitals, as shown here.

3.  RFCs 2407, 2408, and 2409 Are Historic

   As IKEv1 is deprecated, systems running IKEv1 should be upgraded and
   reconfigured to run IKEv2.  Systems that support IKEv1 but not IKEv2
   are most likely also unsuitable candidates for continued operation
   for the following reasons:

   *  IKEv1 development ceased over a decade ago, and no new work will
      happen.  This poses the risk of unmaintained code in an otherwise
      supported product, which can result in security vulnerabilities.

   *  A number of IKEv1 systems have reached their End of Life and,
      therefore, will never be patched by the vendor if a vulnerability
      is found.

   *  There are vendors that still provide updates for their equipment
      that supports IKEv1 and IKEv2 but have "frozen" their IKEv1
      implementation.  Such users might not be aware that they are
      running unmaintained code with its associated security risks.

   *  IKEv1 systems can be abused for packet amplification attacks, as
      documented in the Security Bulletin [CVE-2016-5361].

   *  Great strides have been made in cryptography since IKEv1
      development ceased.  While some modern cryptographic algorithms
      were added to IKEv1, interoperability concerns mean that the
      defacto algorithms negotiated by IKEv1 will consist of dated or
      deprecated algorithms, like AES-CBC, SHA1, and Diffie-Hellman
      groups 1 or 2.  IKEv2 provides a state-of-the-art suite of
      cryptographic algorithms that IKEv1 lacks.

   IKEv2 is a more secure protocol than IKEv1.  For example, IKEv2
   offers more modern cryptographic primitives, proper defense against
   denial-of-service attacks, improved authentication via Extensible
   Authentication Protocol (EAP) methods, and password-authenticated key
   exchange (PAKE) support.  Also, IKEv2 is actively worked on with
   respect to defending against quantum-computer attacks.

   IKEv1-only systems should be upgraded or replaced by systems
   supporting IKEv2.  IKEv2 implementations SHOULD NOT directly import
   IKEv1 configurations without updating the cryptographic algorithms
   used.

4.  IKEv1 Feature Equivalents for IKEv2

   A few notable IKEv1 features are not present in the IKEv2 core
   specification [RFC7296] but are available for IKEv2 via an additional
   specification.

4.1.  IKEv2 Post-Quantum Support

   IKEv1 and its way of using Preshared Keys (PSKs) protects against
   quantum-computer-based attacks.  IKEv2 updated its use of PSKs to
   improve the error reporting but at the expense of post-quantum
   security.  If post-quantum security is required, these systems should
   be migrated to use IKEv2 Post-quantum Preshared Keys (PPKs)
   [RFC8784].

4.2.  IKEv2 Labeled IPsec Support

   Some IKEv1 implementations support Labeled IPsec, a method to
   negotiate an additional Security Context selector to the Security
   Policy Database (SPD), but this method was never standardized in
   IKEv1.  Those IKEv1 systems that require Labeled IPsec should migrate
   to an IKEv2 system supporting Labeled IPsec as specified in
   [LABELED-IPSEC].

4.3.  IKEv2 Group SA and Multicast Support

   The Group Domain of Interpretation (GDOI) protocol [RFC6407], which
   is based on IKEv1, defines the support for Multicast Group SAs.  For
   IKEv2, this work is currently in progress via [G-IKEV2].

5.  Deprecating Obsolete Algorithms

   This document deprecates the following algorithms:

   *  Encryption Algorithms: RC5, IDEA, CAST, Blowfish, and the
      unspecified 3IDEA, ENCR_DES_IV64, and ENCR_DES_IV32

   *  PRF Algorithms: the unspecified PRF_HMAC_TIGER

   *  Integrity Algorithms: HMAC-MD5-128

   *  Diffie-Hellman groups: none

6.  Security Considerations

   There are only security benefits if IKEv1 is deprecated and IKEv2 is
   used.

   The deprecated algorithms have long been in disuse and are no longer
   actively deployed or researched; this presents an unknown security
   risk that is best avoided.  Additionally, these algorithms not being
   supported in implementations simplifies those implementations and
   reduces the accidental use of deprecated algorithms through
   misconfiguration or downgrade attacks.

7.  IANA Considerations

   IANA has added the following line at the top of the Notes section of
   the "Internet Key Exchange (IKE) Attributes" and '"Magic Numbers" for
   ISAKMP Protocol' registries: "All registries listed below have been
   closed.  See RFC 9395."  In addition, this document has been added to
   the "Reference" column in these two registries, and their
   registration procedures have been changed to "Registry closed".

   IANA has added a "Status" column to the following IKEv2 "Transform
   Type Values" registries:

      Transform Type 1 - Encryption Algorithm Transform IDs
      Transform Type 2 - Pseudorandom Function Transform IDs
      Transform Type 3 - Integrity Algorithm Transform IDs
      Transform Type 4 - Key Exchange Method Transform IDs

   Also, the following entries have been marked as DEPRECATED:

            +========+===============+=======================+
            | Number | Name          | Status                |
            +========+===============+=======================+
            | 1      | ENCR_DES_IV64 | DEPRECATED (RFC 9395) |
            +--------+---------------+-----------------------+
            | 2      | ENCR_DES      | DEPRECATED [RFC8247]  |
            +--------+---------------+-----------------------+
            | 4      | ENCR_RC5      | DEPRECATED (RFC 9395) |
            +--------+---------------+-----------------------+
            | 5      | ENCR_IDEA     | DEPRECATED (RFC 9395) |
            +--------+---------------+-----------------------+
            | 6      | ENCR_CAST     | DEPRECATED (RFC 9395) |
            +--------+---------------+-----------------------+
            | 7      | ENCR_BLOWFISH | DEPRECATED (RFC 9395) |
            +--------+---------------+-----------------------+
            | 8      | ENCR_3IDEA    | DEPRECATED (RFC 9395) |
            +--------+---------------+-----------------------+
            | 9      | ENCR_DES_IV32 | DEPRECATED (RFC 9395) |
            +--------+---------------+-----------------------+

                  Table 1: Transform Type 1 - Encryption
                         Algorithm Transform IDs

            +========+================+=======================+
            | Number | Name           | Status                |
            +========+================+=======================+
            | 1      | PRF_HMAC_MD5   | DEPRECATED [RFC8247]  |
            +--------+----------------+-----------------------+
            | 3      | PRF_HMAC_TIGER | DEPRECATED (RFC 9395) |
            +--------+----------------+-----------------------+

                  Table 2: Transform Type 2 - Pseudorandom
                           Function Transform IDs

          +========+====================+=======================+
          | Number | Name               | Status                |
          +========+====================+=======================+
          | 1      | AUTH_HMAC_MD5_96   | DEPRECATED [RFC8247]  |
          +--------+--------------------+-----------------------+
          | 3      | AUTH_DES_MAC       | DEPRECATED [RFC8247]  |
          +--------+--------------------+-----------------------+
          | 4      | AUTH_KPDK_MD5      | DEPRECATED [RFC8247]  |
          +--------+--------------------+-----------------------+
          | 6      | AUTH_HMAC_MD5_128  | DEPRECATED (RFC 9395) |
          +--------+--------------------+-----------------------+
          | 7      | AUTH_HMAC_SHA1_160 | DEPRECATED (RFC 9395) |
          +--------+--------------------+-----------------------+

              Table 3: Transform Type 3 - Integrity Algorithm
                               Transform IDs

     +========+==============================+======================+
     | Number | Name                         | Status               |
     +========+==============================+======================+
     | 1      | 768-bit MODP Group           | DEPRECATED [RFC8247] |
     +--------+------------------------------+----------------------+
     | 22     | 1024-bit MODP Group with     | DEPRECATED [RFC8247] |
     |        | 160-bit Prime Order Subgroup |                      |
     +--------+------------------------------+----------------------+

      Table 4: Transform Type 4 - Key Exchange Method Transform IDs

   All entries not mentioned here should receive no value in the new
   Status field.

8.  References

8.1.  Normative References

   [RFC2119]  Bradner, S., "Key words for use in RFCs to Indicate
              Requirement Levels", BCP 14, RFC 2119,
              DOI 10.17487/RFC2119, March 1997,
              <https://www.rfc-editor.org/info/rfc2119>.

   [RFC8174]  Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC
              2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174,
              May 2017, <https://www.rfc-editor.org/info/rfc8174>.

   [RFC8247]  Nir, Y., Kivinen, T., Wouters, P., and D. Migault,
              "Algorithm Implementation Requirements and Usage Guidance
              for the Internet Key Exchange Protocol Version 2 (IKEv2)",
              RFC 8247, DOI 10.17487/RFC8247, September 2017,
              <https://www.rfc-editor.org/info/rfc8247>.

8.2.  Informative References

   [CVE-2016-5361]
              NIST National Vulnerability Database, "CVE-2016-5361
              Detail", 16 June 2016,
              <https://nvd.nist.gov/vuln/detail/CVE-2016-5361>.

   [G-IKEV2]  Smyslov, V. and B. Weis, "Group Key Management using
              IKEv2", Work in Progress, Internet-Draft, draft-ietf-
              ipsecme-g-ikev2-09, 19 April 2023,
              <https://datatracker.ietf.org/doc/html/draft-ietf-ipsecme-
              g-ikev2-09>.

   [LABELED-IPSEC]
              Wouters, P. and S. Prasad, "Labeled IPsec Traffic Selector
              support for IKEv2", Work in Progress, Internet-Draft,
              draft-ietf-ipsecme-labeled-ipsec-11, 10 April 2023,
              <https://datatracker.ietf.org/doc/html/draft-ietf-ipsecme-
              labeled-ipsec-11>.

   [RFC2407]  Piper, D., "The Internet IP Security Domain of
              Interpretation for ISAKMP", RFC 2407,
              DOI 10.17487/RFC2407, November 1998,
              <https://www.rfc-editor.org/info/rfc2407>.

   [RFC2408]  Maughan, D., Schertler, M., Schneider, M., and J. Turner,
              "Internet Security Association and Key Management Protocol
              (ISAKMP)", RFC 2408, DOI 10.17487/RFC2408, November 1998,
              <https://www.rfc-editor.org/info/rfc2408>.

   [RFC2409]  Harkins, D. and D. Carrel, "The Internet Key Exchange
              (IKE)", RFC 2409, DOI 10.17487/RFC2409, November 1998,
              <https://www.rfc-editor.org/info/rfc2409>.

   [RFC4306]  Kaufman, C., Ed., "Internet Key Exchange (IKEv2)
              Protocol", RFC 4306, DOI 10.17487/RFC4306, December 2005,
              <https://www.rfc-editor.org/info/rfc4306>.

   [RFC6407]  Weis, B., Rowles, S., and T. Hardjono, "The Group Domain
              of Interpretation", RFC 6407, DOI 10.17487/RFC6407,
              October 2011, <https://www.rfc-editor.org/info/rfc6407>.

   [RFC7296]  Kaufman, C., Hoffman, P., Nir, Y., Eronen, P., and T.
              Kivinen, "Internet Key Exchange Protocol Version 2
              (IKEv2)", STD 79, RFC 7296, DOI 10.17487/RFC7296, October
              2014, <https://www.rfc-editor.org/info/rfc7296>.

   [RFC8221]  Wouters, P., Migault, D., Mattsson, J., Nir, Y., and T.
              Kivinen, "Cryptographic Algorithm Implementation
              Requirements and Usage Guidance for Encapsulating Security
              Payload (ESP) and Authentication Header (AH)", RFC 8221,
              DOI 10.17487/RFC8221, October 2017,
              <https://www.rfc-editor.org/info/rfc8221>.

   [RFC8784]  Fluhrer, S., Kampanakis, P., McGrew, D., and V. Smyslov,
              "Mixing Preshared Keys in the Internet Key Exchange
              Protocol Version 2 (IKEv2) for Post-quantum Security",
              RFC 8784, DOI 10.17487/RFC8784, June 2020,
              <https://www.rfc-editor.org/info/rfc8784>.

Author's Address

   Paul Wouters (editor)
   Aiven
   Email: paul.wouters@aiven.io