1 // Copyright (c) 2010 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef NET_BASE_OPENSSL_PRIVATE_KEY_STORE_H_
6 #define NET_BASE_OPENSSL_PRIVATE_KEY_STORE_H_
10 // Avoid including <openssl/evp.h>
11 typedef struct evp_pkey_st EVP_PKEY
;
13 #include "base/basictypes.h"
14 #include "net/base/net_export.h"
20 class X509Certificate
;
22 // OpenSSLPrivateKeyStore provides an interface for storing
23 // public/private key pairs to system storage on platforms where
25 // This class shall only be used from the network thread.
26 class NET_EXPORT OpenSSLPrivateKeyStore
{
28 // Called to permanently store a private/public key pair, generated
29 // via <keygen> while visiting |url|, to an appropriate system
30 // location. Increments |pkey|'s reference count, so the caller is still
31 // responsible for calling EVP_PKEY_free on it.
32 // |url| is the corresponding server URL.
33 // |pkey| is the key pair handle.
34 // Returns false if an error occurred whilst attempting to store the key.
35 static bool StoreKeyPair(const GURL
& url
, EVP_PKEY
* pkey
);
37 // Checks that the private key for a given public key is installed.
38 // |pub_key| a public key.
39 // Returns true if there is a private key that was previously
40 // recorded through StoreKeyPair().
41 // NOTE: Intentionally not implemented on Android because there is no
42 // platform API that can perform this operation silently.
43 static bool HasPrivateKey(EVP_PKEY
* pub_key
);
46 OpenSSLPrivateKeyStore(); // not implemented.
47 ~OpenSSLPrivateKeyStore(); // not implemented.
48 DISALLOW_COPY_AND_ASSIGN(OpenSSLPrivateKeyStore
);
53 #endif // NET_BASE_OPENSSL_PRIVATE_KEY_STORE_H_