/***************************************************************************
- * Copyright (C) 2005-09 by the Quassel Project *
+ * Copyright (C) 2005-2016 by the Quassel Project *
* devel@quassel-irc.org *
* *
* This program is free software; you can redistribute it and/or modify *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
- * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
***************************************************************************/
-#include "coreconnectdlg.h"
-
-#include <QDebug>
-#include <QFormLayout>
-#include <QMessageBox>
-#include <QNetworkProxy>
+#include <QDialogButtonBox>
+#include <QIcon>
+#include <QVBoxLayout>
-#ifdef HAVE_SSL
-#include <QSslSocket>
-#include <QSslCertificate>
-#endif
+#include "coreconnectdlg.h"
-#include "client.h"
#include "clientsettings.h"
-#include "clientsyncer.h"
-#include "coreconfigwizard.h"
-#include "iconloader.h"
-#include "quassel.h"
-#include "util.h"
+#include "coreaccountsettingspage.h"
-CoreConnectDlg::CoreConnectDlg(bool autoconnect, QWidget *parent)
- : QDialog(parent),
- _internalAccountId(0)
+CoreConnectDlg::CoreConnectDlg(QWidget *parent) : QDialog(parent)
{
- ui.setupUi(this);
- ui.editAccount->setIcon(SmallIcon("document-properties"));
- ui.addAccount->setIcon(SmallIcon("list-add"));
- ui.deleteAccount->setIcon(SmallIcon("list-remove"));
- ui.connectIcon->setPixmap(BarIcon("network-disconnect"));
- ui.secureConnection->setPixmap(SmallIcon("document-encrypt"));
-
- if(Quassel::runMode() != Quassel::Monolithic) {
- ui.useInternalCore->hide();
- }
-
- // make it look more native under Mac OS X:
- setWindowFlags(Qt::Sheet);
-
- clientSyncer = new ClientSyncer(this);
- Client::registerClientSyncer(clientSyncer);
-
- wizard = 0;
-
- doingAutoConnect = false;
-
- ui.stackedWidget->setCurrentWidget(ui.accountPage);
-
- CoreAccountSettings s;
- AccountId lastacc = s.lastAccount();
- autoConnectAccount = s.autoConnectAccount();
- QListWidgetItem *currentItem = 0;
- foreach(AccountId id, s.knownAccounts()) {
- if(!id.isValid()) continue;
- QVariantMap data = s.retrieveAccountData(id);
- if(data.contains("InternalAccount") && data["InternalAccount"].toBool()) {
- _internalAccountId = id;
- continue;
- }
- data["AccountId"] = QVariant::fromValue<AccountId>(id);
- accounts[id] = data;
- QListWidgetItem *item = new QListWidgetItem(data["AccountName"].toString(), ui.accountList);
- item->setData(Qt::UserRole, QVariant::fromValue<AccountId>(id));
- if(id == lastacc) currentItem = item;
- }
- if(currentItem) ui.accountList->setCurrentItem(currentItem);
- else ui.accountList->setCurrentRow(0);
-
- setAccountWidgetStates();
-
- ui.accountButtonBox->button(QDialogButtonBox::Ok)->setFocus();
- //ui.accountButtonBox->button(QDialogButtonBox::Ok)->setAutoDefault(true);
-
- connect(clientSyncer, SIGNAL(socketStateChanged(QAbstractSocket::SocketState)),this, SLOT(initPhaseSocketState(QAbstractSocket::SocketState)));
- connect(clientSyncer, SIGNAL(connectionError(const QString &)), this, SLOT(initPhaseError(const QString &)));
- connect(clientSyncer, SIGNAL(connectionWarnings(const QStringList &)), this, SLOT(initPhaseWarnings(const QStringList &)));
- connect(clientSyncer, SIGNAL(connectionMsg(const QString &)), this, SLOT(initPhaseMsg(const QString &)));
- connect(clientSyncer, SIGNAL(startLogin()), this, SLOT(startLogin()));
- connect(clientSyncer, SIGNAL(loginFailed(const QString &)), this, SLOT(loginFailed(const QString &)));
- connect(clientSyncer, SIGNAL(loginSuccess()), this, SLOT(startSync()));
- connect(clientSyncer, SIGNAL(startCoreSetup(const QVariantList &)), this, SLOT(startCoreConfig(const QVariantList &)));
- connect(clientSyncer, SIGNAL(sessionProgress(quint32, quint32)), this, SLOT(coreSessionProgress(quint32, quint32)));
- connect(clientSyncer, SIGNAL(networksProgress(quint32, quint32)), this, SLOT(coreNetworksProgress(quint32, quint32)));
- connect(clientSyncer, SIGNAL(syncFinished()), this, SLOT(syncFinished()));
- connect(clientSyncer, SIGNAL(encrypted()), ui.secureConnection, SLOT(show()));
+ _settingsPage = new CoreAccountSettingsPage(this);
+ _settingsPage->setStandAlone(true);
+ _settingsPage->load();
- connect(ui.user, SIGNAL(textChanged(const QString &)), this, SLOT(setLoginWidgetStates()));
- connect(ui.password, SIGNAL(textChanged(const QString &)), this, SLOT(setLoginWidgetStates()));
-
- connect(ui.loginButtonBox, SIGNAL(rejected()), this, SLOT(restartPhaseNull()));
- connect(ui.syncButtonBox->button(QDialogButtonBox::Abort), SIGNAL(clicked()), this, SLOT(restartPhaseNull()));
-
- if(autoconnect && ui.accountList->count() && autoConnectAccount.isValid()
- && autoConnectAccount == ui.accountList->currentItem()->data(Qt::UserRole).value<AccountId>()) {
- doingAutoConnect = true;
- on_accountButtonBox_accepted();
- }
-}
-
-CoreConnectDlg::~CoreConnectDlg() {
- if(ui.accountList->selectedItems().count()) {
CoreAccountSettings s;
- s.setLastAccount(ui.accountList->selectedItems()[0]->data(Qt::UserRole).value<AccountId>());
- }
-}
-
-
-/****************************************************
- * Account Management
- ***************************************************/
-
-void CoreConnectDlg::on_accountList_itemSelectionChanged() {
- setAccountWidgetStates();
-}
-
-void CoreConnectDlg::setAccountWidgetStates() {
- QList<QListWidgetItem *> selectedItems = ui.accountList->selectedItems();
- ui.editAccount->setEnabled(selectedItems.count());
- ui.deleteAccount->setEnabled(selectedItems.count());
- ui.autoConnect->setEnabled(selectedItems.count());
- if(selectedItems.count()) {
- ui.autoConnect->setChecked(selectedItems[0]->data(Qt::UserRole).value<AccountId>() == autoConnectAccount);
- }
- ui.accountButtonBox->button(QDialogButtonBox::Ok)->setEnabled(ui.accountList->count());
-}
-
-void CoreConnectDlg::on_autoConnect_clicked(bool state) {
- if(!state) {
- autoConnectAccount = 0;
- } else {
- if(ui.accountList->selectedItems().count()) {
- autoConnectAccount = ui.accountList->selectedItems()[0]->data(Qt::UserRole).value<AccountId>();
- } else {
- qWarning() << "Checked auto connect without an enabled item!"; // should never happen!
- autoConnectAccount = 0;
- }
- }
- setAccountWidgetStates();
-}
-
-void CoreConnectDlg::on_addAccount_clicked() {
- QStringList existing;
- for(int i = 0; i < ui.accountList->count(); i++) existing << ui.accountList->item(i)->text();
- CoreAccountEditDlg dlg(0, QVariantMap(), existing, this);
- if(dlg.exec() == QDialog::Accepted) {
- AccountId id = findFreeAccountId();
- QVariantMap data = dlg.accountData();
- data["AccountId"] = QVariant::fromValue<AccountId>(id);
- accounts[id] = data;
- QListWidgetItem *item = new QListWidgetItem(data["AccountName"].toString(), ui.accountList);
- item->setData(Qt::UserRole, QVariant::fromValue<AccountId>(id));
- ui.accountList->setCurrentItem(item);
- }
-}
-
-void CoreConnectDlg::on_editAccount_clicked() {
- QStringList existing;
- for(int i = 0; i < ui.accountList->count(); i++) existing << ui.accountList->item(i)->text();
- AccountId id = ui.accountList->currentItem()->data(Qt::UserRole).value<AccountId>();
- QVariantMap acct = accounts[id];
- CoreAccountEditDlg dlg(id, acct, existing, this);
- if(dlg.exec() == QDialog::Accepted) {
- QVariantMap data = dlg.accountData();
- ui.accountList->currentItem()->setText(data["AccountName"].toString());
- accounts[id] = data;
- }
-}
-
-void CoreConnectDlg::on_deleteAccount_clicked() {
- AccountId id = ui.accountList->currentItem()->data(Qt::UserRole).value<AccountId>();
- int ret = QMessageBox::question(this, tr("Remove Account Settings"),
- tr("Do you really want to remove your local settings for this Quassel Core account?<br>"
- "Note: This will <em>not</em> remove or change any data on the Core itself!"),
- QMessageBox::Yes|QMessageBox::No, QMessageBox::No);
- if(ret == QMessageBox::Yes) {
- int idx = ui.accountList->currentRow();
- delete ui.accountList->takeItem(idx);
- ui.accountList->setCurrentRow(qMin(idx, ui.accountList->count()-1));
- accounts[id]["Delete"] = true; // we only flag this here, actual deletion happens on accept!
- setAccountWidgetStates();
- }
-}
-
-void CoreConnectDlg::on_accountList_itemDoubleClicked(QListWidgetItem *item) {
- Q_UNUSED(item);
- on_accountButtonBox_accepted();
-}
-
-void CoreConnectDlg::on_accountButtonBox_accepted() {
- // save accounts
- CoreAccountSettings s;
- foreach(QVariantMap acct, accounts.values()) {
- AccountId id = acct["AccountId"].value<AccountId>();
- if(acct.contains("Delete")) {
- s.removeAccount(id);
- } else {
- s.storeAccountData(id, acct);
- }
- }
- s.setAutoConnectAccount(autoConnectAccount);
-
- ui.stackedWidget->setCurrentWidget(ui.loginPage);
- account = ui.accountList->currentItem()->data(Qt::UserRole).value<AccountId>();
- accountData = accounts[account];
- s.setLastAccount(account);
- connectToCore();
-}
-
-void CoreConnectDlg::on_useInternalCore_clicked() {
- clientSyncer->useInternalCore();
- ui.loginButtonBox->setStandardButtons(QDialogButtonBox::Cancel);
-}
-
-/*****************************************************
- * Connecting to the Core
- ****************************************************/
-
-/*** Phase One: initializing the core connection ***/
-
-void CoreConnectDlg::connectToCore() {
- ui.secureConnection->hide();
- ui.connectIcon->setPixmap(BarIcon("network-disconnect"));
- ui.connectLabel->setText(tr("Connect to %1").arg(accountData["Host"].toString()));
- ui.coreInfoLabel->setText("");
- ui.loginStack->setCurrentWidget(ui.loginEmptyPage);
- ui.loginButtonBox->setStandardButtons(QDialogButtonBox::Cancel|QDialogButtonBox::Ok);
- ui.loginButtonBox->button(QDialogButtonBox::Ok)->setDefault(true);
- ui.loginButtonBox->button(QDialogButtonBox::Ok)->setDisabled(true);
- disconnect(ui.loginButtonBox, 0, this, 0);
- connect(ui.loginButtonBox, SIGNAL(rejected()), this, SLOT(restartPhaseNull()));
-
- clientSyncer->connectToCore(accountData);
-}
-
-void CoreConnectDlg::initPhaseError(const QString &error) {
- doingAutoConnect = false;
- ui.secureConnection->hide();
- ui.connectIcon->setPixmap(BarIcon("dialog-error"));
- //ui.connectLabel->setBrush(QBrush("red"));
- ui.connectLabel->setText(tr("<div style=color:red;>Connection to %1 failed!</div>").arg(accountData["Host"].toString()));
- ui.coreInfoLabel->setText(error);
- ui.loginButtonBox->setStandardButtons(QDialogButtonBox::Retry|QDialogButtonBox::Cancel);
- ui.loginButtonBox->button(QDialogButtonBox::Retry)->setFocus();
- disconnect(ui.loginButtonBox, 0, this, 0);
- connect(ui.loginButtonBox, SIGNAL(accepted()), this, SLOT(restartPhaseNull()));
- connect(ui.loginButtonBox, SIGNAL(rejected()), this, SLOT(reject()));
-}
-
-void CoreConnectDlg::initPhaseWarnings(const QStringList &warnings) {
- doingAutoConnect = false;
- ui.secureConnection->hide();
- ui.connectIcon->setPixmap(BarIcon("dialog-warning"));
- ui.connectLabel->setText(tr("<div>Errors occurred while connecting to \"%1\":</div>").arg(accountData["Host"].toString()));
- QStringList warningItems;
- foreach(QString warning, warnings) {
- warningItems << QString("<li>%1</li>").arg(warning);
- }
- ui.coreInfoLabel->setText(QString("<ul>%1</ul>").arg(warningItems.join("")));
- ui.loginStack->setCurrentWidget(ui.connectionWarningsPage);
- ui.loginButtonBox->setStandardButtons(QDialogButtonBox::Cancel);
- ui.loginButtonBox->button(QDialogButtonBox::Cancel)->setFocus();
- disconnect(ui.loginButtonBox, 0, this, 0);
- connect(ui.loginButtonBox, SIGNAL(rejected()), this, SLOT(restartPhaseNull()));
-}
-
-void CoreConnectDlg::on_viewSslCertButton_clicked() {
-#ifdef HAVE_SSL
- const QSslSocket *socket = qobject_cast<const QSslSocket *>(clientSyncer->currentDevice());
- if(!socket)
- return;
-
- SslCertDisplayDialog dialog(socket->peerName(), socket->peerCertificate());
- dialog.exec();
-#endif
-}
-
-void CoreConnectDlg::on_ignoreWarningsButton_clicked() {
- clientSyncer->ignoreWarnings(ui.ignoreWarningsPermanently->isChecked());
-}
+ AccountId lastAccount = s.lastAccount();
+ if (lastAccount.isValid())
+ _settingsPage->setSelectedAccount(lastAccount);
+ setWindowTitle(tr("Connect to Core"));
+ setWindowIcon(QIcon::fromTheme("network-disconnect"));
-void CoreConnectDlg::initPhaseMsg(const QString &msg) {
- ui.coreInfoLabel->setText(msg);
-}
-
-void CoreConnectDlg::initPhaseSocketState(QAbstractSocket::SocketState state) {
- QString s;
- QString host = accountData["Host"].toString();
- switch(state) {
- case QAbstractSocket::UnconnectedState: s = tr("Not connected to %1.").arg(host); break;
- case QAbstractSocket::HostLookupState: s = tr("Looking up %1...").arg(host); break;
- case QAbstractSocket::ConnectingState: s = tr("Connecting to %1...").arg(host); break;
- case QAbstractSocket::ConnectedState: s = tr("Connected to %1").arg(host); break;
- default: s = tr("Unknown connection state to %1"); break;
- }
- ui.connectLabel->setText(s);
-}
+ QVBoxLayout *layout = new QVBoxLayout(this);
+ layout->addWidget(_settingsPage);
-void CoreConnectDlg::restartPhaseNull() {
- doingAutoConnect = false;
- ui.stackedWidget->setCurrentWidget(ui.accountPage);
- clientSyncer->disconnectFromCore();
-}
-
-/*********************************************************
- * Phase Two: Login
- *********************************************************/
-
-void CoreConnectDlg::startLogin() {
- ui.connectIcon->setPixmap(BarIcon("network-connect"));
- ui.loginStack->setCurrentWidget(ui.loginCredentialsPage);
- //ui.loginStack->setMinimumSize(ui.loginStack->sizeHint()); ui.loginStack->updateGeometry();
- ui.loginButtonBox->setStandardButtons(QDialogButtonBox::Ok|QDialogButtonBox::Cancel);
- ui.loginButtonBox->button(QDialogButtonBox::Ok)->setDefault(true);
- ui.loginButtonBox->button(QDialogButtonBox::Ok)->setFocus();
- if(!accountData["User"].toString().isEmpty()) {
- ui.user->setText(accountData["User"].toString());
- if(accountData["RememberPasswd"].toBool()) {
- ui.password->setText(accountData["Password"].toString());
- ui.rememberPasswd->setChecked(true);
- ui.loginButtonBox->button(QDialogButtonBox::Ok)->setFocus();
- } else {
- ui.rememberPasswd->setChecked(false);
- ui.password->setFocus();
- }
- } else ui.user->setFocus();
- disconnect(ui.loginButtonBox, 0, this, 0);
- connect(ui.loginButtonBox, SIGNAL(accepted()), this, SLOT(doLogin()));
- connect(ui.loginButtonBox, SIGNAL(rejected()), this, SLOT(restartPhaseNull()));
- if(doingAutoConnect) doLogin();
-}
-
-void CoreConnectDlg::doLogin() {
- QVariantMap loginData;
- loginData["User"] = ui.user->text();
- loginData["Password"] = ui.password->text();
- loginData["RememberPasswd"] = ui.rememberPasswd->isChecked();
- doLogin(loginData);
-}
+ QDialogButtonBox *buttonBox = new QDialogButtonBox(this);
+ buttonBox->setStandardButtons(QDialogButtonBox::Ok|QDialogButtonBox::Cancel);
+ layout->addWidget(buttonBox);
-void CoreConnectDlg::doLogin(const QVariantMap &loginData) {
- disconnect(ui.loginButtonBox, 0, this, 0);
- connect(ui.loginButtonBox, SIGNAL(accepted()), this, SLOT(doLogin()));
- connect(ui.loginButtonBox, SIGNAL(rejected()), this, SLOT(restartPhaseNull()));
- ui.loginStack->setCurrentWidget(ui.loginCredentialsPage);
- ui.loginGroup->setTitle(tr("Logging in..."));
- ui.user->setDisabled(true);
- ui.password->setDisabled(true);
- ui.rememberPasswd->setDisabled(true);
- ui.loginButtonBox->button(QDialogButtonBox::Ok)->setDisabled(true);
- accountData["User"] = loginData["User"];
- accountData["RememberPasswd"] = loginData["RememberPasswd"];
- if(loginData["RememberPasswd"].toBool()) accountData["Password"] = loginData["Password"];
- else accountData.remove("Password");
- ui.user->setText(loginData["User"].toString());
- ui.password->setText(loginData["Password"].toString());
- ui.rememberPasswd->setChecked(loginData["RememberPasswd"].toBool());
- CoreAccountSettings s;
- s.storeAccountData(account, accountData);
- clientSyncer->loginToCore(loginData["User"].toString(), loginData["Password"].toString());
+ connect(_settingsPage, SIGNAL(connectToCore(AccountId)), SLOT(accept()));
+ connect(buttonBox, SIGNAL(accepted()), SLOT(accept()));
+ connect(buttonBox, SIGNAL(rejected()), SLOT(reject()));
}
-void CoreConnectDlg::setLoginWidgetStates() {
- ui.loginButtonBox->button(QDialogButtonBox::Ok)->setDisabled(ui.user->text().isEmpty() || ui.password->text().isEmpty());
-}
-
-void CoreConnectDlg::loginFailed(const QString &error) {
- if(wizard) {
- wizard->reject();
- }
- ui.connectIcon->setPixmap(BarIcon("dialog-error"));
- ui.loginStack->setCurrentWidget(ui.loginCredentialsPage);
- ui.loginGroup->setTitle(tr("Login"));
- ui.user->setEnabled(true);
- ui.password->setEnabled(true);
- ui.rememberPasswd->setEnabled(true);
- ui.coreInfoLabel->setText(error);
- ui.loginButtonBox->button(QDialogButtonBox::Ok)->setEnabled(true);
- ui.password->setFocus();
- doingAutoConnect = false;
-}
-
-void CoreConnectDlg::startCoreConfig(const QVariantList &backends) {
- storageBackends = backends;
- ui.loginStack->setCurrentWidget(ui.coreConfigPage);
-
- //on_launchCoreConfigWizard_clicked();
-
-}
-
-void CoreConnectDlg::on_launchCoreConfigWizard_clicked() {
- Q_ASSERT(!wizard);
- wizard = new CoreConfigWizard(storageBackends, this);
- connect(wizard, SIGNAL(setupCore(const QVariant &)), clientSyncer, SLOT(doCoreSetup(const QVariant &)));
- connect(wizard, SIGNAL(loginToCore(const QVariantMap &)), this, SLOT(doLogin(const QVariantMap &)));
- connect(clientSyncer, SIGNAL(coreSetupSuccess()), wizard, SLOT(coreSetupSuccess()));
- connect(clientSyncer, SIGNAL(coreSetupFailed(const QString &)), wizard, SLOT(coreSetupFailed(const QString &)));
- connect(wizard, SIGNAL(accepted()), this, SLOT(configWizardAccepted()));
- connect(wizard, SIGNAL(rejected()), this, SLOT(configWizardRejected()));
- connect(clientSyncer, SIGNAL(loginSuccess()), wizard, SLOT(loginSuccess()));
- connect(clientSyncer, SIGNAL(syncFinished()), wizard, SLOT(syncFinished()));
- wizard->show();
-}
-
-void CoreConnectDlg::configWizardAccepted() {
-
- wizard->deleteLater();
- wizard = 0;
-}
-void CoreConnectDlg::configWizardRejected() {
-
- wizard->deleteLater();
- wizard = 0;
- //exit(1); // FIXME
-}
-
-
-/************************************************************
- * Phase Three: Syncing
- ************************************************************/
-
-void CoreConnectDlg::startSync() {
- ui.sessionProgress->setRange(0, 1);
- ui.sessionProgress->setValue(0);
- ui.networksProgress->setRange(0, 1);
- ui.networksProgress->setValue(0);
-
- ui.stackedWidget->setCurrentWidget(ui.syncPage);
- // clean up old page
- ui.loginGroup->setTitle(tr("Login"));
- ui.user->setEnabled(true);
- ui.password->setEnabled(true);
- ui.rememberPasswd->setEnabled(true);
- if(ui.loginButtonBox->standardButtons() & QDialogButtonBox::Ok) // in mono mode we don't show an Ok Button
- ui.loginButtonBox->button(QDialogButtonBox::Ok)->setEnabled(true);
+AccountId CoreConnectDlg::selectedAccount() const
+{
+ return _settingsPage->selectedAccount();
}
-void CoreConnectDlg::coreSessionProgress(quint32 val, quint32 max) {
- ui.sessionProgress->setRange(0, max);
- ui.sessionProgress->setValue(val);
-
-}
-void CoreConnectDlg::coreNetworksProgress(quint32 val, quint32 max) {
- if(max == 0) {
- ui.networksProgress->setFormat("0/0");
- ui.networksProgress->setRange(0, 1);
- ui.networksProgress->setValue(1);
- } else {
- ui.networksProgress->setFormat("%v/%m");
- ui.networksProgress->setRange(0, max);
- ui.networksProgress->setValue(val);
- }
+void CoreConnectDlg::accept()
+{
+ _settingsPage->save();
+ QDialog::accept();
}
-void CoreConnectDlg::syncFinished() {
- if(!wizard) accept();
- else {
- hide();
- disconnect(wizard, 0, this, 0);
- connect(wizard, SIGNAL(finished(int)), this, SLOT(accept()));
- }
-}
-AccountId CoreConnectDlg::findFreeAccountId() {
- for(AccountId i = 1;; i++) {
- if(!accounts.contains(i) && i != _internalAccountId)
- return i;
- }
-}
+/******** CoreConnectAuthDlg ****************************************************************/
-/*****************************************************************************************
- * CoreAccountEditDlg
- *****************************************************************************************/
-CoreAccountEditDlg::CoreAccountEditDlg(AccountId id, const QVariantMap &acct, const QStringList &_existing, QWidget *parent)
- : QDialog(parent)
+CoreConnectAuthDlg::CoreConnectAuthDlg(CoreAccount *account, QWidget *parent)
+ : QDialog(parent),
+ _account(account)
{
- ui.setupUi(this);
- ui.useSsl->setIcon(SmallIcon("document-encrypt"));
+ ui.setupUi(this);
- existing = _existing;
- if(id.isValid()) {
- account = acct;
+ connect(ui.user, SIGNAL(textChanged(QString)), SLOT(setButtonStates()));
+ connect(ui.password, SIGNAL(textChanged(QString)), SLOT(setButtonStates()));
- existing.removeAll(acct["AccountName"].toString());
- ui.host->setText(acct["Host"].toString());
- ui.port->setValue(acct["Port"].toUInt());
- ui.accountName->setText(acct["AccountName"].toString());
-#ifdef HAVE_SSL
- ui.useSsl->setChecked(acct["useSsl"].toBool());
-#else
- ui.useSsl->setChecked(false);
- ui.useSsl->setEnabled(false);
-#endif
- ui.useProxy->setChecked(acct["useProxy"].toBool());
- ui.proxyHost->setText(acct["proxyHost"].toString());
- ui.proxyPort->setValue(acct["proxyPort"].toUInt());
- ui.proxyType->setCurrentIndex(acct["proxyType"].toInt() == QNetworkProxy::Socks5Proxy ? 0 : 1);
- ui.proxyUser->setText(acct["proxyUser"].toString());
- ui.proxyPassword->setText(acct["proxyPassword"].toString());
- } else {
- setWindowTitle(tr("Add Core Account"));
-#ifndef HAVE_SSL
- ui.useSsl->setChecked(false);
- ui.useSsl->setEnabled(false);
-#endif
- }
-}
+ ui.label->setText(tr("Please enter your credentials for %1:").arg(account->accountName()));
+ ui.user->setText(account->user());
+ ui.password->setText(account->password());
+ ui.rememberPasswd->setChecked(account->storePassword());
-QVariantMap CoreAccountEditDlg::accountData() {
- account["AccountName"] = ui.accountName->text().trimmed();
- account["Host"] = ui.host->text().trimmed();
- account["Port"] = ui.port->value();
- account["useSsl"] = ui.useSsl->isChecked();
- account["useProxy"] = ui.useProxy->isChecked();
- account["proxyHost"] = ui.proxyHost->text().trimmed();
- account["proxyPort"] = ui.proxyPort->value();
- account["proxyType"] = ui.proxyType->currentIndex() == 0 ? QNetworkProxy::Socks5Proxy : QNetworkProxy::HttpProxy;
- account["proxyUser"] = ui.proxyUser->text().trimmed();
- account["proxyPassword"] = ui.proxyPassword->text().trimmed();
- return account;
+ if (ui.user->text().isEmpty())
+ ui.user->setFocus();
+ else
+ ui.password->setFocus();
}
-void CoreAccountEditDlg::setWidgetStates() {
- bool ok = !ui.accountName->text().trimmed().isEmpty() && !existing.contains(ui.accountName->text()) && !ui.host->text().isEmpty();
- ui.buttonBox->button(QDialogButtonBox::Ok)->setEnabled(ok);
-}
-void CoreAccountEditDlg::on_host_textChanged(const QString &text) {
- Q_UNUSED(text);
- setWidgetStates();
-}
+void CoreConnectAuthDlg::accept()
+{
+ _account->setUser(ui.user->text());
+ _account->setPassword(ui.password->text());
+ _account->setStorePassword(ui.rememberPasswd->isChecked());
-void CoreAccountEditDlg::on_accountName_textChanged(const QString &text) {
- Q_UNUSED(text);
- setWidgetStates();
+ QDialog::accept();
}
-
-// ========================================
-// SslCertDisplayDialog
-// ========================================
-#ifdef HAVE_SSL
-SslCertDisplayDialog::SslCertDisplayDialog(const QString &host, const QSslCertificate &cert, QWidget *parent)
- : QDialog(parent)
+void CoreConnectAuthDlg::setButtonStates()
{
- setWindowTitle(tr("SSL Certificate used by %1").arg(host));
-
- QVBoxLayout *mainLayout = new QVBoxLayout(this);
-
- QGroupBox *issuerBox = new QGroupBox(tr("Issuer Info"), this);
- QFormLayout *issuerLayout = new QFormLayout(issuerBox);
- issuerLayout->addRow(tr("Organization:"), new QLabel(cert.issuerInfo(QSslCertificate::Organization), this));
- issuerLayout->addRow(tr("Locality Name:"), new QLabel(cert.issuerInfo(QSslCertificate::LocalityName), this));
- issuerLayout->addRow(tr("Organizational Unit Name:"), new QLabel(cert.issuerInfo(QSslCertificate::OrganizationalUnitName), this));
- issuerLayout->addRow(tr("Country Name:"), new QLabel(cert.issuerInfo(QSslCertificate::CountryName), this));
- issuerLayout->addRow(tr("State or Province Name:"), new QLabel(cert.issuerInfo(QSslCertificate::StateOrProvinceName), this));
- mainLayout->addWidget(issuerBox);
-
- QGroupBox *subjectBox = new QGroupBox(tr("Subject Info"), this);
- QFormLayout *subjectLayout = new QFormLayout(subjectBox);
- subjectLayout->addRow(tr("Organization:"), new QLabel(cert.subjectInfo(QSslCertificate::Organization), this));
- subjectLayout->addRow(tr("Locality Name:"), new QLabel(cert.subjectInfo(QSslCertificate::LocalityName), this));
- subjectLayout->addRow(tr("Organizational Unit Name:"), new QLabel(cert.subjectInfo(QSslCertificate::OrganizationalUnitName), this));
- subjectLayout->addRow(tr("Country Name:"), new QLabel(cert.subjectInfo(QSslCertificate::CountryName), this));
- subjectLayout->addRow(tr("State or Province Name:"), new QLabel(cert.subjectInfo(QSslCertificate::StateOrProvinceName), this));
- mainLayout->addWidget(subjectBox);
-
- QGroupBox *additionalBox = new QGroupBox(tr("Additional Info"), this);
- QFormLayout *additionalLayout = new QFormLayout(additionalBox);
- additionalLayout->addRow(tr("Valid From:"), new QLabel(cert.effectiveDate().toString(), this));
- additionalLayout->addRow(tr("Valid To:"), new QLabel(cert.expiryDate().toString(), this));
- QStringList hostnames = cert.alternateSubjectNames().values(QSsl::DnsEntry);
- for(int i = 0; i < hostnames.count(); i++) {
- additionalLayout->addRow(tr("Hostname %1:").arg(i + 1), new QLabel(hostnames[i], this));
- }
- QStringList mailaddresses = cert.alternateSubjectNames().values(QSsl::EmailEntry);
- for(int i = 0; i < mailaddresses.count(); i++) {
- additionalLayout->addRow(tr("E-Mail Address %1:").arg(i + 1), new QLabel(mailaddresses[i], this));
- }
- additionalLayout->addRow(tr("Digest:"), new QLabel(QString(prettyDigest(cert.digest()))));
- mainLayout->addWidget(additionalBox);
-
-
- QDialogButtonBox *buttonBox = new QDialogButtonBox(QDialogButtonBox::Ok, Qt::Horizontal, this);
- mainLayout->addWidget(buttonBox);
-
- connect(buttonBox, SIGNAL(accepted()), this, SLOT(accept()));
- connect(buttonBox, SIGNAL(rejected()), this, SLOT(reject()));
+ bool valid = !(ui.user->text().isEmpty() || ui.password->text().isEmpty());
+ ui.buttonBox->button(QDialogButtonBox::Ok)->setEnabled(valid);
}
-#endif