RTCIceCandidateStats
The WebRTC API's RTCIceCandidateStats
dictionary provides statistics related to an RTCIceCandidate
.
Properties
RTCIceCandidateStats
is based upon the RTCStats
dictionary, so it includes those properties in addition to the ones below.
-
address
Optional -
A string containing the address of the candidate. This value may be an IPv4 address, an IPv6 address, or a fully-qualified domain name. This property was previously named
ip
and only accepted IP addresses. -
candidateType
Optional -
A string matching one of the values in
RTCIceCandidate.type
, indicating what kind of candidate the object provides statistics for. -
deleted
Optional -
A Boolean value indicating whether or not the candidate has been released or deleted; the default value is
false
. For local candidates, it's value istrue
if the candidate has been deleted or released. For host candidates,true
means that any network resources (usually a network socket) associated with the candidate have already been released. For TURN candidates, the TURN allocation is no longer active for deleted candidates. This property is not present for remote candidates. -
networkType
Optional -
A string from the
RTCNetworkType
enumerated type which indicates the type of interface used for a local candidate. This property is only present for local candidates. -
port
Optional -
The network port number used by the candidate.
-
priority
Optional -
The candidate's priority, corresponding to
RTCIceCandidate.priority
. -
protocol
Optional -
A string specifying the protocol (
tcp
orudp
) used to transmit data on theport
. -
relayProtocol
Optional -
A string identifying the protocol used by the endpoint for communicating with the TURN server; valid values are
tcp
,udp
, andtls
. Only present for local candidates. -
transportId
Optional -
A string uniquely identifiying the transport object that was inspected in order to obtain the
RTCTransportStats
associated with the candidate correspondin to these statistics. -
url
Optional -
For local candidates, the
url
property is the URL of the ICE server from which the candidate was received. This URL matches the one included in theRTCPeerConnectionIceEvent
object representing theicecandidate
event that delivered the candidate to the local peer.
Example
This example features a function, isUsableNetworkType()
, whose job it is to look at an RTCIceCandidateStats
object's networkType
and determine whether or not the type of network is acceptable for use.
This function is then called for RTCStats
objects whose type is local-candidate
, indicating that the object is in fact an RTCIceCandidateStats
with information about a local ICE candidate.
const isUsableNetworkType = stats => { switch(stats.networkType) { case "ethernet": case "vpn": return true; case "bluetooth": case "cellular": case "wimax": case "unknown": default: return false; } } if (rtcStats && rtcStats.type === "local-candidate") { if (!isUsableNetworkType(rtcStats)) { abortConnection(); return; } }
This code calls a function called abortConnection()
if the RTCStats
object represents information about a local candidate is which would be using a network connection other than Ethernet or a VPN.
Specifications
Browser compatibility
Desktop | Mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
RTCIceCandidateStats |
No |
No |
27 |
No |
? |
12.1 |
No |
No |
27 |
? |
12.2 |
No |
address |
No |
No |
65
27
|
No |
? |
12.1 |
No |
No |
65
27
|
? |
12.2 |
No |
candidateType |
No |
No |
27 |
No |
? |
12.1 |
No |
No |
27 |
? |
12.2 |
No |
componentId |
No |
No |
29
componentId is a Firefox-specific property and should not be used in production code. |
No |
? |
No |
No |
No |
29
componentId is a Firefox-specific property and should not be used in production code. |
? |
No |
No |
deleted |
No |
No |
No |
No |
? |
12.1 |
No |
No |
No |
? |
12.2 |
No |
networkType |
No |
No |
No |
No |
? |
No |
No |
No |
No |
? |
No |
No |
port |
No |
No |
27 |
No |
? |
12.1 |
No |
No |
27 |
? |
12.2 |
No |
priority |
No |
No |
No |
No |
? |
12.1 |
No |
No |
No |
? |
12.2 |
No |
protocol |
No |
No |
64
31
|
No |
? |
12.1 |
No |
No |
64
31
|
? |
12.2 |
No |
relayProtocol |
No |
No |
64
31
|
No |
? |
No |
No |
No |
64
31
|
? |
No |
No |
transportId |
No |
No |
31 |
No |
? |
12.1 |
No |
No |
31 |
? |
12.2 |
No |
url |
No |
No |
No |
No |
? |
12.1 |
No |
No |
No |
? |
12.2 |
No |
© 2005–2021 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/RTCIceCandidateStats