| /* |
| * Copyright 2020 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| #ifndef PC_USAGE_PATTERN_H_ |
| #define PC_USAGE_PATTERN_H_ |
| |
| #include "api/peer_connection_interface.h" |
| |
| namespace webrtc { |
| |
| class PeerConnectionObserver; |
| |
| // A bit in the usage pattern is registered when its defining event occurs |
| // at least once. |
| enum class UsageEvent : int { |
| TURN_SERVER_ADDED = 0x01, |
| STUN_SERVER_ADDED = 0x02, |
| DATA_ADDED = 0x04, |
| AUDIO_ADDED = 0x08, |
| VIDEO_ADDED = 0x10, |
| // `SetLocalDescription` returns successfully. |
| SET_LOCAL_DESCRIPTION_SUCCEEDED = 0x20, |
| // `SetRemoteDescription` returns successfully. |
| SET_REMOTE_DESCRIPTION_SUCCEEDED = 0x40, |
| // A local candidate (with type host, server-reflexive, or relay) is |
| // collected. |
| CANDIDATE_COLLECTED = 0x80, |
| // A remote candidate is successfully added via `AddIceCandidate`. |
| ADD_ICE_CANDIDATE_SUCCEEDED = 0x100, |
| ICE_STATE_CONNECTED = 0x200, |
| CLOSE_CALLED = 0x400, |
| // A local candidate with private IP is collected. |
| PRIVATE_CANDIDATE_COLLECTED = 0x800, |
| // A remote candidate with private IP is added, either via AddiceCandidate |
| // or from the remote description. |
| REMOTE_PRIVATE_CANDIDATE_ADDED = 0x1000, |
| // A local mDNS candidate is collected. |
| MDNS_CANDIDATE_COLLECTED = 0x2000, |
| // A remote mDNS candidate is added, either via AddIceCandidate or from the |
| // remote description. |
| REMOTE_MDNS_CANDIDATE_ADDED = 0x4000, |
| // A local candidate with IPv6 address is collected. |
| IPV6_CANDIDATE_COLLECTED = 0x8000, |
| // A remote candidate with IPv6 address is added, either via AddIceCandidate |
| // or from the remote description. |
| REMOTE_IPV6_CANDIDATE_ADDED = 0x10000, |
| // A remote candidate (with type host, server-reflexive, or relay) is |
| // successfully added, either via AddIceCandidate or from the remote |
| // description. |
| REMOTE_CANDIDATE_ADDED = 0x20000, |
| // An explicit host-host candidate pair is selected, i.e. both the local and |
| // the remote candidates have the host type. This does not include candidate |
| // pairs formed with equivalent prflx remote candidates, e.g. a host-prflx |
| // pair where the prflx candidate has the same base as a host candidate of |
| // the remote peer. |
| DIRECT_CONNECTION_SELECTED = 0x40000, |
| MAX_VALUE = 0x80000, |
| }; |
| |
| class UsagePattern { |
| public: |
| void NoteUsageEvent(UsageEvent event); |
| void ReportUsagePattern(PeerConnectionObserver* observer) const; |
| |
| private: |
| int usage_event_accumulator_ = 0; |
| }; |
| |
| } // namespace webrtc |
| #endif // PC_USAGE_PATTERN_H_ |