Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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/page_info_model.h" | 5 #include "chrome/browser/page_info_model.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "app/l10n_util.h" | 9 #include "app/l10n_util.h" |
| 10 #include "base/callback.h" | 10 #include "base/callback.h" |
| 11 #include "base/i18n/time_formatting.h" | 11 #include "base/i18n/time_formatting.h" |
| 12 #include "base/utf_string_conversions.h" | 12 #include "base/utf_string_conversions.h" |
| 13 #include "chrome/browser/cert_store.h" | 13 #include "chrome/browser/cert_store.h" |
| 14 #include "chrome/browser/pref_service.h" | 14 #include "chrome/browser/pref_service.h" |
| 15 #include "chrome/browser/profile.h" | 15 #include "chrome/browser/profile.h" |
| 16 #include "chrome/browser/ssl/ssl_manager.h" | 16 #include "chrome/browser/ssl/ssl_manager.h" |
| 17 #include "chrome/common/pref_names.h" | 17 #include "chrome/common/pref_names.h" |
| 18 #include "grit/generated_resources.h" | 18 #include "grit/generated_resources.h" |
| 19 #include "net/base/cert_status_flags.h" | 19 #include "net/base/cert_status_flags.h" |
| 20 #include "net/base/ssl_connection_status_flags.h" | |
| 21 #include "net/base/ssl_cipher_suite_names.h" | |
| 20 #include "net/base/x509_certificate.h" | 22 #include "net/base/x509_certificate.h" |
| 21 | 23 |
| 22 namespace { | 24 namespace { |
| 23 // Returns a name that can be used to represent the issuer. It tries in this | 25 // Returns a name that can be used to represent the issuer. It tries in this |
| 24 // order CN, O and OU and returns the first non-empty one found. | 26 // order CN, O and OU and returns the first non-empty one found. |
| 25 std::string GetIssuerName(const net::X509Certificate::Principal& issuer) { | 27 std::string GetIssuerName(const net::X509Certificate::Principal& issuer) { |
| 26 if (!issuer.common_name.empty()) | 28 if (!issuer.common_name.empty()) |
| 27 return issuer.common_name; | 29 return issuer.common_name; |
| 28 if (!issuer.organization_names.empty()) | 30 if (!issuer.organization_names.empty()) |
| 29 return issuer.organization_names[0]; | 31 return issuer.organization_names[0]; |
| (...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 126 IDS_PAGE_INFO_SECURITY_TAB_NOT_ENCRYPTED_CONNECTION_TEXT, | 128 IDS_PAGE_INFO_SECURITY_TAB_NOT_ENCRYPTED_CONNECTION_TEXT, |
| 127 subject_name)); | 129 subject_name)); |
| 128 } else if (ssl.security_bits() < 80) { | 130 } else if (ssl.security_bits() < 80) { |
| 129 state = false; | 131 state = false; |
| 130 description.assign(l10n_util::GetStringFUTF16( | 132 description.assign(l10n_util::GetStringFUTF16( |
| 131 IDS_PAGE_INFO_SECURITY_TAB_WEAK_ENCRYPTION_CONNECTION_TEXT, | 133 IDS_PAGE_INFO_SECURITY_TAB_WEAK_ENCRYPTION_CONNECTION_TEXT, |
| 132 subject_name)); | 134 subject_name)); |
| 133 } else { | 135 } else { |
| 134 description.assign(l10n_util::GetStringFUTF16( | 136 description.assign(l10n_util::GetStringFUTF16( |
| 135 IDS_PAGE_INFO_SECURITY_TAB_ENCRYPTED_CONNECTION_TEXT, | 137 IDS_PAGE_INFO_SECURITY_TAB_ENCRYPTED_CONNECTION_TEXT, |
| 136 subject_name, | 138 subject_name)); |
| 137 IntToString16(ssl.security_bits()))); | |
| 138 if (ssl.displayed_insecure_content() || ssl.ran_insecure_content()) { | 139 if (ssl.displayed_insecure_content() || ssl.ran_insecure_content()) { |
| 139 state = false; | 140 state = false; |
| 140 description.assign(l10n_util::GetStringFUTF16( | 141 description.assign(l10n_util::GetStringFUTF16( |
| 141 IDS_PAGE_INFO_SECURITY_TAB_ENCRYPTED_SENTENCE_LINK, | 142 IDS_PAGE_INFO_SECURITY_TAB_ENCRYPTED_SENTENCE_LINK, |
| 142 description, | 143 description, |
| 143 l10n_util::GetStringUTF16(ssl.ran_insecure_content() ? | 144 l10n_util::GetStringUTF16(ssl.ran_insecure_content() ? |
| 144 IDS_PAGE_INFO_SECURITY_TAB_ENCRYPTED_INSECURE_CONTENT_ERROR : | 145 IDS_PAGE_INFO_SECURITY_TAB_ENCRYPTED_INSECURE_CONTENT_ERROR : |
| 145 IDS_PAGE_INFO_SECURITY_TAB_ENCRYPTED_INSECURE_CONTENT_WARNING))); | 146 IDS_PAGE_INFO_SECURITY_TAB_ENCRYPTED_INSECURE_CONTENT_WARNING))); |
| 146 } | 147 } |
| 147 } | 148 } |
| 149 | |
| 150 uint16_t cipher_suite = | |
|
wtc
2010/07/16 20:07:10
Question: are we supposed to use uint16_t instead
agl
2010/07/18 17:03:49
I haven't heard so. I tend to use _t because it's
| |
| 151 ((ssl.connection_status() >> net::SSL_CONNECTION_CIPHERSUITE_SHIFT) & | |
| 152 net::SSL_CONNECTION_CIPHERSUITE_MASK); | |
| 153 if (ssl.security_bits() > 0 && cipher_suite) { | |
| 154 uint8_t compression_id = | |
| 155 ((ssl.connection_status() >> net::SSL_CONNECTION_COMPRESSION_SHIFT) & | |
| 156 net::SSL_CONNECTION_COMPRESSION_MASK); | |
| 157 bool did_fallback = ssl.connection_status() & | |
| 158 net::SSL_CONNECTION_SSL3_FALLBACK; | |
| 159 bool no_renegotiation = ssl.connection_status() & | |
| 160 net::SSL_CONNECTION_NO_RENEGOTIATION_EXTENSION; | |
| 161 // For now, only SSLv3 fallback will trigger a warning icon here. | |
| 162 state = !did_fallback; | |
| 163 const char *key_exchange, *cipher, *mac, *compression; | |
| 164 net::SSLCipherSuiteToStrings(&key_exchange, &cipher, &mac, cipher_suite); | |
| 165 net::SSLCompressionToString(&compression, compression_id); | |
| 166 | |
| 167 description += ASCIIToUTF16("\n\n"); | |
|
wtc
2010/07/16 20:07:10
Can we add "\n\n" here? Are there some languages
agl
2010/07/18 17:03:49
I wondered about that also, but I believe that we'
| |
| 168 description += l10n_util::GetStringFUTF16( | |
| 169 IDS_PAGE_INFO_SECURITY_TAB_ENCRYPTION_DETAILS, | |
| 170 ASCIIToUTF16(cipher), ASCIIToUTF16(mac), ASCIIToUTF16(key_exchange), | |
| 171 ASCIIToUTF16(compression)); | |
| 172 | |
| 173 if (did_fallback) { | |
| 174 description += ASCIIToUTF16("\n\n"); | |
| 175 description += l10n_util::GetStringUTF16( | |
| 176 IDS_PAGE_INFO_SECURITY_TAB_FALLBACK_MESSAGE); | |
| 177 } | |
| 178 if (no_renegotiation) { | |
| 179 description += ASCIIToUTF16("\n\n"); | |
| 180 description += l10n_util::GetStringUTF16( | |
| 181 IDS_PAGE_INFO_SECURITY_TAB_RENEGOTIATION_MESSAGE); | |
| 182 } | |
| 183 } | |
| 184 | |
| 148 sections_.push_back(SectionInfo( | 185 sections_.push_back(SectionInfo( |
| 149 state, | 186 state, |
| 150 l10n_util::GetStringUTF16(IDS_PAGE_INFO_SECURITY_TAB_CONNECTION_TITLE), | 187 l10n_util::GetStringUTF16(IDS_PAGE_INFO_SECURITY_TAB_CONNECTION_TITLE), |
| 151 head_line, | 188 head_line, |
| 152 description)); | 189 description)); |
| 153 | 190 |
| 154 // Request the number of visits. | 191 // Request the number of visits. |
| 155 HistoryService* history = profile->GetHistoryService( | 192 HistoryService* history = profile->GetHistoryService( |
| 156 Profile::EXPLICIT_ACCESS); | 193 Profile::EXPLICIT_ACCESS); |
| 157 if (show_history && history) { | 194 if (show_history && history) { |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 205 IDS_PAGE_INFO_SECURITY_TAB_VISITED_BEFORE_TODAY, | 242 IDS_PAGE_INFO_SECURITY_TAB_VISITED_BEFORE_TODAY, |
| 206 WideToUTF16(base::TimeFormatShortDate(first_visit))))); | 243 WideToUTF16(base::TimeFormatShortDate(first_visit))))); |
| 207 } | 244 } |
| 208 observer_->ModelChanged(); | 245 observer_->ModelChanged(); |
| 209 } | 246 } |
| 210 | 247 |
| 211 // static | 248 // static |
| 212 void PageInfoModel::RegisterPrefs(PrefService* prefs) { | 249 void PageInfoModel::RegisterPrefs(PrefService* prefs) { |
| 213 prefs->RegisterDictionaryPref(prefs::kPageInfoWindowPlacement); | 250 prefs->RegisterDictionaryPref(prefs::kPageInfoWindowPlacement); |
| 214 } | 251 } |
| OLD | NEW |