1
mirror of https://invent.kde.org/network/falkon.git synced 2024-12-19 10:16:34 +01:00

Allow using wildcards (*,?) in proxy exceptions.

Closes #788
This commit is contained in:
nowrep 2013-04-06 23:44:59 +02:00
parent 35ceee25ee
commit a73ad89f9e
3 changed files with 82 additions and 7 deletions

View File

@ -3,6 +3,7 @@ Version 1.5.0
* added support for Proxy Auto-Config (PAC)
* added option to open another private window from private window
* added delete action in edit context menu on page
* proxy exceptions now supports wildcards (*, ?)
* cancel upload when trying to upload non-readable files
* GreaseMonkey: added support for GM_Settings
* fixed: size of preferences dialog on low-res screens

View File

@ -20,6 +20,46 @@
#include "settings.h"
#include "pac/pacmanager.h"
WildcardMatcher::WildcardMatcher(const QString &pattern)
: m_regExp(0)
{
setPattern(pattern);
}
WildcardMatcher::~WildcardMatcher()
{
delete m_regExp;
}
void WildcardMatcher::setPattern(const QString &pattern)
{
m_pattern = pattern;
if (m_pattern.contains(QLatin1Char('?')) || m_pattern.contains(QLatin1Char('*'))) {
QString regexp = m_pattern;
regexp.replace(QLatin1Char('.'), QLatin1String("\\."))
.replace(QLatin1Char('*'), QLatin1String(".*"))
.replace(QLatin1Char('?'), QLatin1Char('.'));
regexp = QString("^.*%1.*$").arg(regexp);
m_regExp = new QzRegExp(regexp, Qt::CaseInsensitive);
}
}
QString WildcardMatcher::pattern() const
{
return m_pattern;
}
bool WildcardMatcher::match(const QString &str) const
{
if (!m_regExp) {
return str.contains(m_pattern, Qt::CaseInsensitive);
}
return m_regExp->indexIn(str) > -1;
}
NetworkProxyFactory::NetworkProxyFactory()
: QNetworkProxyFactory()
, m_pacManager(new PacManager)
@ -45,9 +85,16 @@ void NetworkProxyFactory::loadSettings()
m_httpsUsername = settings.value("HttpsUsername", QString()).toString();
m_httpsPassword = settings.value("HttpsPassword", QString()).toString();
m_proxyExceptions = settings.value("ProxyExceptions", QStringList() << "localhost" << "127.0.0.1").toStringList();
QStringList exceptions = settings.value("ProxyExceptions", QStringList() << "localhost" << "127.0.0.1").toStringList();
settings.endGroup();
qDeleteAll(m_proxyExceptions);
m_proxyExceptions.clear();
foreach (const QString &exception, exceptions) {
m_proxyExceptions.append(new WildcardMatcher(exception.trimmed()));
}
m_pacManager->loadSettings();
}
@ -60,20 +107,24 @@ QList<QNetworkProxy> NetworkProxyFactory::queryProxy(const QNetworkProxyQuery &q
{
QList<QNetworkProxy> proxyList;
if (m_proxyExceptions.contains(query.url().host(), Qt::CaseInsensitive)) {
if (m_proxyPreference == NoProxy) {
proxyList.append(QNetworkProxy::NoProxy);
return proxyList;
}
const QString &urlHost = query.url().host();
foreach (WildcardMatcher* m, m_proxyExceptions) {
if (m->match(urlHost)) {
proxyList.append(QNetworkProxy::NoProxy);
return proxyList;
}
}
switch (m_proxyPreference) {
case SystemProxy:
proxyList.append(systemProxyForQuery(query));
break;
case NoProxy:
proxyList.append(QNetworkProxy::NoProxy);
break;
case ProxyAutoConfig:
proxyList.append(m_pacManager->queryProxy(query.url()));
break;
@ -113,3 +164,8 @@ QList<QNetworkProxy> NetworkProxyFactory::queryProxy(const QNetworkProxyQuery &q
return proxyList;
}
NetworkProxyFactory::~NetworkProxyFactory()
{
qDeleteAll(m_proxyExceptions);
}

View File

@ -22,15 +22,33 @@
#include <QStringList>
#include "qz_namespace.h"
#include "qzregexp.h"
class PacManager;
class WildcardMatcher
{
public:
explicit WildcardMatcher(const QString &pattern = QString());
~WildcardMatcher();
void setPattern(const QString &pattern);
QString pattern() const;
bool match(const QString &str) const;
private:
QString m_pattern;
QzRegExp* m_regExp;
};
class QT_QUPZILLA_EXPORT NetworkProxyFactory : public QNetworkProxyFactory
{
public:
enum ProxyPreference { SystemProxy, NoProxy, ProxyAutoConfig, DefinedProxy };
explicit NetworkProxyFactory();
~NetworkProxyFactory();
void loadSettings();
PacManager* pacManager() const;
@ -53,7 +71,7 @@ private:
QString m_httpsUsername;
QString m_httpsPassword;
QStringList m_proxyExceptions;
QList<WildcardMatcher*> m_proxyExceptions;
bool m_useDifferentProxyForHttps;
};