RTCRtpTransceiver: direction property

Baseline Widely available *

This feature is well established and works across many devices and browser versions. It’s been available across browsers since January 2020.

* Some parts of this feature may have varying levels of support.

The RTCRtpTransceiver property direction is a string that indicates the transceiver's preferred directionality.

The directionality indicates whether the transceiver will offer to send and/or receive RTP data, or whether it is inactive or stopped (terminated). When setting the transceiver's direction, the value is not applied immediately. The current direction is indicated by the currentDirection property.

Value

A string with one of the following values:

"sendrecv"

Transceiver offers to send and receive RTP data:

  • RTCRtpSender: Offers to send RTP data, and will do so if the remote peer accepts the connection and at least one of the sender's encodings is active.
  • RTCRtpReceiver: Offers to receive RTP data, and does so if the remote peer accepts.
"sendonly"

Transceiver offers to send but not receive RTP data:

  • RTCRtpSender: Offers to send RTP data, and will do so if the remote peer accepts the connection and at least one of the sender's encodings is active.
  • RTCRtpReceiver: Does not offer to receive RTP data and will not do so.
"recvonly"

Transceiver offers to receive but not set RTP data:

  • RTCRtpSender: Does not offer to send RTP data, and will not do so.
  • RTCRtpReceiver: Offers to receive RTP data, and will do so if the remote peer offers.
"inactive"

Transceiver is inactive:

  • RTCRtpSender: Does not offer to send RTP data, and will not do so.
  • RTCRtpReceiver: Does not offer to receive RTP data and will not do so.
"stopped"

This is the terminal state of the transceiver. The transceiver is stopped and will not send or receive RTP data or offer to do so. Setting this value when the transceiver is not already stopped raises a TypeError.

  • RTCRtpSender: Does not offer to send RTP data, and will not do so.
  • RTCRtpReceiver: Does not offer to receive RTP data and will not do so.

Exceptions

When setting the value of direction, the following exception can occur:

InvalidStateError DOMException

The receiver's RTCPeerConnection is closed or the RTCRtpReceiver is stopped.

TypeError

The value is being set to stopped when the current value is anything other than stopped.

Description

The direction property can be used to set or get the transceiver's preferred directionality.

Updating the directionality does not take effect immediately. If the new value of direction is different from the existing value, renegotiation of the connection is required, so a negotiationneeded event is sent to the RTCPeerConnection. A direction value (other than stopped) is then used by RTCPeerConnection.createOffer() or RTCPeerConnection.createAnswer() in order to generate the SDP message created those methods. For example, if the direction is specified as "sendrecv", the corresponding SDP a-line indicates the directionality:

a=sendrecv

The new directionality takes effect once the negotiation process is completed and the new session description is successfully applied.

The transceiver's current direction is indicated by the currentDirection property.

Specifications

Specification
WebRTC: Real-Time Communication in Browsers
# dom-rtcrtptransceiver-direction

Browser compatibility

Report problems with this compatibility data on GitHub
desktopmobile
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
direction
"stopped" value

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support
No support
No support

See also