Chromium Code Reviews| 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 #include "chrome/browser/safe_browsing/database_manager.h" | 5 #include "chrome/browser/safe_browsing/database_manager.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 23 #include "chrome/browser/safe_browsing/malware_details.h" | 23 #include "chrome/browser/safe_browsing/malware_details.h" |
| 24 #include "chrome/browser/safe_browsing/protocol_manager.h" | 24 #include "chrome/browser/safe_browsing/protocol_manager.h" |
| 25 #include "chrome/browser/safe_browsing/safe_browsing_database.h" | 25 #include "chrome/browser/safe_browsing/safe_browsing_database.h" |
| 26 #include "chrome/browser/safe_browsing/safe_browsing_service.h" | 26 #include "chrome/browser/safe_browsing/safe_browsing_service.h" |
| 27 #include "chrome/browser/safe_browsing/ui_manager.h" | 27 #include "chrome/browser/safe_browsing/ui_manager.h" |
| 28 #include "chrome/common/chrome_constants.h" | 28 #include "chrome/common/chrome_constants.h" |
| 29 #include "chrome/common/chrome_paths.h" | 29 #include "chrome/common/chrome_paths.h" |
| 30 #include "chrome/common/chrome_switches.h" | 30 #include "chrome/common/chrome_switches.h" |
| 31 #include "components/metrics/metrics_service.h" | 31 #include "components/metrics/metrics_service.h" |
| 32 #include "components/startup_metric_utils/startup_metric_utils.h" | 32 #include "components/startup_metric_utils/startup_metric_utils.h" |
| 33 #include "components/variations/variations_associated_data.h" | |
| 33 #include "content/public/browser/browser_thread.h" | 34 #include "content/public/browser/browser_thread.h" |
| 34 #include "content/public/browser/notification_service.h" | 35 #include "content/public/browser/notification_service.h" |
| 35 #include "url/url_constants.h" | 36 #include "url/url_constants.h" |
| 36 | 37 |
| 37 using content::BrowserThread; | 38 using content::BrowserThread; |
| 38 | 39 |
| 39 namespace { | 40 namespace { |
| 40 | 41 |
| 41 // Timeout for match checks, e.g. download URLs, hashes. | 42 // Timeout for match checks, e.g. download URLs, hashes. |
| 42 const int kCheckTimeoutMs = 10000; | 43 const int kCheckTimeoutMs = 10000; |
| (...skipping 600 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 643 DCHECK(enabled_); | 644 DCHECK(enabled_); |
| 644 safe_browsing_thread_->message_loop()->PostTask(FROM_HERE, base::Bind( | 645 safe_browsing_thread_->message_loop()->PostTask(FROM_HERE, base::Bind( |
| 645 &SafeBrowsingDatabaseManager::OnResetDatabase, this)); | 646 &SafeBrowsingDatabaseManager::OnResetDatabase, this)); |
| 646 } | 647 } |
| 647 | 648 |
| 648 void SafeBrowsingDatabaseManager::StartOnIOThread() { | 649 void SafeBrowsingDatabaseManager::StartOnIOThread() { |
| 649 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 650 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 650 if (enabled_) | 651 if (enabled_) |
| 651 return; | 652 return; |
| 652 | 653 |
| 654 // TODO(asvitkine): Experimental code for measuring start up impact of SB. | |
| 655 // Remove when experimentation is complete. http://crbug.com/416219 | |
|
gab
2015/02/12 16:57:00
Wrong bug #, should be 450037, right?
Alexei Svitkine (slow)
2015/02/12 17:27:12
Done.
| |
| 656 if (!variations::GetVariationParamValue("LightSpeed", "DisableSB").empty()) | |
|
gab
2015/02/12 16:57:00
So the experiment name is "LightSpeed" and it has
Alexei Svitkine (slow)
2015/02/12 17:27:12
This is using the parameters support in the variat
gab
2015/02/12 17:35:42
Oh very cool! SGTM
The one thing I'm worried abou
Alexei Svitkine (slow)
2015/02/12 17:47:56
Right, it depends how many we want to run in paral
gab
2015/02/12 18:26:58
Okay SGTM.
| |
| 657 return; | |
| 658 | |
| 653 DCHECK(!safe_browsing_thread_.get()); | 659 DCHECK(!safe_browsing_thread_.get()); |
| 654 safe_browsing_thread_.reset(new base::Thread("Chrome_SafeBrowsingThread")); | 660 safe_browsing_thread_.reset(new base::Thread("Chrome_SafeBrowsingThread")); |
| 655 if (!safe_browsing_thread_->Start()) | 661 if (!safe_browsing_thread_->Start()) |
| 656 return; | 662 return; |
| 657 enabled_ = true; | 663 enabled_ = true; |
| 658 | 664 |
| 659 MakeDatabaseAvailable(); | 665 MakeDatabaseAvailable(); |
| 660 } | 666 } |
| 661 | 667 |
| 662 void SafeBrowsingDatabaseManager::StopOnIOThread(bool shutdown) { | 668 void SafeBrowsingDatabaseManager::StopOnIOThread(bool shutdown) { |
| (...skipping 506 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1169 new base::WeakPtrFactory<SafeBrowsingDatabaseManager>(this)); | 1175 new base::WeakPtrFactory<SafeBrowsingDatabaseManager>(this)); |
| 1170 checks_.insert(check); | 1176 checks_.insert(check); |
| 1171 | 1177 |
| 1172 safe_browsing_thread_->message_loop()->PostTask(FROM_HERE, task); | 1178 safe_browsing_thread_->message_loop()->PostTask(FROM_HERE, task); |
| 1173 | 1179 |
| 1174 base::MessageLoop::current()->PostDelayedTask(FROM_HERE, | 1180 base::MessageLoop::current()->PostDelayedTask(FROM_HERE, |
| 1175 base::Bind(&SafeBrowsingDatabaseManager::TimeoutCallback, | 1181 base::Bind(&SafeBrowsingDatabaseManager::TimeoutCallback, |
| 1176 check->timeout_factory_->GetWeakPtr(), check), | 1182 check->timeout_factory_->GetWeakPtr(), check), |
| 1177 check_timeout_); | 1183 check_timeout_); |
| 1178 } | 1184 } |
| OLD | NEW |