files/en-us/web/api/rtcicecandidate/foundation/index.md
{{APIRef("WebRTC")}}
The foundation read-only property of the {{domxref("RTCIceCandidate")}} interface is a string that allows correlation of candidates from a common network path on multiple {{domxref("RTCIceTransport")}} objects.
Candidates share the same foundation if they:
This is used to help optimize ICE performance while prioritizing and correlating candidates that appear on multiple {{domxref("RTCIceTransport")}} objects.
A string which uniquely identifies the candidate across all RTCIceTransports on which it is available.
[!NOTE] If
portisnull— andportis supported by the {{Glossary("user agent")}} — passing the candidate to {{domxref("RTCPeerConnection.addIceCandidate", "addIceCandidate()")}} will fail, throwing anOperationErrorexception.
Consider this {{Glossary("SDP")}} attribute line (a-line) which describes an ICE candidate:
a=candidate:4234997325 1 udp 2043278322 192.0.2.172 44323 typ host
The field "4234997325" is the foundation.
This code snippet uses the foundation of two candidates to determine if they're actually the same candidate.
if (candidate1.foundation === candidate2.foundation) {
/* the two candidates are the same, even if they're on
different transports */
}
{{Specifications}}
{{Compat}}