Home | History | Annotate | Download | only in domain_reliability
      1 // Copyright 2014 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 COMPONENTS_DOMAIN_RELIABILITY_MONITOR_H_
      6 #define COMPONENTS_DOMAIN_RELIABILITY_MONITOR_H_
      7 
      8 #include <map>
      9 
     10 #include "base/memory/ref_counted.h"
     11 #include "base/memory/scoped_ptr.h"
     12 #include "base/memory/weak_ptr.h"
     13 #include "base/single_thread_task_runner.h"
     14 #include "base/time/time.h"
     15 #include "components/domain_reliability/beacon.h"
     16 #include "components/domain_reliability/clear_mode.h"
     17 #include "components/domain_reliability/config.h"
     18 #include "components/domain_reliability/context.h"
     19 #include "components/domain_reliability/dispatcher.h"
     20 #include "components/domain_reliability/domain_reliability_export.h"
     21 #include "components/domain_reliability/scheduler.h"
     22 #include "components/domain_reliability/uploader.h"
     23 #include "components/domain_reliability/util.h"
     24 #include "net/base/load_timing_info.h"
     25 #include "net/http/http_response_info.h"
     26 #include "net/url_request/url_request_status.h"
     27 
     28 namespace base {
     29 class ThreadChecker;
     30 class Value;
     31 }  // namespace base
     32 
     33 namespace net {
     34 class URLRequest;
     35 class URLRequestContext;
     36 class URLRequestContextGetter;
     37 }  // namespace net
     38 
     39 namespace domain_reliability {
     40 
     41 // The top-level object that measures requests and hands off the measurements
     42 // to the proper |DomainReliabilityContext|.
     43 class DOMAIN_RELIABILITY_EXPORT DomainReliabilityMonitor {
     44  public:
     45   // Creates a Monitor. |local_state_pref_service| must live on |pref_thread|
     46   // (which should be the current thread); |network_thread| is the thread
     47   // on which requests will actually be monitored and reported.
     48   DomainReliabilityMonitor(
     49       const std::string& upload_reporter_string,
     50       scoped_refptr<base::SingleThreadTaskRunner> pref_thread,
     51       scoped_refptr<base::SingleThreadTaskRunner> network_thread);
     52 
     53   // Same, but specifies a mock interface for time functions for testing.
     54   DomainReliabilityMonitor(
     55       const std::string& upload_reporter_string,
     56       scoped_refptr<base::SingleThreadTaskRunner> pref_thread,
     57       scoped_refptr<base::SingleThreadTaskRunner> network_thread,
     58       scoped_ptr<MockableTime> time);
     59 
     60   // Must be called from the pref thread if |MoveToNetworkThread| was not
     61   // called, or from the network thread if it was called.
     62   ~DomainReliabilityMonitor();
     63 
     64   // Must be called before |InitURLRequestContext| on the same thread on which
     65   // the Monitor was constructed. Moves (most of) the Monitor to the network
     66   // thread passed in the constructor.
     67   void MoveToNetworkThread();
     68 
     69   // All public methods below this point must be called on the network thread
     70   // after |MoveToNetworkThread| is called on the pref thread.
     71 
     72   // Initializes the Monitor's URLRequestContextGetter.
     73   //
     74   // Must be called on the network thread, after |MoveToNetworkThread|.
     75   void InitURLRequestContext(net::URLRequestContext* url_request_context);
     76 
     77   // Same, but for unittests where the Getter is readily available.
     78   void InitURLRequestContext(
     79       scoped_refptr<net::URLRequestContextGetter> url_request_context_getter);
     80 
     81   // Populates the monitor with contexts that were configured at compile time.
     82   void AddBakedInConfigs();
     83 
     84   // Sets whether the uploader will discard uploads. Must be called after
     85   // |InitURLRequestContext|.
     86   void SetDiscardUploads(bool discard_uploads);
     87 
     88   // Should be called when |request| is about to follow a redirect. Will
     89   // examine and possibly log the redirect request. Must be called after
     90   // |SetDiscardUploads|.
     91   void OnBeforeRedirect(net::URLRequest* request);
     92 
     93   // Should be called when |request| is complete. Will examine and possibly
     94   // log the (final) request. |started| should be true if the request was
     95   // actually started before it was terminated. Must be called after
     96   // |SetDiscardUploads|.
     97   void OnCompleted(net::URLRequest* request, bool started);
     98 
     99   // Called to remove browsing data. With CLEAR_BEACONS, leaves contexts in
    100   // place but clears beacons (which betray browsing history); with
    101   // CLEAR_CONTEXTS, removes all contexts (which can behave as cookies).
    102   void ClearBrowsingData(DomainReliabilityClearMode mode);
    103 
    104   // Gets a Value containing data that can be formatted into a web page for
    105   // debugging purposes.
    106   scoped_ptr<base::Value> GetWebUIData() const;
    107 
    108   DomainReliabilityContext* AddContextForTesting(
    109       scoped_ptr<const DomainReliabilityConfig> config);
    110 
    111   size_t contexts_size_for_testing() const { return contexts_.size(); }
    112 
    113  private:
    114   friend class DomainReliabilityMonitorTest;
    115   // Allow the Service to call |MakeWeakPtr|.
    116   friend class DomainReliabilityServiceImpl;
    117 
    118   typedef std::map<std::string, DomainReliabilityContext*> ContextMap;
    119 
    120   struct DOMAIN_RELIABILITY_EXPORT RequestInfo {
    121     RequestInfo();
    122     explicit RequestInfo(const net::URLRequest& request);
    123     ~RequestInfo();
    124 
    125     bool AccessedNetwork() const;
    126 
    127     GURL url;
    128     net::URLRequestStatus status;
    129     net::HttpResponseInfo response_info;
    130     int load_flags;
    131     net::LoadTimingInfo load_timing_info;
    132     bool is_upload;
    133   };
    134 
    135   // Creates a context, adds it to the monitor, and returns a pointer to it.
    136   // (The pointer is only valid until the Monitor is destroyed.)
    137   DomainReliabilityContext* AddContext(
    138       scoped_ptr<const DomainReliabilityConfig> config);
    139   // Deletes all contexts from |contexts_| and clears the map.
    140   void ClearContexts();
    141   void OnRequestLegComplete(const RequestInfo& info);
    142 
    143   DomainReliabilityContext* GetContextForHost(const std::string& host) const;
    144 
    145   bool OnPrefThread() const {
    146     return pref_task_runner_->BelongsToCurrentThread();
    147   }
    148   bool OnNetworkThread() const {
    149     return network_task_runner_->BelongsToCurrentThread();
    150   }
    151 
    152   base::WeakPtr<DomainReliabilityMonitor> MakeWeakPtr();
    153 
    154   scoped_ptr<MockableTime> time_;
    155   const std::string upload_reporter_string_;
    156   DomainReliabilityScheduler::Params scheduler_params_;
    157   DomainReliabilityDispatcher dispatcher_;
    158   scoped_ptr<DomainReliabilityUploader> uploader_;
    159   ContextMap contexts_;
    160 
    161   scoped_refptr<base::SingleThreadTaskRunner> pref_task_runner_;
    162   scoped_refptr<base::SingleThreadTaskRunner> network_task_runner_;
    163 
    164   bool moved_to_network_thread_;
    165   bool discard_uploads_set_;
    166 
    167   base::WeakPtrFactory<DomainReliabilityMonitor> weak_factory_;
    168 
    169   DISALLOW_COPY_AND_ASSIGN(DomainReliabilityMonitor);
    170 };
    171 
    172 }  // namespace domain_reliability
    173 
    174 #endif  // COMPONENTS_DOMAIN_RELIABILITY_MONITOR_H_
    175