Windows - "bypass proxy for local..." also affects IP addresses
If the "bypass proxy for local addresses" option is enabled in the windows proxy configuration, then do not use the proxy for any IP address in the subnet of any network interface. As the systemProxyForQuery api is now offering HTTP proxy tunnels for TCP sockets, this change avoids local ad-hoc network connections being routed through the proxy. In the case where the local address was on a different interface to the proxy server, it may have been unreachable through the proxy. For example IP over USB or Bluetooth. Change-Id: I0842732832a7795112be029d923ed168edc008d6 Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
This commit is contained in:
parent
57482b930f
commit
fffc900f78
@ -48,6 +48,7 @@
|
|||||||
#include <qregexp.h>
|
#include <qregexp.h>
|
||||||
#include <qurl.h>
|
#include <qurl.h>
|
||||||
#include <private/qsystemlibrary_p.h>
|
#include <private/qsystemlibrary_p.h>
|
||||||
|
#include <qnetworkinterface.h>
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <qt_windows.h>
|
#include <qt_windows.h>
|
||||||
@ -191,10 +192,26 @@ static bool isBypassed(const QString &host, const QStringList &bypassList)
|
|||||||
QHostAddress ipAddress;
|
QHostAddress ipAddress;
|
||||||
bool isIpAddress = ipAddress.setAddress(host);
|
bool isIpAddress = ipAddress.setAddress(host);
|
||||||
|
|
||||||
|
// always exclude loopback
|
||||||
|
if (isIpAddress && ipAddress.isLoopback())
|
||||||
|
return true;
|
||||||
|
|
||||||
// does it match the list of exclusions?
|
// does it match the list of exclusions?
|
||||||
foreach (const QString &entry, bypassList) {
|
foreach (const QString &entry, bypassList) {
|
||||||
if (isSimple && entry == QLatin1String("<local>"))
|
if (entry == QLatin1String("<local>")) {
|
||||||
return true;
|
if (isSimple)
|
||||||
|
return true;
|
||||||
|
if (isIpAddress) {
|
||||||
|
//exclude all local subnets
|
||||||
|
foreach (const QNetworkInterface &iface, QNetworkInterface::allInterfaces()) {
|
||||||
|
foreach (const QNetworkAddressEntry netaddr, iface.addressEntries()) {
|
||||||
|
if (ipAddress.isInSubnet(netaddr.ip(), netaddr.prefixLength())) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
if (isIpAddress && ipAddress.isInSubnet(QHostAddress::parseSubnet(entry))) {
|
if (isIpAddress && ipAddress.isInSubnet(QHostAddress::parseSubnet(entry))) {
|
||||||
return true; // excluded
|
return true; // excluded
|
||||||
} else {
|
} else {
|
||||||
|
@ -133,6 +133,10 @@ void tst_QNetworkProxyFactory::systemProxyForQuery_data()
|
|||||||
QTest::newRow("imap") << (int)QNetworkProxyQuery::TcpSocket << QUrl() << QString() << QString("qt-project.org") << 0 << (int)QNetworkProxy::TunnelingCapability;
|
QTest::newRow("imap") << (int)QNetworkProxyQuery::TcpSocket << QUrl() << QString() << QString("qt-project.org") << 0 << (int)QNetworkProxy::TunnelingCapability;
|
||||||
QTest::newRow("autobind-server") << (int)QNetworkProxyQuery::TcpServer << QUrl() << QString() << QString() << 0 << (int)QNetworkProxy::ListeningCapability;
|
QTest::newRow("autobind-server") << (int)QNetworkProxyQuery::TcpServer << QUrl() << QString() << QString() << 0 << (int)QNetworkProxy::ListeningCapability;
|
||||||
QTest::newRow("web-server") << (int)QNetworkProxyQuery::TcpServer << QUrl() << QString() << QString() << 80 << (int)QNetworkProxy::ListeningCapability;
|
QTest::newRow("web-server") << (int)QNetworkProxyQuery::TcpServer << QUrl() << QString() << QString() << 80 << (int)QNetworkProxy::ListeningCapability;
|
||||||
|
//windows: these should be bypassed if "bypass proxy server for local addresses" is ticked
|
||||||
|
foreach (QHostAddress address, QNetworkInterface::allAddresses()) {
|
||||||
|
QTest::newRow(qPrintable(address.toString())) << (int)QNetworkProxyQuery::TcpSocket << QUrl() << QString() << address.toString() << 0 << 0;
|
||||||
|
}
|
||||||
|
|
||||||
//UDP
|
//UDP
|
||||||
QTest::newRow("udp") << (int)QNetworkProxyQuery::UdpSocket << QUrl() << QString() << QString() << 0 << (int)QNetworkProxy::UdpTunnelingCapability;
|
QTest::newRow("udp") << (int)QNetworkProxyQuery::UdpSocket << QUrl() << QString() << QString() << 0 << (int)QNetworkProxy::UdpTunnelingCapability;
|
||||||
|
Loading…
Reference in New Issue
Block a user