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 <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include "base/callback.h" | 9 #include "base/callback.h" |
10 #include "build/build_config.h" | 10 #include "build/build_config.h" |
11 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" | 11 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" |
12 #include "chrome/browser/permissions/permission_context.h" | 12 #include "chrome/browser/permissions/permission_context.h" |
13 #include "chrome/browser/permissions/permission_context_base.h" | 13 #include "chrome/browser/permissions/permission_context_base.h" |
14 #include "chrome/browser/permissions/permission_request_id.h" | 14 #include "chrome/browser/permissions/permission_request_id.h" |
| 15 #include "chrome/browser/permissions/permission_uma_util.h" |
| 16 #include "chrome/browser/permissions/permission_util.h" |
15 #include "chrome/browser/profiles/profile.h" | 17 #include "chrome/browser/profiles/profile.h" |
16 #include "chrome/browser/tab_contents/tab_util.h" | 18 #include "chrome/browser/tab_contents/tab_util.h" |
17 #include "components/content_settings/core/browser/host_content_settings_map.h" | 19 #include "components/content_settings/core/browser/host_content_settings_map.h" |
18 #include "content/public/browser/permission_type.h" | 20 #include "content/public/browser/permission_type.h" |
19 #include "content/public/browser/render_frame_host.h" | 21 #include "content/public/browser/render_frame_host.h" |
20 #include "content/public/browser/render_process_host.h" | 22 #include "content/public/browser/render_process_host.h" |
21 #include "content/public/browser/web_contents.h" | 23 #include "content/public/browser/web_contents.h" |
22 | 24 |
23 #if !defined(OS_ANDROID) | 25 #if !defined(OS_ANDROID) |
24 #include "chrome/browser/ui/website_settings/permission_bubble_manager.h" | 26 #include "chrome/browser/ui/website_settings/permission_bubble_manager.h" |
(...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
191 PermissionType permission; | 193 PermissionType permission; |
192 GURL requesting_origin; | 194 GURL requesting_origin; |
193 GURL embedding_origin; | 195 GURL embedding_origin; |
194 base::Callback<void(PermissionStatus)> callback; | 196 base::Callback<void(PermissionStatus)> callback; |
195 ContentSetting current_value; | 197 ContentSetting current_value; |
196 }; | 198 }; |
197 | 199 |
198 PermissionManager::PermissionManager(Profile* profile) | 200 PermissionManager::PermissionManager(Profile* profile) |
199 : profile_(profile), | 201 : profile_(profile), |
200 weak_ptr_factory_(this) { | 202 weak_ptr_factory_(this) { |
| 203 HostContentSettingsMapFactory::GetForProfile(profile_)->AddObserver(this); |
201 } | 204 } |
202 | 205 |
203 PermissionManager::~PermissionManager() { | 206 PermissionManager::~PermissionManager() { |
204 if (!subscriptions_.IsEmpty()) | 207 HostContentSettingsMapFactory::GetForProfile(profile_)->RemoveObserver(this); |
205 HostContentSettingsMapFactory::GetForProfile(profile_) | |
206 ->RemoveObserver(this); | |
207 } | 208 } |
208 | 209 |
209 int PermissionManager::RequestPermission( | 210 int PermissionManager::RequestPermission( |
210 PermissionType permission, | 211 PermissionType permission, |
211 content::RenderFrameHost* render_frame_host, | 212 content::RenderFrameHost* render_frame_host, |
212 const GURL& requesting_origin, | 213 const GURL& requesting_origin, |
213 const base::Callback<void(PermissionStatus)>& callback) { | 214 const base::Callback<void(PermissionStatus)>& callback) { |
214 return RequestPermissions( | 215 return RequestPermissions( |
215 std::vector<PermissionType>(1, permission), | 216 std::vector<PermissionType>(1, permission), |
216 render_frame_host, | 217 render_frame_host, |
(...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
344 requesting_origin, | 345 requesting_origin, |
345 embedding_origin, | 346 embedding_origin, |
346 PermissionTypeToContentSetting(permission)); | 347 PermissionTypeToContentSetting(permission)); |
347 } | 348 } |
348 | 349 |
349 int PermissionManager::SubscribePermissionStatusChange( | 350 int PermissionManager::SubscribePermissionStatusChange( |
350 PermissionType permission, | 351 PermissionType permission, |
351 const GURL& requesting_origin, | 352 const GURL& requesting_origin, |
352 const GURL& embedding_origin, | 353 const GURL& embedding_origin, |
353 const base::Callback<void(PermissionStatus)>& callback) { | 354 const base::Callback<void(PermissionStatus)>& callback) { |
354 if (subscriptions_.IsEmpty()) | |
355 HostContentSettingsMapFactory::GetForProfile(profile_)->AddObserver(this); | |
356 | 355 |
357 Subscription* subscription = new Subscription(); | 356 Subscription* subscription = new Subscription(); |
358 subscription->permission = permission; | 357 subscription->permission = permission; |
359 subscription->requesting_origin = requesting_origin; | 358 subscription->requesting_origin = requesting_origin; |
360 subscription->embedding_origin = embedding_origin; | 359 subscription->embedding_origin = embedding_origin; |
361 subscription->callback = callback; | 360 subscription->callback = callback; |
362 | 361 |
363 if (IsConstantPermission(permission)) { | 362 if (IsConstantPermission(permission)) { |
364 subscription->current_value = GetContentSettingForConstantPermission( | 363 subscription->current_value = GetContentSettingForConstantPermission( |
365 permission); | 364 permission); |
366 } else { | 365 } else { |
367 subscription->current_value = PermissionContext::Get(profile_, permission) | 366 subscription->current_value = PermissionContext::Get(profile_, permission) |
368 ->GetPermissionStatus(subscription->requesting_origin, | 367 ->GetPermissionStatus(subscription->requesting_origin, |
369 subscription->embedding_origin); | 368 subscription->embedding_origin); |
370 } | 369 } |
371 | 370 |
372 return subscriptions_.Add(subscription); | 371 return subscriptions_.Add(subscription); |
373 } | 372 } |
374 | 373 |
375 void PermissionManager::UnsubscribePermissionStatusChange(int subscription_id) { | 374 void PermissionManager::UnsubscribePermissionStatusChange(int subscription_id) { |
376 // Whether |subscription_id| is known will be checked by the Remove() call. | 375 // Whether |subscription_id| is known will be checked by the Remove() call. |
377 subscriptions_.Remove(subscription_id); | 376 subscriptions_.Remove(subscription_id); |
378 | |
379 if (subscriptions_.IsEmpty()) | |
380 HostContentSettingsMapFactory::GetForProfile(profile_) | |
381 ->RemoveObserver(this); | |
382 } | 377 } |
383 | 378 |
384 bool PermissionManager::IsPermissionBubbleManagerMissing( | 379 bool PermissionManager::IsPermissionBubbleManagerMissing( |
385 content::WebContents* web_contents) { | 380 content::WebContents* web_contents) { |
386 // TODO(felt): Remove this method entirely. Leaving it to make a minimal | 381 // TODO(felt): Remove this method entirely. Leaving it to make a minimal |
387 // last-minute merge to 46. See crbug.com/457091 and crbug.com/534631. | 382 // last-minute merge to 46. See crbug.com/457091 and crbug.com/534631. |
388 return false; | 383 return false; |
389 } | 384 } |
390 | 385 |
391 void PermissionManager::OnContentSettingChanged( | 386 void PermissionManager::OnContentSettingChanged( |
(...skipping 30 matching lines...) Expand all Loading... |
422 // Add the callback to |callbacks| which will be run after the loop to | 417 // Add the callback to |callbacks| which will be run after the loop to |
423 // prevent re-entrance issues. | 418 // prevent re-entrance issues. |
424 callbacks.push_back( | 419 callbacks.push_back( |
425 base::Bind(subscription->callback, | 420 base::Bind(subscription->callback, |
426 ContentSettingToPermissionStatus(new_value))); | 421 ContentSettingToPermissionStatus(new_value))); |
427 } | 422 } |
428 | 423 |
429 for (const auto& callback : callbacks) | 424 for (const auto& callback : callbacks) |
430 callback.Run(); | 425 callback.Run(); |
431 } | 426 } |
| 427 |
| 428 void PermissionManager::OnContentSettingRevoked( |
| 429 const GURL& primary_url, |
| 430 const GURL& secondary_url, |
| 431 ContentSettingsType content_type, |
| 432 std::string resource_identifier) { |
| 433 PermissionType permission_type; |
| 434 if (PermissionUtil::GetPermissionType(content_type, &permission_type)) |
| 435 PermissionUmaUtil::PermissionRevoked(permission_type, primary_url); |
| 436 } |
OLD | NEW |