OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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_decision_auto_blocker.h" | 5 #include "chrome/browser/permissions/permission_decision_auto_blocker.h" |
6 | 6 |
| 7 #include <string.h> |
| 8 |
7 #include <memory> | 9 #include <memory> |
8 | 10 |
9 #include "base/feature_list.h" | 11 #include "base/feature_list.h" |
10 #include "base/logging.h" | 12 #include "base/logging.h" |
11 #include "base/memory/ptr_util.h" | 13 #include "base/memory/ptr_util.h" |
12 #include "base/strings/string_number_conversions.h" | 14 #include "base/strings/string_number_conversions.h" |
13 #include "base/values.h" | 15 #include "base/values.h" |
14 #include "chrome/browser/browser_process.h" | 16 #include "chrome/browser/browser_process.h" |
15 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" | 17 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" |
16 #include "chrome/browser/permissions/permission_blacklist_client.h" | 18 #include "chrome/browser/permissions/permission_blacklist_client.h" |
| 19 #include "chrome/browser/permissions/permission_uma_util.h" |
17 #include "chrome/browser/permissions/permission_util.h" | 20 #include "chrome/browser/permissions/permission_util.h" |
18 #include "chrome/browser/profiles/incognito_helpers.h" | 21 #include "chrome/browser/profiles/incognito_helpers.h" |
19 #include "chrome/browser/profiles/profile.h" | 22 #include "chrome/browser/profiles/profile.h" |
20 #include "chrome/browser/safe_browsing/safe_browsing_service.h" | 23 #include "chrome/browser/safe_browsing/safe_browsing_service.h" |
21 #include "chrome/common/chrome_features.h" | 24 #include "chrome/common/chrome_features.h" |
22 #include "components/content_settings/core/browser/host_content_settings_map.h" | 25 #include "components/content_settings/core/browser/host_content_settings_map.h" |
23 #include "components/keyed_service/content/browser_context_dependency_manager.h" | 26 #include "components/keyed_service/content/browser_context_dependency_manager.h" |
24 #include "components/safe_browsing_db/database_manager.h" | 27 #include "components/safe_browsing_db/database_manager.h" |
25 #include "components/variations/variations_associated_data.h" | 28 #include "components/variations/variations_associated_data.h" |
26 #include "content/public/browser/permission_type.h" | 29 #include "content/public/browser/permission_type.h" |
(...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
106 HostContentSettingsMapFactory::GetForProfile(profile); | 109 HostContentSettingsMapFactory::GetForProfile(profile); |
107 std::unique_ptr<base::DictionaryValue> dict = GetOriginDict(map, url); | 110 std::unique_ptr<base::DictionaryValue> dict = GetOriginDict(map, url); |
108 base::DictionaryValue* permission_dict = GetOrCreatePermissionDict( | 111 base::DictionaryValue* permission_dict = GetOrCreatePermissionDict( |
109 dict.get(), PermissionUtil::GetPermissionString(permission)); | 112 dict.get(), PermissionUtil::GetPermissionString(permission)); |
110 | 113 |
111 int current_count = 0; | 114 int current_count = 0; |
112 permission_dict->GetInteger(key, ¤t_count); | 115 permission_dict->GetInteger(key, ¤t_count); |
113 return current_count; | 116 return current_count; |
114 } | 117 } |
115 | 118 |
| 119 // Returns true if |url| has been embargoed from requesting |permission| for the |
| 120 // reason corresponding to |key|. |
| 121 bool WasPreviouslyEmbargoed(Profile* profile, |
| 122 const GURL& url, |
| 123 content::PermissionType permission, |
| 124 const char* key) { |
| 125 HostContentSettingsMap* map = |
| 126 HostContentSettingsMapFactory::GetForProfile(profile); |
| 127 std::unique_ptr<base::DictionaryValue> dict = GetOriginDict(map, url); |
| 128 base::DictionaryValue* permission_dict = GetOrCreatePermissionDict( |
| 129 dict.get(), PermissionUtil::GetPermissionString(permission)); |
| 130 return permission_dict->HasKey(key); |
| 131 } |
| 132 |
116 } // namespace | 133 } // namespace |
117 | 134 |
118 // PermissionDecisionAutoBlocker::Factory -------------------------------------- | 135 // PermissionDecisionAutoBlocker::Factory -------------------------------------- |
119 | 136 |
120 // static | 137 // static |
121 PermissionDecisionAutoBlocker* | 138 PermissionDecisionAutoBlocker* |
122 PermissionDecisionAutoBlocker::Factory::GetForProfile(Profile* profile) { | 139 PermissionDecisionAutoBlocker::Factory::GetForProfile(Profile* profile) { |
123 return static_cast<PermissionDecisionAutoBlocker*>( | 140 return static_cast<PermissionDecisionAutoBlocker*>( |
124 GetInstance()->GetServiceForBrowserContext(profile, true)); | 141 GetInstance()->GetServiceForBrowserContext(profile, true)); |
125 } | 142 } |
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
220 } | 237 } |
221 | 238 |
222 bool PermissionDecisionAutoBlocker::RecordDismissAndEmbargo( | 239 bool PermissionDecisionAutoBlocker::RecordDismissAndEmbargo( |
223 const GURL& url, | 240 const GURL& url, |
224 content::PermissionType permission) { | 241 content::PermissionType permission) { |
225 int current_dismissal_count = RecordActionInWebsiteSettings( | 242 int current_dismissal_count = RecordActionInWebsiteSettings( |
226 url, permission, kPromptDismissCountKey, profile_); | 243 url, permission, kPromptDismissCountKey, profile_); |
227 | 244 |
228 if (base::FeatureList::IsEnabled(features::kBlockPromptsIfDismissedOften) && | 245 if (base::FeatureList::IsEnabled(features::kBlockPromptsIfDismissedOften) && |
229 current_dismissal_count >= g_prompt_dismissals_before_block) { | 246 current_dismissal_count >= g_prompt_dismissals_before_block) { |
| 247 if (WasPreviouslyEmbargoed(profile_, url, permission, |
| 248 kPermissionDismissalEmbargoKey)) { |
| 249 PermissionUmaUtil::RecordRepeatedEmbargo( |
| 250 PermissionEmbargoReason::REPEATED_DISMISSALS); |
| 251 } |
| 252 |
230 PlaceUnderEmbargo(permission, url, kPermissionDismissalEmbargoKey); | 253 PlaceUnderEmbargo(permission, url, kPermissionDismissalEmbargoKey); |
231 return true; | 254 return true; |
232 } | 255 } |
233 return false; | 256 return false; |
234 } | 257 } |
235 | 258 |
236 int PermissionDecisionAutoBlocker::RecordIgnore( | 259 int PermissionDecisionAutoBlocker::RecordIgnore( |
237 const GURL& url, | 260 const GURL& url, |
238 content::PermissionType permission) { | 261 content::PermissionType permission) { |
239 return RecordActionInWebsiteSettings(url, permission, kPromptIgnoreCountKey, | 262 return RecordActionInWebsiteSettings(url, permission, kPromptIgnoreCountKey, |
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
334 return is_under_dismiss_embargo || is_under_blacklist_embargo; | 357 return is_under_dismiss_embargo || is_under_blacklist_embargo; |
335 } | 358 } |
336 | 359 |
337 // static | 360 // static |
338 void PermissionDecisionAutoBlocker::CheckSafeBrowsingResult( | 361 void PermissionDecisionAutoBlocker::CheckSafeBrowsingResult( |
339 content::PermissionType permission, | 362 content::PermissionType permission, |
340 const GURL& request_origin, | 363 const GURL& request_origin, |
341 base::Callback<void(bool)> callback, | 364 base::Callback<void(bool)> callback, |
342 bool should_be_embargoed) { | 365 bool should_be_embargoed) { |
343 if (should_be_embargoed) { | 366 if (should_be_embargoed) { |
344 // Requesting site is blacklisted for this permission, update the content | 367 if (WasPreviouslyEmbargoed(profile_, request_origin, permission, |
345 // setting to place it under embargo. | 368 kPermissionBlacklistEmbargoKey)) { |
| 369 PermissionUmaUtil::RecordRepeatedEmbargo( |
| 370 PermissionEmbargoReason::PERMISSIONS_BLACKLISTING); |
| 371 } |
| 372 |
346 PlaceUnderEmbargo(permission, request_origin, | 373 PlaceUnderEmbargo(permission, request_origin, |
347 kPermissionBlacklistEmbargoKey); | 374 kPermissionBlacklistEmbargoKey); |
348 } | 375 } |
349 callback.Run(should_be_embargoed /* permission blocked */); | 376 |
| 377 callback.Run(should_be_embargoed); |
350 } | 378 } |
351 | 379 |
352 // static | 380 // static |
353 void PermissionDecisionAutoBlocker::PlaceUnderEmbargo( | 381 void PermissionDecisionAutoBlocker::PlaceUnderEmbargo( |
354 content::PermissionType permission, | 382 content::PermissionType permission, |
355 const GURL& request_origin, | 383 const GURL& request_origin, |
356 const char* key) { | 384 const char* key) { |
357 HostContentSettingsMap* map = | 385 HostContentSettingsMap* map = |
358 HostContentSettingsMapFactory::GetForProfile(profile_); | 386 HostContentSettingsMapFactory::GetForProfile(profile_); |
359 std::unique_ptr<base::DictionaryValue> dict = | 387 std::unique_ptr<base::DictionaryValue> dict = |
360 GetOriginDict(map, request_origin); | 388 GetOriginDict(map, request_origin); |
361 base::DictionaryValue* permission_dict = GetOrCreatePermissionDict( | 389 base::DictionaryValue* permission_dict = GetOrCreatePermissionDict( |
362 dict.get(), PermissionUtil::GetPermissionString(permission)); | 390 dict.get(), PermissionUtil::GetPermissionString(permission)); |
363 permission_dict->SetDouble(key, clock_->Now().ToInternalValue()); | 391 permission_dict->SetDouble(key, clock_->Now().ToInternalValue()); |
364 map->SetWebsiteSettingDefaultScope( | 392 map->SetWebsiteSettingDefaultScope( |
365 request_origin, GURL(), CONTENT_SETTINGS_TYPE_PROMPT_NO_DECISION_COUNT, | 393 request_origin, GURL(), CONTENT_SETTINGS_TYPE_PROMPT_NO_DECISION_COUNT, |
366 std::string(), std::move(dict)); | 394 std::string(), std::move(dict)); |
| 395 PermissionEmbargoReason embargo_reason = |
| 396 PermissionEmbargoReason::PERMISSIONS_BLACKLISTING; |
| 397 if (std::strcmp(key, kPermissionDismissalEmbargoKey) == 0) |
| 398 embargo_reason = PermissionEmbargoReason::REPEATED_DISMISSALS; |
| 399 PermissionUmaUtil::RecordPermissionEmbargoReason(embargo_reason); |
367 } | 400 } |
368 | 401 |
369 void PermissionDecisionAutoBlocker:: | 402 void PermissionDecisionAutoBlocker:: |
370 SetSafeBrowsingDatabaseManagerAndTimeoutForTesting( | 403 SetSafeBrowsingDatabaseManagerAndTimeoutForTesting( |
371 scoped_refptr<safe_browsing::SafeBrowsingDatabaseManager> db_manager, | 404 scoped_refptr<safe_browsing::SafeBrowsingDatabaseManager> db_manager, |
372 int timeout) { | 405 int timeout) { |
373 db_manager_ = db_manager; | 406 db_manager_ = db_manager; |
374 safe_browsing_timeout_ = timeout; | 407 safe_browsing_timeout_ = timeout; |
375 } | 408 } |
376 | 409 |
377 void PermissionDecisionAutoBlocker::SetClockForTesting( | 410 void PermissionDecisionAutoBlocker::SetClockForTesting( |
378 std::unique_ptr<base::Clock> clock) { | 411 std::unique_ptr<base::Clock> clock) { |
379 clock_ = std::move(clock); | 412 clock_ = std::move(clock); |
380 } | 413 } |
OLD | NEW |