Split security page

wilder-work
Montel Laurent 13 years ago
parent 01ee76314e
commit fc2f3e5d95
  1. 1
      CMakeLists.txt
  2. 746
      configuredialog/configuredialog.cpp
  3. 158
      configuredialog/configuredialog_p.h
  4. 773
      configuredialog/configuresecuritypage.cpp
  5. 181
      configuredialog/configuresecuritypage.h
  6. 1
      kcm_kmail.cpp

@ -85,6 +85,7 @@ if (NOT WINCE AND KDEPIM_BUILD_DESKTOP)
configuredialog/configuredialog.cpp
configuredialog/configuredialog_p.cpp
configuredialog/configuremiscpage.cpp
configuredialog/configuresecuritypage.cpp
identity/identitylistview.cpp
identity/identitydialog.cpp
settings/globalsettings.cpp

@ -66,7 +66,6 @@ using KPIM::RecentAddresses;
#include "messageviewer/widgets/configurewidget.h"
#include "messageviewer/settings/globalsettings.h"
#include "messageviewer/header/customheadersettingwidget.h"
#include "messageviewer/adblock/adblocksettingwidget.h"
#include "messagelist/core/settings.h"
#include "messagelist/messagelistutil.h"
#include "messagecore/settings/globalsettings.h"
@ -87,11 +86,6 @@ using KPIM::RecentAddresses;
#include <kpimidentities/identity.h>
#include <kmime/kmime_dateformatter.h>
using KMime::DateFormatter;
#include "kleo/cryptoconfig.h"
#include "kleo/cryptobackendfactory.h"
#include "libkleo/ui/keyrequester.h"
#include "libkleo/ui/keyselectiondialog.h"
#include "libkleo/ui/cryptoconfigdialog.h"
#include <mailtransport/transportmanagementwidget.h>
using MailTransport::TransportManagementWidget;
@ -151,7 +145,6 @@ using MailTransport::TransportManagementWidget;
#include <nepomuk2/resourcemanager.h>
#include <libkdepim/widgets/nepomukwarning.h>
using namespace MailCommon;
using namespace KMail;
namespace {
@ -3509,743 +3502,4 @@ void ComposerPageAutoImageResizeTab::doResetToDefaultsOther()
}
// *************************************************************
// * *
// * SecurityPage *
// * *
// *************************************************************
QString SecurityPage::helpAnchor() const
{
return QString::fromLatin1("configure-security");
}
SecurityPage::SecurityPage( const KComponentData &instance, QWidget *parent )
: ConfigModuleWithTabs( instance, parent )
{
//
// "Reading" tab:
//
mGeneralTab = new GeneralTab(); // @TODO: rename
addTab( mGeneralTab, i18n("Reading") );
addTab( new MDNTab(), i18n("Message Disposition Notifications") );
//
// "Composing" tab:
//
mComposerCryptoTab = new ComposerCryptoTab();
addTab( mComposerCryptoTab, i18n("Composing") );
//
// "Warnings" tab:
//
mWarningTab = new WarningTab();
addTab( mWarningTab, i18n("Miscellaneous") );
//
// "S/MIME Validation" tab:
//
mSMimeTab = new SMimeTab();
addTab( mSMimeTab, i18n("S/MIME Validation") );
mSAdBlockTab = new SecurityPageAdBlockTab;
addTab( mSAdBlockTab, i18n("Ad block") );
}
QString SecurityPage::GeneralTab::helpAnchor() const
{
return QString::fromLatin1("configure-security-reading");
}
SecurityPageGeneralTab::SecurityPageGeneralTab( QWidget * parent )
: ConfigModuleTab( parent )
{
mSGTab.setupUi( this );
connect( mSGTab.mHtmlMailCheck, SIGNAL(stateChanged(int)),
this, SLOT(slotEmitChanged()) );
connect( mSGTab.mExternalReferences, SIGNAL(stateChanged(int)),
this, SLOT(slotEmitChanged()) );
connect(mSGTab.labelWarnHTML, SIGNAL(linkActivated(QString)),
SLOT(slotLinkClicked(QString)));
connect( mSGTab.mAlwaysDecrypt, SIGNAL(stateChanged(int)),
this, SLOT(slotEmitChanged()) );
connect( mSGTab.mAutomaticallyImportAttachedKeysCheck, SIGNAL(toggled(bool)),
SLOT(slotEmitChanged()) );
connect( mSGTab.mScamDetection, SIGNAL(toggled(bool)),
SLOT(slotEmitChanged()) );
connect( mSGTab.scamWhiteList, SIGNAL(changed()),
SLOT(slotEmitChanged()) );
}
void SecurityPageGeneralTab::slotLinkClicked( const QString & link )
{
if ( link == QLatin1String( "whatsthis1" ) )
QWhatsThis::showText( QCursor::pos(), mSGTab.mHtmlMailCheck->whatsThis() );
else if (link == QLatin1String( "whatsthis2" ) )
QWhatsThis::showText( QCursor::pos(), mSGTab.mExternalReferences->whatsThis() );
}
void SecurityPage::GeneralTab::doLoadOther()
{
mSGTab.mHtmlMailCheck->setChecked( MessageViewer::GlobalSettings::self()->htmlMail() );
mSGTab.mExternalReferences->setChecked( MessageViewer::GlobalSettings::self()->htmlLoadExternal() );
mSGTab.mAutomaticallyImportAttachedKeysCheck->setChecked(
MessageViewer::GlobalSettings::self()->autoImportKeys() );
mSGTab.mAlwaysDecrypt->setChecked( MessageViewer::GlobalSettings::self()->alwaysDecrypt() );
mSGTab.mScamDetection->setChecked( MessageViewer::GlobalSettings::self()->scamDetectionEnabled());
mSGTab.scamWhiteList->setStringList( MessageViewer::GlobalSettings::self()->scamDetectionWhiteList() );
}
void SecurityPage::GeneralTab::save()
{
if ( MessageViewer::GlobalSettings::self()->htmlMail() != mSGTab.mHtmlMailCheck->isChecked())
{
if (KMessageBox::warningContinueCancel(this, i18n("Changing the global "
"HTML setting will override all folder specific values."), QString(),
KStandardGuiItem::cont(), KStandardGuiItem::cancel(), QLatin1String("htmlMailOverride")) == KMessageBox::Continue)
{
MessageViewer::GlobalSettings::self()->setHtmlMail( mSGTab.mHtmlMailCheck->isChecked() );
foreach( const Akonadi::Collection &collection, kmkernel->allFolders() ) {
KConfigGroup config( KMKernel::self()->config(), MailCommon::FolderCollection::configGroupName(collection) );
config.writeEntry("htmlMailOverride", false);
}
}
}
MessageViewer::GlobalSettings::self()->setHtmlLoadExternal( mSGTab.mExternalReferences->isChecked() );
MessageViewer::GlobalSettings::self()->setAutoImportKeys(
mSGTab.mAutomaticallyImportAttachedKeysCheck->isChecked() );
MessageViewer::GlobalSettings::self()->setAlwaysDecrypt( mSGTab.mAlwaysDecrypt->isChecked() );
MessageViewer::GlobalSettings::self()->setScamDetectionEnabled( mSGTab.mScamDetection->isChecked() );
MessageViewer::GlobalSettings::self()->setScamDetectionWhiteList( mSGTab.scamWhiteList->stringList() );
}
//Adblock
QString SecurityPageAdBlockTab::helpAnchor() const
{
return QString();
}
SecurityPageAdBlockTab::SecurityPageAdBlockTab( QWidget * parent )
: ConfigModuleTab( parent )
{
QHBoxLayout *lay = new QHBoxLayout;
lay->setMargin(0);
mWidget = new MessageViewer::AdBlockSettingWidget;
lay->addWidget(mWidget);
connect(mWidget, SIGNAL(changed(bool)), SLOT(slotEmitChanged()));
setLayout(lay);
}
SecurityPageAdBlockTab::~SecurityPageAdBlockTab()
{
}
void SecurityPageAdBlockTab::save()
{
mWidget->save();
}
void SecurityPageAdBlockTab::doLoadFromGlobalSettings()
{
mWidget->doLoadFromGlobalSettings();
}
void SecurityPageAdBlockTab::doLoadOther()
{
}
void SecurityPageAdBlockTab::doResetToDefaultsOther()
{
mWidget->doResetToDefaultsOther();
}
QString SecurityPage::MDNTab::helpAnchor() const
{
return QString::fromLatin1("configure-security-mdn");
}
SecurityPageMDNTab::SecurityPageMDNTab( QWidget * parent )
: ConfigModuleTab( parent )
{
mUi.setupUi( this );
// "ignore", "ask", "deny", "always send" radiobuttons
mMDNGroup = new QButtonGroup( this );
connect( mMDNGroup, SIGNAL(buttonClicked(int)),
this, SLOT(slotEmitChanged()) );
mMDNGroup->addButton( mUi.radioIgnore, 0 );
mMDNGroup->addButton( mUi.radioAsk, 1 );
mMDNGroup->addButton( mUi.radioDeny, 2 );
mMDNGroup->addButton( mUi.radioAlways, 3 );
// "Original Message quote" radiobuttons
mOrigQuoteGroup = new QButtonGroup( this );
connect( mOrigQuoteGroup, SIGNAL(buttonClicked(int)),
this, SLOT(slotEmitChanged()) );
mOrigQuoteGroup->addButton( mUi.radioNothing, 0 );
mOrigQuoteGroup->addButton( mUi.radioFull, 1 );
mOrigQuoteGroup->addButton( mUi.radioHeaders, 2 );
connect( mUi.mNoMDNsWhenEncryptedCheck, SIGNAL(toggled(bool)), SLOT(slotEmitChanged()) );
connect( mUi.labelWarning, SIGNAL(linkActivated(QString)),
SLOT(slotLinkClicked(QString)) );
}
void SecurityPageMDNTab::slotLinkClicked( const QString & link )
{
if ( link == QLatin1String( "whatsthis-mdn" ) )
QWhatsThis::showText( QCursor::pos(), mUi.radioIgnore->whatsThis() );
}
void SecurityPage::MDNTab::doLoadOther()
{
int num = MessageViewer::GlobalSettings::self()->defaultPolicy();
if ( num < 0 || num >= mMDNGroup->buttons().count() ) num = 0;
mMDNGroup->button(num)->setChecked(true);
num = MessageViewer::GlobalSettings::self()->quoteMessage();
if ( num < 0 || num >= mOrigQuoteGroup->buttons().count() ) num = 0;
mOrigQuoteGroup->button(num)->setChecked(true);
mUi.mNoMDNsWhenEncryptedCheck->setChecked( MessageViewer::GlobalSettings::self()->notSendWhenEncrypted() );
}
void SecurityPage::MDNTab::save()
{
MessageViewer::GlobalSettings::self()->setDefaultPolicy( mMDNGroup->checkedId() );
MessageViewer::GlobalSettings::self()->setQuoteMessage( mOrigQuoteGroup->checkedId() );
MessageViewer::GlobalSettings::self()->setNotSendWhenEncrypted( mUi.mNoMDNsWhenEncryptedCheck->isChecked() );
}
QString SecurityPage::ComposerCryptoTab::helpAnchor() const
{
return QString::fromLatin1("configure-security-composing");
}
SecurityPageComposerCryptoTab::SecurityPageComposerCryptoTab( QWidget * parent )
: ConfigModuleTab( parent )
{
mWidget = new Ui::ComposerCryptoConfiguration;
mWidget->setupUi( this );
connect( mWidget->mEncToSelf, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->mShowEncryptionResult, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->mShowKeyApprovalDlg, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->mAutoEncrypt, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->mNeverEncryptWhenSavingInDrafts, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->mStoreEncrypted, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
}
SecurityPageComposerCryptoTab::~SecurityPageComposerCryptoTab()
{
delete mWidget;
}
void SecurityPage::ComposerCryptoTab::doLoadOther()
{
// If you change default values, sync messagecomposer.cpp too
mWidget->mEncToSelf->setChecked( MessageComposer::MessageComposerSettings::self()->cryptoEncryptToSelf() );
mWidget->mShowEncryptionResult->setChecked( false ); //composer.readBoolEntry( "crypto-show-encryption-result", true ) );
mWidget->mShowEncryptionResult->hide();
mWidget->mShowKeyApprovalDlg->setChecked( MessageComposer::MessageComposerSettings::self()->cryptoShowKeysForApproval() );
mWidget->mAutoEncrypt->setChecked( MessageComposer::MessageComposerSettings::self()->pgpAutoEncrypt() ) ;
mWidget->mNeverEncryptWhenSavingInDrafts->setChecked(
GlobalSettings::self()->neverEncryptDrafts() );
mWidget->mStoreEncrypted->setChecked( GlobalSettings::self()->cryptoStoreEncrypted() );
}
void SecurityPage::ComposerCryptoTab::save()
{
MessageComposer::MessageComposerSettings::self()->setCryptoEncryptToSelf( mWidget->mEncToSelf->isChecked() );
GlobalSettings::self()->setCryptoShowEncryptionResult( mWidget->mShowEncryptionResult->isChecked() );
MessageComposer::MessageComposerSettings::self()->setCryptoShowKeysForApproval( mWidget->mShowKeyApprovalDlg->isChecked() );
MessageComposer::MessageComposerSettings::self()->setPgpAutoEncrypt( mWidget->mAutoEncrypt->isChecked() );
GlobalSettings::self()->setNeverEncryptDrafts( mWidget->mNeverEncryptWhenSavingInDrafts->isChecked() );
GlobalSettings::self()->setCryptoStoreEncrypted( mWidget->mStoreEncrypted->isChecked() );
}
void SecurityPage::ComposerCryptoTab::doLoadFromGlobalSettings()
{
mWidget->mEncToSelf->setChecked( MessageComposer::MessageComposerSettings::self()->cryptoEncryptToSelf() );
mWidget->mShowEncryptionResult->setChecked( GlobalSettings::self()->cryptoShowEncryptionResult() );
mWidget->mShowKeyApprovalDlg->setChecked(MessageComposer::MessageComposerSettings::self()->cryptoShowKeysForApproval() );
mWidget->mAutoEncrypt->setChecked(MessageComposer::MessageComposerSettings::self()->pgpAutoEncrypt() );
mWidget->mNeverEncryptWhenSavingInDrafts->setChecked( GlobalSettings::self()->neverEncryptDrafts() );
mWidget->mStoreEncrypted->setChecked(GlobalSettings::self()->cryptoStoreEncrypted() );
}
QString SecurityPage::WarningTab::helpAnchor() const
{
return QString::fromLatin1("configure-security-warnings");
}
SecurityPageWarningTab::SecurityPageWarningTab( QWidget * parent )
: ConfigModuleTab( parent )
{
mWidget = new Ui::WarningConfiguration;
mWidget->setupUi( this );
mWidget->chiasmusButton->hide();
connect( mWidget->warnGroupBox, SIGNAL(toggled(bool)), SLOT(slotEmitChanged()) );
connect( mWidget->mWarnUnsigned, SIGNAL(toggled(bool)), SLOT(slotEmitChanged()) );
connect( mWidget->warnUnencryptedCB, SIGNAL(toggled(bool)), SLOT(slotEmitChanged()) );
connect( mWidget->warnReceiverNotInCertificateCB, SIGNAL(toggled(bool)), SLOT(slotEmitChanged()) );
connect( mWidget->gnupgButton, SIGNAL(clicked()), SLOT(slotConfigureGnupg()) );
//connect( mWidget->chiasmusButton, SIGNAL(clicked()), SLOT(slotConfigureChiasmus()) );
connect( mWidget->enableAllWarningsPB, SIGNAL(clicked()), SLOT(slotReenableAllWarningsClicked()) );
}
SecurityPageWarningTab::~SecurityPageWarningTab()
{
delete mWidget;
}
void SecurityPage::WarningTab::doLoadFromGlobalSettings()
{
mWidget->warnUnencryptedCB->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarningUnencrypted() );
mWidget->mWarnUnsigned->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarningUnsigned() );
mWidget->warnReceiverNotInCertificateCB->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarnRecvNotInCert() );
// The "-int" part of the key name is because there used to be a separate boolean
// config entry for enabling/disabling. This is done with the single bool value now.
mWidget->warnGroupBox->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarnWhenNearExpire() );
mWidget->mWarnSignKeyExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignKeyNearExpiryThresholdDays() );
mWidget->mWarnSignChainCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignChaincertNearExpiryThresholdDays() );
mWidget->mWarnSignRootCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignRootNearExpiryThresholdDays() );
mWidget->mWarnEncrKeyExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrKeyNearExpiryThresholdDays() );
mWidget->mWarnEncrChainCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrChaincertNearExpiryThresholdDays() );
mWidget->mWarnEncrRootCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrRootNearExpiryThresholdDays() );
}
void SecurityPage::WarningTab::doLoadOther()
{
mWidget->warnUnencryptedCB->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarningUnencrypted() );
mWidget->mWarnUnsigned->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarningUnsigned() );
mWidget->warnReceiverNotInCertificateCB->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarnRecvNotInCert() );
// The "-int" part of the key name is because there used to be a separate boolean
// config entry for enabling/disabling. This is done with the single bool value now.
mWidget->warnGroupBox->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarnWhenNearExpire() );
mWidget->mWarnSignKeyExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignKeyNearExpiryThresholdDays() );
mWidget->mWarnSignKeyExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->mWarnSignChainCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignChaincertNearExpiryThresholdDays() );
mWidget->mWarnSignChainCertExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->mWarnSignRootCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignRootNearExpiryThresholdDays() );
mWidget->mWarnSignRootCertExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->mWarnEncrKeyExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrKeyNearExpiryThresholdDays() );
mWidget->mWarnEncrKeyExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->mWarnEncrChainCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrChaincertNearExpiryThresholdDays() );
mWidget->mWarnEncrChainCertExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->mWarnEncrRootCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrRootNearExpiryThresholdDays() );
mWidget->mWarnEncrRootCertExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->enableAllWarningsPB->setEnabled( true );
}
void SecurityPage::WarningTab::save()
{
MessageComposer::MessageComposerSettings::self()->setCryptoWarnRecvNotInCert(
mWidget->warnReceiverNotInCertificateCB->isChecked() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarningUnencrypted(
mWidget->warnUnencryptedCB->isChecked() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarningUnsigned(
mWidget->mWarnUnsigned->isChecked() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnWhenNearExpire(
mWidget->warnGroupBox->isChecked() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnSignKeyNearExpiryThresholdDays(
mWidget->mWarnSignKeyExpiresSB->value() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnSignChaincertNearExpiryThresholdDays(
mWidget->mWarnSignChainCertExpiresSB->value() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnSignRootNearExpiryThresholdDays(
mWidget->mWarnSignRootCertExpiresSB->value() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnEncrKeyNearExpiryThresholdDays(
mWidget->mWarnEncrKeyExpiresSB->value() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnEncrChaincertNearExpiryThresholdDays(
mWidget->mWarnEncrChainCertExpiresSB->value() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnEncrRootNearExpiryThresholdDays(
mWidget->mWarnEncrRootCertExpiresSB->value() );
}
void SecurityPage::WarningTab::slotReenableAllWarningsClicked()
{
KMessageBox::enableAllMessages();
//Nepomuk composer.
const QString groupName = KPIM::NepomukWarning::nepomukWarningGroupName();
if ( KMKernel::self()->config()->hasGroup( groupName ) ) {
KConfigGroup cfgGroup( KMKernel::self()->config(), groupName );
cfgGroup.deleteGroup();
}
mWidget->enableAllWarningsPB->setEnabled( false );
}
void SecurityPage::WarningTab::slotConfigureGnupg()
{
QPointer<KCMultiDialog> dlg( new KCMultiDialog( this ) );
dlg->addModule( QLatin1String("kleopatra_config_gnupgsystem") );
dlg->exec();
delete dlg;
}
#if 0
void SecurityPage::WarningTab::slotConfigureChiasmus()
{
using namespace Kleo;
// Find Chiasmus backend:
if ( const CryptoBackendFactory * const bf = Kleo::CryptoBackendFactory::instance() )
for ( unsigned int i = 0 ; const CryptoBackend * const b = bf->backend( i ) ; ++i )
if ( b->name() == QLatin1String( "Chiasmus" ) )
if ( CryptoConfig * const c = b->config() ) {
QPointer<CryptoConfigDialog> dlg( new CryptoConfigDialog( c, this ) );
dlg->exec();
delete dlg;
break;
} else {
kWarning() << "Found Chiasmus backend, but there doesn't seem to be a config object available from it.";
}
else
kDebug() << "Skipping" << b->name() << "backend (not \"Chiasmus\")";
else
kDebug() << "Kleo::CryptoBackendFactory::instance() returned NULL!";
}
#endif
////
QString SecurityPage::SMimeTab::helpAnchor() const
{
return QString::fromLatin1("configure-security-smime-validation");
}
SecurityPageSMimeTab::SecurityPageSMimeTab( QWidget * parent )
: ConfigModuleTab( parent )
{
mWidget = new Ui::SMimeConfiguration;
mWidget->setupUi( this );
// Button-group for exclusive radiobuttons
QButtonGroup* bg = new QButtonGroup( this );
bg->addButton( mWidget->CRLRB );
bg->addButton( mWidget->OCSPRB );
// Settings for the keyrequester custom widget
mWidget->OCSPResponderSignature->setAllowedKeys(
Kleo::KeySelectionDialog::SMIMEKeys
| Kleo::KeySelectionDialog::TrustedKeys
| Kleo::KeySelectionDialog::ValidKeys
| Kleo::KeySelectionDialog::SigningKeys
| Kleo::KeySelectionDialog::PublicKeys );
mWidget->OCSPResponderSignature->setMultipleKeysEnabled( false );
mConfig = Kleo::CryptoBackendFactory::instance()->config();
connect( mWidget->CRLRB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->OCSPRB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->OCSPResponderURL, SIGNAL(textChanged(QString)), this, SLOT(slotEmitChanged()) );
connect( mWidget->OCSPResponderSignature, SIGNAL(changed()), this, SLOT(slotEmitChanged()) );
connect( mWidget->doNotCheckCertPolicyCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->neverConsultCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->fetchMissingCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->ignoreServiceURLCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->ignoreHTTPDPCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->disableHTTPCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->honorHTTPProxyRB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->useCustomHTTPProxyRB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->customHTTPProxy, SIGNAL(textChanged(QString)), this, SLOT(slotEmitChanged()) );
connect( mWidget->ignoreLDAPDPCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->disableLDAPCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->customLDAPProxy, SIGNAL(textChanged(QString)), this, SLOT(slotEmitChanged()) );
connect( mWidget->disableHTTPCB, SIGNAL(toggled(bool)),
this, SLOT(slotUpdateHTTPActions()) );
connect( mWidget->ignoreHTTPDPCB, SIGNAL(toggled(bool)),
this, SLOT(slotUpdateHTTPActions()) );
// Button-group for exclusive radiobuttons
QButtonGroup* bgHTTPProxy = new QButtonGroup( this );
bgHTTPProxy->addButton( mWidget->honorHTTPProxyRB );
bgHTTPProxy->addButton( mWidget->useCustomHTTPProxyRB );
QDBusConnection::sessionBus().connect(QString(), QString(), QLatin1String("org.kde.kleo.CryptoConfig"), QLatin1String("changed"),this, SLOT(load()) );
}
SecurityPageSMimeTab::~SecurityPageSMimeTab()
{
delete mWidget;
}
static void disableDirmngrWidget( QWidget* w )
{
w->setEnabled( false );
w->setWhatsThis( i18n( "This option requires dirmngr >= 0.9.0" ) );
}
static void initializeDirmngrCheckbox( QCheckBox* cb, Kleo::CryptoConfigEntry* entry )
{
if ( entry )
cb->setChecked( entry->boolValue() );
else
disableDirmngrWidget( cb );
}
struct SMIMECryptoConfigEntries {
SMIMECryptoConfigEntries( Kleo::CryptoConfig* config )
: mConfig( config ) {
// Checkboxes
mCheckUsingOCSPConfigEntry = configEntry( QLatin1String("gpgsm"), QLatin1String("Security"), QLatin1String("enable-ocsp"), Kleo::CryptoConfigEntry::ArgType_None, false );
mEnableOCSPsendingConfigEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("OCSP"), QLatin1String("allow-ocsp"), Kleo::CryptoConfigEntry::ArgType_None, false );
mDoNotCheckCertPolicyConfigEntry = configEntry( QLatin1String("gpgsm"), QLatin1String("Security"), QLatin1String("disable-policy-checks"), Kleo::CryptoConfigEntry::ArgType_None, false );
mNeverConsultConfigEntry = configEntry( QLatin1String("gpgsm"), QLatin1String("Security"), QLatin1String("disable-crl-checks"), Kleo::CryptoConfigEntry::ArgType_None, false );
mFetchMissingConfigEntry = configEntry( QLatin1String("gpgsm"), QLatin1String("Security"), QLatin1String("auto-issuer-key-retrieve"), Kleo::CryptoConfigEntry::ArgType_None, false );
// dirmngr-0.9.0 options
mIgnoreServiceURLEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("OCSP"), QLatin1String("ignore-ocsp-service-url"), Kleo::CryptoConfigEntry::ArgType_None, false );
mIgnoreHTTPDPEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("HTTP"), QLatin1String("ignore-http-dp"), Kleo::CryptoConfigEntry::ArgType_None, false );
mDisableHTTPEntry = configEntry(QLatin1String( "dirmngr"), QLatin1String("HTTP"), QLatin1String("disable-http"), Kleo::CryptoConfigEntry::ArgType_None, false );
mHonorHTTPProxy = configEntry( QLatin1String("dirmngr"), QLatin1String("HTTP"), QLatin1String("honor-http-proxy"), Kleo::CryptoConfigEntry::ArgType_None, false );
mIgnoreLDAPDPEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("LDAP"), QLatin1String("ignore-ldap-dp"), Kleo::CryptoConfigEntry::ArgType_None, false );
mDisableLDAPEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("LDAP"), QLatin1String("disable-ldap"), Kleo::CryptoConfigEntry::ArgType_None, false );
// Other widgets
mOCSPResponderURLConfigEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("OCSP"), QLatin1String("ocsp-responder"), Kleo::CryptoConfigEntry::ArgType_String, false );
mOCSPResponderSignature = configEntry( QLatin1String("dirmngr"), QLatin1String("OCSP"), QLatin1String("ocsp-signer"), Kleo::CryptoConfigEntry::ArgType_String, false );
mCustomHTTPProxy = configEntry( QLatin1String("dirmngr"), QLatin1String("HTTP"), QLatin1String("http-proxy"), Kleo::CryptoConfigEntry::ArgType_String, false );
mCustomLDAPProxy = configEntry( QLatin1String("dirmngr"), QLatin1String("LDAP"), QLatin1String("ldap-proxy"), Kleo::CryptoConfigEntry::ArgType_String, false );
}
Kleo::CryptoConfigEntry* configEntry(const QString &componentName,
const QString &groupName,
const QString &entryName,
int argType,
bool isList );
// Checkboxes
Kleo::CryptoConfigEntry* mCheckUsingOCSPConfigEntry;
Kleo::CryptoConfigEntry* mEnableOCSPsendingConfigEntry;
Kleo::CryptoConfigEntry* mDoNotCheckCertPolicyConfigEntry;
Kleo::CryptoConfigEntry* mNeverConsultConfigEntry;
Kleo::CryptoConfigEntry* mFetchMissingConfigEntry;
Kleo::CryptoConfigEntry* mIgnoreServiceURLEntry;
Kleo::CryptoConfigEntry* mIgnoreHTTPDPEntry;
Kleo::CryptoConfigEntry* mDisableHTTPEntry;
Kleo::CryptoConfigEntry* mHonorHTTPProxy;
Kleo::CryptoConfigEntry* mIgnoreLDAPDPEntry;
Kleo::CryptoConfigEntry* mDisableLDAPEntry;
// Other widgets
Kleo::CryptoConfigEntry* mOCSPResponderURLConfigEntry;
Kleo::CryptoConfigEntry* mOCSPResponderSignature;
Kleo::CryptoConfigEntry* mCustomHTTPProxy;
Kleo::CryptoConfigEntry* mCustomLDAPProxy;
Kleo::CryptoConfig* mConfig;
};
void SecurityPage::SMimeTab::doLoadOther()
{
if ( !mConfig ) {
setEnabled( false );
return;
}
// Force re-parsing gpgconf data, in case e.g. kleopatra or "configure backend" was used
// (which ends up calling us via D-Bus)
mConfig->clear();
// Create config entries
// Don't keep them around, they'll get deleted by clear(), which could be
// done by the "configure backend" button even before we save().
SMIMECryptoConfigEntries e( mConfig );
// Initialize GUI items from the config entries
if ( e.mCheckUsingOCSPConfigEntry ) {
bool b = e.mCheckUsingOCSPConfigEntry->boolValue();
mWidget->OCSPRB->setChecked( b );
mWidget->CRLRB->setChecked( !b );
mWidget->OCSPGroupBox->setEnabled( b );
} else {
mWidget->OCSPGroupBox->setEnabled( false );
}
if ( e.mDoNotCheckCertPolicyConfigEntry )
mWidget->doNotCheckCertPolicyCB->setChecked( e.mDoNotCheckCertPolicyConfigEntry->boolValue() );
if ( e.mNeverConsultConfigEntry )
mWidget->neverConsultCB->setChecked( e.mNeverConsultConfigEntry->boolValue() );
if ( e.mFetchMissingConfigEntry )
mWidget->fetchMissingCB->setChecked( e.mFetchMissingConfigEntry->boolValue() );
if ( e.mOCSPResponderURLConfigEntry )
mWidget->OCSPResponderURL->setText( e.mOCSPResponderURLConfigEntry->stringValue() );
if ( e.mOCSPResponderSignature ) {
mWidget->OCSPResponderSignature->setFingerprint( e.mOCSPResponderSignature->stringValue() );
}
// dirmngr-0.9.0 options
initializeDirmngrCheckbox( mWidget->ignoreServiceURLCB, e.mIgnoreServiceURLEntry );
initializeDirmngrCheckbox( mWidget->ignoreHTTPDPCB, e.mIgnoreHTTPDPEntry );
initializeDirmngrCheckbox( mWidget->disableHTTPCB, e.mDisableHTTPEntry );
initializeDirmngrCheckbox( mWidget->ignoreLDAPDPCB, e.mIgnoreLDAPDPEntry );
initializeDirmngrCheckbox( mWidget->disableLDAPCB, e.mDisableLDAPEntry );
if ( e.mCustomHTTPProxy ) {
QString systemProxy = QString::fromLocal8Bit( qgetenv( "http_proxy" ) );
if ( systemProxy.isEmpty() )
systemProxy = i18n( "no proxy" );
mWidget->systemHTTPProxy->setText( i18n( "(Current system setting: %1)", systemProxy ) );
bool honor = e.mHonorHTTPProxy && e.mHonorHTTPProxy->boolValue();
mWidget->honorHTTPProxyRB->setChecked( honor );
mWidget->useCustomHTTPProxyRB->setChecked( !honor );
mWidget->customHTTPProxy->setText( e.mCustomHTTPProxy->stringValue() );
} else {
disableDirmngrWidget( mWidget->honorHTTPProxyRB );
disableDirmngrWidget( mWidget->useCustomHTTPProxyRB );
disableDirmngrWidget( mWidget->systemHTTPProxy );
disableDirmngrWidget( mWidget->customHTTPProxy );
}
if ( e.mCustomLDAPProxy )
mWidget->customLDAPProxy->setText( e.mCustomLDAPProxy->stringValue() );
else {
disableDirmngrWidget( mWidget->customLDAPProxy );
disableDirmngrWidget( mWidget->customLDAPLabel );
}
slotUpdateHTTPActions();
}
void SecurityPage::SMimeTab::slotUpdateHTTPActions()
{
mWidget->ignoreHTTPDPCB->setEnabled( !mWidget->disableHTTPCB->isChecked() );
// The proxy settings only make sense when "Ignore HTTP CRL DPs of certificate" is checked.
bool enableProxySettings = !mWidget->disableHTTPCB->isChecked()
&& mWidget->ignoreHTTPDPCB->isChecked();
mWidget->systemHTTPProxy->setEnabled( enableProxySettings );
mWidget->useCustomHTTPProxyRB->setEnabled( enableProxySettings );
mWidget->honorHTTPProxyRB->setEnabled( enableProxySettings );
mWidget->customHTTPProxy->setEnabled( enableProxySettings && mWidget->useCustomHTTPProxyRB->isChecked());
if ( !mWidget->useCustomHTTPProxyRB->isChecked() &&
!mWidget->honorHTTPProxyRB->isChecked() )
mWidget->honorHTTPProxyRB->setChecked( true );
}
static void saveCheckBoxToKleoEntry( QCheckBox* cb, Kleo::CryptoConfigEntry* entry )
{
const bool b = cb->isChecked();
if ( entry && entry->boolValue() != b )
entry->setBoolValue( b );
}
void SecurityPage::SMimeTab::save()
{
if ( !mConfig ) {
return;
}
// Create config entries
// Don't keep them around, they'll get deleted by clear(), which could be done by the
// "configure backend" button.
SMIMECryptoConfigEntries e( mConfig );
bool b = mWidget->OCSPRB->isChecked();
if ( e.mCheckUsingOCSPConfigEntry && e.mCheckUsingOCSPConfigEntry->boolValue() != b )
e.mCheckUsingOCSPConfigEntry->setBoolValue( b );
// Set allow-ocsp together with enable-ocsp
if ( e.mEnableOCSPsendingConfigEntry && e.mEnableOCSPsendingConfigEntry->boolValue() != b )
e.mEnableOCSPsendingConfigEntry->setBoolValue( b );
saveCheckBoxToKleoEntry( mWidget->doNotCheckCertPolicyCB, e.mDoNotCheckCertPolicyConfigEntry );
saveCheckBoxToKleoEntry( mWidget->neverConsultCB, e.mNeverConsultConfigEntry );
saveCheckBoxToKleoEntry( mWidget->fetchMissingCB, e.mFetchMissingConfigEntry );
QString txt = mWidget->OCSPResponderURL->text();
if ( e.mOCSPResponderURLConfigEntry && e.mOCSPResponderURLConfigEntry->stringValue() != txt )
e.mOCSPResponderURLConfigEntry->setStringValue( txt );
txt = mWidget->OCSPResponderSignature->fingerprint();
if ( e.mOCSPResponderSignature && e.mOCSPResponderSignature->stringValue() != txt ) {
e.mOCSPResponderSignature->setStringValue( txt );
}
//dirmngr-0.9.0 options
saveCheckBoxToKleoEntry( mWidget->ignoreServiceURLCB, e.mIgnoreServiceURLEntry );
saveCheckBoxToKleoEntry( mWidget->ignoreHTTPDPCB, e.mIgnoreHTTPDPEntry );
saveCheckBoxToKleoEntry( mWidget->disableHTTPCB, e.mDisableHTTPEntry );
saveCheckBoxToKleoEntry( mWidget->ignoreLDAPDPCB, e.mIgnoreLDAPDPEntry );
saveCheckBoxToKleoEntry( mWidget->disableLDAPCB, e.mDisableLDAPEntry );
if ( e.mCustomHTTPProxy ) {
const bool honor = mWidget->honorHTTPProxyRB->isChecked();
if ( e.mHonorHTTPProxy && e.mHonorHTTPProxy->boolValue() != honor )
e.mHonorHTTPProxy->setBoolValue( honor );
QString chosenProxy = mWidget->customHTTPProxy->text();
if ( chosenProxy != e.mCustomHTTPProxy->stringValue() )
e.mCustomHTTPProxy->setStringValue( chosenProxy );
}
txt = mWidget->customLDAPProxy->text();
if ( e.mCustomLDAPProxy && e.mCustomLDAPProxy->stringValue() != txt )
e.mCustomLDAPProxy->setStringValue( mWidget->customLDAPProxy->text() );
mConfig->sync( true );
}
Kleo::CryptoConfigEntry* SMIMECryptoConfigEntries::configEntry( const QString &componentName,
const QString &groupName,
const QString &entryName,
int /*Kleo::CryptoConfigEntry::ArgType*/ argType,
bool isList )
{
Kleo::CryptoConfigEntry* entry = mConfig->entry( componentName, groupName, entryName );
if ( !entry ) {
kWarning() << QString::fromLatin1("Backend error: gpgconf doesn't seem to know the entry for %1/%2/%3" ).arg( componentName, groupName, entryName );
return 0;
}
if( entry->argType() != argType || entry->isList() != isList ) {
kWarning() << QString::fromLatin1("Backend error: gpgconf has wrong type for %1/%2/%3: %4 %5" ).arg( componentName, groupName, entryName ).arg( entry->argType() ).arg( entry->isList() );
return 0;
}
return entry;
}

@ -17,12 +17,9 @@
#include <akonadi/agentinstance.h>
#include "ui_composercryptoconfiguration.h"
#include "ui_warningconfiguration.h"
#include "ui_smimeconfiguration.h"
#include "ui_customtemplates_base.h"
#include "ui_securitypagegeneraltab.h"
#include "ui_securitypagemdntab.h"
#include "ui_accountspagereceivingtab.h"
#include "tag.h"
class QPushButton;
@ -752,159 +749,4 @@ private:
ExternalEditorTab *mExternalEditorTab;
};
//
//
// SecurityPage
//
//
class SecurityPageGeneralTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageGeneralTab( QWidget * parent=0 );
QString helpAnchor() const;
void save();
private:
//virtual void doLoadFromGlobalSettings();
void doLoadOther();
//FIXME virtual void doResetToDefaultsOther();
private:
Ui_SecurityPageGeneralTab mSGTab;
private slots:
void slotLinkClicked( const QString & link );
};
class SecurityPageMDNTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageMDNTab( QWidget * parent=0 );
QString helpAnchor() const;
void save();
private:
void doLoadOther();
private:
QButtonGroup *mMDNGroup;
QButtonGroup *mOrigQuoteGroup;
Ui_SecurityPageMDNTab mUi;
private slots:
void slotLinkClicked( const QString & link );
};
class SecurityPageComposerCryptoTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageComposerCryptoTab( QWidget * parent=0 );
~SecurityPageComposerCryptoTab();
QString helpAnchor() const;
void save();
private:
void doLoadFromGlobalSettings();
void doLoadOther();
//FIXME virtual void doResetToDefaultsOther();
private:
Ui::ComposerCryptoConfiguration* mWidget;
};
class SecurityPageWarningTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageWarningTab( QWidget * parent=0 );
~SecurityPageWarningTab();
QString helpAnchor() const;
void save();
private Q_SLOTS:
void slotReenableAllWarningsClicked();
void slotConfigureGnupg();
//void slotConfigureChiasmus();
private:
void doLoadFromGlobalSettings();
void doLoadOther();
//FIXME virtual void doResetToDefaultsOther();
private:
Ui::WarningConfiguration* mWidget;
};
class SecurityPageSMimeTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageSMimeTab( QWidget * parent=0 );
~SecurityPageSMimeTab();
QString helpAnchor() const;
void save();
private slots:
void slotUpdateHTTPActions();
private:
//virtual void doLoadFromGlobalSettings();
void doLoadOther();
//FIXME virtual void doResetToDefaultsOther();
private:
Ui::SMimeConfiguration* mWidget;
Kleo::CryptoConfig* mConfig;
};
class SecurityPageAdBlockTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageAdBlockTab( QWidget * parent=0 );
~SecurityPageAdBlockTab();
QString helpAnchor() const;
void save();
private:
void doLoadFromGlobalSettings();
void doLoadOther();
void doResetToDefaultsOther();
private:
MessageViewer::AdBlockSettingWidget *mWidget;
};
class KMAIL_EXPORT SecurityPage : public ConfigModuleWithTabs {
Q_OBJECT
public:
explicit SecurityPage( const KComponentData &instance, QWidget *parent=0 );
QString helpAnchor() const;
typedef SecurityPageGeneralTab GeneralTab;
typedef SecurityPageMDNTab MDNTab;
typedef SecurityPageComposerCryptoTab ComposerCryptoTab;
typedef SecurityPageWarningTab WarningTab;
typedef SecurityPageSMimeTab SMimeTab;
private:
GeneralTab *mGeneralTab;
ComposerCryptoTab *mComposerCryptoTab;
WarningTab *mWarningTab;
SMimeTab *mSMimeTab;
SecurityPageAdBlockTab *mSAdBlockTab;
};
#endif // _CONFIGURE_DIALOG_PRIVATE_H_

@ -0,0 +1,773 @@
/*
Copyright (c) 2013 Montel Laurent <montel@kde.org>
This program is free software; you can redistribute it and/or modify it
under the terms of the GNU General Public License, version 2, as
published by the Free Software Foundation.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "configuresecuritypage.h"
#include "messageviewer/settings/globalsettings.h"
#include "messagecomposer/settings/messagecomposersettings.h"
#include "messageviewer/adblock/adblocksettingwidget.h"
#include "mailcommon/folder/foldercollection.h"
#include "settings/globalsettings.h"
#include <libkdepim/widgets/nepomukwarning.h>
#include "kmkernel.h"
#include "kleo/cryptoconfig.h"
#include "kleo/cryptobackendfactory.h"
#include "libkleo/ui/keyrequester.h"
#include "libkleo/ui/keyselectiondialog.h"
#include "libkleo/ui/cryptoconfigdialog.h"
#include <KLocale>
#include <KCMultiDialog>
#include <KMessageBox>
#include <QWhatsThis>
#include <QDBusConnection>
QString SecurityPage::helpAnchor() const
{
return QString::fromLatin1("configure-security");
}
SecurityPage::SecurityPage( const KComponentData &instance, QWidget *parent )
: ConfigModuleWithTabs( instance, parent )
{
//
// "Reading" tab:
//
mGeneralTab = new GeneralTab(); // @TODO: rename
addTab( mGeneralTab, i18n("Reading") );
addTab( new MDNTab(), i18n("Message Disposition Notifications") );
//
// "Composing" tab:
//
mComposerCryptoTab = new ComposerCryptoTab();
addTab( mComposerCryptoTab, i18n("Composing") );
//
// "Warnings" tab:
//
mWarningTab = new WarningTab();
addTab( mWarningTab, i18n("Miscellaneous") );
//
// "S/MIME Validation" tab:
//
mSMimeTab = new SMimeTab();
addTab( mSMimeTab, i18n("S/MIME Validation") );
mSAdBlockTab = new SecurityPageAdBlockTab;
addTab( mSAdBlockTab, i18n("Ad block") );
}
QString SecurityPage::GeneralTab::helpAnchor() const
{
return QString::fromLatin1("configure-security-reading");
}
SecurityPageGeneralTab::SecurityPageGeneralTab( QWidget * parent )
: ConfigModuleTab( parent )
{
mSGTab.setupUi( this );
connect( mSGTab.mHtmlMailCheck, SIGNAL(stateChanged(int)),
this, SLOT(slotEmitChanged()) );
connect( mSGTab.mExternalReferences, SIGNAL(stateChanged(int)),
this, SLOT(slotEmitChanged()) );
connect(mSGTab.labelWarnHTML, SIGNAL(linkActivated(QString)),
SLOT(slotLinkClicked(QString)));
connect( mSGTab.mAlwaysDecrypt, SIGNAL(stateChanged(int)),
this, SLOT(slotEmitChanged()) );
connect( mSGTab.mAutomaticallyImportAttachedKeysCheck, SIGNAL(toggled(bool)),
SLOT(slotEmitChanged()) );
connect( mSGTab.mScamDetection, SIGNAL(toggled(bool)),
SLOT(slotEmitChanged()) );
connect( mSGTab.scamWhiteList, SIGNAL(changed()),
SLOT(slotEmitChanged()) );
}
void SecurityPageGeneralTab::slotLinkClicked( const QString & link )
{
if ( link == QLatin1String( "whatsthis1" ) )
QWhatsThis::showText( QCursor::pos(), mSGTab.mHtmlMailCheck->whatsThis() );
else if (link == QLatin1String( "whatsthis2" ) )
QWhatsThis::showText( QCursor::pos(), mSGTab.mExternalReferences->whatsThis() );
}
void SecurityPage::GeneralTab::doLoadOther()
{
mSGTab.mHtmlMailCheck->setChecked( MessageViewer::GlobalSettings::self()->htmlMail() );
mSGTab.mExternalReferences->setChecked( MessageViewer::GlobalSettings::self()->htmlLoadExternal() );
mSGTab.mAutomaticallyImportAttachedKeysCheck->setChecked(
MessageViewer::GlobalSettings::self()->autoImportKeys() );
mSGTab.mAlwaysDecrypt->setChecked( MessageViewer::GlobalSettings::self()->alwaysDecrypt() );
mSGTab.mScamDetection->setChecked( MessageViewer::GlobalSettings::self()->scamDetectionEnabled());
mSGTab.scamWhiteList->setStringList( MessageViewer::GlobalSettings::self()->scamDetectionWhiteList() );
}
void SecurityPage::GeneralTab::save()
{
if ( MessageViewer::GlobalSettings::self()->htmlMail() != mSGTab.mHtmlMailCheck->isChecked())
{
if (KMessageBox::warningContinueCancel(this, i18n("Changing the global "
"HTML setting will override all folder specific values."), QString(),
KStandardGuiItem::cont(), KStandardGuiItem::cancel(), QLatin1String("htmlMailOverride")) == KMessageBox::Continue)
{
MessageViewer::GlobalSettings::self()->setHtmlMail( mSGTab.mHtmlMailCheck->isChecked() );
foreach( const Akonadi::Collection &collection, kmkernel->allFolders() ) {
KConfigGroup config( KMKernel::self()->config(), MailCommon::FolderCollection::configGroupName(collection) );
config.writeEntry("htmlMailOverride", false);
}
}
}
MessageViewer::GlobalSettings::self()->setHtmlLoadExternal( mSGTab.mExternalReferences->isChecked() );
MessageViewer::GlobalSettings::self()->setAutoImportKeys(
mSGTab.mAutomaticallyImportAttachedKeysCheck->isChecked() );
MessageViewer::GlobalSettings::self()->setAlwaysDecrypt( mSGTab.mAlwaysDecrypt->isChecked() );
MessageViewer::GlobalSettings::self()->setScamDetectionEnabled( mSGTab.mScamDetection->isChecked() );
MessageViewer::GlobalSettings::self()->setScamDetectionWhiteList( mSGTab.scamWhiteList->stringList() );
}
//Adblock
QString SecurityPageAdBlockTab::helpAnchor() const
{
return QString();
}
SecurityPageAdBlockTab::SecurityPageAdBlockTab( QWidget * parent )
: ConfigModuleTab( parent )
{
QHBoxLayout *lay = new QHBoxLayout;
lay->setMargin(0);
mWidget = new MessageViewer::AdBlockSettingWidget;
lay->addWidget(mWidget);
connect(mWidget, SIGNAL(changed(bool)), SLOT(slotEmitChanged()));
setLayout(lay);
}
SecurityPageAdBlockTab::~SecurityPageAdBlockTab()
{
}
void SecurityPageAdBlockTab::save()
{
mWidget->save();
}
void SecurityPageAdBlockTab::doLoadFromGlobalSettings()
{
mWidget->doLoadFromGlobalSettings();
}
void SecurityPageAdBlockTab::doLoadOther()
{
}
void SecurityPageAdBlockTab::doResetToDefaultsOther()
{
mWidget->doResetToDefaultsOther();
}
QString SecurityPage::MDNTab::helpAnchor() const
{
return QString::fromLatin1("configure-security-mdn");
}
SecurityPageMDNTab::SecurityPageMDNTab( QWidget * parent )
: ConfigModuleTab( parent )
{
mUi.setupUi( this );
// "ignore", "ask", "deny", "always send" radiobuttons
mMDNGroup = new QButtonGroup( this );
connect( mMDNGroup, SIGNAL(buttonClicked(int)),
this, SLOT(slotEmitChanged()) );
mMDNGroup->addButton( mUi.radioIgnore, 0 );
mMDNGroup->addButton( mUi.radioAsk, 1 );
mMDNGroup->addButton( mUi.radioDeny, 2 );
mMDNGroup->addButton( mUi.radioAlways, 3 );
// "Original Message quote" radiobuttons
mOrigQuoteGroup = new QButtonGroup( this );
connect( mOrigQuoteGroup, SIGNAL(buttonClicked(int)),
this, SLOT(slotEmitChanged()) );
mOrigQuoteGroup->addButton( mUi.radioNothing, 0 );
mOrigQuoteGroup->addButton( mUi.radioFull, 1 );
mOrigQuoteGroup->addButton( mUi.radioHeaders, 2 );
connect( mUi.mNoMDNsWhenEncryptedCheck, SIGNAL(toggled(bool)), SLOT(slotEmitChanged()) );
connect( mUi.labelWarning, SIGNAL(linkActivated(QString)),
SLOT(slotLinkClicked(QString)) );
}
void SecurityPageMDNTab::slotLinkClicked( const QString & link )
{
if ( link == QLatin1String( "whatsthis-mdn" ) )
QWhatsThis::showText( QCursor::pos(), mUi.radioIgnore->whatsThis() );
}
void SecurityPage::MDNTab::doLoadOther()
{
int num = MessageViewer::GlobalSettings::self()->defaultPolicy();
if ( num < 0 || num >= mMDNGroup->buttons().count() ) num = 0;
mMDNGroup->button(num)->setChecked(true);
num = MessageViewer::GlobalSettings::self()->quoteMessage();
if ( num < 0 || num >= mOrigQuoteGroup->buttons().count() ) num = 0;
mOrigQuoteGroup->button(num)->setChecked(true);
mUi.mNoMDNsWhenEncryptedCheck->setChecked( MessageViewer::GlobalSettings::self()->notSendWhenEncrypted() );
}
void SecurityPage::MDNTab::save()
{
MessageViewer::GlobalSettings::self()->setDefaultPolicy( mMDNGroup->checkedId() );
MessageViewer::GlobalSettings::self()->setQuoteMessage( mOrigQuoteGroup->checkedId() );
MessageViewer::GlobalSettings::self()->setNotSendWhenEncrypted( mUi.mNoMDNsWhenEncryptedCheck->isChecked() );
}
QString SecurityPage::ComposerCryptoTab::helpAnchor() const
{
return QString::fromLatin1("configure-security-composing");
}
SecurityPageComposerCryptoTab::SecurityPageComposerCryptoTab( QWidget * parent )
: ConfigModuleTab( parent )
{
mWidget = new Ui::ComposerCryptoConfiguration;
mWidget->setupUi( this );
connect( mWidget->mEncToSelf, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->mShowEncryptionResult, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->mShowKeyApprovalDlg, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->mAutoEncrypt, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->mNeverEncryptWhenSavingInDrafts, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->mStoreEncrypted, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
}
SecurityPageComposerCryptoTab::~SecurityPageComposerCryptoTab()
{
delete mWidget;
}
void SecurityPage::ComposerCryptoTab::doLoadOther()
{
// If you change default values, sync messagecomposer.cpp too
mWidget->mEncToSelf->setChecked( MessageComposer::MessageComposerSettings::self()->cryptoEncryptToSelf() );
mWidget->mShowEncryptionResult->setChecked( false ); //composer.readBoolEntry( "crypto-show-encryption-result", true ) );
mWidget->mShowEncryptionResult->hide();
mWidget->mShowKeyApprovalDlg->setChecked( MessageComposer::MessageComposerSettings::self()->cryptoShowKeysForApproval() );
mWidget->mAutoEncrypt->setChecked( MessageComposer::MessageComposerSettings::self()->pgpAutoEncrypt() ) ;
mWidget->mNeverEncryptWhenSavingInDrafts->setChecked(
GlobalSettings::self()->neverEncryptDrafts() );
mWidget->mStoreEncrypted->setChecked( GlobalSettings::self()->cryptoStoreEncrypted() );
}
void SecurityPage::ComposerCryptoTab::save()
{
MessageComposer::MessageComposerSettings::self()->setCryptoEncryptToSelf( mWidget->mEncToSelf->isChecked() );
GlobalSettings::self()->setCryptoShowEncryptionResult( mWidget->mShowEncryptionResult->isChecked() );
MessageComposer::MessageComposerSettings::self()->setCryptoShowKeysForApproval( mWidget->mShowKeyApprovalDlg->isChecked() );
MessageComposer::MessageComposerSettings::self()->setPgpAutoEncrypt( mWidget->mAutoEncrypt->isChecked() );
GlobalSettings::self()->setNeverEncryptDrafts( mWidget->mNeverEncryptWhenSavingInDrafts->isChecked() );
GlobalSettings::self()->setCryptoStoreEncrypted( mWidget->mStoreEncrypted->isChecked() );
}
void SecurityPage::ComposerCryptoTab::doLoadFromGlobalSettings()
{
mWidget->mEncToSelf->setChecked( MessageComposer::MessageComposerSettings::self()->cryptoEncryptToSelf() );
mWidget->mShowEncryptionResult->setChecked( GlobalSettings::self()->cryptoShowEncryptionResult() );
mWidget->mShowKeyApprovalDlg->setChecked(MessageComposer::MessageComposerSettings::self()->cryptoShowKeysForApproval() );
mWidget->mAutoEncrypt->setChecked(MessageComposer::MessageComposerSettings::self()->pgpAutoEncrypt() );
mWidget->mNeverEncryptWhenSavingInDrafts->setChecked( GlobalSettings::self()->neverEncryptDrafts() );
mWidget->mStoreEncrypted->setChecked(GlobalSettings::self()->cryptoStoreEncrypted() );
}
QString SecurityPage::WarningTab::helpAnchor() const
{
return QString::fromLatin1("configure-security-warnings");
}
SecurityPageWarningTab::SecurityPageWarningTab( QWidget * parent )
: ConfigModuleTab( parent )
{
mWidget = new Ui::WarningConfiguration;
mWidget->setupUi( this );
mWidget->chiasmusButton->hide();
connect( mWidget->warnGroupBox, SIGNAL(toggled(bool)), SLOT(slotEmitChanged()) );
connect( mWidget->mWarnUnsigned, SIGNAL(toggled(bool)), SLOT(slotEmitChanged()) );
connect( mWidget->warnUnencryptedCB, SIGNAL(toggled(bool)), SLOT(slotEmitChanged()) );
connect( mWidget->warnReceiverNotInCertificateCB, SIGNAL(toggled(bool)), SLOT(slotEmitChanged()) );
connect( mWidget->gnupgButton, SIGNAL(clicked()), SLOT(slotConfigureGnupg()) );
//connect( mWidget->chiasmusButton, SIGNAL(clicked()), SLOT(slotConfigureChiasmus()) );
connect( mWidget->enableAllWarningsPB, SIGNAL(clicked()), SLOT(slotReenableAllWarningsClicked()) );
}
SecurityPageWarningTab::~SecurityPageWarningTab()
{
delete mWidget;
}
void SecurityPage::WarningTab::doLoadFromGlobalSettings()
{
mWidget->warnUnencryptedCB->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarningUnencrypted() );
mWidget->mWarnUnsigned->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarningUnsigned() );
mWidget->warnReceiverNotInCertificateCB->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarnRecvNotInCert() );
// The "-int" part of the key name is because there used to be a separate boolean
// config entry for enabling/disabling. This is done with the single bool value now.
mWidget->warnGroupBox->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarnWhenNearExpire() );
mWidget->mWarnSignKeyExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignKeyNearExpiryThresholdDays() );
mWidget->mWarnSignChainCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignChaincertNearExpiryThresholdDays() );
mWidget->mWarnSignRootCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignRootNearExpiryThresholdDays() );
mWidget->mWarnEncrKeyExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrKeyNearExpiryThresholdDays() );
mWidget->mWarnEncrChainCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrChaincertNearExpiryThresholdDays() );
mWidget->mWarnEncrRootCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrRootNearExpiryThresholdDays() );
}
void SecurityPage::WarningTab::doLoadOther()
{
mWidget->warnUnencryptedCB->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarningUnencrypted() );
mWidget->mWarnUnsigned->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarningUnsigned() );
mWidget->warnReceiverNotInCertificateCB->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarnRecvNotInCert() );
// The "-int" part of the key name is because there used to be a separate boolean
// config entry for enabling/disabling. This is done with the single bool value now.
mWidget->warnGroupBox->setChecked(
MessageComposer::MessageComposerSettings::self()->cryptoWarnWhenNearExpire() );
mWidget->mWarnSignKeyExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignKeyNearExpiryThresholdDays() );
mWidget->mWarnSignKeyExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->mWarnSignChainCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignChaincertNearExpiryThresholdDays() );
mWidget->mWarnSignChainCertExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->mWarnSignRootCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnSignRootNearExpiryThresholdDays() );
mWidget->mWarnSignRootCertExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->mWarnEncrKeyExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrKeyNearExpiryThresholdDays() );
mWidget->mWarnEncrKeyExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->mWarnEncrChainCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrChaincertNearExpiryThresholdDays() );
mWidget->mWarnEncrChainCertExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->mWarnEncrRootCertExpiresSB->setValue(
MessageComposer::MessageComposerSettings::self()->cryptoWarnEncrRootNearExpiryThresholdDays() );
mWidget->mWarnEncrRootCertExpiresSB->setSuffix(ki18np(" day", " days"));
mWidget->enableAllWarningsPB->setEnabled( true );
}
void SecurityPage::WarningTab::save()
{
MessageComposer::MessageComposerSettings::self()->setCryptoWarnRecvNotInCert(
mWidget->warnReceiverNotInCertificateCB->isChecked() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarningUnencrypted(
mWidget->warnUnencryptedCB->isChecked() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarningUnsigned(
mWidget->mWarnUnsigned->isChecked() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnWhenNearExpire(
mWidget->warnGroupBox->isChecked() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnSignKeyNearExpiryThresholdDays(
mWidget->mWarnSignKeyExpiresSB->value() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnSignChaincertNearExpiryThresholdDays(
mWidget->mWarnSignChainCertExpiresSB->value() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnSignRootNearExpiryThresholdDays(
mWidget->mWarnSignRootCertExpiresSB->value() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnEncrKeyNearExpiryThresholdDays(
mWidget->mWarnEncrKeyExpiresSB->value() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnEncrChaincertNearExpiryThresholdDays(
mWidget->mWarnEncrChainCertExpiresSB->value() );
MessageComposer::MessageComposerSettings::self()->setCryptoWarnEncrRootNearExpiryThresholdDays(
mWidget->mWarnEncrRootCertExpiresSB->value() );
}
void SecurityPage::WarningTab::slotReenableAllWarningsClicked()
{
KMessageBox::enableAllMessages();
//Nepomuk composer.
const QString groupName = KPIM::NepomukWarning::nepomukWarningGroupName();
if ( KMKernel::self()->config()->hasGroup( groupName ) ) {
KConfigGroup cfgGroup( KMKernel::self()->config(), groupName );
cfgGroup.deleteGroup();
}
mWidget->enableAllWarningsPB->setEnabled( false );
}
void SecurityPage::WarningTab::slotConfigureGnupg()
{
QPointer<KCMultiDialog> dlg( new KCMultiDialog( this ) );
dlg->addModule( QLatin1String("kleopatra_config_gnupgsystem") );
dlg->exec();
delete dlg;
}
#if 0
void SecurityPage::WarningTab::slotConfigureChiasmus()
{
using namespace Kleo;
// Find Chiasmus backend:
if ( const CryptoBackendFactory * const bf = Kleo::CryptoBackendFactory::instance() )
for ( unsigned int i = 0 ; const CryptoBackend * const b = bf->backend( i ) ; ++i )
if ( b->name() == QLatin1String( "Chiasmus" ) )
if ( CryptoConfig * const c = b->config() ) {
QPointer<CryptoConfigDialog> dlg( new CryptoConfigDialog( c, this ) );
dlg->exec();
delete dlg;
break;
} else {
kWarning() << "Found Chiasmus backend, but there doesn't seem to be a config object available from it.";
}
else
kDebug() << "Skipping" << b->name() << "backend (not \"Chiasmus\")";
else
kDebug() << "Kleo::CryptoBackendFactory::instance() returned NULL!";
}
#endif
////
QString SecurityPage::SMimeTab::helpAnchor() const
{
return QString::fromLatin1("configure-security-smime-validation");
}
SecurityPageSMimeTab::SecurityPageSMimeTab( QWidget * parent )
: ConfigModuleTab( parent )
{
mWidget = new Ui::SMimeConfiguration;
mWidget->setupUi( this );
// Button-group for exclusive radiobuttons
QButtonGroup* bg = new QButtonGroup( this );
bg->addButton( mWidget->CRLRB );
bg->addButton( mWidget->OCSPRB );
// Settings for the keyrequester custom widget
mWidget->OCSPResponderSignature->setAllowedKeys(
Kleo::KeySelectionDialog::SMIMEKeys
| Kleo::KeySelectionDialog::TrustedKeys
| Kleo::KeySelectionDialog::ValidKeys
| Kleo::KeySelectionDialog::SigningKeys
| Kleo::KeySelectionDialog::PublicKeys );
mWidget->OCSPResponderSignature->setMultipleKeysEnabled( false );
mConfig = Kleo::CryptoBackendFactory::instance()->config();
connect( mWidget->CRLRB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->OCSPRB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->OCSPResponderURL, SIGNAL(textChanged(QString)), this, SLOT(slotEmitChanged()) );
connect( mWidget->OCSPResponderSignature, SIGNAL(changed()), this, SLOT(slotEmitChanged()) );
connect( mWidget->doNotCheckCertPolicyCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->neverConsultCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->fetchMissingCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->ignoreServiceURLCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->ignoreHTTPDPCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->disableHTTPCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->honorHTTPProxyRB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->useCustomHTTPProxyRB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->customHTTPProxy, SIGNAL(textChanged(QString)), this, SLOT(slotEmitChanged()) );
connect( mWidget->ignoreLDAPDPCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->disableLDAPCB, SIGNAL(toggled(bool)), this, SLOT(slotEmitChanged()) );
connect( mWidget->customLDAPProxy, SIGNAL(textChanged(QString)), this, SLOT(slotEmitChanged()) );
connect( mWidget->disableHTTPCB, SIGNAL(toggled(bool)),
this, SLOT(slotUpdateHTTPActions()) );
connect( mWidget->ignoreHTTPDPCB, SIGNAL(toggled(bool)),
this, SLOT(slotUpdateHTTPActions()) );
// Button-group for exclusive radiobuttons
QButtonGroup* bgHTTPProxy = new QButtonGroup( this );
bgHTTPProxy->addButton( mWidget->honorHTTPProxyRB );
bgHTTPProxy->addButton( mWidget->useCustomHTTPProxyRB );
QDBusConnection::sessionBus().connect(QString(), QString(), QLatin1String("org.kde.kleo.CryptoConfig"), QLatin1String("changed"),this, SLOT(load()) );
}
SecurityPageSMimeTab::~SecurityPageSMimeTab()
{
delete mWidget;
}
static void disableDirmngrWidget( QWidget* w )
{
w->setEnabled( false );
w->setWhatsThis( i18n( "This option requires dirmngr >= 0.9.0" ) );
}
static void initializeDirmngrCheckbox( QCheckBox* cb, Kleo::CryptoConfigEntry* entry )
{
if ( entry )
cb->setChecked( entry->boolValue() );
else
disableDirmngrWidget( cb );
}
struct SMIMECryptoConfigEntries {
SMIMECryptoConfigEntries( Kleo::CryptoConfig* config )
: mConfig( config ) {
// Checkboxes
mCheckUsingOCSPConfigEntry = configEntry( QLatin1String("gpgsm"), QLatin1String("Security"), QLatin1String("enable-ocsp"), Kleo::CryptoConfigEntry::ArgType_None, false );
mEnableOCSPsendingConfigEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("OCSP"), QLatin1String("allow-ocsp"), Kleo::CryptoConfigEntry::ArgType_None, false );
mDoNotCheckCertPolicyConfigEntry = configEntry( QLatin1String("gpgsm"), QLatin1String("Security"), QLatin1String("disable-policy-checks"), Kleo::CryptoConfigEntry::ArgType_None, false );
mNeverConsultConfigEntry = configEntry( QLatin1String("gpgsm"), QLatin1String("Security"), QLatin1String("disable-crl-checks"), Kleo::CryptoConfigEntry::ArgType_None, false );
mFetchMissingConfigEntry = configEntry( QLatin1String("gpgsm"), QLatin1String("Security"), QLatin1String("auto-issuer-key-retrieve"), Kleo::CryptoConfigEntry::ArgType_None, false );
// dirmngr-0.9.0 options
mIgnoreServiceURLEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("OCSP"), QLatin1String("ignore-ocsp-service-url"), Kleo::CryptoConfigEntry::ArgType_None, false );
mIgnoreHTTPDPEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("HTTP"), QLatin1String("ignore-http-dp"), Kleo::CryptoConfigEntry::ArgType_None, false );
mDisableHTTPEntry = configEntry(QLatin1String( "dirmngr"), QLatin1String("HTTP"), QLatin1String("disable-http"), Kleo::CryptoConfigEntry::ArgType_None, false );
mHonorHTTPProxy = configEntry( QLatin1String("dirmngr"), QLatin1String("HTTP"), QLatin1String("honor-http-proxy"), Kleo::CryptoConfigEntry::ArgType_None, false );
mIgnoreLDAPDPEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("LDAP"), QLatin1String("ignore-ldap-dp"), Kleo::CryptoConfigEntry::ArgType_None, false );
mDisableLDAPEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("LDAP"), QLatin1String("disable-ldap"), Kleo::CryptoConfigEntry::ArgType_None, false );
// Other widgets
mOCSPResponderURLConfigEntry = configEntry( QLatin1String("dirmngr"), QLatin1String("OCSP"), QLatin1String("ocsp-responder"), Kleo::CryptoConfigEntry::ArgType_String, false );
mOCSPResponderSignature = configEntry( QLatin1String("dirmngr"), QLatin1String("OCSP"), QLatin1String("ocsp-signer"), Kleo::CryptoConfigEntry::ArgType_String, false );
mCustomHTTPProxy = configEntry( QLatin1String("dirmngr"), QLatin1String("HTTP"), QLatin1String("http-proxy"), Kleo::CryptoConfigEntry::ArgType_String, false );
mCustomLDAPProxy = configEntry( QLatin1String("dirmngr"), QLatin1String("LDAP"), QLatin1String("ldap-proxy"), Kleo::CryptoConfigEntry::ArgType_String, false );
}
Kleo::CryptoConfigEntry* configEntry(const QString &componentName,
const QString &groupName,
const QString &entryName,
int argType,
bool isList );
// Checkboxes
Kleo::CryptoConfigEntry* mCheckUsingOCSPConfigEntry;
Kleo::CryptoConfigEntry* mEnableOCSPsendingConfigEntry;
Kleo::CryptoConfigEntry* mDoNotCheckCertPolicyConfigEntry;
Kleo::CryptoConfigEntry* mNeverConsultConfigEntry;
Kleo::CryptoConfigEntry* mFetchMissingConfigEntry;
Kleo::CryptoConfigEntry* mIgnoreServiceURLEntry;
Kleo::CryptoConfigEntry* mIgnoreHTTPDPEntry;
Kleo::CryptoConfigEntry* mDisableHTTPEntry;
Kleo::CryptoConfigEntry* mHonorHTTPProxy;
Kleo::CryptoConfigEntry* mIgnoreLDAPDPEntry;
Kleo::CryptoConfigEntry* mDisableLDAPEntry;
// Other widgets
Kleo::CryptoConfigEntry* mOCSPResponderURLConfigEntry;
Kleo::CryptoConfigEntry* mOCSPResponderSignature;
Kleo::CryptoConfigEntry* mCustomHTTPProxy;
Kleo::CryptoConfigEntry* mCustomLDAPProxy;
Kleo::CryptoConfig* mConfig;
};
void SecurityPage::SMimeTab::doLoadOther()
{
if ( !mConfig ) {
setEnabled( false );
return;
}
// Force re-parsing gpgconf data, in case e.g. kleopatra or "configure backend" was used
// (which ends up calling us via D-Bus)
mConfig->clear();
// Create config entries
// Don't keep them around, they'll get deleted by clear(), which could be
// done by the "configure backend" button even before we save().
SMIMECryptoConfigEntries e( mConfig );
// Initialize GUI items from the config entries
if ( e.mCheckUsingOCSPConfigEntry ) {
bool b = e.mCheckUsingOCSPConfigEntry->boolValue();
mWidget->OCSPRB->setChecked( b );
mWidget->CRLRB->setChecked( !b );
mWidget->OCSPGroupBox->setEnabled( b );
} else {
mWidget->OCSPGroupBox->setEnabled( false );
}
if ( e.mDoNotCheckCertPolicyConfigEntry )
mWidget->doNotCheckCertPolicyCB->setChecked( e.mDoNotCheckCertPolicyConfigEntry->boolValue() );
if ( e.mNeverConsultConfigEntry )
mWidget->neverConsultCB->setChecked( e.mNeverConsultConfigEntry->boolValue() );
if ( e.mFetchMissingConfigEntry )
mWidget->fetchMissingCB->setChecked( e.mFetchMissingConfigEntry->boolValue() );
if ( e.mOCSPResponderURLConfigEntry )
mWidget->OCSPResponderURL->setText( e.mOCSPResponderURLConfigEntry->stringValue() );
if ( e.mOCSPResponderSignature ) {
mWidget->OCSPResponderSignature->setFingerprint( e.mOCSPResponderSignature->stringValue() );
}
// dirmngr-0.9.0 options
initializeDirmngrCheckbox( mWidget->ignoreServiceURLCB, e.mIgnoreServiceURLEntry );
initializeDirmngrCheckbox( mWidget->ignoreHTTPDPCB, e.mIgnoreHTTPDPEntry );
initializeDirmngrCheckbox( mWidget->disableHTTPCB, e.mDisableHTTPEntry );
initializeDirmngrCheckbox( mWidget->ignoreLDAPDPCB, e.mIgnoreLDAPDPEntry );
initializeDirmngrCheckbox( mWidget->disableLDAPCB, e.mDisableLDAPEntry );
if ( e.mCustomHTTPProxy ) {
QString systemProxy = QString::fromLocal8Bit( qgetenv( "http_proxy" ) );
if ( systemProxy.isEmpty() )
systemProxy = i18n( "no proxy" );
mWidget->systemHTTPProxy->setText( i18n( "(Current system setting: %1)", systemProxy ) );
bool honor = e.mHonorHTTPProxy && e.mHonorHTTPProxy->boolValue();
mWidget->honorHTTPProxyRB->setChecked( honor );
mWidget->useCustomHTTPProxyRB->setChecked( !honor );
mWidget->customHTTPProxy->setText( e.mCustomHTTPProxy->stringValue() );
} else {
disableDirmngrWidget( mWidget->honorHTTPProxyRB );
disableDirmngrWidget( mWidget->useCustomHTTPProxyRB );
disableDirmngrWidget( mWidget->systemHTTPProxy );
disableDirmngrWidget( mWidget->customHTTPProxy );
}
if ( e.mCustomLDAPProxy )
mWidget->customLDAPProxy->setText( e.mCustomLDAPProxy->stringValue() );
else {
disableDirmngrWidget( mWidget->customLDAPProxy );
disableDirmngrWidget( mWidget->customLDAPLabel );
}
slotUpdateHTTPActions();
}
void SecurityPage::SMimeTab::slotUpdateHTTPActions()
{
mWidget->ignoreHTTPDPCB->setEnabled( !mWidget->disableHTTPCB->isChecked() );
// The proxy settings only make sense when "Ignore HTTP CRL DPs of certificate" is checked.
bool enableProxySettings = !mWidget->disableHTTPCB->isChecked()
&& mWidget->ignoreHTTPDPCB->isChecked();
mWidget->systemHTTPProxy->setEnabled( enableProxySettings );
mWidget->useCustomHTTPProxyRB->setEnabled( enableProxySettings );
mWidget->honorHTTPProxyRB->setEnabled( enableProxySettings );
mWidget->customHTTPProxy->setEnabled( enableProxySettings && mWidget->useCustomHTTPProxyRB->isChecked());
if ( !mWidget->useCustomHTTPProxyRB->isChecked() &&
!mWidget->honorHTTPProxyRB->isChecked() )
mWidget->honorHTTPProxyRB->setChecked( true );
}
static void saveCheckBoxToKleoEntry( QCheckBox* cb, Kleo::CryptoConfigEntry* entry )
{
const bool b = cb->isChecked();
if ( entry && entry->boolValue() != b )
entry->setBoolValue( b );
}
void SecurityPage::SMimeTab::save()
{
if ( !mConfig ) {
return;
}
// Create config entries
// Don't keep them around, they'll get deleted by clear(), which could be done by the
// "configure backend" button.
SMIMECryptoConfigEntries e( mConfig );
bool b = mWidget->OCSPRB->isChecked();
if ( e.mCheckUsingOCSPConfigEntry && e.mCheckUsingOCSPConfigEntry->boolValue() != b )
e.mCheckUsingOCSPConfigEntry->setBoolValue( b );
// Set allow-ocsp together with enable-ocsp
if ( e.mEnableOCSPsendingConfigEntry && e.mEnableOCSPsendingConfigEntry->boolValue() != b )
e.mEnableOCSPsendingConfigEntry->setBoolValue( b );
saveCheckBoxToKleoEntry( mWidget->doNotCheckCertPolicyCB, e.mDoNotCheckCertPolicyConfigEntry );
saveCheckBoxToKleoEntry( mWidget->neverConsultCB, e.mNeverConsultConfigEntry );
saveCheckBoxToKleoEntry( mWidget->fetchMissingCB, e.mFetchMissingConfigEntry );
QString txt = mWidget->OCSPResponderURL->text();
if ( e.mOCSPResponderURLConfigEntry && e.mOCSPResponderURLConfigEntry->stringValue() != txt )
e.mOCSPResponderURLConfigEntry->setStringValue( txt );
txt = mWidget->OCSPResponderSignature->fingerprint();
if ( e.mOCSPResponderSignature && e.mOCSPResponderSignature->stringValue() != txt ) {
e.mOCSPResponderSignature->setStringValue( txt );
}
//dirmngr-0.9.0 options
saveCheckBoxToKleoEntry( mWidget->ignoreServiceURLCB, e.mIgnoreServiceURLEntry );
saveCheckBoxToKleoEntry( mWidget->ignoreHTTPDPCB, e.mIgnoreHTTPDPEntry );
saveCheckBoxToKleoEntry( mWidget->disableHTTPCB, e.mDisableHTTPEntry );
saveCheckBoxToKleoEntry( mWidget->ignoreLDAPDPCB, e.mIgnoreLDAPDPEntry );
saveCheckBoxToKleoEntry( mWidget->disableLDAPCB, e.mDisableLDAPEntry );
if ( e.mCustomHTTPProxy ) {
const bool honor = mWidget->honorHTTPProxyRB->isChecked();
if ( e.mHonorHTTPProxy && e.mHonorHTTPProxy->boolValue() != honor )
e.mHonorHTTPProxy->setBoolValue( honor );
QString chosenProxy = mWidget->customHTTPProxy->text();
if ( chosenProxy != e.mCustomHTTPProxy->stringValue() )
e.mCustomHTTPProxy->setStringValue( chosenProxy );
}
txt = mWidget->customLDAPProxy->text();
if ( e.mCustomLDAPProxy && e.mCustomLDAPProxy->stringValue() != txt )
e.mCustomLDAPProxy->setStringValue( mWidget->customLDAPProxy->text() );
mConfig->sync( true );
}
Kleo::CryptoConfigEntry* SMIMECryptoConfigEntries::configEntry( const QString &componentName,
const QString &groupName,
const QString &entryName,
int /*Kleo::CryptoConfigEntry::ArgType*/ argType,
bool isList )
{
Kleo::CryptoConfigEntry* entry = mConfig->entry( componentName, groupName, entryName );
if ( !entry ) {
kWarning() << QString::fromLatin1("Backend error: gpgconf doesn't seem to know the entry for %1/%2/%3" ).arg( componentName, groupName, entryName );
return 0;
}
if( entry->argType() != argType || entry->isList() != isList ) {
kWarning() << QString::fromLatin1("Backend error: gpgconf has wrong type for %1/%2/%3: %4 %5" ).arg( componentName, groupName, entryName ).arg( entry->argType() ).arg( entry->isList() );
return 0;
}
return entry;
}

@ -0,0 +1,181 @@
/*
Copyright (c) 2013 Montel Laurent <montel@kde.org>
This program is free software; you can redistribute it and/or modify it
under the terms of the GNU General Public License, version 2, as
published by the Free Software Foundation.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef CONFIGURESECURITYPAGE_H
#define CONFIGURESECURITYPAGE_H
#include "kmail_export.h"
#include "configuredialog_p.h"
#include "ui_securitypagegeneraltab.h"
#include "ui_securitypagemdntab.h"
#include "ui_composercryptoconfiguration.h"
class QButtonGroup;
namespace MessageViewer {
class AdBlockSettingWidget;
}
class SecurityPageGeneralTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageGeneralTab( QWidget * parent=0 );
QString helpAnchor() const;
void save();
private:
//virtual void doLoadFromGlobalSettings();
void doLoadOther();
//FIXME virtual void doResetToDefaultsOther();
private:
Ui_SecurityPageGeneralTab mSGTab;
private slots:
void slotLinkClicked( const QString & link );
};
class SecurityPageMDNTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageMDNTab( QWidget * parent=0 );
QString helpAnchor() const;
void save();
private:
void doLoadOther();
private:
QButtonGroup *mMDNGroup;
QButtonGroup *mOrigQuoteGroup;
Ui_SecurityPageMDNTab mUi;
private slots:
void slotLinkClicked( const QString & link );
};
class SecurityPageComposerCryptoTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageComposerCryptoTab( QWidget * parent=0 );
~SecurityPageComposerCryptoTab();
QString helpAnchor() const;
void save();
private:
void doLoadFromGlobalSettings();
void doLoadOther();
//FIXME virtual void doResetToDefaultsOther();
private:
Ui::ComposerCryptoConfiguration* mWidget;
};
class SecurityPageWarningTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageWarningTab( QWidget * parent=0 );
~SecurityPageWarningTab();
QString helpAnchor() const;
void save();
private Q_SLOTS:
void slotReenableAllWarningsClicked();
void slotConfigureGnupg();
//void slotConfigureChiasmus();
private:
void doLoadFromGlobalSettings();
void doLoadOther();
//FIXME virtual void doResetToDefaultsOther();
private:
Ui::WarningConfiguration* mWidget;
};
class SecurityPageSMimeTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageSMimeTab( QWidget * parent=0 );
~SecurityPageSMimeTab();
QString helpAnchor() const;
void save();
private slots:
void slotUpdateHTTPActions();
private:
//virtual void doLoadFromGlobalSettings();
void doLoadOther();
//FIXME virtual void doResetToDefaultsOther();
private:
Ui::SMimeConfiguration* mWidget;
Kleo::CryptoConfig* mConfig;
};
class SecurityPageAdBlockTab : public ConfigModuleTab {
Q_OBJECT
public:
explicit SecurityPageAdBlockTab( QWidget * parent=0 );
~SecurityPageAdBlockTab();
QString helpAnchor() const;
void save();
private:
void doLoadFromGlobalSettings();
void doLoadOther();
void doResetToDefaultsOther();
private:
MessageViewer::AdBlockSettingWidget *mWidget;
};
class KMAIL_EXPORT SecurityPage : public ConfigModuleWithTabs {
Q_OBJECT
public:
explicit SecurityPage( const KComponentData &instance, QWidget *parent=0 );
QString helpAnchor() const;
typedef SecurityPageGeneralTab GeneralTab;
typedef SecurityPageMDNTab MDNTab;
typedef SecurityPageComposerCryptoTab ComposerCryptoTab;
typedef SecurityPageWarningTab WarningTab;
typedef SecurityPageSMimeTab SMimeTab;
private:
GeneralTab *mGeneralTab;
ComposerCryptoTab *mComposerCryptoTab;
WarningTab *mWarningTab;
SMimeTab *mSMimeTab;
SecurityPageAdBlockTab *mSAdBlockTab;
};
#endif // CONFIGURESECURITYPAGE_H

@ -24,6 +24,7 @@
#include "configuredialog/configuredialog.h"
#include "configuredialog/configuredialog_p.h"
#include "configuredialog/configuremiscpage.h"
#include "configuredialog/configuresecuritypage.h"
#include "identity/identitypage.h"
#include <kcmodule.h>
#include <kcomponentdata.h>

Loading…
Cancel
Save