RTCIceCandidateStats
Baseline Widely available *
This feature is well established and works across many devices and browser versions. It’s been available across browsers since February 2020.
* Some parts of this feature may have varying levels of support.
TheRTCIceCandidateStats dictionary of theWebRTC API is used to report statistics related to anRTCIceCandidate.
The statistics can be obtained by iterating theRTCStatsReport returned byRTCPeerConnection.getStats() until you find a report with thetype oflocal-candidate.
In this article
Instance properties
addressOptionalA 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
ipand only accepted IP addresses.Corresponds toRTCIceCandidate.address.candidateTypeA string matching one of the values in
RTCIceCandidate.type, indicating what kind of candidate the object provides statistics for.deletedA boolean indicating whether or not the candidate has been deleted or released.
foundationOptionalExperimentalA string that uniquely identifies the candidate across multiple transports.Corresponds to
RTCIceCandidate.foundation.portOptionalThe network port number used by the candidate.Corresponds to
RTCIceCandidate.port.priorityOptionalThe candidate's priority.Corresponds to
RTCIceCandidate.priority.protocolOptionalA string specifying the protocol (
tcporudp) used to transmit data on theport.Corresponds toRTCIceCandidate.protocol.relayProtocolA string specifying the protocol being used by a localICE candidate to communicate with theTURN server.
transportIdA string uniquely identifying the transport object that was inspected in order to obtain the
RTCTransportStatsassociated with the candidate corresponding to these statistics.urlOptionalA string specifying the URL of theICE server from which the described candidate was obtained. This property isonly available for local candidates.
usernameFragmentOptionalExperimentalA string containing the ICE username fragment ("ice-ufrag").Corresponds to
RTCIceCandidate.usernameFragment.
Common instance properties
The following properties are common to all WebRTC statistics objects.
idA string that uniquely identifies the object that is being monitored to produce this set of statistics.
timestampA
DOMHighResTimeStampobject indicating the time at which the sample was taken for this statistics object.typeA string with the value
"local-candidate", indicating the type of statistics that the object contains.
Examples
Given a variablemyPeerConnection, which is an instance ofRTCPeerConnection, the code below usesawait to wait for the statistics report, and then iterates it usingRTCStatsReport.forEach().It then filters the dictionaries for just those reports that have the type oflocal-candidate and logs the result.
const stats = await myPeerConnection.getStats();stats.forEach((report) => { if (report.type === "local-candidate") { // Log the ICE candidate information console.log(report); }});Specifications
| Specification |
|---|
| Identifiers for WebRTC's Statistics API> # dom-rtcstatstype-local-candidate> |