Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(290)

Side by Side Diff: chrome/browser/extensions/extension_service.cc

Issue 671873004: Migrates legacy packaged app data when it's upgraded to a platform app (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: More changes for review Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 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/extension_service.h" 5 #include "chrome/browser/extensions/extension_service.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 #include <iterator> 8 #include <iterator>
9 #include <set> 9 #include <set>
10 10
11 #include "base/command_line.h" 11 #include "base/command_line.h"
12 #include "base/metrics/histogram.h" 12 #include "base/metrics/histogram.h"
13 #include "base/strings/string_number_conversions.h" 13 #include "base/strings/string_number_conversions.h"
14 #include "base/strings/stringprintf.h" 14 #include "base/strings/stringprintf.h"
15 #include "base/strings/utf_string_conversions.h" 15 #include "base/strings/utf_string_conversions.h"
16 #include "base/threading/sequenced_worker_pool.h" 16 #include "base/threading/sequenced_worker_pool.h"
17 #include "base/threading/thread_restrictions.h" 17 #include "base/threading/thread_restrictions.h"
18 #include "base/time/time.h" 18 #include "base/time/time.h"
19 #include "chrome/browser/browser_process.h" 19 #include "chrome/browser/browser_process.h"
20 #include "chrome/browser/chrome_notification_types.h" 20 #include "chrome/browser/chrome_notification_types.h"
21 #include "chrome/browser/content_settings/content_settings_custom_extension_prov ider.h" 21 #include "chrome/browser/content_settings/content_settings_custom_extension_prov ider.h"
22 #include "chrome/browser/content_settings/content_settings_internal_extension_pr ovider.h" 22 #include "chrome/browser/content_settings/content_settings_internal_extension_pr ovider.h"
23 #include "chrome/browser/extensions/api/content_settings/content_settings_servic e.h" 23 #include "chrome/browser/extensions/api/content_settings/content_settings_servic e.h"
24 #include "chrome/browser/extensions/app_data_migrator.h"
24 #include "chrome/browser/extensions/component_loader.h" 25 #include "chrome/browser/extensions/component_loader.h"
25 #include "chrome/browser/extensions/crx_installer.h" 26 #include "chrome/browser/extensions/crx_installer.h"
26 #include "chrome/browser/extensions/data_deleter.h" 27 #include "chrome/browser/extensions/data_deleter.h"
27 #include "chrome/browser/extensions/extension_action_storage_manager.h" 28 #include "chrome/browser/extensions/extension_action_storage_manager.h"
28 #include "chrome/browser/extensions/extension_assets_manager.h" 29 #include "chrome/browser/extensions/extension_assets_manager.h"
29 #include "chrome/browser/extensions/extension_disabled_ui.h" 30 #include "chrome/browser/extensions/extension_disabled_ui.h"
30 #include "chrome/browser/extensions/extension_error_controller.h" 31 #include "chrome/browser/extensions/extension_error_controller.h"
31 #include "chrome/browser/extensions/extension_special_storage_policy.h" 32 #include "chrome/browser/extensions/extension_special_storage_policy.h"
32 #include "chrome/browser/extensions/extension_sync_service.h" 33 #include "chrome/browser/extensions/extension_sync_service.h"
33 #include "chrome/browser/extensions/extension_util.h" 34 #include "chrome/browser/extensions/extension_util.h"
(...skipping 229 matching lines...) Expand 10 before | Expand all | Expand 10 after
263 pending_extension_manager_(profile), 264 pending_extension_manager_(profile),
264 install_directory_(install_directory), 265 install_directory_(install_directory),
265 extensions_enabled_(extensions_enabled), 266 extensions_enabled_(extensions_enabled),
266 show_extensions_prompts_(true), 267 show_extensions_prompts_(true),
267 install_updates_when_idle_(true), 268 install_updates_when_idle_(true),
268 ready_(ready), 269 ready_(ready),
269 update_once_all_providers_are_ready_(false), 270 update_once_all_providers_are_ready_(false),
270 browser_terminating_(false), 271 browser_terminating_(false),
271 installs_delayed_for_gc_(false), 272 installs_delayed_for_gc_(false),
272 is_first_run_(false), 273 is_first_run_(false),
273 shared_module_service_(new extensions::SharedModuleService(profile_)) { 274 shared_module_service_(new extensions::SharedModuleService(profile_)),
275 app_data_migrator_(new extensions::AppDataMigrator(profile_, registry_)) {
274 CHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 276 CHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
275 277
276 // Figure out if extension installation should be enabled. 278 // Figure out if extension installation should be enabled.
277 if (extensions::ExtensionsBrowserClient::Get()->AreExtensionsDisabled( 279 if (extensions::ExtensionsBrowserClient::Get()->AreExtensionsDisabled(
278 *command_line, profile)) 280 *command_line, profile))
279 extensions_enabled_ = false; 281 extensions_enabled_ = false;
280 282
281 registrar_.Add(this, chrome::NOTIFICATION_APP_TERMINATING, 283 registrar_.Add(this, chrome::NOTIFICATION_APP_TERMINATING,
282 content::NotificationService::AllBrowserContextsAndSources()); 284 content::NotificationService::AllBrowserContextsAndSources());
283 registrar_.Add(this, 285 registrar_.Add(this,
(...skipping 1434 matching lines...) Expand 10 before | Expand all | Expand 10 after
1718 int install_flags, 1720 int install_flags,
1719 const syncer::StringOrdinal& page_ordinal, 1721 const syncer::StringOrdinal& page_ordinal,
1720 const std::string& install_parameter) { 1722 const std::string& install_parameter) {
1721 CHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 1723 CHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
1722 bool was_ephemeral = extension_prefs_->IsEphemeralApp(extension->id()); 1724 bool was_ephemeral = extension_prefs_->IsEphemeralApp(extension->id());
1723 extension_prefs_->OnExtensionInstalled( 1725 extension_prefs_->OnExtensionInstalled(
1724 extension, initial_state, page_ordinal, install_flags, install_parameter); 1726 extension, initial_state, page_ordinal, install_flags, install_parameter);
1725 delayed_installs_.Remove(extension->id()); 1727 delayed_installs_.Remove(extension->id());
1726 if (InstallVerifier::NeedsVerification(*extension)) 1728 if (InstallVerifier::NeedsVerification(*extension))
1727 system_->install_verifier()->VerifyExtension(extension->id()); 1729 system_->install_verifier()->VerifyExtension(extension->id());
1730
1731 const Extension* old = GetInstalledExtension(extension->id());
1732 if (app_data_migrator_->NeedsMigration(old, extension)) {
1733 app_data_migrator_->DoMigrationAndReply(
1734 old,
1735 extension,
1736 base::Bind(&ExtensionService::FinishInstallation,
1737 AsWeakPtr(),
1738 make_scoped_refptr(extension),
1739 was_ephemeral));
1740 return;
1741 }
1742
1728 FinishInstallation(extension, was_ephemeral); 1743 FinishInstallation(extension, was_ephemeral);
1729 } 1744 }
1730 1745
1731 void ExtensionService::MaybeFinishDelayedInstallation( 1746 void ExtensionService::MaybeFinishDelayedInstallation(
1732 const std::string& extension_id) { 1747 const std::string& extension_id) {
1733 // Check if the extension already got installed. 1748 // Check if the extension already got installed.
1734 if (!delayed_installs_.Contains(extension_id)) 1749 if (!delayed_installs_.Contains(extension_id))
1735 return; 1750 return;
1736 extensions::ExtensionPrefs::DelayReason reason = 1751 extensions::ExtensionPrefs::DelayReason reason =
1737 extension_prefs_->GetDelayedInstallReason(extension_id); 1752 extension_prefs_->GetDelayedInstallReason(extension_id);
(...skipping 633 matching lines...) Expand 10 before | Expand all | Expand 10 after
2371 } 2386 }
2372 2387
2373 void ExtensionService::OnProfileDestructionStarted() { 2388 void ExtensionService::OnProfileDestructionStarted() {
2374 ExtensionIdSet ids_to_unload = registry_->enabled_extensions().GetIDs(); 2389 ExtensionIdSet ids_to_unload = registry_->enabled_extensions().GetIDs();
2375 for (ExtensionIdSet::iterator it = ids_to_unload.begin(); 2390 for (ExtensionIdSet::iterator it = ids_to_unload.begin();
2376 it != ids_to_unload.end(); 2391 it != ids_to_unload.end();
2377 ++it) { 2392 ++it) {
2378 UnloadExtension(*it, UnloadedExtensionInfo::REASON_PROFILE_SHUTDOWN); 2393 UnloadExtension(*it, UnloadedExtensionInfo::REASON_PROFILE_SHUTDOWN);
2379 } 2394 }
2380 } 2395 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698