Интерфейс RTCPeerConnection

Конструктор

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

RTCPeerConnection() Это экспериментальное API, которое не должно использоваться в рабочем коде.
The RTCPeerConnection() constructor returns a newly-created RTCPeerConnection, which represents a connection between the local device and a remote peer.

Свойства

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

canTrickleIceCandidates
The read-only RTCPeerConnection property canTrickleIceCandidates returns a Boolean which indicates whether or not the remote peer can accept trickled ICE candidates.
connectionState Это экспериментальное API, которое не должно использоваться в рабочем коде.
The read-only connectionState property of the RTCPeerConnection interface indicates the current state of the peer connection by returning one of the string values specified by the enum RTCPeerConnectionState.
currentLocalDescription undefined
The read-only property RTCPeerConnection.currentLocalDescription returns an RTCSessionDescription object describing the local end of the connection as it was most recently successfully negotiated since the last time the  RTCPeerConnection finished negotiating and connecting to a remote peer. Also included is a list of any ICE candidates that may already have been generated by the ICE agent since the offer or answer represented by the description was first instantiated.
currentRemoteDescription undefined
The read-only property RTCPeerConnection.currentRemoteDescription returns an RTCSessionDescription object describing the remote end of the connection as it was most recently successfully negotiated since the last time the RTCPeerConnection finished negotiating and connecting to a remote peer. Also included is a list of any ICE candidates that may already have been generated by the ICE agent since the offer or answer represented by the description was first instantiated.
getDefaultIceServers() Это экспериментальное API, которое не должно использоваться в рабочем коде.
The getDefaultIceServers() method of the RTCPeerConnection interface returns an array of objects based on the RTCIceServer dictionary, which indicates what, if any, ICE servers the browser will use by default if none are provided to the RTCPeerConnection in its RTCConfiguration. However, browsers are not required to provide any default ICE servers at all.
iceConnectionState undefined
The read-only property RTCPeerConnection.iceConnectionState returns an enum of type RTCIceConnectionState which state of the ICE agent associated with the RTCPeerConnection.
iceGatheringState Это экспериментальное API, которое не должно использоваться в рабочем коде. undefined
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 Это экспериментальное API, которое не должно использоваться в рабочем коде. undefined
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 undefined
The read-only RTCPeerConnection property peerIdentity returns a JavaScript Promise that resolves to an RTCIdentityAssertion which contains a DOMString identifying the remote peer.
pendingLocalDescription undefined
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 /en-US/docs/Web/API/WebRTC_API/Connectivity.
pendingRemoteDescription undefined
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 /en-US/docs/Web/API/WebRTC_API/Connectivity.
remoteDescription Это экспериментальное API, которое не должно использоваться в рабочем коде. undefined
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 Это экспериментальное API, которое не должно использоваться в рабочем коде.
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 undefined
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 /en-US/docs/Web/API/WebRTC_API/Session_lifetime for more details about the signaling process.

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

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

onaddstream Это устаревшее API больше не должно использоваться, но оно по-прежнему может работать.
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 RTCPeerConnection.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 Это экспериментальное API, которое не должно использоваться в рабочем коде.
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 RTCPeerConnection.createDataChannel.
onicecandidate
The RTCPeerConnection property RTCPeerConnection.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 Это экспериментальное API, которое не должно использоваться в рабочем коде.
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 RTCPeerConnection.iceConnectionState property, changes.
onicegatheringstatechange Это экспериментальное API, которое не должно использоваться в рабочем коде.
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 Это экспериментальное API, которое не должно использоваться в рабочем коде.
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 RTCPeerConnection.getIdentityAssertion() or during the creation of an offer or an answer.
onidpassertionerror Этот API вышел из употребления и его работа больше не гарантируется.
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 Этот API вышел из употребления и его работа больше не гарантируется.
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 Это экспериментальное API, которое не должно использоваться в рабочем коде.
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 Этот API вышел из употребления и его работа больше не гарантируется.
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 Это экспериментальное API, которое не должно использоваться в рабочем коде.
The removestream event has been removed from the WebRTC specification in favor of the existing removetrack event on the remote MediaStream and the corresponding MediaStream.onremovetrack event handler property of the remote MediaStream. The RTCPeerConnection API is now track-based, so having zero tracks in the remote stream is equivalent to the remote stream being removed and the old removestream event.
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 Это экспериментальное API, которое не должно использоваться в рабочем коде.
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() Это экспериментальное API, которое не должно использоваться в рабочем коде. Это устаревшее API больше не должно использоваться, но оно по-прежнему может работать.
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 RTCPeerConnection.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() Это экспериментальное API, которое не должно использоваться в рабочем коде.
The RTCPeerConnection.close() method closes the current peer connection.
createAnswer() Это экспериментальное API, которое не должно использоваться в рабочем коде.
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() Это экспериментальное API, которое не должно использоваться в рабочем коде.
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() Это экспериментальное API, которое не должно использоваться в рабочем коде.
The RTCPeerConnection.getConfiguration() method returns an RTCConfiguration object which indicates the current configuration of the RTCPeerConnection on which the method is called.
getIdentityAssertion() Это экспериментальное API, которое не должно использоваться в рабочем коде.
The RTCPeerConnection.getIdentityAssertion() method initiates the gathering of an identity assertion. This has an effect only if the RTCPeerConnection.signalingState is not "closed".
getReceivers() Это экспериментальное API, которое не должно использоваться в рабочем коде.
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() Это экспериментальное API, которое не должно использоваться в рабочем коде.
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() Это экспериментальное API, которое не должно использоваться в рабочем коде. Это устаревшее API больше не должно использоваться, но оно по-прежнему может работать.
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 RTCPeerConnection.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() Это экспериментальное API, которое не должно использоваться в рабочем коде.
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() Это экспериментальное API, которое не должно использоваться в рабочем коде.
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 RTCPeerConnection.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() Этот API вышел из употребления и его работа больше не гарантируется.
Создает новый объект типа 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 Этот API вышел из употребления и его работа больше не гарантируется.
Возникает, когда новый объект MediaStream был добавлен в соединение. Вместо наблюдения за этим устаревшим событием, разработчику следует наблюдать за каждым событием track, возникающим при добавлении в соединение объекта  MediaStreamTrack..
Установка обработчика возможна через свойство onaddstream .
identityresult Этот API вышел из употребления и его работа больше не гарантируется.
В старой версии спецификации WebRTC это событие использовалось для указания доступности подтверждения идентичности. Теперь, следует ждать возвращение промиса от peerIdentity для подтверждения личности. 
Установка обработчика возможна через свойство onidentityresult.
idpassertionerror Этот API вышел из употребления и его работа больше не гарантируется.
В старой версии спецификации WebRTC это событие использовалось для определения возникшей ошибки при попытке генерации подтверждения идентичности. Теперь, нужно ожидать результата работы промиса, возвращаемого методом доступа peerIdentity , передающий в метод перехвата ошибок промиса, возникшую ошибку.
Установка обработчика возможна через свойство onidpinsertionerror..
idpvalidationerror Этот API вышел из употребления и его работа больше не гарантируется.
В старой версии спецификации WebRTC это событие использовалось для определения того, что ошибка возникла при попытке подтверждения идентичности. Теперь, следует ожидать результат работы промиса, возвращаемого методом доступа peerIdentity, для перехвата ошибки в соответствующем методе.
Установка обработчика возможна через свойство onpeerdentity .
peeridentity Этот API вышел из употребления и его работа больше не гарантируется.
В старой версии спецификации WebRTC это событие использовалось для доставки полученной идентичности. Теперь, нужно ожидать результата работы промиса, возвращаемого методом доступа peerIdentity, для получения идентичности.
removestream Этот API вышел из употребления и его работа больше не гарантируется.
Возникает на объекте 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" Этот API вышел из употребления и его работа больше не гарантируется. Будут рассматриваться  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" Этот API вышел из употребления и его работа больше не гарантируется.

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

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

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

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

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

BCD tables only load in the browser

Смотри так же