Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/profiles/profile_impl.h" | 5 #include "chrome/browser/profiles/profile_impl.h" |
| 6 | 6 |
| 7 #include "app/resource_bundle.h" | 7 #include "app/resource_bundle.h" |
| 8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 9 #include "base/environment.h" | 9 #include "base/environment.h" |
| 10 #include "base/file_path.h" | 10 #include "base/file_path.h" |
| 11 #include "base/file_util.h" | 11 #include "base/file_util.h" |
| 12 #include "base/metrics/histogram.h" | 12 #include "base/metrics/histogram.h" |
| 13 #include "base/path_service.h" | 13 #include "base/path_service.h" |
| 14 #include "base/scoped_ptr.h" | 14 #include "base/scoped_ptr.h" |
| 15 #include "base/string_number_conversions.h" | 15 #include "base/string_number_conversions.h" |
| 16 #include "base/string_util.h" | 16 #include "base/string_util.h" |
| 17 #include "base/values.h" | |
| 18 #include "base/version.h" | |
| 17 #include "chrome/browser/about_flags.h" | 19 #include "chrome/browser/about_flags.h" |
| 18 #include "chrome/browser/appcache/chrome_appcache_service.h" | 20 #include "chrome/browser/appcache/chrome_appcache_service.h" |
| 19 #include "chrome/browser/autocomplete/autocomplete_classifier.h" | 21 #include "chrome/browser/autocomplete/autocomplete_classifier.h" |
| 20 #include "chrome/browser/autofill/personal_data_manager.h" | 22 #include "chrome/browser/autofill/personal_data_manager.h" |
| 21 #include "chrome/browser/background_contents_service.h" | 23 #include "chrome/browser/background_contents_service.h" |
| 22 #include "chrome/browser/background_mode_manager.h" | 24 #include "chrome/browser/background_mode_manager.h" |
| 23 #include "chrome/browser/bookmarks/bookmark_model.h" | 25 #include "chrome/browser/bookmarks/bookmark_model.h" |
| 24 #include "chrome/browser/browser_list.h" | 26 #include "chrome/browser/browser_list.h" |
| 25 #include "chrome/browser/browser_process.h" | 27 #include "chrome/browser/browser_process.h" |
| 26 #include "chrome/browser/browser_signin.h" | 28 #include "chrome/browser/browser_signin.h" |
| 27 #include "chrome/browser/browser_thread.h" | 29 #include "chrome/browser/browser_thread.h" |
| 28 #include "chrome/browser/chrome_blob_storage_context.h" | 30 #include "chrome/browser/chrome_blob_storage_context.h" |
| 29 #include "chrome/browser/content_settings/host_content_settings_map.h" | 31 #include "chrome/browser/content_settings/host_content_settings_map.h" |
| 30 #include "chrome/browser/dom_ui/ntp_resource_cache.h" | 32 #include "chrome/browser/dom_ui/ntp_resource_cache.h" |
| 31 #include "chrome/browser/download/download_manager.h" | 33 #include "chrome/browser/download/download_manager.h" |
| 32 #include "chrome/browser/extensions/default_apps.h" | 34 #include "chrome/browser/extensions/default_apps.h" |
| 35 #include "chrome/browser/extensions/extension_accessibility_api.h" | |
| 33 #include "chrome/browser/extensions/extension_devtools_manager.h" | 36 #include "chrome/browser/extensions/extension_devtools_manager.h" |
| 34 #include "chrome/browser/extensions/extension_error_reporter.h" | 37 #include "chrome/browser/extensions/extension_error_reporter.h" |
| 35 #include "chrome/browser/extensions/extension_info_map.h" | 38 #include "chrome/browser/extensions/extension_info_map.h" |
| 36 #include "chrome/browser/extensions/extension_event_router.h" | 39 #include "chrome/browser/extensions/extension_event_router.h" |
| 37 #include "chrome/browser/extensions/extension_message_service.h" | 40 #include "chrome/browser/extensions/extension_message_service.h" |
| 38 #include "chrome/browser/extensions/extension_pref_store.h" | 41 #include "chrome/browser/extensions/extension_pref_store.h" |
| 39 #include "chrome/browser/extensions/extension_process_manager.h" | 42 #include "chrome/browser/extensions/extension_process_manager.h" |
| 40 #include "chrome/browser/extensions/extension_service.h" | 43 #include "chrome/browser/extensions/extension_service.h" |
| 41 #include "chrome/browser/extensions/user_script_master.h" | 44 #include "chrome/browser/extensions/user_script_master.h" |
| 42 #include "chrome/browser/favicon_service.h" | 45 #include "chrome/browser/favicon_service.h" |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 80 #include "chrome/browser/user_style_sheet_watcher.h" | 83 #include "chrome/browser/user_style_sheet_watcher.h" |
| 81 #include "chrome/browser/visitedlink/visitedlink_event_listener.h" | 84 #include "chrome/browser/visitedlink/visitedlink_event_listener.h" |
| 82 #include "chrome/browser/visitedlink/visitedlink_master.h" | 85 #include "chrome/browser/visitedlink/visitedlink_master.h" |
| 83 #include "chrome/browser/web_resource/web_resource_service.h" | 86 #include "chrome/browser/web_resource/web_resource_service.h" |
| 84 #include "chrome/browser/webdata/web_data_service.h" | 87 #include "chrome/browser/webdata/web_data_service.h" |
| 85 #include "chrome/common/chrome_constants.h" | 88 #include "chrome/common/chrome_constants.h" |
| 86 #include "chrome/common/chrome_paths.h" | 89 #include "chrome/common/chrome_paths.h" |
| 87 #include "chrome/common/chrome_paths_internal.h" | 90 #include "chrome/common/chrome_paths_internal.h" |
| 88 #include "chrome/common/chrome_switches.h" | 91 #include "chrome/common/chrome_switches.h" |
| 89 #include "chrome/common/json_pref_store.h" | 92 #include "chrome/common/json_pref_store.h" |
| 93 #include "chrome/common/json_value_serializer.h" | |
| 90 #include "chrome/common/notification_service.h" | 94 #include "chrome/common/notification_service.h" |
| 91 #include "chrome/common/pref_names.h" | 95 #include "chrome/common/pref_names.h" |
| 92 #include "chrome/common/render_messages.h" | 96 #include "chrome/common/render_messages.h" |
| 97 #include "chrome/common/zip.h" | |
| 93 #include "grit/browser_resources.h" | 98 #include "grit/browser_resources.h" |
| 94 #include "grit/locale_settings.h" | 99 #include "grit/locale_settings.h" |
| 95 #include "net/base/transport_security_state.h" | 100 #include "net/base/transport_security_state.h" |
| 96 #include "webkit/database/database_tracker.h" | 101 #include "webkit/database/database_tracker.h" |
| 97 | 102 |
| 98 #if defined(TOOLKIT_USES_GTK) | 103 #if defined(TOOLKIT_USES_GTK) |
| 99 #include "chrome/browser/gtk/gtk_theme_provider.h" | 104 #include "chrome/browser/gtk/gtk_theme_provider.h" |
| 100 #endif | 105 #endif |
| 101 | 106 |
| 102 #if defined(OS_WIN) | 107 #if defined(OS_WIN) |
| (...skipping 272 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 375 | 380 |
| 376 void ProfileImpl::RegisterComponentExtensions() { | 381 void ProfileImpl::RegisterComponentExtensions() { |
| 377 // Register the component extensions. | 382 // Register the component extensions. |
| 378 typedef std::list<std::pair<std::string, int> > ComponentExtensionList; | 383 typedef std::list<std::pair<std::string, int> > ComponentExtensionList; |
| 379 ComponentExtensionList component_extensions; | 384 ComponentExtensionList component_extensions; |
| 380 | 385 |
| 381 // Bookmark manager. | 386 // Bookmark manager. |
| 382 component_extensions.push_back( | 387 component_extensions.push_back( |
| 383 std::make_pair("bookmark_manager", IDR_BOOKMARKS_MANIFEST)); | 388 std::make_pair("bookmark_manager", IDR_BOOKMARKS_MANIFEST)); |
| 384 | 389 |
| 390 #if defined(OS_CHROMEOS) | |
| 391 // Register access extensions only if accessibility is enabled. | |
| 392 if (ExtensionAccessibilityEventRouter::GetInstance()-> | |
|
asargent_no_longer_on_chrome
2011/01/20 05:55:59
It seems kind of weird to ask the event router if
Chaitanya
2011/01/20 20:04:52
using prefs now
On 2011/01/20 05:55:59, Antony Sa
| |
| 393 IsAccessibilityEnabled()) { | |
| 394 component_extensions.push_back( | |
| 395 std::make_pair("access_chromevox", IDR_CHROMEVOX_MANIFEST)); | |
| 396 } | |
| 397 #endif | |
| 398 | |
| 385 #if defined(TOUCH_UI) | 399 #if defined(TOUCH_UI) |
| 386 component_extensions.push_back( | 400 component_extensions.push_back( |
| 387 std::make_pair("keyboard", IDR_KEYBOARD_MANIFEST)); | 401 std::make_pair("keyboard", IDR_KEYBOARD_MANIFEST)); |
| 388 #endif | 402 #endif |
| 389 | 403 |
| 390 // Web Store. | 404 // Web Store. |
| 391 component_extensions.push_back( | 405 component_extensions.push_back( |
| 392 std::make_pair("web_store", IDR_WEBSTORE_MANIFEST)); | 406 std::make_pair("web_store", IDR_WEBSTORE_MANIFEST)); |
| 393 | 407 |
| 394 for (ComponentExtensionList::iterator iter = component_extensions.begin(); | 408 for (ComponentExtensionList::iterator iter = component_extensions.begin(); |
| 395 iter != component_extensions.end(); ++iter) { | 409 iter != component_extensions.end(); ++iter) { |
| 396 FilePath path; | 410 FilePath path; |
| 397 if (PathService::Get(chrome::DIR_RESOURCES, &path)) { | 411 if (PathService::Get(chrome::DIR_RESOURCES, &path)) { |
| 398 path = path.AppendASCII(iter->first); | 412 path = path.AppendASCII(iter->first); |
| 399 } else { | 413 } else { |
| 400 NOTREACHED(); | 414 NOTREACHED(); |
| 401 } | 415 } |
| 402 | 416 |
| 403 std::string manifest = | 417 std::string manifest = |
| 404 ResourceBundle::GetSharedInstance().GetRawDataResource( | 418 ResourceBundle::GetSharedInstance().GetRawDataResource( |
| 405 iter->second).as_string(); | 419 iter->second).as_string(); |
| 420 | |
| 421 #if defined(OS_CHROMEOS) | |
| 422 if (StartsWithASCII(iter->first, "access_", true)) { | |
| 423 path = GetPath().AppendASCII( | |
| 424 ExtensionService::kAccessibilityInstallDirectoryName); | |
| 425 path = path.AppendASCII(iter->first); | |
| 426 UnzipAccessibilityExtensionResources(iter->first, path, manifest); | |
|
asargent_no_longer_on_chrome
2011/01/20 05:55:59
nit: it might read more clearly if you factor out
Chaitanya
2011/01/20 20:04:52
Done.
| |
| 427 } | |
| 428 #endif | |
| 429 | |
| 406 extensions_service_->register_component_extension( | 430 extensions_service_->register_component_extension( |
| 407 ExtensionService::ComponentExtensionInfo(manifest, path)); | 431 ExtensionService::ComponentExtensionInfo(manifest, path)); |
| 408 } | 432 } |
| 409 } | 433 } |
| 410 | 434 |
| 411 void ProfileImpl::InstallDefaultApps() { | 435 void ProfileImpl::InstallDefaultApps() { |
| 412 ExtensionService* extension_service = GetExtensionService(); | 436 ExtensionService* extension_service = GetExtensionService(); |
| 413 DefaultApps* default_apps = extension_service->default_apps(); | 437 DefaultApps* default_apps = extension_service->default_apps(); |
| 414 | 438 |
| 415 if (!default_apps->ShouldInstallDefaultApps(extension_service->GetAppIds())) | 439 if (!default_apps->ShouldInstallDefaultApps(extension_service->GetAppIds())) |
| 416 return; | 440 return; |
| 417 | 441 |
| 418 const ExtensionIdSet& app_ids = default_apps->default_apps(); | 442 const ExtensionIdSet& app_ids = default_apps->default_apps(); |
| 419 for (ExtensionIdSet::const_iterator iter = app_ids.begin(); | 443 for (ExtensionIdSet::const_iterator iter = app_ids.begin(); |
| 420 iter != app_ids.end(); ++iter) { | 444 iter != app_ids.end(); ++iter) { |
| 421 extension_service->AddPendingExtensionFromDefaultAppList(*iter); | 445 extension_service->AddPendingExtensionFromDefaultAppList(*iter); |
| 422 } | 446 } |
| 423 } | 447 } |
| 424 | 448 |
| 449 #if defined(OS_CHROMEOS) | |
| 450 void ProfileImpl::UnzipAccessibilityExtensionResources( | |
| 451 const std::string ext_name, | |
| 452 const FilePath dir_path, | |
| 453 const std::string manifest) { | |
| 454 JSONStringValueSerializer serializer(manifest); | |
| 455 scoped_ptr<DictionaryValue> dict( | |
| 456 static_cast<DictionaryValue*>(serializer.Deserialize(NULL, NULL))); | |
| 457 std::string new_version_str = "0.0"; | |
| 458 dict->GetString("version", &new_version_str); | |
| 459 scoped_ptr<Version> new_version( | |
| 460 Version::GetVersionFromString(new_version_str)); | |
| 461 scoped_ptr<Version> curr_version(Version::GetVersionFromString( | |
| 462 GetPrefs()->GetString(prefs::kAccessibilityChromeVoxVersion))); | |
| 463 if (new_version->CompareTo(*curr_version.get()) == 1 && | |
| 464 Unzip(FilePath().AppendASCII(extension_misc::kAccessExtensionCrxPath) | |
| 465 .AppendASCII(ext_name).ReplaceExtension(FILE_PATH_LITERAL(".zip")), | |
|
asargent_no_longer_on_chrome
2011/01/20 05:55:59
This is a little hard to read. Can you factor this
Chaitanya
2011/01/20 20:04:52
Removed UnzipAccessibilityExtensionResources and a
| |
| 466 dir_path) { | |
| 467 GetPrefs()->SetString(prefs::kAccessibilityChromeVoxVersion, | |
| 468 new_version_str); | |
| 469 } | |
| 470 } | |
| 471 #endif | |
| 472 | |
| 425 void ProfileImpl::InitWebResources() { | 473 void ProfileImpl::InitWebResources() { |
| 426 if (web_resource_service_) | 474 if (web_resource_service_) |
| 427 return; | 475 return; |
| 428 | 476 |
| 429 web_resource_service_ = new WebResourceService(this); | 477 web_resource_service_ = new WebResourceService(this); |
| 430 web_resource_service_->StartAfterDelay(); | 478 web_resource_service_->StartAfterDelay(); |
| 431 } | 479 } |
| 432 | 480 |
| 433 NTPResourceCache* ProfileImpl::GetNTPResourceCache() { | 481 NTPResourceCache* ProfileImpl::GetNTPResourceCache() { |
| 434 if (!ntp_resource_cache_.get()) | 482 if (!ntp_resource_cache_.get()) |
| (...skipping 954 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1389 } | 1437 } |
| 1390 | 1438 |
| 1391 PrerenderManager* ProfileImpl::GetPrerenderManager() { | 1439 PrerenderManager* ProfileImpl::GetPrerenderManager() { |
| 1392 CommandLine* cl = CommandLine::ForCurrentProcess(); | 1440 CommandLine* cl = CommandLine::ForCurrentProcess(); |
| 1393 if (!cl->HasSwitch(switches::kEnablePagePrerender)) | 1441 if (!cl->HasSwitch(switches::kEnablePagePrerender)) |
| 1394 return NULL; | 1442 return NULL; |
| 1395 if (!prerender_manager_) | 1443 if (!prerender_manager_) |
| 1396 prerender_manager_ = new PrerenderManager(this); | 1444 prerender_manager_ = new PrerenderManager(this); |
| 1397 return prerender_manager_; | 1445 return prerender_manager_; |
| 1398 } | 1446 } |
| OLD | NEW |