ssl_error_info.cc revision 5821806d5e7f356e8fa4b058a389a808ea183019
15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved. 25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be 35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file. 45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/ssl/ssl_error_info.h" 65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/i18n/time_formatting.h" 85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/utf_string_conversions.h" 95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/common/time_format.h" 105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/public/browser/cert_store.h" 115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "googleurl/src/gurl.h" 125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "grit/chromium_strings.h" 135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "grit/generated_resources.h" 145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/base/cert_status_flags.h" 155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/base/escape.h" 165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/base/net_errors.h" 175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/base/ssl_info.h" 185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ui/base/l10n/l10n_util.h" 195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)SSLErrorInfo::SSLErrorInfo(const string16& title, 215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const string16& details, 225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const string16& short_description, 235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const std::vector<string16>& extra_info) 245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) : title_(title), 255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details_(details), 265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description_(short_description), 275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_information_(extra_info) { 285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// static 315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)SSLErrorInfo SSLErrorInfo::CreateError(ErrorType error_type, 325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::X509Certificate* cert, 335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const GURL& request_url) { 345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) string16 title, details, short_description; 355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) std::vector<string16> extra_info; 365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) switch (error_type) { 375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_COMMON_NAME_INVALID: { 385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = 395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_COMMON_NAME_INVALID_TITLE); 405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // If the certificate contains multiple DNS names, we choose the most 415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // representative one -- either the DNS name that's also in the subject 425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // field, or the first one. If this heuristic turns out to be 435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // inadequate, we can consider choosing the DNS name that is the 445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // "closest match" to the host name in the request URL, or listing all 455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // the DNS names with an HTML <ul>. 465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) std::vector<std::string> dns_names; 475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cert->GetDNSNames(&dns_names); 485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(!dns_names.empty()); 495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) size_t i = 0; 505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (; i < dns_names.size(); ++i) { 515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (dns_names[i] == cert->subject().common_name) 525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (i == dns_names.size()) 555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) i = 0; 565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = 575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringFUTF16(IDS_CERT_ERROR_COMMON_NAME_INVALID_DETAILS, 585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()), 595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::EscapeForHTML( 605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(dns_names[i])), 615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_COMMON_NAME_INVALID_DESCRIPTION); 645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringFUTF16( 685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_COMMON_NAME_INVALID_EXTRA_INFO_2, 695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::EscapeForHTML(UTF8ToUTF16(cert->subject().common_name)), 705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()))); 715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_DATE_INVALID: 745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (cert->HasExpired()) { 775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXPIRED_TITLE); 785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_EXPIRED_DETAILS, 805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()), 815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()), 825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::TimeFormatFriendlyDateAndTime(base::Time::Now())); 835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXPIRED_DESCRIPTION); 855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back(l10n_util::GetStringUTF16( 865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_EXPIRED_DETAILS_EXTRA_INFO_2)); 875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } else { 885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Then it must be not yet valid. We don't check that it is not yet 895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // valid as there is still a very unlikely chance that the cert might 905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // have become valid since the error occurred. 915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_NOT_YET_VALID_TITLE); 925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_NOT_YET_VALID_DETAILS, 945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()), 955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()), 965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::TimeFormatFriendlyDateAndTime(base::Time::Now())); 975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_NOT_YET_VALID_DESCRIPTION); 995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16( 1015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_NOT_YET_VALID_DETAILS_EXTRA_INFO_2)); 1025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 1035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_AUTHORITY_INVALID: 1055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_AUTHORITY_INVALID_TITLE); 1065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 1075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_AUTHORITY_INVALID_DETAILS, 1085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 1095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 1105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_AUTHORITY_INVALID_DESCRIPTION); 1115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 1135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back(l10n_util::GetStringFUTF16( 1145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_AUTHORITY_INVALID_EXTRA_INFO_2, 1155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()), 1165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()))); 1175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back(l10n_util::GetStringUTF16( 1185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_AUTHORITY_INVALID_EXTRA_INFO_3)); 1195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_CONTAINS_ERRORS: 1215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_CONTAINS_ERRORS_TITLE); 1225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 1235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_CONTAINS_ERRORS_DETAILS, 1245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 1255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 1265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_CONTAINS_ERRORS_DESCRIPTION); 1275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringFUTF16(IDS_CERT_ERROR_EXTRA_INFO_1, 1295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()))); 1305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back(l10n_util::GetStringUTF16( 1315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_CONTAINS_ERRORS_EXTRA_INFO_2)); 1325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_NO_REVOCATION_MECHANISM: 1345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16( 1355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_NO_REVOCATION_MECHANISM_TITLE); 1365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringUTF16( 1375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_NO_REVOCATION_MECHANISM_DETAILS); 1385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 1395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_NO_REVOCATION_MECHANISM_DESCRIPTION); 1405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_UNABLE_TO_CHECK_REVOCATION: 1425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16( 1435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_UNABLE_TO_CHECK_REVOCATION_TITLE); 1445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringUTF16( 1455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_UNABLE_TO_CHECK_REVOCATION_DETAILS); 1465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 1475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_UNABLE_TO_CHECK_REVOCATION_DESCRIPTION); 1485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_REVOKED: 1505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_REVOKED_CERT_TITLE); 1515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16(IDS_CERT_ERROR_REVOKED_CERT_DETAILS, 1525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 1535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 1545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_REVOKED_CERT_DESCRIPTION); 1555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 1575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_REVOKED_CERT_EXTRA_INFO_2)); 1595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_INVALID: 1615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_INVALID_CERT_TITLE); 1625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 1635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_INVALID_CERT_DETAILS, 1645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 1655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 1665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_INVALID_CERT_DESCRIPTION); 1675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 1695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back(l10n_util::GetStringUTF16( 1705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_INVALID_CERT_EXTRA_INFO_2)); 1715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_WEAK_SIGNATURE_ALGORITHM: 1735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16( 1745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_SIGNATURE_ALGORITHM_TITLE); 1755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 1765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_SIGNATURE_ALGORITHM_DETAILS, 1775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 1785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 1795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_SIGNATURE_ALGORITHM_DESCRIPTION); 1805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 1825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16( 1845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_SIGNATURE_ALGORITHM_EXTRA_INFO_2)); 1855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_WEAK_KEY: 1875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_WEAK_KEY_TITLE); 1885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 1895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_KEY_DETAILS, UTF8ToUTF16(request_url.host())); 1905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 1915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_KEY_DESCRIPTION); 1925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 1945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16( 1965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_KEY_EXTRA_INFO_2)); 1975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case UNKNOWN: 1995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_UNKNOWN_ERROR_TITLE); 2005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringUTF16(IDS_CERT_ERROR_UNKNOWN_ERROR_DETAILS); 2015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 2025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_UNKNOWN_ERROR_DESCRIPTION); 2035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 2045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) default: 2055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) NOTREACHED(); 2065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return SSLErrorInfo(title, details, short_description, extra_info); 2085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)SSLErrorInfo::~SSLErrorInfo() { 2115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// static 2145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)SSLErrorInfo::ErrorType SSLErrorInfo::NetErrorToErrorType(int net_error) { 2155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) switch (net_error) { 2165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_COMMON_NAME_INVALID: 2175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_COMMON_NAME_INVALID; 2185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_DATE_INVALID: 2195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_DATE_INVALID; 2205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_AUTHORITY_INVALID: 2215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_AUTHORITY_INVALID; 2225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_CONTAINS_ERRORS: 2235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_CONTAINS_ERRORS; 2245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_NO_REVOCATION_MECHANISM: 2255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_NO_REVOCATION_MECHANISM; 2265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_UNABLE_TO_CHECK_REVOCATION: 2275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_UNABLE_TO_CHECK_REVOCATION; 2285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_REVOKED: 2295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_REVOKED; 2305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_INVALID: 2315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_INVALID; 2325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_WEAK_SIGNATURE_ALGORITHM: 2335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_WEAK_SIGNATURE_ALGORITHM; 2345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_WEAK_KEY: 2355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_WEAK_KEY; 2365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) default: 2375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) NOTREACHED(); 2385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return UNKNOWN; 2395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// static 2435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)int SSLErrorInfo::GetErrorsForCertStatus(int cert_id, 2445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CertStatus cert_status, 2455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const GURL& url, 2465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) std::vector<SSLErrorInfo>* errors) { 2475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const net::CertStatus kErrorFlags[] = { 2485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_COMMON_NAME_INVALID, 2495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_DATE_INVALID, 2505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_AUTHORITY_INVALID, 2515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_NO_REVOCATION_MECHANISM, 2525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_UNABLE_TO_CHECK_REVOCATION, 2535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_REVOKED, 2545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_INVALID, 2555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_WEAK_SIGNATURE_ALGORITHM, 2565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_WEAK_KEY 2575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) }; 2585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const ErrorType kErrorTypes[] = { 2605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_COMMON_NAME_INVALID, 2615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_DATE_INVALID, 2625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_AUTHORITY_INVALID, 2635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_NO_REVOCATION_MECHANISM, 2645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_UNABLE_TO_CHECK_REVOCATION, 2655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_REVOKED, 2665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_INVALID, 2675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_WEAK_SIGNATURE_ALGORITHM, 2685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_WEAK_KEY 2695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) }; 2705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(arraysize(kErrorFlags) == arraysize(kErrorTypes)); 2715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) scoped_refptr<net::X509Certificate> cert = NULL; 2735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) int count = 0; 2745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (size_t i = 0; i < arraysize(kErrorFlags); ++i) { 2755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (cert_status & kErrorFlags[i]) { 2765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) count++; 2775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (!cert.get()) { 2785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) bool r = content::CertStore::GetInstance()->RetrieveCert( 2795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cert_id, &cert); 2805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(r); 2815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (errors) 2835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) errors->push_back(SSLErrorInfo::CreateError(kErrorTypes[i], cert, url)); 2845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return count; 2875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 288