mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-12-01 03:46:42 -05:00
Complete refactor of TOTP integration
* Eliminate TOTP logic from GUI elements * Consolidate TOTP functionality under the Totp namespace * Eliminate guessing about state and encoders * Increased test cases * Add entry view column for TOTP [#2132] * General code cleanup, reduction of unnecessary steps, separation of concerns * Rename SetupTotpDialog to TotpSetupDialog for consistency
This commit is contained in:
parent
b74fb3e208
commit
1dc9f10c7f
21 changed files with 585 additions and 716 deletions
83
src/gui/TotpSetupDialog.cpp
Normal file
83
src/gui/TotpSetupDialog.cpp
Normal file
|
|
@ -0,0 +1,83 @@
|
|||
/*
|
||||
* Copyright (C) 2017 Weslly Honorato <weslly@protonmail.com>
|
||||
* Copyright (C) 2017 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
|
||||
* the Free Software Foundation, either version 2 or (at your option)
|
||||
* version 3 of the License.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include "TotpSetupDialog.h"
|
||||
#include "totp/totp.h"
|
||||
#include "ui_TotpSetupDialog.h"
|
||||
|
||||
TotpSetupDialog::TotpSetupDialog(QWidget* parent, Entry* entry)
|
||||
: QDialog(parent)
|
||||
, m_ui(new Ui::TotpSetupDialog())
|
||||
, m_entry(entry)
|
||||
{
|
||||
m_ui->setupUi(this);
|
||||
setAttribute(Qt::WA_DeleteOnClose);
|
||||
setFixedSize(sizeHint());
|
||||
|
||||
connect(m_ui->buttonBox, SIGNAL(rejected()), SLOT(close()));
|
||||
connect(m_ui->buttonBox, SIGNAL(accepted()), SLOT(saveSettings()));
|
||||
connect(m_ui->radioCustom, SIGNAL(toggled(bool)), SLOT(toggleCustom(bool)));
|
||||
|
||||
init();
|
||||
}
|
||||
|
||||
TotpSetupDialog::~TotpSetupDialog()
|
||||
{
|
||||
}
|
||||
|
||||
void TotpSetupDialog::saveSettings()
|
||||
{
|
||||
QString encShortName;
|
||||
uint digits = Totp::DEFAULT_DIGITS;
|
||||
if (m_ui->radio8Digits->isChecked()) {
|
||||
digits = 8;
|
||||
} else if (m_ui->radioSteam->isChecked()) {
|
||||
digits = Totp::STEAM_DIGITS;
|
||||
encShortName = Totp::STEAM_SHORTNAME;
|
||||
}
|
||||
|
||||
auto settings = Totp::createSettings(m_ui->seedEdit->text(), digits, m_ui->stepSpinBox->value(), encShortName);
|
||||
m_entry->setTotp(settings);
|
||||
emit totpUpdated();
|
||||
close();
|
||||
}
|
||||
|
||||
void TotpSetupDialog::toggleCustom(bool status)
|
||||
{
|
||||
m_ui->customGroup->setEnabled(status);
|
||||
}
|
||||
|
||||
void TotpSetupDialog::init()
|
||||
{
|
||||
auto settings = m_entry->totpSettings();
|
||||
if (!settings.isNull()) {
|
||||
m_ui->seedEdit->setText(settings->key);
|
||||
m_ui->stepSpinBox->setValue(settings->step);
|
||||
|
||||
if (settings->encoder.shortName == Totp::STEAM_SHORTNAME) {
|
||||
m_ui->radioSteam->setChecked(true);
|
||||
} else if (settings->custom) {
|
||||
m_ui->radioCustom->setChecked(true);
|
||||
if (settings->digits == 8) {
|
||||
m_ui->radio8Digits->setChecked(true);
|
||||
} else {
|
||||
m_ui->radio6Digits->setChecked(true);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue