blob: 3efa13644d2c498cf86d83b05acdb3c5b0423d87 [file] [log] [blame]
[email protected]f2a893c2011-01-05 09:38:071// Copyright (c) 2011 The Chromium Authors. All rights reserved.
license.botbf09a502008-08-24 00:55:552// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
initial.commit09911bf2008-07-26 23:55:294
5#include "chrome/browser/browser_process_impl.h"
6
[email protected]3cdacd42010-04-30 18:55:537#include <map>
[email protected]68f88b992011-05-07 02:01:398#include <set>
9#include <vector>
[email protected]3cdacd42010-04-30 18:55:5310
initial.commit09911bf2008-07-26 23:55:2911#include "base/command_line.h"
[email protected]6641bf662009-08-21 00:34:0912#include "base/file_util.h"
initial.commit09911bf2008-07-26 23:55:2913#include "base/path_service.h"
[email protected]985655a2011-02-23 09:54:2514#include "base/synchronization/waitable_event.h"
[email protected]c6032e82010-09-13 20:06:0515#include "base/task.h"
[email protected]34b99632011-01-01 01:01:0616#include "base/threading/thread.h"
17#include "base/threading/thread_restrictions.h"
[email protected]e13ad79b2010-07-22 21:36:5018#include "chrome/browser/automation/automation_provider_list.h"
[email protected]b443cb042009-12-15 22:05:0919#include "chrome/browser/browser_main.h"
[email protected]0ac83682010-01-22 17:46:2720#include "chrome/browser/browser_process_sub_thread.h"
[email protected]ac262c9f2008-10-19 17:45:2121#include "chrome/browser/browser_trial.h"
[email protected]6ccb5e52011-05-19 23:36:2522#include "chrome/browser/browsing_data_remover.h"
[email protected]9678cb42011-01-31 18:49:4223#include "chrome/browser/debugger/browser_list_tabcontents_provider.h"
[email protected]5613126e2011-01-31 15:27:5524#include "chrome/browser/debugger/devtools_http_protocol_handler.h"
[email protected]40ecc902009-03-16 13:42:4725#include "chrome/browser/debugger/devtools_manager.h"
[email protected]5613126e2011-01-31 15:27:5526#include "chrome/browser/debugger/devtools_protocol_handler.h"
[email protected]6c69796d2010-07-16 21:41:1627#include "chrome/browser/download/download_file_manager.h"
[email protected]5ba0a2c2009-02-19 01:19:3428#include "chrome/browser/download/save_file_manager.h"
[email protected]3ce02412011-03-01 12:01:1529#include "chrome/browser/extensions/extension_event_router_forwarder.h"
[email protected]fc4facd2011-03-22 23:18:5030#include "chrome/browser/extensions/extension_tab_id_map.h"
[email protected]214538842011-04-01 18:47:2431#include "chrome/browser/extensions/user_script_listener.h"
[email protected]815856722011-04-13 17:19:1932#include "chrome/browser/first_run/upgrade_util.h"
[email protected]f7578f52010-08-30 22:22:4933#include "chrome/browser/google/google_url_tracker.h"
[email protected]dcefa302009-05-20 00:24:3934#include "chrome/browser/icon_manager.h"
[email protected]c4ff4952010-01-08 19:12:4735#include "chrome/browser/intranet_redirect_detector.h"
[email protected]0ac83682010-01-22 17:46:2736#include "chrome/browser/io_thread.h"
[email protected]dc6f4962009-02-13 01:25:5037#include "chrome/browser/metrics/metrics_service.h"
[email protected]0b565182011-03-02 18:11:1538#include "chrome/browser/metrics/thread_watcher.h"
[email protected]b2fcd0e2010-12-01 15:19:4039#include "chrome/browser/net/chrome_net_log.h"
[email protected]3530cd92010-06-27 06:22:0140#include "chrome/browser/net/predictor_api.h"
[email protected]d393a0fd2009-05-13 23:32:0141#include "chrome/browser/net/sdch_dictionary_fetcher.h"
[email protected]29672ab2009-10-30 03:44:0342#include "chrome/browser/notifications/notification_ui_manager.h"
[email protected]838dd914a2011-05-09 02:50:5843#include "chrome/browser/platform_util.h"
[email protected]6618d1d2010-12-15 21:18:4744#include "chrome/browser/plugin_data_remover.h"
[email protected]985655a2011-02-23 09:54:2545#include "chrome/browser/policy/browser_policy_connector.h"
[email protected]caf63aea2011-04-26 11:04:1046#include "chrome/browser/prefs/browser_prefs.h"
[email protected]37858e52010-08-26 00:22:0247#include "chrome/browser/prefs/pref_service.h"
[email protected]68f88b992011-05-07 02:01:3948#include "chrome/browser/printing/background_printing_manager.h"
[email protected]e06131d2010-02-10 18:40:3349#include "chrome/browser/printing/print_job_manager.h"
[email protected]dbeebd52010-11-16 20:34:1650#include "chrome/browser/printing/print_preview_tab_controller.h"
[email protected]8ecad5e2010-12-02 21:18:3351#include "chrome/browser/profiles/profile_manager.h"
[email protected]a7a5e992010-12-09 23:39:5152#include "chrome/browser/safe_browsing/client_side_detection_service.h"
[email protected]81218f42009-02-05 18:48:0853#include "chrome/browser/safe_browsing/safe_browsing_service.h"
[email protected]e450fa62011-02-01 12:52:5654#include "chrome/browser/shell_integration.h"
[email protected]8b8e7c92010-08-19 18:05:5655#include "chrome/browser/sidebar/sidebar_manager.h"
[email protected]0b4d3382010-07-14 16:13:0456#include "chrome/browser/tab_closeable_state_watcher.h"
[email protected]71b73f02011-04-06 15:57:2957#include "chrome/browser/ui/browser_list.h"
[email protected]4ef795df2010-02-03 02:35:0858#include "chrome/common/chrome_constants.h"
initial.commit09911bf2008-07-26 23:55:2959#include "chrome/common/chrome_paths.h"
60#include "chrome/common/chrome_switches.h"
[email protected]de23f3f2011-05-18 16:20:2361#include "chrome/common/default_plugin.h"
[email protected]f1b6de22010-03-06 12:13:4762#include "chrome/common/extensions/extension_l10n_util.h"
[email protected]985655a2011-02-23 09:54:2563#include "chrome/common/extensions/extension_resource.h"
[email protected]ea587b02010-05-21 15:01:3564#include "chrome/common/json_pref_store.h"
initial.commit09911bf2008-07-26 23:55:2965#include "chrome/common/pref_names.h"
[email protected]5c08f222010-09-22 09:37:2166#include "chrome/common/switch_utils.h"
[email protected]985655a2011-02-23 09:54:2567#include "chrome/common/url_constants.h"
[email protected]bd48c2b02010-04-09 20:32:4268#include "chrome/installer/util/google_update_constants.h"
[email protected]a01efd22011-03-01 00:38:3269#include "content/browser/browser_child_process_host.h"
70#include "content/browser/browser_thread.h"
[email protected]419a0572011-04-18 22:21:4671#include "content/browser/child_process_security_policy.h"
[email protected]d9f37932011-05-09 20:09:2472#include "content/browser/gpu/gpu_process_host_ui_shim.h"
[email protected]a01efd22011-03-01 00:38:3273#include "content/browser/plugin_service.h"
74#include "content/browser/renderer_host/render_process_host.h"
75#include "content/browser/renderer_host/resource_dispatcher_host.h"
[email protected]f20d7332011-03-08 21:11:5376#include "content/common/notification_service.h"
[email protected]d55aaa132009-09-28 21:08:0477#include "ipc/ipc_logging.h"
[email protected]abe2c032011-03-31 18:49:3478#include "net/url_request/url_request_context_getter.h"
[email protected]2dfeaf92011-01-10 21:08:2179#include "ui/base/clipboard/clipboard.h"
[email protected]c051a1b2011-01-21 23:30:1780#include "ui/base/l10n/l10n_util.h"
[email protected]4ef795df2010-02-03 02:35:0881#include "webkit/database/database_tracker.h"
[email protected]de23f3f2011-05-18 16:20:2382#include "webkit/plugins/npapi/plugin_list.h"
[email protected]b112a4c2009-02-01 20:24:0183
84#if defined(OS_WIN)
[email protected]2362e4f2009-05-08 00:34:0585#include "views/focus/view_storage.h"
[email protected]86230b92009-11-23 20:38:3886#endif
87
[email protected]d55aaa132009-09-28 21:08:0488#if defined(IPC_MESSAGE_LOG_ENABLED)
[email protected]ff47b2962011-03-07 23:51:4989#include "content/common/child_process_messages.h"
[email protected]d55aaa132009-09-28 21:08:0490#endif
91
[email protected]db0e86dd2011-03-16 14:47:2192#if defined(OS_CHROMEOS)
93#include "chrome/browser/chromeos/proxy_config_service_impl.h"
[email protected]2d14b3732011-05-10 16:48:4494#include "chrome/browser/chromeos/web_socket_proxy_controller.h"
[email protected]db0e86dd2011-03-16 14:47:2195#endif // defined(OS_CHROMEOS)
96
[email protected]3cdacd42010-04-30 18:55:5397#if (defined(OS_WIN) || defined(OS_LINUX)) && !defined(OS_CHROMEOS)
98// How often to check if the persistent instance of Chrome needs to restart
99// to install an update.
100static const int kUpdateCheckIntervalHours = 6;
101#endif
102
[email protected]c6032e82010-09-13 20:06:05103#if defined(USE_X11)
104// How long to wait for the File thread to complete during EndSession, on
105// Linux. We have a timeout here because we're unable to run the UI messageloop
106// and there's some deadlock risk. Our only option is to exit anyway.
107static const int kEndSessionTimeoutSeconds = 10;
108#endif
109
[email protected]bb975362009-01-21 01:00:22110BrowserProcessImpl::BrowserProcessImpl(const CommandLine& command_line)
initial.commit09911bf2008-07-26 23:55:29111 : created_resource_dispatcher_host_(false),
112 created_metrics_service_(false),
113 created_io_thread_(false),
114 created_file_thread_(false),
115 created_db_thread_(false),
[email protected]914511712009-11-23 19:42:33116 created_process_launcher_thread_(false),
[email protected]875ee822010-05-18 20:58:01117 created_cache_thread_(false),
[email protected]7a31f7c2011-03-21 23:22:04118 created_gpu_thread_(false),
[email protected]0b565182011-03-02 18:11:15119 created_watchdog_thread_(false),
[email protected]2d14b3732011-05-10 16:48:44120#if defined(OS_CHROMEOS)
121 created_web_socket_proxy_thread_(false),
122#endif
initial.commit09911bf2008-07-26 23:55:29123 created_profile_manager_(false),
124 created_local_state_(false),
[email protected]b112a4c2009-02-01 20:24:01125 created_icon_manager_(false),
[email protected]40ecc902009-03-16 13:42:47126 created_devtools_manager_(false),
[email protected]8b8e7c92010-08-19 18:05:56127 created_sidebar_manager_(false),
[email protected]985655a2011-02-23 09:54:25128 created_browser_policy_connector_(false),
[email protected]29672ab2009-10-30 03:44:03129 created_notification_ui_manager_(false),
[email protected]a7a5e992010-12-09 23:39:51130 created_safe_browsing_detection_service_(false),
initial.commit09911bf2008-07-26 23:55:29131 module_ref_count_(0),
[email protected]afd20c022010-06-10 00:48:20132 did_start_(false),
[email protected]1b2db1a2008-08-08 17:46:13133 checked_for_new_frames_(false),
[email protected]4747caf2011-03-23 20:09:21134 using_new_frames_(false) {
initial.commit09911bf2008-07-26 23:55:29135 g_browser_process = this;
[email protected]2dfeaf92011-01-10 21:08:21136 clipboard_.reset(new ui::Clipboard);
initial.commit09911bf2008-07-26 23:55:29137 main_notification_service_.reset(new NotificationService);
138
[email protected]6618d1d2010-12-15 21:18:47139 notification_registrar_.Add(this,
140 NotificationType::APP_TERMINATING,
141 NotificationService::AllSources());
142
initial.commit09911bf2008-07-26 23:55:29143 // Must be created after the NotificationService.
144 print_job_manager_.reset(new printing::PrintJobManager);
145
[email protected]b797e152009-01-23 16:06:14146 shutdown_event_.reset(new base::WaitableEvent(true, false));
[email protected]b2fcd0e2010-12-01 15:19:40147
148 net_log_.reset(new ChromeNetLog);
[email protected]3ce02412011-03-01 12:01:15149
150 extension_event_router_forwarder_ = new ExtensionEventRouterForwarder;
[email protected]fc4facd2011-03-22 23:18:50151
152 ExtensionTabIdMap::GetInstance()->Init();
initial.commit09911bf2008-07-26 23:55:29153}
154
155BrowserProcessImpl::~BrowserProcessImpl() {
[email protected]4ef795df2010-02-03 02:35:08156 FilePath profile_path;
157 bool clear_local_state_on_exit;
158
159 // Store the profile path for clearing local state data on exit.
160 clear_local_state_on_exit = ShouldClearLocalState(&profile_path);
161
[email protected]2d14b3732011-05-10 16:48:44162#if defined(OS_CHROMEOS)
163 if (web_socket_proxy_thread_.get())
164 chromeos::WebSocketProxyController::Shutdown();
165 web_socket_proxy_thread_.reset();
166#endif
167
initial.commit09911bf2008-07-26 23:55:29168 // Delete the AutomationProviderList before NotificationService,
169 // since it may try to unregister notifications
170 // Both NotificationService and AutomationProvider are singleton instances in
171 // the BrowserProcess. Since AutomationProvider may have some active
172 // notification observers, it is essential that it gets destroyed before the
173 // NotificationService. NotificationService won't be destroyed until after
174 // this destructor is run.
175 automation_provider_list_.reset();
176
[email protected]d393a0fd2009-05-13 23:32:01177 // We need to shutdown the SdchDictionaryFetcher as it regularly holds
178 // a pointer to a URLFetcher, and that URLFetcher (upon destruction) will do
179 // a PostDelayedTask onto the IO thread. This shutdown call will both discard
180 // any pending URLFetchers, and avoid creating any more.
181 SdchDictionaryFetcher::Shutdown();
182
[email protected]51ac040762011-01-20 02:01:04183 // We need to destroy the MetricsService, GoogleURLTracker,
184 // IntranetRedirectDetector, and SafeBrowsing ClientSideDetectionService
185 // before the io_thread_ gets destroyed, since their destructors can call the
186 // URLFetcher destructor, which does a PostDelayedTask operation on the IO
187 // thread. (The IO thread will handle that URLFetcher operation before going
188 // away.)
initial.commit09911bf2008-07-26 23:55:29189 metrics_service_.reset();
190 google_url_tracker_.reset();
[email protected]c4ff4952010-01-08 19:12:47191 intranet_redirect_detector_.reset();
[email protected]51ac040762011-01-20 02:01:04192 safe_browsing_detection_service_.reset();
initial.commit09911bf2008-07-26 23:55:29193
[email protected]d8a899c2010-09-21 04:50:33194 // Need to clear the desktop notification balloons before the io_thread_ and
195 // before the profiles, since if there are any still showing we will access
196 // those things during teardown.
197 notification_ui_manager_.reset();
198
initial.commit09911bf2008-07-26 23:55:29199 // Need to clear profiles (download managers) before the io_thread_.
200 profile_manager_.reset();
201
202 // Debugger must be cleaned up before IO thread and NotificationService.
[email protected]5613126e2011-01-31 15:27:55203 if (devtools_http_handler_.get()) {
204 devtools_http_handler_->Stop();
205 devtools_http_handler_ = NULL;
206 }
207 if (devtools_legacy_handler_.get()) {
208 devtools_legacy_handler_->Stop();
209 devtools_legacy_handler_ = NULL;
210 }
initial.commit09911bf2008-07-26 23:55:29211
212 if (resource_dispatcher_host_.get()) {
213 // Need to tell Safe Browsing Service that the IO thread is going away
214 // since it cached a pointer to it.
215 if (resource_dispatcher_host()->safe_browsing_service())
216 resource_dispatcher_host()->safe_browsing_service()->ShutDown();
217
218 // Cancel pending requests and prevent new requests.
219 resource_dispatcher_host()->Shutdown();
220 }
221
[email protected]fc4facd2011-03-22 23:18:50222 ExtensionTabIdMap::GetInstance()->Shutdown();
223
[email protected]985655a2011-02-23 09:54:25224 // The policy providers managed by |browser_policy_connector_| need to shut
225 // down while the IO and FILE threads are still alive.
226 browser_policy_connector_.reset();
[email protected]f2a893c2011-01-05 09:38:07227
[email protected]753efc42010-03-09 19:52:16228#if defined(USE_X11)
[email protected]4c3cd7412009-04-22 17:56:06229 // The IO thread must outlive the BACKGROUND_X11 thread.
230 background_x11_thread_.reset();
231#endif
232
[email protected]6618d1d2010-12-15 21:18:47233 // Wait for removing plugin data to finish before shutting down the IO thread.
234 WaitForPluginDataRemoverToFinish();
235
[email protected]7a31f7c2011-03-21 23:22:04236 // Destroying the GpuProcessHostUIShims on the UI thread posts a task to
237 // delete related objects on the GPU thread. This must be done before
238 // stopping the GPU thread. The GPU thread will close IPC channels to renderer
239 // processes so this has to happen before stopping the IO thread.
240 GpuProcessHostUIShim::DestroyAll();
241 gpu_thread_.reset();
242
initial.commit09911bf2008-07-26 23:55:29243 // Need to stop io_thread_ before resource_dispatcher_host_, since
244 // io_thread_ may still deref ResourceDispatcherHost and handle resource
245 // request before going away.
[email protected]0ac83682010-01-22 17:46:27246 io_thread_.reset();
initial.commit09911bf2008-07-26 23:55:29247
[email protected]875ee822010-05-18 20:58:01248 // The IO thread was the only user of this thread.
249 cache_thread_.reset();
250
[email protected]914511712009-11-23 19:42:33251 // Stop the process launcher thread after the IO thread, in case the IO thread
252 // posted a task to terminate a process on the process launcher thread.
253 process_launcher_thread_.reset();
254
initial.commit09911bf2008-07-26 23:55:29255 // Clean up state that lives on the file_thread_ before it goes away.
256 if (resource_dispatcher_host_.get()) {
257 resource_dispatcher_host()->download_file_manager()->Shutdown();
258 resource_dispatcher_host()->save_file_manager()->Shutdown();
259 }
260
261 // Need to stop the file_thread_ here to force it to process messages in its
262 // message loop from the previous call to shutdown the DownloadFileManager,
263 // SaveFileManager and SessionService.
264 file_thread_.reset();
265
266 // With the file_thread_ flushed, we can release any icon resources.
267 icon_manager_.reset();
268
269 // Need to destroy ResourceDispatcherHost before PluginService and
[email protected]49f28bc72010-02-04 00:10:01270 // SafeBrowsingService, since it caches a pointer to it. This also
271 // causes the webkit thread to terminate.
initial.commit09911bf2008-07-26 23:55:29272 resource_dispatcher_host_.reset();
273
274 // Wait for the pending print jobs to finish.
275 print_job_manager_->OnQuit();
276 print_job_manager_.reset();
277
[email protected]0b4d3382010-07-14 16:13:04278 // Destroy TabCloseableStateWatcher before NotificationService since the
279 // former registers for notifications.
280 tab_closeable_state_watcher_.reset();
281
initial.commit09911bf2008-07-26 23:55:29282 // Now OK to destroy NotificationService.
283 main_notification_service_.reset();
284
[email protected]49f28bc72010-02-04 00:10:01285 // Prior to clearing local state, we want to complete tasks pending
286 // on the db thread too.
287 db_thread_.reset();
288
[email protected]0b565182011-03-02 18:11:15289 // Stop the watchdog thread after stopping other threads.
290 watchdog_thread_.reset();
291
[email protected]49f28bc72010-02-04 00:10:01292 // At this point, no render process exist and the file, io, db, and
293 // webkit threads in this process have all terminated, so it's safe
294 // to access local state data such as cookies, database, or local storage.
295 if (clear_local_state_on_exit)
296 ClearLocalState(profile_path);
297
initial.commit09911bf2008-07-26 23:55:29298 g_browser_process = NULL;
299}
300
[email protected]c6032e82010-09-13 20:06:05301#if defined(OS_WIN)
[email protected]295039bd2008-08-15 04:32:57302// Send a QuitTask to the given MessageLoop.
303static void PostQuit(MessageLoop* message_loop) {
304 message_loop->PostTask(FROM_HERE, new MessageLoop::QuitTask());
305}
[email protected]c6032e82010-09-13 20:06:05306#elif defined(USE_X11)
307static void Signal(base::WaitableEvent* event) {
308 event->Signal();
309}
310#endif
initial.commit09911bf2008-07-26 23:55:29311
[email protected]b443cb042009-12-15 22:05:09312unsigned int BrowserProcessImpl::AddRefModule() {
313 DCHECK(CalledOnValidThread());
[email protected]afd20c022010-06-10 00:48:20314 did_start_ = true;
[email protected]b443cb042009-12-15 22:05:09315 module_ref_count_++;
316 return module_ref_count_;
317}
318
319unsigned int BrowserProcessImpl::ReleaseModule() {
320 DCHECK(CalledOnValidThread());
[email protected]760d970a2010-05-18 00:39:18321 DCHECK_NE(0u, module_ref_count_);
[email protected]b443cb042009-12-15 22:05:09322 module_ref_count_--;
323 if (0 == module_ref_count_) {
[email protected]7d038c32010-12-14 00:40:00324 // Allow UI and IO threads to do blocking IO on shutdown, since we do a lot
325 // of it on shutdown for valid reasons.
326 base::ThreadRestrictions::SetIOAllowed(true);
327 io_thread()->message_loop()->PostTask(
328 FROM_HERE,
329 NewRunnableFunction(&base::ThreadRestrictions::SetIOAllowed, true));
[email protected]b443cb042009-12-15 22:05:09330 MessageLoop::current()->PostTask(
[email protected]34f73fb2010-03-24 20:50:34331 FROM_HERE, NewRunnableFunction(DidEndMainMessageLoop));
[email protected]b443cb042009-12-15 22:05:09332 MessageLoop::current()->Quit();
333 }
334 return module_ref_count_;
335}
336
initial.commit09911bf2008-07-26 23:55:29337void BrowserProcessImpl::EndSession() {
[email protected]c6032e82010-09-13 20:06:05338#if defined(OS_WIN) || defined(USE_X11)
[email protected]d65cab7a2008-08-12 01:25:41339 // Notify we are going away.
[email protected]c6032e82010-09-13 20:06:05340 shutdown_event_->Signal();
[email protected]b112a4c2009-02-01 20:24:01341#endif
[email protected]d65cab7a2008-08-12 01:25:41342
initial.commit09911bf2008-07-26 23:55:29343 // Mark all the profiles as clean.
344 ProfileManager* pm = profile_manager();
[email protected]844a1002011-04-19 11:37:21345 std::vector<Profile*> profiles(pm->GetLoadedProfiles());
346 for (size_t i = 0; i < profiles.size(); ++i)
347 profiles[i]->MarkAsCleanShutdown();
initial.commit09911bf2008-07-26 23:55:29348
349 // Tell the metrics service it was cleanly shutdown.
350 MetricsService* metrics = g_browser_process->metrics_service();
351 if (metrics && local_state()) {
initial.commit09911bf2008-07-26 23:55:29352 metrics->RecordStartOfSessionEnd();
353
354 // MetricsService lazily writes to prefs, force it to write now.
[email protected]6faa0e0d2009-04-28 06:50:36355 local_state()->SavePersistentPrefs();
initial.commit09911bf2008-07-26 23:55:29356 }
357
358 // We must write that the profile and metrics service shutdown cleanly,
359 // otherwise on startup we'll think we crashed. So we block until done and
360 // then proceed with normal shutdown.
[email protected]c6032e82010-09-13 20:06:05361#if defined(USE_X11)
362 // Can't run a local loop on linux. Instead create a waitable event.
363 base::WaitableEvent done_writing(false, false);
[email protected]d04e7662010-10-10 22:24:48364 BrowserThread::PostTask(BrowserThread::FILE, FROM_HERE,
[email protected]c6032e82010-09-13 20:06:05365 NewRunnableFunction(Signal, &done_writing));
366 done_writing.TimedWait(
367 base::TimeDelta::FromSeconds(kEndSessionTimeoutSeconds));
368#elif defined(OS_WIN)
[email protected]d04e7662010-10-10 22:24:48369 BrowserThread::PostTask(BrowserThread::FILE, FROM_HERE,
[email protected]295039bd2008-08-15 04:32:57370 NewRunnableFunction(PostQuit, MessageLoop::current()));
initial.commit09911bf2008-07-26 23:55:29371 MessageLoop::current()->Run();
[email protected]c6032e82010-09-13 20:06:05372#else
373 NOTIMPLEMENTED();
374#endif
initial.commit09911bf2008-07-26 23:55:29375}
376
[email protected]e13ad79b2010-07-22 21:36:50377ResourceDispatcherHost* BrowserProcessImpl::resource_dispatcher_host() {
378 DCHECK(CalledOnValidThread());
379 if (!created_resource_dispatcher_host_)
380 CreateResourceDispatcherHost();
381 return resource_dispatcher_host_.get();
382}
383
384MetricsService* BrowserProcessImpl::metrics_service() {
385 DCHECK(CalledOnValidThread());
386 if (!created_metrics_service_)
387 CreateMetricsService();
388 return metrics_service_.get();
389}
390
391IOThread* BrowserProcessImpl::io_thread() {
392 DCHECK(CalledOnValidThread());
393 if (!created_io_thread_)
394 CreateIOThread();
395 return io_thread_.get();
396}
397
398base::Thread* BrowserProcessImpl::file_thread() {
399 DCHECK(CalledOnValidThread());
400 if (!created_file_thread_)
401 CreateFileThread();
402 return file_thread_.get();
403}
404
405base::Thread* BrowserProcessImpl::db_thread() {
406 DCHECK(CalledOnValidThread());
407 if (!created_db_thread_)
408 CreateDBThread();
409 return db_thread_.get();
410}
411
412base::Thread* BrowserProcessImpl::process_launcher_thread() {
413 DCHECK(CalledOnValidThread());
414 if (!created_process_launcher_thread_)
415 CreateProcessLauncherThread();
416 return process_launcher_thread_.get();
417}
418
419base::Thread* BrowserProcessImpl::cache_thread() {
420 DCHECK(CalledOnValidThread());
421 if (!created_cache_thread_)
422 CreateCacheThread();
423 return cache_thread_.get();
424}
425
[email protected]7a31f7c2011-03-21 23:22:04426base::Thread* BrowserProcessImpl::gpu_thread() {
427 DCHECK(CalledOnValidThread());
428 if (!created_gpu_thread_)
429 CreateGpuThread();
430 return gpu_thread_.get();
431}
432
[email protected]e13ad79b2010-07-22 21:36:50433#if defined(USE_X11)
434base::Thread* BrowserProcessImpl::background_x11_thread() {
435 DCHECK(CalledOnValidThread());
436 // The BACKGROUND_X11 thread is created when the IO thread is created.
437 if (!created_io_thread_)
438 CreateIOThread();
439 return background_x11_thread_.get();
440}
441#endif
442
[email protected]0b565182011-03-02 18:11:15443WatchDogThread* BrowserProcessImpl::watchdog_thread() {
444 DCHECK(CalledOnValidThread());
445 if (!created_watchdog_thread_)
446 CreateWatchdogThread();
447 DCHECK(watchdog_thread_.get() != NULL);
448 return watchdog_thread_.get();
449}
450
[email protected]2d14b3732011-05-10 16:48:44451#if defined(OS_CHROMEOS)
452base::Thread* BrowserProcessImpl::web_socket_proxy_thread() {
453 DCHECK(CalledOnValidThread());
454 if (!created_web_socket_proxy_thread_)
455 CreateWebSocketProxyThread();
456 DCHECK(web_socket_proxy_thread_.get() != NULL);
457 return web_socket_proxy_thread_.get();
458}
459#endif
460
[email protected]e13ad79b2010-07-22 21:36:50461ProfileManager* BrowserProcessImpl::profile_manager() {
462 DCHECK(CalledOnValidThread());
463 if (!created_profile_manager_)
464 CreateProfileManager();
465 return profile_manager_.get();
466}
467
468PrefService* BrowserProcessImpl::local_state() {
469 DCHECK(CalledOnValidThread());
470 if (!created_local_state_)
471 CreateLocalState();
472 return local_state_.get();
473}
474
475DevToolsManager* BrowserProcessImpl::devtools_manager() {
476 DCHECK(CalledOnValidThread());
477 if (!created_devtools_manager_)
478 CreateDevToolsManager();
479 return devtools_manager_.get();
480}
481
[email protected]8b8e7c92010-08-19 18:05:56482SidebarManager* BrowserProcessImpl::sidebar_manager() {
483 DCHECK(CalledOnValidThread());
484 if (!created_sidebar_manager_)
485 CreateSidebarManager();
486 return sidebar_manager_.get();
487}
488
[email protected]2dfeaf92011-01-10 21:08:21489ui::Clipboard* BrowserProcessImpl::clipboard() {
[email protected]e13ad79b2010-07-22 21:36:50490 DCHECK(CalledOnValidThread());
491 return clipboard_.get();
492}
493
[email protected]abe2c032011-03-31 18:49:34494net::URLRequestContextGetter* BrowserProcessImpl::system_request_context() {
[email protected]db0e86dd2011-03-16 14:47:21495 DCHECK(CalledOnValidThread());
496 return io_thread()->system_url_request_context_getter();
497}
498
499#if defined(OS_CHROMEOS)
500chromeos::ProxyConfigServiceImpl*
501BrowserProcessImpl::chromeos_proxy_config_service_impl() {
502 DCHECK(CalledOnValidThread());
503 if (!chromeos_proxy_config_service_impl_) {
504 chromeos_proxy_config_service_impl_ =
505 new chromeos::ProxyConfigServiceImpl();
506 }
507 return chromeos_proxy_config_service_impl_;
508}
509#endif // defined(OS_CHROMEOS)
510
[email protected]3ce02412011-03-01 12:01:15511ExtensionEventRouterForwarder*
512BrowserProcessImpl::extension_event_router_forwarder() {
513 return extension_event_router_forwarder_.get();
514}
515
[email protected]e13ad79b2010-07-22 21:36:50516NotificationUIManager* BrowserProcessImpl::notification_ui_manager() {
517 DCHECK(CalledOnValidThread());
518 if (!created_notification_ui_manager_)
519 CreateNotificationUIManager();
520 return notification_ui_manager_.get();
521}
522
[email protected]985655a2011-02-23 09:54:25523policy::BrowserPolicyConnector* BrowserProcessImpl::browser_policy_connector() {
[email protected]f2a893c2011-01-05 09:38:07524 DCHECK(CalledOnValidThread());
[email protected]985655a2011-02-23 09:54:25525 if (!created_browser_policy_connector_) {
526 DCHECK(browser_policy_connector_.get() == NULL);
527 created_browser_policy_connector_ = true;
[email protected]d9ee002c2011-04-27 12:52:54528 browser_policy_connector_.reset(policy::BrowserPolicyConnector::Create());
[email protected]f2a893c2011-01-05 09:38:07529 }
[email protected]985655a2011-02-23 09:54:25530 return browser_policy_connector_.get();
[email protected]f2a893c2011-01-05 09:38:07531}
532
[email protected]e13ad79b2010-07-22 21:36:50533IconManager* BrowserProcessImpl::icon_manager() {
534 DCHECK(CalledOnValidThread());
535 if (!created_icon_manager_)
536 CreateIconManager();
537 return icon_manager_.get();
538}
539
540ThumbnailGenerator* BrowserProcessImpl::GetThumbnailGenerator() {
541 return &thumbnail_generator_;
542}
543
544AutomationProviderList* BrowserProcessImpl::InitAutomationProviderList() {
545 DCHECK(CalledOnValidThread());
546 if (automation_provider_list_.get() == NULL) {
547 automation_provider_list_.reset(AutomationProviderList::GetInstance());
548 }
549 return automation_provider_list_.get();
550}
551
[email protected]5613126e2011-01-31 15:27:55552void BrowserProcessImpl::InitDevToolsHttpProtocolHandler(
[email protected]01000cf12011-02-04 11:39:22553 const std::string& ip,
[email protected]5613126e2011-01-31 15:27:55554 int port,
555 const std::string& frontend_url) {
[email protected]e13ad79b2010-07-22 21:36:50556 DCHECK(CalledOnValidThread());
[email protected]5613126e2011-01-31 15:27:55557 devtools_http_handler_ =
[email protected]01000cf12011-02-04 11:39:22558 DevToolsHttpProtocolHandler::Start(ip,
559 port,
[email protected]9678cb42011-01-31 18:49:42560 frontend_url,
561 new BrowserListTabContentsProvider());
[email protected]5613126e2011-01-31 15:27:55562}
563
564void BrowserProcessImpl::InitDevToolsLegacyProtocolHandler(int port) {
565 DCHECK(CalledOnValidThread());
566 devtools_legacy_handler_ = DevToolsProtocolHandler::Start(port);
[email protected]e13ad79b2010-07-22 21:36:50567}
568
569bool BrowserProcessImpl::IsShuttingDown() {
570 DCHECK(CalledOnValidThread());
571 return did_start_ && 0 == module_ref_count_;
572}
573
initial.commit09911bf2008-07-26 23:55:29574printing::PrintJobManager* BrowserProcessImpl::print_job_manager() {
575 // TODO(abarth): DCHECK(CalledOnValidThread());
[email protected]d8922f22010-05-07 00:57:27576 // http://code.google.com/p/chromium/issues/detail?id=6828
initial.commit09911bf2008-07-26 23:55:29577 // print_job_manager_ is initialized in the constructor and destroyed in the
578 // destructor, so it should always be valid.
579 DCHECK(print_job_manager_.get());
580 return print_job_manager_.get();
581}
582
[email protected]dbeebd52010-11-16 20:34:16583printing::PrintPreviewTabController*
584 BrowserProcessImpl::print_preview_tab_controller() {
585 DCHECK(CalledOnValidThread());
586 if (!print_preview_tab_controller_.get())
587 CreatePrintPreviewTabController();
588 return print_preview_tab_controller_.get();
589}
590
[email protected]68f88b992011-05-07 02:01:39591printing::BackgroundPrintingManager*
592 BrowserProcessImpl::background_printing_manager() {
593 DCHECK(CalledOnValidThread());
594 if (!background_printing_manager_.get())
595 CreateBackgroundPrintingManager();
596 return background_printing_manager_.get();
597}
598
[email protected]e13ad79b2010-07-22 21:36:50599GoogleURLTracker* BrowserProcessImpl::google_url_tracker() {
600 DCHECK(CalledOnValidThread());
601 if (!google_url_tracker_.get())
602 CreateGoogleURLTracker();
603 return google_url_tracker_.get();
604}
605
606IntranetRedirectDetector* BrowserProcessImpl::intranet_redirect_detector() {
607 DCHECK(CalledOnValidThread());
608 if (!intranet_redirect_detector_.get())
609 CreateIntranetRedirectDetector();
610 return intranet_redirect_detector_.get();
611}
612
613const std::string& BrowserProcessImpl::GetApplicationLocale() {
614 DCHECK(!locale_.empty());
615 return locale_;
616}
617
618void BrowserProcessImpl::SetApplicationLocale(const std::string& locale) {
619 locale_ = locale;
620 extension_l10n_util::SetProcessLocale(locale);
621}
622
[email protected]073ed7b2010-09-27 09:20:02623DownloadStatusUpdater* BrowserProcessImpl::download_status_updater() {
624 return &download_status_updater_;
625}
626
[email protected]e13ad79b2010-07-22 21:36:50627base::WaitableEvent* BrowserProcessImpl::shutdown_event() {
628 return shutdown_event_.get();
629}
630
631TabCloseableStateWatcher* BrowserProcessImpl::tab_closeable_state_watcher() {
632 DCHECK(CalledOnValidThread());
633 if (!tab_closeable_state_watcher_.get())
634 CreateTabCloseableStateWatcher();
635 return tab_closeable_state_watcher_.get();
636}
637
[email protected]a7a5e992010-12-09 23:39:51638safe_browsing::ClientSideDetectionService*
639 BrowserProcessImpl::safe_browsing_detection_service() {
640 DCHECK(CalledOnValidThread());
641 if (!created_safe_browsing_detection_service_) {
642 CreateSafeBrowsingDetectionService();
643 }
644 return safe_browsing_detection_service_.get();
645}
646
[email protected]8b08a47f2011-02-25 12:36:37647bool BrowserProcessImpl::plugin_finder_disabled() const {
648 return *plugin_finder_disabled_pref_;
649}
650
[email protected]6618d1d2010-12-15 21:18:47651void BrowserProcessImpl::Observe(NotificationType type,
652 const NotificationSource& source,
653 const NotificationDetails& details) {
654 if (type == NotificationType::APP_TERMINATING) {
655 Profile* profile = ProfileManager::GetDefaultProfile();
656 if (profile) {
657 PrefService* prefs = profile->GetPrefs();
[email protected]2ffc3c6c2011-01-14 12:50:24658 if (prefs->GetBoolean(prefs::kClearSiteDataOnExit) &&
[email protected]6618d1d2010-12-15 21:18:47659 local_state()->GetBoolean(prefs::kClearPluginLSODataEnabled)) {
660 plugin_data_remover_ = new PluginDataRemover();
[email protected]c7d58d62011-01-21 10:27:18661 if (!plugin_data_remover_mime_type().empty())
662 plugin_data_remover_->set_mime_type(plugin_data_remover_mime_type());
663 plugin_data_remover_->StartRemoving(base::Time());
[email protected]6618d1d2010-12-15 21:18:47664 }
665 }
[email protected]e450fa62011-02-01 12:52:56666 } else if (type == NotificationType::PREF_CHANGED) {
667 std::string* pref = Details<std::string>(details).ptr();
668 if (*pref == prefs::kDefaultBrowserSettingEnabled) {
669 if (local_state_->GetBoolean(prefs::kDefaultBrowserSettingEnabled))
670 ShellIntegration::SetAsDefaultBrowser();
[email protected]419a0572011-04-18 22:21:46671 } else if (*pref == prefs::kDisabledSchemes) {
672 ApplyDisabledSchemesPolicy();
[email protected]e450fa62011-02-01 12:52:56673 }
[email protected]6618d1d2010-12-15 21:18:47674 } else {
675 NOTREACHED();
676 }
677}
678
679void BrowserProcessImpl::WaitForPluginDataRemoverToFinish() {
[email protected]c7d58d62011-01-21 10:27:18680 if (plugin_data_remover_.get())
681 plugin_data_remover_->Wait();
[email protected]6618d1d2010-12-15 21:18:47682}
683
[email protected]e13ad79b2010-07-22 21:36:50684#if (defined(OS_WIN) || defined(OS_LINUX)) && !defined(OS_CHROMEOS)
685void BrowserProcessImpl::StartAutoupdateTimer() {
686 autoupdate_timer_.Start(
687 base::TimeDelta::FromHours(kUpdateCheckIntervalHours),
688 this,
689 &BrowserProcessImpl::OnAutoupdateTimer);
690}
691#endif
692
[email protected]d6f37fc2011-02-13 23:58:41693ChromeNetLog* BrowserProcessImpl::net_log() {
694 return net_log_.get();
695}
696
[email protected]4ef795df2010-02-03 02:35:08697void BrowserProcessImpl::ClearLocalState(const FilePath& profile_path) {
[email protected]72cfd90f2010-02-06 03:08:04698 webkit_database::DatabaseTracker::ClearLocalState(profile_path);
[email protected]6ccb5e52011-05-19 23:36:25699 BrowsingDataRemover::ClearGearsData(profile_path);
[email protected]4ef795df2010-02-03 02:35:08700}
701
702bool BrowserProcessImpl::ShouldClearLocalState(FilePath* profile_path) {
703 FilePath user_data_dir;
704 Profile* profile;
705
[email protected]09584972010-07-03 00:00:59706 // Check for the existence of a profile manager. When quitting early,
[email protected]ed0cf562010-02-05 22:50:41707 // e.g. because another chrome instance is running, or when invoked with
708 // options such as --uninstall or --try-chrome-again=0, the profile manager
709 // does not exist yet.
710 if (!profile_manager_.get())
711 return false;
712
[email protected]4ef795df2010-02-03 02:35:08713 PathService::Get(chrome::DIR_USER_DATA, &user_data_dir);
714 profile = profile_manager_->GetDefaultProfile(user_data_dir);
[email protected]7bfc674322010-03-05 00:20:57715 if (!profile)
716 return false;
[email protected]4ef795df2010-02-03 02:35:08717 *profile_path = profile->GetPath();
718 return profile->GetPrefs()->GetBoolean(prefs::kClearSiteDataOnExit);
719}
720
initial.commit09911bf2008-07-26 23:55:29721void BrowserProcessImpl::CreateResourceDispatcherHost() {
722 DCHECK(!created_resource_dispatcher_host_ &&
723 resource_dispatcher_host_.get() == NULL);
724 created_resource_dispatcher_host_ = true;
725
[email protected]214538842011-04-01 18:47:24726 // UserScriptListener will delete itself.
727 ResourceQueue::DelegateSet resource_queue_delegates;
728 resource_queue_delegates.insert(new UserScriptListener());
729
730 resource_dispatcher_host_.reset(
731 new ResourceDispatcherHost(resource_queue_delegates));
initial.commit09911bf2008-07-26 23:55:29732 resource_dispatcher_host_->Initialize();
733}
734
735void BrowserProcessImpl::CreateMetricsService() {
736 DCHECK(!created_metrics_service_ && metrics_service_.get() == NULL);
737 created_metrics_service_ = true;
738
739 metrics_service_.reset(new MetricsService);
740}
741
742void BrowserProcessImpl::CreateIOThread() {
743 DCHECK(!created_io_thread_ && io_thread_.get() == NULL);
744 created_io_thread_ = true;
745
746 // Prior to starting the io thread, we create the plugin service as
747 // it is predominantly used from the io thread, but must be created
748 // on the main thread. The service ctor is inexpensive and does not
749 // invoke the io_thread() accessor.
750 PluginService::GetInstance();
751
[email protected]de23f3f2011-05-18 16:20:23752 // Add the Chrome specific plugins.
753 chrome::RegisterInternalDefaultPlugin();
754
755 // Register the internal Flash if available.
756 FilePath path;
757 if (!CommandLine::ForCurrentProcess()->HasSwitch(
758 switches::kDisableInternalFlash) &&
759 PathService::Get(chrome::FILE_FLASH_PLUGIN, &path)) {
760 webkit::npapi::PluginList::Singleton()->AddExtraPluginPath(path);
761 }
762
[email protected]753efc42010-03-09 19:52:16763#if defined(USE_X11)
[email protected]4c3cd7412009-04-22 17:56:06764 // The lifetime of the BACKGROUND_X11 thread is a subset of the IO thread so
765 // we start it now.
766 scoped_ptr<base::Thread> background_x11_thread(
[email protected]d04e7662010-10-10 22:24:48767 new BrowserProcessSubThread(BrowserThread::BACKGROUND_X11));
[email protected]4c3cd7412009-04-22 17:56:06768 if (!background_x11_thread->Start())
769 return;
770 background_x11_thread_.swap(background_x11_thread);
771#endif
772
[email protected]3ce02412011-03-01 12:01:15773 scoped_ptr<IOThread> thread(new IOThread(
774 local_state(), net_log_.get(), extension_event_router_forwarder_.get()));
[email protected]ab820df2008-08-26 05:55:10775 base::Thread::Options options;
776 options.message_loop_type = MessageLoop::TYPE_IO;
777 if (!thread->StartWithOptions(options))
initial.commit09911bf2008-07-26 23:55:29778 return;
779 io_thread_.swap(thread);
780}
781
782void BrowserProcessImpl::CreateFileThread() {
783 DCHECK(!created_file_thread_ && file_thread_.get() == NULL);
784 created_file_thread_ = true;
785
[email protected]ab820df2008-08-26 05:55:10786 scoped_ptr<base::Thread> thread(
[email protected]d04e7662010-10-10 22:24:48787 new BrowserProcessSubThread(BrowserThread::FILE));
[email protected]a1db3842008-09-17 22:04:06788 base::Thread::Options options;
[email protected]9e549b582009-02-05 21:13:39789#if defined(OS_WIN)
790 // On Windows, the FILE thread needs to be have a UI message loop which pumps
791 // messages in such a way that Google Update can communicate back to us.
[email protected]a1db3842008-09-17 22:04:06792 options.message_loop_type = MessageLoop::TYPE_UI;
[email protected]9e549b582009-02-05 21:13:39793#else
794 options.message_loop_type = MessageLoop::TYPE_IO;
795#endif
[email protected]a1db3842008-09-17 22:04:06796 if (!thread->StartWithOptions(options))
initial.commit09911bf2008-07-26 23:55:29797 return;
798 file_thread_.swap(thread);
799}
800
[email protected]2d14b3732011-05-10 16:48:44801#if defined(OS_CHROMEOS)
802void BrowserProcessImpl::CreateWebSocketProxyThread() {
803 DCHECK(!created_web_socket_proxy_thread_);
804 DCHECK(web_socket_proxy_thread_.get() == NULL);
805 created_web_socket_proxy_thread_ = true;
806
807 scoped_ptr<base::Thread> thread(
808 new BrowserProcessSubThread(BrowserThread::WEB_SOCKET_PROXY));
809 base::Thread::Options options;
810 options.message_loop_type = MessageLoop::TYPE_IO;
811 if (!thread->StartWithOptions(options))
812 return;
813 web_socket_proxy_thread_.swap(thread);
814}
815#endif
816
initial.commit09911bf2008-07-26 23:55:29817void BrowserProcessImpl::CreateDBThread() {
818 DCHECK(!created_db_thread_ && db_thread_.get() == NULL);
819 created_db_thread_ = true;
820
[email protected]ab820df2008-08-26 05:55:10821 scoped_ptr<base::Thread> thread(
[email protected]d04e7662010-10-10 22:24:48822 new BrowserProcessSubThread(BrowserThread::DB));
initial.commit09911bf2008-07-26 23:55:29823 if (!thread->Start())
824 return;
825 db_thread_.swap(thread);
826}
827
[email protected]914511712009-11-23 19:42:33828void BrowserProcessImpl::CreateProcessLauncherThread() {
829 DCHECK(!created_process_launcher_thread_ && !process_launcher_thread_.get());
830 created_process_launcher_thread_ = true;
831
832 scoped_ptr<base::Thread> thread(
[email protected]d04e7662010-10-10 22:24:48833 new BrowserProcessSubThread(BrowserThread::PROCESS_LAUNCHER));
[email protected]914511712009-11-23 19:42:33834 if (!thread->Start())
835 return;
836 process_launcher_thread_.swap(thread);
837}
838
[email protected]875ee822010-05-18 20:58:01839void BrowserProcessImpl::CreateCacheThread() {
840 DCHECK(!created_cache_thread_ && !cache_thread_.get());
841 created_cache_thread_ = true;
842
843 scoped_ptr<base::Thread> thread(
[email protected]75096332010-11-09 03:28:13844 new BrowserThread(BrowserThread::CACHE));
[email protected]875ee822010-05-18 20:58:01845 base::Thread::Options options;
846 options.message_loop_type = MessageLoop::TYPE_IO;
847 if (!thread->StartWithOptions(options))
848 return;
849 cache_thread_.swap(thread);
850}
851
[email protected]7a31f7c2011-03-21 23:22:04852void BrowserProcessImpl::CreateGpuThread() {
853 DCHECK(!created_gpu_thread_ && !gpu_thread_.get());
854 created_gpu_thread_ = true;
855
856 scoped_ptr<base::Thread> thread(new BrowserThread(BrowserThread::GPU));
857
858 base::Thread::Options options;
859#if defined(OS_WIN)
860 // On Windows the GPU thread needs to pump the compositor child window's
861 // message loop. TODO(apatrick): make this an IO thread if / when we get rid
862 // of this child window. Unfortunately it might always be necessary for
863 // Windows XP because we cannot share the backing store textures between
864 // processes.
865 options.message_loop_type = MessageLoop::TYPE_UI;
866#else
867 options.message_loop_type = MessageLoop::TYPE_IO;
868#endif
869
870 if (!thread->StartWithOptions(options))
871 return;
872 gpu_thread_.swap(thread);
873}
874
[email protected]0b565182011-03-02 18:11:15875void BrowserProcessImpl::CreateWatchdogThread() {
876 DCHECK(!created_watchdog_thread_ && watchdog_thread_.get() == NULL);
877 created_watchdog_thread_ = true;
878
879 scoped_ptr<WatchDogThread> thread(new WatchDogThread());
880 if (!thread->Start())
881 return;
882 watchdog_thread_.swap(thread);
883}
884
initial.commit09911bf2008-07-26 23:55:29885void BrowserProcessImpl::CreateProfileManager() {
886 DCHECK(!created_profile_manager_ && profile_manager_.get() == NULL);
887 created_profile_manager_ = true;
888
889 profile_manager_.reset(new ProfileManager());
890}
891
892void BrowserProcessImpl::CreateLocalState() {
893 DCHECK(!created_local_state_ && local_state_.get() == NULL);
894 created_local_state_ = true;
895
[email protected]b9636002009-03-04 00:05:25896 FilePath local_state_path;
initial.commit09911bf2008-07-26 23:55:29897 PathService::Get(chrome::FILE_LOCAL_STATE, &local_state_path);
[email protected]f2d1f612010-12-09 15:10:17898 local_state_.reset(
[email protected]845b43a82011-05-11 10:14:43899 PrefService::CreatePrefService(local_state_path, NULL, NULL, false));
[email protected]492d2142010-09-10 13:55:18900
[email protected]caf63aea2011-04-26 11:04:10901 // Initialize the prefs of the local state.
902 browser::RegisterLocalState(local_state_.get());
903
[email protected]2a7e7c152010-10-01 20:12:09904 pref_change_registrar_.Init(local_state_.get());
905
[email protected]f16b9662011-04-27 10:06:07906 print_job_manager_->InitOnUIThread(local_state_.get());
[email protected]e450fa62011-02-01 12:52:56907
908 // Initialize the notification for the default browser setting policy.
909 local_state_->RegisterBooleanPref(prefs::kDefaultBrowserSettingEnabled,
910 false);
911 if (local_state_->IsManagedPreference(prefs::kDefaultBrowserSettingEnabled)) {
912 if (local_state_->GetBoolean(prefs::kDefaultBrowserSettingEnabled))
913 ShellIntegration::SetAsDefaultBrowser();
914 }
915 pref_change_registrar_.Add(prefs::kDefaultBrowserSettingEnabled, this);
[email protected]8b08a47f2011-02-25 12:36:37916
917 // Initialize the preference for the plugin finder policy.
918 // This preference is only needed on the IO thread so make it available there.
919 local_state_->RegisterBooleanPref(prefs::kDisablePluginFinder, false);
920 plugin_finder_disabled_pref_.Init(prefs::kDisablePluginFinder,
921 local_state_.get(), NULL);
922 plugin_finder_disabled_pref_.MoveToThread(BrowserThread::IO);
[email protected]419a0572011-04-18 22:21:46923
[email protected]1f8110b2011-05-24 14:48:30924 // Initialize the disk cache location policy. This policy is not hot update-
925 // able so we need to have it when initializing the profiles.
926 local_state_->RegisterFilePathPref(prefs::kDiskCacheDir, FilePath());
927
[email protected]b99c41c2011-04-27 15:18:48928 // This is observed by ChildProcessSecurityPolicy, which lives in content/
929 // though, so it can't register itself.
[email protected]419a0572011-04-18 22:21:46930 local_state_->RegisterListPref(prefs::kDisabledSchemes);
[email protected]b99c41c2011-04-27 15:18:48931 pref_change_registrar_.Add(prefs::kDisabledSchemes, this);
[email protected]419a0572011-04-18 22:21:46932 ApplyDisabledSchemesPolicy();
[email protected]fd6159a2010-09-03 09:38:39933}
initial.commit09911bf2008-07-26 23:55:29934
initial.commit09911bf2008-07-26 23:55:29935void BrowserProcessImpl::CreateIconManager() {
936 DCHECK(!created_icon_manager_ && icon_manager_.get() == NULL);
937 created_icon_manager_ = true;
938 icon_manager_.reset(new IconManager);
939}
940
[email protected]40ecc902009-03-16 13:42:47941void BrowserProcessImpl::CreateDevToolsManager() {
[email protected]73ee01522009-06-05 10:13:44942 DCHECK(devtools_manager_.get() == NULL);
[email protected]40ecc902009-03-16 13:42:47943 created_devtools_manager_ = true;
[email protected]73ee01522009-06-05 10:13:44944 devtools_manager_ = new DevToolsManager();
[email protected]40ecc902009-03-16 13:42:47945}
946
[email protected]8b8e7c92010-08-19 18:05:56947void BrowserProcessImpl::CreateSidebarManager() {
948 DCHECK(sidebar_manager_.get() == NULL);
949 created_sidebar_manager_ = true;
950 sidebar_manager_ = new SidebarManager();
951}
952
initial.commit09911bf2008-07-26 23:55:29953void BrowserProcessImpl::CreateGoogleURLTracker() {
954 DCHECK(google_url_tracker_.get() == NULL);
955 scoped_ptr<GoogleURLTracker> google_url_tracker(new GoogleURLTracker);
956 google_url_tracker_.swap(google_url_tracker);
957}
[email protected]6641bf662009-08-21 00:34:09958
[email protected]c4ff4952010-01-08 19:12:47959void BrowserProcessImpl::CreateIntranetRedirectDetector() {
960 DCHECK(intranet_redirect_detector_.get() == NULL);
961 scoped_ptr<IntranetRedirectDetector> intranet_redirect_detector(
962 new IntranetRedirectDetector);
963 intranet_redirect_detector_.swap(intranet_redirect_detector);
964}
965
[email protected]29672ab2009-10-30 03:44:03966void BrowserProcessImpl::CreateNotificationUIManager() {
967 DCHECK(notification_ui_manager_.get() == NULL);
[email protected]b0b2a3dd2011-01-06 00:30:05968 notification_ui_manager_.reset(NotificationUIManager::Create(local_state()));
969
[email protected]29672ab2009-10-30 03:44:03970 created_notification_ui_manager_ = true;
971}
972
[email protected]0b4d3382010-07-14 16:13:04973void BrowserProcessImpl::CreateTabCloseableStateWatcher() {
974 DCHECK(tab_closeable_state_watcher_.get() == NULL);
975 tab_closeable_state_watcher_.reset(TabCloseableStateWatcher::Create());
976}
977
[email protected]dbeebd52010-11-16 20:34:16978void BrowserProcessImpl::CreatePrintPreviewTabController() {
979 DCHECK(print_preview_tab_controller_.get() == NULL);
980 print_preview_tab_controller_ = new printing::PrintPreviewTabController();
981}
982
[email protected]68f88b992011-05-07 02:01:39983void BrowserProcessImpl::CreateBackgroundPrintingManager() {
984 DCHECK(background_printing_manager_.get() == NULL);
985 background_printing_manager_.reset(new printing::BackgroundPrintingManager());
986}
987
[email protected]a7a5e992010-12-09 23:39:51988void BrowserProcessImpl::CreateSafeBrowsingDetectionService() {
989 DCHECK(safe_browsing_detection_service_.get() == NULL);
990 // Set this flag to true so that we don't retry indefinitely to
991 // create the service class if there was an error.
992 created_safe_browsing_detection_service_ = true;
993
994 FilePath model_file_path;
995 Profile* profile = profile_manager() ?
996 profile_manager()->GetDefaultProfile() : NULL;
997 if (IsSafeBrowsingDetectionServiceEnabled() &&
998 PathService::Get(chrome::DIR_USER_DATA, &model_file_path) &&
999 profile && profile->GetRequestContext()) {
1000 safe_browsing_detection_service_.reset(
1001 safe_browsing::ClientSideDetectionService::Create(
1002 model_file_path.Append(chrome::kSafeBrowsingPhishingModelFilename),
1003 profile->GetRequestContext()));
1004 }
1005}
1006
1007bool BrowserProcessImpl::IsSafeBrowsingDetectionServiceEnabled() {
1008 // The safe browsing client-side detection is enabled only if the switch is
[email protected]42930de42011-01-13 23:26:281009 // enabled and when safe browsing related stats is allowed to be collected.
[email protected]838dd914a2011-05-09 02:50:581010 // For now we only enable client-side detection on the canary, dev and beta
1011 // channel.
[email protected]d081d192011-04-01 02:33:241012#ifdef OS_CHROMEOS
1013 return false;
1014#else
[email protected]838dd914a2011-05-09 02:50:581015 std::string channel = platform_util::GetVersionStringModifier();
[email protected]d081d192011-04-01 02:33:241016 return !CommandLine::ForCurrentProcess()->HasSwitch(
1017 switches::kDisableClientSidePhishingDetection) &&
[email protected]42930de42011-01-13 23:26:281018 resource_dispatcher_host()->safe_browsing_service() &&
[email protected]838dd914a2011-05-09 02:50:581019 resource_dispatcher_host()->safe_browsing_service()->CanReportStats() &&
1020 (channel == "beta" || channel == "dev" || channel == "canary");
[email protected]d081d192011-04-01 02:33:241021#endif
[email protected]a7a5e992010-12-09 23:39:511022}
1023
[email protected]419a0572011-04-18 22:21:461024void BrowserProcessImpl::ApplyDisabledSchemesPolicy() {
1025 std::set<std::string> schemes;
[email protected]b99c41c2011-04-27 15:18:481026 const ListValue* scheme_list = local_state_->GetList(prefs::kDisabledSchemes);
1027 for (ListValue::const_iterator iter = scheme_list->begin();
1028 iter != scheme_list->end(); ++iter) {
[email protected]419a0572011-04-18 22:21:461029 std::string scheme;
1030 if ((*iter)->GetAsString(&scheme))
1031 schemes.insert(scheme);
1032 }
1033 ChildProcessSecurityPolicy::GetInstance()->RegisterDisabledSchemes(schemes);
1034}
1035
[email protected]6641bf662009-08-21 00:34:091036// The BrowserProcess object must outlive the file thread so we use traits
1037// which don't do any management.
[email protected]c56428f22010-06-16 02:17:231038DISABLE_RUNNABLE_METHOD_REFCOUNT(BrowserProcessImpl);
[email protected]6641bf662009-08-21 00:34:091039
[email protected]d55aaa132009-09-28 21:08:041040#if defined(IPC_MESSAGE_LOG_ENABLED)
1041
1042void BrowserProcessImpl::SetIPCLoggingEnabled(bool enable) {
1043 // First enable myself.
1044 if (enable)
[email protected]8e8bb6d2010-12-13 08:18:551045 IPC::Logging::GetInstance()->Enable();
[email protected]d55aaa132009-09-28 21:08:041046 else
[email protected]8e8bb6d2010-12-13 08:18:551047 IPC::Logging::GetInstance()->Disable();
[email protected]d55aaa132009-09-28 21:08:041048
1049 // Now tell subprocesses. Messages to ChildProcess-derived
1050 // processes must be done on the IO thread.
1051 io_thread()->message_loop()->PostTask
1052 (FROM_HERE,
1053 NewRunnableMethod(
1054 this,
1055 &BrowserProcessImpl::SetIPCLoggingEnabledForChildProcesses,
1056 enable));
1057
1058 // Finally, tell the renderers which don't derive from ChildProcess.
1059 // Messages to the renderers must be done on the UI (main) thread.
[email protected]019191a2009-10-02 20:37:271060 for (RenderProcessHost::iterator i(RenderProcessHost::AllHostsIterator());
1061 !i.IsAtEnd(); i.Advance())
[email protected]ff47b2962011-03-07 23:51:491062 i.GetCurrentValue()->Send(new ChildProcessMsg_SetIPCLoggingEnabled(enable));
[email protected]d55aaa132009-09-28 21:08:041063}
1064
1065// Helper for SetIPCLoggingEnabled.
1066void BrowserProcessImpl::SetIPCLoggingEnabledForChildProcesses(bool enabled) {
[email protected]d04e7662010-10-10 22:24:481067 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
[email protected]d55aaa132009-09-28 21:08:041068
[email protected]d27893f62010-07-03 05:47:421069 BrowserChildProcessHost::Iterator i; // default constr references a singleton
[email protected]34cf97d2009-09-29 22:46:111070 while (!i.Done()) {
[email protected]ff47b2962011-03-07 23:51:491071 i->Send(new ChildProcessMsg_SetIPCLoggingEnabled(enabled));
[email protected]34cf97d2009-09-29 22:46:111072 ++i;
[email protected]d55aaa132009-09-28 21:08:041073 }
1074}
1075
1076#endif // IPC_MESSAGE_LOG_ENABLED
1077
[email protected]3cdacd42010-04-30 18:55:531078// Mac is currently not supported.
1079#if (defined(OS_WIN) || defined(OS_LINUX)) && !defined(OS_CHROMEOS)
[email protected]bd48c2b02010-04-09 20:32:421080
1081bool BrowserProcessImpl::CanAutorestartForUpdate() const {
1082 // Check if browser is in the background and if it needs to be restarted to
1083 // apply a pending update.
[email protected]c10fa3952010-08-24 16:52:531084 return BrowserList::size() == 0 && BrowserList::WillKeepAlive() &&
[email protected]815856722011-04-13 17:19:191085 upgrade_util::IsUpdatePendingRestart();
[email protected]bd48c2b02010-04-09 20:32:421086}
1087
[email protected]5c08f222010-09-22 09:37:211088// Switches to add when auto-restarting Chrome.
[email protected]6c10c972010-08-11 04:15:471089const char* const kSwitchesToAddOnAutorestart[] = {
[email protected]f9a06842010-08-21 00:32:401090 switches::kNoStartupWindow
[email protected]bd48c2b02010-04-09 20:32:421091};
1092
1093void BrowserProcessImpl::RestartPersistentInstance() {
1094 CommandLine* old_cl = CommandLine::ForCurrentProcess();
[email protected]3cdacd42010-04-30 18:55:531095 scoped_ptr<CommandLine> new_cl(new CommandLine(old_cl->GetProgram()));
[email protected]bd48c2b02010-04-09 20:32:421096
1097 std::map<std::string, CommandLine::StringType> switches =
1098 old_cl->GetSwitches();
1099
[email protected]5c08f222010-09-22 09:37:211100 switches::RemoveSwitchesForAutostart(&switches);
[email protected]bd48c2b02010-04-09 20:32:421101
1102 // Append the rest of the switches (along with their values, if any)
1103 // to the new command line
1104 for (std::map<std::string, CommandLine::StringType>::const_iterator i =
1105 switches.begin(); i != switches.end(); ++i) {
1106 CommandLine::StringType switch_value = i->second;
1107 if (switch_value.length() > 0) {
[email protected]05076ba22010-07-30 05:59:571108 new_cl->AppendSwitchNative(i->first, i->second);
[email protected]bd48c2b02010-04-09 20:32:421109 } else {
[email protected]3cdacd42010-04-30 18:55:531110 new_cl->AppendSwitch(i->first);
[email protected]bd48c2b02010-04-09 20:32:421111 }
1112 }
1113
[email protected]6c10c972010-08-11 04:15:471114 // Ensure that our desired switches are set on the new process.
[email protected]5c08f222010-09-22 09:37:211115 for (size_t i = 0; i < arraysize(kSwitchesToAddOnAutorestart); ++i) {
[email protected]6c10c972010-08-11 04:15:471116 if (!new_cl->HasSwitch(kSwitchesToAddOnAutorestart[i]))
1117 new_cl->AppendSwitch(kSwitchesToAddOnAutorestart[i]);
1118 }
[email protected]bd48c2b02010-04-09 20:32:421119
[email protected]3cdacd42010-04-30 18:55:531120 DLOG(WARNING) << "Shutting down current instance of the browser.";
1121 BrowserList::CloseAllBrowsersAndExit();
1122
1123 // Transfer ownership to Upgrade.
[email protected]815856722011-04-13 17:19:191124 upgrade_util::SetNewCommandLine(new_cl.release());
[email protected]bd48c2b02010-04-09 20:32:421125}
1126
1127void BrowserProcessImpl::OnAutoupdateTimer() {
1128 if (CanAutorestartForUpdate()) {
[email protected]3cdacd42010-04-30 18:55:531129 DLOG(WARNING) << "Detected update. Restarting browser.";
[email protected]bd48c2b02010-04-09 20:32:421130 RestartPersistentInstance();
1131 }
1132}
1133
[email protected]3cdacd42010-04-30 18:55:531134#endif // (defined(OS_WIN) || defined(OS_LINUX)) && !defined(OS_CHROMEOS)