mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-13 16:30:29 -05:00
Allow abbreviation of search field names
This allows `t:word` instead of `title:word` and `p:word` instead of `password:word`, and so on. The rule is that an abbreviated name expands to the first field name that starts with it, with exceptions `u:` expanding to `username:` instead of `url:` and `pw:` expanding to `password:`.
This commit is contained in:
parent
0a3b19edf2
commit
41131ae48d
@ -173,6 +173,17 @@ bool EntrySearcher::searchEntryImpl(Entry* entry)
|
|||||||
|
|
||||||
void EntrySearcher::parseSearchTerms(const QString& searchString)
|
void EntrySearcher::parseSearchTerms(const QString& searchString)
|
||||||
{
|
{
|
||||||
|
static const QList<QPair<QString, Field>> fieldnames{
|
||||||
|
{QStringLiteral("attachment"), Field::Attachment},
|
||||||
|
{QStringLiteral("attribute"), Field::AttributeKey},
|
||||||
|
{QStringLiteral("notes"), Field::Notes},
|
||||||
|
{QStringLiteral("pw"), Field::Password},
|
||||||
|
{QStringLiteral("password"), Field::Password},
|
||||||
|
{QStringLiteral("title"), Field::Title},
|
||||||
|
{QStringLiteral("u"), Field::Username}, // u: stands for username rather than url
|
||||||
|
{QStringLiteral("url"), Field::Url},
|
||||||
|
{QStringLiteral("username"), Field::Username}};
|
||||||
|
|
||||||
m_searchTerms.clear();
|
m_searchTerms.clear();
|
||||||
auto results = m_termParser.globalMatch(searchString);
|
auto results = m_termParser.globalMatch(searchString);
|
||||||
while (results.hasNext()) {
|
while (results.hasNext()) {
|
||||||
@ -201,32 +212,24 @@ void EntrySearcher::parseSearchTerms(const QString& searchString)
|
|||||||
term->exclude = mods.contains("-") || mods.contains("!");
|
term->exclude = mods.contains("-") || mods.contains("!");
|
||||||
|
|
||||||
// Determine the field to search
|
// Determine the field to search
|
||||||
|
term->field = Field::Undefined;
|
||||||
|
|
||||||
QString field = result.captured(2);
|
QString field = result.captured(2);
|
||||||
if (!field.isEmpty()) {
|
if (!field.isEmpty()) {
|
||||||
auto cs = Qt::CaseInsensitive;
|
if (field.startsWith("_", Qt::CaseInsensitive)) {
|
||||||
if (field.compare("title", cs) == 0) {
|
|
||||||
term->field = Field::Title;
|
|
||||||
} else if (field.startsWith("user", cs)) {
|
|
||||||
term->field = Field::Username;
|
|
||||||
} else if (field.startsWith("pass", cs)) {
|
|
||||||
term->field = Field::Password;
|
|
||||||
} else if (field.compare("url", cs) == 0) {
|
|
||||||
term->field = Field::Url;
|
|
||||||
} else if (field.compare("notes", cs) == 0) {
|
|
||||||
term->field = Field::Notes;
|
|
||||||
} else if (field.startsWith("attr", cs)) {
|
|
||||||
term->field = Field::AttributeKey;
|
|
||||||
} else if (field.startsWith("attach", cs)) {
|
|
||||||
term->field = Field::Attachment;
|
|
||||||
} else if (field.startsWith("_", cs)) {
|
|
||||||
term->field = Field::AttributeValue;
|
term->field = Field::AttributeValue;
|
||||||
// searching a custom attribute
|
// searching a custom attribute
|
||||||
// in this case term->word is the attribute key (removing the leading "_")
|
// in this case term->word is the attribute key (removing the leading "_")
|
||||||
// and term->regex is used to match attribute value
|
// and term->regex is used to match attribute value
|
||||||
term->word = field.mid(1);
|
term->word = field.mid(1);
|
||||||
|
} else {
|
||||||
|
for (const auto& pair : fieldnames) {
|
||||||
|
if (pair.first.startsWith(field, Qt::CaseInsensitive)) {
|
||||||
|
term->field = pair.second;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
term->field = Field::Undefined;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
m_searchTerms.append(term);
|
m_searchTerms.append(term);
|
||||||
|
@ -237,21 +237,21 @@
|
|||||||
<item row="1" column="0">
|
<item row="1" column="0">
|
||||||
<widget class="QLabel" name="label_3">
|
<widget class="QLabel" name="label_3">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string notr="true">username</string>
|
<string notr="true">username (u)</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="2" column="0">
|
<item row="2" column="0">
|
||||||
<widget class="QLabel" name="label_11">
|
<widget class="QLabel" name="label_11">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string notr="true">password</string>
|
<string notr="true">password (p, pw)</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="0" column="0">
|
<item row="0" column="0">
|
||||||
<widget class="QLabel" name="label">
|
<widget class="QLabel" name="label">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string notr="true">title</string>
|
<string notr="true">title (t)</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
@ -265,21 +265,21 @@
|
|||||||
<item row="0" column="1">
|
<item row="0" column="1">
|
||||||
<widget class="QLabel" name="label_5">
|
<widget class="QLabel" name="label_5">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string notr="true">notes</string>
|
<string notr="true">notes (n)</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="1">
|
<item row="1" column="1">
|
||||||
<widget class="QLabel" name="label_12">
|
<widget class="QLabel" name="label_12">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string notr="true">attribute</string>
|
<string notr="true">attribute (attr)</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="2" column="1">
|
<item row="2" column="1">
|
||||||
<widget class="QLabel" name="label_14">
|
<widget class="QLabel" name="label_14">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string notr="true">attachment</string>
|
<string notr="true">attachment (attach)</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
@ -96,7 +96,7 @@ void TestEntrySearcher::testSearch()
|
|||||||
e3->setGroup(group3);
|
e3->setGroup(group3);
|
||||||
|
|
||||||
Entry* e3b = new Entry();
|
Entry* e3b = new Entry();
|
||||||
e3b->setTitle("test search test");
|
e3b->setTitle("test search test 123");
|
||||||
e3b->setUsername("test@email.com");
|
e3b->setUsername("test@email.com");
|
||||||
e3b->setPassword("realpass");
|
e3b->setPassword("realpass");
|
||||||
e3b->setGroup(group3);
|
e3b->setGroup(group3);
|
||||||
@ -108,16 +108,31 @@ void TestEntrySearcher::testSearch()
|
|||||||
m_searchResult = m_entrySearcher.search("search term", m_rootGroup);
|
m_searchResult = m_entrySearcher.search("search term", m_rootGroup);
|
||||||
QCOMPARE(m_searchResult.count(), 3);
|
QCOMPARE(m_searchResult.count(), 3);
|
||||||
|
|
||||||
|
m_searchResult = m_entrySearcher.search("123", m_rootGroup);
|
||||||
|
QCOMPARE(m_searchResult.count(), 2);
|
||||||
|
|
||||||
m_searchResult = m_entrySearcher.search("search term", group211);
|
m_searchResult = m_entrySearcher.search("search term", group211);
|
||||||
QCOMPARE(m_searchResult.count(), 1);
|
QCOMPARE(m_searchResult.count(), 1);
|
||||||
|
|
||||||
// Test advanced search terms
|
// Test advanced search terms
|
||||||
|
m_searchResult = m_entrySearcher.search("title:123", m_rootGroup);
|
||||||
|
QCOMPARE(m_searchResult.count(), 1);
|
||||||
|
|
||||||
|
m_searchResult = m_entrySearcher.search("t:123", m_rootGroup);
|
||||||
|
QCOMPARE(m_searchResult.count(), 1);
|
||||||
|
|
||||||
m_searchResult = m_entrySearcher.search("password:testpass", m_rootGroup);
|
m_searchResult = m_entrySearcher.search("password:testpass", m_rootGroup);
|
||||||
QCOMPARE(m_searchResult.count(), 1);
|
QCOMPARE(m_searchResult.count(), 1);
|
||||||
|
|
||||||
|
m_searchResult = m_entrySearcher.search("pw:testpass", m_rootGroup);
|
||||||
|
QCOMPARE(m_searchResult.count(), 1);
|
||||||
|
|
||||||
m_searchResult = m_entrySearcher.search("!user:email.com", m_rootGroup);
|
m_searchResult = m_entrySearcher.search("!user:email.com", m_rootGroup);
|
||||||
QCOMPARE(m_searchResult.count(), 5);
|
QCOMPARE(m_searchResult.count(), 5);
|
||||||
|
|
||||||
|
m_searchResult = m_entrySearcher.search("!u:email.com", m_rootGroup);
|
||||||
|
QCOMPARE(m_searchResult.count(), 5);
|
||||||
|
|
||||||
m_searchResult = m_entrySearcher.search("*user:\".*@.*\\.com\"", m_rootGroup);
|
m_searchResult = m_entrySearcher.search("*user:\".*@.*\\.com\"", m_rootGroup);
|
||||||
QCOMPARE(m_searchResult.count(), 1);
|
QCOMPARE(m_searchResult.count(), 1);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user