OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/permissions/permission_manager.h" | 5 #include "chrome/browser/permissions/permission_manager.h" |
6 | 6 |
7 #include <memory> | 7 #include <memory> |
8 #include <utility> | 8 #include <utility> |
9 | 9 |
10 #include "base/callback.h" | 10 #include "base/callback.h" |
11 #include "base/memory/ptr_util.h" | 11 #include "base/memory/ptr_util.h" |
12 #include "build/build_config.h" | 12 #include "build/build_config.h" |
13 #include "chrome/browser/background_sync/background_sync_permission_context.h" | 13 #include "chrome/browser/background_sync/background_sync_permission_context.h" |
14 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" | 14 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" |
15 #include "chrome/browser/media/midi_permission_context.h" | 15 #include "chrome/browser/media/midi_permission_context.h" |
16 #include "chrome/browser/media/webrtc/media_stream_device_permission_context.h" | 16 #include "chrome/browser/media/webrtc/media_stream_device_permission_context.h" |
17 #include "chrome/browser/notifications/notification_permission_context.h" | 17 #include "chrome/browser/notifications/notification_permission_context.h" |
18 #include "chrome/browser/permissions/permission_context_base.h" | 18 #include "chrome/browser/permissions/permission_context_base.h" |
19 #include "chrome/browser/permissions/permission_manager_factory.h" | 19 #include "chrome/browser/permissions/permission_manager_factory.h" |
20 #include "chrome/browser/permissions/permission_request_id.h" | 20 #include "chrome/browser/permissions/permission_request_id.h" |
21 #include "chrome/browser/permissions/permission_result.h" | 21 #include "chrome/browser/permissions/permission_result.h" |
22 #include "chrome/browser/permissions/permission_uma_util.h" | 22 #include "chrome/browser/permissions/permission_uma_util.h" |
23 #include "chrome/browser/profiles/profile.h" | 23 #include "chrome/browser/profiles/profile.h" |
| 24 #include "chrome/browser/sensor/sensor_permission_context.h" |
24 #include "chrome/browser/storage/durable_storage_permission_context.h" | 25 #include "chrome/browser/storage/durable_storage_permission_context.h" |
25 #include "chrome/browser/tab_contents/tab_util.h" | 26 #include "chrome/browser/tab_contents/tab_util.h" |
26 #include "chrome/common/features.h" | 27 #include "chrome/common/features.h" |
27 #include "components/content_settings/core/browser/host_content_settings_map.h" | 28 #include "components/content_settings/core/browser/host_content_settings_map.h" |
28 #include "content/public/browser/browser_thread.h" | 29 #include "content/public/browser/browser_thread.h" |
29 #include "content/public/browser/permission_type.h" | 30 #include "content/public/browser/permission_type.h" |
30 #include "content/public/browser/render_frame_host.h" | 31 #include "content/public/browser/render_frame_host.h" |
31 #include "content/public/browser/render_process_host.h" | 32 #include "content/public/browser/render_process_host.h" |
32 #include "content/public/browser/web_contents.h" | 33 #include "content/public/browser/web_contents.h" |
33 #include "ppapi/features/features.h" | 34 #include "ppapi/features/features.h" |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
69 | 70 |
70 NOTREACHED(); | 71 NOTREACHED(); |
71 return PermissionStatus::DENIED; | 72 return PermissionStatus::DENIED; |
72 } | 73 } |
73 | 74 |
74 // Helper method to convert PermissionType to ContentSettingType. | 75 // Helper method to convert PermissionType to ContentSettingType. |
75 ContentSettingsType PermissionTypeToContentSetting(PermissionType permission) { | 76 ContentSettingsType PermissionTypeToContentSetting(PermissionType permission) { |
76 switch (permission) { | 77 switch (permission) { |
77 case PermissionType::MIDI: | 78 case PermissionType::MIDI: |
78 return CONTENT_SETTINGS_TYPE_MIDI; | 79 return CONTENT_SETTINGS_TYPE_MIDI; |
| 80 case PermissionType::SENSORS: |
| 81 return CONTENT_SETTINGS_TYPE_SENSORS; |
| 82 case PermissionType::AMBIENT_LIGHT_SENSOR: |
| 83 return CONTENT_SETTINGS_TYPE_AMBIENT_LIGHT_SENSOR; |
| 84 case PermissionType::MAGNETOMETER: |
| 85 return CONTENT_SETTINGS_TYPE_MAGNETOMETER; |
| 86 case PermissionType::ACCELEROMETER: |
| 87 return CONTENT_SETTINGS_TYPE_ACCELEROMETER; |
| 88 case PermissionType::GYROSCOPE: |
| 89 return CONTENT_SETTINGS_TYPE_GYROSCOPE; |
| 90 case PermissionType::ORIENTATION_SENSOR: |
| 91 return CONTENT_SETTINGS_TYPE_ORIENTATION_SENSOR; |
79 case PermissionType::MIDI_SYSEX: | 92 case PermissionType::MIDI_SYSEX: |
80 return CONTENT_SETTINGS_TYPE_MIDI_SYSEX; | 93 return CONTENT_SETTINGS_TYPE_MIDI_SYSEX; |
81 case PermissionType::PUSH_MESSAGING: | 94 case PermissionType::PUSH_MESSAGING: |
82 return CONTENT_SETTINGS_TYPE_PUSH_MESSAGING; | 95 return CONTENT_SETTINGS_TYPE_PUSH_MESSAGING; |
83 case PermissionType::NOTIFICATIONS: | 96 case PermissionType::NOTIFICATIONS: |
84 return CONTENT_SETTINGS_TYPE_NOTIFICATIONS; | 97 return CONTENT_SETTINGS_TYPE_NOTIFICATIONS; |
85 case PermissionType::GEOLOCATION: | 98 case PermissionType::GEOLOCATION: |
86 return CONTENT_SETTINGS_TYPE_GEOLOCATION; | 99 return CONTENT_SETTINGS_TYPE_GEOLOCATION; |
87 case PermissionType::PROTECTED_MEDIA_IDENTIFIER: | 100 case PermissionType::PROTECTED_MEDIA_IDENTIFIER: |
88 #if defined(OS_ANDROID) || defined(OS_CHROMEOS) | 101 #if defined(OS_ANDROID) || defined(OS_CHROMEOS) |
(...skipping 20 matching lines...) Expand all Loading... |
109 NOTREACHED() << "Unknown content setting for permission " | 122 NOTREACHED() << "Unknown content setting for permission " |
110 << static_cast<int>(permission); | 123 << static_cast<int>(permission); |
111 return CONTENT_SETTINGS_TYPE_DEFAULT; | 124 return CONTENT_SETTINGS_TYPE_DEFAULT; |
112 } | 125 } |
113 | 126 |
114 // Returns whether the permission has a constant ContentSetting value (i.e. | 127 // Returns whether the permission has a constant ContentSetting value (i.e. |
115 // always approved or always denied) | 128 // always approved or always denied) |
116 // The ContentSettingsTypes for which true is returned will also return nullptr | 129 // The ContentSettingsTypes for which true is returned will also return nullptr |
117 // in PermissionManager::GetPermissionContext since they don't have a context. | 130 // in PermissionManager::GetPermissionContext since they don't have a context. |
118 bool IsConstantPermission(ContentSettingsType type) { | 131 bool IsConstantPermission(ContentSettingsType type) { |
119 return type == CONTENT_SETTINGS_TYPE_MIDI; | 132 return (type == CONTENT_SETTINGS_TYPE_MIDI || |
| 133 type == CONTENT_SETTINGS_TYPE_ACCELEROMETER || |
| 134 type == CONTENT_SETTINGS_TYPE_GYROSCOPE); |
120 } | 135 } |
121 | 136 |
122 void SubscriptionCallbackWrapper( | 137 void SubscriptionCallbackWrapper( |
123 const base::Callback<void(PermissionStatus)>& callback, | 138 const base::Callback<void(PermissionStatus)>& callback, |
124 ContentSetting content_setting) { | 139 ContentSetting content_setting) { |
125 callback.Run(ContentSettingToPermissionStatus(content_setting)); | 140 callback.Run(ContentSettingToPermissionStatus(content_setting)); |
126 } | 141 } |
127 | 142 |
128 void PermissionStatusCallbackWrapper( | 143 void PermissionStatusCallbackWrapper( |
129 const base::Callback<void(PermissionStatus)>& callback, | 144 const base::Callback<void(PermissionStatus)>& callback, |
(...skipping 23 matching lines...) Expand all Loading... |
153 // value i.e. they are always approved or always denied etc. | 168 // value i.e. they are always approved or always denied etc. |
154 // CONTENT_SETTING_DEFAULT is returned if the permission needs further handling. | 169 // CONTENT_SETTING_DEFAULT is returned if the permission needs further handling. |
155 // This function should only be called when IsConstantPermission has returned | 170 // This function should only be called when IsConstantPermission has returned |
156 // true for the PermissionType. | 171 // true for the PermissionType. |
157 ContentSetting GetContentSettingForConstantPermission( | 172 ContentSetting GetContentSettingForConstantPermission( |
158 ContentSettingsType type) { | 173 ContentSettingsType type) { |
159 DCHECK(IsConstantPermission(type)); | 174 DCHECK(IsConstantPermission(type)); |
160 switch (type) { | 175 switch (type) { |
161 case CONTENT_SETTINGS_TYPE_MIDI: | 176 case CONTENT_SETTINGS_TYPE_MIDI: |
162 return CONTENT_SETTING_ALLOW; | 177 return CONTENT_SETTING_ALLOW; |
| 178 case CONTENT_SETTINGS_TYPE_AMBIENT_LIGHT_SENSOR: |
| 179 return CONTENT_SETTING_ALLOW; |
163 default: | 180 default: |
164 return CONTENT_SETTING_BLOCK; | 181 return CONTENT_SETTING_BLOCK; |
165 } | 182 } |
166 } | 183 } |
167 | 184 |
168 } // anonymous namespace | 185 } // anonymous namespace |
169 | 186 |
170 class PermissionManager::PendingRequest { | 187 class PermissionManager::PendingRequest { |
171 public: | 188 public: |
172 PendingRequest( | 189 PendingRequest( |
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
225 // static | 242 // static |
226 PermissionManager* PermissionManager::Get(Profile* profile) { | 243 PermissionManager* PermissionManager::Get(Profile* profile) { |
227 return PermissionManagerFactory::GetForProfile(profile); | 244 return PermissionManagerFactory::GetForProfile(profile); |
228 } | 245 } |
229 | 246 |
230 PermissionManager::PermissionManager(Profile* profile) | 247 PermissionManager::PermissionManager(Profile* profile) |
231 : profile_(profile), | 248 : profile_(profile), |
232 weak_ptr_factory_(this) { | 249 weak_ptr_factory_(this) { |
233 permission_contexts_[CONTENT_SETTINGS_TYPE_MIDI_SYSEX] = | 250 permission_contexts_[CONTENT_SETTINGS_TYPE_MIDI_SYSEX] = |
234 base::MakeUnique<MidiPermissionContext>(profile); | 251 base::MakeUnique<MidiPermissionContext>(profile); |
| 252 permission_contexts_[CONTENT_SETTINGS_TYPE_SENSORS] = |
| 253 base::MakeUnique<SensorPermissionContext>(profile); |
235 permission_contexts_[CONTENT_SETTINGS_TYPE_PUSH_MESSAGING] = | 254 permission_contexts_[CONTENT_SETTINGS_TYPE_PUSH_MESSAGING] = |
236 base::MakeUnique<NotificationPermissionContext>( | 255 base::MakeUnique<NotificationPermissionContext>( |
237 profile, CONTENT_SETTINGS_TYPE_PUSH_MESSAGING); | 256 profile, CONTENT_SETTINGS_TYPE_PUSH_MESSAGING); |
238 permission_contexts_[CONTENT_SETTINGS_TYPE_NOTIFICATIONS] = | 257 permission_contexts_[CONTENT_SETTINGS_TYPE_NOTIFICATIONS] = |
239 base::MakeUnique<NotificationPermissionContext>( | 258 base::MakeUnique<NotificationPermissionContext>( |
240 profile, CONTENT_SETTINGS_TYPE_NOTIFICATIONS); | 259 profile, CONTENT_SETTINGS_TYPE_NOTIFICATIONS); |
241 #if !defined(OS_ANDROID) | 260 #if !defined(OS_ANDROID) |
242 permission_contexts_[CONTENT_SETTINGS_TYPE_GEOLOCATION] = | 261 permission_contexts_[CONTENT_SETTINGS_TYPE_GEOLOCATION] = |
243 base::MakeUnique<GeolocationPermissionContext>(profile); | 262 base::MakeUnique<GeolocationPermissionContext>(profile); |
244 #else | 263 #else |
245 permission_contexts_[CONTENT_SETTINGS_TYPE_GEOLOCATION] = | 264 permission_contexts_[CONTENT_SETTINGS_TYPE_GEOLOCATION] = |
246 base::MakeUnique<GeolocationPermissionContextAndroid>(profile); | 265 base::MakeUnique<GeolocationPermissionContextAndroid>(profile); |
247 #endif | 266 #endif |
248 #if defined(OS_CHROMEOS) || defined(OS_ANDROID) | 267 #if defined(OS_CHROMEOS) || defined(OS_ANDROID) |
249 permission_contexts_[CONTENT_SETTINGS_TYPE_PROTECTED_MEDIA_IDENTIFIER] = | 268 permission_contexts_[CONTENT_SETTINGS_TYPE_PROTECTED_MEDIA_IDENTIFIER] = |
250 base::MakeUnique<ProtectedMediaIdentifierPermissionContext>(profile); | 269 base::MakeUnique<ProtectedMediaIdentifierPermissionContext>(profile); |
251 #endif | 270 #endif |
252 permission_contexts_[CONTENT_SETTINGS_TYPE_DURABLE_STORAGE] = | 271 permission_contexts_[CONTENT_SETTINGS_TYPE_DURABLE_STORAGE] = |
253 base::MakeUnique<DurableStoragePermissionContext>(profile); | 272 base::MakeUnique<DurableStoragePermissionContext>(profile); |
254 permission_contexts_[CONTENT_SETTINGS_TYPE_MEDIASTREAM_MIC] = | 273 permission_contexts_[CONTENT_SETTINGS_TYPE_MEDIASTREAM_MIC] = |
255 base::MakeUnique<MediaStreamDevicePermissionContext>( | 274 base::MakeUnique<MediaStreamDevicePermissionContext>( |
256 profile, CONTENT_SETTINGS_TYPE_MEDIASTREAM_MIC); | 275 profile, CONTENT_SETTINGS_TYPE_MEDIASTREAM_MIC); |
257 permission_contexts_[CONTENT_SETTINGS_TYPE_MEDIASTREAM_CAMERA] = | 276 permission_contexts_[CONTENT_SETTINGS_TYPE_MEDIASTREAM_CAMERA] = |
258 base::MakeUnique<MediaStreamDevicePermissionContext>( | 277 base::MakeUnique<MediaStreamDevicePermissionContext>( |
259 profile, CONTENT_SETTINGS_TYPE_MEDIASTREAM_CAMERA); | 278 profile, CONTENT_SETTINGS_TYPE_MEDIASTREAM_CAMERA); |
260 permission_contexts_[CONTENT_SETTINGS_TYPE_BACKGROUND_SYNC] = | 279 permission_contexts_[CONTENT_SETTINGS_TYPE_BACKGROUND_SYNC] = |
261 base::MakeUnique<BackgroundSyncPermissionContext>(profile); | 280 base::MakeUnique<BackgroundSyncPermissionContext>(profile); |
| 281 permission_contexts_[CONTENT_SETTINGS_TYPE_SENSORS] = |
| 282 base::MakeUnique<SensorPermissionContext>(profile); |
262 #if BUILDFLAG(ENABLE_PLUGINS) | 283 #if BUILDFLAG(ENABLE_PLUGINS) |
263 permission_contexts_[CONTENT_SETTINGS_TYPE_PLUGINS] = | 284 permission_contexts_[CONTENT_SETTINGS_TYPE_PLUGINS] = |
264 base::MakeUnique<FlashPermissionContext>(profile); | 285 base::MakeUnique<FlashPermissionContext>(profile); |
265 #endif | 286 #endif |
266 } | 287 } |
267 | 288 |
268 PermissionManager::~PermissionManager() { | 289 PermissionManager::~PermissionManager() { |
269 if (!subscriptions_.IsEmpty()) | 290 if (!subscriptions_.IsEmpty()) |
270 HostContentSettingsMapFactory::GetForProfile(profile_) | 291 HostContentSettingsMapFactory::GetForProfile(profile_) |
271 ->RemoveObserver(this); | 292 ->RemoveObserver(this); |
(...skipping 276 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
548 } | 569 } |
549 PermissionContextBase* context = GetPermissionContext(permission); | 570 PermissionContextBase* context = GetPermissionContext(permission); |
550 PermissionResult result = context->GetPermissionStatus( | 571 PermissionResult result = context->GetPermissionStatus( |
551 nullptr /* render_frame_host */, requesting_origin.GetOrigin(), | 572 nullptr /* render_frame_host */, requesting_origin.GetOrigin(), |
552 embedding_origin.GetOrigin()); | 573 embedding_origin.GetOrigin()); |
553 DCHECK(result.content_setting == CONTENT_SETTING_ALLOW || | 574 DCHECK(result.content_setting == CONTENT_SETTING_ALLOW || |
554 result.content_setting == CONTENT_SETTING_ASK || | 575 result.content_setting == CONTENT_SETTING_ASK || |
555 result.content_setting == CONTENT_SETTING_BLOCK); | 576 result.content_setting == CONTENT_SETTING_BLOCK); |
556 return result; | 577 return result; |
557 } | 578 } |
OLD | NEW |