blob: 084d153a2de2acaa64684c73dc115e6ed6375d30 [file] [log] [blame]
[email protected]91e4b7f62012-01-25 23:23:021// Copyright (c) 2012 The Chromium Authors. All rights reserved.
[email protected]44f60762011-03-23 12:13:352// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef REMOTING_HOST_CLIENT_SESSION_H_
6#define REMOTING_HOST_CLIENT_SESSION_H_
7
[email protected]c78669c92011-06-13 22:42:388#include <list>
[email protected]c78669c92011-06-13 22:42:389
[email protected]60fc96002011-08-12 23:07:0510#include "base/time.h"
[email protected]ec6411872011-11-11 03:28:5511#include "base/threading/non_thread_safe.h"
[email protected]86cbe6b2012-04-03 00:56:1812#include "remoting/host/remote_input_filter.h"
[email protected]e265ad72012-03-16 17:28:0313#include "remoting/protocol/clipboard_stub.h"
[email protected]44f60762011-03-23 12:13:3514#include "remoting/protocol/connection_to_client.h"
[email protected]e265ad72012-03-16 17:28:0315#include "remoting/protocol/host_event_stub.h"
[email protected]44f60762011-03-23 12:13:3516#include "remoting/protocol/host_stub.h"
[email protected]86cbe6b2012-04-03 00:56:1817#include "remoting/protocol/input_event_tracker.h"
18#include "remoting/protocol/input_filter.h"
19#include "remoting/protocol/input_stub.h"
[email protected]f5d62e362012-04-30 20:54:3720#include "remoting/protocol/mouse_input_filter.h"
[email protected]bcad2682011-09-30 20:35:2621#include "third_party/skia/include/core/SkPoint.h"
[email protected]44f60762011-03-23 12:13:3522
23namespace remoting {
24
[email protected]995c2c6d2011-09-15 05:08:2525class Capturer;
[email protected]4ea2c7c2011-03-31 14:20:0626
[email protected]44f60762011-03-23 12:13:3527// A ClientSession keeps a reference to a connection to a client, and maintains
28// per-client state.
[email protected]e265ad72012-03-16 17:28:0329class ClientSession : public protocol::HostEventStub,
30 public protocol::HostStub,
[email protected]ee910fd2011-11-10 18:23:3131 public protocol::ConnectionToClient::EventHandler,
[email protected]ec6411872011-11-11 03:28:5532 public base::NonThreadSafe {
[email protected]44f60762011-03-23 12:13:3533 public:
34 // Callback interface for passing events to the ChromotingHost.
35 class EventHandler {
36 public:
37 virtual ~EventHandler() {}
38
[email protected]1f249e22011-11-29 20:19:5939 // Called after authentication has finished successfully.
[email protected]ee910fd2011-11-10 18:23:3140 virtual void OnSessionAuthenticated(ClientSession* client) = 0;
[email protected]1f249e22011-11-29 20:19:5941
[email protected]cba6f812012-03-27 01:01:5042 // Called after we've finished connecting all channels.
43 virtual void OnSessionChannelsConnected(ClientSession* client) = 0;
44
[email protected]1f249e22011-11-29 20:19:5945 // Called after authentication has failed. Must not tear down this
46 // object. OnSessionClosed() is notified after this handler
47 // returns.
48 virtual void OnSessionAuthenticationFailed(ClientSession* client) = 0;
49
50 // Called after connection has failed or after the client closed it.
[email protected]ee910fd2011-11-10 18:23:3151 virtual void OnSessionClosed(ClientSession* client) = 0;
[email protected]1f249e22011-11-29 20:19:5952
53 // Called to notify of each message's sequence number. The
54 // callback must not tear down this object.
[email protected]ee910fd2011-11-10 18:23:3155 virtual void OnSessionSequenceNumber(ClientSession* client,
56 int64 sequence_number) = 0;
[email protected]91e4b7f62012-01-25 23:23:0257
58 // Called on notification of a route change event, when a channel is
59 // connected.
[email protected]17af2ab2012-02-02 04:07:5260 virtual void OnSessionRouteChange(
61 ClientSession* client,
62 const std::string& channel_name,
[email protected]be451c82012-03-20 22:24:4763 const protocol::TransportRoute& route) = 0;
[email protected]44f60762011-03-23 12:13:3564 };
65
66 ClientSession(EventHandler* event_handler,
[email protected]3361e1f2012-03-20 20:31:4467 scoped_ptr<protocol::ConnectionToClient> connection,
[email protected]e265ad72012-03-16 17:28:0368 protocol::HostEventStub* host_event_stub,
[email protected]995c2c6d2011-09-15 05:08:2569 Capturer* capturer);
[email protected]ec6411872011-11-11 03:28:5570 virtual ~ClientSession();
[email protected]44f60762011-03-23 12:13:3571
[email protected]e265ad72012-03-16 17:28:0372 // protocol::ClipboardStub interface.
73 virtual void InjectClipboardEvent(
74 const protocol::ClipboardEvent& event) OVERRIDE;
75
[email protected]4ea2c7c2011-03-31 14:20:0676 // protocol::InputStub interface.
[email protected]6a6fe8062011-11-19 00:06:0277 virtual void InjectKeyEvent(const protocol::KeyEvent& event) OVERRIDE;
78 virtual void InjectMouseEvent(const protocol::MouseEvent& event) OVERRIDE;
[email protected]4ea2c7c2011-03-31 14:20:0679
[email protected]f2b9cf32012-04-27 00:13:4380 // protocol::HostStub interface.
81 virtual void NotifyClientDimensions(
82 const protocol::ClientDimensions& dimensions) OVERRIDE;
[email protected]50d71c72012-05-03 01:28:5583 virtual void ControlVideo(
84 const protocol::VideoControl& video_control) OVERRIDE;
[email protected]f2b9cf32012-04-27 00:13:4385
[email protected]ee910fd2011-11-10 18:23:3186 // protocol::ConnectionToClient::EventHandler interface.
[email protected]cba6f812012-03-27 01:01:5087 virtual void OnConnectionAuthenticated(
[email protected]ee910fd2011-11-10 18:23:3188 protocol::ConnectionToClient* connection) OVERRIDE;
[email protected]cba6f812012-03-27 01:01:5089 virtual void OnConnectionChannelsConnected(
[email protected]ee910fd2011-11-10 18:23:3190 protocol::ConnectionToClient* connection) OVERRIDE;
[email protected]cba6f812012-03-27 01:01:5091 virtual void OnConnectionClosed(protocol::ConnectionToClient* connection,
[email protected]204a9e32012-03-02 05:42:5892 protocol::ErrorCode error) OVERRIDE;
[email protected]ee910fd2011-11-10 18:23:3193 virtual void OnSequenceNumberUpdated(
94 protocol::ConnectionToClient* connection, int64 sequence_number) OVERRIDE;
[email protected]17af2ab2012-02-02 04:07:5295 virtual void OnRouteChange(
96 protocol::ConnectionToClient* connection,
97 const std::string& channel_name,
[email protected]be451c82012-03-20 22:24:4798 const protocol::TransportRoute& route) OVERRIDE;
[email protected]44f60762011-03-23 12:13:3599
[email protected]ee910fd2011-11-10 18:23:31100 // Disconnects the session and destroys the transport. Event handler
101 // is guaranteed not to be called after this method is called. Can
102 // be called multiple times. The object should not be used after
103 // this method returns.
104 void Disconnect();
[email protected]1ce457a2011-05-19 19:59:48105
[email protected]4ea2c7c2011-03-31 14:20:06106 protocol::ConnectionToClient* connection() const {
107 return connection_.get();
108 }
[email protected]44f60762011-03-23 12:13:35109
[email protected]f19d9bd2011-09-13 05:21:11110 const std::string& client_jid() { return client_jid_; }
111
[email protected]c78669c92011-06-13 22:42:38112 // Indicate that local mouse activity has been detected. This causes remote
113 // inputs to be ignored for a short time so that the local user will always
114 // have the upper hand in 'pointer wars'.
[email protected]bcad2682011-09-30 20:35:26115 void LocalMouseMoved(const SkIPoint& new_pos);
[email protected]c78669c92011-06-13 22:42:38116
[email protected]86cbe6b2012-04-03 00:56:18117 // Disable handling of input events from this client. If the client has any
118 // keys or mouse buttons pressed then these will be released.
119 void SetDisableInputs(bool disable_inputs);
[email protected]c78669c92011-06-13 22:42:38120
[email protected]44f60762011-03-23 12:13:35121 private:
[email protected]44f60762011-03-23 12:13:35122 EventHandler* event_handler_;
[email protected]4ea2c7c2011-03-31 14:20:06123
[email protected]4ea2c7c2011-03-31 14:20:06124 // The connection to the client.
[email protected]ec6411872011-11-11 03:28:55125 scoped_ptr<protocol::ConnectionToClient> connection_;
[email protected]44f60762011-03-23 12:13:35126
[email protected]f19d9bd2011-09-13 05:21:11127 std::string client_jid_;
128
[email protected]f5d62e362012-04-30 20:54:37129 // The host event stub to which this object delegates. This is the final
130 // element in the input pipeline, whose components appear in order below.
[email protected]e265ad72012-03-16 17:28:03131 protocol::HostEventStub* host_event_stub_;
[email protected]4ea2c7c2011-03-31 14:20:06132
[email protected]86cbe6b2012-04-03 00:56:18133 // Tracker used to release pressed keys and buttons when disconnecting.
134 protocol::InputEventTracker input_tracker_;
135
136 // Filter used to disable remote inputs during local input activity.
137 RemoteInputFilter remote_input_filter_;
138
[email protected]f5d62e362012-04-30 20:54:37139 // Filter used to clamp mouse events to the current display dimensions.
140 protocol::MouseInputFilter mouse_input_filter_;
141
[email protected]86cbe6b2012-04-03 00:56:18142 // Filter used to manage enabling & disabling of client input events.
143 protocol::InputFilter disable_input_filter_;
144
145 // Filter used to disable inputs when we're not authenticated.
146 protocol::InputFilter auth_input_filter_;
147
[email protected]995c2c6d2011-09-15 05:08:25148 // Capturer, used to determine current screen size for ensuring injected
149 // mouse events fall within the screen area.
150 // TODO(lambroslambrou): Move floor-control logic, and clamping to screen
151 // area, out of this class (crbug.com/96508).
152 Capturer* capturer_;
153
[email protected]44f60762011-03-23 12:13:35154 DISALLOW_COPY_AND_ASSIGN(ClientSession);
155};
156
157} // namespace remoting
158
159#endif // REMOTING_HOST_CLIENT_SESSION_H_