OLD | NEW |
| (Empty) |
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. | |
4 | |
5 #ifndef REMOTING_HOST_HOST_KEY_PAIR_H_ | |
6 #define REMOTING_HOST_HOST_KEY_PAIR_H_ | |
7 | |
8 #include <string> | |
9 | |
10 #include "base/memory/ref_counted.h" | |
11 #include "base/memory/scoped_ptr.h" | |
12 | |
13 namespace crypto { | |
14 class RSAPrivateKey; | |
15 } // namespace base | |
16 | |
17 namespace remoting { | |
18 | |
19 class HostConfig; | |
20 class MutableHostConfig; | |
21 | |
22 class HostKeyPair { | |
23 public: | |
24 HostKeyPair(); | |
25 ~HostKeyPair(); | |
26 | |
27 void Generate(); | |
28 bool LoadFromString(const std::string& key_base64); | |
29 bool Load(const HostConfig& host_config); | |
30 void Save(MutableHostConfig* host_config); | |
31 | |
32 crypto::RSAPrivateKey* private_key() { return key_.get(); } | |
33 | |
34 std::string GetAsString() const; | |
35 std::string GetPublicKey() const; | |
36 std::string GetSignature(const std::string& message) const; | |
37 | |
38 // Make a new copy of private key. Caller will own the generated private key. | |
39 crypto::RSAPrivateKey* CopyPrivateKey() const; | |
40 | |
41 // Generates self-signed certificate using the key pair. Returns empty string | |
42 // if cert generation fails (e.g. it may happen when the system clock is off). | |
43 std::string GenerateCertificate() const; | |
44 | |
45 private: | |
46 scoped_ptr<crypto::RSAPrivateKey> key_; | |
47 }; | |
48 | |
49 } // namespace remoting | |
50 | |
51 #endif // REMOTING_HOST_HOST_KEY_PAIR_H_ | |
OLD | NEW |