Интерфейс 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.

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

BCD tables only load in the browser

Смотри так же