45 lines
1.5 KiB
C
45 lines
1.5 KiB
C
|
|
// Copyright 2012 The Chromium Authors
|
||
|
|
// 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/functional/callback_forward.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:
|
||
|
|
ClientCertStore(const ClientCertStore&) = delete;
|
||
|
|
ClientCertStore& operator=(const ClientCertStore&) = delete;
|
||
|
|
|
||
|
|
virtual ~ClientCertStore() = default;
|
||
|
|
|
||
|
|
using ClientCertListCallback =
|
||
|
|
base::OnceCallback<void(ClientCertIdentityList)>;
|
||
|
|
|
||
|
|
// 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,
|
||
|
|
ClientCertListCallback callback) = 0;
|
||
|
|
|
||
|
|
protected:
|
||
|
|
ClientCertStore() = default;
|
||
|
|
};
|
||
|
|
|
||
|
|
} // namespace net
|
||
|
|
|
||
|
|
#endif // NET_SSL_CLIENT_CERT_STORE_H_
|