60 lines
2.2 KiB
C
60 lines
2.2 KiB
C
|
|
// Copyright 2013 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_MAC_H_
|
||
|
|
#define NET_SSL_CLIENT_CERT_STORE_MAC_H_
|
||
|
|
|
||
|
|
#include "base/functional/callback.h"
|
||
|
|
#include "net/base/net_export.h"
|
||
|
|
#include "net/ssl/client_cert_store.h"
|
||
|
|
#include "net/ssl/ssl_cert_request_info.h"
|
||
|
|
|
||
|
|
namespace net {
|
||
|
|
|
||
|
|
class ClientCertIdentityMac;
|
||
|
|
|
||
|
|
class NET_EXPORT ClientCertStoreMac : public ClientCertStore {
|
||
|
|
public:
|
||
|
|
ClientCertStoreMac();
|
||
|
|
|
||
|
|
ClientCertStoreMac(const ClientCertStoreMac&) = delete;
|
||
|
|
ClientCertStoreMac& operator=(const ClientCertStoreMac&) = delete;
|
||
|
|
|
||
|
|
~ClientCertStoreMac() override;
|
||
|
|
|
||
|
|
// ClientCertStore:
|
||
|
|
void GetClientCerts(const SSLCertRequestInfo& cert_request_info,
|
||
|
|
ClientCertListCallback callback) override;
|
||
|
|
|
||
|
|
private:
|
||
|
|
// TODO(https://crbug.com/1302761): Improve test coverage and remove/reduce
|
||
|
|
// the friend tests and ForTesting methods.
|
||
|
|
friend class ClientCertStoreMacTest;
|
||
|
|
friend class ClientCertStoreMacTestDelegate;
|
||
|
|
|
||
|
|
// A hook for testing. Filters |input_identities| using the logic being used
|
||
|
|
// to filter the system store when GetClientCerts() is called. Implemented by
|
||
|
|
// creating a list of certificates that otherwise would be extracted from the
|
||
|
|
// system store and filtering it using the common logic (less adequate than
|
||
|
|
// the approach used on Windows).
|
||
|
|
bool SelectClientCertsForTesting(
|
||
|
|
std::vector<std::unique_ptr<ClientCertIdentityMac>> input_identities,
|
||
|
|
const SSLCertRequestInfo& cert_request_info,
|
||
|
|
ClientCertIdentityList* selected_identities);
|
||
|
|
|
||
|
|
// Testing hook specific to Mac, where the internal logic recognizes preferred
|
||
|
|
// certificates for particular domains. If the preferred certificate is
|
||
|
|
// present in the output list (i.e. it doesn't get filtered out), it should
|
||
|
|
// always come first.
|
||
|
|
bool SelectClientCertsGivenPreferredForTesting(
|
||
|
|
std::unique_ptr<ClientCertIdentityMac> preferred_identity,
|
||
|
|
std::vector<std::unique_ptr<ClientCertIdentityMac>> regular_identities,
|
||
|
|
const SSLCertRequestInfo& request,
|
||
|
|
ClientCertIdentityList* selected_identities);
|
||
|
|
};
|
||
|
|
|
||
|
|
} // namespace net
|
||
|
|
|
||
|
|
#endif // NET_SSL_CLIENT_CERT_STORE_MAC_H_
|