mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-05 05:27:39 +03:00
Create new UrlTools class
This commit is contained in:
parent
509e218676
commit
8f45431ecb
15 changed files with 418 additions and 233 deletions
|
@ -25,6 +25,7 @@
|
|||
#include "BrowserMessageBuilder.h"
|
||||
#include "BrowserSettings.h"
|
||||
#include "core/Tools.h"
|
||||
#include "core/UrlTools.h"
|
||||
#include "gui/MainWindow.h"
|
||||
#include "gui/MessageBox.h"
|
||||
#include "gui/osutils/OSUtils.h"
|
||||
|
@ -544,33 +545,6 @@ bool BrowserService::isPasswordGeneratorRequested() const
|
|||
return m_passwordGeneratorRequested;
|
||||
}
|
||||
|
||||
// Returns true if URLs are identical. Paths with "/" are removed during comparison.
|
||||
// URLs without scheme reverts to https.
|
||||
// Special handling is needed because QUrl::matches() with QUrl::StripTrailingSlash does not strip "/" paths.
|
||||
bool BrowserService::isUrlIdentical(const QString& first, const QString& second) const
|
||||
{
|
||||
auto trimUrl = [](QString url) {
|
||||
url = url.trimmed();
|
||||
if (url.endsWith("/")) {
|
||||
url.remove(url.length() - 1, 1);
|
||||
}
|
||||
|
||||
return url;
|
||||
};
|
||||
|
||||
if (first.isEmpty() || second.isEmpty()) {
|
||||
return false;
|
||||
}
|
||||
|
||||
const auto firstUrl = trimUrl(first);
|
||||
const auto secondUrl = trimUrl(second);
|
||||
if (firstUrl == secondUrl) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return QUrl(firstUrl).matches(QUrl(secondUrl), QUrl::StripTrailingSlash);
|
||||
}
|
||||
|
||||
QString BrowserService::storeKey(const QString& key)
|
||||
{
|
||||
auto db = getDatabase();
|
||||
|
@ -1080,18 +1054,6 @@ int BrowserService::sortPriority(const QStringList& urls, const QString& siteUrl
|
|||
return *std::max_element(priorityList.begin(), priorityList.end());
|
||||
}
|
||||
|
||||
bool BrowserService::schemeFound(const QString& url)
|
||||
{
|
||||
QUrl address(url);
|
||||
return !address.scheme().isEmpty();
|
||||
}
|
||||
|
||||
bool BrowserService::isIpAddress(const QString& host) const
|
||||
{
|
||||
QHostAddress address(host);
|
||||
return address.protocol() == QAbstractSocket::IPv4Protocol || address.protocol() == QAbstractSocket::IPv6Protocol;
|
||||
}
|
||||
|
||||
bool BrowserService::removeFirstDomain(QString& hostname)
|
||||
{
|
||||
int pos = hostname.indexOf(".");
|
||||
|
@ -1187,7 +1149,7 @@ bool BrowserService::handleURL(const QString& entryUrl,
|
|||
}
|
||||
|
||||
// Match the base domain
|
||||
if (getTopLevelDomainFromUrl(siteQUrl.host()) != getTopLevelDomainFromUrl(entryQUrl.host())) {
|
||||
if (urlTools()->getBaseDomainFromUrl(siteQUrl.host()) != urlTools()->getBaseDomainFromUrl(entryQUrl.host())) {
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -1197,34 +1159,6 @@ bool BrowserService::handleURL(const QString& entryUrl,
|
|||
}
|
||||
|
||||
return false;
|
||||
};
|
||||
|
||||
/**
|
||||
* Gets the base domain of URL.
|
||||
*
|
||||
* Returns the base domain, e.g. https://another.example.co.uk -> example.co.uk
|
||||
*/
|
||||
QString BrowserService::getTopLevelDomainFromUrl(const QString& url) const
|
||||
{
|
||||
QUrl qurl = QUrl::fromUserInput(url);
|
||||
QString host = qurl.host();
|
||||
|
||||
// If the hostname is an IP address, return it directly
|
||||
if (isIpAddress(host)) {
|
||||
return host;
|
||||
}
|
||||
|
||||
if (host.isEmpty() || !host.contains(qurl.topLevelDomain())) {
|
||||
return {};
|
||||
}
|
||||
|
||||
// Remove the top level domain part from the hostname, e.g. https://another.example.co.uk -> https://another.example
|
||||
host.chop(qurl.topLevelDomain().length());
|
||||
// Split the URL and select the last part, e.g. https://another.example -> example
|
||||
QString baseDomain = host.split('.').last();
|
||||
// Append the top level domain back to the URL, e.g. example -> example.co.uk
|
||||
baseDomain.append(qurl.topLevelDomain());
|
||||
return baseDomain;
|
||||
}
|
||||
|
||||
QSharedPointer<Database> BrowserService::getDatabase()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue