mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-06 14:07:38 +03:00
Re-implement AutoOpen functionality after refactor (#2504)
The database refactor in #2491 removed auto-open functionality.
This commit is contained in:
parent
785a64cc3b
commit
ff7191eef3
4 changed files with 75 additions and 10 deletions
|
@ -397,6 +397,7 @@ void DatabaseWidget::replaceDatabase(QSharedPointer<Database> db)
|
|||
m_db = std::move(db);
|
||||
connectDatabaseSignals();
|
||||
m_groupView->changeDatabase(m_db);
|
||||
processAutoOpen();
|
||||
}
|
||||
|
||||
void DatabaseWidget::cloneEntry()
|
||||
|
@ -954,6 +955,7 @@ void DatabaseWidget::switchToOpenDatabase(const QString& filePath)
|
|||
setCurrentWidget(m_unlockDatabaseWidget);
|
||||
}
|
||||
}
|
||||
|
||||
void DatabaseWidget::switchToCsvImport(const QString& filePath)
|
||||
{
|
||||
setCurrentWidget(m_csvImportWizard);
|
||||
|
@ -980,6 +982,18 @@ void DatabaseWidget::switchToImportKeepass1(const QString& filePath)
|
|||
setCurrentWidget(m_keepass1OpenWidget);
|
||||
}
|
||||
|
||||
void DatabaseWidget::performUnlockDatabase(const QString& password, const QString& keyfile)
|
||||
{
|
||||
if (password.isEmpty() && keyfile.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (!m_db->isInitialized() || isLocked()) {
|
||||
switchToOpenDatabase();
|
||||
m_databaseOpenWidget->enterKey(password, keyfile);
|
||||
}
|
||||
}
|
||||
|
||||
void DatabaseWidget::refreshSearch()
|
||||
{
|
||||
if (isSearchActive()) {
|
||||
|
@ -1561,3 +1575,37 @@ void DatabaseWidget::emptyRecycleBin()
|
|||
refreshSearch();
|
||||
}
|
||||
}
|
||||
|
||||
void DatabaseWidget::processAutoOpen()
|
||||
{
|
||||
Q_ASSERT(m_db);
|
||||
|
||||
auto* autoopenGroup = m_db->rootGroup()->findGroupByPath("/AutoOpen");
|
||||
if (!autoopenGroup) {
|
||||
return;
|
||||
}
|
||||
|
||||
for (const auto* entry : autoopenGroup->entries()) {
|
||||
if (entry->url().isEmpty() || entry->password().isEmpty()) {
|
||||
continue;
|
||||
}
|
||||
QFileInfo filepath;
|
||||
if (entry->url().startsWith("file://")) {
|
||||
QUrl url(entry->url());
|
||||
filepath.setFile(url.toLocalFile());
|
||||
} else {
|
||||
filepath.setFile(entry->url());
|
||||
if (filepath.isRelative()) {
|
||||
QFileInfo currentpath(m_db->filePath());
|
||||
filepath.setFile(currentpath.absoluteDir(), entry->url());
|
||||
}
|
||||
}
|
||||
|
||||
if (!filepath.isFile()) {
|
||||
continue;
|
||||
}
|
||||
|
||||
// Request to open the database file in the background
|
||||
emit requestOpenDatabase(filepath.canonicalFilePath(), true, entry->password());
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue