/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 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 . * * 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(sender()); QTimer *timer = m_timeoutTimers.take(reply); timer->stop(); timer->deleteLater(); } void NetworkAccessManagerImpl::networkTimeout() { QTimer *timer = static_cast(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; } }