diff options
author | tmdiep@chromium.org <tmdiep@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-08-06 06:26:28 +0000 |
---|---|---|
committer | tmdiep@chromium.org <tmdiep@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-08-06 06:26:28 +0000 |
commit | 8f959f52d735203ca0efc2776b094ceed33b754f (patch) | |
tree | 58ea66f19dd96b2790c3a273b503233b8252eb16 /extensions | |
parent | 3687b2f8321ad2ddfc0dfbf51547fbdcc53491ad (diff) | |
download | chromium_src-8f959f52d735203ca0efc2776b094ceed33b754f.zip chromium_src-8f959f52d735203ca0efc2776b094ceed33b754f.tar.gz chromium_src-8f959f52d735203ca0efc2776b094ceed33b754f.tar.bz2 |
Disable ephemeral apps after they stop running
Ephemeral apps are unloaded and disabled after they stop running to
ensure that they have no background activity while they are cached.
The event router, message service and message center no longer need
special handling for idle ephemeral apps.
BUG=339001,358052
TEST=browser_tests
TBR=dewittj@chromium.org (for removal of code in message_center_settings_controller.cc)
Review URL: https://codereview.chromium.org/344543006
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@287705 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'extensions')
-rw-r--r-- | extensions/browser/api/app_runtime/app_runtime_api.cc | 3 | ||||
-rw-r--r-- | extensions/browser/event_router.cc | 19 | ||||
-rw-r--r-- | extensions/browser/event_router.h | 6 | ||||
-rw-r--r-- | extensions/common/extension.h | 4 |
4 files changed, 6 insertions, 26 deletions
diff --git a/extensions/browser/api/app_runtime/app_runtime_api.cc b/extensions/browser/api/app_runtime/app_runtime_api.cc index 0ba19fb..0704478 100644 --- a/extensions/browser/api/app_runtime/app_runtime_api.cc +++ b/extensions/browser/api/app_runtime/app_runtime_api.cc @@ -32,7 +32,6 @@ void DispatchOnEmbedRequestedEventImpl( scoped_ptr<Event> event( new Event(app_runtime::OnEmbedRequested::kEventName, args.Pass())); event->restrict_to_browser_context = context; - event->can_load_ephemeral_apps = true; system->event_router()->DispatchEventWithLazyListener(extension_id, event.Pass()); @@ -52,7 +51,6 @@ void DispatchOnLaunchedEventImpl(const std::string& extension_id, scoped_ptr<Event> event( new Event(app_runtime::OnLaunched::kEventName, args.Pass())); event->restrict_to_browser_context = context; - event->can_load_ephemeral_apps = true; EventRouter::Get(context) ->DispatchEventWithLazyListener(extension_id, event.Pass()); ExtensionPrefs::Get(context) @@ -86,7 +84,6 @@ void AppRuntimeEventRouter::DispatchOnRestartedEvent( scoped_ptr<Event> event( new Event(app_runtime::OnRestarted::kEventName, arguments.Pass())); event->restrict_to_browser_context = context; - event->can_load_ephemeral_apps = true; EventRouter::Get(context) ->DispatchEventToExtension(extension->id(), event.Pass()); } diff --git a/extensions/browser/event_router.cc b/extensions/browser/event_router.cc index fd39a7b..73846ba 100644 --- a/extensions/browser/event_router.cc +++ b/extensions/browser/event_router.cc @@ -19,7 +19,6 @@ #include "extensions/browser/extension_prefs.h" #include "extensions/browser/extension_registry.h" #include "extensions/browser/extension_system.h" -#include "extensions/browser/extension_util.h" #include "extensions/browser/extensions_browser_client.h" #include "extensions/browser/lazy_background_task_queue.h" #include "extensions/browser/notification_types.h" @@ -625,15 +624,6 @@ bool EventRouter::MaybeLoadLazyBackgroundPageToDispatchEvent( BrowserContext* context, const Extension* extension, const linked_ptr<Event>& event) { - if (util::IsEphemeralApp(extension->id(), context) && - !event->can_load_ephemeral_apps) { - // Most events can only be dispatched to ephemeral apps that are already - // running. - ProcessManager* pm = ExtensionSystem::Get(context)->process_manager(); - if (!pm->GetBackgroundHostForExtension(extension->id())) - return false; - } - if (!CanDispatchEventToBrowserContext(context, extension, event)) return false; @@ -774,8 +764,7 @@ Event::Event(const std::string& event_name, : event_name(event_name), event_args(event_args.Pass()), restrict_to_browser_context(NULL), - user_gesture(EventRouter::USER_GESTURE_UNKNOWN), - can_load_ephemeral_apps(false) { + user_gesture(EventRouter::USER_GESTURE_UNKNOWN) { DCHECK(this->event_args.get()); } @@ -785,8 +774,7 @@ Event::Event(const std::string& event_name, : event_name(event_name), event_args(event_args.Pass()), restrict_to_browser_context(restrict_to_browser_context), - user_gesture(EventRouter::USER_GESTURE_UNKNOWN), - can_load_ephemeral_apps(false) { + user_gesture(EventRouter::USER_GESTURE_UNKNOWN) { DCHECK(this->event_args.get()); } @@ -801,8 +789,7 @@ Event::Event(const std::string& event_name, restrict_to_browser_context(restrict_to_browser_context), event_url(event_url), user_gesture(user_gesture), - filter_info(filter_info), - can_load_ephemeral_apps(false) { + filter_info(filter_info) { DCHECK(this->event_args.get()); } diff --git a/extensions/browser/event_router.h b/extensions/browser/event_router.h index fba6144..f0f9b95 100644 --- a/extensions/browser/event_router.h +++ b/extensions/browser/event_router.h @@ -351,12 +351,6 @@ struct Event { // this event to be dispatched to non-extension processes, like WebUI. WillDispatchCallback will_dispatch_callback; - // If true, this event will always be dispatched to ephemeral apps, regardless - // of whether they are running or inactive. Defaults to false. - // Most events can only be dispatched to ephemeral apps that are already - // running. Cached ephemeral apps are inactive until launched by the user. - bool can_load_ephemeral_apps; - Event(const std::string& event_name, scoped_ptr<base::ListValue> event_args); diff --git a/extensions/common/extension.h b/extensions/common/extension.h index 64241d2..a429d59 100644 --- a/extensions/common/extension.h +++ b/extensions/common/extension.h @@ -96,7 +96,9 @@ class Extension : public base::RefCountedThreadSafe<Extension> { DISABLE_GREYLIST = 1 << 9, DISABLE_CORRUPTED = 1 << 10, DISABLE_REMOTE_INSTALL = 1 << 11, - DISABLE_REASON_LAST = 1 << 12, // This should always be the last value + DISABLE_INACTIVE_EPHEMERAL_APP = 1 << 12, // Cached ephemeral apps are + // disabled to prevent activity. + DISABLE_REASON_LAST = 1 << 13, // This should always be the last value }; // A base class for parsed manifest data that APIs want to store on |