Chromium Code Reviews| Index: remoting/host/client_session.h |
| diff --git a/remoting/host/client_session.h b/remoting/host/client_session.h |
| index f8923297df77816725a250ab44a445eb4edae483..70fd887ea64a07ec28f9481f63bf28fff2db8fe5 100644 |
| --- a/remoting/host/client_session.h |
| +++ b/remoting/host/client_session.h |
| @@ -8,6 +8,7 @@ |
| #include <string> |
| #include "base/memory/ref_counted.h" |
| +#include "base/memory/scoped_vector.h" |
| #include "base/memory/weak_ptr.h" |
| #include "base/sequenced_task_runner_helpers.h" |
| #include "base/threading/non_thread_safe.h" |
| @@ -15,6 +16,8 @@ |
| #include "base/timer/timer.h" |
| #include "remoting/host/client_session_control.h" |
| #include "remoting/host/gnubby_auth_handler.h" |
| +#include "remoting/host/host_extension.h" |
| +#include "remoting/host/host_extension_session.h" |
| #include "remoting/host/mouse_clamping_filter.h" |
| #include "remoting/host/remote_input_filter.h" |
| #include "remoting/protocol/clipboard_echo_filter.h" |
| @@ -64,6 +67,9 @@ class ClientSession |
| // Called after we've finished connecting all channels. |
| virtual void OnSessionChannelsConnected(ClientSession* client) = 0; |
| + // Called after client has reported capabilities. |
| + virtual void OnClientCapabilities(ClientSession* client) = 0; |
|
Wez
2014/05/28 23:03:41
All the other handlers are OnSession<Foo>; OnSessi
dcaiafa
2014/05/29 00:03:16
Done.
|
| + |
| // Called after authentication has failed. Must not tear down this |
| // object. OnSessionClosed() is notified after this handler |
| // returns. |
| @@ -88,7 +94,7 @@ class ClientSession |
| virtual ~EventHandler() {} |
| }; |
| - // |event_handler| and |desktop_environment_factory| must outlive |this|. |
| + // |event_handler|, |desktop_environment_factory| must outlive |this|. |
|
Wez
2014/05/28 23:03:41
nit: , -> and
dcaiafa
2014/05/29 00:03:16
Done.
|
| ClientSession( |
| EventHandler* event_handler, |
| scoped_refptr<base::SingleThreadTaskRunner> audio_task_runner, |
| @@ -103,6 +109,14 @@ class ClientSession |
| scoped_refptr<protocol::PairingRegistry> pairing_registry); |
| virtual ~ClientSession(); |
| + // Adds an extension to client to handle extension messages. |
| + void AddExtensionSession(scoped_ptr<HostExtensionSession> extension_session); |
| + |
| + // Adds one or more host capabilities in the form of a space-separated list of |
| + // words, to be reported to the client. |
| + // This must be called during the call to |OnSessionAuthenticated|. |
| + void AddHostCapabilities(const std::string& capability); |
| + |
| // protocol::HostStub interface. |
| virtual void NotifyClientResolution( |
| const protocol::ClientResolution& resolution) OVERRIDE; |
| @@ -148,7 +162,13 @@ class ClientSession |
| bool is_authenticated() { return auth_input_filter_.enabled(); } |
| + const std::string* client_capabilities() const { |
| + return client_capabilities_.get(); |
| + } |
| + |
| private: |
| + typedef ScopedVector<HostExtensionSession> HostExtensionSessionList; |
| + |
| // Creates a proxy for sending clipboard events to the client. |
| scoped_ptr<protocol::ClipboardStub> CreateClipboardProxy(); |
| @@ -244,6 +264,9 @@ class ClientSession |
| // Used to proxy gnubby auth traffic. |
| scoped_ptr<GnubbyAuthHandler> gnubby_auth_handler_; |
| + // Host extension sessions, used to handle extension messages. |
| + HostExtensionSessionList extension_sessions_; |
| + |
| DISALLOW_COPY_AND_ASSIGN(ClientSession); |
| }; |