| Index: chrome/browser/ssl/bad_clock_blocking_page.cc
|
| diff --git a/chrome/browser/ssl/bad_clock_blocking_page.cc b/chrome/browser/ssl/bad_clock_blocking_page.cc
|
| index 0bf69fff9b07ce0469dd61fa821e9cc0a9155fe8..261b90fc9a6961ec6142b62bec2239413c0c9d29 100644
|
| --- a/chrome/browser/ssl/bad_clock_blocking_page.cc
|
| +++ b/chrome/browser/ssl/bad_clock_blocking_page.cc
|
| @@ -36,6 +36,7 @@
|
| #include "content/public/browser/navigation_entry.h"
|
| #include "content/public/browser/render_process_host.h"
|
| #include "content/public/browser/render_view_host.h"
|
| +#include "content/public/browser/signed_certificate_timestamp_store.h"
|
| #include "content/public/browser/web_contents.h"
|
| #include "content/public/common/renderer_preferences.h"
|
| #include "content/public/common/ssl_status.h"
|
| @@ -276,15 +277,24 @@ void BadClockBlockingPage::PopulateInterstitialStrings(
|
| }
|
|
|
| void BadClockBlockingPage::OverrideEntry(NavigationEntry* entry) {
|
| - int cert_id = content::CertStore::GetInstance()->StoreCert(
|
| - ssl_info_.cert.get(), web_contents()->GetRenderProcessHost()->GetID());
|
| + const int process_id = web_contents()->GetRenderProcessHost()->GetID();
|
| + const int cert_id = content::CertStore::GetInstance()->StoreCert(
|
| + ssl_info_.cert.get(), process_id);
|
| DCHECK(cert_id);
|
|
|
| - entry->GetSSL().security_style =
|
| - content::SECURITY_STYLE_AUTHENTICATION_BROKEN;
|
| - entry->GetSSL().cert_id = cert_id;
|
| - entry->GetSSL().cert_status = ssl_info_.cert_status;
|
| - entry->GetSSL().security_bits = ssl_info_.security_bits;
|
| + content::SignedCertificateTimestampStore* sct_store(
|
| + content::SignedCertificateTimestampStore::GetInstance());
|
| + content::SignedCertificateTimestampIDStatusList sct_ids;
|
| + for (const auto& sct_and_status : ssl_info_.signed_certificate_timestamps) {
|
| + const int sct_id(sct_store->Store(sct_and_status.sct.get(), process_id));
|
| + DCHECK(sct_id);
|
| + sct_ids.push_back(content::SignedCertificateTimestampIDAndStatus(
|
| + sct_id, sct_and_status.status));
|
| + }
|
| +
|
| + entry->GetSSL() =
|
| + content::SSLStatus(content::SECURITY_STYLE_AUTHENTICATION_BROKEN, cert_id,
|
| + sct_ids, ssl_info_);
|
| }
|
|
|
| // This handles the commands sent from the interstitial JavaScript.
|
|
|