mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-15 23:01:21 +01:00

This is a reland of eed5aa8904
Original change's description:
> Structured ICE logging via RtcEventLog.
>
> This change list contains the structured logging module for ICE using
> the RtcEventLog infrastructure, and also extension to the log parser
> and analyzer.
>
> Bug: None
> Change-Id: I6539cf282155c2cde4d3161c53500c0746671a02
> Reviewed-on: https://webrtc-review.googlesource.com/34622
> Commit-Queue: Qingsi Wang <qingsi@google.com>
> Reviewed-by: Björn Terelius <terelius@webrtc.org>
> Reviewed-by: Peter Thatcher <pthatcher@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#21816}
TBR=pthatcher@webrtc.org,terelius@webrtc.org,deadbeef@webrtc.org
Bug: None
Change-Id: I3df585bf636315ceb0273967146111346a83be86
Reviewed-on: https://webrtc-review.googlesource.com/47545
Commit-Queue: Qingsi Wang <qingsi@google.com>
Reviewed-by: Qingsi Wang <qingsi@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#21881}
51 lines
1.8 KiB
C++
51 lines
1.8 KiB
C++
/*
|
|
* Copyright (c) 2017 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 LOGGING_RTC_EVENT_LOG_ICELOGGER_H_
|
|
#define LOGGING_RTC_EVENT_LOG_ICELOGGER_H_
|
|
|
|
#include <unordered_map>
|
|
|
|
#include "logging/rtc_event_log/events/rtc_event_ice_candidate_pair.h"
|
|
#include "logging/rtc_event_log/events/rtc_event_ice_candidate_pair_config.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class RtcEventLog;
|
|
|
|
// IceEventLog wraps RtcEventLog and provides structural logging of ICE-specific
|
|
// events. The logged events are serialized with other RtcEvent's if protobuf is
|
|
// enabled in the build.
|
|
class IceEventLog {
|
|
public:
|
|
IceEventLog();
|
|
~IceEventLog();
|
|
void set_event_log(RtcEventLog* event_log) { event_log_ = event_log; }
|
|
void LogCandidatePairEvent(
|
|
IceCandidatePairEventType type,
|
|
uint32_t candidate_pair_id,
|
|
const IceCandidatePairDescription& candidate_pair_desc);
|
|
// This method constructs a config event for each candidate pair with their
|
|
// description and logs these config events. It is intended to be called when
|
|
// logging starts to ensure that we have at least one config for each
|
|
// candidate pair id.
|
|
void DumpCandidatePairDescriptionToMemoryAsConfigEvents() const;
|
|
|
|
private:
|
|
bool IsIceCandidatePairConfigEvent(IceCandidatePairEventType type);
|
|
|
|
RtcEventLog* event_log_ = nullptr;
|
|
std::unordered_map<uint32_t, IceCandidatePairDescription>
|
|
candidate_pair_desc_by_id_;
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // LOGGING_RTC_EVENT_LOG_ICELOGGER_H_
|