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

Unified Diff: chrome/browser/services/gcm/push_messaging_permission_context.cc

Issue 785993003: [Push] Register: require user-visible to be present in the manifest (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years 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/services/gcm/push_messaging_permission_context.cc
diff --git a/chrome/browser/services/gcm/push_messaging_permission_context.cc b/chrome/browser/services/gcm/push_messaging_permission_context.cc
index 418b1742997436582cbef7c2d51312891a453a9a..9badad170510eb1137bc2e58d0eb7ac369b4007d 100644
--- a/chrome/browser/services/gcm/push_messaging_permission_context.cc
+++ b/chrome/browser/services/gcm/push_messaging_permission_context.cc
@@ -4,21 +4,25 @@
#include "chrome/browser/services/gcm/push_messaging_permission_context.h"
+#include "chrome/browser/content_settings/permission_context_uma_util.h"
+#include "chrome/browser/notifications/desktop_notification_service.h"
+#include "chrome/browser/notifications/desktop_notification_service_factory.h"
#include "chrome/browser/profiles/profile.h"
#include "components/content_settings/core/browser/host_content_settings_map.h"
+#include "components/content_settings/core/common/permission_request_id.h"
+#include "content/public/browser/browser_thread.h"
#include "content/public/browser/web_contents.h"
#include "content/public/browser/web_contents_delegate.h"
const ContentSettingsType kPushSettingType =
CONTENT_SETTINGS_TYPE_PUSH_MESSAGING;
-const ContentSettingsType kNotificationSettingType =
- CONTENT_SETTINGS_TYPE_NOTIFICATIONS;
namespace gcm {
PushMessagingPermissionContext::PushMessagingPermissionContext(Profile* profile)
: PermissionContextBase(profile, CONTENT_SETTINGS_TYPE_PUSH_MESSAGING),
- profile_(profile) {
+ profile_(profile),
+ weak_factory_(this) {
}
PushMessagingPermissionContext::~PushMessagingPermissionContext() {
@@ -27,6 +31,7 @@ PushMessagingPermissionContext::~PushMessagingPermissionContext() {
ContentSetting PushMessagingPermissionContext::GetPermissionStatus(
const GURL& requesting_origin,
const GURL& embedding_origin) const {
+#if defined(ENABLE_NOTIFICATIONS)
if (requesting_origin != embedding_origin)
return CONTENT_SETTING_BLOCK;
@@ -34,22 +39,28 @@ ContentSetting PushMessagingPermissionContext::GetPermissionStatus(
profile_->GetHostContentSettingsMap()->GetContentSetting(
requesting_origin, embedding_origin, kPushSettingType, std::string());
- ContentSetting notifications_content_setting =
- profile_->GetHostContentSettingsMap()->GetContentSetting(
- requesting_origin, embedding_origin, kNotificationSettingType,
- std::string());
+ DesktopNotificationService* notification_service =
+ DesktopNotificationServiceFactory::GetForProfile(profile_);
+ DCHECK(notification_service);
+
+ ContentSetting notifications_permission =
+ notification_service->GetPermissionStatus(requesting_origin,
+ embedding_origin);
- if (notifications_content_setting == CONTENT_SETTING_BLOCK ||
+ if (notifications_permission == CONTENT_SETTING_BLOCK ||
push_content_setting == CONTENT_SETTING_BLOCK) {
return CONTENT_SETTING_BLOCK;
}
- if (notifications_content_setting == CONTENT_SETTING_ASK ||
+ if (notifications_permission == CONTENT_SETTING_ASK ||
push_content_setting == CONTENT_SETTING_ASK) {
return CONTENT_SETTING_ASK;
}
- DCHECK_EQ(CONTENT_SETTING_ALLOW, notifications_content_setting);
+ DCHECK_EQ(CONTENT_SETTING_ALLOW, notifications_permission);
DCHECK_EQ(CONTENT_SETTING_ALLOW, push_content_setting);
return CONTENT_SETTING_ALLOW;
+#else
+ return CONTENT_SETTING_BLOCK;
+#endif
}
// Unlike other permissions, push is decided by the following algorithm
@@ -65,23 +76,34 @@ void PushMessagingPermissionContext::DecidePermission(
const GURL& embedding_origin,
bool user_gesture,
const BrowserPermissionCallback& callback) {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
+#if defined(ENABLE_NOTIFICATIONS)
if (requesting_origin != embedding_origin) {
NotifyPermissionSet(id, requesting_origin, embedding_origin, callback,
false /* persist */, false /* granted */);
}
- ContentSetting notifications_content_setting =
- profile_->GetHostContentSettingsMap()
- ->GetContentSettingAndMaybeUpdateLastUsage(
- requesting_origin, embedding_origin, kNotificationSettingType,
- std::string());
-
- if (notifications_content_setting != CONTENT_SETTING_ALLOW) {
- DVLOG(1) << "Notification permission has not been granted.";
- NotifyPermissionSet(id, requesting_origin, embedding_origin, callback,
- false /* persist */, false /* granted */);
- return;
- }
+ DesktopNotificationService* notification_service =
+ DesktopNotificationServiceFactory::GetForProfile(profile_);
+ DCHECK(notification_service);
+
+ notification_service->RequestPermission(
+ web_contents, id, requesting_origin, user_gesture,
+ base::Bind(&PushMessagingPermissionContext::DecidePushPermission,
+ weak_factory_.GetWeakPtr(), id, requesting_origin,
Michael van Ouwerkerk 2014/12/11 15:55:35 Weak pointers and their factories are not thread s
Miguel Garcia 2014/12/11 16:20:07 Done.
+ embedding_origin, callback));
+#else
+ NotifyPermissionSet(id, requesting_origin, embedding_origin, callback,
+ false /* persist */, false /* granted */);
+#endif
+}
+void PushMessagingPermissionContext::DecidePushPermission(
+ const PermissionRequestID& id,
+ const GURL& requesting_origin,
+ const GURL& embedding_origin,
+ const BrowserPermissionCallback& callback,
+ bool notifications_permission_granted) {
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
ContentSetting push_content_setting =
profile_->GetHostContentSettingsMap()
->GetContentSettingAndMaybeUpdateLastUsage(
@@ -90,13 +112,24 @@ void PushMessagingPermissionContext::DecidePermission(
if (push_content_setting == CONTENT_SETTING_BLOCK) {
DVLOG(1) << "Push permission was explicitly blocked.";
+ PermissionContextUmaUtil::PermissionDenied(kPushSettingType,
+ requesting_origin);
+ NotifyPermissionSet(id, requesting_origin, embedding_origin, callback,
+ true /* persist */, false /* granted */);
+ return;
+ }
+
+ if (!notifications_permission_granted) {
+ DVLOG(1) << "Notification permission has not been granted.";
NotifyPermissionSet(id, requesting_origin, embedding_origin, callback,
false /* persist */, false /* granted */);
return;
}
+ PermissionContextUmaUtil::PermissionGranted(kPushSettingType,
+ requesting_origin);
NotifyPermissionSet(id, requesting_origin, embedding_origin, callback,
true /* persist */, true /* granted */);
}
-
} // namespace gcm
+

Powered by Google App Engine
This is Rietveld 408576698