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 <memory> | 7 #include <memory> |
8 | 8 |
9 #include "base/feature_list.h" | 9 #include "base/feature_list.h" |
10 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
(...skipping 286 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
297 return false; | 297 return false; |
298 } | 298 } |
299 | 299 |
300 int PermissionDecisionAutoBlocker::RecordIgnore( | 300 int PermissionDecisionAutoBlocker::RecordIgnore( |
301 const GURL& url, | 301 const GURL& url, |
302 ContentSettingsType permission) { | 302 ContentSettingsType permission) { |
303 return RecordActionInWebsiteSettings(url, permission, kPromptIgnoreCountKey, | 303 return RecordActionInWebsiteSettings(url, permission, kPromptIgnoreCountKey, |
304 profile_); | 304 profile_); |
305 } | 305 } |
306 | 306 |
| 307 void PermissionDecisionAutoBlocker::RemoveEmbargoByUrl( |
| 308 const GURL& url, |
| 309 ContentSettingsType permission) { |
| 310 if (!PermissionUtil::IsPermission(permission)) |
| 311 return; |
| 312 |
| 313 // Don't proceed if |permission| was not under embargo for |url|. |
| 314 PermissionResult result = GetEmbargoResult(url, permission); |
| 315 if (result.source != PermissionStatusSource::MULTIPLE_DISMISSALS && |
| 316 result.source != PermissionStatusSource::SAFE_BROWSING_BLACKLIST) { |
| 317 return; |
| 318 } |
| 319 |
| 320 HostContentSettingsMap* map = |
| 321 HostContentSettingsMapFactory::GetForProfile(profile_); |
| 322 std::unique_ptr<base::DictionaryValue> dict = GetOriginDict(map, url); |
| 323 base::DictionaryValue* permission_dict = GetOrCreatePermissionDict( |
| 324 dict.get(), PermissionUtil::GetPermissionString(permission)); |
| 325 |
| 326 // Deleting non-existent entries will return a false value. Since it should be |
| 327 // impossible for a permission to have been embargoed for two different |
| 328 // reasons at the same time, check that exactly one deletion was successful. |
| 329 const bool dismissal_key_deleted = |
| 330 permission_dict->RemoveWithoutPathExpansion( |
| 331 kPermissionDismissalEmbargoKey, nullptr); |
| 332 const bool blacklist_key_deleted = |
| 333 permission_dict->RemoveWithoutPathExpansion( |
| 334 kPermissionBlacklistEmbargoKey, nullptr); |
| 335 DCHECK(dismissal_key_deleted != blacklist_key_deleted); |
| 336 |
| 337 map->SetWebsiteSettingDefaultScope( |
| 338 url, GURL(), CONTENT_SETTINGS_TYPE_PERMISSION_AUTOBLOCKER_DATA, |
| 339 std::string(), std::move(dict)); |
| 340 } |
| 341 |
307 void PermissionDecisionAutoBlocker::RemoveCountsByUrl( | 342 void PermissionDecisionAutoBlocker::RemoveCountsByUrl( |
308 base::Callback<bool(const GURL& url)> filter) { | 343 base::Callback<bool(const GURL& url)> filter) { |
309 HostContentSettingsMap* map = | 344 HostContentSettingsMap* map = |
310 HostContentSettingsMapFactory::GetForProfile(profile_); | 345 HostContentSettingsMapFactory::GetForProfile(profile_); |
311 | 346 |
312 std::unique_ptr<ContentSettingsForOneType> settings( | 347 std::unique_ptr<ContentSettingsForOneType> settings( |
313 new ContentSettingsForOneType); | 348 new ContentSettingsForOneType); |
314 map->GetSettingsForOneType(CONTENT_SETTINGS_TYPE_PERMISSION_AUTOBLOCKER_DATA, | 349 map->GetSettingsForOneType(CONTENT_SETTINGS_TYPE_PERMISSION_AUTOBLOCKER_DATA, |
315 std::string(), settings.get()); | 350 std::string(), settings.get()); |
316 | 351 |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
373 scoped_refptr<safe_browsing::SafeBrowsingDatabaseManager> db_manager, | 408 scoped_refptr<safe_browsing::SafeBrowsingDatabaseManager> db_manager, |
374 int timeout) { | 409 int timeout) { |
375 db_manager_ = db_manager; | 410 db_manager_ = db_manager; |
376 safe_browsing_timeout_ = timeout; | 411 safe_browsing_timeout_ = timeout; |
377 } | 412 } |
378 | 413 |
379 void PermissionDecisionAutoBlocker::SetClockForTesting( | 414 void PermissionDecisionAutoBlocker::SetClockForTesting( |
380 std::unique_ptr<base::Clock> clock) { | 415 std::unique_ptr<base::Clock> clock) { |
381 clock_ = std::move(clock); | 416 clock_ = std::move(clock); |
382 } | 417 } |
OLD | NEW |