OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef REMOTING_PROTOCOL_SSL_HMAC_CHANNEL_AUTHENTICATOR_H_ | 5 #ifndef REMOTING_PROTOCOL_SSL_HMAC_CHANNEL_AUTHENTICATOR_H_ |
6 #define REMOTING_PROTOCOL_SSL_HMAC_CHANNEL_AUTHENTICATOR_H_ | 6 #define REMOTING_PROTOCOL_SSL_HMAC_CHANNEL_AUTHENTICATOR_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/callback.h" | 10 #include "base/callback.h" |
11 #include "base/memory/ref_counted.h" | 11 #include "base/memory/ref_counted.h" |
12 #include "base/memory/scoped_ptr.h" | 12 #include "base/memory/scoped_ptr.h" |
13 #include "base/threading/non_thread_safe.h" | 13 #include "base/threading/non_thread_safe.h" |
14 #include "remoting/protocol/channel_authenticator.h" | 14 #include "remoting/protocol/channel_authenticator.h" |
15 | 15 |
16 namespace net { | 16 namespace net { |
| 17 class CertVerifier; |
17 class DrainableIOBuffer; | 18 class DrainableIOBuffer; |
18 class GrowableIOBuffer; | 19 class GrowableIOBuffer; |
19 class SSLSocket; | 20 class SSLSocket; |
20 class TransportSecurityState; | 21 class TransportSecurityState; |
21 } // namespace net | 22 } // namespace net |
22 | 23 |
23 namespace remoting { | 24 namespace remoting { |
24 | 25 |
25 class RsaKeyPair; | 26 class RsaKeyPair; |
26 | 27 |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
70 void OnAuthBytesWritten(int result); | 71 void OnAuthBytesWritten(int result); |
71 bool HandleAuthBytesWritten(int result, bool* callback_called); | 72 bool HandleAuthBytesWritten(int result, bool* callback_called); |
72 | 73 |
73 void ReadAuthenticationBytes(); | 74 void ReadAuthenticationBytes(); |
74 void OnAuthBytesRead(int result); | 75 void OnAuthBytesRead(int result); |
75 bool HandleAuthBytesRead(int result); | 76 bool HandleAuthBytesRead(int result); |
76 bool VerifyAuthBytes(const std::string& received_auth_bytes); | 77 bool VerifyAuthBytes(const std::string& received_auth_bytes); |
77 | 78 |
78 void CheckDone(bool* callback_called); | 79 void CheckDone(bool* callback_called); |
79 void NotifyError(int error); | 80 void NotifyError(int error); |
80 void CallDoneCallback(int error, scoped_ptr<net::StreamSocket> socket); | |
81 | 81 |
82 // The mutual secret used for authentication. | 82 // The mutual secret used for authentication. |
83 std::string auth_key_; | 83 std::string auth_key_; |
84 | 84 |
85 // Used in the SERVER mode only. | 85 // Used in the SERVER mode only. |
86 std::string local_cert_; | 86 std::string local_cert_; |
87 scoped_refptr<RsaKeyPair> local_key_pair_; | 87 scoped_refptr<RsaKeyPair> local_key_pair_; |
88 | 88 |
89 // Used in the CLIENT mode only. | 89 // Used in the CLIENT mode only. |
90 std::string remote_cert_; | 90 std::string remote_cert_; |
91 scoped_ptr<net::TransportSecurityState> transport_security_state_; | 91 scoped_ptr<net::TransportSecurityState> transport_security_state_; |
| 92 scoped_ptr<net::CertVerifier> cert_verifier_; |
92 | 93 |
93 scoped_ptr<net::SSLSocket> socket_; | 94 scoped_ptr<net::SSLSocket> socket_; |
94 DoneCallback done_callback_; | 95 DoneCallback done_callback_; |
95 | 96 |
96 scoped_refptr<net::DrainableIOBuffer> auth_write_buf_; | 97 scoped_refptr<net::DrainableIOBuffer> auth_write_buf_; |
97 scoped_refptr<net::GrowableIOBuffer> auth_read_buf_; | 98 scoped_refptr<net::GrowableIOBuffer> auth_read_buf_; |
98 | 99 |
99 DISALLOW_COPY_AND_ASSIGN(SslHmacChannelAuthenticator); | 100 DISALLOW_COPY_AND_ASSIGN(SslHmacChannelAuthenticator); |
100 }; | 101 }; |
101 | 102 |
102 } // namespace protocol | 103 } // namespace protocol |
103 } // namespace remoting | 104 } // namespace remoting |
104 | 105 |
105 #endif // REMOTING_PROTOCOL_SSL_HMAC_CHANNEL_AUTHENTICATOR_H_ | 106 #endif // REMOTING_PROTOCOL_SSL_HMAC_CHANNEL_AUTHENTICATOR_H_ |
OLD | NEW |