mirror of https://github.com/nymea/nymea.git
187 lines
6.0 KiB
C++
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;
|
|
}
|
|
|
|
}
|