2016-06-12 22:27:24 +02:00
|
|
|
|
|
|
|
#include "QtHttpServer.h"
|
|
|
|
#include "QtHttpRequest.h"
|
|
|
|
#include "QtHttpReply.h"
|
|
|
|
#include "QtHttpClientWrapper.h"
|
|
|
|
|
2017-04-03 05:19:05 +02:00
|
|
|
#include <QDebug>
|
|
|
|
#include <QUrlQuery>
|
2016-06-12 22:27:24 +02:00
|
|
|
|
|
|
|
const QString & QtHttpServer::HTTP_VERSION = QStringLiteral ("HTTP/1.1");
|
|
|
|
|
2017-04-03 05:19:05 +02:00
|
|
|
QtHttpServerWrapper::QtHttpServerWrapper (QObject * parent)
|
|
|
|
: QTcpServer (parent)
|
|
|
|
, m_useSsl (false)
|
|
|
|
{ }
|
|
|
|
|
|
|
|
QtHttpServerWrapper::~QtHttpServerWrapper (void) { }
|
|
|
|
|
|
|
|
void QtHttpServerWrapper::setUseSecure (const bool ssl) {
|
|
|
|
m_useSsl = ssl;
|
|
|
|
}
|
|
|
|
|
|
|
|
void QtHttpServerWrapper::incomingConnection (qintptr handle) {
|
|
|
|
QTcpSocket * sock = (m_useSsl
|
|
|
|
? new QSslSocket (this)
|
|
|
|
: new QTcpSocket (this));
|
|
|
|
if (sock->setSocketDescriptor (handle)) {
|
|
|
|
addPendingConnection (sock);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
delete sock;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-12 22:27:24 +02:00
|
|
|
QtHttpServer::QtHttpServer (QObject * parent)
|
|
|
|
: QObject (parent)
|
2017-04-03 05:19:05 +02:00
|
|
|
, m_useSsl (false)
|
2016-06-12 22:27:24 +02:00
|
|
|
, m_serverName (QStringLiteral ("The Qt5 HTTP Server"))
|
|
|
|
{
|
2017-04-03 05:19:05 +02:00
|
|
|
m_sockServer = new QtHttpServerWrapper (this);
|
|
|
|
connect (m_sockServer, &QtHttpServerWrapper::newConnection, this, &QtHttpServer::onClientConnected);
|
2016-06-12 22:27:24 +02:00
|
|
|
}
|
|
|
|
|
2017-01-14 19:04:58 +01:00
|
|
|
const QString & QtHttpServer::getServerName (void) const {
|
2016-06-12 22:27:24 +02:00
|
|
|
return m_serverName;
|
|
|
|
}
|
|
|
|
|
2017-01-14 19:04:58 +01:00
|
|
|
quint16 QtHttpServer::getServerPort (void) const {
|
|
|
|
return m_sockServer->serverPort ();
|
|
|
|
}
|
|
|
|
|
|
|
|
QString QtHttpServer::getErrorString (void) const {
|
|
|
|
return m_sockServer->errorString ();
|
|
|
|
}
|
|
|
|
|
2016-06-12 22:27:24 +02:00
|
|
|
void QtHttpServer::start (quint16 port) {
|
|
|
|
if (m_sockServer->listen (QHostAddress::Any, port)) {
|
|
|
|
emit started (m_sockServer->serverPort ());
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
emit error (m_sockServer->errorString ());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void QtHttpServer::stop (void) {
|
|
|
|
if (m_sockServer->isListening ()) {
|
|
|
|
m_sockServer->close ();
|
|
|
|
emit stopped ();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void QtHttpServer::setServerName (const QString & serverName) {
|
|
|
|
m_serverName = serverName;
|
|
|
|
}
|
|
|
|
|
2017-04-03 05:19:05 +02:00
|
|
|
void QtHttpServer::setUseSecure (const bool ssl) {
|
|
|
|
m_useSsl = ssl;
|
|
|
|
m_sockServer->setUseSecure (m_useSsl);
|
|
|
|
}
|
|
|
|
|
|
|
|
void QtHttpServer::setPrivateKey (const QSslKey & key) {
|
|
|
|
m_sslKey = key;
|
|
|
|
}
|
|
|
|
|
|
|
|
void QtHttpServer::setCertificates (const QList<QSslCertificate> & certs) {
|
|
|
|
m_sslCerts = certs;
|
|
|
|
}
|
|
|
|
|
2016-06-12 22:27:24 +02:00
|
|
|
void QtHttpServer::onClientConnected (void) {
|
|
|
|
while (m_sockServer->hasPendingConnections ()) {
|
2017-04-03 05:19:05 +02:00
|
|
|
if (QTcpSocket * sock = m_sockServer->nextPendingConnection ()) {
|
|
|
|
connect (sock, &QTcpSocket::disconnected, this, &QtHttpServer::onClientDisconnected);
|
|
|
|
if (m_useSsl) {
|
|
|
|
if (QSslSocket * ssl = qobject_cast<QSslSocket *> (sock)) {
|
|
|
|
connect (ssl, SslErrorSignal (&QSslSocket::sslErrors), this, &QtHttpServer::onClientSslErrors);
|
|
|
|
connect (ssl, &QSslSocket::encrypted, this, &QtHttpServer::onClientSslEncrypted);
|
|
|
|
connect (ssl, &QSslSocket::peerVerifyError, this, &QtHttpServer::onClientSslPeerVerifyError);
|
|
|
|
connect (ssl, &QSslSocket::modeChanged, this, &QtHttpServer::onClientSslModeChanged);
|
|
|
|
ssl->setLocalCertificateChain (m_sslCerts);
|
|
|
|
ssl->setPrivateKey (m_sslKey);
|
|
|
|
ssl->setPeerVerifyMode (QSslSocket::AutoVerifyPeer);
|
|
|
|
ssl->startServerEncryption ();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
QtHttpClientWrapper * wrapper = new QtHttpClientWrapper (sock, this);
|
|
|
|
m_socksClientsHash.insert (sock, wrapper);
|
|
|
|
emit clientConnected (wrapper->getGuid ());
|
|
|
|
}
|
2016-06-12 22:27:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-03 05:19:05 +02:00
|
|
|
void QtHttpServer::onClientSslEncrypted (void) { }
|
|
|
|
|
|
|
|
void QtHttpServer::onClientSslPeerVerifyError (const QSslError & err) {
|
|
|
|
Q_UNUSED (err)
|
|
|
|
}
|
|
|
|
|
|
|
|
void QtHttpServer::onClientSslErrors (const QList<QSslError> & errors) {
|
|
|
|
Q_UNUSED (errors)
|
|
|
|
}
|
|
|
|
|
|
|
|
void QtHttpServer::onClientSslModeChanged (QSslSocket::SslMode mode) {
|
|
|
|
Q_UNUSED (mode)
|
|
|
|
}
|
|
|
|
|
2016-06-12 22:27:24 +02:00
|
|
|
void QtHttpServer::onClientDisconnected (void) {
|
2017-04-03 05:19:05 +02:00
|
|
|
if (QTcpSocket * sockClient = qobject_cast<QTcpSocket *> (sender ())) {
|
|
|
|
if (QtHttpClientWrapper * wrapper = m_socksClientsHash.value (sockClient, Q_NULLPTR)) {
|
2016-06-12 22:27:24 +02:00
|
|
|
emit clientDisconnected (wrapper->getGuid ());
|
|
|
|
wrapper->deleteLater ();
|
|
|
|
m_socksClientsHash.remove (sockClient);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|