1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143
|
/*
* VncClientProtocol.h - header file for the VncClientProtocol class
*
* Copyright (c) 2017-2021 Tobias Junghans <tobydox@veyon.io>
*
* This file is part of Veyon - https://veyon.io
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this program (see COPYING); if not, write to the
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
* Boston, MA 02111-1307, USA.
*
*/
#pragma once
#include <QRect>
#include "rfb/rfbproto.h"
#include "CryptoCore.h"
class QBuffer;
class QTcpSocket;
class VEYON_CORE_EXPORT VncClientProtocol
{
public:
using Password = CryptoCore::SecureArray;
enum State {
Disconnected,
Protocol,
SecurityInit,
SecurityChallenge,
SecurityResult,
FramebufferInit,
Running,
StateCount
} ;
VncClientProtocol( QTcpSocket* socket, const Password& vncPassword );
State state() const
{
return m_state;
}
void start();
bool read(); // Flawfinder: ignore
const QByteArray& serverInitMessage() const
{
return m_serverInitMessage;
}
int framebufferWidth() const
{
return m_framebufferWidth;
}
int framebufferHeight() const
{
return m_framebufferHeight;
}
bool setPixelFormat( rfbPixelFormat pixelFormat );
bool setEncodings( const QVector<uint32_t>& encodings );
void requestFramebufferUpdate( bool incremental );
bool receiveMessage();
const QByteArray& lastMessage() const
{
return m_lastMessage;
}
uint8_t lastMessageType() const
{
return static_cast<uint8_t>( m_lastMessage.constData()[0] );
}
const QRect& lastUpdatedRect() const
{
return m_lastUpdatedRect;
}
private:
bool readProtocol();
bool receiveSecurityTypes();
bool receiveSecurityChallenge();
bool receiveSecurityResult();
bool receiveServerInitMessage();
bool receiveFramebufferUpdateMessage();
bool receiveColourMapEntriesMessage();
bool receiveBellMessage();
bool receiveCutTextMessage();
bool receiveResizeFramebufferMessage();
bool receiveXvpMessage();
bool readMessage( int size );
bool handleRect( QBuffer& buffer, rfbFramebufferUpdateRectHeader rectHeader );
bool handleRectEncodingRRE( QBuffer& buffer, uint bytesPerPixel );
bool handleRectEncodingCoRRE( QBuffer& buffer, uint bytesPerPixel );
bool handleRectEncodingHextile( QBuffer& buffer,
const rfbFramebufferUpdateRectHeader rectHeader,
uint bytesPerPixel );
bool handleRectEncodingZlib( QBuffer& buffer );
bool handleRectEncodingZRLE( QBuffer& buffer );
static bool isPseudoEncoding( rfbFramebufferUpdateRectHeader header );
static constexpr auto MaximumMessageSize = 4096*4096*4;
QTcpSocket* m_socket;
State m_state;
Password m_vncPassword;
QByteArray m_serverInitMessage;
rfbPixelFormat m_pixelFormat;
quint16 m_framebufferWidth;
quint16 m_framebufferHeight;
QByteArray m_lastMessage;
QRect m_lastUpdatedRect;
} ;
|