QNativeSocketEngine - set query type in checkProxy
The default query type for QNetworkProxyQuery is TcpSocket (that's what our QNetworkProxy::applicationProxy() requests). Unfortunately, this can result in http_proxy found and QTcpServer::listen() failing (probably, QUdpSocket is also affected). So now we extract applicationProxy's logic but modify it to provide the exact query type we need. Task-number: QTBUG-58706 Task-number: QTBUG-41053 Task-number: QTBUG-58374 Change-Id: I79ce0efb779bbaf08afd78c44cbe92d08730152b Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
This commit is contained in:
parent
b48e960969
commit
c0157a9f03
@ -358,17 +358,41 @@ bool QNativeSocketEnginePrivate::checkProxy(const QHostAddress &address)
|
|||||||
#if !defined(QT_NO_NETWORKPROXY)
|
#if !defined(QT_NO_NETWORKPROXY)
|
||||||
QObject *parent = q_func()->parent();
|
QObject *parent = q_func()->parent();
|
||||||
QNetworkProxy proxy;
|
QNetworkProxy proxy;
|
||||||
|
QNetworkProxyQuery::QueryType queryType = QNetworkProxyQuery::TcpSocket;
|
||||||
if (QAbstractSocket *socket = qobject_cast<QAbstractSocket *>(parent)) {
|
if (QAbstractSocket *socket = qobject_cast<QAbstractSocket *>(parent)) {
|
||||||
proxy = socket->proxy();
|
proxy = socket->proxy();
|
||||||
|
switch (socket->socketType()) {
|
||||||
|
case QAbstractSocket::UdpSocket:
|
||||||
|
queryType = QNetworkProxyQuery::UdpSocket;
|
||||||
|
break;
|
||||||
|
case QAbstractSocket::SctpSocket:
|
||||||
|
queryType = QNetworkProxyQuery::SctpSocket;
|
||||||
|
break;
|
||||||
|
case QAbstractSocket::TcpSocket:
|
||||||
|
case QAbstractSocket::UnknownSocketType:
|
||||||
|
queryType = QNetworkProxyQuery::TcpSocket;
|
||||||
|
}
|
||||||
} else if (QTcpServer *server = qobject_cast<QTcpServer *>(parent)) {
|
} else if (QTcpServer *server = qobject_cast<QTcpServer *>(parent)) {
|
||||||
proxy = server->proxy();
|
proxy = server->proxy();
|
||||||
|
queryType = QNetworkProxyQuery::TcpServer;
|
||||||
|
#ifndef QT_NO_SCTP
|
||||||
|
if (qobject_cast<QSctpServer *>(server))
|
||||||
|
queryType = QNetworkProxyQuery::SctpServer;
|
||||||
|
#endif
|
||||||
} else {
|
} else {
|
||||||
// no parent -> no proxy
|
// no parent -> no proxy
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (proxy.type() == QNetworkProxy::DefaultProxy)
|
if (proxy.type() == QNetworkProxy::DefaultProxy) {
|
||||||
proxy = QNetworkProxy::applicationProxy();
|
// This is similar to what we have in QNetworkProxy::applicationProxy,
|
||||||
|
// the only difference is that we provide the correct query type instead of
|
||||||
|
// always using TcpSocket unconditionally (this is the default type for
|
||||||
|
// QNetworkProxyQuery).
|
||||||
|
QNetworkProxyQuery query;
|
||||||
|
query.setQueryType(queryType);
|
||||||
|
proxy = QNetworkProxyFactory::systemProxyForQuery(query).constFirst();
|
||||||
|
}
|
||||||
|
|
||||||
if (proxy.type() != QNetworkProxy::DefaultProxy &&
|
if (proxy.type() != QNetworkProxy::DefaultProxy &&
|
||||||
proxy.type() != QNetworkProxy::NoProxy) {
|
proxy.type() != QNetworkProxy::NoProxy) {
|
||||||
|
Loading…
Reference in New Issue
Block a user