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

Unified Diff: chrome/browser/extensions/api/notifications/notifications_api.cc

Issue 2921263002: Remove many delegates, let's see what breaks
Patch Set: fix test Created 3 years, 6 months 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/api/notifications/notifications_api.cc
diff --git a/chrome/browser/extensions/api/notifications/notifications_api.cc b/chrome/browser/extensions/api/notifications/notifications_api.cc
index 7d04180e57b340984058f050780f8e024f0b0f41..793605904164250526221c879ec9bae8e6de6eb2 100644
--- a/chrome/browser/extensions/api/notifications/notifications_api.cc
+++ b/chrome/browser/extensions/api/notifications/notifications_api.cc
@@ -22,16 +22,14 @@
#include "chrome/browser/browser_process.h"
#include "chrome/browser/extensions/api/notifications/extension_notification_display_helper.h"
#include "chrome/browser/extensions/api/notifications/extension_notification_display_helper_factory.h"
-#include "chrome/browser/notifications/native_notification_delegate.h"
#include "chrome/browser/notifications/notification.h"
#include "chrome/browser/notifications/notification_common.h"
#include "chrome/browser/notifications/notification_delegate.h"
#include "chrome/browser/notifications/notifier_state_tracker.h"
#include "chrome/browser/notifications/notifier_state_tracker_factory.h"
+#include "chrome/browser/notifications/web_notification_delegate.h"
#include "chrome/browser/profiles/profile.h"
-#include "chrome/common/chrome_features.h"
#include "chrome/common/extensions/api/notifications/notification_style.h"
-#include "chrome/common/features.h"
#include "components/keyed_service/content/browser_context_keyed_service_shutdown_notifier_factory.h"
#include "components/keyed_service/core/keyed_service_shutdown_notifier.h"
#include "content/public/browser/render_process_host.h"
@@ -44,7 +42,6 @@
#include "extensions/browser/extension_system_provider.h"
#include "extensions/browser/extensions_browser_client.h"
#include "extensions/common/extension.h"
-#include "extensions/common/features/feature.h"
#include "third_party/skia/include/core/SkBitmap.h"
#include "ui/base/layout.h"
#include "ui/gfx/image/image.h"
@@ -62,10 +59,6 @@ namespace extensions {
namespace notifications = api::notifications;
-const base::Feature kAllowFullscreenAppNotificationsFeature{
- "FSNotificationsApp", base::FEATURE_ENABLED_BY_DEFAULT
-};
-
namespace {
const char kMissingRequiredPropertiesForCreateNotification[] =
@@ -190,159 +183,6 @@ bool NotificationBitmapToGfxImage(
return true;
}
-class ShutdownNotifierFactory
- : public BrowserContextKeyedServiceShutdownNotifierFactory {
- public:
- static ShutdownNotifierFactory* GetInstance() {
- return base::Singleton<ShutdownNotifierFactory>::get();
- }
-
- private:
- friend struct base::DefaultSingletonTraits<ShutdownNotifierFactory>;
-
- ShutdownNotifierFactory()
- : BrowserContextKeyedServiceShutdownNotifierFactory(
- "NotificationsApiDelegate") {
- DependsOn(ExtensionsBrowserClient::Get()->GetExtensionSystemFactory());
- }
- ~ShutdownNotifierFactory() override {}
-
- DISALLOW_COPY_AND_ASSIGN(ShutdownNotifierFactory);
-};
-
-// Message center based notification delegate with all the functionality.
-class NotificationApiDelegate : public NotificationDelegate {
- public:
- NotificationApiDelegate(ChromeAsyncExtensionFunction* api_function,
- Profile* profile,
- const std::string& extension_id,
- const std::string& id)
- : api_function_(api_function),
- event_router_(EventRouter::Get(profile)),
- display_helper_(
- ExtensionNotificationDisplayHelperFactory::GetForProfile(profile)),
- extension_id_(extension_id),
- scoped_id_(CreateScopedIdentifier(extension_id, id)) {
- DCHECK(api_function_);
- DCHECK(display_helper_);
-
- shutdown_notifier_subscription_ =
- ShutdownNotifierFactory::GetInstance()->Get(profile)->Subscribe(
- base::Bind(&NotificationApiDelegate::Shutdown,
- base::Unretained(this)));
- }
-
- void Close(bool by_user) override {
- EventRouter::UserGestureState gesture =
- by_user ? EventRouter::USER_GESTURE_ENABLED
- : EventRouter::USER_GESTURE_NOT_ENABLED;
- std::unique_ptr<base::ListValue> args(CreateBaseEventArgs());
- args->AppendBoolean(by_user);
- SendEvent(events::NOTIFICATIONS_ON_CLOSED,
- notifications::OnClosed::kEventName, gesture, std::move(args));
-
- DCHECK(display_helper_);
- display_helper_->EraseDataForNotificationId(scoped_id_);
- }
-
- void Click() override {
- std::unique_ptr<base::ListValue> args(CreateBaseEventArgs());
- SendEvent(events::NOTIFICATIONS_ON_CLICKED,
- notifications::OnClicked::kEventName,
- EventRouter::USER_GESTURE_ENABLED, std::move(args));
- }
-
- bool HasClickedListener() override {
- if (!event_router_)
- return false;
-
- return event_router_->HasEventListener(
- notifications::OnClicked::kEventName);
- }
-
- void ButtonClick(int index) override {
- std::unique_ptr<base::ListValue> args(CreateBaseEventArgs());
- args->AppendInteger(index);
- SendEvent(events::NOTIFICATIONS_ON_BUTTON_CLICKED,
- notifications::OnButtonClicked::kEventName,
- EventRouter::USER_GESTURE_ENABLED, std::move(args));
- }
-
- std::string id() const override { return scoped_id_; }
-
- // Should only display when fullscreen if this app is the source of the
- // fullscreen window.
- bool ShouldDisplayOverFullscreen() const override {
- AppWindowRegistry::AppWindowList windows = AppWindowRegistry::Get(
- api_function_->GetProfile())->GetAppWindowsForApp(extension_id_);
- for (auto* window : windows) {
- // Window must be fullscreen and visible
- if (window->IsFullscreen() && window->GetBaseWindow()->IsActive()) {
- bool enabled = base::FeatureList::IsEnabled(
- kAllowFullscreenAppNotificationsFeature);
- if (enabled) {
- UMA_HISTOGRAM_ENUMERATION("Notifications.Display_Fullscreen.Shown",
- NotifierId::APPLICATION,
- NotifierId::SIZE);
- } else {
- UMA_HISTOGRAM_ENUMERATION(
- "Notifications.Display_Fullscreen.Suppressed",
- NotifierId::APPLICATION,
- NotifierId::SIZE);
-
- }
- return enabled;
- }
- }
-
- return false;
- }
-
- private:
- ~NotificationApiDelegate() override {}
-
- void SendEvent(events::HistogramValue histogram_value,
- const std::string& name,
- EventRouter::UserGestureState user_gesture,
- std::unique_ptr<base::ListValue> args) {
- if (!event_router_)
- return;
-
- std::unique_ptr<Event> event(
- new Event(histogram_value, name, std::move(args)));
- event->user_gesture = user_gesture;
- event_router_->DispatchEventToExtension(extension_id_, std::move(event));
- }
-
- void Shutdown() {
- shutdown_notifier_subscription_.reset();
- event_router_ = nullptr;
- display_helper_ = nullptr;
- }
-
- std::unique_ptr<base::ListValue> CreateBaseEventArgs() {
- std::unique_ptr<base::ListValue> args(new base::ListValue());
- args->AppendString(StripScopeFromIdentifier(extension_id_, scoped_id_));
- return args;
- }
-
- scoped_refptr<ChromeAsyncExtensionFunction> api_function_;
-
- // Since this class is refcounted it may outlive the profile. We listen for
- // profile-keyed service shutdown events and reset to nullptr at that time,
- // so make sure to check for a valid pointer before use.
- EventRouter* event_router_;
- ExtensionNotificationDisplayHelper* display_helper_;
-
- const std::string extension_id_;
- const std::string scoped_id_;
-
- std::unique_ptr<KeyedServiceShutdownNotifier::Subscription>
- shutdown_notifier_subscription_;
-
- DISALLOW_COPY_AND_ASSIGN(NotificationApiDelegate);
-};
-
} // namespace
bool NotificationsApiFunction::IsNotificationsApiAvailable() {
@@ -497,20 +337,9 @@ bool NotificationsApiFunction::CreateNotification(
optional_fields.clickable = *options->is_clickable;
// Create the notification api delegate. Ownership passed to the notification.
- NotificationDelegate* api_delegate;
-#if BUILDFLAG(ENABLE_NATIVE_NOTIFICATIONS)
- if (base::FeatureList::IsEnabled(features::kNativeNotifications) &&
- g_browser_process->notification_platform_bridge()) {
- api_delegate = new NativeNotificationDelegate(
- CreateScopedIdentifier(extension_->id(), id));
- } else {
- api_delegate =
- new NotificationApiDelegate(this, GetProfile(), extension_->id(), id);
- }
-#else
- api_delegate =
- new NotificationApiDelegate(this, GetProfile(), extension_->id(), id);
-#endif // BUILDFLAG(ENABLE_NATIVE_NOTIFICATIONS)
+ NotificationDelegate* api_delegate = new WebNotificationDelegate(
+ NotificationCommon::EXTENSION, GetProfile(),
+ CreateScopedIdentifier(extension_->id(), id), extension_->url());
Notification notification(
type, title, message, icon,

Powered by Google App Engine
This is Rietveld 408576698