Chromium Code Reviews| 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 |
| + |