mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-03 20:47:37 +03:00
Passkeys: Add support for importing Passkey to entry (#9987)
--------- Co-authored-by: Jonathan White <support@dmapps.us>
This commit is contained in:
parent
013db199cb
commit
13c88e1013
27 changed files with 459 additions and 176 deletions
|
@ -341,8 +341,8 @@ void TestBrowser::testSearchEntriesByReference()
|
|||
auto secondEntryUuid = entries[1]->uuidToHex();
|
||||
auto fullReference = QString("{REF:A@I:%1}").arg(firstEntryUuid);
|
||||
auto partialReference = QString("https://subdomain.{REF:A@I:%1}").arg(secondEntryUuid);
|
||||
entries[2]->attributes()->set(BrowserService::ADDITIONAL_URL, fullReference);
|
||||
entries[3]->attributes()->set(BrowserService::ADDITIONAL_URL, partialReference);
|
||||
entries[2]->attributes()->set(EntryAttributes::AdditionalUrlAttribute, fullReference);
|
||||
entries[3]->attributes()->set(EntryAttributes::AdditionalUrlAttribute, partialReference);
|
||||
entries[4]->setUrl(fullReference);
|
||||
entries[5]->setUrl(partialReference);
|
||||
|
||||
|
@ -351,11 +351,13 @@ void TestBrowser::testSearchEntriesByReference()
|
|||
QCOMPARE(result[0]->url(), urls[0]);
|
||||
QCOMPARE(result[1]->url(), urls[1]);
|
||||
QCOMPARE(result[2]->url(), urls[2]);
|
||||
QCOMPARE(result[2]->resolveMultiplePlaceholders(result[2]->attributes()->value(BrowserService::ADDITIONAL_URL)),
|
||||
urls[0]);
|
||||
QCOMPARE(
|
||||
result[2]->resolveMultiplePlaceholders(result[2]->attributes()->value(EntryAttributes::AdditionalUrlAttribute)),
|
||||
urls[0]);
|
||||
QCOMPARE(result[3]->url(), urls[3]);
|
||||
QCOMPARE(result[3]->resolveMultiplePlaceholders(result[3]->attributes()->value(BrowserService::ADDITIONAL_URL)),
|
||||
urls[0]);
|
||||
QCOMPARE(
|
||||
result[3]->resolveMultiplePlaceholders(result[3]->attributes()->value(EntryAttributes::AdditionalUrlAttribute)),
|
||||
urls[0]);
|
||||
QCOMPARE(result[4]->url(), fullReference);
|
||||
QCOMPARE(result[4]->resolveMultiplePlaceholders(result[4]->url()), urls[0]); // Should be resolved to the main entry
|
||||
QCOMPARE(result[5]->url(), partialReference);
|
||||
|
@ -386,7 +388,7 @@ void TestBrowser::testSearchEntriesWithAdditionalURLs()
|
|||
auto entries = createEntries(urls, root);
|
||||
|
||||
// Add an additional URL to the first entry
|
||||
entries.first()->attributes()->set(BrowserService::ADDITIONAL_URL, "https://keepassxc.org");
|
||||
entries.first()->attributes()->set(EntryAttributes::AdditionalUrlAttribute, "https://keepassxc.org");
|
||||
|
||||
auto result = m_browserService->searchEntries(db, "https://github.com", "https://github.com/session");
|
||||
QCOMPARE(result.length(), 1);
|
||||
|
@ -663,7 +665,7 @@ void TestBrowser::testBestMatchingWithAdditionalURLs()
|
|||
browserSettings()->setBestMatchOnly(true);
|
||||
|
||||
// Add an additional URL to the first entry
|
||||
entries.first()->attributes()->set(BrowserService::ADDITIONAL_URL, "https://test.github.com/anotherpage");
|
||||
entries.first()->attributes()->set(EntryAttributes::AdditionalUrlAttribute, "https://test.github.com/anotherpage");
|
||||
|
||||
// The first entry should be triggered
|
||||
auto result = m_browserService->searchEntries(
|
||||
|
|
|
@ -19,6 +19,9 @@
|
|||
#include "browser/BrowserCbor.h"
|
||||
#include "browser/BrowserMessageBuilder.h"
|
||||
#include "browser/BrowserService.h"
|
||||
#include "core/Database.h"
|
||||
#include "core/Entry.h"
|
||||
#include "core/Group.h"
|
||||
#include "crypto/Crypto.h"
|
||||
|
||||
#include <QJsonArray>
|
||||
|
@ -469,3 +472,27 @@ void TestPasskeys::testSetFlags()
|
|||
auto discouragedResult = browserPasskeys()->setFlagsFromJson(discouragedJson);
|
||||
QCOMPARE(discouragedResult, 0x01);
|
||||
}
|
||||
|
||||
void TestPasskeys::testEntry()
|
||||
{
|
||||
Database db;
|
||||
auto* root = db.rootGroup();
|
||||
root->setUuid(QUuid::createUuid());
|
||||
|
||||
auto* group1 = new Group();
|
||||
group1->setUuid(QUuid::createUuid());
|
||||
group1->setParent(root);
|
||||
|
||||
auto* entry = new Entry();
|
||||
entry->setGroup(root);
|
||||
|
||||
browserService()->addPasskeyToEntry(entry,
|
||||
QString("example.com"),
|
||||
QString("example.com"),
|
||||
QString("username"),
|
||||
QString("userId"),
|
||||
QString("userHandle"),
|
||||
QString("privateKey"));
|
||||
|
||||
QVERIFY(entry->hasPasskey());
|
||||
}
|
||||
|
|
|
@ -43,5 +43,7 @@ private slots:
|
|||
void testExtensions();
|
||||
void testParseFlags();
|
||||
void testSetFlags();
|
||||
|
||||
void testEntry();
|
||||
};
|
||||
#endif // KEEPASSXC_TESTPASSKEYS_H
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright (C) 2021 KeePassXC Team <team@keepassxc.org>
|
||||
* Copyright (C) 2023 KeePassXC Team <team@keepassxc.org>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
|
@ -239,3 +239,30 @@ void TestTools::testConvertToRegex_data()
|
|||
<< input << static_cast<int>(Tools::RegexConvertOpts::WILDCARD_UNLIMITED_MATCH)
|
||||
<< QString(R"(te\|st.*t\?\[5\]\^\(test\)\;\'\,\.)");
|
||||
}
|
||||
|
||||
void TestTools::testArrayContainsValues()
|
||||
{
|
||||
const auto values = QStringList() << "first"
|
||||
<< "second"
|
||||
<< "third";
|
||||
|
||||
// One missing
|
||||
const auto result1 = Tools::getMissingValuesFromList<QString>(values,
|
||||
QStringList() << "first"
|
||||
<< "second"
|
||||
<< "none");
|
||||
QCOMPARE(result1.length(), 1);
|
||||
QCOMPARE(result1.first(), QString("none"));
|
||||
|
||||
// All found
|
||||
const auto result2 = Tools::getMissingValuesFromList<QString>(values,
|
||||
QStringList() << "first"
|
||||
<< "second"
|
||||
<< "third");
|
||||
QCOMPARE(result2.length(), 0);
|
||||
|
||||
// None are found
|
||||
const auto numberValues = QList<int>({1, 2, 3, 4, 5});
|
||||
const auto result3 = Tools::getMissingValuesFromList<int>(numberValues, QList<int>({6, 7, 8}));
|
||||
QCOMPARE(result3.length(), 3);
|
||||
}
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright (C) 2021 KeePassXC Team <team@keepassxc.org>
|
||||
* Copyright (C) 2023 KeePassXC Team <team@keepassxc.org>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
|
@ -35,6 +35,7 @@ private slots:
|
|||
void testEscapeRegex_data();
|
||||
void testConvertToRegex();
|
||||
void testConvertToRegex_data();
|
||||
void testArrayContainsValues();
|
||||
};
|
||||
|
||||
#endif // KEEPASSX_TESTTOOLS_H
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue