1. Introduction
This section is non-normative.
This specification uses [RFC3550] to send and receive RTP and RTCP packets.
Note: The API presented in this specification represents a preliminary proposal based on work-in-progress within the W3C WEBRTC WG. As a result, the API is likely to change significantly going forward.
2. Conformance
As well as sections marked as non-normative, all authoring guidelines, diagrams, examples, and notes in this specification are non-normative. Everything else in this specification is normative.
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" are to be interpreted as described in [RFC2119] and [RFC8174] when, and only when, they appear in all capitals, as shown here.
This specification defines conformance criteria that apply to a single product: the user agent that implements the interfaces that it contains.
Conformance requirements phrased as algorithms or specific steps may be implemented in any manner, so long as the end result is equivalent. (In particular, the algorithms defined in this specification are intended to be easy to follow, and not intended to be performant.)
Implementations that use ECMAScript to implement the APIs defined in this specification MUST implement them in a manner consistent with the ECMAScript Bindings defined in the Web IDL specification [WEBIDL], as this specification uses that specification and terminology.
3. Terminology
Terminology definitions go here.
4. RTCRtpTransport
Interface
[Exposed =(Window )]interface RTCRtpTransport {attribute EventHandler onpacketizedrtpavailable ;sequence <RTCRtpPacket >readPacketizedRtp (unsigned long ); // BYOP: Copies the read packets into dstPackets, returning the number of packets written (up to dstPackets.length).
maxNumberOfPackets unsigned long readPacketizedRtp (sequence <RTCRtpPacket >);
dstPackets attribute EventHandler onsentrtp ; // Batch interface to read RTCRtpSent notifications.sequence <RTCRtpSent >readSentRtp (long );
maxCount attribute EventHandler onreceivedrtpacks ; // No payload. Use readReceivedRtpAcks // Batch interface to read RTCRtpAcks as an alternative to onrtpacksreceived.sequence <RTCRtpAcks >readReceivedRtpAcks (long );
maxCount readonly attribute unsigned long bandwidthEstimate ; // bpsreadonly attribute unsigned long allocatedBandwidth ; // bpsattribute unsigned long customAllocatedBandwidth ; // writable // Means "when doing bitrate allocation and rate control, don’t use more than this"attribute unsigned long customMaxBandwidth ; // Means "make each packet smaller by this much so I can put custom stuff in each packet"attribute unsigned long customPerPacketOverhead ; };
4.1. Attributes
-
onpacketizedrtpavailable
, of type EventHandler -
onsentrtp
, of type EventHandler -
onreceivedrtpacks
, of type EventHandler -
bandwidthEstimate
, of type unsigned long, readonly -
allocatedBandwidth
, of type unsigned long, readonly -
customAllocatedBandwidth
, of type unsigned long -
customMaxBandwidth
, of type unsigned long -
customPerPacketOverhead
, of type unsigned long
4.2. Methods
-
readPacketizedRtp(unsigned long maxNumberOfPackets)
-
readPacketizedRtp(sequence<RTCRtpPacket> dstPackets)
-
readSentRtp(long maxCount)
-
readReceivedRtpAcks(long maxCount)
5. Objects
5.1. RTCRtpPacket
Interface
[Exposed =(Window )]interface RTCRtpPacket {(
constructor RTCRtpPacketInit ); // BYOP: Construct a packet that can be used as destination for writing read packets.
init ();
constructor attribute boolean marker ;attribute octet payloadType ;attribute unsigned short sequenceNumber ;attribute unsigned long timestamp ;attribute unsigned long ssrc ;sequence <unsigned long >getCsrcs ();undefined setCsrcs (sequence <unsigned long >);
csrcs sequence <RTCRtpHeaderExtension >getHeaderExtensions ();undefined setHeaderExtensions (sequence <RTCRtpHeaderExtension >);
headerExtensions attribute unsigned long paddingBytes ;attribute AllowSharedBufferSource ; // OPTIONAL: Extra information that may be useful to know
payload attribute DOMHighResTimeStamp ?receivedTime ;attribute unsigned long ?sequenceNumberRolloverCount ; };
-
marker
, of type boolean -
payloadType
, of type octet -
sequenceNumber
, of type unsigned short -
timestamp
, of type unsigned long -
ssrc
, of type unsigned long -
paddingBytes
, of type unsigned long -
receivedTime
, of type DOMHighResTimeStamp, nullable -
sequenceNumberRolloverCount
, of type unsigned long, nullable
-
getCsrcs()
-
setCsrcs(sequence<unsigned long> csrcs)
-
getHeaderExtensions()
-
setHeaderExtensions(sequence<RTCRtpHeaderExtension> headerExtensions)
5.2. RTCRtpHeaderExtension
Interface
[Exposed =(Window )]interface RTCRtpHeaderExtension {(
constructor RTCRtpHeaderExtensionInit );
init readonly attribute DOMString uri ;readonly attribute unsigned long valueByteLength ; // Write the extension’s value to the specified (Shared-)ArrayBuffer/ArrayBufferView, // allowing for BYOB. Throws a TypeError if |destination| is smaller than // |valueByteLength|.undefined copyValueTo (AllowSharedBufferSource ); };
destination
-
uri
, of type DOMString, readonly -
valueByteLength
, of type unsigned long, readonly
-
copyValueTo(AllowSharedBufferSource destination)
5.3. RTCRtpHeaderExtensionInit
Dictionary
dictionary RTCRtpHeaderExtensionInit {required DOMString uri ;required AllowSharedBufferSource value ; };
-
uri
, of type DOMString -
value
, of type AllowSharedBufferSource
5.4. RTCRtpPacketInit
Dictionary
dictionary RTCRtpPacketInit {boolean marker =false ;required octet payloadType ;required unsigned long timestamp ;sequence <unsigned long >csrcs = []; // Cannot be MID, RID, or congestion control sequence numbersequence <RTCRtpHeaderExtensionInit >headerExtensions = [];required AllowSharedBufferSource payload ; // Causes padding bit to be set and padding added when serializing if > 0.unsigned long paddingBytes = 0; };
-
marker
, of type boolean, defaulting tofalse
-
payloadType
, of type octet -
timestamp
, of type unsigned long -
csrcs
, of typesequence<unsigned long>
, defaulting to[]
-
headerExtensions
, of type sequence<RTCRtpHeaderExtensionInit>, defaulting to[]
-
payload
, of type AllowSharedBufferSource -
paddingBytes
, of type unsigned long, defaulting to0
5.5. RTCRtpAcks
Interface
[Exposed =(Window )]interface RTCRtpAcks {sequence <RTCRtpAck >getAcks ();readonly attribute unsigned long long remoteSendTimestamp ;readonly attribute DOMHighResTimeStamp receivedTime ;readonly attribute RTCExplicitCongestionNotification explicitCongestionNotification ; // AKA "ECN" };
-
getAcks()
-
remoteSendTimestamp
, of type unsigned long long, readonly -
receivedTime
, of type DOMHighResTimeStamp, readonly -
explicitCongestionNotification
, of type RTCExplicitCongestionNotification, readonly
5.6. RTCRtpAck
[Exposed =(Window )]interface RTCRtpAck { // Correlated with RtpSent.ackIdreadonly attribute unsigned long long ackId ;readonly attribute unsigned long long remoteReceiveTimestamp ; };
-
ackId
, of type unsigned long long, readonly -
remoteReceiveTimestamp
, of type unsigned long long, readonly
5.7. RTCExplicitCongestionNotification
enum RTCExplicitCongestionNotification { // ECT = ECN-Capable Transport, // AKA "Not-ECT"; Bits: 00
"unset" , // AKA "ECT(1)" or "Scalable" or "L4S" ; Bits: 01
"scalable-congestion-not-experienced" , // AKA "ECT(0)" or "Classic" or "not L4S"; Bits: 10
"classic-congestion-not-experienced" // AKA "CE" or "ECN-marked" or "marked"; Bits: 11 };
"congestion-experienced"
6. RTCRtpPacketSender
Interface
[Exposed =(Window ,Worker ),Transferable ]interface RTCRtpPacketSender {readonly attribute DOMString ?mid ;readonly attribute DOMString ?rid ;readonly attribute unsigned long ssrc ;readonly attribute unsigned long rtxSsrc ;attribute EventHandler onpacketizedrtp ;sequence <RTCRtpPacket >readPacketizedRtp (unsigned long ); // BYOP: Copies the read packets into dstPackets, returning the number of packets written (up to dstPackets.length).
maxNumberOfPackets unsigned long readPacketizedRtp (sequence <RTCRtpPacket >); // https://github.com/w3c/webrtc-rtptransport/issues/32
dstPackets undefined sendRtp (RTCRtpPacket );
packet Promise <RTCRtpSendResult >sendRtp (RTCRtpPacketInit ,
packetInit optional RTCRtpSendOptions = {}); // Amount allocated by the browser
options readonly attribute unsigned long ; };
allocatedBandwidth
-
mid
, of type DOMString, readonly, nullable -
rid
, of type DOMString, readonly, nullable -
ssrc
, of type unsigned long, readonly -
rtxSsrc
, of type unsigned long, readonly -
onpacketizedrtp
, of type EventHandler
-
readPacketizedRtp(unsigned long maxNumberOfPackets)
-
readPacketizedRtp(sequence<RTCRtpPacket> dstPackets)
-
sendRtp(RTCRtpPacket packet)
-
sendRtp(RTCRtpPacketInit packetInit, optional RTCRtpSendOptions options = {})
6.1. RTCRtpSendResult
Interface
[Exposed =(Window )]interface RTCRtpSendResult {readonly attribute RTCRtpSent ?sent ;readonly attribute RTCRtpUnsentReason ?unsent ; };
-
sent
, of type RTCRtpSent, readonly, nullable -
unsent
, of type RTCRtpUnsentReason, readonly, nullable
6.2. RTCRtpSent
Interface
[Exposed =(Window )]interface RTCRtpSent {readonly attribute DOMHighResTimeStamp time ; // Can be correlated with acksreadonly attribute unsigned long long ?ackId ;readonly attribute unsigned long long size ; };
-
time
, of type DOMHighResTimeStamp, readonly -
ackId
, of type unsigned long long, readonly, nullable -
size
, of type unsigned long long, readonly
6.3. RTCRtpUnsentReason
Enum
enum RTCRtpUnsentReason {,
"overuse" , };
"transport-unavailable"
6.4. RTCRtpSendOptions
Dictionary
dictionary RTCRtpSendOptions {DOMHighResTimeStamp sendTime ; };
-
sendTime
, of type DOMHighResTimeStamp
7. RTCRtpPacketReceiver
Interface
[Exposed =(Window ,Worker ),Transferable ]interface RTCRtpPacketReceiver {readonly attribute DOMString ?mid ;readonly attribute DOMString ?rid ; // Unique to RTCRtpPacketReceiver (scoped to MID)sequence <unsigned long >getSsrcs ();sequence <unsigned long >getRtxSsrcs ();attribute EventHandler onreceivedrtp ;sequence <RTCRtpPacket >readReceivedRtp (long ); // BYOP: Copies the read packets into dstPackets, returning the number of packets written (up to dstPackets.length).
maxNumberOfPackets unsigned long readReceivedRtp (sequence <RTCRtpPacket >);
dstPackets undefined receiveRtp (RTCRtpPacket ); };
packet
-
mid
, of type DOMString, readonly, nullable -
rid
, of type DOMString, readonly, nullable -
onreceivedrtp
, of type EventHandler
-
readReceivedRtp(long maxNumberOfPackets)
-
readReceivedRtp(sequence<RTCRtpPacket> dstPackets)
-
receiveRtp(RTCRtpPacket packet)
-
getSsrcs()
-
getRtxSsrcs()
8. Interface Extensions
8.1. RTCPeerConnection Interface Extensions
partial interface RTCPeerConnection { // There may be an RtpTransport with no RtpSenders and no RtpReceivers.readonly attribute RTCRtpTransport ?rtpTransport ; };
-
rtpTransport
, of type RTCRtpTransport, readonly, nullable
8.2. RTCRtpSender Interface Extensions
partial interface RTCRtpSender { // shared between RTCRtpSenders in the same BUNDLE groupreadonly attribute RTCRtpTransport ?rtpTransport ;Promise <RTCRtpPacketSender >replacePacketSender (); };
-
rtpTransport
, of type RTCRtpTransport, readonly, nullable -
replacePacketSender()
8.3. RTCConfiguration Dictionary Extensions
partial dictionary RTCConfiguration { // Means "continue to encode and packetize packets, but don’t send them. // Instead give them to me via onpacketizedrtpavailable/readPacketizedRtp // and I will send them." // TODO: Think of a better nameboolean customPacer ; };
-
customPacer
, of type boolean
8.4. RTCRtpReceiver Interface Extensions
partial interface RTCRtpReceiver { // shared between RTCRtpSenders in the same BUNDLE groupreadonly attribute RTCRtpTransport ?rtpTransport ;Promise <RTCRtpPacketReceiver >replacePacketReciever (); };
-
rtpTransport
, of type RTCRtpTransport, readonly, nullable -
replacePacketReciever()
9. Privacy and security considerations
9.1. Confidentiality of Communications
9.2. State Persistence
9.3. Protocol Security
9.4. Fingerprinting and Tracking
10. Examples
See the explainer document.