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
|
/*
* FeatureWorkerManager.h - class for managing feature worker instances
*
* Copyright (c) 2017-2019 Tobias Junghans <tobydox@veyon.io>
*
* This file is part of Veyon - http://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.
*
*/
#ifndef FEATURE_WORKER_MANAGER_H
#define FEATURE_WORKER_MANAGER_H
#include <QMutex>
#include <QPointer>
#include <QProcess>
#include <QTcpServer>
#include <QTcpSocket>
#include "FeatureMessage.h"
class FeatureManager;
class VeyonServerInterface;
class VEYON_CORE_EXPORT FeatureWorkerManager : public QObject
{
Q_OBJECT
public:
typedef enum WorkerProcessModes {
ManagedSystemProcess,
UnmanagedSessionProcess,
WorkerProcessModeCount
} WorkerProcessMode;
FeatureWorkerManager( VeyonServerInterface& server, FeatureManager& featureManager, QObject* parent = nullptr );
~FeatureWorkerManager() override;
Q_INVOKABLE void startWorker( const Feature& feature, WorkerProcessMode workerProcessMode );
Q_INVOKABLE void stopWorker( const Feature& feature );
Q_INVOKABLE void sendMessage( const FeatureMessage& message );
bool isWorkerRunning( const Feature& feature );
FeatureUidList runningWorkers();
private slots:
void acceptConnection();
void processConnection( QTcpSocket* socket );
void closeConnection( QTcpSocket* socket );
void sendPendingMessages();
private:
VeyonServerInterface& m_server;
FeatureManager& m_featureManager;
QTcpServer m_tcpServer;
struct Worker
{
QPointer<QTcpSocket> socket;
QPointer<QProcess> process;
QList<FeatureMessage> pendingMessages;
Worker() :
socket( nullptr ),
process( nullptr ),
pendingMessages()
{
}
Worker( const Worker &ref ) :
socket( ref.socket ),
process( ref.process ),
pendingMessages( ref.pendingMessages )
{
}
~Worker() {}
Worker& operator=( const Worker& ref )
{
socket = ref.socket;
process = ref.process;
pendingMessages = ref.pendingMessages;
return *this;
}
};
typedef QMap<Feature::Uid, Worker> WorkerMap;
WorkerMap m_workers;
QMutex m_workersMutex;
} ;
#endif
|