Blink roll 9cb8a59:1c10331 (svn 181953:181956)
[chromium-blink-merge.git] / remoting / base / rsa_key_pair.h
blobf5009b27e5c1334b7146f0832bf993f472589de7
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_
8 #include <string>
10 #include "base/memory/ref_counted.h"
11 #include "base/memory/scoped_ptr.h"
13 namespace crypto {
14 class RSAPrivateKey;
15 } // namespace crypto
17 namespace remoting {
19 class RsaKeyPair : public base::RefCountedThreadSafe<RsaKeyPair> {
20 public:
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
32 // clock is off).
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(); }
43 private:
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_