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_NEGOTIATING_AUTHENTICATOR_H_ | 5 #ifndef REMOTING_PROTOCOL_NEGOTIATING_AUTHENTICATOR_H_ |
6 #define REMOTING_PROTOCOL_NEGOTIATING_AUTHENTICATOR_H_ | 6 #define REMOTING_PROTOCOL_NEGOTIATING_AUTHENTICATOR_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
12 #include "base/memory/ref_counted.h" | 12 #include "base/memory/ref_counted.h" |
13 #include "base/memory/scoped_ptr.h" | 13 #include "base/memory/scoped_ptr.h" |
14 #include "base/memory/weak_ptr.h" | 14 #include "base/memory/weak_ptr.h" |
15 #include "remoting/protocol/authenticator.h" | 15 #include "remoting/protocol/authenticator.h" |
16 #include "remoting/protocol/authentication_method.h" | 16 #include "remoting/protocol/authentication_method.h" |
17 #include "remoting/protocol/third_party_host_authenticator.h" | |
17 | 18 |
18 namespace remoting { | 19 namespace remoting { |
19 | 20 |
20 class RsaKeyPair; | 21 class RsaKeyPair; |
21 | 22 |
22 namespace protocol { | 23 namespace protocol { |
23 | 24 |
24 typedef base::Callback<void(const std::string& secret)> SecretFetchedCallback; | 25 typedef base::Callback<void(const std::string& secret)> SecretFetchedCallback; |
25 typedef base::Callback<void( | 26 typedef base::Callback<void( |
26 const SecretFetchedCallback& secret_fetched_callback)> FetchSecretCallback; | 27 const SecretFetchedCallback& secret_fetched_callback)> FetchSecretCallback; |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
68 public: | 69 public: |
69 virtual ~NegotiatingAuthenticator(); | 70 virtual ~NegotiatingAuthenticator(); |
70 | 71 |
71 // Creates a client authenticator for the given methods. | 72 // Creates a client authenticator for the given methods. |
72 static scoped_ptr<Authenticator> CreateForClient( | 73 static scoped_ptr<Authenticator> CreateForClient( |
73 const std::string& authentication_tag, | 74 const std::string& authentication_tag, |
74 const FetchSecretCallback& fetch_secret_callback, | 75 const FetchSecretCallback& fetch_secret_callback, |
75 const std::vector<AuthenticationMethod>& methods); | 76 const std::vector<AuthenticationMethod>& methods); |
76 | 77 |
77 // Creates a host authenticator, using a fixed shared secret/PIN hash. | 78 // Creates a host authenticator, using a fixed shared secret/PIN hash. |
78 static scoped_ptr<Authenticator> CreateForHost( | 79 static scoped_ptr<Authenticator> CreateForHostSharedSecret( |
Sergey Ulanov
2013/03/28 22:34:54
maybe CreateForHostWithSharedSecret()?
rmsousa
2013/04/04 22:13:43
Done.
| |
79 const std::string& local_cert, | 80 const std::string& local_cert, |
80 scoped_refptr<RsaKeyPair> key_pair, | 81 scoped_refptr<RsaKeyPair> key_pair, |
81 const std::string& shared_secret_hash, | 82 const std::string& shared_secret_hash, |
82 AuthenticationMethod::HashFunction hash_function); | 83 AuthenticationMethod::HashFunction hash_function); |
83 | 84 |
85 // Creates a host authenticator, using third party authentication. | |
86 static scoped_ptr<Authenticator> CreateForHostThirdParty( | |
87 const std::string& local_cert, | |
88 scoped_refptr<RsaKeyPair> key_pair, | |
89 const GURL& token_url, | |
90 const GURL& token_validation_url, | |
91 const std::string& local_jid, | |
92 const std::string& remote_jid, | |
93 ThirdPartyHostAuthenticator::TokenValidatorFactory* | |
94 token_validator_factory); | |
95 | |
84 // Authenticator interface. | 96 // Authenticator interface. |
85 virtual State state() const OVERRIDE; | 97 virtual State state() const OVERRIDE; |
86 virtual RejectionReason rejection_reason() const OVERRIDE; | 98 virtual RejectionReason rejection_reason() const OVERRIDE; |
87 virtual void ProcessMessage(const buzz::XmlElement* message, | 99 virtual void ProcessMessage(const buzz::XmlElement* message, |
88 const base::Closure& resume_callback) OVERRIDE; | 100 const base::Closure& resume_callback) OVERRIDE; |
89 virtual scoped_ptr<buzz::XmlElement> GetNextMessage() OVERRIDE; | 101 virtual scoped_ptr<buzz::XmlElement> GetNextMessage() OVERRIDE; |
90 virtual scoped_ptr<ChannelAuthenticator> | 102 virtual scoped_ptr<ChannelAuthenticator> |
91 CreateChannelAuthenticator() const OVERRIDE; | 103 CreateChannelAuthenticator() const OVERRIDE; |
92 | 104 |
93 private: | 105 private: |
(...skipping 22 matching lines...) Expand all Loading... | |
116 void CreateV2AuthenticatorWithSecret( | 128 void CreateV2AuthenticatorWithSecret( |
117 Authenticator::State initial_state, | 129 Authenticator::State initial_state, |
118 const base::Closure& resume_callback, | 130 const base::Closure& resume_callback, |
119 const std::string& shared_secret); | 131 const std::string& shared_secret); |
120 | 132 |
121 bool is_host_side() const; | 133 bool is_host_side() const; |
122 | 134 |
123 // Used only for host authenticators. | 135 // Used only for host authenticators. |
124 std::string local_cert_; | 136 std::string local_cert_; |
125 scoped_refptr<RsaKeyPair> local_key_pair_; | 137 scoped_refptr<RsaKeyPair> local_key_pair_; |
138 | |
139 // Used only for shared secret host authenticators. | |
126 std::string shared_secret_hash_; | 140 std::string shared_secret_hash_; |
127 | 141 |
142 // Used only for third party host authenticators. | |
143 std::string local_jid_; | |
144 std::string remote_jid_; | |
145 GURL token_url_; | |
146 GURL token_validation_url_; | |
147 ThirdPartyHostAuthenticator::TokenValidatorFactory* token_validator_factory_; | |
148 | |
128 // Used only for client authenticators. | 149 // Used only for client authenticators. |
129 std::string authentication_tag_; | 150 std::string authentication_tag_; |
130 FetchSecretCallback fetch_secret_callback_; | 151 FetchSecretCallback fetch_secret_callback_; |
131 | 152 |
132 // Used for both host and client authenticators. | 153 // Used for both host and client authenticators. |
133 std::vector<AuthenticationMethod> methods_; | 154 std::vector<AuthenticationMethod> methods_; |
134 AuthenticationMethod current_method_; | 155 AuthenticationMethod current_method_; |
135 scoped_ptr<Authenticator> current_authenticator_; | 156 scoped_ptr<Authenticator> current_authenticator_; |
136 State state_; | 157 State state_; |
137 RejectionReason rejection_reason_; | 158 RejectionReason rejection_reason_; |
138 | 159 |
139 base::WeakPtrFactory<NegotiatingAuthenticator> weak_factory_; | 160 base::WeakPtrFactory<NegotiatingAuthenticator> weak_factory_; |
140 | 161 |
141 DISALLOW_COPY_AND_ASSIGN(NegotiatingAuthenticator); | 162 DISALLOW_COPY_AND_ASSIGN(NegotiatingAuthenticator); |
142 }; | 163 }; |
143 | 164 |
144 } // namespace protocol | 165 } // namespace protocol |
145 } // namespace remoting | 166 } // namespace remoting |
146 | 167 |
147 #endif // REMOTING_PROTOCOL_NEGOTIATING_AUTHENTICATOR_H_ | 168 #endif // REMOTING_PROTOCOL_NEGOTIATING_AUTHENTICATOR_H_ |
OLD | NEW |