Roll src/third_party/WebKit 8b42d1d:744641d (svn 186770:186771)
[chromium-blink-merge.git] / chrome / browser / safe_browsing / malware_details_cache.h
blobec855cf9c6419d1dbf82784301c856c607011305
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
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_SAFE_BROWSING_MALWARE_DETAILS_CACHE_H_
6 #define CHROME_BROWSER_SAFE_BROWSING_MALWARE_DETAILS_CACHE_H_
8 // A class that gets malware details from the HTTP Cache.
9 // An instance of this class is generated by MalwareDetails.
11 #include <string>
12 #include <vector>
14 #include "base/callback.h"
15 #include "base/containers/hash_tables.h"
16 #include "base/memory/linked_ptr.h"
17 #include "base/memory/ref_counted.h"
18 #include "chrome/browser/safe_browsing/report.pb.h"
19 #include "net/base/completion_callback.h"
20 #include "net/url_request/url_fetcher_delegate.h"
22 namespace net {
23 class URLFetcher;
24 class URLRequestContext;
27 namespace safe_browsing {
29 // Maps a URL to its Resource.
30 typedef base::hash_map<
31 std::string,
32 linked_ptr<safe_browsing::ClientMalwareReportRequest::Resource> > ResourceMap;
35 class MalwareDetailsCacheCollector
36 : public base::RefCountedThreadSafe<MalwareDetailsCacheCollector>,
37 public net::URLFetcherDelegate {
39 public:
40 MalwareDetailsCacheCollector();
42 // We use |request_context_getter|, we modify |resources| and
43 // |result|, and we call |callback|, so they must all remain alive
44 // for the lifetime of this object.
45 void StartCacheCollection(
46 net::URLRequestContextGetter* request_context_getter,
47 safe_browsing::ResourceMap* resources,
48 bool* result,
49 const base::Closure& callback);
51 // Returns whether or not StartCacheCollection has been called.
52 bool HasStarted();
54 protected:
55 // Implementation of URLFetcher::Delegate. Called after the request
56 // completes (either successfully or with failure).
57 void OnURLFetchComplete(const net::URLFetcher* source) override;
59 private:
60 friend class base::RefCountedThreadSafe<MalwareDetailsCacheCollector>;
62 ~MalwareDetailsCacheCollector() override;
64 // Points to the url for which we are fetching the HTTP cache entry or
65 // redirect chain.
66 safe_browsing::ResourceMap::iterator resources_it_;
68 // Points to the resources_ map in the MalwareDetails.
69 safe_browsing::ResourceMap* resources_;
71 // Points to the cache_result_ in the MalwareDetails.
72 bool* result_;
74 // Method we call when we are done. The caller must be alive for the
75 // whole time, we are modifying its state (see above).
76 base::Closure callback_;
78 // Set to true as soon as StartCacheCollection is called.
79 bool has_started_;
81 // Used to get a pointer to the current request context.
82 scoped_refptr<net::URLRequestContextGetter> request_context_getter_;
84 // The current URLFetcher.
85 scoped_ptr<net::URLFetcher> current_fetch_;
87 // Returns the resource from resources_ that corresponds to |url|
88 safe_browsing::ClientMalwareReportRequest::Resource* GetResource(
89 const GURL& url);
91 // Creates a new URLFetcher and starts it.
92 void OpenEntry();
94 // Read the HTTP response from |source| and add it to |pb_resource|.
95 void ReadResponse(
96 safe_browsing::ClientMalwareReportRequest::Resource* pb_resource,
97 const net::URLFetcher* source);
99 // Read the body |data| and add it to |pb_resource|.
100 void ReadData(
101 safe_browsing::ClientMalwareReportRequest::Resource* pb_resource,
102 const std::string& data);
104 // Called when we are done.
105 void AllDone(bool success);
107 // Advances to the next entry in resources_it_.
108 void AdvanceEntry();
111 #endif // CHROME_BROWSER_SAFE_BROWSING_MALWARE_DETAILS_CACHE_H_