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

Unified Diff: net/cert/sth_distributor.cc

Issue 1968053002: Certificate Transparency: Notify STH Observers of known STHs (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Final operator, test changes 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/cert/sth_distributor.h ('k') | net/cert/sth_distributor_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/cert/sth_distributor.cc
diff --git a/net/cert/sth_distributor.cc b/net/cert/sth_distributor.cc
index 9d56c03fc8d4994b4a812d1b5d5a1bbd4acd5649..c511e27a1635036b016276fe489fa9e86e5d4c80 100644
--- a/net/cert/sth_distributor.cc
+++ b/net/cert/sth_distributor.cc
@@ -25,6 +25,16 @@ STHDistributor::STHDistributor()
STHDistributor::~STHDistributor() {}
void STHDistributor::NewSTHObserved(const SignedTreeHead& sth) {
+ auto it = std::find_if(observed_sths_.begin(), observed_sths_.end(),
+ [&sth](const SignedTreeHead& other) {
+ return sth.log_id == other.log_id;
+ });
+
+ if (it == observed_sths_.end())
+ observed_sths_.push_back(sth);
+ else
+ *it = sth;
+
FOR_EACH_OBSERVER(STHObserver, observer_list_, NewSTHObserved(sth));
if (sth.log_id.compare(0, sth.log_id.size(),
@@ -40,6 +50,13 @@ void STHDistributor::NewSTHObserved(const SignedTreeHead& sth) {
void STHDistributor::RegisterObserver(STHObserver* observer) {
observer_list_.AddObserver(observer);
+ // Make a local copy, because notifying the |observer| of a
+ // new STH may result in this class being notified of a
+ // (different) new STH, thus invalidating the iterator.
+ std::vector<SignedTreeHead> local_sths(observed_sths_);
+
+ for (const auto& sth : local_sths)
+ observer->NewSTHObserved(sth);
}
void STHDistributor::UnregisterObserver(STHObserver* observer) {
« no previous file with comments | « net/cert/sth_distributor.h ('k') | net/cert/sth_distributor_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698