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/extensions/component_loader.h" | 5 #include "chrome/browser/extensions/component_loader.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
| 10 #include "base/files/file_util.h" | 10 #include "base/files/file_util.h" |
| 11 #include "base/json/json_string_value_serializer.h" | 11 #include "base/json/json_string_value_serializer.h" |
| 12 #include "base/metrics/histogram_macros.h" | 12 #include "base/metrics/histogram_macros.h" |
| 13 #include "base/path_service.h" | 13 #include "base/path_service.h" |
| 14 #include "base/time/time.h" | 14 #include "base/time/time.h" |
| 15 #include "base/trace_event/trace_event.h" | 15 #include "base/trace_event/trace_event.h" |
| 16 #include "build/build_config.h" | 16 #include "build/build_config.h" |
| 17 #include "chrome/browser/extensions/component_extensions_whitelist/whitelist.h" | 17 #include "chrome/browser/extensions/component_extensions_whitelist/whitelist.h" |
| 18 #include "chrome/browser/extensions/data_deleter.h" | 18 #include "chrome/browser/extensions/data_deleter.h" |
| 19 #include "chrome/browser/extensions/extension_service.h" | 19 #include "chrome/browser/extensions/extension_service.h" |
| 20 #include "chrome/browser/pdf/pdf_extension_util.h" | 20 #include "chrome/browser/pdf/pdf_extension_util.h" |
| 21 #include "chrome/browser/profiles/profile.h" | 21 #include "chrome/browser/profiles/profile.h" |
| 22 #include "chrome/browser/search/hotword_service.h" | 22 #include "chrome/browser/search/hotword_service.h" |
| 23 #include "chrome/browser/search/hotword_service_factory.h" | 23 #include "chrome/browser/search/hotword_service_factory.h" |
| 24 #include "chrome/common/channel_info.h" | 24 #include "chrome/common/channel_info.h" |
| 25 #include "chrome/common/chrome_features.h" | |
| 25 #include "chrome/common/chrome_paths.h" | 26 #include "chrome/common/chrome_paths.h" |
| 26 #include "chrome/common/chrome_switches.h" | 27 #include "chrome/common/chrome_switches.h" |
| 27 #include "chrome/common/extensions/extension_constants.h" | 28 #include "chrome/common/extensions/extension_constants.h" |
| 28 #include "chrome/common/features.h" | 29 #include "chrome/common/features.h" |
| 29 #include "chrome/grit/browser_resources.h" | 30 #include "chrome/grit/browser_resources.h" |
| 30 #include "chrome/grit/chromium_strings.h" | 31 #include "chrome/grit/chromium_strings.h" |
| 31 #include "chrome/grit/generated_resources.h" | 32 #include "chrome/grit/generated_resources.h" |
| 32 #include "components/crx_file/id_util.h" | 33 #include "components/crx_file/id_util.h" |
| 33 #include "components/version_info/version_info.h" | 34 #include "components/version_info/version_info.h" |
| 34 #include "content/public/browser/browser_thread.h" | 35 #include "content/public/browser/browser_thread.h" |
| (...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 99 } | 100 } |
| 100 | 101 |
| 101 bool IsNormalSession() { | 102 bool IsNormalSession() { |
| 102 return !base::CommandLine::ForCurrentProcess()->HasSwitch( | 103 return !base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 103 chromeos::switches::kGuestSession) && | 104 chromeos::switches::kGuestSession) && |
| 104 user_manager::UserManager::IsInitialized() && | 105 user_manager::UserManager::IsInitialized() && |
| 105 user_manager::UserManager::Get()->IsUserLoggedIn(); | 106 user_manager::UserManager::Get()->IsUserLoggedIn(); |
| 106 } | 107 } |
| 107 #endif // defined(OS_CHROMEOS) | 108 #endif // defined(OS_CHROMEOS) |
| 108 | 109 |
| 110 bool IsMaterialDesignBookmarksEnabled() { | |
| 111 return base::FeatureList::IsEnabled(features::kMaterialDesignBookmarks); | |
| 112 } | |
| 113 | |
| 109 } // namespace | 114 } // namespace |
| 110 | 115 |
| 111 ComponentLoader::ComponentExtensionInfo::ComponentExtensionInfo( | 116 ComponentLoader::ComponentExtensionInfo::ComponentExtensionInfo( |
| 112 const base::DictionaryValue* manifest, const base::FilePath& directory) | 117 const base::DictionaryValue* manifest, const base::FilePath& directory) |
| 113 : manifest(manifest), | 118 : manifest(manifest), |
| 114 root_directory(directory) { | 119 root_directory(directory) { |
| 115 if (!root_directory.IsAbsolute()) { | 120 if (!root_directory.IsAbsolute()) { |
| 116 CHECK(PathService::Get(chrome::DIR_RESOURCES, &root_directory)); | 121 CHECK(PathService::Get(chrome::DIR_RESOURCES, &root_directory)); |
| 117 root_directory = root_directory.Append(directory); | 122 root_directory = root_directory.Append(directory); |
| 118 } | 123 } |
| (...skipping 328 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 447 utf8_error); | 452 utf8_error); |
| 448 } | 453 } |
| 449 | 454 |
| 450 // static | 455 // static |
| 451 void ComponentLoader::EnableBackgroundExtensionsForTesting() { | 456 void ComponentLoader::EnableBackgroundExtensionsForTesting() { |
| 452 enable_background_extensions_during_testing = true; | 457 enable_background_extensions_during_testing = true; |
| 453 } | 458 } |
| 454 | 459 |
| 455 void ComponentLoader::AddDefaultComponentExtensions( | 460 void ComponentLoader::AddDefaultComponentExtensions( |
| 456 bool skip_session_components) { | 461 bool skip_session_components) { |
| 462 base::FilePath bookmarks_path(IsMaterialDesignBookmarksEnabled() | |
| 463 ? FILE_PATH_LITERAL("md_bookmarks") | |
| 464 : FILE_PATH_LITERAL("bookmark_manager")); | |
| 465 int bookmark_manifest_id = IsMaterialDesignBookmarksEnabled() | |
|
Dan Beam
2016/10/25 18:05:51
can we cache this result?
also, can we just do th
calamity
2016/10/28 05:58:22
Done.
| |
| 466 ? IDR_MD_BOOKMARKS_MANIFEST | |
| 467 : IDR_BOOKMARKS_MANIFEST; | |
| 468 | |
| 457 // Do not add component extensions that have background pages here -- add them | 469 // Do not add component extensions that have background pages here -- add them |
| 458 // to AddDefaultComponentExtensionsWithBackgroundPages. | 470 // to AddDefaultComponentExtensionsWithBackgroundPages. |
| 459 #if defined(OS_CHROMEOS) | 471 #if defined(OS_CHROMEOS) |
| 460 Add(IDR_MOBILE_MANIFEST, | 472 Add(IDR_MOBILE_MANIFEST, |
| 461 base::FilePath(FILE_PATH_LITERAL("/usr/share/chromeos-assets/mobile"))); | 473 base::FilePath(FILE_PATH_LITERAL("/usr/share/chromeos-assets/mobile"))); |
| 462 | 474 |
| 463 #if defined(GOOGLE_CHROME_BUILD) | 475 #if defined(GOOGLE_CHROME_BUILD) |
| 464 if (browser_defaults::enable_help_app) { | 476 if (browser_defaults::enable_help_app) { |
| 465 Add(IDR_HELP_MANIFEST, base::FilePath(FILE_PATH_LITERAL( | 477 Add(IDR_HELP_MANIFEST, base::FilePath(FILE_PATH_LITERAL( |
| 466 "/usr/share/chromeos-assets/helpapp"))); | 478 "/usr/share/chromeos-assets/helpapp"))); |
| 467 } | 479 } |
| 468 #endif // defined(GOOGLE_CHROME_BUILD) | 480 #endif // defined(GOOGLE_CHROME_BUILD) |
| 469 | 481 |
| 470 // Skip all other extensions that require user session presence. | 482 // Skip all other extensions that require user session presence. |
| 471 if (!skip_session_components) { | 483 if (!skip_session_components) { |
| 472 const base::CommandLine* command_line = | 484 const base::CommandLine* command_line = |
| 473 base::CommandLine::ForCurrentProcess(); | 485 base::CommandLine::ForCurrentProcess(); |
| 474 if (!command_line->HasSwitch(chromeos::switches::kGuestSession)) | 486 if (!command_line->HasSwitch(chromeos::switches::kGuestSession)) |
| 475 Add(IDR_BOOKMARKS_MANIFEST, | 487 Add(bookmark_manifest_id, bookmarks_path); |
| 476 base::FilePath(FILE_PATH_LITERAL("bookmark_manager"))); | |
| 477 | 488 |
| 478 Add(IDR_CROSH_BUILTIN_MANIFEST, base::FilePath(FILE_PATH_LITERAL( | 489 Add(IDR_CROSH_BUILTIN_MANIFEST, base::FilePath(FILE_PATH_LITERAL( |
| 479 "/usr/share/chromeos-assets/crosh_builtin"))); | 490 "/usr/share/chromeos-assets/crosh_builtin"))); |
| 480 } | 491 } |
| 481 #else // defined(OS_CHROMEOS) | 492 #else // defined(OS_CHROMEOS) |
| 482 DCHECK(!skip_session_components); | 493 DCHECK(!skip_session_components); |
| 483 Add(IDR_BOOKMARKS_MANIFEST, | 494 Add(bookmark_manifest_id, bookmarks_path); |
| 484 base::FilePath(FILE_PATH_LITERAL("bookmark_manager"))); | |
| 485 #if defined(ENABLE_PRINTING) | 495 #if defined(ENABLE_PRINTING) |
| 486 // Cloud Print component app. Not required on Chrome OS. | 496 // Cloud Print component app. Not required on Chrome OS. |
| 487 Add(IDR_CLOUDPRINT_MANIFEST, | 497 Add(IDR_CLOUDPRINT_MANIFEST, |
| 488 base::FilePath(FILE_PATH_LITERAL("cloud_print"))); | 498 base::FilePath(FILE_PATH_LITERAL("cloud_print"))); |
| 489 #endif // defined(ENABLE_PRINTING) | 499 #endif // defined(ENABLE_PRINTING) |
| 490 #endif // defined(OS_CHROMEOS) | 500 #endif // defined(OS_CHROMEOS) |
| 491 | 501 |
| 492 if (!skip_session_components) { | 502 if (!skip_session_components) { |
| 493 AddWebStoreApp(); | 503 AddWebStoreApp(); |
| 494 AddChromeApp(); | 504 AddChromeApp(); |
| (...skipping 195 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 690 manifest.release(), | 700 manifest.release(), |
| 691 root_directory, | 701 root_directory, |
| 692 false); | 702 false); |
| 693 CHECK_EQ(extension_id, actual_extension_id); | 703 CHECK_EQ(extension_id, actual_extension_id); |
| 694 if (!done_cb.is_null()) | 704 if (!done_cb.is_null()) |
| 695 done_cb.Run(); | 705 done_cb.Run(); |
| 696 } | 706 } |
| 697 #endif | 707 #endif |
| 698 | 708 |
| 699 } // namespace extensions | 709 } // namespace extensions |
| OLD | NEW |