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

Side by Side Diff: components/certificate_transparency/tree_state_tracker.cc

Issue 1845113003: Certificate Transparency: Start tracking logs' state (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressing review comments Created 4 years, 7 months 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
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "components/certificate_transparency/tree_state_tracker.h"
6
7 #include "components/certificate_transparency/single_tree_tracker.h"
8 #include "net/cert/ct_log_verifier.h"
9 #include "net/cert/signed_certificate_timestamp.h"
10 #include "net/cert/signed_tree_head.h"
11 #include "net/cert/x509_certificate.h"
12
13 using net::X509Certificate;
14 using net::CTLogVerifier;
15 using net::ct::SignedCertificateTimestamp;
16 using net::ct::SignedTreeHead;
17
18 namespace certificate_transparency {
19
20 TreeStateTracker::TreeStateTracker(
21 std::vector<scoped_refptr<const CTLogVerifier>> ct_logs) {
22 for (const auto& log : ct_logs)
23 tree_trackers_[log->key_id()].reset(new SingleTreeTracker(log));
24 }
25
26 TreeStateTracker::~TreeStateTracker() {}
27
28 void TreeStateTracker::OnSCTVerified(X509Certificate* cert,
29 const SignedCertificateTimestamp* sct) {
30 auto it = tree_trackers_.find(sct->log_id);
31 // Ensure the SCT is from a known log.
32 DCHECK(it != tree_trackers_.end());
33
34 it->second->OnSCTVerified(cert, sct);
35 }
36
37 void TreeStateTracker::NewSTHObserved(const SignedTreeHead& sth) {
38 auto it = tree_trackers_.find(sth.log_id);
39 // Is the STH from a known log? Since STHs provided via the
40 // component updater can be for logs not yet recognized older clients
41 // return, rather than DCHECK.
42 if (it == tree_trackers_.end())
43 return;
44
45 it->second->NewSTHObserved(sth);
46 }
47
48 } // namespace certificate_transparency
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698