1
0
mirror of https://github.com/tomahawk-player/tomahawk.git synced 2025-08-13 17:43:59 +02:00

Speedup NetworkReply redirection

This commit is contained in:
Uwe L. Korn
2013-09-01 18:02:20 +02:00
parent 660c633cde
commit 0650ef2ec9
2 changed files with 86 additions and 11 deletions

View File

@@ -33,9 +33,7 @@ NetworkReply::NetworkReply( QNetworkReply* parent )
{ {
m_url = m_reply->url(); m_url = m_reply->url();
connect( m_reply, SIGNAL( finished() ), SLOT( networkLoadFinished() ) ); connectReplySignals();
connect( m_reply, SIGNAL( error( QNetworkReply::NetworkError ) ), SIGNAL( error( QNetworkReply::NetworkError ) ) );
connect( m_reply, SIGNAL( destroyed( QObject* ) ), SLOT( deletedByParent() ) );
} }
@@ -64,6 +62,70 @@ NetworkReply::deletedByParent()
} }
void
NetworkReply::metaDataChanged()
{
// Do an early check if we are redirected.
QVariant redir = m_reply->attribute( QNetworkRequest::RedirectionTargetAttribute );
if ( redir.isValid() && !redir.toUrl().isEmpty() )
{
// We have found a redirect, so follow it.
if ( m_formerUrls.count( redir.toUrl().toString() ) < maxSameRedirects && m_formerUrls.count() < maxRedirects )
{
tDebug( LOGVERBOSE ) << Q_FUNC_INFO << "Redirected HTTP request to" << redir;
if ( m_blacklistedHosts.contains( redir.toUrl().host() ) )
{
// Nope, we won't follow this redirect, emit some other signal here.
emit finalUrlReached();
emit finalUrlReached( redir.toUrl() );
}
else
{
disconnectReplySignals();
load( redir.toUrl() );
emit redirected();
}
}
else
{
// Nope, we won't follow this redirect, emit some other signal here.
emit finalUrlReached();
emit finalUrlReached( m_url );
}
}
else
{
// We do not have enough information to handle a redirect but if this isn't a redirect, we're maybe already done.
QVariant statusCode = m_reply->attribute( QNetworkRequest::HttpStatusCodeAttribute );
if ( statusCode.isValid() && statusCode.toInt() >= 200 && statusCode.toInt() <= 207 )
{
emit finalUrlReached();
emit finalUrlReached( m_url );
}
}
}
void
NetworkReply::connectReplySignals()
{
connect( m_reply, SIGNAL( finished() ), SLOT( networkLoadFinished() ) );
connect( m_reply, SIGNAL( error( QNetworkReply::NetworkError ) ), SIGNAL( error( QNetworkReply::NetworkError ) ) );
connect( m_reply, SIGNAL( destroyed( QObject* ) ), SLOT( deletedByParent() ) );
connect( m_reply, SIGNAL( metaDataChanged() ), SLOT( metaDataChanged() ) );
}
void
NetworkReply::disconnectReplySignals()
{
disconnect( m_reply, SIGNAL( finished() ), this, SLOT( networkLoadFinished() ) );
disconnect( m_reply, SIGNAL( error( QNetworkReply::NetworkError ) ), this, SIGNAL( error( QNetworkReply::NetworkError ) ) );
disconnect( m_reply, SIGNAL( destroyed( QObject* ) ), this, SLOT( deletedByParent() ) );
disconnect( m_reply, SIGNAL( metaDataChanged() ), this, SLOT( metaDataChanged() ) );
}
void void
NetworkReply::load( const QUrl& url ) NetworkReply::load( const QUrl& url )
{ {
@@ -86,9 +148,17 @@ NetworkReply::load( const QUrl& url )
m_reply = Tomahawk::Utils::nam()->get( request ); m_reply = Tomahawk::Utils::nam()->get( request );
} }
connect( m_reply, SIGNAL( finished() ), SLOT( networkLoadFinished() ) ); connectReplySignals();
connect( m_reply, SIGNAL( error( QNetworkReply::NetworkError ) ), SIGNAL( error( QNetworkReply::NetworkError ) ) ); }
connect( m_reply, SIGNAL( destroyed( QObject* ) ), SLOT( deletedByParent() ) );
void
NetworkReply::emitFinished( const QUrl& url )
{
emit finalUrlReached();
emit finalUrlReached( url );
emit finished( url );
emit finished();
} }
@@ -97,7 +167,7 @@ NetworkReply::networkLoadFinished()
{ {
if ( m_reply->error() != QNetworkReply::NoError ) if ( m_reply->error() != QNetworkReply::NoError )
{ {
emit finished(); emitFinished( m_url );
return; return;
} }
@@ -108,8 +178,7 @@ NetworkReply::networkLoadFinished()
if ( m_blacklistedHosts.contains( redir.toUrl().host() ) ) if ( m_blacklistedHosts.contains( redir.toUrl().host() ) )
{ {
tLog( LOGVERBOSE ) << Q_FUNC_INFO << "Reached blacklisted host, not redirecting anymore."; tLog( LOGVERBOSE ) << Q_FUNC_INFO << "Reached blacklisted host, not redirecting anymore.";
emit finished( redir.toUrl() ); emitFinished( redir.toUrl() );
emit finished();
} }
else else
{ {
@@ -119,7 +188,6 @@ NetworkReply::networkLoadFinished()
} }
else else
{ {
emit finished( m_url ); emitFinished( m_url );
emit finished();
} }
} }

View File

@@ -44,15 +44,22 @@ public:
signals: signals:
void redirected(); void redirected();
void finalUrlReached();
void finalUrlReached( const QUrl& finalUrlReached );
void finished(); void finished();
void finished( const QUrl& finalUrl ); void finished( const QUrl& finalUrl );
void error( QNetworkReply::NetworkError error ); void error( QNetworkReply::NetworkError error );
private slots: private slots:
void deletedByParent(); void deletedByParent();
void metaDataChanged();
void networkLoadFinished(); void networkLoadFinished();
private: private:
void connectReplySignals();
void disconnectReplySignals();
void emitFinished( const QUrl& url );
void load( const QUrl& url ); void load( const QUrl& url );
QStringList m_blacklistedHosts; QStringList m_blacklistedHosts;