mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-05 13:37:43 +03:00
Improve Auto-Type Select Dialog
Significant improvements to the Auto-Type select dialog. Reduce stale and unnecessary code paths. * Close select dialog when databases are locked. * Close open modal dialogs prior to showing the Auto-Type select dialog to prevent interference. * Never perform Auto-Type on the KeePassXC window. * Only filter match list based on Group, Title, and Username column data (ie, ignore sequence column) * Always show the sequence column (revert feature) * Show selection dialog if there are no matches to allow for a database search * Close #3630 - Allow typing {USERNAME} and {PASSWORD} from selection dialog (right-click menu). * Close #429 - Ability to search open databases for an entry from the Auto-Type selection dialog. * Fix #5361 - Default size of selection dialog doesn't cut off matches
This commit is contained in:
parent
7ce35f81de
commit
d9ae449f04
38 changed files with 830 additions and 1047 deletions
|
@ -20,6 +20,7 @@
|
|||
#include "config-keepassx.h"
|
||||
|
||||
#include "core/Clock.h"
|
||||
#include "core/Config.h"
|
||||
#include "core/Database.h"
|
||||
#include "core/DatabaseIcons.h"
|
||||
#include "core/Group.h"
|
||||
|
@ -280,6 +281,75 @@ QString Entry::effectiveAutoTypeSequence() const
|
|||
return sequence;
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrive the autotype sequences matches for a given windowTitle
|
||||
* This returns a list with priority ordering. If you don't want duplicates call .toSet() on it.
|
||||
*/
|
||||
QList<QString> Entry::autoTypeSequences(const QString& windowTitle) const
|
||||
{
|
||||
// If no window just return the effective sequence
|
||||
if (windowTitle.isEmpty()) {
|
||||
return {effectiveAutoTypeSequence()};
|
||||
}
|
||||
|
||||
// Define helper functions to match window titles
|
||||
auto windowMatches = [&](const QString& pattern) {
|
||||
// Regex searching
|
||||
if (pattern.startsWith("//") && pattern.endsWith("//") && pattern.size() >= 4) {
|
||||
QRegExp regExp(pattern.mid(2, pattern.size() - 4), Qt::CaseInsensitive, QRegExp::RegExp2);
|
||||
return (regExp.indexIn(windowTitle) != -1);
|
||||
}
|
||||
|
||||
// Wildcard searching
|
||||
auto regex = Tools::convertToRegex(pattern, true, false, false);
|
||||
return windowTitle.contains(regex);
|
||||
};
|
||||
|
||||
auto windowMatchesTitle = [&](const QString& entryTitle) {
|
||||
return !entryTitle.isEmpty() && windowTitle.contains(entryTitle, Qt::CaseInsensitive);
|
||||
};
|
||||
|
||||
auto windowMatchesUrl = [&](const QString& entryUrl) {
|
||||
if (!entryUrl.isEmpty() && windowTitle.contains(entryUrl, Qt::CaseInsensitive)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
QUrl url(entryUrl);
|
||||
if (url.isValid() && !url.host().isEmpty()) {
|
||||
return windowTitle.contains(url.host(), Qt::CaseInsensitive);
|
||||
}
|
||||
|
||||
return false;
|
||||
};
|
||||
|
||||
QList<QString> sequenceList;
|
||||
|
||||
// Add window association matches
|
||||
const auto assocList = autoTypeAssociations()->getAll();
|
||||
for (const auto& assoc : assocList) {
|
||||
auto window = resolveMultiplePlaceholders(assoc.window);
|
||||
if (windowMatches(window)) {
|
||||
if (!assoc.sequence.isEmpty()) {
|
||||
sequenceList << assoc.sequence;
|
||||
} else {
|
||||
sequenceList << effectiveAutoTypeSequence();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Try to match window title
|
||||
if (config()->get(Config::AutoTypeEntryTitleMatch).toBool() && windowMatchesTitle(resolvePlaceholder(title()))) {
|
||||
sequenceList << effectiveAutoTypeSequence();
|
||||
}
|
||||
|
||||
// Try to match url in window title
|
||||
if (config()->get(Config::AutoTypeEntryURLMatch).toBool() && windowMatchesUrl(resolvePlaceholder(url()))) {
|
||||
sequenceList << effectiveAutoTypeSequence();
|
||||
}
|
||||
|
||||
return sequenceList;
|
||||
}
|
||||
|
||||
AutoTypeAssociations* Entry::autoTypeAssociations()
|
||||
{
|
||||
return m_autoTypeAssociations;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue