// 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 #include #include "base/macros.h" #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/context_manager.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/ip_endpoint.h" #include "net/base/load_timing_info.h" #include "net/base/net_error_details.h" #include "net/base/network_change_notifier.h" #include "net/http/http_response_info.h" #include "net/socket/connection_attempts.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 net::NetworkChangeNotifier::NetworkChangeObserver, DomainReliabilityContext::Factory { 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, const scoped_refptr& pref_thread, const scoped_refptr& network_thread); // Same, but specifies a mock interface for time functions for testing. DomainReliabilityMonitor( const std::string& upload_reporter_string, const scoped_refptr& pref_thread, const scoped_refptr& network_thread, scoped_ptr time); // Must be called from the pref thread if |MoveToNetworkThread| was not // called, or from the network thread if it was called. ~DomainReliabilityMonitor() override; // 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( const scoped_refptr& 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); // net::NetworkChangeNotifier::NetworkChangeObserver implementation: void OnNetworkChanged( net::NetworkChangeNotifier::ConnectionType type) override; // 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 GetWebUIData() const; DomainReliabilityContext* AddContextForTesting( scoped_ptr config); size_t contexts_size_for_testing() const { return context_manager_.contexts_size_for_testing(); } // DomainReliabilityContext::Factory implementation: scoped_ptr CreateContextForConfig( scoped_ptr config) override; private: friend class DomainReliabilityMonitorTest; // Allow the Service to call |MakeWeakPtr|. friend class DomainReliabilityServiceImpl; typedef std::map ContextMap; struct DOMAIN_RELIABILITY_EXPORT RequestInfo { RequestInfo(); explicit RequestInfo(const net::URLRequest& request); ~RequestInfo(); static bool ShouldReportRequest(const RequestInfo& request); GURL url; net::URLRequestStatus status; net::HttpResponseInfo response_info; int load_flags; net::LoadTimingInfo load_timing_info; net::ConnectionAttempts connection_attempts; net::IPEndPoint remote_endpoint; int upload_depth; net::NetErrorDetails details; }; void OnRequestLegComplete(const RequestInfo& info); bool OnPrefThread() const { return pref_task_runner_->BelongsToCurrentThread(); } bool OnNetworkThread() const { return network_task_runner_->BelongsToCurrentThread(); } base::WeakPtr MakeWeakPtr(); scoped_ptr time_; base::TimeTicks last_network_change_time_; const std::string upload_reporter_string_; DomainReliabilityScheduler::Params scheduler_params_; DomainReliabilityDispatcher dispatcher_; scoped_ptr uploader_; DomainReliabilityContextManager context_manager_; scoped_refptr pref_task_runner_; scoped_refptr network_task_runner_; bool moved_to_network_thread_; bool discard_uploads_set_; base::WeakPtrFactory weak_factory_; DISALLOW_COPY_AND_ASSIGN(DomainReliabilityMonitor); }; } // namespace domain_reliability #endif // COMPONENTS_DOMAIN_RELIABILITY_MONITOR_H_