Chromium Code Reviews| Index: net/cert/internal/cert_issuer_source_static.cc |
| diff --git a/net/cert/internal/cert_issuer_source_static.cc b/net/cert/internal/cert_issuer_source_static.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..c7685f436a1bbf45b703e26b08614535eba21c5f |
| --- /dev/null |
| +++ b/net/cert/internal/cert_issuer_source_static.cc |
| @@ -0,0 +1,36 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "net/cert/internal/cert_issuer_source_static.h" |
| + |
| +#include "net/cert/internal/parsed_certificate.h" |
| + |
| +namespace net { |
| + |
| +CertIssuerSourceStatic::CertIssuerSourceStatic() = default; |
| +CertIssuerSourceStatic::~CertIssuerSourceStatic() = default; |
| + |
| +void CertIssuerSourceStatic::AddCert(scoped_refptr<ParsedCertificate> cert) { |
| + intermediates_.insert(std::make_pair( |
| + cert->normalized_subject().AsStringPiece(), std::move(cert))); |
| +} |
| + |
| +void CertIssuerSourceStatic::SyncGetIssuersOf( |
| + const ParsedCertificate* cert, |
| + std::vector<scoped_refptr<ParsedCertificate>>* issuers) { |
| + auto range = |
| + intermediates_.equal_range(cert->normalized_issuer().AsStringPiece()); |
| + for (auto it = range.first; it != range.second; ++it) |
| + issuers->push_back(it->second); |
| +} |
| + |
| +void CertIssuerSourceStatic::AsyncGetIssuersOf( |
| + const ParsedCertificate* cert, |
| + const IssuerCallback& issuers_callback, |
| + std::unique_ptr<Request>* out_req) { |
| + // CertIssuerSourceStatic never returns asynchronous results. |
| + out_req->reset(); |
|
eroman
2016/06/01 23:30:23
should we reset out_req too?
mattm
2016/06/01 23:48:33
Isn't that what it's doing?
eroman
2016/06/01 23:53:06
.... yeah.....
sorry, dunno what my brain did righ
|
| +} |
| + |
| +} // namespace net |