2013-08-17 15:39:29 +02:00
|
|
|
// system includes
|
|
|
|
#include <stdexcept>
|
|
|
|
|
|
|
|
// project includes
|
|
|
|
#include <jsonserver/JsonServer.h>
|
|
|
|
#include "JsonClientConnection.h"
|
|
|
|
|
2016-06-19 00:56:47 +02:00
|
|
|
JsonServer::JsonServer(uint16_t port) :
|
2013-08-17 15:39:29 +02:00
|
|
|
QObject(),
|
2016-06-19 00:56:47 +02:00
|
|
|
_hyperion(Hyperion::getInstance()),
|
2013-08-17 15:39:29 +02:00
|
|
|
_server(),
|
2016-07-11 17:08:22 +02:00
|
|
|
_openConnections(),
|
|
|
|
_log(Logger::getInstance("JSONSERVER"))
|
2013-08-17 15:39:29 +02:00
|
|
|
{
|
|
|
|
if (!_server.listen(QHostAddress::Any, port))
|
|
|
|
{
|
2016-03-23 17:40:34 +01:00
|
|
|
throw std::runtime_error("JSONSERVER ERROR: could not bind to port");
|
2013-08-17 15:39:29 +02:00
|
|
|
}
|
|
|
|
|
2016-02-18 10:32:38 +01:00
|
|
|
QList<MessageForwarder::JsonSlaveAddress> list = _hyperion->getForwarder()->getJsonSlaves();
|
|
|
|
for ( int i=0; i<list.size(); i++ )
|
|
|
|
{
|
|
|
|
if ( list.at(i).addr == QHostAddress::LocalHost && list.at(i).port == port ) {
|
2016-03-23 17:40:34 +01:00
|
|
|
throw std::runtime_error("JSONSERVER ERROR: Loop between proto server and forwarder detected. Fix your config!");
|
2016-02-18 10:32:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-17 15:39:29 +02:00
|
|
|
// Set trigger for incoming connections
|
|
|
|
connect(&_server, SIGNAL(newConnection()), this, SLOT(newConnection()));
|
2013-08-17 19:20:19 +02:00
|
|
|
|
|
|
|
// make sure the resources are loaded (they may be left out after static linking
|
2013-08-22 20:31:57 +02:00
|
|
|
Q_INIT_RESOURCE(JsonSchemas);
|
2016-06-01 06:55:11 +10:00
|
|
|
|
2013-08-17 15:39:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
JsonServer::~JsonServer()
|
|
|
|
{
|
|
|
|
foreach (JsonClientConnection * connection, _openConnections) {
|
|
|
|
delete connection;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
uint16_t JsonServer::getPort() const
|
|
|
|
{
|
|
|
|
return _server.serverPort();
|
|
|
|
}
|
|
|
|
|
|
|
|
void JsonServer::newConnection()
|
|
|
|
{
|
|
|
|
QTcpSocket * socket = _server.nextPendingConnection();
|
|
|
|
|
|
|
|
if (socket != nullptr)
|
|
|
|
{
|
2016-07-11 17:08:22 +02:00
|
|
|
Debug(_log, "New connection");
|
2013-08-18 12:21:07 +02:00
|
|
|
JsonClientConnection * connection = new JsonClientConnection(socket, _hyperion);
|
2013-08-17 15:39:29 +02:00
|
|
|
_openConnections.insert(connection);
|
|
|
|
|
|
|
|
// register slot for cleaning up after the connection closed
|
|
|
|
connect(connection, SIGNAL(connectionClosed(JsonClientConnection*)), this, SLOT(closedConnection(JsonClientConnection*)));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JsonServer::closedConnection(JsonClientConnection *connection)
|
|
|
|
{
|
2016-07-11 17:08:22 +02:00
|
|
|
Debug(_log, "Connection closed");
|
2013-08-17 15:39:29 +02:00
|
|
|
_openConnections.remove(connection);
|
|
|
|
|
|
|
|
// schedule to delete the connection object
|
|
|
|
connection->deleteLater();
|
|
|
|
}
|