summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjohnnyg@chromium.org <johnnyg@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-11-24 22:10:49 +0000
committerjohnnyg@chromium.org <johnnyg@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-11-24 22:10:49 +0000
commit0faf2aa8df6e27a0ae8b720440df9907c52fdf31 (patch)
treef32f47ba9f1fa319359b0ec5890576b69306cfd0
parent3d6f426463d2358631000372cba0c40028d8b4c5 (diff)
downloadchromium_src-0faf2aa8df6e27a0ae8b720440df9907c52fdf31.zip
chromium_src-0faf2aa8df6e27a0ae8b720440df9907c52fdf31.tar.gz
chromium_src-0faf2aa8df6e27a0ae8b720440df9907c52fdf31.tar.bz2
Make notifications permission available in the extension manifest and hook up to the desktop notification service.
BUG=27249 TEST=none Review URL: http://codereview.chromium.org/432005 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@32979 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/browser/notifications/desktop_notification_service.cc34
-rw-r--r--chrome/browser/notifications/desktop_notification_service.h20
-rw-r--r--chrome/common/extensions/extension.cc2
-rw-r--r--chrome/common/extensions/extension.h1
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;