summaryrefslogtreecommitdiffstats
path: root/extensions
diff options
context:
space:
mode:
authortmdiep@chromium.org <tmdiep@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-08-06 06:26:28 +0000
committertmdiep@chromium.org <tmdiep@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-08-06 06:26:28 +0000
commit8f959f52d735203ca0efc2776b094ceed33b754f (patch)
tree58ea66f19dd96b2790c3a273b503233b8252eb16 /extensions
parent3687b2f8321ad2ddfc0dfbf51547fbdcc53491ad (diff)
downloadchromium_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.cc3
-rw-r--r--extensions/browser/event_router.cc19
-rw-r--r--extensions/browser/event_router.h6
-rw-r--r--extensions/common/extension.h4
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