Интерфейс RTCPeerConnection

Этот перевод не завершён. Пожалуйста, помогите перевести эту статью с английского

Интерфейс RTCPeerConnection представляет соединение WebRTC между локальным пиром (участником соединения) на локальном компьютере и удаленным пиром на удаленном компьютере. Он предоставляет методы для соединения с удаленным участником соединения, обслуживания, мониторинга и закрытия соединения.

Конструктор

RTCPeerConnection()
Конструктор RTCPeerConnection() возвращает  новый экземпляр объекта RTCPeerConnection, который представляет соединение между локальным устройством и удаленным пиром (участником соединения)

Свойства

Also inherits свойства from: EventTarget

canTrickleIceCandidates
Свойство только для чтения canTrickleIceCandidates , объекта RTCPeerConnection, возвращает значение типа Boolean , которое указывает на то, может ли удаленный пир принимать кандидаты, согласно спецификации  trickled ICE candidates.
connectionState
Только для чтения свойство  connectionState интерфейса RTCPeerConnection указывает на текущее состояние соединения, возвращая одно из строковых значений, определяемых в перечислении RTCPeerConnectionState.
currentLocalDescription Только для чтения
Только для чтения свойство  RTCPeerConnection.currentLocalDescription возвращает объект  RTCSessionDescription , описывающий локальную сторону соединения, как  самый последний, удачно согласованный объект описания, с момента последнего завершения согласования  RTCPeerConnection и соединения с удаленным пиром (участником соединения) .
currentRemoteDescription Только для чтения
Только для чтения свойство RTCPeerConnection.currentRemoteDescription возвращает объект  RTCSessionDescription , представляющий удаленную сторону соединения, как последний, успешно согласованный объект данных, с момента завершения согласования и установки соединения объектом RTCPeerConnection с удаленным пиром.
getDefaultIceServers()
Метод getDefaultIceServers() интерфейса RTCPeerConnection , возвращает массив объектов  RTCIceServer, который указывает, какие серверы ICE браузер будет использовать по умолчанию, если они не указаны в параметре RTCConfiguration конструктора RTCPeerConnection
iceConnectionState Только для чтения [Перевести]
The read-only property RTCPeerConnection.iceConnectionState returns an enum of type RTCIceConnectionState which state of the ICE agent associated with the RTCPeerConnection.
iceGatheringState Только для чтения [Перевести]
The read-only property RTCPeerConnection.iceGatheringState returns an enum of type RTCIceGatheringState that describes connection's ICE gathering state. This lets you detect, for example, when collection of ICE candidates has finished.
localDescription Только для чтения [Перевести]
The read-only property RTCPeerConnection.localDescription returns an RTCSessionDescription describing the session for the local end of the connection. If it has not yet been set, this is null.
peerIdentity Только для чтения [Перевести]
The read-only RTCPeerConnection property peerIdentity returns a JavaScript Promise that resolves to an RTCIdentityAssertion which contains a DOMString identifying the remote peer.
pendingLocalDescription Только для чтения [Перевести]
The read-only property RTCPeerConnection.pendingLocalDescription returns an RTCSessionDescription object describing a pending configuration change for the local end of the connection. This does not describe the connection as it currently stands, but as it may exist in the near future. Use RTCPeerConnection.currentLocalDescription or RTCPeerConnection.localDescription to get the current state of the endpoint. For details on the difference, see Pending and current descriptions in WebRTC connectivity.
pendingRemoteDescription Только для чтения [Перевести]
The read-only property RTCPeerConnection.pendingRemoteDescription returns an RTCSessionDescription object describing a pending configuration change for the remote end of the connection. This does not describe the connection as it currently stands, but as it may exist in the near future. Use RTCPeerConnection.currentRemoteDescription or RTCPeerConnection.remoteDescription to get the current session description for the remote endpoint. For details on the difference, see Pending and current descriptions in WebRTC connectivity.
remoteDescription Только для чтения [Перевести]
The read-only property RTCPeerConnection.remoteDescription returns a RTCSessionDescription describing the session (which includes configuration and media information) for the remote end of the connection. If this hasn't been set yet, this is null.
sctp [Перевести]
The read-only sctp property on the RTCPeerConnection interface returns an RTCSctpTransport describing the SCTP transport over which SCTP data is being sent and received. If SCTP hasn't been negotiated, this value is null.
signalingState Только для чтения [Перевести]
The read-only signalingState property on the RTCPeerConnection interface returns one of the string values specified by the RTCSignalingState enum; these values describe the state of the signaling process on the local end of the connection while connecting or reconnecting to another peer. See Signaling in Lifetime of a WebRTC session for more details about the signaling process.

Обработчики событий

Also inherits обработчики событий from: EventTarget

onaddstream [Перевести]
The RTCPeerConnection.onaddstream event handler is a property containing the code to execute when the addstream event, of type MediaStreamEvent, is received by this RTCPeerConnection. Such an event is sent when a MediaStream is added to this connection by the remote peer. The event is sent immediately after the call setRemoteDescription() and doesn't wait for the result of the SDP negotiation.
onconnectionstatechange [Перевести]
The RTCPeerConnection.onconnectionstatechange property specifies an EventHandler which is called to handle the connectionstatechange event when it occurs on an instance of RTCPeerConnection. This happens whenever the aggregate state of the connection changes.
ondatachannel [Перевести]
The RTCPeerConnection.ondatachannel property is an EventHandler which specifies a function which is called when the datachannel event occurs on an RTCPeerConnection. This event, of type RTCDataChannelEvent, is sent when an RTCDataChannel is added to the connection by the remote peer calling createDataChannel().
onicecandidate [Перевести]
The RTCPeerConnection property onicecandidate property is an EventHandler which specifies a function to be called when the icecandidate event occurs on an RTCPeerConnection instance. This happens whenever the local ICE agent needs to deliver a message to the other peer through the signaling server.
oniceconnectionstatechange [Перевести]
The RTCPeerConnection.oniceconnectionstatechange property is an event handler which specifies a function to be called when the iceconnectionstatechange event is fired on an RTCPeerConnection instance. This happens when the state of the connection's ICE agent, as represented by the iceConnectionState property, changes.
onicegatheringstatechange [Перевести]
The RTCPeerConnection.onicegatheringstatechange property is an EventHandler which specifies a function to be called when the icegatheringstatechange event is sent to an RTCPeerConnection instance. This happens when the ICE gathering state—that is, whether or not the ICE agent is actively gathering candidates—changes.
onidentityresult [Перевести]
The RTCPeerConnection.onidentityresult event handler is a property containing the code to execute when the identityresult event, of type RTCIdentityEvent, is received by this RTCPeerConnection. Such an event is sent when an identity assertion is generated, via getIdentityAssertion() or during the creation of an offer or an answer.
onidpassertionerror [Перевести]
The RTCPeerConnection.onidpassertionerror event handler is a property containing the code to execute whent the idpassertionerror event, of type RTCIdentityErrorEvent, is received by this RTCPeerConnection. Such an event is sent when the associated identity provider (IdP) encounters an error while generating an identity assertion.
onidpvalidationerror [Перевести]
The RTCPeerConnection.onidpvalidationerror event handler is a property containing the code to execute whent the idpvalidationerror event, of type RTCIdentityErrorEvent, is received by this RTCPeerConnection. Such an event is sent when the associated identity provider (IdP) encounters an error while validating an identity assertion.
onnegotiationneeded [Перевести]
The RTCPeerConnection interface's onnegotiationneeded property is an EventListener which specifies a function which is called to handle the negotiationneeded event when it occurs on an RTCPeerConnection instance. This event is fired when a change has occurred which requires session negotiation. This negotiation should be carried out as the offerer, because some session changes cannot be negotiated as the answerer.
onpeeridentity [Перевести]
The RTCPeerConnection.onpeeridentity event handler is a property containing the code to execute whent the peeridentity event, of type Event, is received by this RTCPeerConnection. Such an event is sent when an identity assertion, received from a peer, has been successfully validated.
onremovestream [Перевести]
The RTCPeerConnection.onremovestream event handler is a property containing the code to execute when the removestream event, of type MediaStreamEvent, is received by this RTCPeerConnection. Such an event is sent when a MediaStream is removed from this connection.
onsignalingstatechange [Перевести]
The onsignalingstatechange event handler property of the RTCPeerConnection interface specifies a function to be called when the signalingstatechange event occurs on an RTCPeerConnection interface.
ontrack [Перевести]
The RTCPeerConnection property ontrack is an EventHandler which specifies a function to be called when the track event occurs, indicating that a track has been added to the RTCPeerConnection.

Методы

Also inherits методы from: EventTarget

addIceCandidate() [Перевести]
When a web site or app using RTCPeerConnection receives a new ICE candidate from the remote peer over its signaling channel, it delivers the newly-received candidate to the browser's ICE agent by calling RTCPeerConnection.addIceCandidate().
addStream() [Перевести]
The obsolete RTCPeerConnection method addStream() adds a MediaStream as a local source of audio or video. Instead of using this obsolete method, you should instead use addTrack() once for each track you wish to send to the remote peer.
addTrack() [Перевести]
The RTCPeerConnection method addTrack() adds a new media track to the set of tracks which will be transmitted to the other peer.
close() [Перевести]
The RTCPeerConnection.close() method closes the current peer connection.
createAnswer() [Перевести]
The createAnswer() method on the RTCPeerConnection interface creates an SDP answer to an offer received from a remote peer during the offer/answer negotiation of a WebRTC connection. The answer contains information about any media already attached to the session, codecs and options supported by the browser, and any ICE candidates already gathered. The answer is delivered to the returned Promise, and should then be sent to the source of the offer to continue the negotiation process.
createDataChannel() [Перевести]
The createDataChannel() method on the RTCPeerConnection interface creates a new channel linked with the remote peer, over which any kind of data may be transmitted.
createOffer() [Перевести]
The createOffer() method of the RTCPeerConnection interface initiates the creation of an SDP offer for the purpose of starting a new WebRTC connection to a remote peer.
generateCertificate() static function [Перевести]
The static  RTCPeerConnection.generateCertificate() function creates an X.509 certificate and corresponding private key, returning a promise that resolves with the new RTCCertificate once it's generated.
getConfiguration() [Перевести]
The RTCPeerConnection.getConfiguration() method returns an RTCConfiguration object which indicates the current configuration of the RTCPeerConnection on which the method is called.
getIdentityAssertion() [Перевести]
The RTCPeerConnection.getIdentityAssertion() method initiates the gathering of an identity assertion. This has an effect only if the signalingState is not "closed".
getReceivers() [Перевести]
The RTCPeerConnection.getReceivers() method returns an array of RTCRtpReceiver objects, each of which represents one RTP receiver. Each RTP receiver manages the reception and decoding of data for a MediaStreamTrack on an RTCPeerConnection
getSenders() [Перевести]
The RTCPeerConnection method getSenders() returns an array of RTCRtpSender objects, each of which represents the RTP sender responsible for transmitting one track's data.
getStats() [Перевести]
The RTCPeerConnection method getStats() returns a promise which resolves with data providing statistics about either the overall connection or about the specified MediaStreamTrack.
getStreamById() [Перевести]
The RTCPeerConnection.getStreamById() method returns the MediaStream with the given id that is associated with local or remote end of the connection. If no stream matches, it returns null.
getTransceivers() [Перевести]
The RTCPeerConnection interface's getTransceivers() method returns a list of the RTCRtpTransceiver objects being used to send and receive data on the connection.
removeStream() [Перевести]
The RTCPeerConnection.removeStream() method removes a MediaStream as a local source of audio or video. If the negotiation already happened, a new one will be needed for the remote peer to be able to use it. Because this method has been deprecated, you should instead use removeTrack() if your target browser versions have implemented it.
removeTrack() [Перевести]
The RTCPeerConnection.removeTrack() method tells the local end of the connection to stop sending media from the specified track, without actually removing the corresponding RTCRtpSender from the list of senders as reported by RTCPeerConnection.getSenders().
restartIce() [Перевести]
The WebRTC API's RTCPeerConnection interface offers the restartIce() method to allow a web application to easily request that ICE candidate gathering be redone on both ends of the connection.
setConfiguration() [Перевести]
The RTCPeerConnection.setConfiguration() method sets the current configuration of the RTCPeerConnection based on the values included in the specified RTCConfiguration object. This lets you change the ICE servers used by the connection and which transport policies to use.
setIdentityProvider() [Перевести]
The RTCPeerConnection.setIdentityProvider() method sets the Identity Provider (IdP) to the triplet given in parameter: its name, the protocol used to communicate with it (optional) and an optional username. The IdP will be used only when an assertion is needed.
setLocalDescription() [Перевести]
The RTCPeerConnection method setLocalDescription() changes the local description associated with the connection. This description specifies the properties of the local end of the connection, including the media format.
setRemoteDescription() [Перевести]
The RTCPeerConnection method setRemoteDescription() sets the specified session description as the remote peer's current offer or answer. The description specifies the properties of the remote end of the connection, including the media format.

Устаревший метод

Метод ниже, является устаревшим и не будет в дальнейшем реализован в современных браузерах.

RTCPeerConnection.createDTMFSender()
Создает новый объект типа RTCDTMFSender, связанный с определенным объектом MediaStreamTrack, который сможет отправить объект сигнализации DTMF поверх соединения..

События 

Для прослушивания событий используется функция добавления обработчика события addEventListener() или используется стандартное свойство интерфейса по схеме  onимясобытия (префикс on к которому добавляется имя события прописными буквами) для установки обработчика события.

connectionstatechange
Событие объекта RTCPeerConnection возникает, когда общий статус объекта сосединения RTCPeerConnection изменился.
Так же, доступно через свойство установки обработчика события  onconnectionstatechange.
datachannel
Событие объекта RTCPeerConnection возникает, когда удаленный пир (участник соединения) добавляет объект данных RTCDataChannel  в текущее соединение.
Так же, доступно через свойство установки обработчика события ondatachannel.
icecandidate
Событие объекта RTCPeerConnection возникает, когда  специальный объект ICE кандидата (RTCIceCandidate) сгенерирован RTCPeerConnection и готов для передачи удаленному пиру по каналу сигнализации.Сам сгененрированный объект кандидата передается в параметр вызванного обработчика. 
Так же, доступно через свойство установки обработчика события onicecandidate.
icecandidateerror
Событие типа ошибки  RTCPeerConnectionIceErrorEvent , возникает на объекте соединения при генерации ICE кандидата (RTCIceCandidate), если при этом возникла ошибка. Свойства объекта ошибки, возвращаемого в обработчик,  описывают подробности ошибки.
Так же, доступно через свойство установки обработчика события onicecandidateerror.
iceconnectionstatechange
Событие объекта RTCPeerConnection возникает при изменении статуса ICE соединения. К примеру, ICE соединение разорвано.
Так же, доступно через свойство установки обработчика событияoniceconnectionstatechange .
icegatheringstatechange
Событие объекта RTCPeerConnection, возникает, когда статус сборки, представленный классом iceGatheringState, изменяется. Это указывает на то, что :  согласование соединения ICE еще не началось (статус равен значению "new"); согласование соединения ICE началось (статус равен значеню "gathering"); согласование ICE  соединения завершено (статус равен значению "complete").
Так же, доступно через свойство установки обработчика onicegatheringstatechange .
isolationchange
Событие объекта RTCPeerConnection возникает, когда свойство isolated на одном из объектов  MediaStreamTrack , связанного с соединением изменяет свое значение. Объект трека является изолированным isolated, если его содержимое не может быть доступно содержащему его документу, по причине невозможности аутентификации, или объект трека прибыл не из источника происхождения страницы.
Так же, доступно через свойство установки обработчика onisolationchange.
negotiationneeded
Событие объекта RTCPeerConnection возникает, когда необходимо запустить согласование (пересогласование) ICE соединения; может произойти при первом открытии соединения , или при необходимости принятия изменений условий сети. Получатель должен ответить, создав предложение и отправив его другому партнеру. 
Так же, доступно через свойство установки обработчика onnegotiationneeded.
signalingstatechange
Событие signalingstatechange возникает, когда статус сигнализации ICE соединения изменился..
Так же, доступно через свойство установки обработчика onsignalingstatechange.
track
Событие track возникает после того, как новый объект трека был добавлен в один из объектов интерфейса RTCRtpReceiver , которые входят в состав соединения.
Так же, доступно через свойство установки обработчика ontrack .

Устаревшие события

addstream
Возникает, когда новый объект MediaStream был добавлен в соединение. Вместо наблюдения за этим устаревшим событием, разработчику следует наблюдать за каждым событием track, возникающим при добавлении в соединение объекта  MediaStreamTrack..
Установка обработчика возможна через свойство onaddstream .
identityresult
В старой версии спецификации WebRTC это событие использовалось для указания доступности подтверждения идентичности. Теперь, следует ждать возвращение промиса от peerIdentity для подтверждения личности. 
Установка обработчика возможна через свойство onidentityresult.
idpassertionerror
В старой версии спецификации WebRTC это событие использовалось для определения возникшей ошибки при попытке генерации подтверждения идентичности. Теперь, нужно ожидать результата работы промиса, возвращаемого методом доступа peerIdentity , передающий в метод перехвата ошибок промиса, возникшую ошибку.
Установка обработчика возможна через свойство onidpinsertionerror..
idpvalidationerror
В старой версии спецификации WebRTC это событие использовалось для определения того, что ошибка возникла при попытке подтверждения идентичности. Теперь, следует ожидать результат работы промиса, возвращаемого методом доступа peerIdentity, для перехвата ошибки в соответствующем методе.
Установка обработчика возможна через свойство onpeerdentity .
peeridentity
В старой версии спецификации WebRTC это событие использовалось для доставки полученной идентичности. Теперь, нужно ожидать результата работы промиса, возвращаемого методом доступа peerIdentity, для получения идентичности.
removestream
Возникает на объекте RTCPeerConnection, когда объект MediaStream удаляется из соединения. Теперь, необходимо наблюдать за событиями removetrack на каждом потоке, входящем в состав объекта соединения RTCPeerConnection.
Установка обработчика возможна через свойство onaddstream .

Константы

Перечисление RTCBundlePolicy 

Перечисление RTCBundlePolicy (политика сборки пакетов) определяет строковые константы, которые используются для запроса определенной политики при сборке  ICE кандидатов, в случае, если удаленный участник соединения (удаленная точка) не совместим со стандартом SDP BUNDLE standard  для объединения нескольких медиапотоков в один транспортный пакет.

 Примечание : В технических терминах BUNDLE (пакет) позволяет всем медиапотокам между двумя пирами проходить через один 5 - ти элементный кортеж (тип транспортного протокола передачи сообщений при установки  TCP, UDP, и ICMP соединений, состоящий из пяти элементов анализа данных). То есть, с одного IP-адреса и порта на одном узле на один IP-адрес и порт на другом узле с использованием одного и того же транспортного протокола.

Константа Описание
"balanced"

Сбалансированный. Агент ICE изначально создает по одному объекту  RTCDtlsTransport для каждого типа добавляемого контента: аудио, видео и каналов данных. Если  удаленная конечная точка не опознает пакеты, то каждый из этих DTLS транспортов обрабатывает все коммуникации для одного типа данных.

"max-compat" Максимально совместимый. Агент ICE изначально создает один объект RTCDtlsTransport для каждой медиа-дорожки и отдельный для каналов данных. Если удаленная точка не поддерживает опознавание пакета, все согласовывается на этих отдельных DTLS транспортах
"max-bundle" Максимальный пакет. Агент ICE изначально создает только один объект RTCDtlsTransport для переноса всех данных RTCPeerConnection. Если удаленная  точка не поддерживает опознавание пакета, то согласовывается только одна дорожка, а остальные игнорируются.

Перечисление RTCIceConnectionState

Перечисление RTCIceConnectionState определяет строковые константы, использующиеся для описания текущего состояния  ICE агента и его соединения с ICE сервером  STUN или TURN .

Константа Описание
"new" ICE агент собирает адреса или ожидает получения удаленных кандидатов от вызова метода RTCPeerConnection.addIceCandidate(). Или все сразу.
"checking" ICE агент получил один или несколько удаленных кандидатов и проверяет парность локального и удаленного кандидатов относительно друг друга, пытаясь обнаружить совместимости. Но еще не обнаружил пару, соответствующую устанавливаемому удаленному соединению.Не исключено, что сборка кандидатов продолжиться.
"connected" Совместимая парность локального и удаленного кандидатов найдена для всех компонентов соединения, и соединение было установлено. Не исключено продолжение сборки и проверки кандидатов в процессе соединения, для наилучший совместимости.
"completed" Агент ICE завершил сбор кандидатов, проверил все пары относительно друг друга, и установил все соединения для всех компонентов.
"failed" Агент ICE проверил все пары кандидатов между собой и не нашел совместимых сопоставлений для всех компонентов соединения. Или не нашел совместимых соединений для некоторых компонентов. 
"disconnected" Проверяет, что компоненты все еще подключены, хотябы для одного объекта RTCPeerConnection.  Это менее строгий тест, чем "failed", и он может периодически запускаться и разрешаться спонтанно в менее надежных сетях, или во время временного отключения. Когда проблема исчезнет, ​​соединение может вернуться в состояние "connected". 
"closed" ICE агент закрыл соединение для объекта RTCPeerConnection и больше не обрабатывает запросы.

Перечисление RTCIceGatheringState

Перечисление RTCIceGatheringState определяет строковые константы, которые описывают текущий статус ICE сборки, возвращаемый свойством  RTCPeerConnection.iceGatheringState. Для определения изменнения этого свойства можно подписаться на событие  icegatheringstatechange.

Константы Описание
"new" Соединение только что создано, и еще не имело сетевой активности.
"gathering" Агент ICE находиться в процессе сборки кандидатов соединения.
"complete" Агент ICE завершил сборку кандидатов. Если произойдет, что-то (например, добавление нового ICE сервера), для чего потребуется новая сборка кандидатов, статус переключиться в значение  "gathering" и начнется пересборка кандидатов.

Перечисление RTCIceTransportPolicy

Перечисление RTCIceTransportPolicy определяет строковые константы, использующиеся для ограничения политик передачи ICE кандидатов, учитывающихся во время процесса соединения..

Константа Описание
"all" Все  ICE кандидаты будут рассмотрены.
"public" Будут рассматриваться  ICE кандидаты, только имеющие публичные IP адреса. Удален в спецификации от 13 мая 2016 (working draft).
"relay" Будут рассматриваться ICE кандидаты, только с переданными IP адресами через TURN сервер.

Перечисление RTCPeerConnectionState

Перечисление  RTCPeerConnectionState определяет строковые константы, описывающие статус RTCPeerConnection. Эти значения возвращаются свойством  (методом доступа) connectionState . Этот статус представляет собирательный статус всех ICE передач (которые имеют тип RTCIceTransport или RTCDtlsTransport) , использующиеся соединением.

Константа Описание
"new" Новый. По меньшей мере один из объектов ICE передачи (RTCIceTransport или  RTCDtlsTransport ) в соединении находиться в статусе "new" и ни один из них не находиться в одном из перечисленных статусов : "connecting", "checking", "failed", или "disconnected", или все объекты передач соединения находятся в статусе  "closed".
"connecting" В процессе соединения. Один или несколько объектов ICE передачи находятся в процессе установки соединения. Т.е. их свойство RTCIceConnectionState либо имеет значение "checking" , либо  "connected",  и ни один из объектов передачи не находиться в статусе "failed" . <<< Make this a link once I know where that will be documented
"connected" Соединен. Каждый объект ICE передачи, использующийся соединением либо используется  (имеет статус "connected" или "completed") , либо закрыт  (имеет статус "closed"); кроме того, по крайней мере один объект передачи имеет статус либо  "connected" , либо "completed".
"disconnected" Разъединен. По меньшей мере один из объектов ICE передачи в соединении имеет статус "disconnected"  и ни один из объекто передачи не находиться в статусе : "failed", "connecting", или  "checking".
"failed" Неудачно. Один или несколько объектов передачи могут находиться в статусе "failed".
"closed"

Закрыто. Соединение RTCPeerConnection закрыто.

Ранее входило в значения перечисления RTCSignalingState (и поэтому может быть найдено в свойстве signalingState) до 13 мая, 2016.

Перечисление RTCRtcpMuxPolicy

Перечисление RTCRtcpMuxPolicy содержит строковые константы, определяющие , что собираемые кандидаты должны иметь поддержку немультиплексированного RTCP . <<<add a link to info about multiplexed RTCP.

Константа Описание
"negotiate" Instructs the ICE agent to gather both RTP and RTCP candidates. If the remote peer can multiplex RTCP, then RTCP candidates are multiplexed atop the corresponding RTP candidates. Otherwise, both the RTP and RTCP candidates are returned, separately.
"require" Tells the ICE agent to gather ICE candidates for only RTP, and to multiplex RTCP atop them. If the remote peer doesn't support RTCP multiplexing, then session negotiation fails.

Перечисление RTCSignalingState

Перечисление RTCSignalingState определяет возможные значения состояния сигнализирования  RTCPeerConnection.signalingState, указывая в каком месте процесса сигнализации в настоящее время находиться обмен предложением или ответом.

Константа Описание
"stable"

Стабильно. Текущего процесса обмена предложения/ответ не происходит. Это может означать, что объект соединения RTCPeerConnection новый, и в этом случае объекты описания  localDescription и remoteDescription имеют значения null; Так же, может означать, что согласование завершено и соединение успешно установлено.

"have-local-offer" Имеет локальное предложение. Локальный пир вызвал метод RTCPeerConnection.setLocalDescription(), передав в него объект описания SDP , представляющий предложение  (обычно, созданного вызовом метода RTCPeerConnection.createOffer()), и это предложение было успешно применено.
"have-remote-offer" Имеет удаленное предложение. Удаленный пир создал предложение, использовал сервер сигнализации для передачи этого предложения локальному пользователю, которое было установлено им в параметр, через вызов метода RTCPeerConnection.setRemoteDescription().
"have-local-pranswer" Имеет локальный предварительный ответ. Предложение удаленного пира было применено, и ответ был создан (обычно, через вызов метода RTCPeerConnection.createAnswer()) и использовано в параметре метода установки локального дескриптора RTCPeerConnection.setLocalDescription(). Этот предварительный ответ описывает поддерживаемые медиа форматы и тому подобное. Но он не имееет включенных в него  полного набора ICE кандидатов. Позже, дополнительные кандидаты будут доставлены отдельно.
"have-remote-pranswer" Имеет предварительный удаленный ответ. Предварительный удаленный ответ был получен и успешно применен в ответ на предложение, отправленное ранее и установленное методом setLocalDescription().
"closed"

Закрыто. Соединение закрыто.

Примечание : Это значение перенесено в перечисление RTCPeerConnectionState  в драфте от 13 мая 2016, поскольку оно отражает статус соединения   RTCPeerConnection,  а не статус сигнализации. Теперь, для проверки закрытия соединения нужно проверять статус connectionState на значение "closed" .

Спецификации 

Спецификация Статус Комментарий
WebRTC 1.0: Real-time Communication Between Browsers
Определение 'RTCPeerConnection' в этой спецификации.
Кандидат в рекомендации Initial definition.

Совместимость с браузерами

Update compatibility data on GitHub
КомпьютерыМобильные
ChromeEdgeFirefoxInternet ExplorerOperaSafariAndroid webviewChrome для AndroidFirefox для AndroidOpera для AndroidSafari on iOSSamsung Internet
RTCPeerConnectionChrome Полная поддержка 23Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ≤37Chrome Android Полная поддержка 25Firefox Android Полная поддержка 44
Полная поддержка 44
Нет поддержки 22 — 44
С префиксом
С префиксом Требует вендорный префикс: moz
Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка 11Samsung Internet Android Полная поддержка 6.0
Полная поддержка 6.0
Нет поддержки 5.0 — 6.0
С префиксом
С префиксом Требует вендорный префикс: webkit
RTCPeerConnection() constructorChrome Полная поддержка 23
Замечания
Полная поддержка 23
Замечания
Замечания Before Chrome 63 the default value for the RTCConfiguration.rtcpMuxPolicy parameter was "negotiate"
Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Полная поддержка Да
Замечания
Полная поддержка Да
Замечания
Замечания Before Chrome 63 the default value for the RTCConfiguration.rtcpMuxPolicy parameter was "negotiate"
Chrome Android Полная поддержка Да
Замечания
Полная поддержка Да
Замечания
Замечания Before Chrome 63 the default value for the RTCConfiguration.rtcpMuxPolicy parameter was "negotiate"
Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
addIceCandidateChrome Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка 24
Edge Полная поддержка 15Firefox Полная поддержка 22
Замечания
Полная поддержка 22
Замечания
Замечания Starting in Firefox 68, the candidate parameter is optional when calling addIceCandidate(). A null value for candidate indicates no more candidates will be sent, while an empty candidate string indicates that no more candidates will be sent for the current generation of candidates.
IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка Да
Chrome Android Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка Да
Firefox Android Полная поддержка 44
Замечания
Полная поддержка 44
Замечания
Замечания Starting in Firefox 68, the candidate parameter is optional when calling addIceCandidate(). A null value for candidate indicates no more candidates will be sent, while an empty candidate string indicates that no more candidates will be sent for the current generation of candidates.
Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
Замечания
Полная поддержка 6.0
Замечания
Замечания Promise-based version and unprefixed.
Нет поддержки 5.0 — 6.0
Замечания
Замечания Promise-based version.
addStream
Устаревшая
Chrome Полная поддержка 24Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Полная поддержка ДаChrome Android Полная поддержка ДаFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
addstream event
УстаревшаяНестандартная
Chrome Полная поддержка 24Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari Нет поддержки НетWebView Android Полная поддержка ДаChrome Android Полная поддержка 25Firefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS ? Samsung Internet Android Полная поддержка 6.0
addTrackChrome Полная поддержка 64Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 51Safari Полная поддержка 11WebView Android Полная поддержка 64Chrome Android Полная поддержка 64Firefox Android Полная поддержка 44Opera Android Полная поддержка 47Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
addTransceiverChrome Полная поддержка 69Edge Полная поддержка 79Firefox Полная поддержка 59IE Нет поддержки НетOpera Нет поддержки НетSafari Полная поддержка 11WebView Android Полная поддержка 69Chrome Android Полная поддержка 69Firefox Android Полная поддержка 59Opera Android Нет поддержки НетSafari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 10.0
canTrickleIceCandidatesChrome Нет поддержки НетEdge Нет поддержки 15 — 79Firefox Полная поддержка 47IE Нет поддержки НетOpera Нет поддержки НетSafari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Нет поддержки НетSafari iOS ? Samsung Internet Android Полная поддержка 6.0
closeChrome Полная поддержка 23Edge Полная поддержка 15Firefox Полная поддержка ДаIE Нет поддержки НетOpera Полная поддержка ДаSafari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка ДаFirefox Android Полная поддержка ДаOpera Android Полная поддержка ДаSafari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка Да
connectionStateChrome Полная поддержка 72Edge Полная поддержка 79Firefox Нет поддержки НетIE Нет поддержки НетOpera Нет поддержки НетSafari Полная поддержка 11WebView Android Полная поддержка 72Chrome Android Полная поддержка 72Firefox Android Нет поддержки НетOpera Android Нет поддержки НетSafari iOS Нет поддержки НетSamsung Internet Android Полная поддержка 11.0
connectionstatechange eventChrome Полная поддержка 72Edge Полная поддержка 79Firefox Нет поддержки НетIE Нет поддержки НетOpera Нет поддержки НетSafari Полная поддержка 11WebView Android Полная поддержка 72Chrome Android Полная поддержка 72Firefox Android Нет поддержки НетOpera Android Нет поддержки НетSafari iOS Нет поддержки НетSamsung Internet Android Полная поддержка 11.0
createAnswerChrome Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка 24
Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка Да
Chrome Android Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка Да
Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
Замечания
Полная поддержка 6.0
Замечания
Замечания Promise-based version and unprefixed.
Нет поддержки 5.0 — 6.0
Замечания
Замечания Promise-based version.
createDataChannelChrome Полная поддержка 25Edge Полная поддержка 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 25Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка 11Samsung Internet Android Полная поддержка 6.0
createDTMFSender
Устаревшая
Chrome Полная поддержка 27Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Полная поддержка ДаChrome Android Полная поддержка 27Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
createOfferChrome Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка 24
Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка Да
Chrome Android Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка Да
Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
Замечания
Полная поддержка 6.0
Замечания
Замечания Promise-based version and unprefixed.
Нет поддержки 5.0 — 6.0
Замечания
Замечания Promise-based version.
currentLocalDescriptionChrome Полная поддержка 70Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 70Chrome Android Полная поддержка 70Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
currentRemoteDescriptionChrome Полная поддержка 70Edge Полная поддержка 79Firefox Полная поддержка 57IE Нет поддержки НетOpera Нет поддержки НетSafari Полная поддержка 11WebView Android Полная поддержка 70Chrome Android Полная поддержка 70Firefox Android Полная поддержка ДаOpera Android Нет поддержки НетSafari iOS Нет поддержки НетSamsung Internet Android Полная поддержка 10.0
datachannel eventChrome Полная поддержка 25Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 25Firefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS ? Samsung Internet Android Полная поддержка 6.0
defaultIceServers
УстаревшаяНестандартная
Chrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
generateCertificateChrome Полная поддержка 48Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Полная поддержка 48Chrome Android Полная поддержка 48Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
getConfigurationChrome Полная поддержка 70Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 70Chrome Android Полная поддержка 70Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
getDefaultIceServersChrome Нет поддержки НетEdge Нет поддержки НетFirefox ? IE Нет поддержки НетOpera ? Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android ? Opera Android ? Safari iOS ? Samsung Internet Android Нет поддержки Нет
getIdentityAssertionChrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
getLocalStreams
УстаревшаяНестандартная
Chrome Полная поддержка 27Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Полная поддержка ДаChrome Android Полная поддержка 27Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
getReceiversChrome Полная поддержка 59Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 46Safari Полная поддержка 11WebView Android Полная поддержка 59Chrome Android Полная поддержка 59Firefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
getRemoteStreams
УстаревшаяНестандартная
Chrome Полная поддержка 27Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Полная поддержка ДаChrome Android Полная поддержка 27Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
getSendersChrome Полная поддержка 64Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 51Safari Полная поддержка 11WebView Android Полная поддержка 64Chrome Android Полная поддержка 64Firefox Android Полная поддержка 44Opera Android Полная поддержка 47Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
getStatsChrome Полная поддержка 58
Замечания
Полная поддержка 58
Замечания
Замечания Promise resolves with RTCStatsReport.
Полная поддержка 54
Замечания
Замечания Promise-based version.
Полная поддержка 24
Edge Полная поддержка 15Firefox Полная поддержка ДаIE Нет поддержки НетOpera Полная поддержка 45Safari Полная поддержка 11WebView Android Полная поддержка 58
Замечания
Полная поддержка 58
Замечания
Замечания Promise resolves with RTCStatsReport.
Полная поддержка 54
Замечания
Замечания Promise-based version.
Полная поддержка Да
Chrome Android Полная поддержка 58
Замечания
Полная поддержка 58
Замечания
Замечания Promise resolves with RTCStatsReport.
Полная поддержка 54
Замечания
Замечания Promise-based version.
Полная поддержка Да
Firefox Android Полная поддержка ДаOpera Android Полная поддержка 43Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 7.0
Замечания
Полная поддержка 7.0
Замечания
Замечания Promise resolves with RTCStatsReport.
Полная поддержка 6.0
Замечания
Замечания Promise-based version.
Полная поддержка Да
getStreamById
УстаревшаяНестандартная
Chrome Нет поддержки 56 — 62Edge Нет поддержки 15 — 79Firefox Нет поддержки 22 — 53IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Нет поддержки 56 — 62Chrome Android Нет поддержки 56 — 62Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Нет поддержки 6.0 — 8.0
icecandidate eventChrome Полная поддержка 24Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 25Firefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS ? Samsung Internet Android Полная поддержка 6.0
iceConnectionStateChrome Полная поддержка 26Edge Полная поддержка 15Firefox Полная поддержка 52IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 26Firefox Android Полная поддержка ДаOpera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 7.0
iceconnectionstatechange eventChrome Полная поддержка 28Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 28Firefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS ? Samsung Internet Android Полная поддержка 6.0
iceGatheringStateChrome Полная поддержка 25Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 25Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
identityresult event
Устаревшая
Chrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS ? Samsung Internet Android Полная поддержка 6.0
idpassertionerror event
Устаревшая
Chrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS ? Samsung Internet Android Полная поддержка 6.0
idpvalidationerror event
Устаревшая
Chrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS ? Samsung Internet Android Полная поддержка 6.0
localDescriptionChrome Полная поддержка 24Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 25Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
negotiationneeded eventChrome Полная поддержка 24Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка ДаFirefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS ? Samsung Internet Android Полная поддержка 6.0
onaddstream
УстаревшаяНестандартная
Chrome Полная поддержка 24Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Нет поддержки НетWebView Android Полная поддержка ДаChrome Android Полная поддержка ДаFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Нет поддержки НетSamsung Internet Android Полная поддержка 6.0
onconnectionstatechangeChrome Полная поддержка 72Edge Полная поддержка 79Firefox Нет поддержки НетIE Нет поддержки НетOpera Нет поддержки НетSafari Полная поддержка 11WebView Android Полная поддержка 72Chrome Android Полная поддержка 72Firefox Android Нет поддержки НетOpera Android Нет поддержки НетSafari iOS Нет поддержки НетSamsung Internet Android Полная поддержка 11.0
ondatachannelChrome Полная поддержка 25Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 25Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
onicecandidateChrome Полная поддержка 24Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка ДаFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
onicecandidateerrorChrome Нет поддержки НетEdge Нет поддержки НетFirefox ? IE Нет поддержки НетOpera ? Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android ? Opera Android ? Safari iOS ? Samsung Internet Android Нет поддержки Нет
oniceconnectionstatechangeChrome Полная поддержка 28Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 28Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
onicegatheringstatechangeChrome Полная поддержка 59Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 59Chrome Android Полная поддержка 59Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 7.0
onidentityresult
УстаревшаяНестандартная
Chrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
onidpassertionerror
УстаревшаяНестандартная
Chrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
onidpvalidationerror
УстаревшаяНестандартная
Chrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
onnegotiationneededChrome Полная поддержка 24Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка ДаFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
onpeeridentity
УстаревшаяНестандартная
Chrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
onremovestream
УстаревшаяНестандартная
Chrome Полная поддержка 24Edge Полная поддержка 15Firefox Нет поддержки 22 — 60IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Нет поддержки НетWebView Android Полная поддержка ДаChrome Android Полная поддержка ДаFirefox Android Нет поддержки 44 — 60Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Нет поддержки НетSamsung Internet Android Полная поддержка 6.0
onsignalingstatechangeChrome Полная поддержка 28Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 28Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
ontrackChrome Полная поддержка 64Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 64Chrome Android Полная поддержка 64Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
peerIdentityChrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
peeridentity event
Устаревшая
Chrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS ? Samsung Internet Android Полная поддержка 6.0
pendingLocalDescriptionChrome Полная поддержка 70Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 70Chrome Android Полная поддержка 70Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
pendingRemoteDescriptionChrome Полная поддержка 70Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 70Chrome Android Полная поддержка 70Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
remoteDescriptionChrome Полная поддержка 24Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version and unprefixed.
Нет поддержки 38 — 43
Замечания
Замечания Promise-based version.
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка ДаFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version and unprefixed.
Нет поддержки 41 — 43
Замечания
Замечания Promise-based version.
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
removeStream
УстаревшаяНестандартная
Chrome Полная поддержка 24Edge Полная поддержка 15Firefox Нет поддержки 22 — 51IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Полная поддержка ДаChrome Android Полная поддержка ДаFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Нет поддержки 11 — 12Samsung Internet Android Полная поддержка 6.0
removestream event
УстаревшаяНестандартная
Chrome Полная поддержка 24Edge Полная поддержка 15Firefox Нет поддержки 22 — 60IE Нет поддержки НетOpera Полная поддержка 43Safari Нет поддержки НетWebView Android Полная поддержка ДаChrome Android Полная поддержка 25Firefox Android Нет поддержки 44 — 60Opera Android Полная поддержка 43Safari iOS Нет поддержки НетSamsung Internet Android Полная поддержка 6.0
removeTrackChrome Полная поддержка 64Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 51Safari Полная поддержка 11WebView Android Полная поддержка 64Chrome Android Полная поддержка 64Firefox Android Полная поддержка 44Opera Android Полная поддержка 47Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
restartIce() methodChrome Полная поддержка 77Edge Полная поддержка 79Firefox Полная поддержка 70IE Нет поддержки НетOpera Нет поддержки НетSafari Нет поддержки НетWebView Android Полная поддержка 77Chrome Android Полная поддержка 77Firefox Android Нет поддержки НетOpera Android Полная поддержка 55Safari iOS Нет поддержки НетSamsung Internet Android Полная поддержка 12.0
sctpChrome Полная поддержка 76Edge Полная поддержка 79Firefox Нет поддержки Нет
Замечания
Нет поддержки Нет
Замечания
Замечания See bug 1278299.
IE Нет поддержки НетOpera Нет поддержки НетSafari Нет поддержки НетWebView Android Полная поддержка 76Chrome Android Полная поддержка 76Firefox Android Нет поддержки Нет
Замечания
Нет поддержки Нет
Замечания
Замечания See bug 1278299.
Opera Android Полная поддержка 54Safari iOS Нет поддержки НетSamsung Internet Android Полная поддержка 12.0
setConfigurationChrome Полная поддержка 48Edge Полная поддержка ≤18Firefox Нет поддержки Нет
Замечания
Нет поддержки Нет
Замечания
Замечания See bug 1253706.
IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 48Chrome Android Полная поддержка 48Firefox Android Нет поддержки Нет
Замечания
Нет поддержки Нет
Замечания
Замечания See bug 1253706.
Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
setIdentityProviderChrome Нет поддержки НетEdge Нет поддержки ≤18 — 79Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari ? WebView Android Нет поддержки НетChrome Android Нет поддержки НетFirefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS ? Samsung Internet Android Полная поддержка 6.0
setLocalDescription()Chrome Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка 24
Edge Полная поддержка 15Firefox Полная поддержка 22
Замечания
Полная поддержка 22
Замечания
Замечания Firefox does not support descriptions of type pranswer.
IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка Да
Chrome Android Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка Да
Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
Замечания
Полная поддержка 6.0
Замечания
Замечания Promise-based version and unprefixed.
Нет поддержки 5.0 — 6.0
Замечания
Замечания Promise-based version.
setRemoteDescription()Chrome Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка 24
Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка Да
Chrome Android Полная поддержка 51
Замечания
Полная поддержка 51
Замечания
Замечания Promise-based version.
Полная поддержка Да
Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 5.0
Замечания
Полная поддержка 5.0
Замечания
Замечания Promise-based version.
Полная поддержка Да
signalingStateChrome Полная поддержка 26Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 26Firefox Android Полная поддержка 44Opera Android Полная поддержка 43
Замечания
Полная поддержка 43
Замечания
Замечания Promise-based version.
Нет поддержки 37 — 43
Safari iOS Полная поддержка ДаSamsung Internet Android Полная поддержка 6.0
signalingstatechange eventChrome Полная поддержка 28Edge Полная поддержка 15Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari Полная поддержка 11WebView Android Полная поддержка ДаChrome Android Полная поддержка 28Firefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS Нет поддержки НетSamsung Internet Android Полная поддержка 6.0
track eventChrome Полная поддержка 64Edge Полная поддержка ≤18Firefox Полная поддержка 22IE Нет поддержки НетOpera Полная поддержка 43Safari Полная поддержка 11WebView Android Полная поддержка 64Chrome Android Полная поддержка 64Firefox Android Полная поддержка 44Opera Android Полная поддержка 43Safari iOS ? Samsung Internet Android Полная поддержка 6.0

Легенда

Полная поддержка  
Полная поддержка
Нет поддержки  
Нет поддержки
Совместимость неизвестна  
Совместимость неизвестна
Нестандартная. Ожидается плохая кросс-браузерная поддержка.
Нестандартная. Ожидается плохая кросс-браузерная поддержка.
Устаревшая. Не следует использовать в новых веб-сайтах
Устаревшая. Не следует использовать в новых веб-сайтах
Смотрите замечания реализации.
Смотрите замечания реализации.
Требует вендорный префикс или другое имя для использования.
Требует вендорный префикс или другое имя для использования.

Смотри так же