simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 1 | // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
| 5 | #ifndef CONTENT_BROWSER_TRACING_BACKGROUND_TRACING_MANAGER_IMPL_H_ |
| 6 | #define CONTENT_BROWSER_TRACING_BACKGROUND_TRACING_MANAGER_IMPL_H_ |
| 7 | |
Ehsan Chiniforooshan | a09fc88 | 2017-06-14 16:24:38 | [diff] [blame] | 8 | #include <map> |
dcheng | 5971627 | 2016-04-09 05:19:08 | [diff] [blame] | 9 | #include <memory> |
Ehsan Chiniforooshan | a09fc88 | 2017-06-14 16:24:38 | [diff] [blame] | 10 | #include <set> |
| 11 | #include <string> |
dcheng | 5971627 | 2016-04-09 05:19:08 | [diff] [blame] | 12 | |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 13 | #include "base/lazy_instance.h" |
avi | b734894 | 2015-12-25 20:57:10 | [diff] [blame] | 14 | #include "base/macros.h" |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 15 | #include "base/memory/ref_counted_memory.h" |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 16 | #include "base/memory/weak_ptr.h" |
simonhatch | 2ad3355b | 2015-07-18 03:51:08 | [diff] [blame] | 17 | #include "base/metrics/histogram.h" |
oysteine | f4ce0b06 | 2015-08-26 01:33:06 | [diff] [blame] | 18 | #include "content/browser/tracing/background_tracing_config_impl.h" |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 19 | #include "content/browser/tracing/tracing_controller_impl.h" |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 20 | #include "content/public/browser/background_tracing_manager.h" |
| 21 | |
| 22 | namespace content { |
| 23 | |
oysteine | f4ce0b06 | 2015-08-26 01:33:06 | [diff] [blame] | 24 | class BackgroundTracingRule; |
Ehsan Chiniforooshan | a09fc88 | 2017-06-14 16:24:38 | [diff] [blame] | 25 | class TraceMessageFilter; |
oysteine | 386fc9e | 2015-06-07 18:45:41 | [diff] [blame] | 26 | class TracingDelegate; |
| 27 | |
oysteine | f4ce0b06 | 2015-08-26 01:33:06 | [diff] [blame] | 28 | class BackgroundTracingManagerImpl : public BackgroundTracingManager { |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 29 | public: |
ssid | eb54962 | 2017-03-29 21:46:00 | [diff] [blame] | 30 | // Enabled state observers get a callback when the state of background tracing |
| 31 | // changes. |
| 32 | class CONTENT_EXPORT EnabledStateObserver { |
| 33 | public: |
| 34 | // Called when the activation of a background tracing scenario is |
| 35 | // successful. |
| 36 | virtual void OnScenarioActivated( |
| 37 | const BackgroundTracingConfigImpl* config) = 0; |
| 38 | |
Siddhartha | 24ef3c47 | 2017-08-22 00:19:20 | [diff] [blame] | 39 | // In case the scenario was aborted before or after tracing was enabled. |
| 40 | virtual void OnScenarioAborted() = 0; |
| 41 | |
ssid | eb54962 | 2017-03-29 21:46:00 | [diff] [blame] | 42 | // Called after tracing is enabled on all processes because the rule was |
| 43 | // triggered. |
| 44 | virtual void OnTracingEnabled( |
| 45 | BackgroundTracingConfigImpl::CategoryPreset preset) = 0; |
| 46 | |
| 47 | virtual ~EnabledStateObserver() = default; |
| 48 | }; |
| 49 | |
Ehsan Chiniforooshan | a09fc88 | 2017-06-14 16:24:38 | [diff] [blame] | 50 | class TraceMessageFilterObserver { |
| 51 | public: |
| 52 | virtual void OnTraceMessageFilterAdded(TraceMessageFilter* filter) = 0; |
| 53 | virtual void OnTraceMessageFilterRemoved(TraceMessageFilter* filter) = 0; |
| 54 | }; |
| 55 | |
ssid | eb54962 | 2017-03-29 21:46:00 | [diff] [blame] | 56 | CONTENT_EXPORT static BackgroundTracingManagerImpl* GetInstance(); |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 57 | |
dcheng | 5971627 | 2016-04-09 05:19:08 | [diff] [blame] | 58 | bool SetActiveScenario(std::unique_ptr<BackgroundTracingConfig>, |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 59 | const ReceiveCallback&, |
oysteine | af2b800 | 2015-06-06 05:02:28 | [diff] [blame] | 60 | DataFiltering data_filtering) override; |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 61 | void WhenIdle(IdleCallback idle_callback) override; |
| 62 | |
| 63 | void TriggerNamedEvent(TriggerHandle, StartedFinalizingCallback) override; |
| 64 | TriggerHandle RegisterTriggerType(const char* trigger_name) override; |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 65 | |
oysteine | a7d2d84 | 2015-10-21 20:57:07 | [diff] [blame] | 66 | void OnHistogramTrigger(const std::string& histogram_name); |
| 67 | |
| 68 | void OnRuleTriggered(const BackgroundTracingRule* triggered_rule, |
| 69 | StartedFinalizingCallback callback); |
| 70 | void AbortScenario(); |
oysteine | 5377260 | 2015-11-02 22:41:27 | [diff] [blame] | 71 | bool HasActiveScenario() override; |
oysteine | a7d2d84 | 2015-10-21 20:57:07 | [diff] [blame] | 72 | |
ssid | eb54962 | 2017-03-29 21:46:00 | [diff] [blame] | 73 | void OnStartTracingDone(BackgroundTracingConfigImpl::CategoryPreset preset); |
| 74 | |
| 75 | // Add/remove EnabledStateObserver. |
| 76 | CONTENT_EXPORT void AddEnabledStateObserver(EnabledStateObserver* observer); |
| 77 | CONTENT_EXPORT void RemoveEnabledStateObserver( |
| 78 | EnabledStateObserver* observer); |
| 79 | |
Ehsan Chiniforooshan | a09fc88 | 2017-06-14 16:24:38 | [diff] [blame] | 80 | // Add/remove TraceMessageFilter{Observer}. |
| 81 | void AddTraceMessageFilter(TraceMessageFilter* trace_message_filter); |
| 82 | void RemoveTraceMessageFilter(TraceMessageFilter* trace_message_filter); |
| 83 | void AddTraceMessageFilterObserver(TraceMessageFilterObserver* observer); |
| 84 | void RemoveTraceMessageFilterObserver(TraceMessageFilterObserver* observer); |
| 85 | |
oysteine | a7d2d84 | 2015-10-21 20:57:07 | [diff] [blame] | 86 | // For tests |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 87 | void InvalidateTriggerHandlesForTesting() override; |
oysteine | a7d2d84 | 2015-10-21 20:57:07 | [diff] [blame] | 88 | CONTENT_EXPORT void SetRuleTriggeredCallbackForTesting( |
| 89 | const base::Closure& callback); |
fmeawad | 743fcdf | 2015-06-03 23:55:34 | [diff] [blame] | 90 | void FireTimerForTesting() override; |
oysteine | a7d2d84 | 2015-10-21 20:57:07 | [diff] [blame] | 91 | CONTENT_EXPORT bool IsTracingForTesting(); |
oysteine | f4ce0b06 | 2015-08-26 01:33:06 | [diff] [blame] | 92 | |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 93 | private: |
| 94 | BackgroundTracingManagerImpl(); |
| 95 | ~BackgroundTracingManagerImpl() override; |
| 96 | |
ssid | 8ed4516 | 2016-06-04 08:13:26 | [diff] [blame] | 97 | void StartTracing(BackgroundTracingConfigImpl::CategoryPreset, |
| 98 | base::trace_event::TraceRecordMode); |
zhenw | 873bdff | 2015-11-11 22:16:55 | [diff] [blame] | 99 | void StartTracingIfConfigNeedsIt(); |
dcheng | 5971627 | 2016-04-09 05:19:08 | [diff] [blame] | 100 | void OnFinalizeStarted(std::unique_ptr<const base::DictionaryValue> metadata, |
| 101 | base::RefCountedString*); |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 102 | void OnFinalizeComplete(); |
| 103 | void BeginFinalizing(StartedFinalizingCallback); |
oysteine | 4b43fe0f | 2015-06-12 19:23:08 | [diff] [blame] | 104 | void ValidateStartupScenario(); |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 105 | |
caseq | bffe4e6 | 2016-07-14 02:09:14 | [diff] [blame] | 106 | void AddCustomMetadata(); |
simonhatch | 0cc9fee | 2015-06-15 22:26:19 | [diff] [blame] | 107 | |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 108 | std::string GetTriggerNameFromHandle(TriggerHandle handle) const; |
| 109 | bool IsTriggerHandleValid(TriggerHandle handle) const; |
| 110 | |
oysteine | f4ce0b06 | 2015-08-26 01:33:06 | [diff] [blame] | 111 | BackgroundTracingRule* GetRuleAbleToTriggerTracing( |
| 112 | TriggerHandle handle) const; |
| 113 | bool IsSupportedConfig(BackgroundTracingConfigImpl* config); |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 114 | |
zhenw | d601ddc5 | 2015-06-02 21:46:34 | [diff] [blame] | 115 | std::string GetCategoryFilterStringForCategoryPreset( |
oysteine | f4ce0b06 | 2015-08-26 01:33:06 | [diff] [blame] | 116 | BackgroundTracingConfigImpl::CategoryPreset) const; |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 117 | |
fmeawad | 743fcdf | 2015-06-03 23:55:34 | [diff] [blame] | 118 | class TracingTimer { |
| 119 | public: |
| 120 | explicit TracingTimer(StartedFinalizingCallback); |
| 121 | ~TracingTimer(); |
| 122 | |
simonhatch | 99cf30b | 2015-08-27 14:58:25 | [diff] [blame] | 123 | void StartTimer(int seconds); |
fmeawad | 743fcdf | 2015-06-03 23:55:34 | [diff] [blame] | 124 | void CancelTimer(); |
fmeawad | 743fcdf | 2015-06-03 23:55:34 | [diff] [blame] | 125 | void FireTimerForTesting(); |
| 126 | |
| 127 | private: |
| 128 | void TracingTimerFired(); |
| 129 | |
danakj | 8c3eb80 | 2015-09-24 07:53:00 | [diff] [blame] | 130 | base::OneShotTimer tracing_timer_; |
fmeawad | 743fcdf | 2015-06-03 23:55:34 | [diff] [blame] | 131 | StartedFinalizingCallback callback_; |
| 132 | }; |
| 133 | |
dcheng | 5971627 | 2016-04-09 05:19:08 | [diff] [blame] | 134 | std::unique_ptr<TracingDelegate> delegate_; |
| 135 | std::unique_ptr<const content::BackgroundTracingConfigImpl> config_; |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 136 | std::map<TriggerHandle, std::string> trigger_handles_; |
dcheng | 5971627 | 2016-04-09 05:19:08 | [diff] [blame] | 137 | std::unique_ptr<TracingTimer> tracing_timer_; |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 138 | ReceiveCallback receive_callback_; |
oysteine | 59dc400 | 2016-06-07 21:27:09 | [diff] [blame] | 139 | std::unique_ptr<base::DictionaryValue> last_triggered_rule_; |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 140 | bool is_gathering_; |
| 141 | bool is_tracing_; |
| 142 | bool requires_anonymized_data_; |
| 143 | int trigger_handle_ids_; |
| 144 | |
oysteine | a7d2d84 | 2015-10-21 20:57:07 | [diff] [blame] | 145 | TriggerHandle triggered_named_event_handle_; |
simonhatch | 99cf30b | 2015-08-27 14:58:25 | [diff] [blame] | 146 | |
Ehsan Chiniforooshan | a09fc88 | 2017-06-14 16:24:38 | [diff] [blame] | 147 | // There is no need to use base::ObserverList to store observers because we |
| 148 | // only access |background_tracing_observers_| and |
| 149 | // |trace_message_filter_observers_| from the UI thread. |
| 150 | std::set<EnabledStateObserver*> background_tracing_observers_; |
| 151 | std::set<scoped_refptr<TraceMessageFilter>> trace_message_filters_; |
| 152 | std::set<TraceMessageFilterObserver*> trace_message_filter_observers_; |
ssid | eb54962 | 2017-03-29 21:46:00 | [diff] [blame] | 153 | |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 154 | IdleCallback idle_callback_; |
oysteine | af2b800 | 2015-06-06 05:02:28 | [diff] [blame] | 155 | base::Closure tracing_enabled_callback_for_testing_; |
oysteine | a7d2d84 | 2015-10-21 20:57:07 | [diff] [blame] | 156 | base::Closure rule_triggered_callback_for_testing_; |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 157 | |
scottmg | 5e65e3a | 2017-03-08 08:48:46 | [diff] [blame] | 158 | friend struct base::LazyInstanceTraitsBase<BackgroundTracingManagerImpl>; |
simonhatch | 0b01619 | 2015-05-22 19:14:02 | [diff] [blame] | 159 | |
| 160 | DISALLOW_COPY_AND_ASSIGN(BackgroundTracingManagerImpl); |
| 161 | }; |
| 162 | |
| 163 | } // namespace content |
| 164 | |
| 165 | #endif // CONTENT_BROWSER_TRACING_BACKGROUND_TRACING_MANAGER_IMPL_H_ |