aboutsummaryrefslogtreecommitdiffstats
path: root/mock-server/EchoServer.cpp
blob: 43fc6f9214e5c43328b4132a9b1853ed432ae76d (plain)
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
/**
 * @file   EchoServer.cpp
 * @brief  Simple TCP echo server for a single port.
 */
#include "EchoServer.h"

#include <QTcpSocket>

EchoServer::EchoServer (quint16 port, const char *name, QObject *parent)
    : QTcpServer (parent), m_name (name), m_port (port)
{
  connect (this, &QTcpServer::newConnection, this,
           &EchoServer::onNewConnection);

  if (!listen (QHostAddress::Any, port))
    qCritical ("Failed to listen on %s port %d: %s", m_name, m_port,
               qPrintable (errorString ()));
  else
    qInfo ("Listening on %s port %d", m_name, m_port);
}

void
EchoServer::onNewConnection ()
{
  while (auto *sock = nextPendingConnection ())
    {
      qInfo ("[%s:%d] client connected", m_name, m_port);
      connect (sock, &QTcpSocket::readyRead, this,
               &EchoServer::onClientReadyRead);
      connect (sock, &QTcpSocket::disconnected, this,
               &EchoServer::onClientDisconnected);
    }
}

void
EchoServer::onClientReadyRead ()
{
  auto *sock = qobject_cast<QTcpSocket *> (sender ());
  QByteArray data = sock->readAll ();
  qInfo ("[%s:%d] echo %lld bytes", m_name, m_port, data.size ());
  sock->write (data);
}

void
EchoServer::onClientDisconnected ()
{
  auto *sock = qobject_cast<QTcpSocket *> (sender ());
  qInfo ("[%s:%d] client disconnected", m_name, m_port);
  sock->deleteLater ();
}