aboutsummaryrefslogtreecommitdiffstats
path: root/src/ui/dialog/key_generate
diff options
context:
space:
mode:
Diffstat (limited to 'src/ui/dialog/key_generate')
-rw-r--r--src/ui/dialog/key_generate/KeyGenerateDialog.cpp641
-rw-r--r--src/ui/dialog/key_generate/KeyGenerateDialog.h (renamed from src/ui/dialog/key_generate/KeygenDialog.h)115
-rw-r--r--src/ui/dialog/key_generate/KeygenDialog.cpp482
-rw-r--r--src/ui/dialog/key_generate/SubkeyGenerateDialog.cpp447
-rw-r--r--src/ui/dialog/key_generate/SubkeyGenerateDialog.h91
5 files changed, 853 insertions, 923 deletions
diff --git a/src/ui/dialog/key_generate/KeyGenerateDialog.cpp b/src/ui/dialog/key_generate/KeyGenerateDialog.cpp
new file mode 100644
index 00000000..ab3a5ac8
--- /dev/null
+++ b/src/ui/dialog/key_generate/KeyGenerateDialog.cpp
@@ -0,0 +1,641 @@
+/**
+ * Copyright (C) 2021-2024 Saturneric <[email protected]>
+ *
+ * This file is part of GpgFrontend.
+ *
+ * GpgFrontend 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 3 of the License, or
+ * (at your option) any later version.
+ *
+ * GpgFrontend 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 GpgFrontend. If not, see <https://www.gnu.org/licenses/>.
+ *
+ * The initial version of the source code is inherited from
+ * the gpg4usb project, which is under GPL-3.0-or-later.
+ *
+ * All the source code of GpgFrontend was modified and released by
+ * Saturneric <[email protected]> starting on May 12, 2021.
+ *
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ *
+ */
+
+#include "KeyGenerateDialog.h"
+
+#include "core/GpgModel.h"
+#include "core/function/GlobalSettingStation.h"
+#include "core/function/gpg/GpgKeyOpera.h"
+#include "core/typedef/GpgTypedef.h"
+#include "core/utils/CacheUtils.h"
+#include "core/utils/GpgUtils.h"
+#include "ui/UISignalStation.h"
+#include "ui/UserInterfaceUtils.h"
+#include "ui/function/GpgOperaHelper.h"
+#include "ui/function/KeyGenerateHelper.h"
+
+//
+#include "ui_KeyGenDialog.h"
+
+namespace GpgFrontend::UI {
+
+KeyGenerateDialog::KeyGenerateDialog(int channel, QWidget* parent)
+ : GeneralDialog(typeid(KeyGenerateDialog).name(), parent),
+ ui_(QSharedPointer<Ui_KeyGenDialog>::create()),
+ gen_key_info_(QSharedPointer<KeyGenerateInfo>::create()),
+ gen_subkey_info_(nullptr),
+ supported_primary_key_algos_(KeyGenerateInfo::GetSupportedKeyAlgo()),
+ supported_subkey_algos_(KeyGenerateInfo::GetSupportedSubkeyAlgo()),
+ channel_(channel) {
+ ui_->setupUi(this);
+
+ for (const auto& key_db : GetGpgKeyDatabaseInfos()) {
+ ui_->keyDBIndexComboBox->insertItem(
+ key_db.channel, QString("%1: %2").arg(key_db.channel).arg(key_db.name));
+ }
+
+ ui_->easyAlgoComboBox->addItems({
+ tr("Custom"),
+ "RSA",
+ "DSA",
+ "ECC (25519)",
+ });
+
+ ui_->easyValidityPeriodComboBox->addItems({
+ tr("Custom"),
+ tr("3 Months"),
+ tr("6 Months"),
+ tr("1 Year"),
+ tr("2 Years"),
+ tr("5 Years"),
+ tr("10 Years"),
+ tr("Non Expired"),
+ });
+
+ ui_->easyCombinationComboBox->addItems({
+ tr("Primary Key Only"),
+ tr("Primary Key With Subkey"),
+ });
+
+ ui_->nameLabel->setText(tr("Name"));
+ ui_->emailLabel->setText(tr("Email"));
+ ui_->commentLabel->setText(tr("Comment"));
+ ui_->keyDBLabel->setText(tr("Key Database"));
+ ui_->easyAlgoLabel->setText(tr("Algorithm"));
+ ui_->easyValidPeriodLabel->setText(tr("Validity Period"));
+
+ ui_->pAlgoLabel->setText(tr("Algorithm"));
+ ui_->pExpireDateLabel->setText(tr("Validity Period"));
+ ui_->pKeyLengthLabel->setText(tr("Key Length"));
+ ui_->pUsageLabel->setText(tr("Usage"));
+ ui_->pEncrCheckBox->setText(tr("Encrypt"));
+ ui_->pSignCheckBox->setText(tr("Sign"));
+ ui_->pAuthCheckBox->setText(tr("Authentication"));
+ ui_->noPassphraseCheckBox->setText(tr("No Passphrase"));
+ ui_->pExpireCheckBox->setText(tr("Non Expired"));
+
+ ui_->sAlgoLabel->setText(tr("Algorithm"));
+ ui_->sExpireDateLabel->setText(tr("Expire Date"));
+ ui_->sKeyLengthLabel->setText(tr("Key Length"));
+ ui_->sUsageLabel->setText(tr("Usage"));
+ ui_->sEncrCheckBox->setText(tr("Encrypt"));
+ ui_->sSignCheckBox->setText(tr("Sign"));
+ ui_->sAuthCheckBox->setText(tr("Authentication"));
+ ui_->sExpireCheckBox->setText(tr("Non Expired"));
+
+ assert(ui_->tabWidget->count() == 3);
+ ui_->tabWidget->setTabText(0, tr("Easy Mode"));
+ ui_->tabWidget->setTabText(1, tr("Primary Key"));
+ ui_->tabWidget->setTabText(2, tr("Subkey"));
+ ui_->tabWidget->setCurrentIndex(0);
+
+ ui_->generateButton->setText(tr("Generate"));
+
+ const auto min_date_time = QDateTime::currentDateTime().addDays(3);
+ ui_->pExpireDateTimeEdit->setMinimumDateTime(min_date_time);
+ ui_->sExpireDateTimeEdit->setMinimumDateTime(min_date_time);
+
+ QSet<QString> p_algo_set;
+ for (const auto& algo : supported_primary_key_algos_) {
+ p_algo_set.insert(algo.Name());
+ }
+ ui_->pAlgoComboBox->addItems(
+ QStringList(p_algo_set.cbegin(), p_algo_set.cend()));
+
+ QSet<QString> s_algo_set;
+ for (const auto& algo : supported_subkey_algos_) {
+ s_algo_set.insert(algo.Name());
+ }
+ ui_->sAlgoComboBox->addItem(tr("None"));
+ ui_->sAlgoComboBox->addItems(
+ QStringList(s_algo_set.cbegin(), s_algo_set.cend()));
+
+ ui_->easyAlgoComboBox->setCurrentText("RSA");
+ ui_->easyValidityPeriodComboBox->setCurrentText(tr("2 Years"));
+
+ set_signal_slot_config();
+
+ slot_easy_mode_changed("RSA");
+ slot_easy_valid_date_changed(tr("2 Years"));
+
+ this->setWindowTitle(tr("Generate Key"));
+ this->setAttribute(Qt::WA_DeleteOnClose);
+ this->setModal(true);
+}
+
+void KeyGenerateDialog::slot_key_gen_accept() {
+ QString buffer;
+ QTextStream err_stream(&buffer);
+
+ if (ui_->nameEdit->text().size() < 5) {
+ err_stream << " -> " << tr("Name must contain at least five characters.")
+ << Qt::endl;
+ }
+ if (ui_->emailEdit->text().isEmpty() ||
+ !check_email_address(ui_->emailEdit->text())) {
+ err_stream << " -> " << tr("Please give a valid email address.")
+ << Qt::endl;
+ }
+
+ if (gen_key_info_->GetAlgo() == KeyGenerateInfo::kNoneAlgo) {
+ err_stream << " -> " << tr("Please give a valid primary key algorithm.")
+ << Qt::endl;
+ }
+
+ const auto min_expire_date = QDateTime::currentDateTime().addSecs(120);
+
+ if (!gen_key_info_->IsNonExpired() &&
+ gen_key_info_->GetExpireTime() < min_expire_date) {
+ err_stream << " -> "
+ << tr("Time to primary key expiration must not be less than 120 "
+ "seconds.")
+ << Qt::endl;
+ }
+
+ if (gen_subkey_info_ != nullptr) {
+ if (gen_subkey_info_->GetAlgo() == KeyGenerateInfo::kNoneAlgo) {
+ err_stream << " -> " << tr("Please give a valid subkey algorithm.")
+ << Qt::endl;
+ }
+
+ if (!gen_subkey_info_->IsNonExpired() &&
+ gen_subkey_info_->GetExpireTime() < min_expire_date) {
+ err_stream
+ << " -> "
+ << tr("Time to subkey expiration must not be less than 120 seconds.")
+ << Qt::endl;
+ }
+ }
+
+ const auto err_string = err_stream.readAll();
+ if (!err_string.isEmpty()) {
+ ui_->statusPlainTextEdit->clear();
+ ui_->statusPlainTextEdit->appendPlainText(err_string);
+ return;
+ }
+
+ gen_key_info_->SetName(ui_->nameEdit->text());
+ gen_key_info_->SetEmail(ui_->emailEdit->text());
+ gen_key_info_->SetComment(ui_->commentEdit->text());
+
+ LOG_D() << "try to generate key at gpg context channel: " << channel_;
+
+ do_generate();
+ this->done(0);
+}
+
+void KeyGenerateDialog::refresh_widgets_state() {
+ ui_->pAlgoComboBox->blockSignals(true);
+ ui_->pAlgoComboBox->setCurrentText(gen_key_info_->GetAlgo().Name());
+ ui_->pAlgoComboBox->blockSignals(false);
+
+ ui_->pKeyLengthComboBox->blockSignals(true);
+ SetKeyLengthComboxBoxByAlgo(
+ ui_->pKeyLengthComboBox,
+ SearchAlgoByName(ui_->pAlgoComboBox->currentText(),
+ supported_primary_key_algos_));
+ ui_->pKeyLengthComboBox->setCurrentText(
+ QString::number(gen_key_info_->GetKeyLength()));
+ ui_->pKeyLengthComboBox->blockSignals(false);
+
+ ui_->pEncrCheckBox->blockSignals(true);
+ ui_->pEncrCheckBox->setCheckState(
+ gen_key_info_->IsAllowEncr() ? Qt::Checked : Qt::Unchecked);
+ ui_->pEncrCheckBox->setEnabled(gen_key_info_->IsAllowModifyEncr());
+ ui_->pEncrCheckBox->blockSignals(false);
+
+ ui_->pSignCheckBox->blockSignals(true);
+ ui_->pSignCheckBox->setCheckState(
+ gen_key_info_->IsAllowSign() ? Qt::Checked : Qt::Unchecked);
+ ui_->pSignCheckBox->setEnabled(gen_key_info_->IsAllowModifySign());
+ ui_->pSignCheckBox->blockSignals(false);
+
+ ui_->pAuthCheckBox->blockSignals(true);
+ ui_->pAuthCheckBox->setCheckState(
+ gen_key_info_->IsAllowAuth() ? Qt::Checked : Qt::Unchecked);
+ ui_->pAuthCheckBox->setEnabled(gen_key_info_->IsAllowModifyAuth());
+ ui_->pAuthCheckBox->blockSignals(false);
+
+ ui_->noPassphraseCheckBox->setEnabled(gen_key_info_->IsAllowNoPassPhrase());
+
+ ui_->pExpireDateTimeEdit->blockSignals(true);
+ ui_->pExpireDateTimeEdit->setDateTime(gen_key_info_->GetExpireTime());
+ ui_->pExpireDateTimeEdit->setDisabled(gen_key_info_->IsNonExpired());
+ ui_->pExpireDateTimeEdit->blockSignals(false);
+
+ ui_->pExpireCheckBox->blockSignals(true);
+ ui_->pExpireCheckBox->setChecked(gen_key_info_->IsNonExpired());
+ ui_->pExpireCheckBox->blockSignals(false);
+
+ ui_->generateButton->setDisabled(false);
+
+ if (gen_subkey_info_ == nullptr) {
+ ui_->sTab->setDisabled(true);
+
+ ui_->sAlgoComboBox->blockSignals(true);
+ ui_->sAlgoComboBox->setCurrentText(tr("None"));
+ ui_->sAlgoComboBox->blockSignals(false);
+
+ ui_->sKeyLengthComboBox->blockSignals(true);
+ ui_->sKeyLengthComboBox->clear();
+ ui_->sKeyLengthComboBox->blockSignals(false);
+
+ ui_->sEncrCheckBox->blockSignals(true);
+ ui_->sEncrCheckBox->setCheckState(Qt::Unchecked);
+ ui_->sEncrCheckBox->blockSignals(false);
+
+ ui_->sSignCheckBox->blockSignals(true);
+ ui_->sSignCheckBox->setCheckState(Qt::Unchecked);
+ ui_->sSignCheckBox->blockSignals(false);
+
+ ui_->sAuthCheckBox->blockSignals(true);
+ ui_->sAuthCheckBox->setCheckState(Qt::Unchecked);
+ ui_->sAuthCheckBox->blockSignals(false);
+
+ ui_->sExpireDateTimeEdit->blockSignals(true);
+ ui_->sExpireDateTimeEdit->setDateTime(QDateTime::currentDateTime());
+ ui_->sExpireDateTimeEdit->setDisabled(true);
+ ui_->sExpireDateTimeEdit->blockSignals(false);
+
+ ui_->sExpireCheckBox->blockSignals(true);
+ ui_->sExpireCheckBox->setCheckState(Qt::Unchecked);
+ ui_->sExpireCheckBox->blockSignals(false);
+
+ ui_->easyCombinationComboBox->blockSignals(true);
+ ui_->easyCombinationComboBox->setCurrentText(tr("Primary Key Only"));
+ ui_->easyCombinationComboBox->blockSignals(false);
+ return;
+ }
+
+ ui_->sTab->setDisabled(false);
+
+ ui_->sAlgoComboBox->blockSignals(true);
+ ui_->sAlgoComboBox->setCurrentText(gen_subkey_info_->GetAlgo().Name());
+ ui_->sAlgoComboBox->blockSignals(false);
+
+ ui_->sKeyLengthComboBox->blockSignals(true);
+ SetKeyLengthComboxBoxByAlgo(
+ ui_->sKeyLengthComboBox,
+ SearchAlgoByName(ui_->sAlgoComboBox->currentText(),
+ supported_subkey_algos_));
+ ui_->sKeyLengthComboBox->setCurrentText(
+ QString::number(gen_subkey_info_->GetKeyLength()));
+ ui_->sKeyLengthComboBox->blockSignals(false);
+
+ ui_->sEncrCheckBox->blockSignals(true);
+ ui_->sEncrCheckBox->setCheckState(
+ gen_subkey_info_->IsAllowEncr() ? Qt::Checked : Qt::Unchecked);
+ ui_->sEncrCheckBox->setEnabled(gen_subkey_info_->IsAllowModifyEncr());
+ ui_->sEncrCheckBox->blockSignals(false);
+
+ ui_->sSignCheckBox->blockSignals(true);
+ ui_->sSignCheckBox->setCheckState(
+ gen_subkey_info_->IsAllowSign() ? Qt::Checked : Qt::Unchecked);
+ ui_->sSignCheckBox->setEnabled(gen_subkey_info_->IsAllowModifySign());
+ ui_->sSignCheckBox->blockSignals(false);
+
+ ui_->sAuthCheckBox->blockSignals(true);
+ ui_->sAuthCheckBox->setCheckState(
+ gen_subkey_info_->IsAllowAuth() ? Qt::Checked : Qt::Unchecked);
+ ui_->sAuthCheckBox->setEnabled(gen_subkey_info_->IsAllowModifyAuth());
+ ui_->sAuthCheckBox->blockSignals(false);
+
+ ui_->sExpireDateTimeEdit->blockSignals(true);
+ ui_->sExpireDateTimeEdit->setDateTime(gen_subkey_info_->GetExpireTime());
+ ui_->sExpireDateTimeEdit->setDisabled(gen_subkey_info_->IsNonExpired());
+ ui_->sExpireDateTimeEdit->blockSignals(false);
+
+ ui_->sExpireCheckBox->blockSignals(true);
+ ui_->sExpireCheckBox->setChecked(gen_subkey_info_->IsNonExpired());
+ ui_->sExpireCheckBox->blockSignals(false);
+
+ ui_->easyCombinationComboBox->blockSignals(true);
+ ui_->easyCombinationComboBox->setCurrentText(tr("Primary Key With Subkey"));
+ ui_->easyCombinationComboBox->blockSignals(false);
+}
+
+void KeyGenerateDialog::set_signal_slot_config() {
+ connect(ui_->generateButton, &QPushButton::clicked, this,
+ &KeyGenerateDialog::slot_key_gen_accept);
+
+ connect(
+ ui_->pExpireCheckBox, &QCheckBox::stateChanged, this, [this](int state) {
+ gen_key_info_->SetNonExpired(state == Qt::Checked);
+ gen_key_info_->SetExpireTime(QDateTime::currentDateTime().addYears(2));
+ slot_set_easy_valid_date_2_custom();
+ refresh_widgets_state();
+ });
+ connect(ui_->sExpireCheckBox, &QCheckBox::stateChanged, this,
+ [this](int state) {
+ gen_subkey_info_->SetNonExpired(state == Qt::Checked);
+ gen_subkey_info_->SetExpireTime(
+ QDateTime::currentDateTime().addYears(2));
+ slot_set_easy_valid_date_2_custom();
+ refresh_widgets_state();
+ });
+
+ connect(
+ ui_->pEncrCheckBox, &QCheckBox::stateChanged, this,
+ [this](int state) { gen_key_info_->SetAllowEncr(state == Qt::Checked); });
+ connect(
+ ui_->pSignCheckBox, &QCheckBox::stateChanged, this,
+ [this](int state) { gen_key_info_->SetAllowSign(state == Qt::Checked); });
+ connect(
+ ui_->pAuthCheckBox, &QCheckBox::stateChanged, this,
+ [this](int state) { gen_key_info_->SetAllowAuth(state == Qt::Checked); });
+
+ connect(ui_->sEncrCheckBox, &QCheckBox::stateChanged, this,
+ [this](int state) {
+ gen_subkey_info_->SetAllowEncr(state == Qt::Checked);
+ });
+ connect(ui_->sSignCheckBox, &QCheckBox::stateChanged, this,
+ [this](int state) {
+ gen_subkey_info_->SetAllowSign(state == Qt::Checked);
+ });
+ connect(ui_->sAuthCheckBox, &QCheckBox::stateChanged, this,
+ [this](int state) {
+ gen_subkey_info_->SetAllowAuth(state == Qt::Checked);
+ });
+
+ connect(ui_->noPassphraseCheckBox, &QCheckBox::stateChanged, this,
+ [this](int state) -> void {
+ gen_key_info_->SetNonPassPhrase(state != 0);
+ if (gen_subkey_info_ != nullptr) {
+ gen_subkey_info_->SetNonPassPhrase(state != 0);
+ }
+ });
+
+ connect(ui_->pAlgoComboBox, &QComboBox::currentTextChanged, this,
+ [=](const QString&) {
+ sync_gen_key_algo_info();
+ slot_set_easy_key_algo_2_custom();
+ refresh_widgets_state();
+ });
+
+ connect(ui_->sAlgoComboBox, &QComboBox::currentTextChanged, this,
+ [=](const QString&) {
+ sync_gen_subkey_algo_info();
+ slot_set_easy_key_algo_2_custom();
+ refresh_widgets_state();
+ });
+
+ connect(ui_->easyAlgoComboBox, &QComboBox::currentTextChanged, this,
+ &KeyGenerateDialog::slot_easy_mode_changed);
+
+ connect(ui_->easyValidityPeriodComboBox, &QComboBox::currentTextChanged, this,
+ &KeyGenerateDialog::slot_easy_valid_date_changed);
+
+ connect(ui_->pExpireDateTimeEdit, &QDateTimeEdit::dateTimeChanged, this,
+ [=](const QDateTime& dt) {
+ gen_key_info_->SetExpireTime(dt);
+
+ slot_set_easy_valid_date_2_custom();
+ });
+
+ connect(ui_->sExpireDateTimeEdit, &QDateTimeEdit::dateTimeChanged, this,
+ [=](const QDateTime& dt) {
+ gen_subkey_info_->SetExpireTime(dt);
+
+ slot_set_easy_valid_date_2_custom();
+ });
+
+ connect(ui_->keyDBIndexComboBox, &QComboBox::currentIndexChanged, this,
+ [=](int index) { channel_ = index; });
+
+ connect(ui_->easyCombinationComboBox, &QComboBox::currentTextChanged, this,
+ &KeyGenerateDialog::slot_easy_combination_changed);
+
+ connect(ui_->pKeyLengthComboBox, &QComboBox::currentTextChanged, this,
+ [this](const QString& text) -> void {
+ auto [found, algo] = GetAlgoByNameAndKeyLength(
+ ui_->pAlgoComboBox->currentText(), text.toInt(),
+ supported_primary_key_algos_);
+
+ if (found) gen_key_info_->SetAlgo(algo);
+ });
+
+ connect(ui_->sKeyLengthComboBox, &QComboBox::currentTextChanged, this,
+ [this](const QString& text) -> void {
+ auto [found, algo] = GetAlgoByNameAndKeyLength(
+ ui_->sAlgoComboBox->currentText(), text.toInt(),
+ supported_subkey_algos_);
+
+ if (found) gen_subkey_info_->SetAlgo(algo);
+ });
+
+ connect(this, &KeyGenerateDialog::SignalKeyGenerated,
+ UISignalStation::GetInstance(),
+ &UISignalStation::SignalKeyDatabaseRefresh);
+}
+
+auto KeyGenerateDialog::check_email_address(const QString& str) -> bool {
+ return re_email_.match(str).hasMatch();
+}
+
+void KeyGenerateDialog::sync_gen_key_algo_info() {
+ auto [found, algo] = GetAlgoByName(ui_->pAlgoComboBox->currentText(),
+
+ supported_primary_key_algos_);
+
+ if (found) gen_key_info_->SetAlgo(found ? algo : KeyGenerateInfo::kNoneAlgo);
+}
+
+void KeyGenerateDialog::sync_gen_subkey_algo_info() {
+ if (gen_subkey_info_ != nullptr) {
+ auto [s_found, algo] = GetAlgoByName(ui_->sAlgoComboBox->currentText(),
+ supported_subkey_algos_);
+
+ if (s_found) {
+ gen_subkey_info_->SetAlgo(s_found ? algo : KeyGenerateInfo::kNoneAlgo);
+ }
+ }
+}
+
+void KeyGenerateDialog::slot_easy_mode_changed(const QString& mode) {
+ if (mode == "RSA") {
+ auto [found, algo] = KeyGenerateInfo::SearchPrimaryKeyAlgo("rsa2048");
+ if (found) gen_key_info_->SetAlgo(algo);
+
+ gen_subkey_info_ = nullptr;
+ }
+
+ else if (mode == "DSA") {
+ auto [found, algo] = KeyGenerateInfo::SearchPrimaryKeyAlgo("dsa2048");
+ if (found) gen_key_info_->SetAlgo(algo);
+
+ if (gen_subkey_info_ == nullptr) {
+ create_sync_gen_subkey_info();
+ }
+
+ auto [s_found, s_algo] = KeyGenerateInfo::SearchSubKeyAlgo("elg2048");
+ if (s_found) gen_subkey_info_->SetAlgo(s_algo);
+ }
+
+ else if (mode == "ECC (25519)") {
+ auto [found, algo] = KeyGenerateInfo::SearchPrimaryKeyAlgo("ed25519");
+ if (found) gen_key_info_->SetAlgo(algo);
+
+ if (gen_subkey_info_ == nullptr) {
+ create_sync_gen_subkey_info();
+ }
+
+ auto [s_found, s_algo] = KeyGenerateInfo::SearchSubKeyAlgo("cv25519");
+ if (s_found) gen_subkey_info_->SetAlgo(s_algo);
+ }
+
+ else {
+ auto [found, algo] = KeyGenerateInfo::SearchPrimaryKeyAlgo("rsa2048");
+ if (found) gen_key_info_->SetAlgo(algo);
+
+ if (gen_subkey_info_ == nullptr) {
+ create_sync_gen_subkey_info();
+ }
+
+ auto [s_found, s_algo] = KeyGenerateInfo::SearchSubKeyAlgo("rsa2048");
+ if (s_found) gen_subkey_info_->SetAlgo(s_algo);
+ }
+
+ refresh_widgets_state();
+}
+
+void KeyGenerateDialog::slot_easy_valid_date_changed(const QString& mode) {
+ if (mode == tr("3 Months")) {
+ gen_key_info_->SetNonExpired(false);
+ gen_key_info_->SetExpireTime(QDateTime::currentDateTime().addMonths(3));
+ }
+
+ else if (mode == tr("6 Months")) {
+ gen_key_info_->SetNonExpired(false);
+ gen_key_info_->SetExpireTime(QDateTime::currentDateTime().addMonths(6));
+ }
+
+ else if (mode == tr("1 Year")) {
+ gen_key_info_->SetNonExpired(false);
+ gen_key_info_->SetExpireTime(QDateTime::currentDateTime().addYears(1));
+ }
+
+ else if (mode == tr("2 Years")) {
+ gen_key_info_->SetNonExpired(false);
+ gen_key_info_->SetExpireTime(QDateTime::currentDateTime().addYears(2));
+ }
+
+ else if (mode == tr("5 Years")) {
+ gen_key_info_->SetNonExpired(false);
+ gen_key_info_->SetExpireTime(QDateTime::currentDateTime().addYears(5));
+ }
+
+ else if (mode == tr("10 Years")) {
+ gen_key_info_->SetNonExpired(false);
+ gen_key_info_->SetExpireTime(QDateTime::currentDateTime().addYears(10));
+
+ }
+
+ else if (mode == tr("Non Expired")) {
+ gen_key_info_->SetNonExpired(true);
+ gen_key_info_->SetExpireTime(QDateTime::currentDateTime());
+ }
+
+ else {
+ gen_key_info_->SetNonExpired(false);
+ gen_key_info_->SetExpireTime(QDateTime::currentDateTime().addYears(2));
+ }
+
+ if (gen_subkey_info_ != nullptr) {
+ gen_subkey_info_->SetNonExpired(gen_key_info_->IsNonExpired());
+ gen_subkey_info_->SetExpireTime(gen_key_info_->GetExpireTime());
+ }
+
+ refresh_widgets_state();
+}
+
+void KeyGenerateDialog::slot_set_easy_valid_date_2_custom() {
+ ui_->easyValidityPeriodComboBox->blockSignals(true);
+ ui_->easyValidityPeriodComboBox->setCurrentText(tr("Custom"));
+ ui_->easyValidityPeriodComboBox->blockSignals(false);
+}
+
+void KeyGenerateDialog::slot_set_easy_key_algo_2_custom() {
+ ui_->easyAlgoComboBox->blockSignals(true);
+ ui_->easyAlgoComboBox->setCurrentText(tr("Custom"));
+ ui_->easyAlgoComboBox->blockSignals(false);
+}
+
+void KeyGenerateDialog::slot_easy_combination_changed(const QString& mode) {
+ if (mode == tr("Primary Key Only")) {
+ gen_subkey_info_ = nullptr;
+ } else {
+ create_sync_gen_subkey_info();
+ }
+
+ slot_set_easy_key_algo_2_custom();
+ refresh_widgets_state();
+}
+
+void KeyGenerateDialog::do_generate() {
+ if (!GetSettings()
+ .value("gnupg/use_pinentry_as_password_input_dialog",
+ QString::fromLocal8Bit(qgetenv("container")) != "flatpak")
+ .toBool() &&
+ !ui_->noPassphraseCheckBox->isChecked()) {
+ SetCacheValue("PinentryContext", "NEW_PASSPHRASE");
+ }
+
+ auto f = [this,
+ gen_key_info = this->gen_key_info_](const OperaWaitingHd& hd) {
+ GpgKeyOpera::GetInstance(channel_).GenerateKeyWithSubkey(
+ gen_key_info, gen_subkey_info_,
+ [this, hd](GpgError err, const DataObjectPtr&) {
+ // stop showing waiting dialog
+ hd();
+
+ if (CheckGpgError(err) == GPG_ERR_USER_1) {
+ QMessageBox::critical(this, tr("Error"),
+ tr("Unknown error occurred"));
+ return;
+ }
+
+ CommonUtils::RaiseMessageBox(
+ this->parentWidget() != nullptr ? this->parentWidget() : this,
+ err);
+ if (CheckGpgError(err) == GPG_ERR_NO_ERROR) {
+ emit SignalKeyGenerated();
+ }
+ });
+ };
+ GpgOperaHelper::WaitForOpera(this, tr("Generating"), f);
+}
+
+void KeyGenerateDialog::create_sync_gen_subkey_info() {
+ if (gen_subkey_info_ == nullptr) {
+ gen_subkey_info_ = QSharedPointer<KeyGenerateInfo>::create(true);
+ }
+
+ sync_gen_subkey_algo_info();
+ slot_easy_valid_date_changed(ui_->easyValidityPeriodComboBox->currentText());
+}
+} // namespace GpgFrontend::UI
diff --git a/src/ui/dialog/key_generate/KeygenDialog.h b/src/ui/dialog/key_generate/KeyGenerateDialog.h
index 8b9757d5..ad927446 100644
--- a/src/ui/dialog/key_generate/KeygenDialog.h
+++ b/src/ui/dialog/key_generate/KeyGenerateDialog.h
@@ -28,20 +28,18 @@
#pragma once
-#include <memory>
-
-#include "core/model/GpgGenKeyInfo.h"
-#include "core/utils/MemoryUtils.h"
-#include "ui/GpgFrontendUI.h"
+#include "core/model/GpgKeyGenerateInfo.h"
#include "ui/dialog/GeneralDialog.h"
+class Ui_KeyGenDialog;
+
namespace GpgFrontend::UI {
/**
* @brief
*
*/
-class KeyGenDialog : public GeneralDialog {
+class KeyGenerateDialog : public GeneralDialog {
Q_OBJECT
public:
@@ -52,7 +50,7 @@ class KeyGenDialog : public GeneralDialog {
* @param key The key to show details of
* @param parent The parent of this widget
*/
- explicit KeyGenDialog(int channel, QWidget* parent = nullptr);
+ explicit KeyGenerateDialog(int channel, QWidget* parent = nullptr);
signals:
/**
@@ -61,131 +59,114 @@ class KeyGenDialog : public GeneralDialog {
*/
void SignalKeyGenerated();
- private:
+ private slots:
+
/**
- * @brief Create a key usage group box object
- *
- * @return QGroupBox*
+ * @details check all lineedits for false entries. Show error, when there
+ * is one, otherwise generate the key
*/
- QGroupBox* create_key_usage_group_box();
+ void slot_key_gen_accept();
/**
- * @brief Create a basic info group box object
+ * @brief
*
- * @return QGroupBox*
+ * @param mode
*/
- QGroupBox* create_basic_info_group_box();
+ void slot_easy_mode_changed(const QString& mode);
/**
* @brief
*
+ * @param mode
*/
- QRegularExpression re_email_{
- R"((?:[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*|"(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21\x23-\x5b\x5d-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])*")@(?:(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\[(?:(?:(2(5[0-5]|[0-4][0-9])|1[0-9][0-9]|[1-9]?[0-9]))\.){3}(?:(2(5[0-5]|[0-4][0-9])|1[0-9][0-9]|[1-9]?[0-9])|[a-z0-9-]*[a-z0-9]:(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21-\x5a\x53-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])+)\]))"};
+ void slot_easy_valid_date_changed(const QString& mode);
/**
* @brief
*
*/
- QStringList error_messages_; ///< List of errors occurring when checking
- ///< entries of line edits
-
- std::shared_ptr<GenKeyInfo> gen_key_info_ =
- SecureCreateSharedObject<GenKeyInfo>(); ///<
- std::shared_ptr<GenKeyInfo> gen_subkey_info_ = nullptr; ///<
-
- QDialogButtonBox* button_box_; ///< Box for standard buttons
- QLabel* error_label_{}; ///< Label containing error message
- QLineEdit* name_edit_{}; ///< Line edit for the keys name
- QLineEdit* email_edit_{}; ///< Line edit for the keys email
- QLineEdit* comment_edit_{}; ///< Line edit for the keys comment
- QSpinBox* key_size_spin_box_{}; ///< Spinbox for the keys size (in bit)
- QComboBox* key_type_combo_box_{}; ///< Combobox for Key type
- QDateTimeEdit* date_edit_{}; ///< Date edit for expiration date
- QCheckBox* expire_check_box_{}; ///< Checkbox, if key should expire
- QCheckBox* no_pass_phrase_check_box_{};
- QGroupBox* key_usage_group_box_{}; ///< Group of Widgets detecting the usage
- ///< of the Key
- QDateTime max_date_time_; ///<
- std::vector<QCheckBox*> key_usage_check_boxes_; ///< ENCR, SIGN, CERT, AUTH
- QComboBox* gpg_contexts_combo_box_{};
-
- int default_gpg_context_channel_;
+ void slot_set_easy_valid_date_2_custom();
/**
* @brief
*
*/
- void generate_key_dialog();
+ void slot_set_easy_key_algo_2_custom();
/**
- * @details Refresh widgets state by GenKeyInfo
+ * @brief
+ *
+ * @param mode
*/
- void refresh_widgets_state();
+ void slot_easy_combination_changed(const QString& mode);
+ private:
/**
- * @brief Set the signal slot object
+ * @brief
*
*/
- void set_signal_slot();
+ QRegularExpression re_email_{
+ R"((?:[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*|"(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21\x23-\x5b\x5d-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])*")@(?:(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\[(?:(?:(2(5[0-5]|[0-4][0-9])|1[0-9][0-9]|[1-9]?[0-9]))\.){3}(?:(2(5[0-5]|[0-4][0-9])|1[0-9][0-9]|[1-9]?[0-9])|[a-z0-9-]*[a-z0-9]:(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21-\x5a\x53-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])+)\]))"};
/**
* @brief
*
- * @param str
- * @return true
- * @return false
*/
- bool check_email_address(const QString& str);
+ QStringList error_messages_; ///< List of errors occurring when checking
+ ///< entries of line edits
- private slots:
+ QSharedPointer<Ui_KeyGenDialog> ui_;
+ QSharedPointer<KeyGenerateInfo> gen_key_info_; ///<
+ QSharedPointer<KeyGenerateInfo> gen_subkey_info_; ///<
+
+ QContainer<KeyAlgo> supported_primary_key_algos_;
+ QContainer<KeyAlgo> supported_subkey_algos_;
+
+ int channel_;
/**
- * @details when expirebox was checked/unchecked, enable/disable the
- * expiration date box
+ * @details Refresh widgets state by GenKeyInfo
*/
- void slot_expire_box_changed();
+ void refresh_widgets_state();
/**
- * @details check all lineedits for false entries. Show error, when there is
- * one, otherwise generate the key
+ * @brief Set the signal slot object
+ *
*/
- void slot_key_gen_accept();
+ void set_signal_slot_config();
/**
* @brief
*
- * @param state
+ * @param str
+ * @return true
+ * @return false
*/
- void slot_encryption_box_changed(int state);
+ auto check_email_address(const QString& str) -> bool;
/**
* @brief
*
- * @param state
*/
- void slot_signing_box_changed(int state);
+ void sync_gen_key_algo_info();
/**
* @brief
*
- * @param state
*/
- void slot_certification_box_changed(int state);
+ void sync_gen_subkey_algo_info();
/**
* @brief
*
- * @param state
*/
- void slot_authentication_box_changed(int state);
+ void create_sync_gen_subkey_info();
/**
* @brief
*
- * @param index
*/
- void slot_activated_key_type(int index);
+ void do_generate();
};
} // namespace GpgFrontend::UI
diff --git a/src/ui/dialog/key_generate/KeygenDialog.cpp b/src/ui/dialog/key_generate/KeygenDialog.cpp
deleted file mode 100644
index e29f6b64..00000000
--- a/src/ui/dialog/key_generate/KeygenDialog.cpp
+++ /dev/null
@@ -1,482 +0,0 @@
-/**
- * Copyright (C) 2021-2024 Saturneric <[email protected]>
- *
- * This file is part of GpgFrontend.
- *
- * GpgFrontend 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 3 of the License, or
- * (at your option) any later version.
- *
- * GpgFrontend 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 GpgFrontend. If not, see <https://www.gnu.org/licenses/>.
- *
- * The initial version of the source code is inherited from
- * the gpg4usb project, which is under GPL-3.0-or-later.
- *
- * All the source code of GpgFrontend was modified and released by
- * Saturneric <[email protected]> starting on May 12, 2021.
- *
- * SPDX-License-Identifier: GPL-3.0-or-later
- *
- */
-
-#include "KeygenDialog.h"
-
-#include "core/GpgModel.h"
-#include "core/function/GlobalSettingStation.h"
-#include "core/function/gpg/GpgKeyOpera.h"
-#include "core/model/DataObject.h"
-#include "core/module/ModuleManager.h"
-#include "core/typedef/GpgTypedef.h"
-#include "core/utils/CacheUtils.h"
-#include "core/utils/GpgUtils.h"
-#include "ui/UISignalStation.h"
-#include "ui/UserInterfaceUtils.h"
-
-namespace GpgFrontend::UI {
-
-KeyGenDialog::KeyGenDialog(int channel, QWidget* parent)
- : GeneralDialog(typeid(KeyGenDialog).name(), parent),
- default_gpg_context_channel_(channel) {
- button_box_ =
- new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel);
-
- bool const longer_expiration_date =
- GlobalSettingStation::GetInstance()
- .GetSettings()
- .value("basic/longer_expiration_date", false)
- .toBool();
-
- max_date_time_ = longer_expiration_date
- ? QDateTime::currentDateTime().toLocalTime().addYears(30)
- : QDateTime::currentDateTime().toLocalTime().addYears(2);
-
- connect(this, &KeyGenDialog::SignalKeyGenerated,
- UISignalStation::GetInstance(),
- &UISignalStation::SignalKeyDatabaseRefresh);
-
- generate_key_dialog();
-
- this->setWindowTitle(tr("Generate Key"));
- this->setAttribute(Qt::WA_DeleteOnClose);
- this->setModal(true);
-}
-
-void KeyGenDialog::generate_key_dialog() {
- key_usage_group_box_ = create_key_usage_group_box();
-
- auto* group_grid = new QGridLayout(this);
- group_grid->addWidget(create_basic_info_group_box(), 0, 0);
- group_grid->addWidget(key_usage_group_box_, 1, 0);
-
- auto* name_list = new QWidget(this);
- name_list->setLayout(group_grid);
-
- auto* vbox2 = new QVBoxLayout();
- vbox2->addWidget(name_list);
- vbox2->addWidget(error_label_);
- vbox2->addWidget(button_box_);
-
- this->setLayout(vbox2);
-
- set_signal_slot();
- refresh_widgets_state();
-}
-
-void KeyGenDialog::slot_key_gen_accept() {
- QString buffer;
- QTextStream error_stream(&buffer);
-
- /**
- * check for errors in keygen dialog input
- */
- if ((name_edit_->text()).size() < 5) {
- error_stream << " " << tr("Name must contain at least five characters.")
- << '\n';
- }
- if (email_edit_->text().isEmpty() ||
- !check_email_address(email_edit_->text())) {
- error_stream << " " << tr("Please give a email address.") << '\n';
- }
-
- /**
- * primary keys should have a reasonable expiration date (no more than 2 years
- * in the future)
- */
- if (date_edit_->dateTime() > max_date_time_) {
- error_stream << " " << tr("Expiration time too long.") << '\n';
- }
-
- auto err_string = error_stream.readAll();
- if (err_string.isEmpty()) {
- /**
- * create the string for key generation
- */
- gen_key_info_->SetName(name_edit_->text());
- gen_key_info_->SetEmail(email_edit_->text());
- gen_key_info_->SetComment(comment_edit_->text());
-
- gen_key_info_->SetKeyLength(key_size_spin_box_->value());
-
- if (no_pass_phrase_check_box_->checkState() != 0U) {
- gen_key_info_->SetNonPassPhrase(true);
- if (gen_subkey_info_ != nullptr) {
- gen_subkey_info_->SetNonPassPhrase(true);
- }
- }
-
- if (expire_check_box_->checkState() != 0U) {
- gen_key_info_->SetNonExpired(true);
- if (gen_subkey_info_ != nullptr) gen_subkey_info_->SetNonExpired(true);
- } else {
- gen_key_info_->SetExpireTime(date_edit_->dateTime());
- if (gen_subkey_info_ != nullptr) {
- gen_subkey_info_->SetExpireTime(date_edit_->dateTime());
- }
- }
-
- if (!GlobalSettingStation::GetInstance()
- .GetSettings()
- .value("gnupg/use_pinentry_as_password_input_dialog",
- QString::fromLocal8Bit(qgetenv("container")) != "flatpak")
- .toBool() &&
- !no_pass_phrase_check_box_->isChecked()) {
- SetCacheValue("PinentryContext", "NEW_PASSPHRASE");
- }
-
- auto selected_gpg_context_channel = gpg_contexts_combo_box_->currentIndex();
- LOG_D() << "try to generate key at gpg context channel: "
- << selected_gpg_context_channel;
-
- CommonUtils::WaitForOpera(
- this, tr("Generating"),
- [this, gen_key_info = this->gen_key_info_,
- selected_gpg_context_channel](const OperaWaitingHd& hd) {
- GpgKeyOpera::GetInstance(selected_gpg_context_channel)
- .GenerateKeyWithSubkey(
- gen_key_info, gen_subkey_info_,
- [this, hd](GpgError err, const DataObjectPtr&) {
- // stop showing waiting dialog
- hd();
-
- if (CheckGpgError(err) == GPG_ERR_USER_1) {
- QMessageBox::critical(this, tr("Error"),
- tr("Unknown error occurred"));
- return;
- }
-
- CommonUtils::RaiseMessageBox(this->parentWidget() != nullptr
- ? this->parentWidget()
- : this,
- err);
- if (CheckGpgError(err) == GPG_ERR_NO_ERROR) {
- emit SignalKeyGenerated();
- }
- });
- });
-
- this->done(0);
-
- } else {
- /**
- * create error message
- */
- error_label_->setAutoFillBackground(true);
- QPalette error = error_label_->palette();
- error.setColor(QPalette::Window, "#ff8080");
- error_label_->setPalette(error);
- error_label_->setText(err_string);
-
- this->show();
- }
-}
-
-void KeyGenDialog::slot_expire_box_changed() {}
-
-auto KeyGenDialog::create_key_usage_group_box() -> QGroupBox* {
- auto* group_box = new QGroupBox(this);
- auto* grid = new QGridLayout(this);
-
- group_box->setTitle(tr("Key Usage"));
-
- auto* encrypt = new QCheckBox(tr("Encryption"), group_box);
- encrypt->setTristate(false);
-
- auto* sign = new QCheckBox(tr("Signing"), group_box);
- sign->setTristate(false);
-
- auto* cert = new QCheckBox(tr("Certification"), group_box);
- cert->setTristate(false);
-
- auto* auth = new QCheckBox(tr("Authentication"), group_box);
- auth->setTristate(false);
-
- key_usage_check_boxes_.push_back(encrypt);
- key_usage_check_boxes_.push_back(sign);
- key_usage_check_boxes_.push_back(cert);
- key_usage_check_boxes_.push_back(auth);
-
- grid->addWidget(encrypt, 0, 0);
- grid->addWidget(sign, 0, 1);
- grid->addWidget(cert, 1, 0);
- grid->addWidget(auth, 1, 1);
-
- group_box->setLayout(grid);
-
- return group_box;
-}
-
-void KeyGenDialog::slot_encryption_box_changed(int state) {
- if (state == 0) {
- gen_key_info_->SetAllowEncryption(false);
- } else {
- gen_key_info_->SetAllowEncryption(true);
- }
-}
-
-void KeyGenDialog::slot_signing_box_changed(int state) {
- if (state == 0) {
- gen_key_info_->SetAllowSigning(false);
- } else {
- gen_key_info_->SetAllowSigning(true);
- }
-}
-
-void KeyGenDialog::slot_certification_box_changed(int state) {
- if (state == 0) {
- gen_key_info_->SetAllowCertification(false);
- } else {
- gen_key_info_->SetAllowCertification(true);
- }
-}
-
-void KeyGenDialog::slot_authentication_box_changed(int state) {
- if (state == 0) {
- gen_key_info_->SetAllowAuthentication(false);
- } else {
- gen_key_info_->SetAllowAuthentication(true);
- }
-}
-
-void KeyGenDialog::slot_activated_key_type(int index) {
- // check
- assert(gen_key_info_->GetSupportedKeyAlgo().size() >
- static_cast<size_t>(index));
-
- const auto [name, key_algo, subkey_algo] =
- gen_key_info_->GetSupportedKeyAlgo()[index];
-
- assert(!key_algo.isEmpty());
- gen_key_info_->SetAlgo(key_algo);
-
- if (!subkey_algo.isEmpty()) {
- if (gen_subkey_info_ == nullptr) {
- gen_subkey_info_ = SecureCreateSharedObject<GenKeyInfo>(true);
- }
- gen_subkey_info_->SetAlgo(subkey_algo);
- } else {
- gen_subkey_info_ = nullptr;
- }
-
- refresh_widgets_state();
-}
-
-void KeyGenDialog::refresh_widgets_state() {
- if (gen_key_info_->IsAllowEncryption() ||
- (gen_subkey_info_ != nullptr && gen_subkey_info_->IsAllowEncryption())) {
- key_usage_check_boxes_[0]->setCheckState(Qt::CheckState::Checked);
- } else {
- key_usage_check_boxes_[0]->setCheckState(Qt::CheckState::Unchecked);
- }
-
- if (gen_key_info_->IsAllowChangeEncryption() ||
- (gen_subkey_info_ != nullptr &&
- gen_subkey_info_->IsAllowChangeEncryption())) {
- key_usage_check_boxes_[0]->setDisabled(false);
- } else {
- key_usage_check_boxes_[0]->setDisabled(true);
- }
-
- if (gen_key_info_->IsAllowSigning() ||
- (gen_subkey_info_ != nullptr && gen_subkey_info_->IsAllowSigning())) {
- key_usage_check_boxes_[1]->setCheckState(Qt::CheckState::Checked);
- } else {
- key_usage_check_boxes_[1]->setCheckState(Qt::CheckState::Unchecked);
- }
-
- if (gen_key_info_->IsAllowChangeSigning() ||
- (gen_subkey_info_ != nullptr &&
- gen_subkey_info_->IsAllowChangeSigning())) {
- key_usage_check_boxes_[1]->setDisabled(false);
- } else {
- key_usage_check_boxes_[1]->setDisabled(true);
- }
-
- if (gen_key_info_->IsAllowCertification() ||
- (gen_subkey_info_ != nullptr &&
- gen_subkey_info_->IsAllowCertification())) {
- key_usage_check_boxes_[2]->setCheckState(Qt::CheckState::Checked);
- } else {
- key_usage_check_boxes_[2]->setCheckState(Qt::CheckState::Unchecked);
- }
-
- if (gen_key_info_->IsAllowChangeCertification() ||
- (gen_subkey_info_ != nullptr &&
- gen_subkey_info_->IsAllowChangeCertification())) {
- key_usage_check_boxes_[2]->setDisabled(false);
- } else {
- key_usage_check_boxes_[2]->setDisabled(true);
- }
-
- if (gen_key_info_->IsAllowAuthentication() ||
- (gen_subkey_info_ != nullptr &&
- gen_subkey_info_->IsAllowAuthentication())) {
- key_usage_check_boxes_[3]->setCheckState(Qt::CheckState::Checked);
- } else {
- key_usage_check_boxes_[3]->setCheckState(Qt::CheckState::Unchecked);
- }
-
- if (gen_key_info_->IsAllowChangeAuthentication() ||
- (gen_subkey_info_ != nullptr &&
- gen_subkey_info_->IsAllowChangeAuthentication())) {
- key_usage_check_boxes_[3]->setDisabled(false);
- } else {
- key_usage_check_boxes_[3]->setDisabled(true);
- }
-
- if (gen_key_info_->IsAllowNoPassPhrase()) {
- no_pass_phrase_check_box_->setDisabled(false);
- } else {
- no_pass_phrase_check_box_->setDisabled(true);
- }
-
- if (gen_key_info_->GetSuggestMinKeySize() == -1 ||
- gen_key_info_->GetSuggestMaxKeySize() == -1) {
- key_size_spin_box_->setDisabled(true);
- key_size_spin_box_->setRange(0, 0);
- key_size_spin_box_->setValue(0);
- key_size_spin_box_->setSingleStep(0);
- } else {
- key_size_spin_box_->setDisabled(false);
- key_size_spin_box_->setRange(gen_key_info_->GetSuggestMinKeySize(),
- gen_key_info_->GetSuggestMaxKeySize());
- key_size_spin_box_->setValue(gen_key_info_->GetKeyLength());
- key_size_spin_box_->setSingleStep(gen_key_info_->GetSizeChangeStep());
- }
-}
-
-void KeyGenDialog::set_signal_slot() {
- connect(button_box_, &QDialogButtonBox::accepted, this,
- &KeyGenDialog::slot_key_gen_accept);
- connect(button_box_, &QDialogButtonBox::rejected, this,
- &KeyGenDialog::reject);
-
- connect(expire_check_box_, &QCheckBox::stateChanged, this, [this]() {
- date_edit_->setDisabled(expire_check_box_->checkState() != 0U);
- });
-
- connect(key_usage_check_boxes_[0], &QCheckBox::stateChanged, this,
- &KeyGenDialog::slot_encryption_box_changed);
- connect(key_usage_check_boxes_[1], &QCheckBox::stateChanged, this,
- &KeyGenDialog::slot_signing_box_changed);
- connect(key_usage_check_boxes_[2], &QCheckBox::stateChanged, this,
- &KeyGenDialog::slot_certification_box_changed);
- connect(key_usage_check_boxes_[3], &QCheckBox::stateChanged, this,
- &KeyGenDialog::slot_authentication_box_changed);
-
- connect(key_type_combo_box_, qOverload<int>(&QComboBox::currentIndexChanged),
- this, &KeyGenDialog::slot_activated_key_type);
-
- connect(no_pass_phrase_check_box_, &QCheckBox::stateChanged, this,
- [this](int state) -> void {
- gen_key_info_->SetNonPassPhrase(state != 0);
- if (gen_subkey_info_ != nullptr) {
- gen_subkey_info_->SetNonPassPhrase(state != 0);
- }
- });
-}
-
-auto KeyGenDialog::check_email_address(const QString& str) -> bool {
- return re_email_.match(str).hasMatch();
-}
-
-auto KeyGenDialog::create_basic_info_group_box() -> QGroupBox* {
- error_label_ = new QLabel();
- name_edit_ = new QLineEdit(this);
- email_edit_ = new QLineEdit(this);
- comment_edit_ = new QLineEdit(this);
- key_size_spin_box_ = new QSpinBox(this);
- key_type_combo_box_ = new QComboBox(this);
- gpg_contexts_combo_box_ = new QComboBox(this);
-
- auto gpg_context_index_list =
- Module::ListRTChildKeys("core", "gpgme.ctx.list");
-
- for (auto& context_index : gpg_context_index_list) {
- const auto grt_key_prefix = QString("gpgme.ctx.list.%1").arg(context_index);
- auto channel = Module::RetrieveRTValueTypedOrDefault(
- "core", grt_key_prefix + ".channel", -1);
- auto database_name = Module::RetrieveRTValueTypedOrDefault(
- "core", grt_key_prefix + ".database_name", QString{});
- gpg_contexts_combo_box_->addItem(
- QString("%1: %2").arg(channel).arg(database_name));
- }
- gpg_contexts_combo_box_->setCurrentIndex(default_gpg_context_channel_);
-
- for (const auto& algo : GenKeyInfo::GetSupportedKeyAlgo()) {
- key_type_combo_box_->addItem(std::get<0>(algo));
- }
- if (!GenKeyInfo::GetSupportedKeyAlgo().empty()) {
- key_type_combo_box_->setCurrentIndex(0);
- }
-
- date_edit_ =
- new QDateTimeEdit(QDateTime::currentDateTime().addYears(2), this);
- date_edit_->setMinimumDateTime(QDateTime::currentDateTime());
- date_edit_->setMaximumDateTime(max_date_time_);
- date_edit_->setDisplayFormat("dd/MM/yyyy hh:mm:ss");
- date_edit_->setCalendarPopup(true);
- date_edit_->setEnabled(true);
-
- expire_check_box_ = new QCheckBox(this);
- expire_check_box_->setCheckState(Qt::Unchecked);
-
- no_pass_phrase_check_box_ = new QCheckBox(this);
- no_pass_phrase_check_box_->setCheckState(Qt::Unchecked);
-
- auto* vbox1 = new QGridLayout;
-
- vbox1->addWidget(new QLabel(tr("Key Database") + ": "), 0, 0);
- vbox1->addWidget(new QLabel(tr("Name") + ": "), 1, 0);
- vbox1->addWidget(new QLabel(tr("Email Address") + ": "), 2, 0);
- vbox1->addWidget(new QLabel(tr("Comment") + ": "), 3, 0);
- vbox1->addWidget(new QLabel(tr("Expiration Date") + ": "), 4, 0);
- vbox1->addWidget(new QLabel(tr("Never Expire") + ": "), 4, 3);
- vbox1->addWidget(new QLabel(tr("KeySize (in Bit)") + ": "), 5, 0);
- vbox1->addWidget(new QLabel(tr("Key Type") + ": "), 6, 0);
- vbox1->addWidget(new QLabel(tr("Non Pass Phrase")), 7, 0);
-
- vbox1->addWidget(gpg_contexts_combo_box_, 0, 1, 1, 3);
- vbox1->addWidget(name_edit_, 1, 1, 1, 3);
- vbox1->addWidget(email_edit_, 2, 1, 1, 3);
- vbox1->addWidget(comment_edit_, 3, 1, 1, 3);
- vbox1->addWidget(date_edit_, 4, 1);
- vbox1->addWidget(expire_check_box_, 4, 2);
- vbox1->addWidget(key_size_spin_box_, 5, 1);
- vbox1->addWidget(key_type_combo_box_, 6, 1);
- vbox1->addWidget(no_pass_phrase_check_box_, 7, 1);
-
- auto* basic_info_group_box = new QGroupBox();
- basic_info_group_box->setLayout(vbox1);
- basic_info_group_box->setTitle(tr("Basic Information"));
-
- return basic_info_group_box;
-}
-
-} // namespace GpgFrontend::UI
diff --git a/src/ui/dialog/key_generate/SubkeyGenerateDialog.cpp b/src/ui/dialog/key_generate/SubkeyGenerateDialog.cpp
index dd88aac2..58734c7d 100644
--- a/src/ui/dialog/key_generate/SubkeyGenerateDialog.cpp
+++ b/src/ui/dialog/key_generate/SubkeyGenerateDialog.cpp
@@ -31,345 +31,200 @@
#include <cassert>
#include <cstddef>
-#include "core/function/GlobalSettingStation.h"
#include "core/function/gpg/GpgKeyGetter.h"
#include "core/function/gpg/GpgKeyOpera.h"
-#include "core/utils/CacheUtils.h"
#include "core/utils/GpgUtils.h"
#include "ui/UISignalStation.h"
#include "ui/UserInterfaceUtils.h"
+#include "ui/function/GpgOperaHelper.h"
+#include "ui/function/KeyGenerateHelper.h"
+
+//
+#include "ui_SubkeyGenDialog.h"
namespace GpgFrontend::UI {
SubkeyGenerateDialog::SubkeyGenerateDialog(int channel, const KeyId& key_id,
QWidget* parent)
: GeneralDialog(typeid(SubkeyGenerateDialog).name(), parent),
+ ui_(QSharedPointer<Ui_SubkeyGenDialog>::create()),
current_gpg_context_channel_(channel),
key_(GpgKeyGetter::GetInstance(current_gpg_context_channel_)
- .GetKey(key_id)) {
+ .GetKey(key_id)),
+ gen_subkey_info_(QSharedPointer<KeyGenerateInfo>::create(true)),
+ supported_subkey_algos_(KeyGenerateInfo::GetSupportedSubkeyAlgo()) {
+ ui_->setupUi(this);
assert(key_.IsGood());
- bool longer_expiration_date =
- GlobalSettingStation::GetInstance()
- .GetSettings()
- .value("basic/longer_expiration_date", false)
- .toBool();
-
- max_date_time_ = longer_expiration_date
- ? QDateTime::currentDateTime().toLocalTime().addYears(30)
- : QDateTime::currentDateTime().toLocalTime().addYears(2);
-
- button_box_ =
- new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel);
+ ui_->algoLabel->setText(tr("Algorithm"));
+ ui_->keyLengthLabel->setText(tr("Key Length"));
+ ui_->expireLabel->setText(tr("Expire Date"));
+ ui_->usageLabel->setText(tr("Usage"));
+ ui_->encrCheckBox->setText(tr("Encrypt"));
+ ui_->signCheckBox->setText(tr("Sign"));
+ ui_->authCheckBox->setText(tr("Authentication"));
+ ui_->nonExpiredCheckBox->setText(tr("Non Expired"));
+ ui_->nonPassphraseCheckBox->setText(tr("No Passphrase"));
- key_usage_group_box_ = create_key_usage_group_box();
+ const auto min_date_time = QDateTime::currentDateTime().addDays(3);
+ ui_->expireDateTimeEdit->setMinimumDateTime(min_date_time);
- auto* group_grid = new QGridLayout(this);
- group_grid->addWidget(create_basic_info_group_box(), 0, 0);
- group_grid->addWidget(key_usage_group_box_, 1, 0);
-
- auto* tipps_label =
- new QLabel(tr("Tipps: if the key pair has a passphrase, the subkey's "
- "passphrase must be equal to it."));
- tipps_label->setWordWrap(true);
- group_grid->addWidget(tipps_label);
+ QSet<QString> algo_set;
+ for (const auto& algo : supported_subkey_algos_) {
+ algo_set.insert(algo.Name());
+ }
+ ui_->algoComboBox->addItems(QStringList(algo_set.cbegin(), algo_set.cend()));
- auto* name_list = new QWidget(this);
- name_list->setLayout(group_grid);
+ ui_->expireDateTimeEdit->setDateTime(gen_subkey_info_->GetExpireTime());
+ ui_->expireDateTimeEdit->setDisabled(gen_subkey_info_->IsNonExpired());
- auto* vbox2 = new QVBoxLayout();
- vbox2->addWidget(name_list);
- vbox2->addWidget(error_label_);
- vbox2->addWidget(button_box_);
+ ui_->statusPlainTextEdit->appendPlainText(
+ tr("Tipps: if the key pair has a passphrase, the subkey's "
+ "passphrase must be equal to it."));
this->setWindowTitle(tr("Generate New Subkey"));
- this->setLayout(vbox2);
this->setAttribute(Qt::WA_DeleteOnClose);
this->setModal(true);
- set_signal_slot();
+ set_signal_slot_config();
refresh_widgets_state();
}
-QGroupBox* SubkeyGenerateDialog::create_key_usage_group_box() {
- auto* group_box = new QGroupBox(this);
- auto* grid = new QGridLayout(this);
-
- group_box->setTitle(tr("Key Usage"));
-
- auto* encrypt = new QCheckBox(tr("Encryption"), group_box);
- encrypt->setTristate(false);
-
- auto* sign = new QCheckBox(tr("Signing"), group_box);
- sign->setTristate(false);
-
- auto* cert = new QCheckBox(tr("Certification"), group_box);
- cert->setTristate(false);
-
- auto* auth = new QCheckBox(tr("Authentication"), group_box);
- auth->setTristate(false);
-
- key_usage_check_boxes_.push_back(encrypt);
- key_usage_check_boxes_.push_back(sign);
- key_usage_check_boxes_.push_back(cert);
- key_usage_check_boxes_.push_back(auth);
-
- grid->addWidget(encrypt, 0, 0);
- grid->addWidget(sign, 0, 1);
- grid->addWidget(cert, 1, 0);
- grid->addWidget(auth, 1, 1);
-
- group_box->setLayout(grid);
-
- return group_box;
-}
-
-QGroupBox* SubkeyGenerateDialog::create_basic_info_group_box() {
- error_label_ = new QLabel();
- key_size_spin_box_ = new QSpinBox(this);
- key_type_combo_box_ = new QComboBox(this);
- no_pass_phrase_check_box_ = new QCheckBox(this);
-
- for (const auto& algo : GenKeyInfo::GetSupportedSubkeyAlgo()) {
- key_type_combo_box_->addItem(std::get<0>(algo));
- }
- if (!GenKeyInfo::GetSupportedSubkeyAlgo().empty()) {
- key_type_combo_box_->setCurrentIndex(0);
- }
-
- date_edit_ =
- new QDateTimeEdit(QDateTime::currentDateTime().addYears(2), this);
- date_edit_->setMinimumDateTime(QDateTime::currentDateTime());
- date_edit_->setMaximumDateTime(max_date_time_);
- date_edit_->setDisplayFormat("dd/MM/yyyy hh:mm:ss");
- date_edit_->setCalendarPopup(true);
- date_edit_->setEnabled(true);
-
- expire_check_box_ = new QCheckBox(this);
- expire_check_box_->setCheckState(Qt::Unchecked);
-
- auto* vbox1 = new QGridLayout;
-
- vbox1->addWidget(new QLabel(tr("Key Type") + ": "), 0, 0);
- vbox1->addWidget(new QLabel(tr("KeySize (in Bit)") + ": "), 1, 0);
- vbox1->addWidget(new QLabel(tr("Expiration Date") + ": "), 2, 0);
- vbox1->addWidget(new QLabel(tr("Never Expire")), 2, 3);
- vbox1->addWidget(new QLabel(tr("Non Pass Phrase")), 3, 0);
-
- vbox1->addWidget(key_type_combo_box_, 0, 1);
- vbox1->addWidget(key_size_spin_box_, 1, 1);
- vbox1->addWidget(date_edit_, 2, 1);
- vbox1->addWidget(expire_check_box_, 2, 2);
- vbox1->addWidget(no_pass_phrase_check_box_, 3, 1);
-
- auto* basic_info_group_box = new QGroupBox();
- basic_info_group_box->setLayout(vbox1);
- basic_info_group_box->setTitle(tr("Basic Information"));
-
- return basic_info_group_box;
-}
-
-void SubkeyGenerateDialog::set_signal_slot() {
- connect(button_box_, &QDialogButtonBox::accepted, this,
+void SubkeyGenerateDialog::set_signal_slot_config() {
+ connect(ui_->generateButton, &QPushButton::clicked, this,
&SubkeyGenerateDialog::slot_key_gen_accept);
- connect(button_box_, &QDialogButtonBox::rejected, this,
- &SubkeyGenerateDialog::reject);
-
- connect(expire_check_box_, &QCheckBox::stateChanged, this,
- &SubkeyGenerateDialog::slot_expire_box_changed);
- connect(key_usage_check_boxes_[0], &QCheckBox::stateChanged, this,
- &SubkeyGenerateDialog::slot_encryption_box_changed);
- connect(key_usage_check_boxes_[1], &QCheckBox::stateChanged, this,
- &SubkeyGenerateDialog::slot_signing_box_changed);
- connect(key_usage_check_boxes_[2], &QCheckBox::stateChanged, this,
- &SubkeyGenerateDialog::slot_certification_box_changed);
- connect(key_usage_check_boxes_[3], &QCheckBox::stateChanged, this,
- &SubkeyGenerateDialog::slot_authentication_box_changed);
+ connect(ui_->nonExpiredCheckBox, &QCheckBox::stateChanged, this,
+ [=](int state) {
+ gen_subkey_info_->SetNonExpired(state == Qt::Checked);
+ refresh_widgets_state();
+ });
- connect(key_type_combo_box_, qOverload<int>(&QComboBox::currentIndexChanged),
- this, &SubkeyGenerateDialog::slot_activated_key_type);
+ connect(ui_->encrCheckBox, &QCheckBox::stateChanged, this, [this](int state) {
+ gen_subkey_info_->SetAllowEncr(state == Qt::Checked);
+ });
+ connect(ui_->signCheckBox, &QCheckBox::stateChanged, this, [this](int state) {
+ gen_subkey_info_->SetAllowSign(state == Qt::Checked);
+ });
+ connect(ui_->authCheckBox, &QCheckBox::stateChanged, this, [this](int state) {
+ gen_subkey_info_->SetAllowAuth(state == Qt::Checked);
+ });
+
+ connect(ui_->algoComboBox, &QComboBox::currentTextChanged, this,
+ [=](const QString& text) {
+ auto [found, algo] = GetAlgoByName(text, supported_subkey_algos_);
+ ui_->generateButton->setDisabled(!found);
+ if (found) gen_subkey_info_->SetAlgo(algo);
+
+ refresh_widgets_state();
+ });
- connect(no_pass_phrase_check_box_, &QCheckBox::stateChanged, this,
+ connect(ui_->nonPassphraseCheckBox, &QCheckBox::stateChanged, this,
[this](int state) -> void {
- gen_key_info_->SetNonPassPhrase(state != 0);
+ gen_subkey_info_->SetNonPassPhrase(state == Qt::Checked);
});
-}
-void SubkeyGenerateDialog::slot_expire_box_changed() {
- if (expire_check_box_->checkState() != 0U) {
- date_edit_->setEnabled(false);
- } else {
- date_edit_->setEnabled(true);
- }
+ connect(ui_->keyLengthComboBox, &QComboBox::currentTextChanged, this,
+ [this](const QString& text) -> void {
+ auto [found, algo] = GetAlgoByNameAndKeyLength(
+ ui_->algoComboBox->currentText(), text.toInt(),
+ supported_subkey_algos_);
+
+ if (found) gen_subkey_info_->SetAlgo(algo);
+ });
}
void SubkeyGenerateDialog::refresh_widgets_state() {
- if (gen_key_info_->IsAllowEncryption()) {
- key_usage_check_boxes_[0]->setCheckState(Qt::CheckState::Checked);
- } else {
- key_usage_check_boxes_[0]->setCheckState(Qt::CheckState::Unchecked);
- }
-
- if (gen_key_info_->IsAllowChangeEncryption()) {
- key_usage_check_boxes_[0]->setDisabled(false);
- } else {
- key_usage_check_boxes_[0]->setDisabled(true);
- }
-
- if (gen_key_info_->IsAllowSigning()) {
- key_usage_check_boxes_[1]->setCheckState(Qt::CheckState::Checked);
- } else {
- key_usage_check_boxes_[1]->setCheckState(Qt::CheckState::Unchecked);
- }
-
- if (gen_key_info_->IsAllowChangeSigning()) {
- key_usage_check_boxes_[1]->setDisabled(false);
- } else {
- key_usage_check_boxes_[1]->setDisabled(true);
- }
-
- if (gen_key_info_->IsAllowCertification()) {
- key_usage_check_boxes_[2]->setCheckState(Qt::CheckState::Checked);
- } else {
- key_usage_check_boxes_[2]->setCheckState(Qt::CheckState::Unchecked);
- }
-
- if (gen_key_info_->IsAllowChangeCertification()) {
- key_usage_check_boxes_[2]->setDisabled(false);
- } else {
- key_usage_check_boxes_[2]->setDisabled(true);
- }
-
- if (gen_key_info_->IsAllowAuthentication()) {
- key_usage_check_boxes_[3]->setCheckState(Qt::CheckState::Checked);
- } else {
- key_usage_check_boxes_[3]->setCheckState(Qt::CheckState::Unchecked);
- }
-
- if (gen_key_info_->IsAllowChangeAuthentication()) {
- key_usage_check_boxes_[3]->setDisabled(false);
- } else {
- key_usage_check_boxes_[3]->setDisabled(true);
- }
-
- if (gen_key_info_->GetSuggestMinKeySize() == -1 ||
- gen_key_info_->GetSuggestMaxKeySize() == -1) {
- key_size_spin_box_->setDisabled(true);
- key_size_spin_box_->setRange(0, 0);
- key_size_spin_box_->setValue(0);
- key_size_spin_box_->setSingleStep(0);
- } else {
- key_size_spin_box_->setDisabled(false);
- key_size_spin_box_->setRange(gen_key_info_->GetSuggestMinKeySize(),
- gen_key_info_->GetSuggestMaxKeySize());
- key_size_spin_box_->setValue(gen_key_info_->GetKeyLength());
- key_size_spin_box_->setSingleStep(gen_key_info_->GetSizeChangeStep());
- }
+ ui_->algoComboBox->blockSignals(true);
+ ui_->algoComboBox->setCurrentText(gen_subkey_info_->GetAlgo().Name());
+ ui_->algoComboBox->blockSignals(false);
+
+ ui_->keyLengthComboBox->blockSignals(true);
+ SetKeyLengthComboxBoxByAlgo(ui_->keyLengthComboBox,
+ SearchAlgoByName(ui_->algoComboBox->currentText(),
+ supported_subkey_algos_));
+ ui_->keyLengthComboBox->setCurrentText(
+ QString::number(gen_subkey_info_->GetKeyLength()));
+ ui_->keyLengthComboBox->blockSignals(false);
+
+ ui_->encrCheckBox->blockSignals(true);
+ ui_->encrCheckBox->setChecked(gen_subkey_info_->IsAllowEncr());
+ ui_->encrCheckBox->setEnabled(gen_subkey_info_->IsAllowModifyEncr());
+ ui_->encrCheckBox->blockSignals(false);
+
+ ui_->signCheckBox->blockSignals(true);
+ ui_->signCheckBox->setChecked(gen_subkey_info_->IsAllowSign());
+ ui_->signCheckBox->setEnabled(gen_subkey_info_->IsAllowModifySign());
+ ui_->signCheckBox->blockSignals(false);
+
+ ui_->authCheckBox->blockSignals(true);
+ ui_->authCheckBox->setChecked(gen_subkey_info_->IsAllowAuth());
+ ui_->authCheckBox->setEnabled(gen_subkey_info_->IsAllowModifyAuth());
+ ui_->authCheckBox->blockSignals(false);
+
+ ui_->nonPassphraseCheckBox->setEnabled(
+ gen_subkey_info_->IsAllowNoPassPhrase());
+
+ ui_->expireDateTimeEdit->blockSignals(true);
+ ui_->expireDateTimeEdit->setDateTime(gen_subkey_info_->GetExpireTime());
+ ui_->expireDateTimeEdit->setDisabled(gen_subkey_info_->IsNonExpired());
+ ui_->expireDateTimeEdit->blockSignals(false);
+
+ ui_->nonExpiredCheckBox->blockSignals(true);
+ ui_->nonExpiredCheckBox->setChecked(gen_subkey_info_->IsNonExpired());
+ ui_->nonExpiredCheckBox->blockSignals(false);
}
void SubkeyGenerateDialog::slot_key_gen_accept() {
QString buffer;
QTextStream err_stream(&buffer);
- /**
- * primary keys should have a reasonable expiration date (no more than 2 years
- * in the future)
- */
- if (date_edit_->dateTime() > QDateTime::currentDateTime().addYears(2)) {
- err_stream << " " << tr("Expiration time no more than 2 years.") << " ";
- }
-
- auto err_string = err_stream.readAll();
-
- if (err_string.isEmpty()) {
- gen_key_info_->SetKeyLength(key_size_spin_box_->value());
-
- if (expire_check_box_->checkState() != 0U) {
- gen_key_info_->SetNonExpired(true);
- } else {
- gen_key_info_->SetExpireTime(date_edit_->dateTime());
- }
-
- CommonUtils::WaitForOpera(
- this, tr("Generating"),
- [this, key = this->key_,
- gen_key_info = this->gen_key_info_](const OperaWaitingHd& hd) {
- GpgKeyOpera::GetInstance(current_gpg_context_channel_)
- .GenerateSubkey(key, gen_key_info,
- [this, hd](GpgError err, const DataObjectPtr&) {
- // stop showing waiting dialog
- hd();
-
- if (CheckGpgError(err) == GPG_ERR_USER_1) {
- QMessageBox::critical(
- this, tr("Error"),
- tr("Unknown error occurred"));
- return;
- }
-
- CommonUtils::RaiseMessageBox(this, err);
- if (CheckGpgError(err) == GPG_ERR_NO_ERROR) {
- emit UISignalStation::GetInstance()
- -> SignalKeyDatabaseRefresh();
- }
- });
- });
- this->done(0);
-
- } else {
- /**
- * create error message
- */
- error_label_->setAutoFillBackground(true);
- QPalette error = error_label_->palette();
- error.setColor(QPalette::Window, "#ff8080");
- error_label_->setPalette(error);
- error_label_->setText(err_string);
-
- this->show();
- }
-}
-
-void SubkeyGenerateDialog::slot_encryption_box_changed(int state) {
- if (state == 0) {
- gen_key_info_->SetAllowEncryption(false);
- } else {
- gen_key_info_->SetAllowEncryption(true);
- }
-}
-
-void SubkeyGenerateDialog::slot_signing_box_changed(int state) {
- if (state == 0) {
- gen_key_info_->SetAllowSigning(false);
- } else {
- gen_key_info_->SetAllowSigning(true);
- }
-}
-
-void SubkeyGenerateDialog::slot_certification_box_changed(int state) {
- if (state == 0) {
- gen_key_info_->SetAllowCertification(false);
- } else {
- gen_key_info_->SetAllowCertification(true);
- }
-}
-
-void SubkeyGenerateDialog::slot_authentication_box_changed(int state) {
- if (state == 0) {
- gen_key_info_->SetAllowAuthentication(false);
- } else {
- gen_key_info_->SetAllowAuthentication(true);
- }
-}
-
-void SubkeyGenerateDialog::slot_activated_key_type(int index) {
- // check
- assert(gen_key_info_->GetSupportedSubkeyAlgo().size() >
- static_cast<size_t>(index));
- gen_key_info_->SetAlgo(
- std::get<2>(gen_key_info_->GetSupportedSubkeyAlgo()[index]));
- refresh_widgets_state();
+ if (gen_subkey_info_->GetAlgo() == KeyGenerateInfo::kNoneAlgo) {
+ err_stream << " -> " << tr("Please give a valid subkey algorithm.")
+ << Qt::endl;
+ }
+
+ if (!gen_subkey_info_->IsNonExpired() &&
+ gen_subkey_info_->GetExpireTime() <
+ QDateTime::currentDateTime().addSecs(120)) {
+ err_stream
+ << " -> "
+ << tr("Time to subkey expiration must not be less than 120 seconds.")
+ << Qt::endl;
+ }
+
+ const auto err_string = err_stream.readAll();
+ if (!err_string.isEmpty()) {
+ ui_->statusPlainTextEdit->clear();
+ ui_->statusPlainTextEdit->appendPlainText(err_string);
+ return;
+ }
+
+ GpgOperaHelper::WaitForOpera(
+ this, tr("Generating"),
+ [this, key = this->key_,
+ gen_key_info = this->gen_subkey_info_](const OperaWaitingHd& hd) {
+ GpgKeyOpera::GetInstance(current_gpg_context_channel_)
+ .GenerateSubkey(key, gen_key_info,
+ [this, hd](GpgError err, const DataObjectPtr&) {
+ // stop showing waiting dialog
+ hd();
+
+ if (CheckGpgError(err) == GPG_ERR_USER_1) {
+ QMessageBox::critical(
+ this, tr("Error"),
+ tr("Unknown error occurred"));
+ return;
+ }
+
+ CommonUtils::RaiseMessageBox(this, err);
+ if (CheckGpgError(err) == GPG_ERR_NO_ERROR) {
+ emit UISignalStation::GetInstance()
+ -> SignalKeyDatabaseRefresh();
+ }
+ });
+ });
+ this->done(0);
}
} // namespace GpgFrontend::UI
diff --git a/src/ui/dialog/key_generate/SubkeyGenerateDialog.h b/src/ui/dialog/key_generate/SubkeyGenerateDialog.h
index f0a4fed6..96dee49e 100644
--- a/src/ui/dialog/key_generate/SubkeyGenerateDialog.h
+++ b/src/ui/dialog/key_generate/SubkeyGenerateDialog.h
@@ -28,16 +28,16 @@
#pragma once
-#include <memory>
-
#include "core/function/gpg/GpgContext.h"
-#include "core/model/GpgGenKeyInfo.h"
#include "core/model/GpgKey.h"
+#include "core/model/GpgKeyGenerateInfo.h"
#include "core/typedef/GpgTypedef.h"
#include "core/utils/MemoryUtils.h"
#include "ui/GpgFrontendUI.h"
#include "ui/dialog/GeneralDialog.h"
+class Ui_SubkeyGenDialog;
+
namespace GpgFrontend::UI {
/**
* @brief
@@ -56,97 +56,32 @@ class SubkeyGenerateDialog : public GeneralDialog {
explicit SubkeyGenerateDialog(int channel, const KeyId& key_id,
QWidget* parent);
- private:
- int current_gpg_context_channel_; ///<
- GpgKey key_; ///<
-
- std::shared_ptr<GenKeyInfo> gen_key_info_ =
- SecureCreateSharedObject<GenKeyInfo>(true); ///<
-
- QGroupBox* key_usage_group_box_{};
- QDialogButtonBox* button_box_; ///< Box for standard buttons
- QLabel* error_label_{}; ///< Label containing error message
- QSpinBox* key_size_spin_box_{}; ///< Spinbox for the keys size (in bit)
- QComboBox* key_type_combo_box_{}; ///< Combobox for Key tpe
- QDateTimeEdit* date_edit_{}; ///< Date edit for expiration date
- QCheckBox* expire_check_box_{}; ///< Checkbox, if key should expire
- QCheckBox* no_pass_phrase_check_box_{}; ///< Checkbox, if key should expire
-
- std::vector<QCheckBox*> key_usage_check_boxes_; ///< ENCR, SIGN, CERT, AUTH
- QDateTime max_date_time_; ///<
-
- /**
- * @brief Create a key usage group box object
- *
- * @return QGroupBox*
- */
- QGroupBox* create_key_usage_group_box();
-
- /**
- * @brief Create a basic info group box object
- *
- * @return QGroupBox*
- */
- QGroupBox* create_basic_info_group_box();
- /**
- * @brief Set the signal slot object
- *
- */
- void set_signal_slot();
-
- /**
- * @details Refresh widgets state by GenKeyInfo
- */
- void refresh_widgets_state();
-
private slots:
/**
- * @details when expire box was checked/unchecked, enable/disable the
- * expiration date box
- */
- void slot_expire_box_changed();
-
- /**
* @details check all line edits for false entries. Show error, when there is
* one, otherwise generate the key
*/
void slot_key_gen_accept();
- /**
- * @brief
- *
- * @param state
- */
- void slot_encryption_box_changed(int state);
-
- /**
- * @brief
- *
- * @param state
- */
- void slot_signing_box_changed(int state);
+ private:
+ QSharedPointer<Ui_SubkeyGenDialog> ui_; ///<
+ int current_gpg_context_channel_; ///<
- /**
- * @brief
- *
- * @param state
- */
- void slot_certification_box_changed(int state);
+ GpgKey key_; ///<
+ QSharedPointer<KeyGenerateInfo> gen_subkey_info_; ///<
+ QContainer<KeyAlgo> supported_subkey_algos_; ///<
/**
- * @brief
+ * @brief Set the signal slot object
*
- * @param state
*/
- void slot_authentication_box_changed(int state);
+ void set_signal_slot_config();
/**
- * @brief
- *
- * @param index
+ * @details Refresh widgets state by GenKeyInfo
*/
- void slot_activated_key_type(int index);
+ void refresh_widgets_state();
};
} // namespace GpgFrontend::UI