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/shell_integration.h" | 5 #include "chrome/browser/shell_integration.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 9 #include "base/files/file_util.h" | 9 #include "base/files/file_util.h" |
| 10 #include "base/prefs/pref_service.h" | 10 #include "base/prefs/pref_service.h" |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 22 #endif | 22 #endif |
| 23 | 23 |
| 24 #if !defined(OS_WIN) | 24 #if !defined(OS_WIN) |
| 25 #include "chrome/common/channel_info.h" | 25 #include "chrome/common/channel_info.h" |
| 26 #include "chrome/grit/chromium_strings.h" | 26 #include "chrome/grit/chromium_strings.h" |
| 27 #include "ui/base/l10n/l10n_util.h" | 27 #include "ui/base/l10n/l10n_util.h" |
| 28 #endif | 28 #endif |
| 29 | 29 |
| 30 using content::BrowserThread; | 30 using content::BrowserThread; |
| 31 | 31 |
| 32 #if !defined(OS_WIN) | |
| 33 // static | |
| 34 bool ShellIntegration::IsSetAsDefaultAsynchronous() { | |
| 35 return false; | |
| 36 } | |
| 37 | |
| 38 // static | |
| 39 void ShellIntegration::SetAsDefaultBrowserAsynchronous() { | |
| 40 NOTREACHED(); | |
| 41 } | |
| 42 #endif // !defined(OS_WIN) | |
| 43 | |
| 32 // static | 44 // static |
| 33 ShellIntegration::DefaultWebClientSetPermission | 45 ShellIntegration::DefaultWebClientSetPermission |
| 34 ShellIntegration::CanSetAsDefaultProtocolClient() { | 46 ShellIntegration::CanSetAsDefaultProtocolClient() { |
| 35 // Allowed as long as the browser can become the operating system default | 47 // Allowed as long as the browser can become the operating system default |
| 36 // browser. | 48 // browser. |
| 37 return CanSetAsDefaultBrowser(); | 49 return CanSetAsDefaultBrowser(); |
| 38 } | 50 } |
| 39 | 51 |
| 40 static const struct ShellIntegration::AppModeInfo* gAppModeInfo = NULL; | 52 static const struct ShellIntegration::AppModeInfo* gAppModeInfo = NULL; |
| 41 | 53 |
| (...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 128 bool ShellIntegration::SetAsDefaultProtocolClientInteractive( | 140 bool ShellIntegration::SetAsDefaultProtocolClientInteractive( |
| 129 const std::string& protocol) { | 141 const std::string& protocol) { |
| 130 return false; | 142 return false; |
| 131 } | 143 } |
| 132 | 144 |
| 133 // static | 145 // static |
| 134 bool ShellIntegration::IsElevationNeededForSettingDefaultProtocolClient() { | 146 bool ShellIntegration::IsElevationNeededForSettingDefaultProtocolClient() { |
| 135 return false; | 147 return false; |
| 136 } | 148 } |
| 137 | 149 |
| 150 void ShellIntegration::DefaultBrowserWorker::InitializeSetAsDefault() {} | |
| 151 | |
| 152 bool ShellIntegration::DefaultBrowserWorker::UninitializeSetAsDefault( | |
| 153 bool succeeded) { | |
| 154 return true; | |
| 155 } | |
| 156 | |
| 138 #endif // !defined(OS_WIN) | 157 #endif // !defined(OS_WIN) |
| 139 | 158 |
| 140 bool ShellIntegration::DefaultWebClientObserver::IsOwnedByWorker() { | 159 bool ShellIntegration::DefaultWebClientObserver::IsOwnedByWorker() { |
| 141 return false; | 160 return false; |
| 142 } | 161 } |
| 143 | 162 |
| 144 bool ShellIntegration::DefaultWebClientObserver:: | 163 bool ShellIntegration::DefaultWebClientObserver:: |
| 145 IsInteractiveSetDefaultPermitted() { | 164 IsInteractiveSetDefaultPermitted() { |
| 146 return false; | 165 return false; |
| 147 } | 166 } |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 164 &DefaultWebClientWorker::ExecuteCheckIsDefault, this)); | 183 &DefaultWebClientWorker::ExecuteCheckIsDefault, this)); |
| 165 } | 184 } |
| 166 } | 185 } |
| 167 | 186 |
| 168 void ShellIntegration::DefaultWebClientWorker::StartSetAsDefault() { | 187 void ShellIntegration::DefaultWebClientWorker::StartSetAsDefault() { |
| 169 bool interactive_permitted = false; | 188 bool interactive_permitted = false; |
| 170 if (observer_) { | 189 if (observer_) { |
| 171 observer_->SetDefaultWebClientUIState(STATE_PROCESSING); | 190 observer_->SetDefaultWebClientUIState(STATE_PROCESSING); |
| 172 interactive_permitted = observer_->IsInteractiveSetDefaultPermitted(); | 191 interactive_permitted = observer_->IsInteractiveSetDefaultPermitted(); |
| 173 } | 192 } |
| 193 | |
| 194 InitializeSetAsDefault(); | |
| 195 | |
| 174 BrowserThread::PostTask( | 196 BrowserThread::PostTask( |
| 175 BrowserThread::FILE, FROM_HERE, | 197 BrowserThread::FILE, FROM_HERE, |
| 176 base::Bind(&DefaultWebClientWorker::ExecuteSetAsDefault, this, | 198 base::Bind(&DefaultWebClientWorker::ExecuteSetAsDefault, this, |
| 177 interactive_permitted)); | 199 interactive_permitted)); |
| 178 } | 200 } |
| 179 | 201 |
| 180 void ShellIntegration::DefaultWebClientWorker::ObserverDestroyed() { | 202 void ShellIntegration::DefaultWebClientWorker::ObserverDestroyed() { |
| 181 // Our associated view has gone away, so we shouldn't call back to it if | 203 // Our associated view has gone away, so we shouldn't call back to it if |
| 182 // our worker thread returns after the view is dead. | 204 // our worker thread returns after the view is dead. |
| 183 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 205 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 184 observer_ = NULL; | 206 observer_ = NULL; |
| 185 } | 207 } |
| 186 | 208 |
| 187 /////////////////////////////////////////////////////////////////////////////// | 209 /////////////////////////////////////////////////////////////////////////////// |
| 188 // DefaultWebClientWorker, private: | 210 // DefaultWebClientWorker, private: |
| 189 | 211 |
| 190 void ShellIntegration::DefaultWebClientWorker::ExecuteCheckIsDefault() { | 212 void ShellIntegration::DefaultWebClientWorker::ExecuteCheckIsDefault() { |
| 191 DCHECK_CURRENTLY_ON(BrowserThread::FILE); | 213 DCHECK_CURRENTLY_ON(BrowserThread::FILE); |
| 192 DefaultWebClientState state = CheckIsDefault(); | 214 DefaultWebClientState state = CheckIsDefault(); |
| 193 BrowserThread::PostTask( | 215 BrowserThread::PostTask( |
| 194 BrowserThread::UI, FROM_HERE, | 216 BrowserThread::UI, FROM_HERE, |
| 195 base::Bind( | 217 base::Bind( |
| 196 &DefaultWebClientWorker::CompleteCheckIsDefault, this, state)); | 218 &DefaultWebClientWorker::CompleteCheckIsDefault, this, state)); |
| 197 } | 219 } |
| 198 | 220 |
| 199 void ShellIntegration::DefaultWebClientWorker::CompleteCheckIsDefault( | 221 void ShellIntegration::DefaultWebClientWorker::CompleteCheckIsDefault( |
| 200 DefaultWebClientState state) { | 222 DefaultWebClientState state) { |
| 201 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 223 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 224 | |
| 202 UpdateUI(state); | 225 UpdateUI(state); |
| 226 | |
| 203 // The worker has finished everything it needs to do, so free the observer | 227 // The worker has finished everything it needs to do, so free the observer |
| 204 // if we own it. | 228 // if we own it. |
| 205 if (observer_ && observer_->IsOwnedByWorker()) { | 229 if (observer_ && observer_->IsOwnedByWorker()) { |
| 206 delete observer_; | 230 delete observer_; |
| 207 observer_ = NULL; | 231 observer_ = NULL; |
| 208 } | 232 } |
| 209 } | 233 } |
| 210 | 234 |
| 211 void ShellIntegration::DefaultWebClientWorker::ExecuteSetAsDefault( | 235 void ShellIntegration::DefaultWebClientWorker::ExecuteSetAsDefault( |
| 212 bool interactive_permitted) { | 236 bool interactive_permitted) { |
| 213 DCHECK_CURRENTLY_ON(BrowserThread::FILE); | 237 DCHECK_CURRENTLY_ON(BrowserThread::FILE); |
| 214 | 238 |
| 215 bool result = SetAsDefault(interactive_permitted); | 239 SetAsDefault(interactive_permitted); |
| 216 BrowserThread::PostTask( | |
| 217 BrowserThread::UI, FROM_HERE, | |
| 218 base::Bind(&DefaultWebClientWorker::CompleteSetAsDefault, this, result)); | |
| 219 } | 240 } |
| 220 | 241 |
| 221 void ShellIntegration::DefaultWebClientWorker::CompleteSetAsDefault( | 242 void ShellIntegration::DefaultWebClientWorker::CompleteSetAsDefault( |
| 222 bool succeeded) { | 243 bool succeeded) { |
| 223 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 244 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 224 // First tell the observer what the SetAsDefault call has returned. | 245 |
| 225 if (observer_) | 246 // Only notify observer is |UninitializeSetAsDefault| returns true. This is to |
|
grt (UTC plus 2)
2015/09/22 18:21:47
is -> if
Patrick Monette
2015/09/23 22:40:44
Comment removed.
| |
| 226 observer_->OnSetAsDefaultConcluded(succeeded); | 247 // filter out multiple calls to |CompleteSetAsDefault| due to possible race |
| 227 // Set as default completed, check again to make sure it stuck... | 248 // conditions. |
| 228 StartCheckIsDefault(); | 249 if (UninitializeSetAsDefault(succeeded)) { |
| 250 // First tell the observer what the SetAsDefault call has returned. | |
| 251 if (observer_) | |
| 252 observer_->OnSetAsDefaultConcluded(succeeded); | |
| 253 // Set as default completed, check again to make sure it stuck... | |
| 254 StartCheckIsDefault(); | |
| 255 } | |
| 229 } | 256 } |
| 230 | 257 |
| 231 void ShellIntegration::DefaultWebClientWorker::UpdateUI( | 258 void ShellIntegration::DefaultWebClientWorker::UpdateUI( |
| 232 DefaultWebClientState state) { | 259 DefaultWebClientState state) { |
| 233 if (observer_) { | 260 if (observer_) { |
| 234 switch (state) { | 261 switch (state) { |
| 235 case NOT_DEFAULT: | 262 case NOT_DEFAULT: |
| 236 observer_->SetDefaultWebClientUIState(STATE_NOT_DEFAULT); | 263 observer_->SetDefaultWebClientUIState(STATE_NOT_DEFAULT); |
| 237 break; | 264 break; |
| 238 case IS_DEFAULT: | 265 case IS_DEFAULT: |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 257 } | 284 } |
| 258 | 285 |
| 259 /////////////////////////////////////////////////////////////////////////////// | 286 /////////////////////////////////////////////////////////////////////////////// |
| 260 // DefaultBrowserWorker, private: | 287 // DefaultBrowserWorker, private: |
| 261 | 288 |
| 262 ShellIntegration::DefaultWebClientState | 289 ShellIntegration::DefaultWebClientState |
| 263 ShellIntegration::DefaultBrowserWorker::CheckIsDefault() { | 290 ShellIntegration::DefaultBrowserWorker::CheckIsDefault() { |
| 264 return ShellIntegration::GetDefaultBrowser(); | 291 return ShellIntegration::GetDefaultBrowser(); |
| 265 } | 292 } |
| 266 | 293 |
| 267 bool ShellIntegration::DefaultBrowserWorker::SetAsDefault( | 294 void ShellIntegration::DefaultBrowserWorker::SetAsDefault( |
| 268 bool interactive_permitted) { | 295 bool interactive_permitted) { |
| 269 bool result = false; | 296 bool result = false; |
| 270 switch (ShellIntegration::CanSetAsDefaultBrowser()) { | 297 switch (ShellIntegration::CanSetAsDefaultBrowser()) { |
| 271 case ShellIntegration::SET_DEFAULT_UNATTENDED: | 298 case ShellIntegration::SET_DEFAULT_UNATTENDED: |
| 272 result = ShellIntegration::SetAsDefaultBrowser(); | 299 result = ShellIntegration::SetAsDefaultBrowser(); |
| 300 BrowserThread::PostTask( | |
| 301 BrowserThread::UI, FROM_HERE, | |
| 302 base::Bind(&DefaultBrowserWorker::CompleteSetAsDefault, this, | |
| 303 result)); | |
| 273 break; | 304 break; |
| 274 case ShellIntegration::SET_DEFAULT_INTERACTIVE: | 305 case ShellIntegration::SET_DEFAULT_INTERACTIVE: |
| 306 if (interactive_permitted) { | |
| 307 result = ShellIntegration::SetAsDefaultBrowserInteractive(); | |
| 308 BrowserThread::PostTask( | |
| 309 BrowserThread::UI, FROM_HERE, | |
| 310 base::Bind(&DefaultBrowserWorker::CompleteSetAsDefault, this, | |
| 311 result)); | |
| 312 } | |
|
grt (UTC plus 2)
2015/09/22 18:21:47
this should run CompleteSetAsDefault with result=f
Patrick Monette
2015/09/23 22:40:44
CompleteSetAsDefault is not called at the end with
| |
| 313 break; | |
| 314 case ShellIntegration::SET_DEFAULT_ASYNCHRONOUS: | |
| 275 if (interactive_permitted) | 315 if (interactive_permitted) |
| 276 result = ShellIntegration::SetAsDefaultBrowserInteractive(); | 316 ShellIntegration::SetAsDefaultBrowserAsynchronous(); |
| 277 break; | 317 break; |
| 278 default: | 318 default: |
|
grt (UTC plus 2)
2015/09/22 18:21:47
while you're here, please change this from "defaul
Patrick Monette
2015/09/23 22:40:44
Done. Moved the cases around so they are in the sa
| |
| 279 NOTREACHED(); | 319 NOTREACHED(); |
| 280 } | 320 } |
| 281 | |
| 282 return result; | |
| 283 } | 321 } |
| 284 | 322 |
| 285 /////////////////////////////////////////////////////////////////////////////// | 323 /////////////////////////////////////////////////////////////////////////////// |
| 286 // ShellIntegration::DefaultProtocolClientWorker | 324 // ShellIntegration::DefaultProtocolClientWorker |
| 287 // | 325 // |
| 288 | 326 |
| 289 ShellIntegration::DefaultProtocolClientWorker::DefaultProtocolClientWorker( | 327 ShellIntegration::DefaultProtocolClientWorker::DefaultProtocolClientWorker( |
| 290 DefaultWebClientObserver* observer, const std::string& protocol) | 328 DefaultWebClientObserver* observer, const std::string& protocol) |
| 291 : DefaultWebClientWorker(observer), | 329 : DefaultWebClientWorker(observer), |
| 292 protocol_(protocol) { | 330 protocol_(protocol) { |
| 293 } | 331 } |
| 294 | 332 |
| 295 /////////////////////////////////////////////////////////////////////////////// | 333 /////////////////////////////////////////////////////////////////////////////// |
| 296 // DefaultProtocolClientWorker, private: | 334 // DefaultProtocolClientWorker, private: |
| 297 | 335 |
| 298 ShellIntegration::DefaultWebClientState | 336 ShellIntegration::DefaultWebClientState |
| 299 ShellIntegration::DefaultProtocolClientWorker::CheckIsDefault() { | 337 ShellIntegration::DefaultProtocolClientWorker::CheckIsDefault() { |
| 300 return ShellIntegration::IsDefaultProtocolClient(protocol_); | 338 return ShellIntegration::IsDefaultProtocolClient(protocol_); |
| 301 } | 339 } |
| 302 | 340 |
| 303 bool ShellIntegration::DefaultProtocolClientWorker::SetAsDefault( | 341 void ShellIntegration::DefaultProtocolClientWorker::SetAsDefault( |
| 304 bool interactive_permitted) { | 342 bool interactive_permitted) { |
| 305 bool result = false; | 343 bool result = false; |
| 306 switch (ShellIntegration::CanSetAsDefaultProtocolClient()) { | 344 switch (ShellIntegration::CanSetAsDefaultProtocolClient()) { |
| 307 case ShellIntegration::SET_DEFAULT_NOT_ALLOWED: | 345 case ShellIntegration::SET_DEFAULT_NOT_ALLOWED: |
| 308 result = false; | 346 BrowserThread::PostTask( |
| 347 BrowserThread::UI, FROM_HERE, | |
| 348 base::Bind(&DefaultProtocolClientWorker::CompleteSetAsDefault, this, | |
| 349 false)); | |
| 309 break; | 350 break; |
| 310 case ShellIntegration::SET_DEFAULT_UNATTENDED: | 351 case ShellIntegration::SET_DEFAULT_UNATTENDED: |
| 311 result = ShellIntegration::SetAsDefaultProtocolClient(protocol_); | 352 result = ShellIntegration::SetAsDefaultProtocolClient(protocol_); |
| 353 BrowserThread::PostTask( | |
| 354 BrowserThread::UI, FROM_HERE, | |
| 355 base::Bind(&DefaultProtocolClientWorker::CompleteSetAsDefault, this, | |
| 356 result)); | |
| 312 break; | 357 break; |
| 313 case ShellIntegration::SET_DEFAULT_INTERACTIVE: | 358 case ShellIntegration::SET_DEFAULT_INTERACTIVE: |
| 314 if (interactive_permitted) { | 359 if (interactive_permitted) { |
| 315 result = ShellIntegration::SetAsDefaultProtocolClientInteractive( | 360 result = |
| 316 protocol_); | 361 ShellIntegration::SetAsDefaultProtocolClientInteractive(protocol_); |
| 362 BrowserThread::PostTask( | |
| 363 BrowserThread::UI, FROM_HERE, | |
| 364 base::Bind(&DefaultProtocolClientWorker::CompleteSetAsDefault, this, | |
| 365 result)); | |
| 317 } | 366 } |
| 318 break; | 367 break; |
| 319 } | 368 } |
| 320 | |
| 321 return result; | |
| 322 } | 369 } |
| OLD | NEW |