| 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/webstore_installer.h" | 5 #include "chrome/browser/extensions/webstore_installer.h" |
| 6 | 6 |
| 7 #include <vector> | 7 #include <vector> |
| 8 | 8 |
| 9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| 11 #include "base/command_line.h" | 11 #include "base/command_line.h" |
| 12 #include "base/file_util.h" | 12 #include "base/file_util.h" |
| 13 #include "base/metrics/field_trial.h" |
| 14 #include "base/path_service.h" |
| 13 #include "base/rand_util.h" | 15 #include "base/rand_util.h" |
| 14 #include "base/strings/string_number_conversions.h" | 16 #include "base/strings/string_number_conversions.h" |
| 15 #include "base/strings/string_util.h" | 17 #include "base/strings/string_util.h" |
| 16 #include "base/strings/stringprintf.h" | 18 #include "base/strings/stringprintf.h" |
| 17 #include "base/strings/utf_string_conversions.h" | 19 #include "base/strings/utf_string_conversions.h" |
| 18 #include "chrome/browser/browser_process.h" | 20 #include "chrome/browser/browser_process.h" |
| 19 #include "chrome/browser/chrome_notification_types.h" | 21 #include "chrome/browser/chrome_notification_types.h" |
| 20 #include "chrome/browser/download/download_crx_util.h" | 22 #include "chrome/browser/download/download_crx_util.h" |
| 21 #include "chrome/browser/download/download_prefs.h" | 23 #include "chrome/browser/download/download_prefs.h" |
| 22 #include "chrome/browser/download/download_stats.h" | 24 #include "chrome/browser/download/download_stats.h" |
| 23 #include "chrome/browser/extensions/crx_installer.h" | 25 #include "chrome/browser/extensions/crx_installer.h" |
| 24 #include "chrome/browser/extensions/extension_system.h" | 26 #include "chrome/browser/extensions/extension_system.h" |
| 25 #include "chrome/browser/extensions/install_tracker.h" | 27 #include "chrome/browser/extensions/install_tracker.h" |
| 26 #include "chrome/browser/extensions/install_tracker_factory.h" | 28 #include "chrome/browser/extensions/install_tracker_factory.h" |
| 27 #include "chrome/browser/extensions/install_verifier.h" | 29 #include "chrome/browser/extensions/install_verifier.h" |
| 28 #include "chrome/browser/profiles/profile.h" | 30 #include "chrome/browser/profiles/profile.h" |
| 29 #include "chrome/browser/ui/browser_list.h" | 31 #include "chrome/browser/ui/browser_list.h" |
| 30 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 32 #include "chrome/browser/ui/tabs/tab_strip_model.h" |
| 33 #include "chrome/common/chrome_paths.h" |
| 31 #include "chrome/common/chrome_switches.h" | 34 #include "chrome/common/chrome_switches.h" |
| 32 #include "chrome/common/extensions/extension.h" | 35 #include "chrome/common/extensions/extension.h" |
| 33 #include "chrome/common/extensions/extension_constants.h" | 36 #include "chrome/common/extensions/extension_constants.h" |
| 34 #include "chrome/common/extensions/manifest_handlers/shared_module_info.h" | 37 #include "chrome/common/extensions/manifest_handlers/shared_module_info.h" |
| 35 #include "chrome/common/omaha_query_params/omaha_query_params.h" | 38 #include "chrome/common/omaha_query_params/omaha_query_params.h" |
| 36 #include "content/public/browser/browser_thread.h" | 39 #include "content/public/browser/browser_thread.h" |
| 37 #include "content/public/browser/download_manager.h" | 40 #include "content/public/browser/download_manager.h" |
| 38 #include "content/public/browser/download_save_info.h" | 41 #include "content/public/browser/download_save_info.h" |
| 39 #include "content/public/browser/download_url_parameters.h" | 42 #include "content/public/browser/download_url_parameters.h" |
| 40 #include "content/public/browser/navigation_controller.h" | 43 #include "content/public/browser/navigation_controller.h" |
| (...skipping 27 matching lines...) Expand all Loading... |
| 68 | 71 |
| 69 const char kInvalidIdError[] = "Invalid id"; | 72 const char kInvalidIdError[] = "Invalid id"; |
| 70 const char kDownloadDirectoryError[] = "Could not create download directory"; | 73 const char kDownloadDirectoryError[] = "Could not create download directory"; |
| 71 const char kDownloadCanceledError[] = "Download canceled"; | 74 const char kDownloadCanceledError[] = "Download canceled"; |
| 72 const char kInstallCanceledError[] = "Install canceled"; | 75 const char kInstallCanceledError[] = "Install canceled"; |
| 73 const char kDownloadInterruptedError[] = "Download interrupted"; | 76 const char kDownloadInterruptedError[] = "Download interrupted"; |
| 74 const char kInvalidDownloadError[] = | 77 const char kInvalidDownloadError[] = |
| 75 "Download was not a valid extension or user script"; | 78 "Download was not a valid extension or user script"; |
| 76 const char kDependencyNotFoundError[] = "Dependency not found"; | 79 const char kDependencyNotFoundError[] = "Dependency not found"; |
| 77 const char kDependencyNotSharedModuleError[] = | 80 const char kDependencyNotSharedModuleError[] = |
| 78 "Dependency is not shared module"; | 81 "Dependency is not shared module"; |
| 79 const char kInlineInstallSource[] = "inline"; | 82 const char kInlineInstallSource[] = "inline"; |
| 80 const char kDefaultInstallSource[] = "ondemand"; | 83 const char kDefaultInstallSource[] = "ondemand"; |
| 81 const char kAppLauncherInstallSource[] = "applauncher"; | 84 const char kAppLauncherInstallSource[] = "applauncher"; |
| 82 | 85 |
| 86 // Folder for downloading crx files from the webstore. This is used so that the |
| 87 // crx files don't go via the usual downloads folder. |
| 88 const base::FilePath::CharType kWebstoreDownloadFolder[] = |
| 89 FILE_PATH_LITERAL("Webstore Downloads"); |
| 90 |
| 83 base::FilePath* g_download_directory_for_tests = NULL; | 91 base::FilePath* g_download_directory_for_tests = NULL; |
| 84 | 92 |
| 85 // Must be executed on the FILE thread. | 93 // Must be executed on the FILE thread. |
| 86 void GetDownloadFilePath( | 94 void GetDownloadFilePath( |
| 87 const base::FilePath& download_directory, const std::string& id, | 95 const base::FilePath& download_directory, |
| 96 const std::string& id, |
| 88 const base::Callback<void(const base::FilePath&)>& callback) { | 97 const base::Callback<void(const base::FilePath&)>& callback) { |
| 89 base::FilePath directory(g_download_directory_for_tests ? | 98 base::FilePath directory(g_download_directory_for_tests ? |
| 90 *g_download_directory_for_tests : download_directory); | 99 *g_download_directory_for_tests : download_directory); |
| 91 | 100 |
| 92 #if defined(OS_CHROMEOS) | 101 #if defined(OS_CHROMEOS) |
| 93 // Do not use drive for extension downloads. | 102 // Do not use drive for extension downloads. |
| 94 if (drive::util::IsUnderDriveMountPoint(directory)) | 103 if (drive::util::IsUnderDriveMountPoint(directory)) |
| 95 directory = DownloadPrefs::GetDefaultDownloadDirectory(); | 104 directory = DownloadPrefs::GetDefaultDownloadDirectory(); |
| 96 #endif | 105 #endif |
| 97 | 106 |
| 98 // Ensure the download directory exists. TODO(asargent) - make this use | 107 // Ensure the download directory exists. TODO(asargent) - make this use |
| 99 // common code from the downloads system. | 108 // common code from the downloads system. |
| 100 if (!base::DirectoryExists(directory)) { | 109 if (!base::DirectoryExists(directory)) { |
| (...skipping 18 matching lines...) Expand all Loading... |
| 119 file_util::GetUniquePathNumber(file, base::FilePath::StringType()); | 128 file_util::GetUniquePathNumber(file, base::FilePath::StringType()); |
| 120 if (uniquifier > 0) { | 129 if (uniquifier > 0) { |
| 121 file = file.InsertBeforeExtensionASCII( | 130 file = file.InsertBeforeExtensionASCII( |
| 122 base::StringPrintf(" (%d)", uniquifier)); | 131 base::StringPrintf(" (%d)", uniquifier)); |
| 123 } | 132 } |
| 124 | 133 |
| 125 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 134 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
| 126 base::Bind(callback, file)); | 135 base::Bind(callback, file)); |
| 127 } | 136 } |
| 128 | 137 |
| 138 bool UseSeparateWebstoreDownloadDirectory() { |
| 139 const char kFieldTrial[] = "WebstoreDownloadDirectory"; |
| 140 const char kSeparateDirectoryUnderUDD[] = "SeparateDirectoryUnderUDD"; |
| 141 |
| 142 std::string field_trial_group = |
| 143 base::FieldTrialList::FindFullName(kFieldTrial); |
| 144 return field_trial_group == kSeparateDirectoryUnderUDD; |
| 145 } |
| 146 |
| 129 } // namespace | 147 } // namespace |
| 130 | 148 |
| 131 namespace extensions { | 149 namespace extensions { |
| 132 | 150 |
| 133 // static | 151 // static |
| 134 GURL WebstoreInstaller::GetWebstoreInstallURL( | 152 GURL WebstoreInstaller::GetWebstoreInstallURL( |
| 135 const std::string& extension_id, InstallSource source) { | 153 const std::string& extension_id, |
| 154 InstallSource source) { |
| 136 std::string install_source; | 155 std::string install_source; |
| 137 switch (source) { | 156 switch (source) { |
| 138 case INSTALL_SOURCE_INLINE: | 157 case INSTALL_SOURCE_INLINE: |
| 139 install_source = kInlineInstallSource; | 158 install_source = kInlineInstallSource; |
| 140 break; | 159 break; |
| 141 case INSTALL_SOURCE_APP_LAUNCHER: | 160 case INSTALL_SOURCE_APP_LAUNCHER: |
| 142 install_source = kAppLauncherInstallSource; | 161 install_source = kAppLauncherInstallSource; |
| 143 break; | 162 break; |
| 144 case INSTALL_SOURCE_OTHER: | 163 case INSTALL_SOURCE_OTHER: |
| 145 install_source = kDefaultInstallSource; | 164 install_source = kDefaultInstallSource; |
| (...skipping 340 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 486 CHECK(!pending_modules_.empty()); | 505 CHECK(!pending_modules_.empty()); |
| 487 if (pending_modules_.size() == 1) { | 506 if (pending_modules_.size() == 1) { |
| 488 DCHECK_EQ(id_, pending_modules_.front().extension_id); | 507 DCHECK_EQ(id_, pending_modules_.front().extension_id); |
| 489 DownloadCrx(id_, install_source_); | 508 DownloadCrx(id_, install_source_); |
| 490 } else { | 509 } else { |
| 491 DownloadCrx(pending_modules_.front().extension_id, INSTALL_SOURCE_OTHER); | 510 DownloadCrx(pending_modules_.front().extension_id, INSTALL_SOURCE_OTHER); |
| 492 } | 511 } |
| 493 } | 512 } |
| 494 | 513 |
| 495 void WebstoreInstaller::DownloadCrx( | 514 void WebstoreInstaller::DownloadCrx( |
| 496 const std::string& extension_id, InstallSource source) { | 515 const std::string& extension_id, |
| 516 InstallSource source) { |
| 497 download_url_ = GetWebstoreInstallURL(extension_id, source); | 517 download_url_ = GetWebstoreInstallURL(extension_id, source); |
| 498 base::FilePath download_path = DownloadPrefs::FromDownloadManager( | 518 |
| 499 BrowserContext::GetDownloadManager(profile_))->DownloadPath(); | 519 base::FilePath download_path; |
| 520 if (UseSeparateWebstoreDownloadDirectory()) { |
| 521 base::FilePath user_data_dir; |
| 522 PathService::Get(chrome::DIR_USER_DATA, &user_data_dir); |
| 523 download_path = user_data_dir.Append(kWebstoreDownloadFolder); |
| 524 } else { |
| 525 download_path = DownloadPrefs::FromDownloadManager( |
| 526 BrowserContext::GetDownloadManager(profile_))->DownloadPath(); |
| 527 } |
| 528 |
| 500 BrowserThread::PostTask( | 529 BrowserThread::PostTask( |
| 501 BrowserThread::FILE, FROM_HERE, | 530 BrowserThread::FILE, FROM_HERE, |
| 502 base::Bind(&GetDownloadFilePath, download_path, id_, | 531 base::Bind(&GetDownloadFilePath, download_path, id_, |
| 503 base::Bind(&WebstoreInstaller::StartDownload, this))); | 532 base::Bind(&WebstoreInstaller::StartDownload, this))); |
| 504 } | 533 } |
| 505 | 534 |
| 506 // http://crbug.com/165634 | 535 // http://crbug.com/165634 |
| 507 // http://crbug.com/126013 | 536 // http://crbug.com/126013 |
| 508 // The current working theory is that one of the many pointers dereferenced in | 537 // The current working theory is that one of the many pointers dereferenced in |
| 509 // here is occasionally deleted before all of its referers are nullified, | 538 // here is occasionally deleted before all of its referers are nullified, |
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 590 void WebstoreInstaller::ReportSuccess() { | 619 void WebstoreInstaller::ReportSuccess() { |
| 591 if (delegate_) { | 620 if (delegate_) { |
| 592 delegate_->OnExtensionInstallSuccess(id_); | 621 delegate_->OnExtensionInstallSuccess(id_); |
| 593 delegate_ = NULL; | 622 delegate_ = NULL; |
| 594 } | 623 } |
| 595 | 624 |
| 596 Release(); // Balanced in Start(). | 625 Release(); // Balanced in Start(). |
| 597 } | 626 } |
| 598 | 627 |
| 599 } // namespace extensions | 628 } // namespace extensions |
| OLD | NEW |