#include "net/cert/multi_log_ct_verifier.h"
#include <string_view>
#include <vector>
#include "base/logging.h"
#include "base/metrics/histogram_macros.h"
#include "base/values.h"
#include "net/base/net_errors.h"
#include "net/cert/ct_log_verifier.h"
#include "net/cert/ct_objects_extractor.h"
#include "net/cert/ct_serialization.h"
#include "net/cert/ct_signed_certificate_timestamp_log_param.h"
#include "net/cert/sct_status_flags.h"
#include "net/cert/signed_certificate_timestamp_and_status.h"
#include "net/cert/x509_certificate.h"
#include "net/log/net_log_event_type.h"
#include "net/log/net_log_with_source.h"
namespace net {
namespace {
void LogSCTStatusToUMA(ct::SCTVerifyStatus status) { … }
void LogSCTOriginToUMA(ct::SignedCertificateTimestamp::Origin origin) { … }
void AddSCTAndLogStatus(scoped_refptr<ct::SignedCertificateTimestamp> sct,
ct::SCTVerifyStatus status,
SignedCertificateTimestampAndStatusList* sct_list) { … }
std::map<std::string, scoped_refptr<const CTLogVerifier>> CreateLogsMap(
const std::vector<scoped_refptr<const CTLogVerifier>>& log_verifiers) { … }
}
MultiLogCTVerifier::MultiLogCTVerifier(
const std::vector<scoped_refptr<const CTLogVerifier>>& log_verifiers)
: … { … }
MultiLogCTVerifier::~MultiLogCTVerifier() = default;
void MultiLogCTVerifier::Verify(
X509Certificate* cert,
std::string_view stapled_ocsp_response,
std::string_view sct_list_from_tls_extension,
SignedCertificateTimestampAndStatusList* output_scts,
const NetLogWithSource& net_log) const { … }
void MultiLogCTVerifier::VerifySCTs(
std::string_view encoded_sct_list,
const ct::SignedEntryData& expected_entry,
ct::SignedCertificateTimestamp::Origin origin,
X509Certificate* cert,
SignedCertificateTimestampAndStatusList* output_scts) const { … }
bool MultiLogCTVerifier::VerifySingleSCT(
scoped_refptr<ct::SignedCertificateTimestamp> sct,
const ct::SignedEntryData& expected_entry,
X509Certificate* cert,
SignedCertificateTimestampAndStatusList* output_scts) const { … }
}