blob: 3c7672f44a060ac2786378582e462e6a2b6c723e [file] [log] [blame]
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +00001/* Copyright (C) 2002-2005 RealVNC Ltd. All Rights Reserved.
Pierre Ossmana3ac01e2011-11-07 21:13:54 +00002 * Copyright 2009-2011 Pierre Ossman for Cendio AB
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +00003 *
4 * This is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
8 *
9 * This software is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this software; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
17 * USA.
18 */
19
20//
21// VNCSConnectionST is our derived class of SConnection for VNCServerST - there
22// is one for each connected client. We think of VNCSConnectionST as part of
23// the VNCServerST implementation, so its methods are allowed full access to
24// members of VNCServerST.
25//
26
27#ifndef __RFB_VNCSCONNECTIONST_H__
28#define __RFB_VNCSCONNECTIONST_H__
29
30#include <set>
31#include <rfb/SConnection.h>
32#include <rfb/SMsgWriter.h>
33#include <rfb/TransImageGetter.h>
34#include <rfb/VNCServerST.h>
Pierre Ossman1bb8b6c2011-10-25 15:20:05 +000035#include <rfb/Timer.h>
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000036
Pierre Ossman1b478e52011-11-15 12:08:30 +000037struct RTTInfo;
38
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000039namespace rfb {
40 class VNCSConnectionST : public SConnection,
Pierre Ossman1bb8b6c2011-10-25 15:20:05 +000041 public WriteSetCursorCallback,
42 public Timer::Callback {
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000043 public:
44 VNCSConnectionST(VNCServerST* server_, network::Socket* s, bool reverse);
45 virtual ~VNCSConnectionST();
46
47 // Methods called from VNCServerST. None of these methods ever knowingly
48 // throw an exception.
49
50 // Unless otherwise stated, the SConnectionST may not be valid after any of
51 // these methods are called, since they catch exceptions and may have
52 // called close() which deletes the object.
53
54 // init() must be called to initialise the protocol. If it fails it
55 // returns false, and close() will have been called.
56 bool init();
57
58 // close() shuts down the socket to the client and deletes the
59 // SConnectionST object.
60 void close(const char* reason);
61
62 // processMessages() processes incoming messages from the client, invoking
63 // various callbacks as a result. It continues to process messages until
64 // reading might block. shutdown() will be called on the connection's
65 // Socket if an error occurs, via the close() call.
66 void processMessages();
67
Pierre Ossmana3ac01e2011-11-07 21:13:54 +000068 // Called when the underlying pixelbuffer is resized or replaced.
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000069 void pixelBufferChange();
Pierre Ossmana3ac01e2011-11-07 21:13:54 +000070
71 // Wrappers to make these methods "safe" for VNCServerST.
72 void writeFramebufferUpdateOrClose();
73 void screenLayoutChangeOrClose(rdr::U16 reason);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000074 void setCursorOrClose();
Pierre Ossmana3ac01e2011-11-07 21:13:54 +000075 void bellOrClose();
76 void serverCutTextOrClose(const char *str, int len);
77 void setDesktopNameOrClose(const char *name);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000078
79 // checkIdleTimeout() returns the number of milliseconds left until the
80 // idle timeout expires. If it has expired, the connection is closed and
81 // zero is returned. Zero is also returned if there is no idle timeout.
82 int checkIdleTimeout();
83
84 // The following methods never throw exceptions nor do they ever delete the
85 // SConnectionST object.
86
Pierre Ossmanb114cec2011-11-20 15:36:11 +000087 // getComparerState() returns if this client would like the framebuffer
88 // comparer to be enabled.
89 bool getComparerState();
90
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000091 // renderedCursorChange() is called whenever the server-side rendered
92 // cursor changes shape or position. It ensures that the next update will
93 // clean up the old rendered cursor and if necessary draw the new rendered
94 // cursor.
95 void renderedCursorChange();
96
97 // needRenderedCursor() returns true if this client needs the server-side
98 // rendered cursor. This may be because it does not support local cursor
99 // or because the current cursor position has not been set by this client.
100 bool needRenderedCursor();
101
102 network::Socket* getSock() { return sock; }
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000103 void add_changed(const Region& region) { updates.add_changed(region); }
104 void add_copied(const Region& dest, const Point& delta) {
105 updates.add_copied(dest, delta);
106 }
107
108 const char* getPeerEndpoint() const {return peerEndpoint.buf;}
109
110 // approveConnectionOrClose() is called some time after
111 // VNCServerST::queryConnection() has returned with PENDING to accept or
112 // reject the connection. The accept argument should be true for
113 // acceptance, or false for rejection, in which case a string reason may
114 // also be given.
115
116 void approveConnectionOrClose(bool accept, const char* reason);
117
118 char* getStartTime();
119
120 void setStatus(int status);
121 int getStatus();
122
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000123 private:
124 // SConnection callbacks
125
126 // These methods are invoked as callbacks from processMsg(). Note that
127 // none of these methods should call any of the above methods which may
128 // delete the SConnectionST object.
129
130 virtual void authSuccess();
131 virtual void queryConnection(const char* userName);
132 virtual void clientInit(bool shared);
133 virtual void setPixelFormat(const PixelFormat& pf);
134 virtual void pointerEvent(const Point& pos, int buttonMask);
135 virtual void keyEvent(rdr::U32 key, bool down);
136 virtual void clientCutText(const char* str, int len);
137 virtual void framebufferUpdateRequest(const Rect& r, bool incremental);
Pierre Ossman34bb0612009-03-21 21:16:14 +0000138 virtual void setDesktopSize(int fb_width, int fb_height,
139 const ScreenSet& layout);
Pierre Ossman2c764942011-11-14 15:54:30 +0000140 virtual void fence(rdr::U32 flags, unsigned len, const char data[]);
Pierre Ossman1b478e52011-11-15 12:08:30 +0000141 virtual void enableContinuousUpdates(bool enable,
142 int x, int y, int w, int h);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000143 virtual void supportsLocalCursor();
Pierre Ossman2c764942011-11-14 15:54:30 +0000144 virtual void supportsFence();
Pierre Ossman1b478e52011-11-15 12:08:30 +0000145 virtual void supportsContinuousUpdates();
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000146
147 // setAccessRights() allows a security package to limit the access rights
148 // of a VNCSConnectioST to the server. These access rights are applied
149 // such that the actual rights granted are the minimum of the server's
150 // default access settings and the connection's access settings.
151 virtual void setAccessRights(AccessRights ar) {accessRights=ar;}
152
153 // WriteSetCursorCallback
154 virtual void writeSetCursorCallback();
155
Pierre Ossman1bb8b6c2011-10-25 15:20:05 +0000156 // Timer callbacks
157 virtual bool handleTimeout(Timer* t);
158
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000159 // Internal methods
160
Pierre Ossman1b478e52011-11-15 12:08:30 +0000161 // Congestion control
162 void writeRTTPing();
163 void handleRTTPong(const struct RTTInfo &rttInfo);
Pierre Ossman1bb8b6c2011-10-25 15:20:05 +0000164 bool isCongested();
Pierre Ossman1b478e52011-11-15 12:08:30 +0000165 void updateCongestion();
Pierre Ossman1bb8b6c2011-10-25 15:20:05 +0000166
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000167 // writeFramebufferUpdate() attempts to write a framebuffer update to the
168 // client.
169
170 void writeFramebufferUpdate();
171
172 void writeRenderedCursorRect();
Pierre Ossmana3ac01e2011-11-07 21:13:54 +0000173 void screenLayoutChange(rdr::U16 reason);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000174 void setCursor();
Pierre Ossmana3ac01e2011-11-07 21:13:54 +0000175 void setDesktopName(const char *name);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000176 void setSocketTimeouts();
177
178 network::Socket* sock;
179 CharArray peerEndpoint;
Pierre Ossmana3ac01e2011-11-07 21:13:54 +0000180
181 bool inProcessMessages;
182
Pierre Ossmanb8b1e962012-07-20 10:47:00 +0000183 bool pendingSyncFence, syncFence;
Pierre Ossman2c764942011-11-14 15:54:30 +0000184 rdr::U32 fenceFlags;
185 unsigned fenceDataLen;
186 char *fenceData;
187
Pierre Ossman1b478e52011-11-15 12:08:30 +0000188 unsigned baseRTT;
189 unsigned congWindow;
190 int ackedOffset, sentOffset;
191
192 unsigned minRTT;
193 bool seenCongestion;
194 unsigned pingCounter;
195 Timer congestionTimer;
196
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000197 VNCServerST* server;
198 SimpleUpdateTracker updates;
199 TransImageGetter image_getter;
200 Region requested;
201 bool drawRenderedCursor, removeRenderedCursor;
202 Rect renderedCursorRect;
Pierre Ossman1b478e52011-11-15 12:08:30 +0000203 bool continuousUpdates;
204 Region cuRegion;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000205
Pierre Ossman1bb8b6c2011-10-25 15:20:05 +0000206 Timer updateTimer;
207
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000208 std::set<rdr::U32> pressedKeys;
209
210 time_t lastEventTime;
211 time_t pointerEventTime;
212 Point pointerEventPos;
213
214 AccessRights accessRights;
215
216 CharArray closeReason;
217 time_t startTime;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000218 };
219}
220#endif