Document WSProxy
This commit is contained in:
parent
e49324fcbc
commit
ea9716949d
@ -25,21 +25,66 @@
|
|||||||
#include <QtWebSockets/QtWebSockets>
|
#include <QtWebSockets/QtWebSockets>
|
||||||
#include <QHostAddress>
|
#include <QHostAddress>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Handles WebSocket connections by redirecting data sent through them through a local TCP connection
|
||||||
|
* for common handling.
|
||||||
|
*/
|
||||||
class WSProxy : public QObject {
|
class WSProxy : public QObject {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
|
/**
|
||||||
|
* @brief Creates a WSProxy instance.
|
||||||
|
*
|
||||||
|
* @param p_local_port The port through which the TCP connection should be directed. Should the same as with
|
||||||
|
* non-WebAO connections.
|
||||||
|
* @param p_ws_port The WebSocket port. Should the same that is opened for WebSockets connections.
|
||||||
|
* @param p_parent Qt-based parent, passed along to inherited constructor from QObject.
|
||||||
|
*/
|
||||||
WSProxy(int p_local_port, int p_ws_port, QObject* parent);
|
WSProxy(int p_local_port, int p_ws_port, QObject* parent);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Destructor for the WSProxy class.
|
||||||
|
*
|
||||||
|
* @details Marks the WebSocket server that is used to handle the proxy process to be deleted later.
|
||||||
|
*/
|
||||||
~WSProxy();
|
~WSProxy();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Starts listening for WebSocket connections on the given port.
|
||||||
|
*/
|
||||||
void start();
|
void start();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
|
/**
|
||||||
|
* @brief Sets up the proxy process to the newly connected WebSocket.
|
||||||
|
*
|
||||||
|
* @details This function creates a TCP socket to establish the proxy, creates a WSClient to represent the client connecting through WebSocket.
|
||||||
|
*/
|
||||||
void wsConnected();
|
void wsConnected();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
/**
|
||||||
|
* @brief The WebSocket server listening to incoming WebSocket connections.
|
||||||
|
*/
|
||||||
QWebSocketServer* server;
|
QWebSocketServer* server;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Every client connected through WebSocket.
|
||||||
|
*/
|
||||||
QVector<WSClient*> clients;
|
QVector<WSClient*> clients;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The TCP port that the WebSocket connections will be redirected through.
|
||||||
|
*
|
||||||
|
* @note Should be the same that desktop clients connect through, and that was announced to the master server.
|
||||||
|
*/
|
||||||
int local_port;
|
int local_port;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The port for incoming WebSocket connections.
|
||||||
|
*
|
||||||
|
* @note Should be the same that was announced to the master server.
|
||||||
|
*/
|
||||||
int ws_port;
|
int ws_port;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -17,10 +17,11 @@
|
|||||||
//////////////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////////////
|
||||||
#include "include/ws_proxy.h"
|
#include "include/ws_proxy.h"
|
||||||
|
|
||||||
WSProxy::WSProxy(int p_local_port, int p_ws_port, QObject* parent) : QObject(parent)
|
WSProxy::WSProxy(int p_local_port, int p_ws_port, QObject* parent) :
|
||||||
|
QObject(parent),
|
||||||
|
local_port(p_local_port),
|
||||||
|
ws_port(p_ws_port)
|
||||||
{
|
{
|
||||||
local_port = p_local_port;
|
|
||||||
ws_port = p_ws_port;
|
|
||||||
server = new QWebSocketServer(QStringLiteral(""),
|
server = new QWebSocketServer(QStringLiteral(""),
|
||||||
QWebSocketServer::NonSecureMode, this);
|
QWebSocketServer::NonSecureMode, this);
|
||||||
connect(server, &QWebSocketServer::newConnection, this,
|
connect(server, &QWebSocketServer::newConnection, this,
|
||||||
|
Loading…
Reference in New Issue
Block a user