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

Side by Side Diff: chrome/browser/ssl/chrome_security_state_model_client.cc

Issue 2451293002: Add a histogram for each time the HTTP Bad UI is shown (Closed)
Patch Set: Correct style and nits Created 4 years, 1 month 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 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/ssl/chrome_security_state_model_client.h" 5 #include "chrome/browser/ssl/chrome_security_state_model_client.h"
6 6
7 #include <openssl/ssl.h> 7 #include <openssl/ssl.h>
8 8
9 #include <vector> 9 #include <vector>
10 10
(...skipping 320 matching lines...) Expand 10 before | Expand all | Expand 10 after
331 void ChromeSecurityStateModelClient::VisibleSSLStateChanged() { 331 void ChromeSecurityStateModelClient::VisibleSSLStateChanged() {
332 if (logged_http_warning_on_current_navigation_) 332 if (logged_http_warning_on_current_navigation_)
333 return; 333 return;
334 334
335 security_state::SecurityStateModel::SecurityInfo security_info; 335 security_state::SecurityStateModel::SecurityInfo security_info;
336 GetSecurityInfo(&security_info); 336 GetSecurityInfo(&security_info);
337 if (!security_info.displayed_private_user_data_input_on_http) 337 if (!security_info.displayed_private_user_data_input_on_http)
338 return; 338 return;
339 339
340 std::string warning; 340 std::string warning;
341 bool warning_is_user_visible = false;
341 switch (security_info.security_level) { 342 switch (security_info.security_level) {
342 case security_state::SecurityStateModel::HTTP_SHOW_WARNING: 343 case security_state::SecurityStateModel::HTTP_SHOW_WARNING:
343 warning = 344 warning =
344 "This page includes a password or credit card input in a non-secure " 345 "This page includes a password or credit card input in a non-secure "
345 "context. A warning has been added to the URL bar. For more " 346 "context. A warning has been added to the URL bar. For more "
346 "information, see https://goo.gl/zmWq3m."; 347 "information, see https://goo.gl/zmWq3m.";
348 warning_is_user_visible = true;
347 break; 349 break;
348 case security_state::SecurityStateModel::NONE: 350 case security_state::SecurityStateModel::NONE:
351 case security_state::SecurityStateModel::DANGEROUS:
estark 2016/10/26 21:29:46 Two notes about this (no changes needed): 1. One
349 warning = 352 warning =
350 "This page includes a password or credit card input in a non-secure " 353 "This page includes a password or credit card input in a non-secure "
351 "context. A warning will be added to the URL bar in Chrome 56 (Jan " 354 "context. A warning will be added to the URL bar in Chrome 56 (Jan "
352 "2017). For more information, see https://goo.gl/zmWq3m."; 355 "2017). For more information, see https://goo.gl/zmWq3m.";
353 break; 356 break;
354 default: 357 default:
355 return; 358 return;
356 } 359 }
357 360
358 logged_http_warning_on_current_navigation_ = true; 361 logged_http_warning_on_current_navigation_ = true;
359 web_contents_->GetMainFrame()->AddMessageToConsole( 362 web_contents_->GetMainFrame()->AddMessageToConsole(
360 content::CONSOLE_MESSAGE_LEVEL_WARNING, warning); 363 content::CONSOLE_MESSAGE_LEVEL_WARNING, warning);
364 UMA_HISTOGRAM_BOOLEAN("Security.HTTPBad.UserWarnedAboutSensitiveInput",
365 warning_is_user_visible);
361 } 366 }
362 367
363 void ChromeSecurityStateModelClient::DidFinishNavigation( 368 void ChromeSecurityStateModelClient::DidFinishNavigation(
364 content::NavigationHandle* navigation_handle) { 369 content::NavigationHandle* navigation_handle) {
365 if (navigation_handle->IsInMainFrame() && 370 if (navigation_handle->IsInMainFrame() &&
366 !navigation_handle->IsSynchronousNavigation()) { 371 !navigation_handle->IsSynchronousNavigation()) {
367 // Only reset the console message flag for main-frame navigations, 372 // Only reset the console message flag for main-frame navigations,
368 // and not for synchronous navigations like reference fragments and 373 // and not for synchronous navigations like reference fragments and
369 // pushState. 374 // pushState.
370 logged_http_warning_on_current_navigation_ = false; 375 logged_http_warning_on_current_navigation_ = false;
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after
427 !!(ssl.content_status & content::SSLStatus::RAN_CONTENT_WITH_CERT_ERRORS); 432 !!(ssl.content_status & content::SSLStatus::RAN_CONTENT_WITH_CERT_ERRORS);
428 state->displayed_password_field_on_http = 433 state->displayed_password_field_on_http =
429 !!(ssl.content_status & 434 !!(ssl.content_status &
430 content::SSLStatus::DISPLAYED_PASSWORD_FIELD_ON_HTTP); 435 content::SSLStatus::DISPLAYED_PASSWORD_FIELD_ON_HTTP);
431 state->displayed_credit_card_field_on_http = 436 state->displayed_credit_card_field_on_http =
432 !!(ssl.content_status & 437 !!(ssl.content_status &
433 content::SSLStatus::DISPLAYED_CREDIT_CARD_FIELD_ON_HTTP); 438 content::SSLStatus::DISPLAYED_CREDIT_CARD_FIELD_ON_HTTP);
434 439
435 CheckSafeBrowsingStatus(entry, web_contents_, state); 440 CheckSafeBrowsingStatus(entry, web_contents_, state);
436 } 441 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698