OLD | NEW |
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 // Implementation of the MalwareDetails class. | 5 // Implementation of the MalwareDetails class. |
6 | 6 |
7 #include "chrome/browser/safe_browsing/malware_details.h" | 7 #include "chrome/browser/safe_browsing/malware_details.h" |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/lazy_instance.h" | 10 #include "base/lazy_instance.h" |
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
69 // Fetch a URL and advance to the next one when done. | 69 // Fetch a URL and advance to the next one when done. |
70 void MalwareDetailsCacheCollector::OpenEntry() { | 70 void MalwareDetailsCacheCollector::OpenEntry() { |
71 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 71 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
72 DVLOG(1) << "OpenEntry"; | 72 DVLOG(1) << "OpenEntry"; |
73 | 73 |
74 if (resources_it_ == resources_->end()) { // We are done. | 74 if (resources_it_ == resources_->end()) { // We are done. |
75 AllDone(true); | 75 AllDone(true); |
76 return; | 76 return; |
77 } | 77 } |
78 | 78 |
79 if (!request_context_getter_) { | 79 if (!request_context_getter_.get()) { |
80 DVLOG(1) << "Missing request context getter"; | 80 DVLOG(1) << "Missing request context getter"; |
81 AllDone(false); | 81 AllDone(false); |
82 return; | 82 return; |
83 } | 83 } |
84 | 84 |
85 current_fetch_.reset(net::URLFetcher::Create( | 85 current_fetch_.reset(net::URLFetcher::Create( |
86 GURL(resources_it_->first), net::URLFetcher::GET, this)); | 86 GURL(resources_it_->first), net::URLFetcher::GET, this)); |
87 current_fetch_->SetRequestContext(request_context_getter_); | 87 current_fetch_->SetRequestContext(request_context_getter_.get()); |
88 // Only from cache, and don't save cookies. | 88 // Only from cache, and don't save cookies. |
89 current_fetch_->SetLoadFlags(net::LOAD_ONLY_FROM_CACHE | | 89 current_fetch_->SetLoadFlags(net::LOAD_ONLY_FROM_CACHE | |
90 net::LOAD_DO_NOT_SAVE_COOKIES); | 90 net::LOAD_DO_NOT_SAVE_COOKIES); |
91 current_fetch_->SetAutomaticallyRetryOn5xx(false); // No retries. | 91 current_fetch_->SetAutomaticallyRetryOn5xx(false); // No retries. |
92 current_fetch_->Start(); // OnURLFetchComplete will be called when done. | 92 current_fetch_->Start(); // OnURLFetchComplete will be called when done. |
93 } | 93 } |
94 | 94 |
95 ClientMalwareReportRequest::Resource* MalwareDetailsCacheCollector::GetResource( | 95 ClientMalwareReportRequest::Resource* MalwareDetailsCacheCollector::GetResource( |
96 const GURL& url) { | 96 const GURL& url) { |
97 safe_browsing::ResourceMap::iterator it = resources_->find(url.spec()); | 97 safe_browsing::ResourceMap::iterator it = resources_->find(url.spec()); |
(...skipping 103 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
201 base::Bind(&MalwareDetailsCacheCollector::OpenEntry, this)); | 201 base::Bind(&MalwareDetailsCacheCollector::OpenEntry, this)); |
202 } | 202 } |
203 | 203 |
204 void MalwareDetailsCacheCollector::AllDone(bool success) { | 204 void MalwareDetailsCacheCollector::AllDone(bool success) { |
205 DVLOG(1) << "AllDone"; | 205 DVLOG(1) << "AllDone"; |
206 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 206 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
207 *result_ = success; | 207 *result_ = success; |
208 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, callback_); | 208 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, callback_); |
209 callback_.Reset(); | 209 callback_.Reset(); |
210 } | 210 } |
OLD | NEW |