// Copyright (c) 2012 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. #ifndef NET_SSL_CLIENT_CERT_STORE_H_ #define NET_SSL_CLIENT_CERT_STORE_H_ #include "base/callback_forward.h" #include "base/macros.h" #include "net/base/net_export.h" #include "net/cert/x509_certificate.h" #include "net/ssl/client_cert_identity.h" namespace net { class SSLCertRequestInfo; // A handle to a client certificate store to query matching certificates when a // server requests client auth. Note that there may be multiple ClientCertStore // objects corresponding to the same platform certificate store; each request // gets its own uniquely owned handle. class NET_EXPORT ClientCertStore { public: virtual ~ClientCertStore() {} using ClientCertListCallback = base::Callback; // Get client certs matching the |cert_request_info| and pass them to the // |callback|. The |callback| may be called sychronously. The caller must // ensure the ClientCertStore and |cert_request_info| remain alive until the // callback has been run. virtual void GetClientCerts(const SSLCertRequestInfo& cert_request_info, const ClientCertListCallback& callback) = 0; protected: ClientCertStore() {} private: DISALLOW_COPY_AND_ASSIGN(ClientCertStore); }; } // namespace net #endif // NET_SSL_CLIENT_CERT_STORE_H_