Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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/chrome_cleaner/chrome_cleaner_controller_ win.h" | 5 #include "chrome/browser/safe_browsing/chrome_cleaner/chrome_cleaner_controller_ win.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| 11 #include "base/callback.h" | 11 #include "base/callback.h" |
| 12 #include "base/files/file_util.h" | 12 #include "base/files/file_util.h" |
| 13 #include "base/location.h" | 13 #include "base/location.h" |
| 14 #include "base/logging.h" | 14 #include "base/logging.h" |
| 15 #include "base/memory/ptr_util.h" | 15 #include "base/memory/ptr_util.h" |
| 16 #include "base/memory/singleton.h" | 16 #include "base/memory/singleton.h" |
| 17 #include "base/task_scheduler/post_task.h" | 17 #include "base/task_scheduler/post_task.h" |
| 18 #include "base/task_scheduler/task_traits.h" | 18 #include "base/task_scheduler/task_traits.h" |
| 19 #include "base/threading/thread_restrictions.h" | 19 #include "base/threading/thread_restrictions.h" |
| 20 #include "base/threading/thread_task_runner_handle.h" | 20 #include "base/threading/thread_task_runner_handle.h" |
| 21 #include "chrome/browser/browser_process.h" | |
| 21 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" | 22 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" |
| 23 #include "chrome/browser/profiles/profile.h" | |
| 24 #include "chrome/browser/profiles/profile_manager.h" | |
| 22 #include "chrome/browser/safe_browsing/chrome_cleaner/chrome_cleaner_fetcher_win .h" | 25 #include "chrome/browser/safe_browsing/chrome_cleaner/chrome_cleaner_fetcher_win .h" |
| 23 #include "chrome/browser/safe_browsing/chrome_cleaner/chrome_cleaner_runner_win. h" | 26 #include "chrome/browser/safe_browsing/chrome_cleaner/chrome_cleaner_runner_win. h" |
| 27 #include "chrome/browser/safe_browsing/chrome_cleaner/settings_resetter_win.h" | |
| 24 #include "chrome/browser/safe_browsing/chrome_cleaner/srt_client_info_win.h" | 28 #include "chrome/browser/safe_browsing/chrome_cleaner/srt_client_info_win.h" |
| 25 #include "components/chrome_cleaner/public/constants/constants.h" | 29 #include "components/chrome_cleaner/public/constants/constants.h" |
| 26 #include "components/safe_browsing/common/safe_browsing_prefs.h" | 30 #include "components/safe_browsing/common/safe_browsing_prefs.h" |
| 27 #include "content/public/browser/browser_thread.h" | 31 #include "content/public/browser/browser_thread.h" |
| 28 #include "net/http/http_status_code.h" | 32 #include "net/http/http_status_code.h" |
| 29 | 33 |
| 30 namespace safe_browsing { | 34 namespace safe_browsing { |
| 31 | 35 |
| 32 namespace { | 36 namespace { |
| 33 | 37 |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 103 | 107 |
| 104 bool ChromeCleanerControllerDelegate:: | 108 bool ChromeCleanerControllerDelegate:: |
| 105 SafeBrowsingExtendedReportingScoutEnabled() { | 109 SafeBrowsingExtendedReportingScoutEnabled() { |
| 106 return safe_browsing::SafeBrowsingExtendedReportingScoutEnabled(); | 110 return safe_browsing::SafeBrowsingExtendedReportingScoutEnabled(); |
| 107 } | 111 } |
| 108 | 112 |
| 109 bool ChromeCleanerControllerDelegate::IsMetricsAndCrashReportingEnabled() { | 113 bool ChromeCleanerControllerDelegate::IsMetricsAndCrashReportingEnabled() { |
| 110 return ChromeMetricsServiceAccessor::IsMetricsAndCrashReportingEnabled(); | 114 return ChromeMetricsServiceAccessor::IsMetricsAndCrashReportingEnabled(); |
| 111 } | 115 } |
| 112 | 116 |
| 117 void ChromeCleanerControllerDelegate::TagForResetting(Profile* profile) { | |
| 118 if (PostCleanupSettingsResetter::IsEnabled()) { | |
|
alito
2017/06/13 22:37:48
nit: no need for {}
ftirelo
2017/06/13 22:54:39
Done.
| |
| 119 PostCleanupSettingsResetter().TagForResetting(profile); | |
| 120 } | |
| 121 } | |
| 122 | |
| 123 void ChromeCleanerControllerDelegate::ResetTaggedProfiles( | |
| 124 std::vector<Profile*> profiles, | |
| 125 base::OnceClosure continuation) { | |
| 126 if (PostCleanupSettingsResetter::IsEnabled()) { | |
| 127 PostCleanupSettingsResetter().ResetTaggedProfiles(std::move(profiles), | |
| 128 std::move(continuation)); | |
| 129 } | |
| 130 } | |
| 131 | |
| 113 // static | 132 // static |
| 114 ChromeCleanerController* ChromeCleanerController::GetInstance() { | 133 ChromeCleanerController* ChromeCleanerController::GetInstance() { |
| 115 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); | 134 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| 116 return base::Singleton<ChromeCleanerController>::get(); | 135 return base::Singleton<ChromeCleanerController>::get(); |
| 117 } | 136 } |
| 118 | 137 |
| 119 void ChromeCleanerController::SetDelegateForTesting( | 138 void ChromeCleanerController::SetDelegateForTesting( |
| 120 ChromeCleanerControllerDelegate* delegate) { | 139 ChromeCleanerControllerDelegate* delegate) { |
| 121 DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); | 140 DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); |
| 122 delegate_ = delegate ? delegate : real_delegate_.get(); | 141 delegate_ = delegate ? delegate : real_delegate_.get(); |
| (...skipping 29 matching lines...) Expand all Loading... | |
| 152 DCHECK(!reporter_invocation_); | 171 DCHECK(!reporter_invocation_); |
| 153 reporter_invocation_ = | 172 reporter_invocation_ = |
| 154 base::MakeUnique<SwReporterInvocation>(reporter_invocation); | 173 base::MakeUnique<SwReporterInvocation>(reporter_invocation); |
| 155 SetStateAndNotifyObservers(State::kScanning); | 174 SetStateAndNotifyObservers(State::kScanning); |
| 156 delegate_->FetchAndVerifyChromeCleaner(base::BindOnce( | 175 delegate_->FetchAndVerifyChromeCleaner(base::BindOnce( |
| 157 &ChromeCleanerController::OnChromeCleanerFetchedAndVerified, | 176 &ChromeCleanerController::OnChromeCleanerFetchedAndVerified, |
| 158 base::Unretained(this))); | 177 base::Unretained(this))); |
| 159 } | 178 } |
| 160 | 179 |
| 161 void ChromeCleanerController::ReplyWithUserResponse( | 180 void ChromeCleanerController::ReplyWithUserResponse( |
| 181 Profile* profile, | |
| 162 UserResponse user_response) { | 182 UserResponse user_response) { |
| 163 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); | 183 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| 164 DCHECK(prompt_user_callback_); | 184 DCHECK(prompt_user_callback_); |
| 165 | 185 |
| 166 if (state() != State::kInfected) | 186 if (state() != State::kInfected) |
| 167 return; | 187 return; |
| 168 | 188 |
| 169 PromptAcceptance acceptance = PromptAcceptance::DENIED; | 189 PromptAcceptance acceptance = PromptAcceptance::DENIED; |
| 170 State new_state = State::kIdle; | 190 State new_state = State::kIdle; |
| 171 switch (user_response) { | 191 switch (user_response) { |
| 172 case UserResponse::kAccepted: | 192 case UserResponse::kAccepted: |
| 173 acceptance = PromptAcceptance::ACCEPTED; | 193 acceptance = PromptAcceptance::ACCEPTED; |
| 174 new_state = State::kCleaning; | 194 new_state = State::kCleaning; |
| 195 delegate_->TagForResetting(profile); | |
| 175 break; | 196 break; |
| 176 case UserResponse::kDenied: // Fallthrough | 197 case UserResponse::kDenied: // Fallthrough |
| 177 case UserResponse::kDismissed: | 198 case UserResponse::kDismissed: |
| 178 acceptance = PromptAcceptance::DENIED; | 199 acceptance = PromptAcceptance::DENIED; |
| 179 idle_reason_ = IdleReason::kUserDeclinedCleanup; | 200 idle_reason_ = IdleReason::kUserDeclinedCleanup; |
| 180 new_state = State::kIdle; | 201 new_state = State::kIdle; |
| 181 break; | 202 break; |
| 182 } | 203 } |
| 183 | 204 |
| 184 BrowserThread::GetTaskRunnerForThread(BrowserThread::IO) | 205 BrowserThread::GetTaskRunnerForThread(BrowserThread::IO) |
| (...skipping 175 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 360 SetStateAndNotifyObservers(State::kIdle); | 381 SetStateAndNotifyObservers(State::kIdle); |
| 361 return; | 382 return; |
| 362 } | 383 } |
| 363 | 384 |
| 364 if (process_status.exit_code == kRebootRequiredExitCode) { | 385 if (process_status.exit_code == kRebootRequiredExitCode) { |
| 365 SetStateAndNotifyObservers(State::kRebootRequired); | 386 SetStateAndNotifyObservers(State::kRebootRequired); |
| 366 return; | 387 return; |
| 367 } | 388 } |
| 368 | 389 |
| 369 if (process_status.exit_code == kRebootNotRequiredExitCode) { | 390 if (process_status.exit_code == kRebootNotRequiredExitCode) { |
| 370 idle_reason_ = IdleReason::kCleaningSucceeded; | 391 delegate_->ResetTaggedProfiles( |
| 371 SetStateAndNotifyObservers(State::kIdle); | 392 g_browser_process->profile_manager()->GetLoadedProfiles(), |
| 393 base::BindOnce(&ChromeCleanerController::OnSettingsResetCompleted, | |
| 394 base::Unretained(this))); | |
| 372 return; | 395 return; |
|
alito
2017/06/13 22:37:48
Before returning here, could you add a call to Res
ftirelo
2017/06/13 22:54:39
Done.
| |
| 373 } | 396 } |
| 374 | 397 |
| 375 idle_reason_ = IdleReason::kCleaningFailed; | 398 idle_reason_ = IdleReason::kCleaningFailed; |
| 376 SetStateAndNotifyObservers(State::kIdle); | 399 SetStateAndNotifyObservers(State::kIdle); |
| 377 } | 400 } |
| 378 | 401 |
| 402 void ChromeCleanerController::OnSettingsResetCompleted() { | |
| 403 idle_reason_ = IdleReason::kCleaningSucceeded; | |
| 404 SetStateAndNotifyObservers(State::kIdle); | |
| 405 } | |
| 406 | |
| 379 } // namespace safe_browsing | 407 } // namespace safe_browsing |
| OLD | NEW |