One document matched: draft-ietf-avt-srtp-not-mandatory-16.xml


<?xml version="1.0" encoding="US-ASCII"?>
<?rfc toc="yes"?>
<?rfc tocdepth="3"?>
<?rfc strict="yes"?>
<?rfc compact="yes"?>
<?rfc subcompact="no"?>
<?rfc sortrefs="yes"?>
<?rfc symrefs="yes"?>
<!DOCTYPE rfc SYSTEM "rfc2629.dtd">
<rfc category="info" docName="draft-ietf-avt-srtp-not-mandatory-16.txt"
     ipr="trust200902">
  <front>
    <title abbrev="Securing the RTP Protocol Framework">Securing the RTP
    Protocol Framework: Why RTP Does Not Mandate a Single Media Security
    Solution</title>

    <author fullname="Colin Perkins" initials="C.S." surname="Perkins">
      <organization abbrev="University of Glasgow">University of
      Glasgow</organization>

      <address>
        <postal>
          <street>School of Computing Science</street>

          <city>Glasgow</city>

          <code>G12 8QQ</code>

          <country>UK</country>
        </postal>

        <email>csp@csperkins.org</email>

        <uri>http://csperkins.org/</uri>
      </address>
    </author>

    <author fullname="Magnus Westerlund" initials="M." surname="Westerlund">
      <organization abbrev="Ericsson">Ericsson</organization>

      <address>
        <postal>
          <street>Farogatan 6</street>

          <city>Kista</city>

          <code>SE-164 80</code>

          <country>Sweden</country>
        </postal>

        <email>magnus.westerlund@ericsson.com</email>
      </address>
    </author>

    <date day="16" month="January" year="2014"/>

    <abstract>
      <t>This memo discusses the problem of securing real-time multimedia
      sessions, and explains why the Real-time Transport Protocol (RTP), and
      the associated RTP Control Protocol (RTCP), do not mandate a single
      media security mechanism. This is relevant for designers and reviewers
      of future RTP extensions, to ensure that appropriate security mechanisms
      are mandated, and that any such mechanisms are specified in a manner
      that conforms with the RTP architecture.</t>
    </abstract>
  </front>

  <middle>
    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <section anchor="intro" title="Introduction">
      <t>The Real-time Transport Protocol (RTP) <xref target="RFC3550"/> is
      widely used for voice over IP, Internet television, video conferencing,
      and other real-time and streaming media applications. Despite this use,
      the basic RTP specification provides only limited options for media
      security, and defines no standard key exchange mechanism. Rather, a
      number of extensions are defined that can provide confidentiality and
      authentication of RTP media streams and RTP Control Protocol (RTCP)
      messages. Other mechanisms define key exchange protocols. This memo
      outlines why it is appropriate that multiple extension mechanisms are
      defined rather than mandating a single security and keying mechanism for
      all users of RTP.</t>

      <t>The IETF policy on Strong Security Requirements for IETF Standard
      Protocols <xref target="RFC3365"/> (the so-called "Danvers Doctrine")
      states that "we MUST implement strong security in all protocols to
      provide for the all too frequent day when the protocol comes into
      widespread use in the global Internet". The security mechanisms defined
      for use with RTP allow these requirements to be met. However, since RTP
      is a protocol framework that is suitable for a wide variety of use
      cases, there is no single security mechanism that is suitable for every
      scenario. This memo outlines why this is the case, and discusses how
      users of RTP can meet the requirement for strong security.</t>

      <t>This document provides high level guidance on how to handle security
      issues for the various type of components within the RTP framework as
      well as the role of the service or application using RTP to ensure
      strong security is implemented. This document does not provide the
      guidance that an individual implementer, or even specifier of a RTP
      application, really can use to determine what security mechanism they
      need to use; that is not intended with this document.</t>

      <t>A non-exhaustive list of the RTP security options available at the
      time of this writing is outlined in <xref
      target="I-D.ietf-avtcore-rtp-security-options"/>. This document gives an
      overview of the available RTP solutions, and provides guidance on their
      applicability for different application domains. It also attempts to
      provide indication of actual and intended usage at time of writing as
      additional input to help with considerations such as interoperability,
      availability of implementations etc.</t>
    </section>

    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <section anchor="scenarios"
             title="RTP Applications and Deployment Scenarios">
      <t>The range of application and deployment scenarios where RTP has been
      used includes, but is not limited to, the following: <list
          style="symbols">
          <t>Point-to-point voice telephony;</t>

          <t>Point-to-point video conferencing and telepresence;</t>

          <t>Centralised group video conferencing and telepresence, using a
          Multipoint Conference Unit (MCU) or similar central middlebox;</t>

          <t>Any Source Multicast (ASM) video conferencing using the
          light-weight sessions model (e.g., the Mbone conferencing
          tools);</t>

          <t>Point-to-point streaming audio and/or video (e.g., on-demand TV
          or movie streaming);</t>

          <t>Source-Specific Multicast (SSM) streaming to large receiver
          groups (e.g., IPTV streaming by residential ISPs, or the 3GPP
          Multimedia Broadcast Multicast Service <xref target="MBMS"/>);</t>

          <t>Replicated unicast streaming to a group of receivers;</t>

          <t>Interconnecting components in music production studios and video
          editing suites;</t>

          <t>Interconnecting components of distributed simulation systems;
          and</t>

          <t>Streaming real-time sensor data (e.g., e-VLBI radio
          astronomy).</t>
        </list> As can be seen, these scenarios vary from point-to-point
      sessions to very large multicast groups, from interactive to
      non-interactive, and from low bandwidth (kilobits per second) telephony
      to high bandwidth (multiple gigabits per second) video and data
      streaming. While most of these applications run over UDP <xref
      target="RFC0768"/>, some use TCP <xref target="RFC0793"/>, <xref
      target="RFC4614"/> or DCCP <xref target="RFC4340"/> as their underlying
      transport. Some run on highly reliable optical networks, others use low
      rate unreliable wireless networks. Some applications of RTP operate
      entirely within a single trust domain, others run inter-domain, with
      untrusted (and, in some cases, potentially unknown) users. The range of
      scenarios is wide, and growing both in number and in heterogeneity.</t>
    </section>

    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <section anchor="media-sec" title="RTP Media Security">
      <t>The wide range of application scenarios where RTP is used has led to
      the development of multiple solutions for securing RTP media streams and
      RTCP control messages, considering different requirements.</t>

      <t>Perhaps the most widely applicable of these security options is the
      <xref target="RFC3711">Secure RTP (SRTP) framework</xref>. This is an
      application-level media security solution, encrypting the media payload
      data (but not the RTP headers) to provide confidentiality, and
      supporting source origin authentication as an option. SRTP was carefully
      designed to be low overhead, including operating on links subject to RTP
      header compression, and to support the group communication and
      third-party performance monitoring features of RTP, across a range of
      networks.</t>

      <t>SRTP is not the only media security solution for RTP, however, and
      alternatives can be more appropriate in some scenarios, perhaps due to
      ease of integration with other parts of the complete system. In
      addition, SRTP does not address all possible security requirements, and
      other solutions are needed in cases where SRTP is not suitable. For
      example, ISMAcryp payload-level confidentiality <xref
      target="ISMACrypt2"/> is appropriate for some types of streaming video
      application, but is not suitable for voice telephony, and uses features
      that are not provided by SRTP.</t>

      <t>The range of available RTP security options, and their applicability
      to different scenarios, is outlined in <xref
      target="I-D.ietf-avtcore-rtp-security-options"/>. At the time of this
      writing, there is no media security protocol that is appropriate for all
      the environments where RTP is used. Multiple RTP media security
      protocols are expected to remain in wide use for the foreseeable
      future.</t>
    </section>

    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <section anchor="media-key"
             title="RTP Session Establishment and Key Management">
      <t>A range of different protocols for RTP session establishment and key
      exchange exist, matching the diverse range of use cases for the RTP
      framework. These mechanisms can be split into two categories: those that
      operate in-band on the media path, and those that are out-of-band and
      operate as part of the session establishment signalling channel. The
      requirements for these two classes of solution are different, and a wide
      range of solutions have been developed in this space.</t>

      <t>A more detailed survey of requirements for media security management
      protocols can be found in <xref target="RFC5479"/>. As can be seen from
      that memo, the range of use cases is wide, and there is no single key
      management protocol that is appropriate for all scenarios. The solutions
      have been further diversified by the existence of infrastructure
      elements, such as authentication systems, that are tied to the key
      management. The most important and widely used keying options for RTP
      sessions at the time of this writing are described in <xref
      target="I-D.ietf-avtcore-rtp-security-options"/>.</t>
    </section>

    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <section anchor="fw"
             title="On the Requirement for Strong Security in Framework protocols">
      <t>The IETF requires that all protocols provide a strong, mandatory to
      implement, security solution <xref target="RFC3365"/>. This is essential
      for the overall security of the Internet, to ensure that all
      implementations of a protocol can interoperate in a secure way.
      Framework protocols offer a challenge for this mandate, however, since
      they are designed to be used by different classes of applications, in a
      wide range of different environments. The different use cases for the
      framework have different security requirements, and implementations
      designed for different environments are generally not expected to
      interwork.</t>

      <t>RTP is an example of a framework protocol with wide applicability.
      The wide range of scenarios described in <xref target="scenarios"/> show
      the issues that arise in mandating a single security mechanism for this
      type of framework. It would be desirable if a single media security
      solution, and a single key management solution, could be developed,
      suitable for applications across this range of use scenarios. The
      authors are not aware of any such solution, however, and believe it is
      unlikely that any such solution will be developed. In part, this is
      because applications in the different domains are not intended to
      interwork, so there is no incentive to develop a single mechanism. More
      importantly, though, the security requirements for the different usage
      scenarios vary widely, and an appropriate security mechanism in one
      scenario simply does not work for some other scenarios.</t>

      <t> For a framework protocol, it appears that the only sensible solution
      to the strong security requirement of <xref target="RFC3365"/> is to
      develop and use building blocks for the basic security services of
      confidentiality, integrity protection, authorisation, authentication,
      and so on. When new uses for the framework protocol arise, they need to
      be studied to determine if the existing security building blocks can
      satisfy the requirements, or if new building blocks need to be
      developed. </t>

      <t>Therefore, when considering the strong and mandatory to implement
      security mechanism for a specific class of applications, one has to
      consider what security building blocks need to be integrated, or if any
      new mechanisms need to be defined to address specific issues relating to
      this new class of application. To maximize interoperability it is
      important that common media security and key management mechanisms are
      defined for classes of application with similar requirements. The IETF
      needs to participate in this selection of security building blocks for
      each class of applications that use the protocol framework and are
      expected to interoperate, in cases where the IETF has the appropriate
      knowledge of the class of applications.</t>
    </section>

    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <section title="Securing the RTP Protocol Framework">
      <t>The IETF requires that protocols specify mandatory to implement (MTI)
      strong security <xref target="RFC3365"/>. This applies to the
      specification of each interoperable class of application that makes use
      of RTP. However, RTP is a framework protocol, so the arguments made in
      <xref target="fw"/> also apply. Given the variability of the classes of
      application that use RTP, and the variety of the currently available
      security mechanisms described in <xref
      target="I-D.ietf-avtcore-rtp-security-options"/>, no one set of MTI
      security options can realistically be specified that apply to all
      classes of RTP applications.</t>

      <t>Documents that define an interoperable class of applications using
      RTP are subject to <xref target="RFC3365"/>, and so need to specify MTI
      security mechanisms. This is because such specifications do fully
      specify interoperable applications that use RTP. Examples of such
      documents under development in the IETF at the time of this writing are
      the <xref target="I-D.ietf-rtcweb-security-arch">RTCWEB Security
      Architecture</xref> and the <xref target="I-D.ietf-mmusic-rfc2326bis">
      Real Time Streaming Protocol 2.0 (RTSP)</xref>. It is also expected that
      a similar document will be produced for voice-over-IP applications using
      SIP and RTP.</t>

      <t>The RTP framework includes several extension points. Some extensions
      can significantly change the behaviour of the protocol, to the extent
      that applications using the extension form a separate interoperable
      class of applications to those that have not been extended. Other
      extension points are defined in such a manner that they can be used
      (largely) independently of the class of applications using RTP. Two
      important extension points that are independent of the class of
      applications are RTP Payload Formats and RTP Profiles.</t>

      <t>An RTP Payload Format defines how the output of a media codec can be
      used with RTP. At the time of this writing, there are over 70 RTP
      Payload Formats defined in published RFCs, with more in development. It
      is appropriate for an RTP Payload Format to discuss the specific
      security implications of using that media codec with RTP. However, an
      RTP Payload Format does not specify an interoperable class of
      applications that use RTP since, in the vast majority of cases, a media
      codec and its associated RTP Payload Format can be used with many
      different classes of application. As such, an RTP Payload Format is
      neither secure in itself, nor something to which <xref
      target="RFC3365"/> applies. Future RTP Payload Format specifications
      need to explicitly state this, and include a reference to this memo for
      explanation. It is not appropriate for an RTP Payload Format to mandate
      the use of SRTP <xref target="RFC3711"/>, or any other security building
      blocks, since that RTP Payload Format might be used by different classes
      of application that use RTP, and that have different security
      requirements.</t>

      <t>RTP Profiles are larger extensions that adapt the RTP framework for
      use with particular classes of application. In some cases, those classes
      of application might share common security requirements so that it could
      make sense for an RTP Profile to mandate particular security options and
      building blocks (the RTP/SAVP profile <xref target="RFC3711"/> is an
      example of this type of RTP Profile). In other cases, though, an RTP
      profile is applicable to such a wide range of applications that it would
      not make sense for that profile to mandate particular security building
      blocks be used (the RTP/AVPF profile <xref target="RFC4585"/> is an
      example of this type of RTP Profile, since it provides building blocks
      that can be used in different styles of application). A new RTP Profile
      specification needs to discuss whether, or not, it makes sense to
      mandate particular security building blocks that need to be used with
      all implementations of that profile; however, there is no expectation
      that all RTP Profiles will mandate particular security solutions. RTP
      Profiles that do not specify an interoperable usage for a particular
      class of RTP applications are neither secure in themselves, nor
      something to which <xref target="RFC3365"/> applies; any future RTP
      Profiles in this category need to explicitly state this with
      justification, and include a reference to this memo.</t>
    </section>

    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <section anchor="conclusions" title="Conclusions">
      <t>The RTP framework is used in a wide range of different scenarios,
      with no common security requirements. Accordingly, neither SRTP <xref
      target="RFC3711"/>, nor any other single media security solution or
      keying mechanism, can be mandated for all uses of RTP. In the absence of
      a single common security solution, it is important to consider what
      mechanisms can be used to provide strong and interoperable security for
      each different scenario where RTP applications are used. This will
      require analysis of each class of application to determine the security
      requirements for the scenarios in which they are to be used, followed by
      the selection of a mandatory to implement security building blocks for
      that class of application, including the desired RTP traffic protection
      and key-management. A non-exhaustive list of the RTP security options
      available at the time of this writing is outlined in <xref
      target="I-D.ietf-avtcore-rtp-security-options"/>. It is expected that
      each class of application will be supported by a memo describing what
      security options are mandatory to implement for that usage scenario.</t>
    </section>

    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <section anchor="security" title="Security Considerations">
      <t>This entire memo is about mandatory to implement security.</t>
    </section>

    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <section anchor="iana" title="IANA Considerations">
      <t>None.</t>
    </section>

    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <section title="Acknowledgements">
      <t>Thanks to Ralph Blom, Hannes Tschofenig, Dan York, Alfred Hoenes,
      Martin Ellis, Ali Begen, Keith Drage, Ray van Brandenburg, Stephen
      Farrell, Sean Turner, John Mattsson, and Benoit Claise for their
      feedback.</t>
    </section>
  </middle>

  <back>
    <!-- +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->

    <references title="Informative References">
      <?rfc include="reference.RFC.0768"?>

      <?rfc include="reference.RFC.0793"?>

      <?rfc include="reference.RFC.3365"?>

      <?rfc include="reference.RFC.3550"?>

      <?rfc include="reference.RFC.3711"?>

      <?rfc include="reference.RFC.4340"?>

      <?rfc include="reference.RFC.4585"?>

      <?rfc include="reference.RFC.4614"?>

      <?rfc include="reference.RFC.5479"?>

      <?rfc include="reference.I-D.ietf-avtcore-rtp-security-options"?>

      <?rfc include="reference.I-D.ietf-rtcweb-security-arch"?>

      <?rfc include='reference.I-D.ietf-mmusic-rfc2326bis'?>

      <reference anchor="MBMS">
        <front>
          <title>Multimedia Broadcast/Multicast Service (MBMS); Protocols and
          codecs TS 26.346</title>

          <author surname="3GPP">
            <organization/>
          </author>

          <date/>
        </front>
      </reference>

      <reference anchor="ISMACrypt2">
        <front>
          <title>ISMA Encryption and Authentication, Version 2.0 release
          version</title>

          <author surname="Internet Streaming Media Alliance (ISMA)">
            <organization/>
          </author>

          <date month="November" year="2007"/>
        </front>

        <format target="http://www.mpegif.org/m4if/bod/ISMA/ISMA_E%26Aspec2.0.pdf"
                type="PDF"/>
      </reference>
    </references>
  </back>
</rfc>

PAFTECH AB 2003-20262026-04-23 05:36:40