Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(382)

Side by Side Diff: chrome/browser/safe_browsing/threat_details_cache.h

Issue 1420053005: Move code in components/safe_browsing_db and chrome/browser/s_b/ under the safe_browsing namespace. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@02_components_move
Patch Set: Other minor fixes incl. using "using safe_browsing::ClassName" instead of safe_browsing::ClassName everywhere. Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_SAFE_BROWSING_THREAT_DETAILS_CACHE_H_ 5 #ifndef CHROME_BROWSER_SAFE_BROWSING_THREAT_DETAILS_CACHE_H_
6 #define CHROME_BROWSER_SAFE_BROWSING_THREAT_DETAILS_CACHE_H_ 6 #define CHROME_BROWSER_SAFE_BROWSING_THREAT_DETAILS_CACHE_H_
7 7
8 // A class that gets threat details from the HTTP Cache. 8 // A class that gets threat details from the HTTP Cache.
9 // An instance of this class is generated by ThreatDetails. 9 // An instance of this class is generated by ThreatDetails.
10 10
11 #include <string> 11 #include <string>
12 #include <vector> 12 #include <vector>
13 13
14 #include "base/callback.h" 14 #include "base/callback.h"
15 #include "base/containers/hash_tables.h" 15 #include "base/containers/hash_tables.h"
16 #include "base/memory/linked_ptr.h" 16 #include "base/memory/linked_ptr.h"
17 #include "base/memory/ref_counted.h" 17 #include "base/memory/ref_counted.h"
18 #include "chrome/browser/safe_browsing/report.pb.h" 18 #include "chrome/browser/safe_browsing/report.pb.h"
19 #include "net/base/completion_callback.h" 19 #include "net/base/completion_callback.h"
20 #include "net/url_request/url_fetcher_delegate.h" 20 #include "net/url_request/url_fetcher_delegate.h"
21 21
22 namespace net { 22 namespace net {
23 class URLFetcher; 23 class URLFetcher;
24 class URLRequestContext; 24 class URLRequestContext;
25 } 25 }
26 26
27 namespace safe_browsing { 27 namespace safe_browsing {
28 28
29 // Maps a URL to its Resource. 29 // Maps a URL to its Resource.
30 typedef base::hash_map< 30 typedef base::hash_map<std::string,
31 std::string, 31 linked_ptr<ClientMalwareReportRequest::Resource>>
32 linked_ptr<safe_browsing::ClientMalwareReportRequest::Resource>>
33 ResourceMap; 32 ResourceMap;
34 }
35 33
36 class ThreatDetailsCacheCollector 34 class ThreatDetailsCacheCollector
37 : public base::RefCountedThreadSafe<ThreatDetailsCacheCollector>, 35 : public base::RefCountedThreadSafe<ThreatDetailsCacheCollector>,
38 public net::URLFetcherDelegate { 36 public net::URLFetcherDelegate {
39 public: 37 public:
40 ThreatDetailsCacheCollector(); 38 ThreatDetailsCacheCollector();
41 39
42 // We use |request_context_getter|, we modify |resources| and 40 // We use |request_context_getter|, we modify |resources| and
43 // |result|, and we call |callback|, so they must all remain alive 41 // |result|, and we call |callback|, so they must all remain alive
44 // for the lifetime of this object. 42 // for the lifetime of this object.
45 void StartCacheCollection( 43 void StartCacheCollection(
46 net::URLRequestContextGetter* request_context_getter, 44 net::URLRequestContextGetter* request_context_getter,
47 safe_browsing::ResourceMap* resources, 45 ResourceMap* resources,
48 bool* result, 46 bool* result,
49 const base::Closure& callback); 47 const base::Closure& callback);
50 48
51 // Returns whether or not StartCacheCollection has been called. 49 // Returns whether or not StartCacheCollection has been called.
52 bool HasStarted(); 50 bool HasStarted();
53 51
54 protected: 52 protected:
55 // Implementation of URLFetcher::Delegate. Called after the request 53 // Implementation of URLFetcher::Delegate. Called after the request
56 // completes (either successfully or with failure). 54 // completes (either successfully or with failure).
57 void OnURLFetchComplete(const net::URLFetcher* source) override; 55 void OnURLFetchComplete(const net::URLFetcher* source) override;
58 56
59 private: 57 private:
60 friend class base::RefCountedThreadSafe<ThreatDetailsCacheCollector>; 58 friend class base::RefCountedThreadSafe<ThreatDetailsCacheCollector>;
61 59
62 ~ThreatDetailsCacheCollector() override; 60 ~ThreatDetailsCacheCollector() override;
63 61
64 // Points to the url for which we are fetching the HTTP cache entry or 62 // Points to the url for which we are fetching the HTTP cache entry or
65 // redirect chain. 63 // redirect chain.
66 safe_browsing::ResourceMap::iterator resources_it_; 64 ResourceMap::iterator resources_it_;
67 65
68 // Points to the resources_ map in the ThreatDetails. 66 // Points to the resources_ map in the ThreatDetails.
69 safe_browsing::ResourceMap* resources_; 67 ResourceMap* resources_;
70 68
71 // Points to the cache_result_ in the ThreatDetails. 69 // Points to the cache_result_ in the ThreatDetails.
72 bool* result_; 70 bool* result_;
73 71
74 // Method we call when we are done. The caller must be alive for the 72 // Method we call when we are done. The caller must be alive for the
75 // whole time, we are modifying its state (see above). 73 // whole time, we are modifying its state (see above).
76 base::Closure callback_; 74 base::Closure callback_;
77 75
78 // Set to true as soon as StartCacheCollection is called. 76 // Set to true as soon as StartCacheCollection is called.
79 bool has_started_; 77 bool has_started_;
80 78
81 // Used to get a pointer to the current request context. 79 // Used to get a pointer to the current request context.
82 scoped_refptr<net::URLRequestContextGetter> request_context_getter_; 80 scoped_refptr<net::URLRequestContextGetter> request_context_getter_;
83 81
84 // The current URLFetcher. 82 // The current URLFetcher.
85 scoped_ptr<net::URLFetcher> current_fetch_; 83 scoped_ptr<net::URLFetcher> current_fetch_;
86 84
87 // Returns the resource from resources_ that corresponds to |url| 85 // Returns the resource from resources_ that corresponds to |url|
88 safe_browsing::ClientMalwareReportRequest::Resource* GetResource( 86 ClientMalwareReportRequest::Resource* GetResource(const GURL& url);
89 const GURL& url);
90 87
91 // Creates a new URLFetcher and starts it. 88 // Creates a new URLFetcher and starts it.
92 void OpenEntry(); 89 void OpenEntry();
93 90
94 // Read the HTTP response from |source| and add it to |pb_resource|. 91 // Read the HTTP response from |source| and add it to |pb_resource|.
95 void ReadResponse( 92 void ReadResponse(ClientMalwareReportRequest::Resource* pb_resource,
96 safe_browsing::ClientMalwareReportRequest::Resource* pb_resource, 93 const net::URLFetcher* source);
97 const net::URLFetcher* source);
98 94
99 // Read the body |data| and add it to |pb_resource|. 95 // Read the body |data| and add it to |pb_resource|.
100 void ReadData( 96 void ReadData(ClientMalwareReportRequest::Resource* pb_resource,
101 safe_browsing::ClientMalwareReportRequest::Resource* pb_resource, 97 const std::string& data);
102 const std::string& data);
103 98
104 // Called when we are done. 99 // Called when we are done.
105 void AllDone(bool success); 100 void AllDone(bool success);
106 101
107 // Advances to the next entry in resources_it_. 102 // Advances to the next entry in resources_it_.
108 void AdvanceEntry(); 103 void AdvanceEntry();
109 }; 104 };
110 105
106 } // namespace safe_browsing
107
111 #endif // CHROME_BROWSER_SAFE_BROWSING_THREAT_DETAILS_CACHE_H_ 108 #endif // CHROME_BROWSER_SAFE_BROWSING_THREAT_DETAILS_CACHE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698