[email protected] | 3bf6ade0 | 2009-07-23 19:51:18 | [diff] [blame] | 1 | // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
license.bot | bf09a50 | 2008-08-24 00:55:55 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 4 | |
[email protected] | 4a0765a | 2009-05-08 23:12:25 | [diff] [blame] | 5 | #include "chrome/browser/shell_integration.h" |
| 6 | |
[email protected] | 28375ae | 2010-02-05 04:45:50 | [diff] [blame] | 7 | #include "base/command_line.h" |
| 8 | #include "base/file_util.h" |
[email protected] | b96aa93 | 2009-08-12 21:34:49 | [diff] [blame] | 9 | #include "base/path_service.h" |
[email protected] | 5d91c9e | 2010-07-28 17:25:28 | [diff] [blame] | 10 | #include "base/string_util.h" |
[email protected] | 64048bd | 2010-03-08 23:28:58 | [diff] [blame] | 11 | #include "base/utf_string_conversions.h" |
[email protected] | b96aa93 | 2009-08-12 21:34:49 | [diff] [blame] | 12 | #include "chrome/common/chrome_paths.h" |
[email protected] | 28375ae | 2010-02-05 04:45:50 | [diff] [blame] | 13 | #include "chrome/common/chrome_switches.h" |
[email protected] | 0d3dc8e2 | 2009-11-03 02:27:01 | [diff] [blame] | 14 | #include "chrome/browser/chrome_thread.h" |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 15 | |
[email protected] | 28375ae | 2010-02-05 04:45:50 | [diff] [blame] | 16 | std::string ShellIntegration::GetCommandLineArgumentsCommon(const GURL& url, |
| 17 | const string16& extension_app_id) { |
| 18 | const CommandLine cmd = *CommandLine::ForCurrentProcess(); |
| 19 | std::wstring arguments_w; |
| 20 | |
| 21 | // Use the same UserDataDir for new launches that we currently have set. |
[email protected] | 63597e4e | 2010-07-08 17:49:05 | [diff] [blame] | 22 | FilePath user_data_dir = cmd.GetSwitchValuePath(switches::kUserDataDir); |
| 23 | if (!user_data_dir.value().empty()) { |
[email protected] | 28375ae | 2010-02-05 04:45:50 | [diff] [blame] | 24 | // Make sure user_data_dir is an absolute path. |
| 25 | if (file_util::AbsolutePath(&user_data_dir) && |
[email protected] | 63597e4e | 2010-07-08 17:49:05 | [diff] [blame] | 26 | file_util::PathExists(user_data_dir)) { |
| 27 | // TODO: This is wrong in pathological quoting scenarios; we shouldn't be |
| 28 | // passing around command lines as strings at all. |
[email protected] | 28375ae | 2010-02-05 04:45:50 | [diff] [blame] | 29 | arguments_w += std::wstring(L"--") + ASCIIToWide(switches::kUserDataDir) + |
[email protected] | 63597e4e | 2010-07-08 17:49:05 | [diff] [blame] | 30 | L"=\"" + user_data_dir.ToWStringHack() + L"\" "; |
[email protected] | 28375ae | 2010-02-05 04:45:50 | [diff] [blame] | 31 | } |
| 32 | } |
| 33 | |
[email protected] | 660e428f | 2010-08-04 01:23:00 | [diff] [blame] | 34 | #if defined(OS_CHROMEOS) |
| 35 | FilePath profile = cmd.GetSwitchValuePath(switches::kLoginProfile); |
[email protected] | 28375ae | 2010-02-05 04:45:50 | [diff] [blame] | 36 | if (!profile.empty()) { |
[email protected] | 74d1397a | 2010-08-02 16:33:33 | [diff] [blame] | 37 | arguments_w += std::wstring(L"--") + ASCIIToWide(switches::kLoginProfile) + |
[email protected] | 660e428f | 2010-08-04 01:23:00 | [diff] [blame] | 38 | L"=\"" + profile.ToWStringHack() + L"\" "; |
[email protected] | 28375ae | 2010-02-05 04:45:50 | [diff] [blame] | 39 | } |
| 40 | #endif |
| 41 | |
| 42 | // If |extension_app_id| is present, we use the kAppId switch rather than |
| 43 | // the kApp switch (the launch url will be read from the extension app |
| 44 | // during launch. |
[email protected] | ec5b50d | 2010-10-09 16:35:18 | [diff] [blame^] | 45 | if (!extension_app_id.empty()) { |
[email protected] | 28375ae | 2010-02-05 04:45:50 | [diff] [blame] | 46 | arguments_w += std::wstring(L"--") + ASCIIToWide(switches::kAppId) + |
[email protected] | 385e5b569 | 2010-08-02 22:56:38 | [diff] [blame] | 47 | L"=\"" + ASCIIToWide(UTF16ToASCII(extension_app_id)); |
[email protected] | 64048bd | 2010-03-08 23:28:58 | [diff] [blame] | 48 | } else { |
[email protected] | 28375ae | 2010-02-05 04:45:50 | [diff] [blame] | 49 | // Use '--app=url' instead of just 'url' to launch the browser with minimal |
| 50 | // chrome. |
| 51 | // Note: Do not change this flag! Old Gears shortcuts will break if you do! |
| 52 | std::string url_string = url.spec(); |
| 53 | ReplaceSubstringsAfterOffset(&url_string, 0, "\\", "%5C"); |
| 54 | ReplaceSubstringsAfterOffset(&url_string, 0, "\"", "%22"); |
| 55 | ReplaceSubstringsAfterOffset(&url_string, 0, ";", "%3B"); |
| 56 | ReplaceSubstringsAfterOffset(&url_string, 0, "$", "%24"); |
| 57 | #if defined(OS_WIN) // Windows shortcuts can't escape % so we use \x instead. |
| 58 | ReplaceSubstringsAfterOffset(&url_string, 0, "%", "\\x"); |
| 59 | #endif |
| 60 | std::wstring url_w = UTF8ToWide(url_string); |
| 61 | arguments_w += std::wstring(L"--") + ASCIIToWide(switches::kApp) + |
| 62 | L"=\"" + url_w + L"\""; |
| 63 | } |
| 64 | return WideToUTF8(arguments_w); |
| 65 | } |
| 66 | |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 67 | /////////////////////////////////////////////////////////////////////////////// |
| 68 | // ShellIntegration::DefaultBrowserWorker |
| 69 | // |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 70 | |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 71 | ShellIntegration::DefaultBrowserWorker::DefaultBrowserWorker( |
| 72 | DefaultBrowserObserver* observer) |
[email protected] | 0d3dc8e2 | 2009-11-03 02:27:01 | [diff] [blame] | 73 | : observer_(observer) { |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 74 | } |
| 75 | |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 76 | void ShellIntegration::DefaultBrowserWorker::StartCheckDefaultBrowser() { |
| 77 | observer_->SetDefaultBrowserUIState(STATE_PROCESSING); |
[email protected] | 0d3dc8e2 | 2009-11-03 02:27:01 | [diff] [blame] | 78 | ChromeThread::PostTask( |
| 79 | ChromeThread::FILE, FROM_HERE, |
| 80 | NewRunnableMethod( |
| 81 | this, &DefaultBrowserWorker::ExecuteCheckDefaultBrowser)); |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 82 | } |
| 83 | |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 84 | void ShellIntegration::DefaultBrowserWorker::StartSetAsDefaultBrowser() { |
| 85 | observer_->SetDefaultBrowserUIState(STATE_PROCESSING); |
[email protected] | 0d3dc8e2 | 2009-11-03 02:27:01 | [diff] [blame] | 86 | ChromeThread::PostTask( |
| 87 | ChromeThread::FILE, FROM_HERE, |
| 88 | NewRunnableMethod( |
| 89 | this, &DefaultBrowserWorker::ExecuteSetAsDefaultBrowser)); |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 90 | } |
| 91 | |
| 92 | void ShellIntegration::DefaultBrowserWorker::ObserverDestroyed() { |
| 93 | // Our associated view has gone away, so we shouldn't call back to it if |
| 94 | // our worker thread returns after the view is dead. |
| 95 | observer_ = NULL; |
| 96 | } |
| 97 | |
| 98 | /////////////////////////////////////////////////////////////////////////////// |
| 99 | // DefaultBrowserWorker, private: |
| 100 | |
| 101 | void ShellIntegration::DefaultBrowserWorker::ExecuteCheckDefaultBrowser() { |
[email protected] | 0d3dc8e2 | 2009-11-03 02:27:01 | [diff] [blame] | 102 | DCHECK(ChromeThread::CurrentlyOn(ChromeThread::FILE)); |
[email protected] | 264f74d1 | 2009-09-04 23:39:58 | [diff] [blame] | 103 | DefaultBrowserState state = ShellIntegration::IsDefaultBrowser(); |
[email protected] | 0d3dc8e2 | 2009-11-03 02:27:01 | [diff] [blame] | 104 | ChromeThread::PostTask( |
| 105 | ChromeThread::UI, FROM_HERE, |
| 106 | NewRunnableMethod( |
| 107 | this, &DefaultBrowserWorker::CompleteCheckDefaultBrowser, state)); |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 108 | } |
| 109 | |
| 110 | void ShellIntegration::DefaultBrowserWorker::CompleteCheckDefaultBrowser( |
[email protected] | 264f74d1 | 2009-09-04 23:39:58 | [diff] [blame] | 111 | DefaultBrowserState state) { |
[email protected] | 0d3dc8e2 | 2009-11-03 02:27:01 | [diff] [blame] | 112 | DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI)); |
[email protected] | 264f74d1 | 2009-09-04 23:39:58 | [diff] [blame] | 113 | UpdateUI(state); |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 114 | } |
| 115 | |
| 116 | void ShellIntegration::DefaultBrowserWorker::ExecuteSetAsDefaultBrowser() { |
[email protected] | 0d3dc8e2 | 2009-11-03 02:27:01 | [diff] [blame] | 117 | DCHECK(ChromeThread::CurrentlyOn(ChromeThread::FILE)); |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 118 | ShellIntegration::SetAsDefaultBrowser(); |
[email protected] | 0d3dc8e2 | 2009-11-03 02:27:01 | [diff] [blame] | 119 | ChromeThread::PostTask( |
| 120 | ChromeThread::UI, FROM_HERE, |
| 121 | NewRunnableMethod( |
| 122 | this, &DefaultBrowserWorker::CompleteSetAsDefaultBrowser)); |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 123 | } |
| 124 | |
| 125 | void ShellIntegration::DefaultBrowserWorker::CompleteSetAsDefaultBrowser() { |
[email protected] | 0d3dc8e2 | 2009-11-03 02:27:01 | [diff] [blame] | 126 | DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI)); |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 127 | if (observer_) { |
| 128 | // Set as default completed, check again to make sure it stuck... |
| 129 | StartCheckDefaultBrowser(); |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 130 | } |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 131 | } |
| 132 | |
[email protected] | 264f74d1 | 2009-09-04 23:39:58 | [diff] [blame] | 133 | void ShellIntegration::DefaultBrowserWorker::UpdateUI( |
| 134 | DefaultBrowserState state) { |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 135 | if (observer_) { |
[email protected] | 264f74d1 | 2009-09-04 23:39:58 | [diff] [blame] | 136 | switch (state) { |
| 137 | case NOT_DEFAULT_BROWSER: |
| 138 | observer_->SetDefaultBrowserUIState(STATE_NOT_DEFAULT); |
| 139 | break; |
| 140 | case IS_DEFAULT_BROWSER: |
| 141 | observer_->SetDefaultBrowserUIState(STATE_IS_DEFAULT); |
| 142 | break; |
| 143 | case UNKNOWN_DEFAULT_BROWSER: |
| 144 | observer_->SetDefaultBrowserUIState(STATE_UNKNOWN); |
| 145 | break; |
| 146 | default: |
| 147 | break; |
| 148 | } |
[email protected] | d24c401 | 2009-07-28 01:57:31 | [diff] [blame] | 149 | } |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 150 | } |