[tracking] Use the network service
- drop own NAM handling - use timeout mechanism - report timeout as fatal error (like it already did), other errors are ignored.
This commit is contained in:
parent
a1b0049bbf
commit
f7215393d1
@ -18,12 +18,10 @@
|
||||
|
||||
#include "TrackingJobs.h"
|
||||
|
||||
#include "network/Manager.h"
|
||||
#include "utils/CalamaresUtilsSystem.h"
|
||||
#include "utils/Logger.h"
|
||||
|
||||
#include <QEventLoop>
|
||||
#include <QNetworkAccessManager>
|
||||
#include <QNetworkReply>
|
||||
#include <QSemaphore>
|
||||
#include <QTimer>
|
||||
|
||||
@ -31,13 +29,11 @@
|
||||
|
||||
TrackingInstallJob::TrackingInstallJob( const QString& url )
|
||||
: m_url( url )
|
||||
, m_networkManager( nullptr )
|
||||
{
|
||||
}
|
||||
|
||||
TrackingInstallJob::~TrackingInstallJob()
|
||||
{
|
||||
delete m_networkManager;
|
||||
}
|
||||
|
||||
QString
|
||||
@ -61,48 +57,23 @@ TrackingInstallJob::prettyStatusMessage() const
|
||||
Calamares::JobResult
|
||||
TrackingInstallJob::exec()
|
||||
{
|
||||
m_networkManager = new QNetworkAccessManager();
|
||||
using CalamaresUtils::Network::Manager;
|
||||
using CalamaresUtils::Network::RequestOptions;
|
||||
using CalamaresUtils::Network::RequestStatus;
|
||||
|
||||
QNetworkRequest request;
|
||||
request.setUrl( QUrl( m_url ) );
|
||||
// Follows all redirects except unsafe ones (https to http).
|
||||
request.setAttribute( QNetworkRequest::FollowRedirectsAttribute, true );
|
||||
// Not everybody likes the default User Agent used by this class (looking at you,
|
||||
// sourceforge.net), so let's set a more descriptive one.
|
||||
request.setRawHeader( "User-Agent", "Mozilla/5.0 (compatible; Calamares)" );
|
||||
|
||||
QTimer timeout;
|
||||
timeout.setSingleShot( true );
|
||||
|
||||
QEventLoop loop;
|
||||
|
||||
connect( m_networkManager, &QNetworkAccessManager::finished, this, &TrackingInstallJob::dataIsHere );
|
||||
connect( m_networkManager, &QNetworkAccessManager::finished, &loop, &QEventLoop::quit );
|
||||
connect( &timeout, &QTimer::timeout, &loop, &QEventLoop::quit );
|
||||
|
||||
m_networkManager->get( request ); // The semaphore is released when data is received
|
||||
timeout.start( std::chrono::milliseconds( 5000 ) );
|
||||
|
||||
loop.exec();
|
||||
|
||||
if ( !timeout.isActive() )
|
||||
auto result = Manager::instance().synchronousPing(
|
||||
QUrl( m_url ),
|
||||
RequestOptions( RequestOptions::FollowRedirect | RequestOptions::FakeUserAgent,
|
||||
RequestOptions::milliseconds( 5000 ) ) );
|
||||
if ( result.status == RequestStatus::Timeout )
|
||||
{
|
||||
cWarning() << "install-tracking request timed out.";
|
||||
return Calamares::JobResult::error( tr( "Internal error in install-tracking." ),
|
||||
tr( "HTTP request timed out." ) );
|
||||
}
|
||||
timeout.stop();
|
||||
|
||||
return Calamares::JobResult::ok();
|
||||
}
|
||||
|
||||
void
|
||||
TrackingInstallJob::dataIsHere( QNetworkReply* reply )
|
||||
{
|
||||
cDebug() << "Installation feedback request OK";
|
||||
reply->deleteLater();
|
||||
}
|
||||
|
||||
QString
|
||||
TrackingMachineNeonJob::prettyName() const
|
||||
{
|
||||
|
@ -21,13 +21,10 @@
|
||||
|
||||
#include "Job.h"
|
||||
|
||||
class QNetworkAccessManager;
|
||||
class QNetworkReply;
|
||||
class QSemaphore;
|
||||
|
||||
class TrackingInstallJob : public Calamares::Job
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
TrackingInstallJob( const QString& url );
|
||||
~TrackingInstallJob() override;
|
||||
@ -37,13 +34,8 @@ public:
|
||||
QString prettyStatusMessage() const override;
|
||||
Calamares::JobResult exec() override;
|
||||
|
||||
public slots:
|
||||
void dataIsHere( QNetworkReply* );
|
||||
|
||||
private:
|
||||
const QString m_url;
|
||||
|
||||
QNetworkAccessManager* m_networkManager;
|
||||
};
|
||||
|
||||
class TrackingMachineNeonJob : public Calamares::Job
|
||||
|
Loading…
Reference in New Issue
Block a user