diff options
Diffstat (limited to 'src/ui/keygen/SubkeyGenerateDialog.cpp')
-rw-r--r-- | src/ui/keygen/SubkeyGenerateDialog.cpp | 439 |
1 files changed, 231 insertions, 208 deletions
diff --git a/src/ui/keygen/SubkeyGenerateDialog.cpp b/src/ui/keygen/SubkeyGenerateDialog.cpp index 3d709d81..593b1cae 100644 --- a/src/ui/keygen/SubkeyGenerateDialog.cpp +++ b/src/ui/keygen/SubkeyGenerateDialog.cpp @@ -1,7 +1,7 @@ /** - * This file is part of GPGFrontend. + * This file is part of GpgFrontend. * - * GPGFrontend is free software: you can redistribute it and/or modify + * 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. @@ -23,277 +23,300 @@ */ #include "ui/keygen/SubkeyGenerateDialog.h" + +#include "gpg/function/GpgKeyGetter.h" +#include "gpg/function/GpgKeyOpera.h" +#include "ui/SignalStation.h" #include "ui/WaitingDialog.h" -SubkeyGenerateDialog::SubkeyGenerateDialog(GpgME::GpgContext *ctx, const GpgKey &key, QWidget *parent) - : genKeyInfo(true), mCtx(ctx), mKey(key), QDialog(parent) { +namespace GpgFrontend::UI { - buttonBox = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel); +SubkeyGenerateDialog::SubkeyGenerateDialog(const KeyId& key_id, QWidget* parent) + : QDialog(parent), mKey(GpgKeyGetter::GetInstance().GetKey(key_id)) { + buttonBox = + new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel); - keyUsageGroupBox = create_key_usage_group_box(); + keyUsageGroupBox = create_key_usage_group_box(); - auto *groupGrid = new QGridLayout(this); - groupGrid->addWidget(create_basic_info_group_box(), 0, 0); - groupGrid->addWidget(keyUsageGroupBox, 1, 0); + auto* groupGrid = new QGridLayout(this); + groupGrid->addWidget(create_basic_info_group_box(), 0, 0); + groupGrid->addWidget(keyUsageGroupBox, 1, 0); - auto *nameList = new QWidget(this); - nameList->setLayout(groupGrid); + auto* nameList = new QWidget(this); + nameList->setLayout(groupGrid); - auto *vbox2 = new QVBoxLayout(); - vbox2->addWidget(nameList); - vbox2->addWidget(errorLabel); - vbox2->addWidget(buttonBox); + auto* vbox2 = new QVBoxLayout(); + vbox2->addWidget(nameList); + vbox2->addWidget(errorLabel); + vbox2->addWidget(buttonBox); - this->setWindowTitle(tr("Generate New Subkey")); + this->setWindowTitle(_("Generate New Subkey")); + this->setLayout(vbox2); + this->setModal(true); - this->setLayout(vbox2); - this->setModal(true); + connect(this, SIGNAL(SubKeyGenerated()), SignalStation::GetInstance(), + SIGNAL(KeyDatabaseRefresh())); - set_signal_slot(); - refresh_widgets_state(); + set_signal_slot(); + refresh_widgets_state(); } -QGroupBox *SubkeyGenerateDialog::create_key_usage_group_box() { - auto *groupBox = new QGroupBox(this); - auto *grid = new QGridLayout(this); +QGroupBox* SubkeyGenerateDialog::create_key_usage_group_box() { + auto* groupBox = new QGroupBox(this); + auto* grid = new QGridLayout(this); - groupBox->setTitle("Key Usage"); + groupBox->setTitle("Key Usage"); - auto* encrypt = new QCheckBox(tr("Encryption"), groupBox); - encrypt->setTristate(false); + auto* encrypt = new QCheckBox(_("Encryption"), groupBox); + encrypt->setTristate(false); - auto* sign = new QCheckBox(tr("Signing"),groupBox); - sign->setTristate(false); + auto* sign = new QCheckBox(_("Signing"), groupBox); + sign->setTristate(false); - auto* cert = new QCheckBox(tr("Certification"),groupBox); - cert->setTristate(false); + auto* cert = new QCheckBox(_("Certification"), groupBox); + cert->setTristate(false); - auto* auth = new QCheckBox(tr("Authentication"), groupBox); - auth->setTristate(false); + auto* auth = new QCheckBox(_("Authentication"), groupBox); + auth->setTristate(false); - keyUsageCheckBoxes.push_back(encrypt); - keyUsageCheckBoxes.push_back(sign); - keyUsageCheckBoxes.push_back(cert); - keyUsageCheckBoxes.push_back(auth); + keyUsageCheckBoxes.push_back(encrypt); + keyUsageCheckBoxes.push_back(sign); + keyUsageCheckBoxes.push_back(cert); + keyUsageCheckBoxes.push_back(auth); - grid->addWidget(encrypt, 0, 0); - grid->addWidget(sign, 0, 1); - grid->addWidget(cert, 1, 0); - grid->addWidget(auth, 1, 1); + grid->addWidget(encrypt, 0, 0); + grid->addWidget(sign, 0, 1); + grid->addWidget(cert, 1, 0); + grid->addWidget(auth, 1, 1); - groupBox->setLayout(grid); + groupBox->setLayout(grid); - return groupBox; + return groupBox; } -QGroupBox *SubkeyGenerateDialog::create_basic_info_group_box() { - errorLabel = new QLabel(tr("")); - keySizeSpinBox = new QSpinBox(this); - keyTypeComboBox = new QComboBox(this); +QGroupBox* SubkeyGenerateDialog::create_basic_info_group_box() { + errorLabel = new QLabel(); + keySizeSpinBox = new QSpinBox(this); + keyTypeComboBox = new QComboBox(this); - for(auto &algo : GenKeyInfo::SupportedSubkeyAlgo) { - keyTypeComboBox->addItem(algo); - } - if(!GenKeyInfo::SupportedKeyAlgo.isEmpty()) { - keyTypeComboBox->setCurrentIndex(0); - } + for (auto& algo : GenKeyInfo::SupportedSubkeyAlgo) { + keyTypeComboBox->addItem(QString::fromStdString(algo)); + } + if (!GenKeyInfo::SupportedKeyAlgo.empty()) { + keyTypeComboBox->setCurrentIndex(0); + } - QDateTime maxDateTime = QDateTime::currentDateTime().addYears(2); + QDateTime maxDateTime = QDateTime::currentDateTime().addYears(2); - dateEdit = new QDateTimeEdit(maxDateTime, this); - dateEdit->setMinimumDateTime(QDateTime::currentDateTime()); - dateEdit->setMaximumDateTime(maxDateTime); - dateEdit->setDisplayFormat("dd/MM/yyyy hh:mm:ss"); - dateEdit->setCalendarPopup(true); - dateEdit->setEnabled(true); + dateEdit = new QDateTimeEdit(maxDateTime, this); + dateEdit->setMinimumDateTime(QDateTime::currentDateTime()); + dateEdit->setMaximumDateTime(maxDateTime); + dateEdit->setDisplayFormat("dd/MM/yyyy hh:mm:ss"); + dateEdit->setCalendarPopup(true); + dateEdit->setEnabled(true); - expireCheckBox = new QCheckBox(this); - expireCheckBox->setCheckState(Qt::Unchecked); + expireCheckBox = new QCheckBox(this); + expireCheckBox->setCheckState(Qt::Unchecked); - auto *vbox1 = new QGridLayout; + auto* vbox1 = new QGridLayout; - vbox1->addWidget(new QLabel(tr("Expiration Date:")), 2, 0); - vbox1->addWidget(new QLabel(tr("Never Expire")), 2, 3); - vbox1->addWidget(new QLabel(tr("KeySize (in Bit):")), 1, 0); - vbox1->addWidget(new QLabel(tr("Key Type:")), 0, 0); + vbox1->addWidget(new QLabel(QString(_("Expiration Date")) + ": "), 2, 0); + vbox1->addWidget(new QLabel(QString(_("Never Expire")) + ": "), 2, 3); + vbox1->addWidget(new QLabel(QString(_("KeySize (in Bit)")) + ": "), 1, 0); + vbox1->addWidget(new QLabel(QString(_("Key Type")) + ": "), 0, 0); - vbox1->addWidget(dateEdit, 2, 1); - vbox1->addWidget(expireCheckBox, 2, 2); - vbox1->addWidget(keySizeSpinBox, 1, 1); - vbox1->addWidget(keyTypeComboBox, 0, 1); + vbox1->addWidget(dateEdit, 2, 1); + vbox1->addWidget(expireCheckBox, 2, 2); + vbox1->addWidget(keySizeSpinBox, 1, 1); + vbox1->addWidget(keyTypeComboBox, 0, 1); - auto basicInfoGroupBox = new QGroupBox(); - basicInfoGroupBox->setLayout(vbox1); - basicInfoGroupBox->setTitle(tr("Basic Information")); + auto basicInfoGroupBox = new QGroupBox(); + basicInfoGroupBox->setLayout(vbox1); + basicInfoGroupBox->setTitle(_("Basic Information")); - return basicInfoGroupBox; + return basicInfoGroupBox; } void SubkeyGenerateDialog::set_signal_slot() { - connect(buttonBox, SIGNAL(accepted()), this, SLOT(slotKeyGenAccept())); - connect(buttonBox, SIGNAL(rejected()), this, SLOT(reject())); - - connect(expireCheckBox, SIGNAL(stateChanged(int)), this, SLOT(slotExpireBoxChanged())); - - connect(keyUsageCheckBoxes[0], SIGNAL(stateChanged(int)), this, SLOT(slotEncryptionBoxChanged(int))); - connect(keyUsageCheckBoxes[1], SIGNAL(stateChanged(int)), this, SLOT(slotSigningBoxChanged(int))); - connect(keyUsageCheckBoxes[2], SIGNAL(stateChanged(int)), this, SLOT(slotCertificationBoxChanged(int))); - connect(keyUsageCheckBoxes[3], SIGNAL(stateChanged(int)), this, SLOT(slotAuthenticationBoxChanged(int))); - - connect(keyTypeComboBox, SIGNAL(currentIndexChanged(int)), this, SLOT(slotActivatedKeyType(int))); + connect(buttonBox, SIGNAL(accepted()), this, SLOT(slotKeyGenAccept())); + connect(buttonBox, SIGNAL(rejected()), this, SLOT(reject())); + + connect(expireCheckBox, SIGNAL(stateChanged(int)), this, + SLOT(slotExpireBoxChanged())); + + connect(keyUsageCheckBoxes[0], SIGNAL(stateChanged(int)), this, + SLOT(slotEncryptionBoxChanged(int))); + connect(keyUsageCheckBoxes[1], SIGNAL(stateChanged(int)), this, + SLOT(slotSigningBoxChanged(int))); + connect(keyUsageCheckBoxes[2], SIGNAL(stateChanged(int)), this, + SLOT(slotCertificationBoxChanged(int))); + connect(keyUsageCheckBoxes[3], SIGNAL(stateChanged(int)), this, + SLOT(slotAuthenticationBoxChanged(int))); + + connect(keyTypeComboBox, SIGNAL(currentIndexChanged(int)), this, + SLOT(slotActivatedKeyType(int))); } void SubkeyGenerateDialog::slotExpireBoxChanged() { - if (expireCheckBox->checkState()) { - dateEdit->setEnabled(false); - } else { - dateEdit->setEnabled(true); - } + if (expireCheckBox->checkState()) { + dateEdit->setEnabled(false); + } else { + dateEdit->setEnabled(true); + } } void SubkeyGenerateDialog::refresh_widgets_state() { - qDebug() << "refresh_widgets_state called"; - - if(genKeyInfo.isAllowEncryption()) - keyUsageCheckBoxes[0]->setCheckState(Qt::CheckState::Checked); - else - keyUsageCheckBoxes[0]->setCheckState(Qt::CheckState::Unchecked); - - if(genKeyInfo.isAllowChangeEncryption()) - keyUsageCheckBoxes[0]->setDisabled(false); - else - keyUsageCheckBoxes[0]->setDisabled(true); - - - if(genKeyInfo.isAllowSigning()) - keyUsageCheckBoxes[1]->setCheckState(Qt::CheckState::Checked); - else - keyUsageCheckBoxes[1]->setCheckState(Qt::CheckState::Unchecked); - - if(genKeyInfo.isAllowChangeSigning()) - keyUsageCheckBoxes[1]->setDisabled(false); - else - keyUsageCheckBoxes[1]->setDisabled(true); - - - if(genKeyInfo.isAllowCertification()) - keyUsageCheckBoxes[2]->setCheckState(Qt::CheckState::Checked); - else - keyUsageCheckBoxes[2]->setCheckState(Qt::CheckState::Unchecked); - - if(genKeyInfo.isAllowChangeCertification()) - keyUsageCheckBoxes[2]->setDisabled(false); - else - keyUsageCheckBoxes[2]->setDisabled(true); - - - if(genKeyInfo.isAllowAuthentication()) - keyUsageCheckBoxes[3]->setCheckState(Qt::CheckState::Checked); - else - keyUsageCheckBoxes[3]->setCheckState(Qt::CheckState::Unchecked); - - if(genKeyInfo.isAllowChangeAuthentication()) - keyUsageCheckBoxes[3]->setDisabled(false); - else - keyUsageCheckBoxes[3]->setDisabled(true); - - - keySizeSpinBox->setRange(genKeyInfo.getSuggestMinKeySize(), genKeyInfo.getSuggestMaxKeySize()); - keySizeSpinBox->setValue(genKeyInfo.getKeySize()); - keySizeSpinBox->setSingleStep(genKeyInfo.getSizeChangeStep()); - + qDebug() << "refresh_widgets_state called"; + + if (genKeyInfo->isAllowEncryption()) + keyUsageCheckBoxes[0]->setCheckState(Qt::CheckState::Checked); + else + keyUsageCheckBoxes[0]->setCheckState(Qt::CheckState::Unchecked); + + if (genKeyInfo->isAllowChangeEncryption()) + keyUsageCheckBoxes[0]->setDisabled(false); + else + keyUsageCheckBoxes[0]->setDisabled(true); + + if (genKeyInfo->isAllowSigning()) + keyUsageCheckBoxes[1]->setCheckState(Qt::CheckState::Checked); + else + keyUsageCheckBoxes[1]->setCheckState(Qt::CheckState::Unchecked); + + if (genKeyInfo->isAllowChangeSigning()) + keyUsageCheckBoxes[1]->setDisabled(false); + else + keyUsageCheckBoxes[1]->setDisabled(true); + + if (genKeyInfo->isAllowCertification()) + keyUsageCheckBoxes[2]->setCheckState(Qt::CheckState::Checked); + else + keyUsageCheckBoxes[2]->setCheckState(Qt::CheckState::Unchecked); + + if (genKeyInfo->isAllowChangeCertification()) + keyUsageCheckBoxes[2]->setDisabled(false); + else + keyUsageCheckBoxes[2]->setDisabled(true); + + if (genKeyInfo->isAllowAuthentication()) + keyUsageCheckBoxes[3]->setCheckState(Qt::CheckState::Checked); + else + keyUsageCheckBoxes[3]->setCheckState(Qt::CheckState::Unchecked); + + if (genKeyInfo->isAllowChangeAuthentication()) + keyUsageCheckBoxes[3]->setDisabled(false); + else + keyUsageCheckBoxes[3]->setDisabled(true); + + keySizeSpinBox->setRange(genKeyInfo->getSuggestMinKeySize(), + genKeyInfo->getSuggestMaxKeySize()); + keySizeSpinBox->setValue(genKeyInfo->getKeySize()); + keySizeSpinBox->setSingleStep(genKeyInfo->getSizeChangeStep()); } void SubkeyGenerateDialog::slotKeyGenAccept() { - QString errorString = ""; - - /** - * primary keys should have a reasonable expiration date (no more than 2 years in the future) - */ - if(dateEdit->dateTime() > QDateTime::currentDateTime().addYears(2)) { - - errorString.append(tr(" Expiration time no more than 2 years. ")); - } + std::stringstream err_stream; - if (errorString.isEmpty()) { + /** + * primary keys should have a reasonable expiration date (no more than 2 years + * in the future) + */ + if (dateEdit->dateTime() > QDateTime::currentDateTime().addYears(2)) { + err_stream << " " << _("Expiration time no more than 2 years.") << " "; + } - genKeyInfo.setKeySize(keySizeSpinBox->value()); + auto err_string = err_stream.str(); - if (expireCheckBox->checkState()) { - genKeyInfo.setNonExpired(true); - } else { - genKeyInfo.setExpired(dateEdit->dateTime()); - } + if (err_string.empty()) { + genKeyInfo->setKeySize(keySizeSpinBox->value()); - gpgme_error_t error = false; - auto thread = QThread::create([&]() { - error = mCtx->generateSubkey(mKey, &genKeyInfo); - }); - thread->start(); - - auto *dialog = new WaitingDialog("Generating", this); - dialog->show(); - - while (thread->isRunning()) { - QCoreApplication::processEvents(); - } + if (expireCheckBox->checkState()) { + genKeyInfo->setNonExpired(true); + } else { + genKeyInfo->setExpired( + boost::posix_time::from_time_t(dateEdit->dateTime().toTime_t()) + .date()); + } - dialog->close(); + GpgError error; + auto thread = QThread::create([&]() { + LOG(INFO) << "SubkeyGenerateDialog::slotKeyGenAccept() Thread Started"; + error = GpgKeyOpera::GetInstance().GenerateSubkey(mKey, genKeyInfo); + }); + thread->start(); - if (gpgme_err_code(error) == GPG_ERR_NO_ERROR) { - QMessageBox::information(nullptr, tr("Success"), tr("The new subkey has been generated.")); - this->close(); - } else - QMessageBox::critical(this, tr("Failure"), tr(gpgme_strerror(error))); + auto* dialog = new WaitingDialog("Generating", this); + dialog->show(); - } else { - /** - * create error message - */ - errorLabel->setAutoFillBackground(true); - QPalette error = errorLabel->palette(); - error.setColor(QPalette::Window, "#ff8080"); - errorLabel->setPalette(error); - errorLabel->setText(errorString); - - this->show(); + while (thread->isRunning()) { + QCoreApplication::processEvents(); } + dialog->close(); + + if (check_gpg_error_2_err_code(error) == GPG_ERR_NO_ERROR) { + auto* msg_box = new QMessageBox(nullptr); + msg_box->setAttribute(Qt::WA_DeleteOnClose); + msg_box->setStandardButtons(QMessageBox::Ok); + msg_box->setWindowTitle(_("Success")); + msg_box->setText(_("The new subkey has been generated.")); + msg_box->setModal(false); + msg_box->open(); + + emit SubKeyGenerated(); + this->close(); + } else + QMessageBox::critical(this, _("Failure"), _(gpgme_strerror(error))); + + } else { + /** + * create error message + */ + errorLabel->setAutoFillBackground(true); + QPalette error = errorLabel->palette(); + error.setColor(QPalette::Window, "#ff8080"); + errorLabel->setPalette(error); + errorLabel->setText(err_string.c_str()); + + this->show(); + } } void SubkeyGenerateDialog::slotEncryptionBoxChanged(int state) { - if(state == 0) { - genKeyInfo.setAllowEncryption(false); - } else { - genKeyInfo.setAllowEncryption(true); - } + if (state == 0) { + genKeyInfo->setAllowEncryption(false); + } else { + genKeyInfo->setAllowEncryption(true); + } } void SubkeyGenerateDialog::slotSigningBoxChanged(int state) { - if(state == 0) { - genKeyInfo.setAllowSigning(false); - } else { - genKeyInfo.setAllowSigning(true); - } + if (state == 0) { + genKeyInfo->setAllowSigning(false); + } else { + genKeyInfo->setAllowSigning(true); + } } void SubkeyGenerateDialog::slotCertificationBoxChanged(int state) { - if(state == 0) { - genKeyInfo.setAllowCertification(false); - } else { - genKeyInfo.setAllowCertification(true); - } + if (state == 0) { + genKeyInfo->setAllowCertification(false); + } else { + genKeyInfo->setAllowCertification(true); + } } void SubkeyGenerateDialog::slotAuthenticationBoxChanged(int state) { - if(state == 0) { - genKeyInfo.setAllowAuthentication(false); - } else { - genKeyInfo.setAllowAuthentication(true); - } + if (state == 0) { + genKeyInfo->setAllowAuthentication(false); + } else { + genKeyInfo->setAllowAuthentication(true); + } } void SubkeyGenerateDialog::slotActivatedKeyType(int index) { - qDebug() << "key type index changed " << index; - genKeyInfo.setAlgo(this->keyTypeComboBox->itemText(index)); - refresh_widgets_state(); + qDebug() << "key type index changed " << index; + genKeyInfo->setAlgo(this->keyTypeComboBox->itemText(index).toStdString()); + refresh_widgets_state(); } + +} // namespace GpgFrontend::UI |