Index: remoting/protocol/host_control_dispatcher.cc |
diff --git a/remoting/protocol/host_control_dispatcher.cc b/remoting/protocol/host_control_dispatcher.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4e9d28fd49daa349c1acd6635aa6bf47f9ab7c6d |
--- /dev/null |
+++ b/remoting/protocol/host_control_dispatcher.cc |
@@ -0,0 +1,56 @@ |
+// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "remoting/protocol/host_control_dispatcher.h" |
+ |
+#include "remoting/protocol/buffered_socket_writer.h" |
Wez
2011/11/17 02:03:40
This belongs after the remoting/proto/ includes?
Sergey Ulanov
2011/11/17 18:38:14
Done.
|
+#include "remoting/proto/control.pb.h" |
+#include "remoting/proto/internal.pb.h" |
+#include "remoting/protocol/host_stub.h" |
+#include "remoting/protocol/session.h" |
+#include "remoting/protocol/util.h" |
+ |
+namespace remoting { |
+namespace protocol { |
+ |
+HostControlDispatcher::HostControlDispatcher( |
+ base::MessageLoopProxy* message_loop) |
+ : host_stub_(NULL), |
+ writer_(new BufferedSocketWriter(message_loop)) { |
+} |
+ |
+HostControlDispatcher::~HostControlDispatcher() { |
+ Close(); |
+} |
+ |
+void HostControlDispatcher::Init(Session* session, HostStub* host_stub) { |
+ DCHECK(session); |
+ DCHECK(host_stub); |
+ |
+ host_stub_ = host_stub; |
+ |
+ reader_.Init(session->control_channel(), base::Bind( |
+ &HostControlDispatcher::OnMessageReceived, base::Unretained(this))); |
+ writer_->Init(session->control_channel(), |
+ BufferedSocketWriter::WriteFailedCallback()); |
+ |
+ // Write legacy BeginSession message. |
+ protocol::ControlMessage message; |
+ message.mutable_begin_session_deprecated()->mutable_login_status()-> |
+ set_success(true); |
+ writer_->Write(SerializeAndFrameMessage(message), base::Closure()); |
Wez
2011/11/17 02:03:40
Is it really the dispatcher's responsibility to do
Sergey Ulanov
2011/11/17 18:38:14
I'd like to hide version-dependent details inside
|
+} |
+ |
+void HostControlDispatcher::OnMessageReceived( |
+ ControlMessage* message, const base::Closure& done_task) { |
+ LOG(WARNING) << "Invalid control message received."; |
Wez
2011/11/17 02:03:40
nit: Not "invalid", just "unknown"!
Sergey Ulanov
2011/11/17 18:38:14
Done.
|
+ done_task.Run(); |
+} |
+ |
+void HostControlDispatcher::Close() { |
+ writer_->Close(); |
+} |
+ |
+} // namespace protocol |
+} // namespace remoting |