AVTCore

Internet Engineering Task Force (IETF)                      G. Hellstrom
Internet-Draft                 Gunnar Hellstrom Accessible Communication Hellström
Request for Comments: 9071                                      GHAccess
Updates: 4103 (if approved)                                  26 May                                                  June 2021
Intended status:
Category: Standards Track
Expires: 27 November 2021

           RTP-mixer formatting
ISSN: 2070-1721

           RTP-Mixer Formatting of multiparty Real-time text
               draft-ietf-avtcore-multi-party-rtt-mix-20 Multiparty Real-Time Text

Abstract

   This document provides enhancements for RFC 4103 of real-time text
   mixing (as specified
   in RFC 4103) suitable for mixing in a centralized conference model that enables model,
   enabling source identification and rapidly interleaved transmission
   of text from different sources.  The intended use is for real-time
   text mixers and participant endpoints capable of providing an
   efficient presentation or other treatment of a multiparty real-time
   text session.  The specified mechanism builds on the standard use of
   the Contributing Source (CSRC) list in the Realtime Real-time Transport
   Protocol (RTP) packet for source identification.  The method makes
   use of the same "text/
   t140" "text/t140" and "text/red" formats as for two-party
   sessions.

   Solutions using multiple RTP streams in the same RTP session are
   briefly mentioned, as they could have some benefits over the RTP-
   mixer model.  The possibility RTP-mixer model was selected to implement be used for the
   fully specified solution in this document because it can be applied
   to a wide range of existing RTP implementations made the RTP-mixer model be
   selected to be fully specified in this document. implementations.

   A capability exchange is specified so that it can be verified that a
   mixer and a participant can handle the multiparty-coded real-time
   text stream using the RTP-mixer method.  The capability is indicated
   by the use of an RFC 8866 a Session Description Protocol (SDP) (RFC 8866) media
   attribute
   attribute, "rtt-mixer".

   The

   This document updates RFC 4103 "RTP ("RTP Payload for Text Conversation". Conversation").

   A specification of for how a mixer can format text for the case when the
   endpoint is not multiparty-aware multiparty aware is also provided.

Status of This Memo

   This Internet-Draft is submitted in full conformance with the
   provisions of BCP 78 and BCP 79.

   Internet-Drafts are working documents an Internet Standards Track document.

   This document is a product of the Internet Engineering Task Force
   (IETF).  Note that other groups may also distribute
   working documents as Internet-Drafts.  The list  It represents the consensus of current Internet-
   Drafts is at https://datatracker.ietf.org/drafts/current/.

   Internet-Drafts are draft documents valid the IETF community.  It has
   received public review and has been approved for a maximum publication by the
   Internet Engineering Steering Group (IESG).  Further information on
   Internet Standards is available in Section 2 of six months RFC 7841.

   Information about the current status of this document, any errata,
   and how to provide feedback on it may be updated, replaced, or obsoleted by other documents obtained at any
   time.  It is inappropriate to use Internet-Drafts as reference
   material or to cite them other than as "work in progress."

   This Internet-Draft will expire on 27 November 2021.
   https://www.rfc-editor.org/info/rfc9071.

Copyright Notice

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

Table of Contents

   1.  Introduction  . . . . . . . . . . . . . . . . . . . . . . . .   4
     1.1.  Terminology . . . . . . . . . . . . . . . . . . . . . . .   6
     1.2.  Selected solution  Main Method, Fallback Method, and considered alternatives . . . . . .   7 Considered Alternatives
     1.3.  Intended application  . . . . . . . . . . . . . . . . . .   9 Application
   2.  Overview of the two specified solutions Two Specified Solutions and selection Selection of
           method  . . . . . . . . . . . . . . . . . . . . . . . . .  10 Method
     2.1.  The RTP-mixer-based solution RTP-Mixer-Based Solution for multiparty-aware
           endpoints . . . . . . . . . . . . . . . . . . . . . . . .  10 Multiparty-Aware Endpoints
     2.2.  Mixing for multiparty-unaware endpoints . . . . . . . . .  11 Multiparty-Unaware Endpoints
     2.3.  Offer/answer considerations . . . . . . . . . . . . . . .  11  Offer/Answer Considerations
     2.4.  Actions depending Depending on capability negotiation result  . . .  13 Capability Negotiation Result
   3.  Details for the RTP-mixer-based mixing method RTP-Mixer-Based Mixing Method for
           multiparty-aware endpoints  . . . . . . . . . . . . . . .  13
           Multiparty-Aware Endpoints
     3.1.  Use of fields Fields in the RTP packets  . . . . . . . . . . . .  13 Packets
     3.2.  Initial transmission Transmission of a BOM character . . . . . . . . .  14 Character
     3.3.  Keep-alive  . . . . . . . . . . . . . . . . . . . . . . .  14  Keep-Alive
     3.4.  Transmission interval . . . . . . . . . . . . . . . . . .  14 Interval
     3.5.  Only one source One Source per packet  . . . . . . . . . . . . . . .  15 Packet
     3.6.  Do not send received text Not Send Received Text to the originating source . . .  15 Originating Source
     3.7.  Clean incoming text . . . . . . . . . . . . . . . . . . .  16 Incoming Text
     3.8.  Principles of Redundant transmission principles . . . . . . . . . . . .  16 Transmission
     3.9.  Text placement Placement in packets . . . . . . . . . . . . . . . .  16 Packets
     3.10. Empty T140blocks  . . . . . . . . . . . . . . . . . . . .  17
     3.11. Creation of the redundancy  . . . . . . . . . . . . . . .  17 Redundancy
     3.12. Timer offset fields . . . . . . . . . . . . . . . . . . .  18 Offset Fields
     3.13. Other RTP header fields . . . . . . . . . . . . . . . . .  18 Header Fields
     3.14. Pause in transmission . . . . . . . . . . . . . . . . . .  18 Transmission
     3.15. RTCP considerations . . . . . . . . . . . . . . . . . . .  19 Considerations
     3.16. Reception of multiparty contents  . . . . . . . . . . . .  19 Multiparty Contents
     3.17. Performance considerations  . . . . . . . . . . . . . . .  21 Considerations
     3.18. Security for session control Session Control and media  . . . . . . . . .  21 Media
     3.19. SDP offer/answer examples . . . . . . . . . . . . . . . .  22 Offer/Answer Examples
     3.20. Packet sequence example Sequence Example from interleaved transmission . .  23 Interleaved Transmission
     3.21. Maximum character rate Character Rate "cps"  . . . . . . . . . . . . . .  26 Setting
   4.  Presentation level considerations . . . . . . . . . . . . . .  26  Presentation-Level Considerations
     4.1.  Presentation by multiparty-aware endpoints  . . . . . . .  27 Multiparty-Aware Endpoints
     4.2.  Multiparty mixing Mixing for multiparty-unaware endpoints  . . .  29 Multiparty-Unaware Endpoints
   5.  Relation  Relationship to Conference Control  . . . . . . . . . . . . . . .  35
     5.1.  Use with SIP centralized conferencing framework . . . . .  36 Centralized Conferencing Framework
     5.2.  Conference control  . . . . . . . . . . . . . . . . . . .  36 Control
   6.  Gateway Considerations  . . . . . . . . . . . . . . . . . . .  36
     6.1.  Gateway considerations Considerations with Textphones  . . . . . . . . .  36
     6.2.  Gateway considerations Considerations with WebRTC  . . . . . . . . . . .  36
   7.  Updates to RFC 4103 . . . . . . . . . . . . . . . . . . . . .  37
   8.  Congestion considerations . . . . . . . . . . . . . . . . . .  38
   9.  IANA Considerations . . . . . . . . . . . . . . . . . . . . .  38
     9.1.  Registration of the "rtt-mixer" SDP media attribute . . .  38
   10. Security Considerations . . . . . . . . . . . . . . . . . . .  39
   11. Change history  . . . . . . . . . . . . . . . . . . . . . . .  40
     11.1.  Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-20 . . . . . . .  40
     11.2.  Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-19 . . . . . . .  40
     11.3.  Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-18 . . . . . . .  40
     11.4.  Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-17 . . . . . . .  40
     11.5.  Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-16 . . . . . . .  40
     11.6.  Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-15 . . . . . . .  41
     11.7.  Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-14 . . . . . . .  41
     11.8.  Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-13 . . . . . . .  41
     11.9.  Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-12 . . . . . . .  42
     11.10. Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-11 . . . . . . .  42
     11.11. Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-10 . . . . . . .  42
     11.12. Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-09 . . . . . . .  42
     11.13. Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-08 . . . . . . .  43
     11.14. Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-07 . . . . . . .  43
     11.15. Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-06 . . . . . . .  43
     11.16. Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-05 . . . . . . .  43
     11.17. Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-04 . . . . . . .  43
     11.18. Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-03 . . . . . . .  44
     11.19. Changes included in
             draft-ietf-avtcore-multi-party-rtt-mix-02 . . . . . . .  45
     11.20. Changes to draft-ietf-avtcore-multi-party-rtt-mix-01 . .  45
     11.21. Changes from
             draft-hellstrom-avtcore-multi-party-rtt-source-03 to
             draft-ietf-avtcore-multi-party-rtt-mix-00 . . . . . . .  45
     11.22. Changes from
             draft-hellstrom-avtcore-multi-party-rtt-source-02 to
             -03 . . . . . . . . . . . . . . . . . . . . . . . . . .  45
     11.23. Changes from
             draft-hellstrom-avtcore-multi-party-rtt-source-01 to
             -02 . . . . . . . . . . . . . . . . . . . . . . . . . .  46
     11.24. Changes from
             draft-hellstrom-avtcore-multi-party-rtt-source-00 to
             -01 . . . . . . . . . . . . . . . . . . . . . . . . . .  47
   12.
   9.  IANA Considerations
     9.1.  Registration of the "rtt-mixer" SDP Media Attribute
   10. Security Considerations
   11. References  . . . . . . . . . . . . . . . . . . . . . . . . .  47
     12.1.
     11.1.  Normative References . . . . . . . . . . . . . . . . . .  47
     12.2.
     11.2.  Informative References . . . . . . . . . . . . . . . . .  48
   Acknowledgements  . . . . . . . . . . . . . . . . . . . . . . . .  49
   Author's Address  . . . . . . . . . . . . . . . . . . . . . . . .  49

1.  Introduction

   "RTP Payload for Text Conversation" [RFC4103] specifies the use of
   the
   Real-Time Real-time Transport Protocol (RTP) [RFC3550] for transmission of
   real-time text (RTT) (often called RTT) and the "text/t140" format.  It
   also specifies a redundancy format "text/red" format, "text/red", for increased
   robustness.  The "text/
   red" "text/red" format is registered in [RFC4102].

   Real-time text is usually provided together with audio and sometimes
   with video in conversational sessions.

   A requirement related to multiparty sessions from the presentation presentation-
   level standard T.140 [T140] for real-time text is: "The is as follows:

   |  The display of text from the members of the conversation should be
   |  arranged so that the text from each participant is clearly
   |  readable, and its source and the relative timing of entered text
   |  is visualized in the
   display." display.

   Another requirement is that the mixing procedure must not introduce
   delays in the text streams that are experienced to could be disturbing perceived as disruptive to
   the real-time experience of the receiving users.

   Use

   The use of RTT real-time text is increasing, and specifically, use in
   emergency calls is increasing.  Emergency call use requires
   multiparty mixing mixing, because it is common that one agent needs to
   transfer the call to another specialized agent but is obliged to stay
   on the call to at least to verify that the transfer was successful.
   Mixer implementations for RFC 4103 "RTP ("RTP Payload for Text Conversation"
   Conversation") can use traditional RFC
   3550 RTP functions (RFC 3550) for
   mixing and source identification, but the performance of the mixer
   when giving turns for the different sources to transmit is limited
   when using the default transmission characteristics with redundancy.

   The redundancy scheme of described in [RFC4103] enables efficient
   transmission of earlier transmitted redundant text in packets
   together with new text.  However, the redundancy header format has no
   source indicators for the redundant transmissions.  The redundant
   parts in a packet must therefore be from the same source as the new
   text.  The recommended transmission is one new and two redundant
   generations of text (T140blocks) in each packet packet, and the recommended
   transmission interval for two-party use is 300 ms.

   Real-time text mixers for multiparty sessions need to include the
   source with each transmitted group of text from a conference
   participant so that the text can be transmitted interleaved with text
   groups from different sources at the rate at which they are created.
   This enables the text groups to be presented by endpoints in a
   suitable grouping with other text from the same source.

   The presentation can then be arranged so that text from different
   sources can be presented in real-time real time and easily read.  At the same
   time
   time, it is possible for a reading user to perceive approximately
   when the text was created in real time by the different parties.  The
   transmission and mixing is are intended to be done in a general way, so
   that presentation can be arranged in a layout decided upon by the
   receiving endpoint.

   There are existing

   Existing implementations of RFC 4103 in endpoints without that do not
   implement the updates from specified in this document.  These will not document cannot be able expected
   to receive
   and properly present real-time text mixed for multiparty-aware
   endpoints.

   A negotiation mechanism is therefore needed for verification to verify if the parties
   (1) are able to handle a common method for multiparty
   transmission transmissions
   and agreeing (2) can agree on using that method.

   A fallback mixing procedure is also needed for cases when the
   negotiation result indicates that a receiving endpoint is not capable
   of handling the mixed format.  Multiparty-unaware endpoints would
   possibly otherwise present all received multiparty mixed text as if
   it came from the same source regardless of any accompanying source
   indication coded in fields in the packet.  Or  Or, they may have other
   undesirable ways of acting on the multiparty content.  The fallback
   method is called the mixing procedure for multiparty-unaware
   endpoints.  The fallback method is naturally not expected to meet all
   performance requirements placed on the mixing procedure for
   multiparty-aware endpoints.

   The

   This document updates [RFC4103] by introducing an attribute for
   declaring support of the RTP-mixer-based multiparty mixing multiparty-mixing case and
   rules for source indications and interleaving of text from different
   sources.

1.1.  Terminology

   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 above. here.

   The terms Source Description "Source Description" (SDES), Canonical name "Canonical Name" (CNAME), Name
   "Name" (NAME), Synchronization Source "Synchronization Source" (SSRC), Contributing Source "Contributing Source"
   (CSRC),
   CSRC list, CSRC count [CC], Real-Time control protocol "CSRC list", "CSRC count" (CC), "RTP Control Protocol"
   (RTCP), RTP-
   mixer, RTP-translator and "RTP mixer" are defined in [RFC3550].

   "real-time text" (RTT) is text transmitted instantly as it is typed
   or created.  Recipients can immediately read the message while it is
   being written, without waiting.

   The term "T140block" is defined in [RFC4103] to contain one or more
   T.140 code elements.

   "TTY" stands for a textphone type used in North America.

   Web based real-time communication Real-Time Communication (WebRTC) is specified by the World Wide
   Web Consortium (W3C) and the IETF.  See [RFC8825].

   "DTLS-SRTP" is a Datagram Transport Layer Security (DTLS) extension
   for use with the Secure Real-Time Real-time Transport Protocol / Secure Real-
   time Transport Protocol/Secure Real-Time Control Protocol (SRTP/SRTCP) as specified in
   [RFC5764].

   "multiparty-aware"

   The term "multiparty aware" describes an endpoint receiving that (1) receives
   real-time text from multiple sources through a common conference mixer being
   mixer, (2) is able to present the text in real-time, real time, separated by
   source, and presented (3) presents the text so that a user can get an
   impression of the approximate relative timing of text from different
   parties.

   "multiparty-unaware"

   The term "multiparty unaware" describes an endpoint not that cannot
   itself being able to separate text from different sources when the text is received
   through a common conference mixer.

1.2.  Selected solution  Main Method, Fallback Method, and considered alternatives Considered Alternatives

   A number of alternatives were considered when searching for an
   efficient and easily implemented multiparty method for real-time
   text.  This section briefly explains a few of them briefly. them.

   Multiple RTP streams, one per participant participant:
      One RTP stream per source would be sent in the same RTP session
      with the "text/red" format.  From some points of view, the use of
      multiple RTP streams, one for each source, sent in the same RTP
      session would be efficient, efficient and would use exactly the same packet
      format as [RFC4103] and the same payload type.  A couple of
      relevant scenarios using multiple RTP-streams RTP streams are specified in
      "RTP Topologies" [RFC7667].  One possibility of special interest
      is the Selective Forwarding Middlebox (SFM) topology specified in
      RFC 7667 section
      Section 3.7 that of [RFC7667], which could enable end-to-end
      encryption.  In contrast to audio and video, real-time text is
      only transmitted when the users actually transmit information.
      Thus, an SFM solution would not need to exclude any party from
      transmission under normal conditions.  In order to allow the mixer
      to convey the packets with the payload preserved and encrypted, an
      SFM solution would need to act on some specific characteristics of
      the "text/red" format.  The redundancy headers are part of the
      payload, so the receiver would need to just assume that the
      payload type number in the redundancy header is for "text/t140".
      The characters per second ("cps") parameter (cps) would need to act per
      stream.  The relation relationship between the SSRC and the source would
      need to be conveyed in some specified way, e.g., in the CSRC.
      Recovery and loss detection would preferably be based on RTP
      sequence number gap detection.  Thus, sequence number gaps in the
      incoming stream to the mixer would need to be reflected in the
      stream to the participant, with no new gaps created by the mixer.
      However, the RTP implementation in both mixers and endpoints need needs
      to support multiple streams in the same RTP session in order to
      use this mechanism.  For  To provide the best deployment opportunity, opportunities for
      deployment, it should be possible to upgrade existing endpoint
      solutions to be multiparty-aware multiparty aware with a reasonable amount of
      effort.  There is currently a lack of support for multi-stream RTP
      in certain implementations.  This fact led to only brief mention
      of this solution being only briefly mentioned in this document as an option for further study.

   RTP-mixer-based method for multiparty-aware endpoints endpoints:
      The "text/red" format as defined in RFC 4102 and applied in RFC
      4103 is sent with a shorter
      transmission interval with the RTP-mixer method and indicating the source in
      the CSRC field.  The "text/red" format with a "text/
      t140" "text/t140" payload
      in a single RTP stream can be sent when text is available from the
      call participants instead of at the regular 300
      ms. ms intervals.
      Transmission of packets with text from different sources can then
      be done smoothly while simultaneous transmission occurs as long as
      it is not limited by the maximum character rate "cps". "cps" value.  With
      ten participants sending text simultaneously, the switching and
      transmission performance is good.  With more simultaneously
      sending participants, participants and with receivers having the at default
      capacity capacity, there
      will be a noticeable jerkiness and delay in text presentation.
      The jerkiness will be more expressed the more participants who send text simultaneously. simultaneously, the more
      jerkiness will occur.  Two seconds of jerkiness will be noticeable
      and slightly unpleasant, but it corresponds in time to what typing
      humans often cause by hesitation hesitating or changing position while
      typing.  A benefit of this method is that no new packet format
      needs to be introduced and implemented.  Since simultaneous typing
      by more than two parties is expected to be very rare -- as
      described in Section 1.3, 1.3 -- this method can be used successfully
      with good performance.  Recovery of text in the case of packet
      loss is based on analysis of timestamps of received redundancy
      versus earlier received text.  Negotiation is based on a new SDP
      media attribute attribute, "rtt-mixer".  This method is was selected to be the
      main one method specified in this document.

   Multiple sources per packet packet:
      A new "text" media subtype would be specified with up to 15
      sources in each packet.  The mechanism would make use of the RTP RTP-
      mixer model specified in RTP [RFC3550].  The sources are would be
      indicated in strict order in the CSRC list of the RTP packets.
      The CSRC list can have up to 15 members.  Therefore, text from up
      to 15 sources can be included in each packet.  Packets are
      normally sent
      with at 300 ms intervals.  The mean delay will would be 150
      ms.  A new redundancy packet format is would be specified.  This
      method would result in good performance, performance but would require
      standardization and implementation of new releases in the target technologies that
      technologies; these would take more time than desirable to
      complete.  It was therefore not selected to be included in this
      document.

   Mixing for multiparty-unaware endpoints
      Presentation endpoints:
      The presentation of text from multiple parties is prepared by the
      mixer in one single stream.  It is desirable to have a method that
      does not require any modifications in existing user devices
      implementing RFC 4103 for RTT real-time text without explicit support
      of multiparty sessions.  This is made possible by having the mixer
      insert a new line and a text formatted text-formatted source label before each
      switch of text source in the stream.  Switch of  Switching the source can
      only be done in places in the text where it does not disturb the
      perception of the contents.  Text from only one source at a time
      can be presented in real time
      at a time.  The delay will therefore vary.  The method also has
      other limitations, but is included in this document as a fallback
      method.  In
      calls where parties take turns properly by ending their entries
      with a new line, the limitations will have limited influence on
      the user experience. when  When only two parties send text, these two
      will see the text in real time with no delay.  This  Although this
      method also has other limitations, it is specified included in this document
      as a fallback method in this document.

   RTT transport in WebRTC
      Transport of real-time method.

   Real-time text transport in the WebRTC technology is specified
      to use WebRTC:
      [RFC8865] specifies how the WebRTC data channel in [RFC8865]. can be used to
      transport real-time text.  That specification contains a section
      briefly describing its use in multiparty sessions.  The focus of
      this document is RTP transport.  Therefore, even if the WebRTC
      transport provides good multiparty performance, it is just only
      mentioned in this document in relation to providing gateways with
      multiparty capabilities between RTP and WebRTC technologies.

1.3.  Intended application Application

   The method for multiparty real-time text specified in this document
   is primarily intended for use in transmission transmissions between mixers and
   endpoints in centralized mixing configurations.  It is also
   applicable between mixers.  An often mentioned often-mentioned application is for
   emergency service calls with real-time text and voice, where a call
   taker wants to make an attended handover of a call to another agent, agent
   and stay on the call to observe the session.  Multimedia conference
   sessions with support for participants to contribute in with text is
   another
   application. example.  Conferences with central support for speech-to-text
   conversion is represent yet another mentioned application. example.

   In all these applications, normally only one participant at a time
   will send long text utterances. comments.  In some cases, one other participant
   will occasionally contribute with a longer comment simultaneously.
   That may also happen in some rare cases when text is interpreted translated to
   text in another language in a conference.  Apart from these cases,
   other participants are only expected to contribute with very brief
   utterings
   comments while others are sending text.

   Users expect that the text they send is to be presented in real-time real time in a
   readable way to the other participants even if they send
   simultaneously with other users and even when they make brief edit
   operations of their text by backspacing and correcting their text.

   Text is supposed to be human generated, by some means of text input means, input,
   such as typing on a keyboard or using speech-to-text technology.
   Occasional small cut-and-paste operations may appear even if that is
   not the initial purpose of real-time text.

   The real-time characteristics of real-time text is are essential for the
   participants to be able to contribute to a conversation.  If the text
   is delayed too much delayed from between the typing of a letter to character and its
   presentation, then, in some conference situations, the opportunity to
   comment will be gone and someone else will grab the turn.  A delay of
   more than one second in such situations is an obstacle for to good
   conversation.

2.  Overview of the two specified solutions Two Specified Solutions and selection Selection of method Method

   This section contains a brief introduction of the two methods
   specified in this document.

2.1.  The RTP-mixer-based solution RTP-Mixer-Based Solution for multiparty-aware endpoints Multiparty-Aware Endpoints

   This method specifies the negotiated use of the formats described in
   RFC 4103 format 4103, for multiparty transmission transmissions in a single RTP stream.  The
   main purpose of this document is to specify a method for true
   multiparty real-time text mixing for multiparty-aware endpoints that
   can be widely deployed.  The RTP-mixer-based method makes use of the
   current format for real-time text as provided in [RFC4103].  It is an update of  This
   method updates RFC 4103 by a
   clarification on clarifying one way to use it in the
   multiparty situation.  That is done by completing a negotiation for
   this kind of multiparty capability and by interleaving packets from
   different sources.  The source is indicated in the CSRC element in
   the RTP packets.  Specific considerations are made to be able regarding the
   ability to recover text after packet loss.

   The detailed procedures for the RTP-mixer-based multiparty-aware case
   are specified in Section 3.

   Please use refer to [RFC4103] as reference when reading the specification. this document.

2.2.  Mixing for multiparty-unaware endpoints

   A method is Multiparty-Unaware Endpoints

   This document also specified specifies a method to be used in this document for cases when the
   endpoint participating in a multiparty call does not itself implement
   any solution, solution or does not implement the same, same solution as the mixer.  The
   This method requires the mixer to insert text dividers and readable
   labels and only send text from one source at a time until a suitable
   point appears for source
   change. changing the source.  This solution is a fallback
   method with functional limitations.  It acts on operates at the presentation
   level.

   A mixer SHOULD by default format and transmit text to a call
   participant to be so that the text is suitable to present for presentation on a
   multiparty-unaware endpoint which that has not negotiated any method for
   true multiparty RTT
   handling, real-time text handling but has negotiated a "text/red" "text/
   red" or "text/t140" format in a session.  This SHOULD be done if
   nothing else is specified for the
   application application, in order to maintain
   interoperability.  Section 4.2 specifies how this mixing is done.

2.3.  Offer/answer considerations

   RTP  Offer/Answer Considerations

   "RTP Payload for Text Conversation Conversation" [RFC4103] specifies the use of
   RTP
   [RFC3550], [RFC3550] and a redundancy format "text/red" ("text/red", as defined in
   [RFC4102]) for increased robustness of real-time text transmission.
   This document updates [RFC4103] by introducing a capability
   negotiation for handling multiparty real-time text, a way to indicate
   the source of transmitted text, and rules for efficient timing of the
   transmissions interleaved from different sources.

   The capability negotiation for the "RTP-mixer-based RTP-mixer-based multiparty
   method" method
   is based on the use of the SDP media attribute "rtt-mixer".

   The syntax is as follows:
      "a=rtt-mixer"

      a=rtt-mixer

   If in the future any other method for RTP-based multiparty real-time
   text gets is specified by additional work, it is assumed that it will be
   recognized by some specific SDP feature exchange.

2.3.1.  Initial offer Offer

   A party intending that intends to set up a session and being is willing to use the
   RTP-mixer-based method of provided in this specification for sending or receiving sending,
   receiving, or both sending and receiving real-time text SHALL include
   the "rtt-
   mixer" "rtt-mixer" SDP attribute in the corresponding "text" media
   section in the initial offer.

   The party MAY indicate its capability for regarding both the RTP-mixer-based RTP-mixer-
   based method
   of provided in this specification and other methods.

   When the offeror offerer has sent the offer including offer, which includes the "rtt-mixer"
   attribute, it MUST be prepared to receive and handle real-time text
   formatted according to both the method for multiparty-aware parties
   specified in Section 3 in this specification and two-party formatted real-time text.

2.3.2.  Answering the offer Offer

   A party receiving that receives an offer containing the "rtt-mixer" SDP
   attribute and being is willing to use the RTP-mixer-based method of provided
   in this specification for sending or receiving sending, receiving, or both sending and
   receiving real-time text SHALL include the "rtt-mixer" SDP attribute
   in the corresponding "text" media section in the answer.

   If the offer did not contain the "rtt-mixer" attribute, the answer
   MUST NOT contain the "rtt-mixer" attribute.

   Even when the "rtt-mixer" attribute is successfully negotiated, the
   parties MAY send and receive two-party coded real-time text.

   An answer MUST NOT include acceptance of more than one method for
   multiparty real-time text in the same RTP session.

   When the answer including acceptance answer, which includes acceptance, is transmitted, the
   answerer MUST be prepared to act on received text in the negotiated
   session according to the method for multiparty-aware parties
   specified in Section 3 of this specification. 3.  Reception of text for a two-party session
   SHALL also be supported.

2.3.3.  Offeror processing  Offerer Processing the answer Answer

   When the answer is processed by the offeror, it offerer, the offerer MUST act as specified follow
   the requirements listed in Section 2.4 2.4.

2.3.4.  Modifying a session Session

   A session MAY be modified at any time by any party offering a
   modified SDP with or without the "rtt-mixer" SDP attribute expressing
   a desired change in the support of multiparty real-time text.

   If the modified offer adds the indication of support for multiparty real-
   time
   real-time text by including the "rtt-mixer" SDP attribute, the
   procedures specified in the previous subsections SHALL be applied.

   If the modified offer deletes the indication of support for
   multiparty real-time text by excluding the "rtt-mixer" SDP attribute,
   the answer MUST NOT contain the "rtt-mixer" attribute.  After
   processing this SDP exchange, the parties MUST NOT send real-time
   text formatted for multiparty-aware parties according to this
   specification.

2.4.  Actions depending Depending on capability negotiation result Capability Negotiation Result

   A transmitting party SHALL send text according to the RTP-mixer-based
   multiparty method only when the negotiation for that method was
   successful and when it conveys text for another source.  In all other
   cases, the packets SHALL be populated and interpreted as for a two-
   party session.

   A party which that has negotiated the "rtt-mixer" SDP media attribute and
   acts as an RTP mixer sending multiparty text MUST (1) populate the CSRC-list,
   CSRC list and (2) format the packets according to Section 3
   if it acts as an rtp-mixer and sends multiparty text. 3.

   A party which that has negotiated the "rtt-mixer" SDP media attribute MUST
   interpret the contents of the "CC" CC field, the CSRC-list CSRC list, and the
   packets according to Section 3 in received RTP packets in the
   corresponding RTP stream.

   A party which that has not successfully completed the negotiation of the
   "rtt-mixer" SDP media attribute MUST NOT transmit packets interleaved
   from different sources in the same RTP stream stream, as specified in
   Section 3.  If the party is a mixer and did declare the "rtt-mixer"
   SDP media attribute, it SHOULD perform the procedure for multiparty-
   unaware endpoints.  If the party is not a mixer, it SHOULD transmit
   as in a two-party session according to [RFC4103].

3.  Details for the RTP-mixer-based mixing method RTP-Mixer-Based Mixing Method for multiparty-aware
    endpoints Multiparty-Aware
    Endpoints

3.1.  Use of fields Fields in the RTP packets Packets

   The CC field SHALL show the number of members in the CSRC list, which
   SHALL be one (1) in transmissions from a mixer when conveying text
   from other sources in a multiparty session, and otherwise 0.

   When text is conveyed by a mixer during a multiparty session, a CSRC
   list SHALL be included in the packet.  The single member in the CSRC- CSRC
   list SHALL contain the SSRC of the source of the T140blocks in the
   packet.

   When redundancy is used, the RECOMMENDED level of redundancy is to
   use one primary and two redundant generations of T140blocks.  In some
   cases, a primary or redundant T140block is empty, empty but is still
   represented by a member in the redundancy header.

   In other regards, respects, the contents of the RTP packets are equal to what
   is will be as
   specified in [RFC4103].

3.2.  Initial transmission Transmission of a BOM character Character

   As soon as a participant is known to participate in a session with
   another entity and is available for text reception, a Unicode Byte-
   Order Mark byte
   order mark (BOM) character SHALL be sent to it by the other entity
   according to the procedures in this section.  This is useful in many
   configurations to open for opening ports and firewalls and for setting up the
   connection between the application and the network.  If the
   transmitter is a mixer, then the source of this character SHALL be
   indicated to be the mixer itself.

   Note that the BOM character SHALL be transmitted with the same
   redundancy procedures as any other text.

3.3.  Keep-alive  Keep-Alive

   After that, the transmitter SHALL send keep-alive traffic to the
   receiver(s) at regular intervals when no other traffic has occurred
   during that interval, if that is decided upon for the actual
   connection.  It is RECOMMENDED to use the keep-alive solution from
   provided in [RFC6263].  The consent check of [RFC7675] is a possible
   alternative if it is used anyway for other reasons.

3.4.  Transmission interval Interval

   A "text/red" or "text/t140" transmitter in a mixer SHALL send packets
   distributed in over time as long as there is something (new or redundant
   T140blocks) to transmit.  The maximum transmission interval between
   text transmissions from the same source SHALL then be 330 ms, when no
   other limitations cause a longer interval to be temporarily used.  It
   is RECOMMENDED to send the next packet to a receiver as soon as new
   text to that receiver is available, as long as the mean character
   rate of new text to the receiver calculated over the last 10 one-
   second intervals does not exceed the "cps" value of the receiver.
   The intention is to keep the latency low and network load limited
   while keeping good protection against text loss in bursty packet loss
   conditions.  The main purpose of the 330 ms interval is for the
   timing of redundant transmission, transmissions, when no new text from the same
   source is available.

   The reason for the value of 330 ms is that used, because many sources of text will
   transmit new text with at 300 ms intervals during periods of continuous
   user typing, and then reception in the mixer of such new text will
   cause a combined transmission of the new text and the unsent
   redundancy from the previous transmission.  Only when the user stops
   typing,
   typing will the 330 ms interval will be applied to send the redundancy.

   If the Characters Per Second (cps) characters per second ("cps") value is reached, a longer
   transmission interval SHALL be applied for text from all sources as
   specified in [RFC4103] and only as much of the text queued for
   transmission SHALL be sent at the end of each transmission interval
   as can be allowed without exceeding the "cps" value.  Division of
   text for partial transmission MUST then be made at T140block borders.
   When the transmission rate falls under below the "cps" value again, the
   transmission intervals SHALL be returned reset to 330 ms and transmission of
   new text SHALL return to again be made as soon as new text is available.

      |  NOTE: that extending Extending the transmission intervals during periods of
      |  high load
   periods does not change the number of characters to be
      |  conveyed.  It just evens out the load in over time and reduces the
      |  number of packets per second.  With human created human-created
      |  conversational text, the sending user will eventually take a pause
      |  pause, letting transmission catch up.

   See also Section 8.

   For a transmitter not acting as a mixer, the transmission interval
   principles from provided in [RFC4103] apply, and the normal transmission
   interval SHALL be 300 ms.

3.5.  Only one source One Source per packet Packet

   New text and redundant copies of earlier text from one source SHALL
   be transmitted in the same packet if available for transmission at
   the same time.  Text from different sources MUST NOT be transmitted
   in the same packet.

3.6.  Do not send received text Not Send Received Text to the originating source Originating Source

   Text received by a mixer from a participant SHOULD NOT be included in
   transmission
   transmissions from the mixer to that participant, because for text
   that is produced locally, the normal behavior of the endpoint is to
   present locally-produced such text locally. directly when it is produced.

3.7.  Clean incoming text Incoming Text

   A mixer SHALL handle reception, recovery from packet loss, deletion
   of superfluous redundancy, marking of possible text loss loss, and
   deletion of 'BOM' BOM characters from each participant before queueing
   received text for transmission to receiving participants as specified
   in [RFC4103] for single-party sources and Section 3.16 for multiparty
   sources (chained mixers).

3.8.  Principles of Redundant transmission principles Transmission

   A transmitting party using redundancy SHALL send redundant
   repetitions of T140blocks already transmitted in earlier packets.

   The number of redundant generations of T140blocks to include in
   transmitted packets SHALL be deduced from the SDP negotiation.  It
   SHALL be set to the minimum of the number declared by the two parties
   negotiating a connection.  It is RECOMMENDED to declare and transmit
   one original and two redundant generations of the T140blocks T140blocks, because
   that
   this provides good protection against text loss in the case of packet
   loss,
   loss and also provides low overhead.

3.9.  Text placement Placement in packets Packets

   The mixer SHALL compose and transmit an RTP packet to a receiver when
   one or more of the following conditions have occurred:

   *  The transmission interval is the normal 330 ms (no matter whether
      the transmission interval has passed or not), and there is newly
      received unsent text available for transmission to that receiver.

   *  The current transmission interval has passed and is longer than
      the normal 330 ms ms, and there is newly received unsent text
      available for transmission to that receiver.

   *  The current transmission interval ( normally (normally 330 ms) has passed
      since already transmitted already-transmitted text was queued for transmission as
      redundant text.

   The principles from provided in [RFC4103] apply for populating the header,
   the redundancy header header, and the data in the packet with specifics specified specific
   information, as detailed here and in the following sections.

   At the time of transmission, the mixer SHALL populate the RTP packet
   with all T140blocks queued for transmission originating from the
   source in turn selected for transmission as long as this is not in conflict
   with the allowed number of characters per second ("cps") or the
   maximum packet size.  In this way, the latency of the latest received
   text is kept low even in moments of simultaneous transmission from
   many sources.

   Redundant text SHALL also be included, and the assessment of how much
   new text can be included within the maximum packet size MUST take
   into account that the redundancy has priority to be transmitted in
   its entirety.  See Section 3.4 3.4.

   The SSRC of the source SHALL be placed as the only member in the
   CSRC-list. CSRC
   list.

      |  Note: The CSRC-list CSRC list in an RTP packet only includes the
      |  participant whose text is included in text blocks.  It is not
      |  the same as the total list of participants in a conference.
      |  With audio and video media, the CSRC-list CSRC list would often contain
      |  all participants who are not
   muted muted, whereas text participants
      |  that don't type are completely silent and thus are not
      |  represented in RTP packet CSRC-lists. CSRC lists.

3.10.  Empty T140blocks

   If no unsent T140blocks were available for a source at the time of
   populating a packet, packet but already-transmitted T140blocks are available which
   that have not yet been sent the full intended number of redundant
   transmissions, then the primary T140block for that source area in the packet is composed of an
   empty
   T140block, T140block and populated included (without taking up any length) in a the
   packet for transmission.  The corresponding SSRC SHALL be placed as
   usual in its place in the CSRC-list. CSRC list.

   The first packet in the session, the first after a source switch, and
   the first after a pause SHALL be populated with the available
   T140blocks for the source in turn selected to be sent as the primary, and
   empty T140blocks for the agreed agreed-upon number of redundancy
   generations.

3.11.  Creation of the redundancy Redundancy

   The primary T140block from a source in the latest transmitted packet
   is saved for populating the first redundant T140block for that source
   in the next transmission of text from that source.  The first
   redundant T140block for that source from the latest transmission is
   saved for populating the second redundant T140block in the next
   transmission of text from that source.

   Usually

   Usually, this is the level of redundancy used.  If a higher level of
   redundancy is negotiated, then the procedure SHALL be maintained continued until
   all available redundant levels of T140blocks are placed in the
   packet.  If a receiver has negotiated a lower number of "text/red"
   generations, then that level SHALL be the maximum used by the
   transmitter.

   The T140blocks saved for transmission as redundant data are assigned
   a planned transmission time of 330 ms after the current time, time but
   SHOULD be transmitted earlier if new text for the same source gets in turn
   selected for transmission before that time.

3.12.  Timer offset fields Offset Fields

   The timestamp offset values SHALL be inserted in the redundancy
   header, with the time offset from the RTP timestamp in the packet
   when the corresponding T140block was sent as the primary.

   The timestamp offsets are expressed in the same clock tick units as
   the RTP timestamp.

   The timestamp offset values for empty T140blocks have no relevance
   but SHOULD be assigned realistic values.

3.13.  Other RTP header fields Header Fields

   The number of members in the CSRC list (0 or 1) SHALL be placed in
   the "CC" CC header field.  Only mixers place value 1 in the "CC" CC field.  A
   value of "0" 0 indicates that the source is the transmitting device
   itself and that the source is indicated by the SSRC field.  This
   value is used by endpoints, endpoints and also by mixers sending self-sourced
   data.

   The current time SHALL be inserted in the timestamp.

   The SSRC header field SHALL contain the SSRC of the RTP session where
   the packet will be transmitted.

   The M-bit SHALL be handled as specified in [RFC4103].

3.14.  Pause in transmission Transmission

   When there is no new T140block to transmit, transmit and no redundant T140block
   that has not been retransmitted the intended number of times from any
   source, the transmission process SHALL be stopped until either new
   T140blocks arrive, arrive or a keep-alive method calls for transmission of
   keep-alive packets.

3.15.  RTCP considerations Considerations

   A mixer SHALL send RTCP reports with SDES, CNAME, and NAME
   information about the sources in the multiparty call.  This makes it
   possible for participants to compose a suitable label for text from
   each source.

   Privacy considerations SHALL be taken when composing these fields.
   They contain name and address information that may be considered
   sensitive to
   transmit if the information is transmitted in its entirety, e.g., to
   unauthenticated participants.

3.16.  Reception of multiparty contents Multiparty Contents

   The "text/red" receiver included in an endpoint with presentation
   functions will receive RTP packets in the single stream from the
   mixer,
   mixer and SHALL distribute the T140blocks for presentation in
   presentation areas for each source.  Other receiver roles, such as
   gateways or chained mixers, are also feasible.  They require
   considerations if  Whether the stream shall just
   will only be forwarded, forwarded or will be distributed based on the different sources.
   sources must be taken into consideration.

3.16.1.  Acting on the source Source of the packet contents Packet Contents

   If the "CC" CC field value of a received packet is 1, it indicates that
   the text is conveyed from a source indicated in the single member in
   the CSRC-list, CSRC list, and the receiver MUST act on the source according to
   its role.  If the CC value is 0, the source is indicated in the SSRC
   field.

3.16.2.  Detection and indication Indication of possible text loss Possible Text Loss

   The receiver SHALL monitor the RTP sequence numbers of the received
   packets for gaps and for packets received out of order.  If a
   sequence number gap appears and still exists after some defined short
   time for jitter and reordering resolution, the packets in the gap
   SHALL be regarded as lost.

   If it is known that only one source is active in the RTP session,
   then it is likely that a gap equal to or larger than the agreed agreed-upon
   number of redundancy generations (including the primary) causes text
   loss.  In that case, the receiver SHALL create a t140block T140block with a
   marker for possible text loss [T140ad1] and [T140ad1], associate it with the
   source
   source, and insert it in the reception buffer for that source.

   If it is known that more than one source is active in the RTP
   session, then it is not possible in general to evaluate if text was
   lost when packets were lost.  With two active sources and the
   recommended number of redundancy generations (3), (one original and two
   redundant), it can take a gap of five consecutive lost packets until before
   any text may be lost, but text loss can also appear if three non-consecutive non-
   consecutive packets are lost when they contained consecutive data
   from the same source.  A simple method to decide for deciding when there is a
   risk for of resulting text loss is to evaluate if three or more packets
   were lost within one second.  If this simple method is used, then a t140block
   T140block SHOULD be created with a marker for possible text loss
   [T140ad1] and associated with the SSRC of the RTP session as a
   general input from the mixer.

   Implementations MAY apply more refined methods for more reliable
   detection of whether text was lost or not.  Any refined method SHOULD
   prefer marking possible loss rather than not marking when it is
   uncertain if there was loss.

3.16.3.  Extracting text Text and handling recovery Handling Recovery

   When applying the following procedures, the effects MUST be
   considered of possible
   timestamp wrap around wraparound and the RTP session possibly changing SSRC. the SSRC
   MUST be considered.

   When a packet is received in an RTP session using the packetization
   for multiparty-aware endpoints, its T140blocks SHALL be extracted in
   the following way. as
   described below.

   The source SHALL be extracted from the CSRC-list CSRC list if available, and
   otherwise from the SSRC.

   If the received packet is the first packet received from the source,
   then all T140blocks in the packet SHALL be retrieved and assigned to
   a receive buffer for the source that source, beginning with the oldest available
   redundant generation, continuing with the younger redundant
   generations in age order order, and finally ending with the primary.

      |  Note: The normal case is that in the first packet, only the
      |  primary data has contents.  The redundant data has contents in
      |  the first received packet from a source only after initial
      |  packet loss.

   If the packet is not the first packet from a source, then if
   redundant data is available, the process SHALL start with the oldest
   generation.  The timestamp of that redundant data SHALL be created by
   subtracting its timestamp offset from the RTP timestamp.  If the
   resulting timestamp is later than the latest retrieved data from the
   same source, then the redundant data SHALL be retrieved and appended
   to the receive buffer.  The process SHALL be continued in the same
   way for all younger generations of redundant data.  After that, the
   timestamp of the packet SHALL be compared with the timestamp of the
   latest retrieved data from the same source and if it is later, then
   the primary data SHALL be retrieved from the packet and appended to
   the receive buffer for the source.

3.16.4.  Delete 'BOM' BOM

   The Unicode BOM character 'BOM' is used as a start indication and is
   sometimes used as a filler or keep alive keep-alive by transmission
   implementations.
   These  Any BOM characters SHALL be deleted after
   extraction from received packets.

3.17.  Performance considerations Considerations

   This solution has good performance with low text delays, as long as
   the mean number of characters per second sent during any 10-second
   interval from a number of simultaneously sending participants to a
   receiving participant, participant does not reach the "cps" value.  At higher
   numbers of sent characters per second, a jerkiness is visible in the
   presentation of text.  The solution is therefore suitable for
   emergency service use, relay service use, and small or well-managed
   larger multimedia conferences.  Only in  In large unmanaged conferences with a
   high number of participants there may only, on very rare occasions
   appear occasions, situations when
   might arise where many participants happen to send text
   simultaneously.  In such circumstances, the result may be
   unpleasantly jerky presentation of text from each sending
   participant.  It should be noted that it is only the number of users
   sending text within the same moment that causes jerkiness, not the
   total number of users with RTT real-time text capability.

3.18.  Security for session control Session Control and media Media

   Security mechanisms to provide confidentiality and confidentiality, integrity
   protection protection,
   and peer authentication SHOULD be applied when possible regarding the
   capabilities of the participating devices by use of SIP using the Session
   Initiation Protocol (SIP) over TLS by default according to [RFC5630] section
   Section 3.1.3 of [RFC5630] on the session control level and by
   default using DTLS-SRTP [RFC5764] on at the media level.  In
   applications where legacy endpoints without security are allowed, a
   negotiation SHOULD be performed to decide if encryption on at the media
   level will be applied.  If no other security solution is mandated for
   the application, then OSRTP the Opportunistic Secure Real-time Transport
   Protocol (OSRTP) [RFC8643] is a suitable method to be applied to
   negotiate SRTP media security with DTLS.  Most  For simplicity, most SDP
   examples below are for simplicity expressed without the security additions.  The
   principles (but not all details) for applying DTLS-SRTP [RFC5764] security
   [RFC5764] are shown in a couple of the following examples.

   Further general security considerations are covered in Section 10.

   End-to-end encryption would require further work and could be based
   on WebRTC as specified in Section 1.2 or on double encryption as
   specified in [RFC8723].

3.19.  SDP offer/answer examples Offer/Answer Examples

   This section shows some examples of SDP for session negotiation of
   the real-time text media in SIP sessions.  Audio is usually provided
   in the same session, and sometimes also video.  The examples only
   show the part of importance for the real-time text media.  The
   examples relate to the single RTP stream mixing for multiparty-aware
   endpoints and for multiparty-unaware endpoints.

      |  Note: Multiparty RTT real-time text MAY also be provided through
      |  other methods, e.g., by a Selective Forwarding Middlebox (SFM).
      |  In that case, the SDP of the offer will include something
      |  specific for that method, e.g., an SDP attribute or another
      |  media format.  An answer selecting the use of that method would
      |  accept it by via a corresponding acknowledgement included in the
      |  SDP.  The offer may contain also contain the "rtt-mixer" SDP media
      |  attribute for the main RTT real-time text media when the
   offeror offerer
      |  has this capability for both multiparty methods, while an
      |  answer,
   selecting choosing to use SFM SFM, will not include the "rtt-mixer"
      |  SDP media attribute.

   Offer example for the "text/red" format and format, multiparty support: support, and
   capability for 90 characters per second:

      m=text 11000 RTP/AVP 100 98
      a=rtpmap:98 t140/1000
      a=fmtp:98 cps=90
      a=rtpmap:100 red/1000
      a=fmtp:100 98/98/98
      a=rtt-mixer

   Answer example from a multiparty-aware device device:

      m=text 14000 RTP/AVP 100 98
      a=rtpmap:98 t140/1000
      a=fmtp:98 cps=90
      a=rtpmap:100 red/1000
      a=fmtp:100 98/98/98
      a=rtt-mixer

   Offer example for the "text/red" format format, including multiparty and
   security:

      a=fingerprint: (fingerprint1)
      m=text 11000 RTP/AVP 100 98
      a=rtpmap:98 t140/1000
      a=rtpmap:100 red/1000
      a=fmtp:100 98/98/98
      a=rtt-mixer

   The "fingerprint" is sufficient to offer DTLS-SRTP, with the media
   line still indicating RTP/AVP.

      |  Note: For brevity, the entire value of the SDP fingerprint "fingerprint"
      |  attribute is not shown in this and the following example.

   Answer example from a multiparty-aware device with security security:

      a=fingerprint: (fingerprint2)
      m=text 16000 RTP/AVP 100 98
      a=rtpmap:98 t140/1000
      a=rtpmap:100 red/1000
      a=fmtp:100 98/98/98
      a=rtt-mixer

   With the "fingerprint" "fingerprint", the device acknowledges the use of SRTP/DTLS. DTLS-SRTP.

   Answer example from a multiparty-unaware device that also does not
   support security:

      m=text 12000 RTP/AVP 100 98
      a=rtpmap:98 t140/1000
      a=rtpmap:100 red/1000
      a=fmtp:100 98/98/98

3.20.  Packet sequence example Sequence Example from interleaved transmission Interleaved Transmission

   This example shows a symbolic flow of packets from a mixer mixer, including
   loss and recovery.  The sequence includes interleaved transmission of
   text from two RTT sources real-time text sources: A and B.  P indicates primary
   data.  R1 is the first redundant generation data of data, and R2 is the
   second redundant generation of data.  A1, B1, A2 A2, etc. are text
   chunks (T140blocks) received from the respective sources and sent on
   to the receiver by the mixer.  X indicates a dropped packet between
   the mixer and a receiver.  The session is assumed to use the original
   and two redundant generations of RTT. real-time text.

     |-----------------------|
     |Seq no 101, Time=20400 |
     |CC=1                   |
     |CSRC list A            |
     |R2: A1, Offset=600     |
     |R1: A2, Offset=300     |
     |P:  A3                 |
     |-----------------------|

   Assuming that earlier packets (with text A1 and A2) were received in
   sequence, text A3 is received from packet 101 and assigned to
   reception buffer A.  The mixer is now assumed to have received
   initial text from source B 100 ms after packet 101 and will send that
   text.  Transmission of A2 and A3 as redundancy is planned for 330 ms
   after packet 101 if no new text from A is ready to be sent before
   that.

      |-----------------------|
      |Seq no 102, Time=20500 |
      |CC=1                   |
      |CSRC list B            |
      |R2  Empty, Offset=600  |
      |R1: Empty, Offset=300  |
      |P:  B1                 |
      |-----------------------|

      Packet 102 is received.

      B1 is retrieved from this packet.  Redundant transmission of B1 is
      planned 330 ms after packet 102.

      X------------------------|
      X Seq no 103, Timer=20730|
      X CC=1                   |
      X CSRC list A            |
      X R2: A2, Offset=630     |
      X R1: A3, Offset=330     |
      X P:  Empty              |
      X------------------------|

      Packet 103 is assumed to be lost due to network problems.

      It contains redundancy for A.  Sending A3 as second level second-level
      redundancy is planned for 330 ms after packet 103.

      X------------------------|
      X Seq no 104, Timer=20800|
      X CC=1                   |
      X CSRC list B            |
      X R2: Empty, Offset=600  |
      X R1: B1, Offset=300     |
      X P:  B2                 |
      X------------------------|

      Packet 104 contains text from B, including new B2 and redundant
      B1.  It is assumed dropped due to network problems.

      The mixer has A3 redundancy to send, but no new text appears from A
      A, and therefore the redundancy is sent 330 ms after the previous
      packet with text from A.

      |------------------------|
      | Seq no 105, Timer=21060|
      | CC=1                   |
      | CSRC list A            |
      | R2: A3, Offset=660     |
      | R1: Empty, Offset=330  |
      | P:  Empty              |
      |------------------------|

      Packet 105 is received.

      A gap for lost packets 103 and 104 is detected.  Assume that no
      other loss was detected during the last second.
     Then it  It can then be
      concluded that nothing was totally lost.

      R2 is checked.  Its original time was 21060-660=20400.  A packet
      with text from A was received with that timestamp, so nothing
      needs to be recovered.

      B1 and B2 still need to be transmitted as redundancy.  This is
      planned 330 ms after packet 104.  That would be at 21130.

      |-----------------------|
      |Seq no 106, Timer=21130|
      |CC=1                   |
      |CSRC list B            |
      | R2: B1, Offset=630    |
      | R1: B2, Offset=330    |
      | P:  Empty             |
      |-----------------------|

      Packet 106 is received.

      The second level second-level redundancy in packet 106 is B1 and has a
      timestamp offset of 630 ms.  The timestamp of packet 106 minus 630
      is 20500 20500, which is the timestamp of packet 102 that was received.  So
      So, B1 does not need to be retrieved.  The first level first-level redundancy
      in packet 106 has an offset of 330.  The timestamp of packet 106
      minus 330 is 20800.  That is later than the latest received packet
      with source B.  Therefore  Therefore, B2 is retrieved and assigned to the
      input buffer for source B.  No primary is available in packet 106.

      After this sequence, A3 and B1 A3, B1, and B2 have been received.  In this
   case
      case, no text was lost.

3.21.  Maximum character rate Character Rate "cps" Setting

   The default maximum rate of reception of "text/t140" real-time text
   is in [RFC4103] text,
   as specified to be in [RFC4103], is 30 characters per second.  The actual
   rate is calculated without regard to any redundant text transmission
   and is is, in the multiparty case case, evaluated for all sources
   contributing to transmission to a receiver.  The value MAY be
   modified in the "cps" parameter of the FMTP "fmtp" attribute in the media section for the
   "text/t140" media. format of the "text" media section.

   A mixer combining real-time text from a number of sources may
   occasionally have a higher combined flow of text coming from the
   sources.  Endpoints SHOULD therefore specify include a suitable higher value
   for the "cps" parameter, corresponding to its real reception
   capability.  A  The default "cps" value 30 can be assumed to be
   sufficient for small meetings and well-managed larger conferences
   with users only making manual text entry.  A "cps" value of 90 SHALL can be the default
   assumed to be sufficient even for the "text/t140" stream in the "text/red" format large unmanaged conferences and for
   cases when multiparty
   real-time speech-to-text technologies are used for text entry.  This
   is also a reachable performance for receivers in modern technologies,
   and 90 is negotiated. therefore the RECOMMENDED "cps" value.  See [RFC4103] for
   the format and use of the "cps" parameter.  The same rules apply for
   the multiparty case
   except for the default value. case.

4.  Presentation level considerations  Presentation-Level Considerations

   "Protocol for multimedia application text conversation" [T140]
   provides the presentation level presentation-level requirements for the [RFC4103]
   transport. RTP transport as
   described in [RFC4103].  Functions for erasure and other formatting
   functions are specified in [T140] [T140], which has the following general
   statement for the presentation:

   "The

   |  The display of text from the members of the conversation should be
   |  arranged so that the text from each participant is clearly
   |  readable, and its source and the relative timing of entered text
   |  is visualized in the display.  Mechanisms for looking back in the
   |  contents from the current session should be provided.  The text
   |  should be displayed as soon as it is received." received.

   Strict application of [T140] is of essence essential for the interoperability of
   real-time text implementations and to fulfill the intention that the
   session participants have the same information conveyed in the text
   contents of the conversation without necessarily having the exact
   same layout of the conversation.

   [T140] specifies a set of presentation control codes (Section 4.2.4)
   to include in the stream.  Some of them are optional.
   Implementations MUST ignore optional control codes that they do not
   support.

   There is no strict "message" concept in real-time text.  The Unicode
   Line Separator character SHALL be used as a separator allowing a part
   of received text to be grouped in a presentation.  The characters character
   combination "CRLF" may be used by other implementations as a
   replacement for the Line Separator.  The "CRLF" combination SHALL be
   erased by just one erasing action, the same as the Line Separator.
   Presentation functions are allowed to group text for presentation in
   smaller groups than the line separators Line Separators imply and present such groups
   with a source indication together with text groups from other sources
   (see the following presentation examples).  Erasure has no specific
   limit by any delimiter in the text stream.

4.1.  Presentation by multiparty-aware endpoints Multiparty-Aware Endpoints

   A multiparty-aware receiving party, party presenting real-time text MUST
   separate text from different sources and present them in separate
   presentation fields.  The receiving party MAY separate the
   presentation of parts of text from a source in readable groups based
   on other criteria other than line separator a Line Separator and merge these groups in the
   presentation area when it benefits the user to most easily find and
   read text from the different participants.  The criteria MAY e.g., MAY, for
   example, be a received comma, a full stop, or some other type of phrase delimiters,
   delimiter, or a long pause.

   When text is received from multiple original sources, the
   presentation SHALL provide a view where text is added in multiple
   presentation fields.

   If the presentation presents text from different sources in one
   common area, the presenting endpoint SHOULD insert text from the
   local user ended user, where the text ends at suitable points and is merged
   properly with received text to indicate the relative timing for when
   the text groups were completed.  In this presentation mode, the
   receiving endpoint SHALL present the source of the different groups
   of text.  This presentation style is called the "chat" style here and
   provides a the possibility to follow of following text arriving from multiple
   parties and the approximate relative time that text is received as
   related to text from the local user.

   A view of a three-party RTT real-time text call in chat style is shown in
   this
   example . example.

             _________________________________________________
            |                                              |^|
            |[Alice] Hi, Alice here.                       |-|
            |                                              | |
            |[Bob] Bob as well.                            | |
            |                                              | |
            |[Eve] Hi, this is Eve, calling from Paris.    | |
            |      I thought you should be here.           | |
            |                                              | |
            |[Alice] I am coming on Thursday, my           | |
            |      performance is not until Friday morning.| |
            |                                              | |
            |[Bob] And I on Wednesday evening.             | |
            |                                              | |
            |[Alice] Can we meet on Thursday evening?      | |
            |                                              | |
            |[Eve] Yes, definitely. How about 7pm.         | |
            |     at the entrance of the restaurant        | |
            |     Le Lion Blanc?                           | |
            |[Eve] we can have dinner and then take a walk |-|
            |______________________________________________|v|
            | <Eve-typing> But I need to be back to        |^|
            |    the hotel by 11 because I need            |-|
            |                                              | |
            | <Bob-typing> I wou                           |-|
            |______________________________________________|v|
            | of course, I underst                           |
            |________________________________________________|

      Figure 3: 1: Example of a three-party RTT call presented Three-Party Real-Time Text Call Presented
             in chat style
   seen Chat Style Seen at participant 'Alice's endpoint.

   Other presentation Participant Alice's Endpoint

   Presentation styles other than the chat style MAY be arranged.

   This figure

   Figure 2 shows how a coordinated column view MAY be presented.

   _____________________________________________________________________
   |       Bob          |       Eve            |       Alice           |
   |____________________|______________________|_______________________|
   |                    |                      |I will arrive by TGV.  |
   |My flight is to Orly|                      |Convenient to the main |
   |                    |Hi all, can we plan   |station.               |
   |                    |for the seminar?      |                       |
   |Eve, will you do    |                      |                       |
   |your presentation on|                      |                       |
   |Friday?             |Yes, Friday at 10.    |                       |
   |Fine, wo            |                      |We need to meet befo   |
   |___________________________________________________________________|

           Figure 4: 2: An example Example of a coordinated column-view Coordinated Column View of a three-party
   session
           Three-Party Session with entries ordered vertically Entries Ordered Vertically in approximate time-order.
                           Approximate Time Order

4.2.  Multiparty mixing Mixing for multiparty-unaware endpoints Multiparty-Unaware Endpoints

   When the mixer has indicated RTT multiparty real-time text capability in
   an SDP
   negotiation, negotiation but the multiparty capability negotiation fails
   with an endpoint, then the agreed agreed-upon "text/red" or "text/t140" format
   SHALL be used and the mixer SHOULD compose a best-effort presentation
   of multiparty real-time text in one stream intended to be presented
   by an endpoint with no multiparty awareness, when that is desired in
   the actual implementation.  The following specifies a procedure which that
   MAY be applied in that situation.

   This presentation format has functional limitations and SHOULD be
   used only to enable participation in multiparty calls by legacy
   deployed endpoints implementing only RFC 4103 without any multiparty
   extensions specified in this document.

   The principles and procedures below do not specify any new protocol
   elements.  They are instead composed of information from provided in
   [T140] and an ambition to provide a best-effort presentation on an
   endpoint
   which that has functions originally intended only for two-party
   calls.

   The mixer performing the mixing for multiparty-unaware endpoints
   SHALL compose a simulated, limited multiparty RTT real-time text view
   suitable for presentation in one presentation area.  The mixer SHALL
   group text in suitable groups and prepare them for presentation of them by
   inserting a line separator Line Separator between them if the transmitted text did
   not already end with a new line (line separator (Line Separator or CRLF).  A
   presentable label SHALL be composed and sent for the source initially
   in the session and after each source switch.  With this procedure procedure,
   the time for switching from transmission of text from one source to
   transmission of text from another source depends on the actions of
   the users.  In order to expedite source switching, a user can, for
   example, end its turn with a new line.

4.2.1.  Actions by the mixer Mixer at reception Reception from the call participants Call Participants

   When text is received by the mixer from the different participants,
   the mixer SHALL recover text from redundancy if any packets are lost.
   The mark marker for lost text [T140ad1] SHALL be inserted in the stream if
   unrecoverable loss appears.  Any Unicode "BOM" BOM characters, possibly
   used for keep-alive, keep-alives, SHALL be deleted.  The time of creation of text
   (retrieved from the RTP timestamp) SHALL be stored together with the
   received text from each source in queues for transmission to the
   recipients in order to be able to evaluate text loss.

4.2.2.  Actions by the mixer Mixer for transmission Transmission to the recipients Recipients

   The following procedure SHALL be applied for each multiparty-unaware
   recipient of multiparty text from the mixer.

   The text for transmission SHALL be formatted by the mixer for each
   receiving user for presentation in one single presentation area.
   Text received from a participant SHOULD NOT be included in
   transmission
   transmissions to that participant participant, because it is usually presented
   locally at transmission time.  When there is text available for
   transmission from the mixer to a receiving party from more than one
   participant, the mixer SHALL switch between transmission of text from
   the different sources at suitable points in the transmitted stream.

   When switching the source, the mixer SHALL insert a line separator Line Separator if
   the
   already transmitted already-transmitted text did not end with a new line (line separator (Line
   Separator or CRLF).  A label SHALL be composed of information in the
   CNAME and NAME fields in RTCP reports from the participant to have
   its text transmitted, or from other session information for that
   user.  The label SHALL be delimited by suitable characters (e.g., '[ ]')
   "[ ]") and transmitted.  The CSRC SHALL indicate the selected source.  Then
   Then, text from that selected participant SHALL be transmitted until
   a new suitable point for switching the source is reached.

   Information available to the mixer for composing the label may
   contain sensitive personal information that SHOULD NOT be revealed in
   sessions not securely authenticated and confidentiality protected.
   Privacy considerations regarding how much personal information is
   included in the label SHOULD therefore be taken when composing the
   label.

   Seeking a suitable point for switching the source SHALL be done when
   there is older text waiting for transmission from any party than the
   age of the last transmitted text.  Suitable points for switching are:

   *  A completed phrase ended by comma ending with a comma.

   *  A completed sentence sentence.

   *  A new line (line separator (Line Separator or CRLF) CRLF).

   *  A long pause (e.g., > 10 seconds) in received text from the
      currently transmitted source source.

   *  If text from one participant has been transmitted with text from
      other sources waiting for transmission for a long time (e.g., > 1
      minute) and none of the other suitable points for switching has
      occurred, a source switch MAY be forced by the mixer at the next
      word delimiter, and also even if a word delimiter does not occur
      within a some period of time (e.g., 15 seconds) after the scan for a
      word delimiter started.

   When switching the source, the source which that has the oldest text in
   queue SHALL be selected to be transmitted.  A character display count
   SHALL be maintained for the currently transmitted source, starting at
   zero after the label is transmitted for the currently transmitted
   source.

   The status SHALL be maintained for the latest control code for Select
   Graphic Rendition (SGR) from each source.  If there is an SGR code
   stored as the status for the current source before the source switch
   is done, a reset of SGR SHALL be sent by the sequence SGR 0 [009B
   0000 006D] [U+009B
   U+0000 U+006D] after the new line and before the new label during a
   source switch.  See SGR below Section 4.2.4 for an explanation.  This
   transmission does not influence the display count.

   If there is an SGR code stored for the new source after the source
   switch, that SGR code SHALL be transmitted to the recipient before
   the label.  This transmission does not influence the display count.

4.2.3.  Actions on transmission Transmission of text Text

   Text from a source sent to the recipient SHALL increase the display
   count by one per transmitted character.

4.2.4.  Actions on transmission Transmission of control codes Control Codes

   The following control codes codes, as specified by T.140 [T140], require
   specific actions.  They SHALL cause specific considerations in the
   mixer.  Note that the codes presented here are expressed in UCS-16, UTF-16,
   while transmission is made in the UTF-8 encoding of these codes.

   BEL 0007 Bell (U+0007):  Bell.  Alert in session.  Provides for alerting during
      an active session.  The display count SHALL NOT be altered.

   NEW LINE 2028 (U+2028):  Line separator. Separator.  Check and perform a source
      switch if appropriate.  Increase the display count by 1.

   CR LF 000D 000A (U+000D U+000A):  A supported supported, but not preferred preferred, way of
      requesting a new line.  Check and perform a source switch if
      appropriate.  Increase the display count by 1.

   INT ESC 0061 (ESC U+0061):  Interrupt (used to initiate the mode negotiation
      procedure).  The display count SHALL NOT be altered.

   SGR 009B (U+009B Ps 006D U+006D):  Select graphic rendition. Graphic Rendition.  Ps is represents the
      rendition parameters specified in ISO 6429. [ISO6429].  (For freely
      available equivalent information, please see [ECMA-48].)  The
      display count SHALL NOT be altered.  The SGR code SHOULD be stored
      for the current source.

   SOS 0098 (U+0098):  Start of string, used String.  Used as a general protocol element
      introducer, followed by a maximum 256-byte string and the ST.  The
      display count SHALL NOT be altered.

   ST 009C (U+009C):  String terminator, end Terminator.  End of SOS string.  The display
      count SHALL NOT be altered.

   ESC 001B  Escape - used (U+001B):  Escape.  Used in control strings.  The display count
      SHALL NOT be altered for the complete escape code.

   Byte order mark "BOM" (U+FEFF) (BOM) (U+FEFF):  "Zero width, no break space", used width no-break space".  Used
      for synchronization and keep-alive.  It SHALL be deleted from
      incoming streams.  It SHALL also be sent first after session
      establishment to the recipient.  The display count SHALL NOT be
      altered.

   Missing text mark (U+FFFD) (U+FFFD):  "Replacement character", represented character".  Represented as
      a question mark in a rhombus, or or, if that is not feasible,
      replaced by an apostrophe '. (').  It marks the place in the stream
      of possible text loss.  This mark SHALL be inserted by the
      reception procedure in the case of unrecoverable loss of packets.
      The display count SHALL be increased by one when sent as for any
      other character.

   SGR

   SGR:  If a control code for selecting graphic rendition (SGR) SGR other than a reset of the graphic
      rendition (SGR 0) is sent to a recipient, that control code SHALL
      also be stored as the status for the source in the storage for SGR
      status.  If a reset graphic rendition (SGR 0) originating from a
      source is sent, then the SGR status storage for that source SHALL
      be cleared.  The display count SHALL NOT be increased.

   BS (U+0008)  Back Space, intended (U+0008):  "Back Space".  Intended to erase the last entered
      character by a source.  Erasure by backspace cannot always be
      performed as the erasing party intended.  If an erasing action
      erases all text up to the end of the leading label after a source
      switch, then the mixer MUST NOT transmit more backspaces.
      Instead, it is RECOMMENDED that a letter "X" is be inserted in the
      text stream for each backspace as an indication of the intent to
      erase more.  A new line is usually coded by a Line Separator, but
      the character combination "CRLF" MAY be used instead.  Erasure of
      a new line is is, in both cases cases, done by just one erasing action (Backspace).
      (backspace).  If the display count has a positive value value, it SHALL
      be decreased by one when the BS is sent.  If the display count is
      at zero, it SHALL NOT be altered.

4.2.5.  Packet transmission Transmission

   A mixer transmitting to a multiparty-unaware terminal endpoint SHALL send
   primary data only from one source per packet.  The SSRC SHALL be the
   SSRC of the mixer.  The CSRC list SHALL MAY contain one member and be the
   SSRC of the source of the primary data.

4.2.6.  Functional limitations Limitations

   When a multiparty-unaware endpoint presents a conversation in one
   display area in a chat style, it inserts source indications for
   remote text and local user text as they are merged in completed text
   groups.  When an endpoint using this layout receives and presents
   text mixed for multiparty-unaware endpoints, there will be two levels
   of source indicators for the received text; text: one generated by the
   mixer and inserted in a label after each source switch, and another
   generated by the receiving endpoint and inserted after each switch
   between the local source and the remote source in the presentation
   area.  This will waste display space and look inconsistent to the
   reader.

   New text can be presented only from only one source at a time.  Switch of  Switching
   the source to be presented takes place at suitable places in the
   text, such as the end of a phrase, the end of a sentence, line separator and or a Line
   Separator, or upon detecting inactivity.  Therefore, the time to
   switch to present waiting text from other sources may become long grow long, and
   it will vary and depend on the actions of the currently presented
   source.

   Erasure can only be done up to the latest source switch.  If a user
   tries to erase more text, the erasing actions will be presented as a
   letter X "X" after the label.

   Text loss because of network errors may hit the label between entries
   from different parties, causing the risk for of a misunderstanding from
   regarding which source provided a piece of text is.

   These facts make text.

   Because of these facts, it is strongly RECOMMENDED implementing that multiparty
   awareness be implemented in RTT real-time text endpoints.  The use of the
   mixing method for multiparty-unaware endpoints should be left for use
   with endpoints
   which that are impossible to upgrade to become multiparty-aware. multiparty
   aware.

4.2.7.  Example views Views of presentation Presentation on multiparty-unaware endpoints Multiparty-Unaware Endpoints

   The following pictures are examples of the view on a participant's
   display for the multiparty-unaware case.

   This figure

   Figure 3 shows how a coordinated column view MAY be presented on
   Alice's device in a view with two-columns. two columns.  The mixer inserts labels
   to show how the sources alternate in the column with received text.
   The mixer alternates between the sources at suitable points in the
   text exchange so that text entries from each party can be
   conveniently read.
     _________________________________________________

             ___________________________________________________
            |       Conference        |          Alice          |
    |________________________|_________________________|
            |_________________________|_________________________|
            |                         |I will arrive by TGV.    |
    |[Bob]:My
            |[Bob]: My flight is to   |Convenient to the main   |
            |Orly.                    |station.                 |
    |[Eve]:Hi
            |[Eve]: Hi all, can we    |                         |
            |plan for the seminar.    |                         |
            |                         |                         |
    |[Bob]:Eve,
            |[Bob]: Eve, will you do  |                         |
            |your presentation on     |                         |
            |Friday?                  |                         |
    |[Eve]:Yes,
            |[Eve]: Yes, Friday at 10.|                         |
            |[Bob]: Fine, wo          |We need to meet befo     |
    |________________________|_________________________|
            |_________________________|_________________________|

          Figure 5: Alice who has a conference-unaware client is receiving 3: Alice, Who Has a Conference-Unaware Client, Is
         Receiving the
   multiparty real-time text Multiparty Real-Time Text in a single-stream. Single Stream

   In this view, Figure 4, there is a tradition in receiving applications to
   include a label showing the source of the text, here shown with
   parenthesis
   parentheses "()".  The mixer also inserts source labels for the
   multiparty call participants, here shown with brackets "[]".

              _________________________________________________
             |                                              |^|
             |(Alice) Hi, Alice here.                       |-|
             |                                              | |
    |(mix)[Bob)]
             |(mix)[Bob] Bob as well.                       | |
             |                                              | |
             |[Eve] Hi, this is Eve, calling from Paris     | |
             |      I thought you should be here.           | |
             |                                              | |
             |(Alice) I am coming on Thursday, my           | |
             |      performance is not until Friday morning.| |
             |                                              | |
             |(mix)[Bob] And I on Wednesday evening.        | |
             |                                              | |
             |[Eve] we can have dinner and then walk        | |
             |                                              | |
             |[Eve] But I need to be back to                | |
             |    the hotel by 11 because I need            | |
             |                                              |-|
             |______________________________________________|v|
             | of course, I underst                           |
             |________________________________________________|

          Figure 6: 4: An example Example of a view View of the multiparty-unaware presentation Multiparty-Unaware
         Presentation in chat style. Chat Style, Where Alice is Is the local user. Local User

5.  Relation  Relationship to Conference Control

5.1.  Use with SIP centralized conferencing framework Centralized Conferencing Framework

   The Session Initiation Protocol (SIP) conferencing framework, mainly
   specified in [RFC4353], [RFC4579] [RFC4579], and [RFC4575] [RFC4575], is suitable for
   coordinating sessions sessions, including multiparty RTT. real-time text.  The RTT
   real-time text stream between the mixer and a participant is one and
   the same during the conference.  Participants get announced by
   notifications when participants are joining or leaving, and further
   user information may be provided.  The SSRC of the text to expect
   from joined users MAY be included in a notification.  The
   notifications MAY be used both for both security purposes and for translation
   to a label for presentation to other users.

5.2.  Conference control Control

   In managed conferences, control of the real-time text media SHOULD be
   provided in the same way as other for other media, e.g., for muting and
   unmuting by the direction attributes in SDP [RFC8866].

   Note that floor control functions may be of value for RTT real-time text
   users as well as for users of other media in a conference.

6.  Gateway Considerations

6.1.  Gateway considerations with Textphones

   multiparty RTT conference.

6.  Gateway Considerations

   Multiparty real-time text sessions may involve gateways of different
   kinds.  Gateways involved in setting up sessions SHALL correctly
   reflect the multiparty capability or unawareness of the combination
   of the gateway and the remote endpoint beyond the gateway.

6.1.  Gateway Considerations with Textphones

   One case that may occur is a gateway to the Public Switched Telephone
   Network (PSTN) for communication with textphones (e.g., TTYs).
   Textphones are limited devices with no multiparty awareness, and it
   SHOULD therefore be suitable appropriate for the gateway to not indicate
   multiparty awareness for that case.  Another solution is that the
   gateway indicates multiparty capability towards the mixer, mixer and
   includes the multiparty mixer function for multiparty-unaware
   endpoints itself.  This solution makes it possible to adapt to the
   functional limitations of the textphone.

   More information on gateways to textphones is found in [RFC5194] [RFC5194].

6.2.  Gateway considerations Considerations with WebRTC

   Gateway operation to between RTP-mixer-based multiparty real-time text
   and WebRTC-based real-time text in WebRTC may also be required.
   In WebRTC, RTT  Real-time text
   transport in WebRTC is specified in [RFC8865].

   A multiparty bridge may have functionality for communicating by RTT
   both via
   real-time text in both (1) RTP streams with RTT real-time text and (2)
   WebRTC T.140 data channels.  Other configurations may consist of a
   multiparty bridge with either technology for RTT real-time text transport
   and a separate gateway for conversion of the text communication
   streams between RTP and T.140 data channel. channels.

   In WebRTC, it is assumed that for a multiparty session, one T.140
   data channel is established for each source from a gateway or bridge
   to each participant.  Each participant also has a data channel with a
   two-way connection with the gateway or bridge.

   The

   A T.140 data channel used both ways for two-way communication is for text from
   the WebRTC user and from the bridge or gateway itself to the WebRTC
   user.  The label parameter of this T.140 data channel is used as the
   NAME field in RTCP to participants on the RTP side.  The other T.140
   data channels are only for text from other participants to the WebRTC
   user.

   When a new participant has entered the session with RTP transport of
   RTT,
   real-time text, a new T.140 data channel SHOULD be established to
   WebRTC users with the label parameter composed of information from
   the NAME field in RTCP on the RTP side.

   When a new participant has entered the multiparty session with RTT real-
   time text transport in a WebRTC T.140 data channel, the new
   participant SHOULD be announced by a notification to RTP users.  The
   label parameter from the WebRTC side or other suitable information
   from the session or stream establishment procedure SHOULD be used as to
   compose the NAME RTCP field on the RTP
   side, or other available session information. side.

   When a participant on the RTP side is disconnected from the
   multiparty session, the corresponding T.140 data channel(s) SHOULD be
   closed.

   When a WebRTC user of T.140 data channels disconnects from the mixer,
   the corresponding RTP streams or sources in an RTP-mixed stream
   SHOULD be closed.

   T.140 data channels MAY be opened and closed by negotiation or
   renegotiation of the session session, or by any other valid means means, as
   specified in section Section 1 of [RFC8865].

7.  Updates to RFC 4103

   This document updates [RFC4103] by introducing an SDP media attribute
   "rtt-mixer"
   attribute, "rtt-mixer", for negotiation of multiparty-mixing
   capability with the format described in [RFC4103] format, and by specifying
   the rules for packets when multiparty capability is negotiated and in
   use.

8.  Congestion considerations Considerations

   The congestion considerations and recommended actions from provided in
   [RFC4103] are also valid in multiparty situations.

   The time values SHALL then be applied per source of text sent to a
   receiver.

   If

   In the very unlikely situation appears event that many participants in a conference
   send text simultaneously for a long period, period of time, a delay may build
   up for the presentation of text at the receivers if the limitation in
   characters per second ("cps") to be transmitted to the participants
   is exceeded.  More  A delay of more than 7 15 seconds can cause confusion in
   the session.  It is therefore RECOMMENDED that an RTP-
   mixer-based RTP mixer discards discard
   such text causing excessive delays and
   inserts insert a general indication of
   possible text loss [T140ad1] in the session.  If the main text
   contributor is indicated in any way, the mixer MAY avoid deleting
   text from that participant.  It should
   however should, however, be noted that human
   creation of text normally contains pauses, when the transmission can
   catch up, so that the transmission
   overload transmission-overload situations are expected to be
   very rare.

9.  IANA Considerations

9.1.  Registration of the "rtt-mixer" SDP media attribute

   [RFC EDITOR NOTE: Please replace all instances of RFCXXXX with the
   RFC number of this document.] Media Attribute

   IANA is asked to register has registered the new SDP attribute "rtt-mixer".

   Contact name:  IESG

   Contact email:  iesg@ietf.org

   Attribute name:  rtt-mixer

   Attribute semantics:  See RFCXXXX RFC 9071, Section 2.3

   Attribute value:  none

   Usage level:  media

   Purpose:  Indicate support by  To indicate mixer and endpoint support of multiparty mixing
      for real-time text transmission, using a common RTP-stream RTP stream for
      transmission of text from a number of sources mixed with one
      source at a time and where the source is indicated in a single
      CSRC-list member.

   Charset Dependent:  no

   O/A procedure: procedures:  See RFCXXXX RFC 9071, Section 2.3

   Mux Category:  normal

   Reference:  RFCXXXX  RFC 9071

10.  Security Considerations

   The RTP-mixer model requires the mixer to be allowed to decrypt,
   pack, and encrypt secured text from the conference participants.
   Therefore, the mixer needs to be trusted to maintain confidentiality
   and integrity of the RTT real-time text data.  This situation is similar
   to the situation for handling audio and video media in centralized
   mixers.

   The requirement to transfer information about the user in RTCP
   reports in SDES, CNAME, and NAME fields, and in conference
   notifications, may have privacy concerns concerns, as already stated in RFC
   3550 [RFC3550], and may be restricted for privacy reasons.  When used
   for the creation of readable labels in the presentation, the
   receiving user will then get a more symbolic label for the source.

   The services available through the RTT real-time text mixer may have be of
   special interest for to deaf and hard-of-hearing persons. individuals.  Some users
   may want to refrain from revealing such characteristics broadly in
   conferences.  The design of the conference  Conference systems where the mixer is included MAY need
   to be made designed with the confidentiality of such characteristics in
   mind.

   Participants with malicious intentions may appear and e.g., disturb and, for example,
   disrupt the multiparty session by emitting a continuous flow of text.
   They may also send text that appears to originate from other
   participants.
   Counteractions  Countermeasures should be to require include requiring secure
   signaling, media media, and authentication, and to provide providing higher-layer
   conference functions functions, e.g., for blocking, muting, and expelling
   participants.

   Participants with malicious intentions may also try to disturb disrupt the
   presentation by sending incomplete or malformed control codes.
   Handling of text from the different sources by the receivers MUST
   therefore be well separated so that the effects of such actions only
   affect text from the source causing the action.

   Care should be taken that to avoid the possibility of attacks by
   unauthenticated call participants, and even eavesdropping and
   manipulation of content by non-participants, if the use of the mixer
   is allowed permitted for users both with and without security procedures, opens for possible attacks
   by both unauthenticated call participants and even eavesdropping and
   manipulating of content non-participants. procedures.

   As already stated in Section 3.18, security in media SHOULD be
   applied by using DTLS-SRTP [RFC5764] on at the media level.

   Further security considerations specific for to this application are
   specified in Section 3.18.

12.

11.  References

12.1.

11.1.  Normative References

   [ECMA-48]  Ecma International, "ECMA-48: Control functions for coded
              character sets", 5th edition, June 1991,
              <https://www.ecma-international.org/publications-and-
              standards/standards/ecma-48/>.

   [ISO6429]  ISO/IEC, "Information technology - Control functions for
              coded character sets", ISO/IEC ISO/IEC 6429:1992, December
              1992, <https://www.iso.org/obp/ui/#iso:std:iso-
              iec:6429:ed-3:v1:en>.

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

   [RFC3550]  Schulzrinne, H., Casner, S., Frederick, R., and V.
              Jacobson, "RTP: A Transport Protocol for Real-Time
              Applications", STD 64, RFC 3550, DOI 10.17487/RFC3550,
              July 2003, <https://www.rfc-editor.org/info/rfc3550>.

   [RFC4102]  Jones, P., "Registration of the text/red MIME Sub-Type",
              RFC 4102, DOI 10.17487/RFC4102, June 2005,
              <https://www.rfc-editor.org/info/rfc4102>.

   [RFC4103]  Hellstrom, G. and P. Jones, "RTP Payload for Text
              Conversation", RFC 4103, DOI 10.17487/RFC4103, June 2005,
              <https://www.rfc-editor.org/info/rfc4103>.

   [RFC5630]  Audet, F., "The Use of the SIPS URI Scheme in the Session
              Initiation Protocol (SIP)", RFC 5630,
              DOI 10.17487/RFC5630, October 2009,
              <https://www.rfc-editor.org/info/rfc5630>.

   [RFC5764]  McGrew, D. and E. Rescorla, "Datagram Transport Layer
              Security (DTLS) Extension to Establish Keys for the Secure
              Real-time Transport Protocol (SRTP)", RFC 5764,
              DOI 10.17487/RFC5764, May 2010,
              <https://www.rfc-editor.org/info/rfc5764>.

   [RFC6263]  Marjou, X. and A. Sollaud, "Application Mechanism for
              Keeping Alive the NAT Mappings Associated with RTP / RTP
              Control Protocol (RTCP) Flows", RFC 6263,
              DOI 10.17487/RFC6263, June 2011,
              <https://www.rfc-editor.org/info/rfc6263>.

   [RFC7675]  Perumal, M., Wing, D., Ravindranath, R., Reddy, T., and M.
              Thomson, "Session Traversal Utilities for NAT (STUN) Usage
              for Consent Freshness", RFC 7675, DOI 10.17487/RFC7675,
              October 2015, <https://www.rfc-editor.org/info/rfc7675>.

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

   [RFC8865]  Holmberg, C. and G. Hellström, "T.140 Real-Time Text
              Conversation over WebRTC Data Channels", RFC 8865,
              DOI 10.17487/RFC8865, January 2021,
              <https://www.rfc-editor.org/info/rfc8865>.

   [RFC8866]  Begen, A., Kyzivat, P., Perkins, C., and M. Handley, "SDP:
              Session Description Protocol", RFC 8866,
              DOI 10.17487/RFC8866, January 2021,
              <https://www.rfc-editor.org/info/rfc8866>.

   [T140]     ITU-T, "Recommendation ITU-T T.140 (02/1998), Protocol "Protocol for multimedia application text
              conversation", ITU-T Recommendation T.140, February 1998,
              <https://www.itu.int/rec/T-REC-T.140-199802-I/en>.

   [T140ad1]  ITU-T, "Recommendation ITU-T.140 Addendum 1 - (02/2000),
              Protocol for multimedia application text conversation", T.140 Addendum", February 2000,
              <https://www.itu.int/rec/T-REC-T.140-200002-I!Add1/en>.

12.2.

11.2.  Informative References

   [RFC4353]  Rosenberg, J., "A Framework for Conferencing with the
              Session Initiation Protocol (SIP)", RFC 4353,
              DOI 10.17487/RFC4353, February 2006,
              <https://www.rfc-editor.org/info/rfc4353>.

   [RFC4575]  Rosenberg, J., Schulzrinne, H., and O. Levin, Ed., "A
              Session Initiation Protocol (SIP) Event Package for
              Conference State", RFC 4575, DOI 10.17487/RFC4575, August
              2006, <https://www.rfc-editor.org/info/rfc4575>.

   [RFC4579]  Johnston, A. and O. Levin, "Session Initiation Protocol
              (SIP) Call Control - Conferencing for User Agents",
              BCP 119, RFC 4579, DOI 10.17487/RFC4579, August 2006,
              <https://www.rfc-editor.org/info/rfc4579>.

   [RFC5194]  van Wijk, A., Ed. and G. Gybels, Ed., "Framework for Real-
              Time Text over IP Using the Session Initiation Protocol
              (SIP)", RFC 5194, DOI 10.17487/RFC5194, June 2008,
              <https://www.rfc-editor.org/info/rfc5194>.

   [RFC7667]  Westerlund, M. and S. Wenger, "RTP Topologies", RFC 7667,
              DOI 10.17487/RFC7667, November 2015,
              <https://www.rfc-editor.org/info/rfc7667>.

   [RFC8643]  Johnston, A., Aboba, B., Hutton, A., Jesske, R., and T.
              Stach, "An Opportunistic Approach for Secure Real-time
              Transport Protocol (OSRTP)", RFC 8643,
              DOI 10.17487/RFC8643, August 2019,
              <https://www.rfc-editor.org/info/rfc8643>.

   [RFC8723]  Jennings, C., Jones, P., Barnes, R., and A.B. Roach,
              "Double Encryption Procedures for the Secure Real-Time
              Transport Protocol (SRTP)", RFC 8723,
              DOI 10.17487/RFC8723, April 2020,
              <https://www.rfc-editor.org/info/rfc8723>.

   [RFC8825]  Alvestrand, H., "Overview: Real-Time Protocols for
              Browser-Based Applications", RFC 8825,
              DOI 10.17487/RFC8825, January 2021,
              <https://www.rfc-editor.org/info/rfc8825>.

Acknowledgements

   The author want wants to thank the following persons for support, reviews reviews,
   and valuable comments: Bernard Aboba, Amanda Baber, Roman Danyliw,
   Spencer Dawkins, Martin Duke, Lars Eggert, James Hamlin, Benjamin
   Kaduk, Murray Kucherawy, Paul Kyziwat, Kyzivat, Jonathan Lennox, Lorenzo
   Miniero, Dan Mongrain, Francesca Palombini, Colin Perkins, Brian
   Rosen, Juergen Schoenwaelder, Rich Salz, Jürgen Schönwälder, Robert Wilton, Dale Worley,
   Peter Yee and
   Yong Xin. Xin, and Peter Yee.

Author's Address

   Gunnar Hellstrom Hellström
   Gunnar Hellstrom Hellström Accessible Communication
   SE-13670 Vendelso Vendelsö
   Sweden

   Email: gunnar.hellstrom@ghaccess.se