diff options
-rw-r--r-- | chrome/browser/notifications/desktop_notification_service.cc | 34 | ||||
-rw-r--r-- | chrome/browser/notifications/desktop_notification_service.h | 20 | ||||
-rw-r--r-- | chrome/common/extensions/extension.cc | 2 | ||||
-rw-r--r-- | chrome/common/extensions/extension.h | 1 |
4 files changed, 50 insertions, 7 deletions
diff --git a/chrome/browser/notifications/desktop_notification_service.cc b/chrome/browser/notifications/desktop_notification_service.cc index 9ece534..0c98404 100644 --- a/chrome/browser/notifications/desktop_notification_service.cc +++ b/chrome/browser/notifications/desktop_notification_service.cc @@ -191,6 +191,11 @@ DesktopNotificationService::DesktopNotificationService(Profile* profile, : profile_(profile), ui_manager_(ui_manager) { InitPrefs(); + + // Listen for new extension installations so we can cache permissions. + notification_registrar_.Add(this, + NotificationType::EXTENSION_LOADED, + Source<Profile>(profile_)); } DesktopNotificationService::~DesktopNotificationService() { @@ -212,6 +217,31 @@ void DesktopNotificationService::InitPrefs() { denied_sites = prefs->GetList(prefs::kDesktopNotificationDeniedOrigins); prefs_cache_ = new NotificationsPrefsCache(allowed_sites, denied_sites); + + ExtensionsService* ext_service = profile_->GetExtensionsService(); + if (ext_service) { + const ExtensionList* extensions = ext_service->extensions(); + for (ExtensionList::const_iterator iter = extensions->begin(); + iter != extensions->end(); ++iter) { + if ((*iter)->HasApiPermission(Extension::kNotificationPermission)) { + prefs_cache_->CacheAllowedOrigin((*iter)->url()); + } + } + } +} + +void DesktopNotificationService::Observe(NotificationType type, + const NotificationSource& source, + const NotificationDetails& details) { + if (type != NotificationType::EXTENSION_LOADED) { + NOTREACHED(); + return; + } + + Details<Extension> extension = static_cast<Details<Extension> >(details); + if (extension->HasApiPermission(Extension::kNotificationPermission)) { + GrantPermission(extension->url()); + } } void DesktopNotificationService::GrantPermission(const GURL& origin) { @@ -292,7 +322,7 @@ bool DesktopNotificationService::CancelDesktopNotification( bool DesktopNotificationService::ShowDesktopNotification( const GURL& origin, const GURL& url, int process_id, int route_id, - NotificationSource source, int notification_id) { + DesktopNotificationSource source, int notification_id) { DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI)); NotificationObjectProxy* proxy = new NotificationObjectProxy(process_id, route_id, @@ -306,7 +336,7 @@ bool DesktopNotificationService::ShowDesktopNotification( bool DesktopNotificationService::ShowDesktopNotificationText( const GURL& origin, const GURL& icon, const string16& title, const string16& text, int process_id, int route_id, - NotificationSource source, int notification_id) { + DesktopNotificationSource source, int notification_id) { DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI)); NotificationObjectProxy* proxy = new NotificationObjectProxy(process_id, route_id, diff --git a/chrome/browser/notifications/desktop_notification_service.h b/chrome/browser/notifications/desktop_notification_service.h index ad075e2..05141ff 100644 --- a/chrome/browser/notifications/desktop_notification_service.h +++ b/chrome/browser/notifications/desktop_notification_service.h @@ -9,6 +9,8 @@ #include "base/basictypes.h" #include "chrome/browser/notifications/notification.h" +#include "chrome/common/notification_registrar.h" +#include "chrome/common/notification_service.h" #include "googleurl/src/gurl.h" class NotificationUIManager; @@ -19,16 +21,16 @@ class Task; // The DesktopNotificationService is an object, owned by the Profile, // which provides the creation of desktop "toasts" to web pages and workers. -class DesktopNotificationService { +class DesktopNotificationService : public NotificationObserver { public: - enum NotificationSource { + enum DesktopNotificationSource { PageNotification, WorkerNotification }; DesktopNotificationService(Profile* profile, NotificationUIManager* ui_manager); - ~DesktopNotificationService(); + virtual ~DesktopNotificationService(); // Requests permission (using an info-bar) for a given origin. // |callback_context| contains an opaque value to pass back to the @@ -49,11 +51,11 @@ class DesktopNotificationService { // value to be passed back to the process when events occur on // this notification. bool ShowDesktopNotification(const GURL& origin, const GURL& url, - int process_id, int route_id, NotificationSource source, + int process_id, int route_id, DesktopNotificationSource source, int notification_id); bool ShowDesktopNotificationText(const GURL& origin, const GURL& icon, const string16& title, const string16& text, int process_id, - int route_id, NotificationSource source, int notification_id); + int route_id, DesktopNotificationSource source, int notification_id); // Cancels a notification. If it has already been shown, it will be // removed from the screen. If it hasn't been shown yet, it won't be @@ -68,6 +70,11 @@ class DesktopNotificationService { NotificationsPrefsCache* prefs_cache() { return prefs_cache_; } + // NotificationObserver interface. + virtual void Observe(NotificationType type, + const NotificationSource& source, + const NotificationDetails& details); + private: void InitPrefs(); @@ -87,6 +94,9 @@ class DesktopNotificationService { // UI for desktop toasts. NotificationUIManager* ui_manager_; + // Connection to the service providing the other kind of notifications. + NotificationRegistrar notification_registrar_; + DISALLOW_COPY_AND_ASSIGN(DesktopNotificationService); }; diff --git a/chrome/common/extensions/extension.cc b/chrome/common/extensions/extension.cc index 6e8c481..4038eaa 100644 --- a/chrome/common/extensions/extension.cc +++ b/chrome/common/extensions/extension.cc @@ -108,10 +108,12 @@ const int Extension::kBrowserActionIconMaxSize = 19; const char* Extension::kTabPermission = "tabs"; const char* Extension::kBookmarkPermission = "bookmarks"; +const char* Extension::kNotificationPermission = "notifications"; const char* Extension::kPermissionNames[] = { Extension::kTabPermission, Extension::kBookmarkPermission, + Extension::kNotificationPermission }; const size_t Extension::kNumPermissions = arraysize(Extension::kPermissionNames); diff --git a/chrome/common/extensions/extension.h b/chrome/common/extensions/extension.h index 9d5c1f5..77e5a64 100644 --- a/chrome/common/extensions/extension.h +++ b/chrome/common/extensions/extension.h @@ -73,6 +73,7 @@ class Extension { // Each permission is a module that the extension is permitted to use. static const char* kTabPermission; static const char* kBookmarkPermission; + static const char* kNotificationPermission; static const char* kPermissionNames[]; static const size_t kNumPermissions; |