-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathserver.cpp
76 lines (66 loc) · 2.22 KB
/
server.cpp
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
#include "connection.h"
#include "server.h"
#include "backend.h"
#include "QsLog.h"
Server::Server(int tcpPort, QObject *parent) :
QObject(parent)
{
mServer = new QTcpServer(this);
if (mServer->listen(QHostAddress::Any, tcpPort)) {
QLOG_INFO() << QString("[Server] Server listening at: %1:%2").
arg(mServer->serverAddress().toString()).
arg(mServer->serverPort());
connect(mServer, SIGNAL(newConnection()), SLOT(newConnection()));
}
else {
QLOG_ERROR() << "[Server] QTcpServer error: " + mServer->errorString();
}
}
void Server::newConnection()
{
QTcpSocket *socket = mServer->nextPendingConnection();
Connection *newConnection = new Connection(socket);
socket->socketOption(QAbstractSocket::LowDelayOption);
QLOG_TRACE() << QString("[Server] New connecion: %1:%2").
arg(socket->peerAddress().toString()).
arg(socket->peerPort());
connect(newConnection, SIGNAL(modbusRequest(ADU *)), SIGNAL(modbusRequest(ADU *)));
connect(socket, SIGNAL(bytesWritten(qint64)), SLOT(bytesWritten(qint64)));
}
void Server::readyRead()
{
QTcpSocket * socket = static_cast<QTcpSocket *>(sender());
QByteArray tcpReq = socket->readAll();
QLOG_DEBUG() << QString("[Server] request from: %1:%2").
arg(socket->peerAddress().toString()).
arg(socket->peerPort());
QLOG_TRACE() << "[Server] request data " << tcpReq.toHex().toUpper();
ADU * request = new ADU(socket, tcpReq);
QLOG_TRACE() << "[Server] Request:" << request->aduToString();
emit modbusRequest(request);
}
void Server::disconnected()
{
QTcpSocket * socket = static_cast<QTcpSocket *>(sender());
QLOG_TRACE() << QString("[Server] Disconnected: %1:%2").
arg(socket->peerAddress().toString()).
arg(socket->peerPort());
socket->deleteLater();
}
void Server::modbusReply(ADU *modbusReply)
{
QLOG_TRACE() << "[Server] Reply:" << modbusReply->aduToString();
QTcpSocket *socket = modbusReply->getSocket();
if (socket == 0)
return;
socket->write(modbusReply->toQByteArray());
delete modbusReply;
}
void Server::bytesWritten(qint64 bytes)
{
QTcpSocket *socket = static_cast<QTcpSocket *>(sender());
QLOG_TRACE() << QString("[Server] bytes written: %1 %2:%3").
arg(bytes).
arg(socket->peerAddress().toString()).
arg(socket->peerPort());
}