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

Side by Side Diff: chrome/browser/content_settings/permission_context_uma_util.cc

Issue 1197853005: Collecting statistics on iframe permissions use. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixed naming and style. Created 5 years, 5 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "base/metrics/histogram_macros.h" 5 #include "base/metrics/histogram_macros.h"
6 #include "base/strings/stringprintf.h" 6 #include "base/strings/stringprintf.h"
7 #include "chrome/browser/browser_process.h" 7 #include "chrome/browser/browser_process.h"
8 #include "chrome/browser/content_settings/permission_context_uma_util.h" 8 #include "chrome/browser/content_settings/permission_context_uma_util.h"
9 #include "components/content_settings/core/browser/host_content_settings_map.h"
9 #include "components/rappor/rappor_utils.h" 10 #include "components/rappor/rappor_utils.h"
10 #include "content/public/browser/permission_type.h" 11 #include "content/public/browser/permission_type.h"
11 #include "content/public/common/origin_util.h" 12 #include "content/public/common/origin_util.h"
12 #include "url/gurl.h" 13 #include "url/gurl.h"
13 14
14 // UMA keys need to be statically initialized so plain function would not 15 // UMA keys need to be statically initialized so plain function would not
15 // work. Use a Macro instead. 16 // work. Use a Macro instead.
16 #define PERMISSION_ACTION_UMA(secure_origin, permission, permission_secure, \ 17 #define PERMISSION_ACTION_UMA(secure_origin, permission, permission_secure, \
17 permission_insecure, action) \ 18 permission_insecure, action) \
18 UMA_HISTOGRAM_ENUMERATION(permission, action, PERMISSION_ACTION_NUM); \ 19 UMA_HISTOGRAM_ENUMERATION(permission, action, PERMISSION_ACTION_NUM); \
(...skipping 113 matching lines...) Expand 10 before | Expand all | Expand 10 after
132 NOTREACHED() << "PERMISSION " << permission << " not accounted for"; 133 NOTREACHED() << "PERMISSION " << permission << " not accounted for";
133 } 134 }
134 135
135 const std::string& rappor_metric = GetRapporMetric(permission, action); 136 const std::string& rappor_metric = GetRapporMetric(permission, action);
136 if (!rappor_metric.empty()) 137 if (!rappor_metric.empty())
137 rappor::SampleDomainAndRegistryFromGURL( 138 rappor::SampleDomainAndRegistryFromGURL(
138 g_browser_process->rappor_service(), rappor_metric, 139 g_browser_process->rappor_service(), rappor_metric,
139 requesting_origin); 140 requesting_origin);
140 } 141 }
141 142
142 void RecordPermissionRequest(ContentSettingsType permission, 143 std::string PermissionTypeToString(PermissionType permission_type) {
143 const GURL& requesting_origin) { 144 switch (permission_type) {
145 case PermissionType::MIDI_SYSEX:
146 return "MidiSysex";
147 case PermissionType::PUSH_MESSAGING:
148 return "PushMessaging";
149 case PermissionType::NOTIFICATIONS:
150 return "Notifications";
151 case PermissionType::GEOLOCATION:
152 return "Geolocation";
153 case PermissionType::PROTECTED_MEDIA_IDENTIFIER:
154 return "ProtectedMediaIdentifier";
155 case PermissionType::NUM:
jww 2015/06/29 21:26:59 nit: Can you make this "default" and then drop the
keenanb 2015/06/29 22:43:44 the way it is now, it will fail fast and loud when
jww 2015/06/29 22:53:23 Fair.
156 NOTREACHED();
157 }
158 return "";
jww 2015/06/29 21:26:59 If you do leave in this empty string return value,
keenanb 2015/06/29 22:43:44 Done.
159 }
160
161 void RecordPermissionRequest(
162 ContentSettingsType permission,
163 const GURL& requesting_origin,
164 const GURL& embedding_origin,
165 HostContentSettingsMap* host_content_settings_map) {
144 bool secure_origin = content::IsOriginSecure(requesting_origin); 166 bool secure_origin = content::IsOriginSecure(requesting_origin);
145 PermissionType type; 167 PermissionType type;
146 switch (permission) { 168 switch (permission) {
147 case CONTENT_SETTINGS_TYPE_GEOLOCATION: 169 case CONTENT_SETTINGS_TYPE_GEOLOCATION:
148 type = PermissionType::GEOLOCATION; 170 type = PermissionType::GEOLOCATION;
149 rappor::SampleDomainAndRegistryFromGURL( 171 rappor::SampleDomainAndRegistryFromGURL(
150 g_browser_process->rappor_service(), 172 g_browser_process->rappor_service(),
151 "ContentSettings.PermissionRequested.Geolocation.Url", 173 "ContentSettings.PermissionRequested.Geolocation.Url",
152 requesting_origin); 174 requesting_origin);
153 break; 175 break;
(...skipping 27 matching lines...) Expand all
181 UMA_HISTOGRAM_ENUMERATION( 203 UMA_HISTOGRAM_ENUMERATION(
182 "ContentSettings.PermissionRequested_SecureOrigin", 204 "ContentSettings.PermissionRequested_SecureOrigin",
183 static_cast<base::HistogramBase::Sample>(type), 205 static_cast<base::HistogramBase::Sample>(type),
184 static_cast<base::HistogramBase::Sample>(PermissionType::NUM)); 206 static_cast<base::HistogramBase::Sample>(PermissionType::NUM));
185 } else { 207 } else {
186 UMA_HISTOGRAM_ENUMERATION( 208 UMA_HISTOGRAM_ENUMERATION(
187 "ContentSettings.PermissionRequested_InsecureOrigin", 209 "ContentSettings.PermissionRequested_InsecureOrigin",
188 static_cast<base::HistogramBase::Sample>(type), 210 static_cast<base::HistogramBase::Sample>(type),
189 static_cast<base::HistogramBase::Sample>(PermissionType::NUM)); 211 static_cast<base::HistogramBase::Sample>(PermissionType::NUM));
190 } 212 }
213
214 // TODO(keenanb): It may not be worth worrying about,
jww 2015/06/29 21:26:59 Change this to "We have decided not to worry about
keenanb 2015/06/29 22:43:44 good point! done.
215 // but statistics would get skewed if, for example,
216 // before the user has made a permission decision,
217 // getCurrentPosition gets called ten times each second
218 // and generates ten permission requests each second.
219 // That may be a job for RAPPOR.
220
jww 2015/06/29 21:26:59 nit: extraneous newline.
keenanb 2015/06/29 22:43:44 Done.
221 DCHECK(requesting_origin.GetOrigin() == requesting_origin);
222 DCHECK(embedding_origin.GetOrigin() == embedding_origin);
jww 2015/06/29 21:26:59 Why are these DCHECKs necessary? In particular, no
keenanb 2015/06/29 22:43:45 (b) it is.
223 bool cross_origin_iframe = (requesting_origin != embedding_origin);
jww 2015/06/29 21:26:59 If you're able to get rid of the above DCHECKs, ch
keenanb 2015/06/29 22:43:44 Done.
224
225 if (cross_origin_iframe) {
226 ContentSetting embedding_content_setting =
227 host_content_settings_map->GetContentSetting(
228 embedding_origin, embedding_origin, permission, std::string());
229
230 UMA_HISTOGRAM_ENUMERATION("ContentSettings.PermissionRequested.OffOrigin_" +
231 PermissionTypeToString(type),
jww 2015/06/29 21:26:59 Formatting looks a little funky to me here (but I
keenanb 2015/06/29 22:43:44 i believe i did. i'll make sure to again.
232 embedding_content_setting,
233 CONTENT_SETTING_NUM_SETTINGS);
234 } else {
235 UMA_HISTOGRAM_ENUMERATION(
236 "ContentSettings.PermissionRequested.SameOrigin",
237 static_cast<base::HistogramBase::Sample>(type),
238 static_cast<base::HistogramBase::Sample>(PermissionType::NUM));
239 }
191 } 240 }
192 241
193 } // namespace 242 } // namespace
194 243
195 // Make sure you update histograms.xml permission histogram_suffix if you 244 // Make sure you update histograms.xml permission histogram_suffix if you
196 // add new permission 245 // add new permission
197 void PermissionContextUmaUtil::PermissionRequested( 246 void PermissionContextUmaUtil::PermissionRequested(
198 ContentSettingsType permission, const GURL& requesting_origin) { 247 ContentSettingsType permission,
199 RecordPermissionRequest(permission, requesting_origin); 248 const GURL& requesting_origin,
249 const GURL& embedding_origin,
250 HostContentSettingsMap* host_content_settings_map) {
251 RecordPermissionRequest(permission, requesting_origin, embedding_origin,
252 host_content_settings_map);
200 } 253 }
201 254
202 void PermissionContextUmaUtil::PermissionGranted( 255 void PermissionContextUmaUtil::PermissionGranted(
203 ContentSettingsType permission, const GURL& requesting_origin) { 256 ContentSettingsType permission, const GURL& requesting_origin) {
204 RecordPermissionAction(permission, GRANTED, requesting_origin); 257 RecordPermissionAction(permission, GRANTED, requesting_origin);
205 } 258 }
206 259
207 void PermissionContextUmaUtil::PermissionDenied( 260 void PermissionContextUmaUtil::PermissionDenied(
208 ContentSettingsType permission, const GURL& requesting_origin) { 261 ContentSettingsType permission, const GURL& requesting_origin) {
209 RecordPermissionAction(permission, DENIED, requesting_origin); 262 RecordPermissionAction(permission, DENIED, requesting_origin);
210 } 263 }
211 264
212 void PermissionContextUmaUtil::PermissionDismissed( 265 void PermissionContextUmaUtil::PermissionDismissed(
213 ContentSettingsType permission, const GURL& requesting_origin) { 266 ContentSettingsType permission, const GURL& requesting_origin) {
214 RecordPermissionAction(permission, DISMISSED, requesting_origin); 267 RecordPermissionAction(permission, DISMISSED, requesting_origin);
215 } 268 }
216 269
217 void PermissionContextUmaUtil::PermissionIgnored( 270 void PermissionContextUmaUtil::PermissionIgnored(
218 ContentSettingsType permission, const GURL& requesting_origin) { 271 ContentSettingsType permission, const GURL& requesting_origin) {
219 RecordPermissionAction(permission, IGNORED, requesting_origin); 272 RecordPermissionAction(permission, IGNORED, requesting_origin);
220 } 273 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698