1*6777b538SAndroid Build Coastguard Worker // Copyright 2012 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker
5*6777b538SAndroid Build Coastguard Worker #include "net/log/test_net_log.h"
6*6777b538SAndroid Build Coastguard Worker
7*6777b538SAndroid Build Coastguard Worker #include "base/synchronization/lock.h"
8*6777b538SAndroid Build Coastguard Worker #include "base/values.h"
9*6777b538SAndroid Build Coastguard Worker #include "net/log/net_log_capture_mode.h"
10*6777b538SAndroid Build Coastguard Worker #include "net/log/net_log_entry.h"
11*6777b538SAndroid Build Coastguard Worker #include "net/log/net_log_source.h"
12*6777b538SAndroid Build Coastguard Worker #include "net/log/net_log_source_type.h"
13*6777b538SAndroid Build Coastguard Worker
14*6777b538SAndroid Build Coastguard Worker namespace net {
15*6777b538SAndroid Build Coastguard Worker
RecordingNetLogObserver()16*6777b538SAndroid Build Coastguard Worker RecordingNetLogObserver::RecordingNetLogObserver()
17*6777b538SAndroid Build Coastguard Worker : RecordingNetLogObserver(NetLogCaptureMode::kIncludeSensitive) {}
18*6777b538SAndroid Build Coastguard Worker
RecordingNetLogObserver(NetLogCaptureMode capture_mode)19*6777b538SAndroid Build Coastguard Worker RecordingNetLogObserver::RecordingNetLogObserver(NetLogCaptureMode capture_mode)
20*6777b538SAndroid Build Coastguard Worker : RecordingNetLogObserver(NetLog::Get(), capture_mode) {}
21*6777b538SAndroid Build Coastguard Worker
RecordingNetLogObserver(NetLog * net_log,NetLogCaptureMode capture_mode)22*6777b538SAndroid Build Coastguard Worker RecordingNetLogObserver::RecordingNetLogObserver(NetLog* net_log,
23*6777b538SAndroid Build Coastguard Worker NetLogCaptureMode capture_mode)
24*6777b538SAndroid Build Coastguard Worker : net_log_(net_log) {
25*6777b538SAndroid Build Coastguard Worker net_log_->AddObserver(this, capture_mode);
26*6777b538SAndroid Build Coastguard Worker }
27*6777b538SAndroid Build Coastguard Worker
~RecordingNetLogObserver()28*6777b538SAndroid Build Coastguard Worker RecordingNetLogObserver::~RecordingNetLogObserver() {
29*6777b538SAndroid Build Coastguard Worker net_log_->RemoveObserver(this);
30*6777b538SAndroid Build Coastguard Worker }
31*6777b538SAndroid Build Coastguard Worker
GetEntries() const32*6777b538SAndroid Build Coastguard Worker std::vector<NetLogEntry> RecordingNetLogObserver::GetEntries() const {
33*6777b538SAndroid Build Coastguard Worker base::AutoLock lock(lock_);
34*6777b538SAndroid Build Coastguard Worker std::vector<NetLogEntry> result;
35*6777b538SAndroid Build Coastguard Worker for (const auto& entry : entry_list_)
36*6777b538SAndroid Build Coastguard Worker result.push_back(entry.Clone());
37*6777b538SAndroid Build Coastguard Worker return result;
38*6777b538SAndroid Build Coastguard Worker }
39*6777b538SAndroid Build Coastguard Worker
GetEntriesForSource(NetLogSource source) const40*6777b538SAndroid Build Coastguard Worker std::vector<NetLogEntry> RecordingNetLogObserver::GetEntriesForSource(
41*6777b538SAndroid Build Coastguard Worker NetLogSource source) const {
42*6777b538SAndroid Build Coastguard Worker base::AutoLock lock(lock_);
43*6777b538SAndroid Build Coastguard Worker std::vector<NetLogEntry> result;
44*6777b538SAndroid Build Coastguard Worker for (const auto& entry : entry_list_) {
45*6777b538SAndroid Build Coastguard Worker if (entry.source.id == source.id)
46*6777b538SAndroid Build Coastguard Worker result.push_back(entry.Clone());
47*6777b538SAndroid Build Coastguard Worker }
48*6777b538SAndroid Build Coastguard Worker return result;
49*6777b538SAndroid Build Coastguard Worker }
50*6777b538SAndroid Build Coastguard Worker
GetEntriesWithType(NetLogEventType type) const51*6777b538SAndroid Build Coastguard Worker std::vector<NetLogEntry> RecordingNetLogObserver::GetEntriesWithType(
52*6777b538SAndroid Build Coastguard Worker NetLogEventType type) const {
53*6777b538SAndroid Build Coastguard Worker base::AutoLock lock(lock_);
54*6777b538SAndroid Build Coastguard Worker std::vector<NetLogEntry> result;
55*6777b538SAndroid Build Coastguard Worker for (const auto& entry : entry_list_) {
56*6777b538SAndroid Build Coastguard Worker if (entry.type == type)
57*6777b538SAndroid Build Coastguard Worker result.push_back(entry.Clone());
58*6777b538SAndroid Build Coastguard Worker }
59*6777b538SAndroid Build Coastguard Worker return result;
60*6777b538SAndroid Build Coastguard Worker }
61*6777b538SAndroid Build Coastguard Worker
GetEntriesForSourceWithType(NetLogSource source,NetLogEventType type,NetLogEventPhase phase) const62*6777b538SAndroid Build Coastguard Worker std::vector<NetLogEntry> RecordingNetLogObserver::GetEntriesForSourceWithType(
63*6777b538SAndroid Build Coastguard Worker NetLogSource source,
64*6777b538SAndroid Build Coastguard Worker NetLogEventType type,
65*6777b538SAndroid Build Coastguard Worker NetLogEventPhase phase) const {
66*6777b538SAndroid Build Coastguard Worker base::AutoLock lock(lock_);
67*6777b538SAndroid Build Coastguard Worker std::vector<NetLogEntry> result;
68*6777b538SAndroid Build Coastguard Worker for (const auto& entry : entry_list_) {
69*6777b538SAndroid Build Coastguard Worker if (entry.source.id == source.id && entry.type == type &&
70*6777b538SAndroid Build Coastguard Worker entry.phase == phase) {
71*6777b538SAndroid Build Coastguard Worker result.push_back(entry.Clone());
72*6777b538SAndroid Build Coastguard Worker }
73*6777b538SAndroid Build Coastguard Worker }
74*6777b538SAndroid Build Coastguard Worker return result;
75*6777b538SAndroid Build Coastguard Worker }
76*6777b538SAndroid Build Coastguard Worker
GetSize() const77*6777b538SAndroid Build Coastguard Worker size_t RecordingNetLogObserver::GetSize() const {
78*6777b538SAndroid Build Coastguard Worker base::AutoLock lock(lock_);
79*6777b538SAndroid Build Coastguard Worker return entry_list_.size();
80*6777b538SAndroid Build Coastguard Worker }
81*6777b538SAndroid Build Coastguard Worker
Clear()82*6777b538SAndroid Build Coastguard Worker void RecordingNetLogObserver::Clear() {
83*6777b538SAndroid Build Coastguard Worker base::AutoLock lock(lock_);
84*6777b538SAndroid Build Coastguard Worker entry_list_.clear();
85*6777b538SAndroid Build Coastguard Worker }
86*6777b538SAndroid Build Coastguard Worker
OnAddEntry(const NetLogEntry & entry)87*6777b538SAndroid Build Coastguard Worker void RecordingNetLogObserver::OnAddEntry(const NetLogEntry& entry) {
88*6777b538SAndroid Build Coastguard Worker base::Value::Dict params = entry.params.Clone();
89*6777b538SAndroid Build Coastguard Worker base::RepeatingClosure add_entry_callback;
90*6777b538SAndroid Build Coastguard Worker {
91*6777b538SAndroid Build Coastguard Worker // Only need to acquire the lock when accessing class variables.
92*6777b538SAndroid Build Coastguard Worker base::AutoLock lock(lock_);
93*6777b538SAndroid Build Coastguard Worker entry_list_.emplace_back(entry.type, entry.source, entry.phase, entry.time,
94*6777b538SAndroid Build Coastguard Worker std::move(params));
95*6777b538SAndroid Build Coastguard Worker add_entry_callback = add_entry_callback_;
96*6777b538SAndroid Build Coastguard Worker }
97*6777b538SAndroid Build Coastguard Worker if (!add_entry_callback.is_null())
98*6777b538SAndroid Build Coastguard Worker add_entry_callback.Run();
99*6777b538SAndroid Build Coastguard Worker }
100*6777b538SAndroid Build Coastguard Worker
SetObserverCaptureMode(NetLogCaptureMode capture_mode)101*6777b538SAndroid Build Coastguard Worker void RecordingNetLogObserver::SetObserverCaptureMode(
102*6777b538SAndroid Build Coastguard Worker NetLogCaptureMode capture_mode) {
103*6777b538SAndroid Build Coastguard Worker net_log_->RemoveObserver(this);
104*6777b538SAndroid Build Coastguard Worker net_log_->AddObserver(this, capture_mode);
105*6777b538SAndroid Build Coastguard Worker }
106*6777b538SAndroid Build Coastguard Worker
SetThreadsafeAddEntryCallback(base::RepeatingClosure add_entry_callback)107*6777b538SAndroid Build Coastguard Worker void RecordingNetLogObserver::SetThreadsafeAddEntryCallback(
108*6777b538SAndroid Build Coastguard Worker base::RepeatingClosure add_entry_callback) {
109*6777b538SAndroid Build Coastguard Worker base::AutoLock lock(lock_);
110*6777b538SAndroid Build Coastguard Worker add_entry_callback_ = add_entry_callback;
111*6777b538SAndroid Build Coastguard Worker }
112*6777b538SAndroid Build Coastguard Worker
113*6777b538SAndroid Build Coastguard Worker } // namespace net
114