Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(704)

Unified Diff: remoting/protocol/channel_authenticator.h

Issue 8604001: Move SSL layer initialization into ChannelAuthenticator implementations. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Simple->V1 Created 9 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « remoting/protocol/auth_util.cc ('k') | remoting/protocol/channel_authenticator.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: remoting/protocol/channel_authenticator.h
diff --git a/remoting/protocol/channel_authenticator.h b/remoting/protocol/channel_authenticator.h
index c925ea901cb349dc364c9050827b2c3c89a5379f..535730a90f77adc49b5255cd1ac5aa9dd58bde4e 100644
--- a/remoting/protocol/channel_authenticator.h
+++ b/remoting/protocol/channel_authenticator.h
@@ -8,93 +8,33 @@
#include <string>
#include "base/callback.h"
-#include "base/memory/ref_counted.h"
-#include "base/threading/non_thread_safe.h"
-#include "net/base/completion_callback.h"
+#include "net/base/net_errors.h"
namespace net {
-class DrainableIOBuffer;
-class GrowableIOBuffer;
-class SSLSocket;
+class StreamSocket;
} // namespace net
namespace remoting {
namespace protocol {
-class ChannelAuthenticator : public base::NonThreadSafe {
+// Interface for channel authentications that perform channel-level
+// authentication. Depending on implementation channel authenticators
+// may also establish SSL connection. Each instance of this interface
+// should be used only once for one channel.
+class ChannelAuthenticator {
public:
- enum Result {
- SUCCESS,
- FAILURE,
- };
-
- typedef base::Callback<void(Result)> DoneCallback;
-
- ChannelAuthenticator() { }
- virtual ~ChannelAuthenticator() { }
-
- // Starts authentication of the |socket|. |done_callback| is called
- // when authentication is finished. Caller retains ownership of
- // |socket|. |shared_secret| is a shared secret that we use to
- // authenticate the channel.
- virtual void Authenticate(net::SSLSocket* socket,
- const DoneCallback& done_callback) = 0;
-
- private:
- DISALLOW_COPY_AND_ASSIGN(ChannelAuthenticator);
-};
-
-class HostChannelAuthenticator : public ChannelAuthenticator {
- public:
- HostChannelAuthenticator(const std::string& shared_secret);
- virtual ~HostChannelAuthenticator();
-
- // ChannelAuthenticator overrides.
- virtual void Authenticate(net::SSLSocket* socket,
- const DoneCallback& done_callback) OVERRIDE;
-
- private:
- void DoAuthRead();
- void OnAuthBytesRead(int result);
- bool HandleAuthBytesRead(int result);
- bool VerifyAuthBytes(const std::string& received_auth_bytes);
-
- std::string shared_secret_;
- std::string auth_bytes_;
- net::SSLSocket* socket_;
- DoneCallback done_callback_;
-
- scoped_refptr<net::GrowableIOBuffer> auth_read_buf_;
-
- net::OldCompletionCallbackImpl<HostChannelAuthenticator> auth_read_callback_;
-
- DISALLOW_COPY_AND_ASSIGN(HostChannelAuthenticator);
-};
-
-class ClientChannelAuthenticator : public ChannelAuthenticator {
- public:
- ClientChannelAuthenticator(const std::string& shared_secret);
- virtual ~ClientChannelAuthenticator();
-
- // ChannelAuthenticator overrides.
- virtual void Authenticate(net::SSLSocket* socket,
- const DoneCallback& done_callback) OVERRIDE;
-
- private:
- void DoAuthWrite();
- void OnAuthBytesWritten(int result);
- bool HandleAuthBytesWritten(int result);
-
- std::string shared_secret_;
- net::SSLSocket* socket_;
- DoneCallback done_callback_;
-
- scoped_refptr<net::DrainableIOBuffer> auth_write_buf_;
-
- net::OldCompletionCallbackImpl<ClientChannelAuthenticator>
- auth_write_callback_;
-
- DISALLOW_COPY_AND_ASSIGN(ClientChannelAuthenticator);
+ typedef base::Callback<void(net::Error error, net::StreamSocket*)>
+ DoneCallback;
+
+ virtual ~ChannelAuthenticator() {}
+
+ // Start authentication of the given |socket|. Takes ownership of
+ // |socket|, and caller must not use |socket| after calling this
+ // method. |done_callback| is called when authentication is
+ // finished. Callback may be invoked before this method
+ // returns. Callback handler must take ownership of the result.
+ virtual void SecureAndAuthenticate(
+ net::StreamSocket* socket, const DoneCallback& done_callback) = 0;
};
} // namespace protocol
« no previous file with comments | « remoting/protocol/auth_util.cc ('k') | remoting/protocol/channel_authenticator.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698