nymea/libnymea-core/hardware/network/networkaccessmanagerimpl.cpp

187 lines
6.0 KiB
C++

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Copyright 2013 - 2020, nymea GmbH
* Contact: contact@nymea.io
*
* This file is part of nymea.
* This project including source code and documentation is protected by
* copyright law, and remains the property of nymea GmbH. All rights, including
* reproduction, publication, editing and translation, are reserved. The use of
* this project is subject to the terms of a license agreement to be concluded
* with nymea GmbH in accordance with the terms of use of nymea GmbH, available
* under https://nymea.io/license
*
* GNU General Public License Usage
* Alternatively, this project may be redistributed and/or modified under the
* terms of the GNU General Public License as published by the Free Software
* Foundation, GNU version 3. This project 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 project. If not, see <https://www.gnu.org/licenses/>.
*
* For any further details and any questions please contact us under
* contact@nymea.io or see our FAQ/Licensing Information on
* https://nymea.io/license/faq
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*!
\class nymeaserver::NetworkAccessManagerImpl
\brief Allows to send network requests and receive replies.
\ingroup hardware
\inmodule libnymea
The network manager class is a reimplementation of the \l{http://doc-snapshot.qt-project.org/qt5-5.4/qnetworkaccessmanager.html}{QNetworkAccessManager}
and allows plugins to send network requests and receive replies.
*/
#include "networkaccessmanagerimpl.h"
#include "loggingcategories.h"
namespace nymeaserver {
/*! Construct the hardware resource NetworkAccessManagerImpl with the given \a parent. */
NetworkAccessManagerImpl::NetworkAccessManagerImpl(QNetworkAccessManager *networkManager, QObject *parent) :
NetworkAccessManager(parent),
m_manager(networkManager)
{
m_available = true;
qCDebug(dcHardware()) << "-->" << name() << "created successfully.";
}
QNetworkReply *NetworkAccessManagerImpl::get(const QNetworkRequest &request)
{
QNetworkReply *reply = m_manager->get(request);
hookupTimeoutTimer(reply);
return reply;
}
QNetworkReply *NetworkAccessManagerImpl::deleteResource(const QNetworkRequest &request)
{
QNetworkReply *reply = m_manager->deleteResource(request);
hookupTimeoutTimer(reply);
return reply;
}
QNetworkReply *NetworkAccessManagerImpl::head(const QNetworkRequest &request)
{
QNetworkReply *reply = m_manager->head(request);
hookupTimeoutTimer(reply);
return reply;
}
QNetworkReply *NetworkAccessManagerImpl::post(const QNetworkRequest &request, QIODevice *data)
{
QNetworkReply *reply = m_manager->post(request, data);
hookupTimeoutTimer(reply);
return reply;
}
QNetworkReply *NetworkAccessManagerImpl::post(const QNetworkRequest &request, const QByteArray &data)
{
QNetworkReply *reply = m_manager->post(request, data);
hookupTimeoutTimer(reply);
return reply;
}
QNetworkReply *NetworkAccessManagerImpl::post(const QNetworkRequest &request, QHttpMultiPart *multiPart)
{
QNetworkReply *reply = m_manager->post(request, multiPart);
hookupTimeoutTimer(reply);
return reply;
}
QNetworkReply *NetworkAccessManagerImpl::put(const QNetworkRequest &request, QIODevice *data)
{
QNetworkReply *reply = m_manager->put(request, data);
hookupTimeoutTimer(reply);
return reply;
}
QNetworkReply *NetworkAccessManagerImpl::put(const QNetworkRequest &request, const QByteArray &data)
{
QNetworkReply *reply = m_manager->put(request, data);
hookupTimeoutTimer(reply);
return reply;
}
QNetworkReply *NetworkAccessManagerImpl::put(const QNetworkRequest &request, QHttpMultiPart *multiPart)
{
QNetworkReply *reply = m_manager->put(request, multiPart);
hookupTimeoutTimer(reply);
return reply;
}
QNetworkReply *NetworkAccessManagerImpl::sendCustomRequest(const QNetworkRequest &request, const QByteArray &verb, QIODevice *data)
{
QNetworkReply* reply = m_manager->sendCustomRequest(request, verb, data);
hookupTimeoutTimer(reply);
return reply;
}
void NetworkAccessManagerImpl::setEnabled(bool enabled)
{
if (!m_available) {
qCWarning(dcNetworkManager()) << "NetworkManager not available, cannot enable";
return;
}
if (m_enabled == enabled) {
qCDebug(dcNetworkManager()) << "Network Manager already" << (enabled ? "enabled" : "disabled") << "... Not changing state.";
return;
}
if (enabled) {
m_manager->setNetworkAccessible(QNetworkAccessManager::Accessible);
qCDebug(dcNetworkManager()) << "Network Manager enabled";
} else {
m_manager->setNetworkAccessible(QNetworkAccessManager::NotAccessible);
qCDebug(dcNetworkManager()) << "Network Manager disabled";
}
m_enabled = enabled;
}
void NetworkAccessManagerImpl::hookupTimeoutTimer(QNetworkReply *reply)
{
connect(reply, &QNetworkReply::finished, this, &NetworkAccessManagerImpl::networkReplyFinished);
QTimer *timer = new QTimer(this);
connect(timer, &QTimer::timeout, this, &NetworkAccessManagerImpl::networkTimeout);
timer->setSingleShot(true);
timer->start(30000);
m_timeoutTimers.insert(reply, timer);
}
void NetworkAccessManagerImpl::networkReplyFinished()
{
QNetworkReply *reply = static_cast<QNetworkReply*>(sender());
QTimer *timer = m_timeoutTimers.take(reply);
timer->stop();
timer->deleteLater();
}
void NetworkAccessManagerImpl::networkTimeout()
{
QTimer *timer = static_cast<QTimer*>(sender());
QNetworkReply *reply = m_timeoutTimers.key(timer);
qCDebug(dcNetworkManager()) << "Network request timeout for:" << reply->request().url();
reply->abort();
}
bool NetworkAccessManagerImpl::available() const
{
return m_available;
}
bool NetworkAccessManagerImpl::enabled() const
{
return m_enabled;
}
}