NOISSUE clean up download redirects and handle their errors as fatal
This commit is contained in:
parent
c33b4e252f
commit
0c2e2094ee
@ -181,6 +181,12 @@ bool Download::handleRedirect()
|
|||||||
* FIXME: report Qt bug for this
|
* FIXME: report Qt bug for this
|
||||||
*/
|
*/
|
||||||
redirect = QUrl(redirectStr, QUrl::TolerantMode);
|
redirect = QUrl(redirectStr, QUrl::TolerantMode);
|
||||||
|
if(!redirect.isValid())
|
||||||
|
{
|
||||||
|
qWarning() << "Failed to parse redirect URL:" << redirectStr;
|
||||||
|
downloadError(QNetworkReply::ProtocolFailure);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
qDebug() << "Fixed location header:" << redirect;
|
qDebug() << "Fixed location header:" << redirect;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -188,29 +194,10 @@ bool Download::handleRedirect()
|
|||||||
qDebug() << "Location header:" << redirect;
|
qDebug() << "Location header:" << redirect;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString redirectURL;
|
|
||||||
if(redirect.isValid())
|
|
||||||
{
|
|
||||||
redirectURL = redirect.toString();
|
|
||||||
}
|
|
||||||
// FIXME: This is a hack for
|
|
||||||
else if(m_reply->hasRawHeader("Location"))
|
|
||||||
{
|
|
||||||
auto data = m_reply->rawHeader("Location");
|
|
||||||
if(data.size() > 2 && data[0] == '/' && data[1] == '/')
|
|
||||||
{
|
|
||||||
redirectURL = m_reply->url().scheme() + ":" + data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!redirectURL.isEmpty())
|
|
||||||
{
|
|
||||||
m_url = QUrl(redirect.toString());
|
m_url = QUrl(redirect.toString());
|
||||||
qDebug() << "Following redirect to " << m_url.toString();
|
qDebug() << "Following redirect to " << m_url.toString();
|
||||||
start();
|
start();
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user