1 // Copyright (c) 2012 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 REMOTING_BASE_RSA_KEY_PAIR_H_
6 #define REMOTING_BASE_RSA_KEY_PAIR_H_
10 #include "base/memory/ref_counted.h"
11 #include "base/memory/scoped_ptr.h"
19 class RsaKeyPair
: public base::RefCountedThreadSafe
<RsaKeyPair
> {
21 // Generates a new (random) private key.
22 static scoped_refptr
<RsaKeyPair
> Generate();
24 // Loads a private key from a base64-encoded string. Returns true on success.
25 static scoped_refptr
<RsaKeyPair
> FromString(const std::string
& key_base64
);
27 // Returns a base64 encoded string representing the private key.
28 std::string
ToString() const;
30 // Generates a DER-encoded self-signed certificate using the key pair. Returns
31 // empty string if cert generation fails (e.g. it may happen when the system
33 std::string
GenerateCertificate() const;
35 // Returns a base64-encoded string representing the public key.
36 std::string
GetPublicKey() const;
38 // Returns a base64-encoded signature for the message.
39 std::string
SignMessage(const std::string
& message
) const;
41 crypto::RSAPrivateKey
* private_key() { return key_
.get(); }
44 friend class base::RefCountedThreadSafe
<RsaKeyPair
>;
45 RsaKeyPair(scoped_ptr
<crypto::RSAPrivateKey
> key
);
46 virtual ~RsaKeyPair();
48 scoped_ptr
<crypto::RSAPrivateKey
> key_
;
50 DISALLOW_COPY_AND_ASSIGN(RsaKeyPair
);
53 } // namespace remoting
55 #endif // REMOTING_BASE_RSA_KEY_PAIR_H_