ssl_error_info.cc revision 5f1c94371a64b3196d4be9466099bb892df9b88e
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" 85f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles)#include "base/strings/string_number_conversions.h" 9868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)#include "base/strings/utf_string_conversions.h" 105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/public/browser/cert_store.h" 115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "grit/chromium_strings.h" 125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "grit/generated_resources.h" 135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/base/escape.h" 145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "net/base/net_errors.h" 15c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)#include "net/cert/cert_status_flags.h" 162a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "net/ssl/ssl_info.h" 175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ui/base/l10n/l10n_util.h" 18eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch#include "url/gurl.h" 195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 205d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)using base::UTF8ToUTF16; 215d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) 22a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)SSLErrorInfo::SSLErrorInfo(const base::string16& title, 23a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles) const base::string16& details, 24a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles) const base::string16& short_description, 255d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) const std::vector<base::string16>& extra_info) 265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) : title_(title), 275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details_(details), 285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description_(short_description), 295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_information_(extra_info) { 305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// static 335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)SSLErrorInfo SSLErrorInfo::CreateError(ErrorType error_type, 345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::X509Certificate* cert, 355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const GURL& request_url) { 36a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles) base::string16 title, details, short_description; 375d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) std::vector<base::string16> extra_info; 385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) switch (error_type) { 395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_COMMON_NAME_INVALID: { 405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = 415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_COMMON_NAME_INVALID_TITLE); 425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // If the certificate contains multiple DNS names, we choose the most 435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // representative one -- either the DNS name that's also in the subject 445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // field, or the first one. If this heuristic turns out to be 455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // inadequate, we can consider choosing the DNS name that is the 465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // "closest match" to the host name in the request URL, or listing all 475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // the DNS names with an HTML <ul>. 485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) std::vector<std::string> dns_names; 495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cert->GetDNSNames(&dns_names); 505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(!dns_names.empty()); 515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) size_t i = 0; 525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (; i < dns_names.size(); ++i) { 535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (dns_names[i] == cert->subject().common_name) 545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (i == dns_names.size()) 575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) i = 0; 585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = 595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringFUTF16(IDS_CERT_ERROR_COMMON_NAME_INVALID_DETAILS, 605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()), 615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::EscapeForHTML( 625f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles) UTF8ToUTF16(dns_names[i]))); 635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_COMMON_NAME_INVALID_DESCRIPTION); 655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringFUTF16( 695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_COMMON_NAME_INVALID_EXTRA_INFO_2, 705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::EscapeForHTML(UTF8ToUTF16(cert->subject().common_name)), 715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()))); 725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_DATE_INVALID: 755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (cert->HasExpired()) { 785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXPIRED_TITLE); 795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_EXPIRED_DETAILS, 815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()), 825f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles) base::IntToString16( 835f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles) (base::Time::Now() - cert->valid_expiry()).InDays()), 845f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles) base::TimeFormatFriendlyDate(base::Time::Now())); 855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXPIRED_DESCRIPTION); 875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back(l10n_util::GetStringUTF16( 885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_EXPIRED_DETAILS_EXTRA_INFO_2)); 895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } else { 905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Then it must be not yet valid. We don't check that it is not yet 915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // valid as there is still a very unlikely chance that the cert might 925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // have become valid since the error occurred. 935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_NOT_YET_VALID_TITLE); 945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_NOT_YET_VALID_DETAILS, 965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()), 975f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles) base::IntToString16( 985f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles) (cert->valid_start() - base::Time::Now()).InDays())); 995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 1005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_NOT_YET_VALID_DESCRIPTION); 1015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16( 1035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_NOT_YET_VALID_DETAILS_EXTRA_INFO_2)); 1045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 1055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_AUTHORITY_INVALID: 1075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_AUTHORITY_INVALID_TITLE); 1085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 1095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_AUTHORITY_INVALID_DETAILS, 1105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 1115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 1125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_AUTHORITY_INVALID_DESCRIPTION); 1135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 1155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back(l10n_util::GetStringFUTF16( 1165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_AUTHORITY_INVALID_EXTRA_INFO_2, 1175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()), 1185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host()))); 119a93a17c8d99d686bd4a1511e5504e5e6cc9fcadfTorne (Richard Coles)#if !defined(OS_IOS) 120a93a17c8d99d686bd4a1511e5504e5e6cc9fcadfTorne (Richard Coles) // The third paragraph advises users to install a private trust anchor, 121a93a17c8d99d686bd4a1511e5504e5e6cc9fcadfTorne (Richard Coles) // but that is not possible in Chrome for iOS at this time. 1225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back(l10n_util::GetStringUTF16( 1235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_AUTHORITY_INVALID_EXTRA_INFO_3)); 124a93a17c8d99d686bd4a1511e5504e5e6cc9fcadfTorne (Richard Coles)#endif 1255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_CONTAINS_ERRORS: 1275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_CONTAINS_ERRORS_TITLE); 1285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 1295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_CONTAINS_ERRORS_DETAILS, 1305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 1315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 1325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_CONTAINS_ERRORS_DESCRIPTION); 1335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 134116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 1355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back(l10n_util::GetStringUTF16( 1365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_CONTAINS_ERRORS_EXTRA_INFO_2)); 1375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_NO_REVOCATION_MECHANISM: 1395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16( 1405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_NO_REVOCATION_MECHANISM_TITLE); 1415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringUTF16( 1425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_NO_REVOCATION_MECHANISM_DETAILS); 1435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 1445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_NO_REVOCATION_MECHANISM_DESCRIPTION); 1455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_UNABLE_TO_CHECK_REVOCATION: 1475f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles) // TODO(felt): Hasn't this been deprecated? 1485f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles) title = l10n_util::GetStringFUTF16( 1495f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles) IDS_CERT_ERROR_UNABLE_TO_CHECK_REVOCATION_TITLE, 1505f1c94371a64b3196d4be9466099bb892df9b88eTorne (Richard Coles) UTF8ToUTF16(request_url.host())); 1515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringUTF16( 1525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_UNABLE_TO_CHECK_REVOCATION_DETAILS); 1535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 1545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_UNABLE_TO_CHECK_REVOCATION_DESCRIPTION); 1555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_REVOKED: 1575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_REVOKED_CERT_TITLE); 1585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16(IDS_CERT_ERROR_REVOKED_CERT_DETAILS, 1595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 1605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 1615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_REVOKED_CERT_DESCRIPTION); 1625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 1645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_REVOKED_CERT_EXTRA_INFO_2)); 1665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_INVALID: 1685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_INVALID_CERT_TITLE); 1695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 1705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_INVALID_CERT_DETAILS, 1715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 1725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 1735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_INVALID_CERT_DESCRIPTION); 1745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 1765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back(l10n_util::GetStringUTF16( 1775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_INVALID_CERT_EXTRA_INFO_2)); 1785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_WEAK_SIGNATURE_ALGORITHM: 1805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16( 1815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_SIGNATURE_ALGORITHM_TITLE); 1825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 1835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_SIGNATURE_ALGORITHM_DETAILS, 1845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 1855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 1865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_SIGNATURE_ALGORITHM_DESCRIPTION); 1875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 1895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 1905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16( 1915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_SIGNATURE_ALGORITHM_EXTRA_INFO_2)); 1925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 1935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case CERT_WEAK_KEY: 1945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_WEAK_KEY_TITLE); 1955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 1965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_KEY_DETAILS, UTF8ToUTF16(request_url.host())); 1975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 1985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_KEY_DESCRIPTION); 1995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 2005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_EXTRA_INFO_1)); 2015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) extra_info.push_back( 2025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16( 2035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_ERROR_WEAK_KEY_EXTRA_INFO_2)); 2045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 2058bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) case CERT_WEAK_KEY_DH: 2068bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) title = l10n_util::GetStringUTF16( 2078bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) IDS_ERRORPAGES_HEADING_WEAK_SERVER_EPHEMERAL_DH_KEY); 2088bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) details = l10n_util::GetStringFUTF16( 2098bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) IDS_CERT_ERROR_WEAK_KEY_DETAILS, UTF8ToUTF16(request_url.host())); 2108bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) short_description = l10n_util::GetStringUTF16( 2118bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) IDS_CERT_ERROR_WEAK_KEY_DESCRIPTION); 2128bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) extra_info.push_back( 2138bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) l10n_util::GetStringUTF16( 2148bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) IDS_ERRORPAGES_SUMMARY_WEAK_SERVER_EPHEMERAL_DH_KEY)); 2155d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) case CERT_NAME_CONSTRAINT_VIOLATION: 2165d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) title = l10n_util::GetStringUTF16( 2175d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) IDS_CERT_ERROR_NAME_CONSTRAINT_VIOLATION_TITLE); 2185d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) details = l10n_util::GetStringFUTF16( 2195d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) IDS_CERT_ERROR_NAME_CONSTRAINT_VIOLATION_DETAILS, 2205d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) UTF8ToUTF16(request_url.host())); 2215d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) short_description = l10n_util::GetStringUTF16( 2225d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) IDS_CERT_ERROR_NAME_CONSTRAINT_VIOLATION_DESCRIPTION); 2235d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) break; 2248bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) case CERT_PINNED_KEY_MISSING: 2258bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) title = l10n_util::GetStringUTF16( 2268bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) IDS_ERRORPAGES_HEADING_PINNING_FAILURE); 2278bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) details = l10n_util::GetStringUTF16( 2288bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) IDS_ERRORPAGES_SUMMARY_PINNING_FAILURE); 2298bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) short_description = l10n_util::GetStringUTF16( 2308bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) IDS_ERRORPAGES_DETAILS_PINNING_FAILURE); 2315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case UNKNOWN: 2325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) title = l10n_util::GetStringUTF16(IDS_CERT_ERROR_UNKNOWN_ERROR_TITLE); 2335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) details = l10n_util::GetStringUTF16(IDS_CERT_ERROR_UNKNOWN_ERROR_DETAILS); 2345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) short_description = 2355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) l10n_util::GetStringUTF16(IDS_CERT_ERROR_UNKNOWN_ERROR_DESCRIPTION); 2365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) break; 2375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) default: 2385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) NOTREACHED(); 2395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return SSLErrorInfo(title, details, short_description, extra_info); 2415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)SSLErrorInfo::~SSLErrorInfo() { 2445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// static 2475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)SSLErrorInfo::ErrorType SSLErrorInfo::NetErrorToErrorType(int net_error) { 2485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) switch (net_error) { 2495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_COMMON_NAME_INVALID: 2505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_COMMON_NAME_INVALID; 2515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_DATE_INVALID: 2525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_DATE_INVALID; 2535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_AUTHORITY_INVALID: 2545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_AUTHORITY_INVALID; 2555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_CONTAINS_ERRORS: 2565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_CONTAINS_ERRORS; 2575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_NO_REVOCATION_MECHANISM: 2585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_NO_REVOCATION_MECHANISM; 2595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_UNABLE_TO_CHECK_REVOCATION: 2605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_UNABLE_TO_CHECK_REVOCATION; 2615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_REVOKED: 2625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_REVOKED; 2635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_INVALID: 2645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_INVALID; 2655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_WEAK_SIGNATURE_ALGORITHM: 2665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_WEAK_SIGNATURE_ALGORITHM; 2675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) case net::ERR_CERT_WEAK_KEY: 2685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return CERT_WEAK_KEY; 2695d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) case net::ERR_CERT_NAME_CONSTRAINT_VIOLATION: 2705d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) return CERT_NAME_CONSTRAINT_VIOLATION; 2718bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) case net::ERR_SSL_WEAK_SERVER_EPHEMERAL_DH_KEY: 2728bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) return CERT_WEAK_KEY_DH; 2738bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) case net::ERR_SSL_PINNED_KEY_NOT_IN_CERT_CHAIN: 2748bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) return CERT_PINNED_KEY_MISSING; 2755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) default: 2765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) NOTREACHED(); 2775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return UNKNOWN; 2785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// static 2825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)int SSLErrorInfo::GetErrorsForCertStatus(int cert_id, 2835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CertStatus cert_status, 2845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const GURL& url, 2855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) std::vector<SSLErrorInfo>* errors) { 2865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const net::CertStatus kErrorFlags[] = { 2875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_COMMON_NAME_INVALID, 2885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_DATE_INVALID, 2895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_AUTHORITY_INVALID, 2905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_NO_REVOCATION_MECHANISM, 2915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_UNABLE_TO_CHECK_REVOCATION, 2925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_REVOKED, 2935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_INVALID, 2945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) net::CERT_STATUS_WEAK_SIGNATURE_ALGORITHM, 2955d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) net::CERT_STATUS_WEAK_KEY, 2965d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) net::CERT_STATUS_NAME_CONSTRAINT_VIOLATION, 2975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) }; 2985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const ErrorType kErrorTypes[] = { 3005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_COMMON_NAME_INVALID, 3015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_DATE_INVALID, 3025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_AUTHORITY_INVALID, 3035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_NO_REVOCATION_MECHANISM, 3045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_UNABLE_TO_CHECK_REVOCATION, 3055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_REVOKED, 3065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_INVALID, 3075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CERT_WEAK_SIGNATURE_ALGORITHM, 3085d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) CERT_WEAK_KEY, 3095d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) CERT_NAME_CONSTRAINT_VIOLATION, 3105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) }; 3115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(arraysize(kErrorFlags) == arraysize(kErrorTypes)); 3125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 3135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) scoped_refptr<net::X509Certificate> cert = NULL; 3145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) int count = 0; 3155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (size_t i = 0; i < arraysize(kErrorFlags); ++i) { 3165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (cert_status & kErrorFlags[i]) { 3175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) count++; 3185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (!cert.get()) { 3195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) bool r = content::CertStore::GetInstance()->RetrieveCert( 3205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cert_id, &cert); 3215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(r); 3225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 3235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (errors) 324868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) errors->push_back( 325868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) SSLErrorInfo::CreateError(kErrorTypes[i], cert.get(), url)); 3265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 3275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 3285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return count; 3295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 330