// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef COMPONENTS_DOMAIN_RELIABILITY_MONITOR_H_ #define COMPONENTS_DOMAIN_RELIABILITY_MONITOR_H_ #include <map> #include "base/memory/ref_counted.h" #include "base/memory/scoped_ptr.h" #include "base/memory/weak_ptr.h" #include "base/single_thread_task_runner.h" #include "base/time/time.h" #include "components/domain_reliability/beacon.h" #include "components/domain_reliability/clear_mode.h" #include "components/domain_reliability/config.h" #include "components/domain_reliability/context.h" #include "components/domain_reliability/dispatcher.h" #include "components/domain_reliability/domain_reliability_export.h" #include "components/domain_reliability/scheduler.h" #include "components/domain_reliability/uploader.h" #include "components/domain_reliability/util.h" #include "net/base/load_timing_info.h" #include "net/http/http_response_info.h" #include "net/url_request/url_request_status.h" namespace base { class ThreadChecker; class Value; } // namespace base namespace net { class URLRequest; class URLRequestContext; class URLRequestContextGetter; } // namespace net namespace domain_reliability { // The top-level object that measures requests and hands off the measurements // to the proper |DomainReliabilityContext|. class DOMAIN_RELIABILITY_EXPORT DomainReliabilityMonitor { public: // Creates a Monitor. |local_state_pref_service| must live on |pref_thread| // (which should be the current thread); |network_thread| is the thread // on which requests will actually be monitored and reported. DomainReliabilityMonitor( const std::string& upload_reporter_string, scoped_refptr<base::SingleThreadTaskRunner> pref_thread, scoped_refptr<base::SingleThreadTaskRunner> network_thread); // Same, but specifies a mock interface for time functions for testing. DomainReliabilityMonitor( const std::string& upload_reporter_string, scoped_refptr<base::SingleThreadTaskRunner> pref_thread, scoped_refptr<base::SingleThreadTaskRunner> network_thread, scoped_ptr<MockableTime> time); // Must be called from the pref thread if |MoveToNetworkThread| was not // called, or from the network thread if it was called. ~DomainReliabilityMonitor(); // Must be called before |InitURLRequestContext| on the same thread on which // the Monitor was constructed. Moves (most of) the Monitor to the network // thread passed in the constructor. void MoveToNetworkThread(); // All public methods below this point must be called on the network thread // after |MoveToNetworkThread| is called on the pref thread. // Initializes the Monitor's URLRequestContextGetter. // // Must be called on the network thread, after |MoveToNetworkThread|. void InitURLRequestContext(net::URLRequestContext* url_request_context); // Same, but for unittests where the Getter is readily available. void InitURLRequestContext( scoped_refptr<net::URLRequestContextGetter> url_request_context_getter); // Populates the monitor with contexts that were configured at compile time. void AddBakedInConfigs(); // Sets whether the uploader will discard uploads. Must be called after // |InitURLRequestContext|. void SetDiscardUploads(bool discard_uploads); // Should be called when |request| is about to follow a redirect. Will // examine and possibly log the redirect request. Must be called after // |SetDiscardUploads|. void OnBeforeRedirect(net::URLRequest* request); // Should be called when |request| is complete. Will examine and possibly // log the (final) request. |started| should be true if the request was // actually started before it was terminated. Must be called after // |SetDiscardUploads|. void OnCompleted(net::URLRequest* request, bool started); // Called to remove browsing data. With CLEAR_BEACONS, leaves contexts in // place but clears beacons (which betray browsing history); with // CLEAR_CONTEXTS, removes all contexts (which can behave as cookies). void ClearBrowsingData(DomainReliabilityClearMode mode); // Gets a Value containing data that can be formatted into a web page for // debugging purposes. scoped_ptr<base::Value> GetWebUIData() const; DomainReliabilityContext* AddContextForTesting( scoped_ptr<const DomainReliabilityConfig> config); size_t contexts_size_for_testing() const { return contexts_.size(); } private: friend class DomainReliabilityMonitorTest; // Allow the Service to call |MakeWeakPtr|. friend class DomainReliabilityServiceImpl; typedef std::map<std::string, DomainReliabilityContext*> ContextMap; struct DOMAIN_RELIABILITY_EXPORT RequestInfo { RequestInfo(); explicit RequestInfo(const net::URLRequest& request); ~RequestInfo(); bool AccessedNetwork() const; GURL url; net::URLRequestStatus status; net::HttpResponseInfo response_info; int load_flags; net::LoadTimingInfo load_timing_info; bool is_upload; }; // Creates a context, adds it to the monitor, and returns a pointer to it. // (The pointer is only valid until the Monitor is destroyed.) DomainReliabilityContext* AddContext( scoped_ptr<const DomainReliabilityConfig> config); // Deletes all contexts from |contexts_| and clears the map. void ClearContexts(); void OnRequestLegComplete(const RequestInfo& info); DomainReliabilityContext* GetContextForHost(const std::string& host) const; bool OnPrefThread() const { return pref_task_runner_->BelongsToCurrentThread(); } bool OnNetworkThread() const { return network_task_runner_->BelongsToCurrentThread(); } base::WeakPtr<DomainReliabilityMonitor> MakeWeakPtr(); scoped_ptr<MockableTime> time_; const std::string upload_reporter_string_; DomainReliabilityScheduler::Params scheduler_params_; DomainReliabilityDispatcher dispatcher_; scoped_ptr<DomainReliabilityUploader> uploader_; ContextMap contexts_; scoped_refptr<base::SingleThreadTaskRunner> pref_task_runner_; scoped_refptr<base::SingleThreadTaskRunner> network_task_runner_; bool moved_to_network_thread_; bool discard_uploads_set_; base::WeakPtrFactory<DomainReliabilityMonitor> weak_factory_; DISALLOW_COPY_AND_ASSIGN(DomainReliabilityMonitor); }; } // namespace domain_reliability #endif // COMPONENTS_DOMAIN_RELIABILITY_MONITOR_H_