mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-05 13:37:43 +03:00
Fix multiple TOTP issues
* Fix #9847 - don't provide TOTP values if settings are blank or completely wrong * Fix #6838 - don't reset the ui when creating a new entry and applying TOTP to it * Move totp source into the core folder
This commit is contained in:
parent
5d64292ed8
commit
9f3b4dc5ea
16 changed files with 52 additions and 17 deletions
|
@ -115,6 +115,7 @@ EditEntryWidget::EditEntryWidget(QWidget* parent)
|
|||
m_entryModifiedTimer.setSingleShot(true);
|
||||
m_entryModifiedTimer.setInterval(0);
|
||||
connect(&m_entryModifiedTimer, &QTimer::timeout, this, [this] {
|
||||
// TODO: Upon refactor of this widget, this needs to merge unsaved changes in the UI
|
||||
if (isVisible() && m_entry) {
|
||||
setForms(m_entry);
|
||||
}
|
||||
|
@ -711,6 +712,13 @@ void EditEntryWidget::toKeeAgentSettings(KeeAgentSettings& settings) const
|
|||
settings.setSaveAttachmentToTempFile(m_sshAgentSettings.saveAttachmentToTempFile());
|
||||
}
|
||||
|
||||
void EditEntryWidget::updateTotp()
|
||||
{
|
||||
if (m_entry) {
|
||||
m_attributesModel->setEntryAttributes(m_entry->attributes());
|
||||
}
|
||||
}
|
||||
|
||||
void EditEntryWidget::browsePrivateKey()
|
||||
{
|
||||
auto fileName = fileDialog()->getOpenFileName(this, tr("Select private key"), FileDialog::getLastDir("sshagent"));
|
||||
|
@ -867,8 +875,6 @@ void EditEntryWidget::loadEntry(Entry* entry,
|
|||
m_create = create;
|
||||
m_history = history;
|
||||
|
||||
connect(m_entry, &Entry::modified, this, [this] { m_entryModifiedTimer.start(); });
|
||||
|
||||
if (history) {
|
||||
setHeadline(QString("%1 \u2022 %2").arg(parentName, tr("Entry history")));
|
||||
} else {
|
||||
|
@ -876,6 +882,8 @@ void EditEntryWidget::loadEntry(Entry* entry,
|
|||
setHeadline(QString("%1 \u2022 %2").arg(parentName, tr("Add entry")));
|
||||
} else {
|
||||
setHeadline(QString("%1 \u2022 %2 \u2022 %3").arg(parentName, entry->title(), tr("Edit entry")));
|
||||
// Reload entry details if changed outside of the edit dialog
|
||||
connect(m_entry, &Entry::modified, this, [this] { m_entryModifiedTimer.start(); });
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue