Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1140)

Side by Side Diff: chrome/browser/permissions/permission_decision_auto_blocker.cc

Issue 2250993002: Add prior dismissal and ignore count metrics for all permission actions. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@kendra-permission-action-reporting
Patch Set: Comments Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/logging.h" 10 #include "base/logging.h"
11 #include "base/memory/ptr_util.h" 11 #include "base/memory/ptr_util.h"
12 #include "base/strings/string_number_conversions.h" 12 #include "base/strings/string_number_conversions.h"
13 #include "base/values.h" 13 #include "base/values.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/permissions/permission_uma_util.h"
16 #include "chrome/browser/permissions/permission_util.h" 15 #include "chrome/browser/permissions/permission_util.h"
17 #include "chrome/common/chrome_features.h" 16 #include "chrome/common/chrome_features.h"
18 #include "components/content_settings/core/browser/host_content_settings_map.h" 17 #include "components/content_settings/core/browser/host_content_settings_map.h"
19 #include "components/variations/variations_associated_data.h" 18 #include "components/variations/variations_associated_data.h"
20 #include "content/public/browser/permission_type.h" 19 #include "content/public/browser/permission_type.h"
21 #include "url/gurl.h" 20 #include "url/gurl.h"
22 21
23 namespace { 22 namespace {
24 23
25 // The default number of times that users may explicitly dismiss a permission 24 // The default number of times that users may explicitly dismiss a permission
(...skipping 21 matching lines...) Expand all
47 if (!origin_dict->GetDictionaryWithoutPathExpansion(permission, 46 if (!origin_dict->GetDictionaryWithoutPathExpansion(permission,
48 &permission_dict)) { 47 &permission_dict)) {
49 permission_dict = new base::DictionaryValue(); 48 permission_dict = new base::DictionaryValue();
50 origin_dict->SetWithoutPathExpansion(permission, 49 origin_dict->SetWithoutPathExpansion(permission,
51 base::WrapUnique(permission_dict)); 50 base::WrapUnique(permission_dict));
52 } 51 }
53 52
54 return permission_dict; 53 return permission_dict;
55 } 54 }
56 55
56 int RecordActionInWebsiteSettings(const GURL& url,
57 content::PermissionType permission,
58 const char* key,
59 Profile* profile) {
60 HostContentSettingsMap* map =
61 HostContentSettingsMapFactory::GetForProfile(profile);
62 std::unique_ptr<base::DictionaryValue> dict = GetOriginDict(map, url);
63
64 base::DictionaryValue* permission_dict = GetOrCreatePermissionDict(
65 dict.get(), PermissionUtil::GetPermissionString(permission));
66
67 int current_count = 0;
68 permission_dict->GetInteger(key, &current_count);
69 permission_dict->SetInteger(key, ++current_count);
70
71 map->SetWebsiteSettingDefaultScope(
72 url, GURL(), CONTENT_SETTINGS_TYPE_PROMPT_NO_DECISION_COUNT,
73 std::string(), std::move(dict));
74
75 return current_count;
76 }
77
78 int GetActionCount(const GURL& url,
79 content::PermissionType permission,
80 const char* key,
81 Profile* profile) {
82 HostContentSettingsMap* map =
83 HostContentSettingsMapFactory::GetForProfile(profile);
84 std::unique_ptr<base::DictionaryValue> dict = GetOriginDict(map, url);
85
86 base::DictionaryValue* permission_dict = GetOrCreatePermissionDict(
87 dict.get(), PermissionUtil::GetPermissionString(permission));
88
89 int current_count = 0;
90 permission_dict->GetInteger(key, &current_count);
91 return current_count;
92 }
93
57 } // namespace 94 } // namespace
58 95
59 // static 96 // static
60 const char PermissionDecisionAutoBlocker::kPromptDismissCountKey[] = 97 const char PermissionDecisionAutoBlocker::kPromptDismissCountKey[] =
61 "dismiss_count"; 98 "dismiss_count";
62 99
63 // static 100 // static
64 const char PermissionDecisionAutoBlocker::kPromptIgnoreCountKey[] = 101 const char PermissionDecisionAutoBlocker::kPromptIgnoreCountKey[] =
65 "ignore_count"; 102 "ignore_count";
66 103
(...skipping 14 matching lines...) Expand all
81 118
82 if (origin.is_valid() && filter.Run(origin)) { 119 if (origin.is_valid() && filter.Run(origin)) {
83 map->SetWebsiteSettingDefaultScope( 120 map->SetWebsiteSettingDefaultScope(
84 origin, GURL(), CONTENT_SETTINGS_TYPE_PROMPT_NO_DECISION_COUNT, 121 origin, GURL(), CONTENT_SETTINGS_TYPE_PROMPT_NO_DECISION_COUNT,
85 std::string(), nullptr); 122 std::string(), nullptr);
86 } 123 }
87 } 124 }
88 } 125 }
89 126
90 // static 127 // static
91 int PermissionDecisionAutoBlocker::GetDismissCount(const GURL& url, 128 int PermissionDecisionAutoBlocker::GetDismissCount(
92 content::PermissionType permission, Profile* profile) { 129 const GURL& url,
130 content::PermissionType permission,
131 Profile* profile) {
93 return GetActionCount(url, permission, kPromptDismissCountKey, profile); 132 return GetActionCount(url, permission, kPromptDismissCountKey, profile);
94 } 133 }
95 134
96 // static 135 // static
97 int PermissionDecisionAutoBlocker::GetIgnoreCount(const GURL& url, 136 int PermissionDecisionAutoBlocker::GetIgnoreCount(
98 content::PermissionType permission, Profile* profile) { 137 const GURL& url,
138 content::PermissionType permission,
139 Profile* profile) {
99 return GetActionCount(url, permission, kPromptIgnoreCountKey, profile); 140 return GetActionCount(url, permission, kPromptIgnoreCountKey, profile);
100 } 141 }
101 142
102 // static
103 int PermissionDecisionAutoBlocker::GetActionCount(
104 const GURL& url,
105 content::PermissionType permission,
106 const char* key,
107 Profile* profile) {
108 HostContentSettingsMap* map =
109 HostContentSettingsMapFactory::GetForProfile(profile);
110 std::unique_ptr<base::DictionaryValue> dict = GetOriginDict(map, url);
111
112 base::DictionaryValue* permission_dict = GetOrCreatePermissionDict(
113 dict.get(), PermissionUtil::GetPermissionString(permission));
114
115 int current_count = 0;
116 permission_dict->GetInteger(key, &current_count);
117 return current_count;
118 }
119
120 PermissionDecisionAutoBlocker::PermissionDecisionAutoBlocker(Profile* profile) 143 PermissionDecisionAutoBlocker::PermissionDecisionAutoBlocker(Profile* profile)
121 : profile_(profile), 144 : profile_(profile),
122 prompt_dismissals_before_block_(kPromptDismissalsBeforeBlock) { 145 prompt_dismissals_before_block_(kPromptDismissalsBeforeBlock) {
123 UpdateFromVariations(); 146 UpdateFromVariations();
124 } 147 }
125 148
126 int PermissionDecisionAutoBlocker::RecordIgnore( 149 int PermissionDecisionAutoBlocker::RecordIgnore(
127 const GURL& url, 150 const GURL& url,
128 content::PermissionType permission) { 151 content::PermissionType permission) {
129 int current_ignore_count = 152 return RecordActionInWebsiteSettings(url, permission, kPromptIgnoreCountKey,
130 RecordActionInWebsiteSettings(url, permission, kPromptIgnoreCountKey); 153 profile_);
131
132 PermissionUmaUtil::PermissionPromptIgnored(permission, current_ignore_count);
133
134 return current_ignore_count;
135 } 154 }
136 155
137 bool PermissionDecisionAutoBlocker::ShouldChangeDismissalToBlock( 156 bool PermissionDecisionAutoBlocker::ShouldChangeDismissalToBlock(
138 const GURL& url, 157 const GURL& url,
139 content::PermissionType permission) { 158 content::PermissionType permission) {
140 int current_dismissal_count = 159 int current_dismissal_count = RecordActionInWebsiteSettings(
141 RecordActionInWebsiteSettings(url, permission, kPromptDismissCountKey); 160 url, permission, kPromptDismissCountKey, profile_);
142
143 PermissionUmaUtil::PermissionPromptDismissed(permission,
144 current_dismissal_count);
145 161
146 if (!base::FeatureList::IsEnabled(features::kBlockPromptsIfDismissedOften)) 162 if (!base::FeatureList::IsEnabled(features::kBlockPromptsIfDismissedOften))
147 return false; 163 return false;
148 164
149 return current_dismissal_count >= prompt_dismissals_before_block_; 165 return current_dismissal_count >= prompt_dismissals_before_block_;
150 } 166 }
151 167
152 int PermissionDecisionAutoBlocker::RecordActionInWebsiteSettings(
153 const GURL& url,
154 content::PermissionType permission,
155 const char* key) {
156 HostContentSettingsMap* map =
157 HostContentSettingsMapFactory::GetForProfile(profile_);
158 std::unique_ptr<base::DictionaryValue> dict = GetOriginDict(map, url);
159
160 base::DictionaryValue* permission_dict = GetOrCreatePermissionDict(
161 dict.get(), PermissionUtil::GetPermissionString(permission));
162
163 int current_count = 0;
164 permission_dict->GetInteger(key, &current_count);
165 permission_dict->SetInteger(key, ++current_count);
166
167 map->SetWebsiteSettingDefaultScope(
168 url, GURL(), CONTENT_SETTINGS_TYPE_PROMPT_NO_DECISION_COUNT,
169 std::string(), std::move(dict));
170
171 return current_count;
172 }
173
174 void PermissionDecisionAutoBlocker::UpdateFromVariations() { 168 void PermissionDecisionAutoBlocker::UpdateFromVariations() {
175 int prompt_dismissals = -1; 169 int prompt_dismissals = -1;
176 std::string value = variations::GetVariationParamValueByFeature( 170 std::string value = variations::GetVariationParamValueByFeature(
177 features::kBlockPromptsIfDismissedOften, kPromptDismissCountKey); 171 features::kBlockPromptsIfDismissedOften, kPromptDismissCountKey);
178 172
179 // If converting the value fails, stick with the default value. 173 // If converting the value fails, stick with the default value.
180 if (base::StringToInt(value, &prompt_dismissals) && prompt_dismissals > 0) 174 if (base::StringToInt(value, &prompt_dismissals) && prompt_dismissals > 0)
181 prompt_dismissals_before_block_ = prompt_dismissals; 175 prompt_dismissals_before_block_ = prompt_dismissals;
182 } 176 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698