| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/callback.h" | 9 #include "base/callback.h" |
| 10 #include "base/lazy_instance.h" | 10 #include "base/lazy_instance.h" |
| 11 #include "base/md5.h" | 11 #include "base/md5.h" |
| 12 #include "base/string_util.h" | 12 #include "base/string_util.h" |
| 13 #include "chrome/browser/net/chrome_url_request_context.h" | 13 #include "chrome/browser/net/chrome_url_request_context.h" |
| 14 #include "chrome/browser/safe_browsing/malware_details_cache.h" | 14 #include "chrome/browser/safe_browsing/malware_details_cache.h" |
| 15 #include "chrome/browser/safe_browsing/safe_browsing_service.h" | 15 #include "chrome/browser/safe_browsing/safe_browsing_service.h" |
| 16 #include "chrome/browser/safe_browsing/report.pb.h" | 16 #include "chrome/browser/safe_browsing/report.pb.h" |
| 17 #include "content/browser/browser_thread.h" | 17 #include "content/browser/browser_thread.h" |
| 18 #include "net/base/host_port_pair.h" |
| 18 #include "net/base/load_flags.h" | 19 #include "net/base/load_flags.h" |
| 19 #include "net/http/http_response_headers.h" | 20 #include "net/http/http_response_headers.h" |
| 20 #include "net/url_request/url_request_context_getter.h" | 21 #include "net/url_request/url_request_context_getter.h" |
| 21 #include "net/url_request/url_request_status.h" | 22 #include "net/url_request/url_request_status.h" |
| 22 | 23 |
| 23 using safe_browsing::ClientMalwareReportRequest; | 24 using safe_browsing::ClientMalwareReportRequest; |
| 24 | 25 |
| 25 // Only send small files for now, a better strategy would use the size | 26 // Only send small files for now, a better strategy would use the size |
| 26 // of the whole report and the user's bandwidth. | 27 // of the whole report and the user's bandwidth. |
| 27 static const uint32 kMaxBodySizeBytes = 1024; | 28 static const uint32 kMaxBodySizeBytes = 1024; |
| (...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 158 ClientMalwareReportRequest::HTTPHeader* pb_header = | 159 ClientMalwareReportRequest::HTTPHeader* pb_header = |
| 159 pb_response->add_headers(); | 160 pb_response->add_headers(); |
| 160 pb_header->set_name(name); | 161 pb_header->set_name(name); |
| 161 // Strip any Set-Cookie headers. | 162 // Strip any Set-Cookie headers. |
| 162 if (LowerCaseEqualsASCII(name, "set-cookie")) { | 163 if (LowerCaseEqualsASCII(name, "set-cookie")) { |
| 163 pb_header->set_value(""); | 164 pb_header->set_value(""); |
| 164 } else { | 165 } else { |
| 165 pb_header->set_value(value); | 166 pb_header->set_value(value); |
| 166 } | 167 } |
| 167 } | 168 } |
| 169 |
| 170 if (!source->was_fetched_via_proxy()) { |
| 171 pb_response->set_remote_ip(source->socket_address().ToString()); |
| 172 } |
| 168 } | 173 } |
| 169 | 174 |
| 170 void MalwareDetailsCacheCollector::ReadData( | 175 void MalwareDetailsCacheCollector::ReadData( |
| 171 ClientMalwareReportRequest::Resource* pb_resource, | 176 ClientMalwareReportRequest::Resource* pb_resource, |
| 172 const std::string& data) { | 177 const std::string& data) { |
| 173 DVLOG(1) << "ReadData"; | 178 DVLOG(1) << "ReadData"; |
| 174 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 179 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 175 ClientMalwareReportRequest::HTTPResponse* pb_response = | 180 ClientMalwareReportRequest::HTTPResponse* pb_response = |
| 176 pb_resource->mutable_response(); | 181 pb_resource->mutable_response(); |
| 177 if (data.size() <= kMaxBodySizeBytes) { // Only send small bodies for now. | 182 if (data.size() <= kMaxBodySizeBytes) { // Only send small bodies for now. |
| (...skipping 17 matching lines...) Expand all Loading... |
| 195 BrowserThread::IO, FROM_HERE, | 200 BrowserThread::IO, FROM_HERE, |
| 196 NewRunnableMethod(this, &MalwareDetailsCacheCollector::OpenEntry)); | 201 NewRunnableMethod(this, &MalwareDetailsCacheCollector::OpenEntry)); |
| 197 } | 202 } |
| 198 | 203 |
| 199 void MalwareDetailsCacheCollector::AllDone(bool success) { | 204 void MalwareDetailsCacheCollector::AllDone(bool success) { |
| 200 DVLOG(1) << "AllDone"; | 205 DVLOG(1) << "AllDone"; |
| 201 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 206 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 202 *result_ = success; | 207 *result_ = success; |
| 203 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, callback_); | 208 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, callback_); |
| 204 } | 209 } |
| OLD | NEW |