You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
601 lines
25 KiB
601 lines
25 KiB
/* -*- mode: C++; c-file-style: "gnu" -*- |
|
identitydialog.cpp |
|
|
|
This file is part of KMail, the KDE mail client. |
|
Copyright (c) 2002 Marc Mutz <mutz@kde.org> |
|
|
|
KMail 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. |
|
|
|
KMail 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
|
|
In addition, as a special exception, the copyright holders give |
|
permission to link the code of this program with any edition of |
|
the Qt library by Trolltech AS, Norway (or with modified versions |
|
of Qt that use the same license as Qt), and distribute linked |
|
combinations including the two. You must obey the GNU General |
|
Public License in all respects for all of the code used other than |
|
Qt. If you modify this file, you may extend this exception to |
|
your version of the file, but you are not obligated to do so. If |
|
you do not wish to do so, delete this exception statement from |
|
your version. |
|
*/ |
|
|
|
#ifdef HAVE_CONFIG_H |
|
#include <config.h> |
|
#endif |
|
|
|
#include "identitydialog.h" |
|
|
|
// other KMail headers: |
|
#include "signatureconfigurator.h" |
|
#include "kmfoldercombobox.h" |
|
#include "kmfoldermgr.h" |
|
#include "transportmanager.h" |
|
#include "kmkernel.h" |
|
#include "dictionarycombobox.h" |
|
|
|
|
|
// other kdepim headers: |
|
// libkdepim |
|
#include <libkpimidentities/identity.h> |
|
#include <libkdepim/addresseelineedit.h> |
|
// libkleopatra: |
|
#include <ui/keyrequester.h> |
|
#include <kleo/cryptobackendfactory.h> |
|
|
|
// other KDE headers: |
|
#include <klocale.h> |
|
#include <kmessagebox.h> |
|
#include <kconfig.h> |
|
|
|
// Qt headers: |
|
#include <qtabwidget.h> |
|
#include <qlabel.h> |
|
#include <qwhatsthis.h> |
|
#include <qlayout.h> |
|
#include <qpushbutton.h> |
|
#include <qcheckbox.h> |
|
#include <qcombobox.h> |
|
|
|
// other headers: |
|
#include <gpgmepp/key.h> |
|
#include <iterator> |
|
#include <algorithm> |
|
|
|
static const Kleo::CryptoMessageFormat cryptoMessageFormats[] = { |
|
Kleo::AutoFormat, |
|
Kleo::InlineOpenPGPFormat, |
|
Kleo::OpenPGPMIMEFormat, |
|
Kleo::SMIMEFormat, |
|
Kleo::SMIMEOpaqueFormat, |
|
}; |
|
static const int numCryptoMessageFormats = sizeof cryptoMessageFormats / sizeof *cryptoMessageFormats ; |
|
|
|
static inline Kleo::CryptoMessageFormat cb2format( int idx ) { |
|
return cryptoMessageFormats[ idx >= 0 || idx < numCryptoMessageFormats ? idx : 0 ]; |
|
} |
|
|
|
static inline int format2cb( Kleo::CryptoMessageFormat f ) { |
|
for ( int i = 0 ; i < numCryptoMessageFormats ; ++i ) |
|
if ( f == cryptoMessageFormats[i] ) |
|
return i; |
|
return 0; |
|
} |
|
|
|
namespace KMail { |
|
|
|
IdentityDialog::IdentityDialog( QWidget * parent, const char * name ) |
|
: KDialogBase( Plain, i18n("Edit Identity"), Ok|Cancel|Help, Ok, |
|
parent, name ) |
|
{ |
|
// tmp. vars: |
|
QWidget * tab; |
|
QLabel * label; |
|
int row; |
|
QGridLayout * glay; |
|
QString msg; |
|
|
|
// |
|
// Tab Widget: General |
|
// |
|
row = -1; |
|
QVBoxLayout * vlay = new QVBoxLayout( plainPage(), 0, spacingHint() ); |
|
QTabWidget *tabWidget = new QTabWidget( plainPage(), "config-identity-tab" ); |
|
vlay->addWidget( tabWidget ); |
|
|
|
tab = new QWidget( tabWidget ); |
|
tabWidget->addTab( tab, i18n("&General") ); |
|
glay = new QGridLayout( tab, 4, 2, marginHint(), spacingHint() ); |
|
glay->setRowStretch( 3, 1 ); |
|
glay->setColStretch( 1, 1 ); |
|
|
|
// "Name" line edit and label: |
|
++row; |
|
mNameEdit = new KLineEdit( tab ); |
|
glay->addWidget( mNameEdit, row, 1 ); |
|
label = new QLabel( mNameEdit, i18n("&Your name:"), tab ); |
|
glay->addWidget( label, row, 0 ); |
|
msg = i18n("<qt><h3>Your name</h3>" |
|
"<p>This field should contain your name as you would like " |
|
"it to appear in the email header that is sent out;</p>" |
|
"<p>if you leave this blank your real name will not " |
|
"appear, only the email address.</p></qt>"); |
|
QWhatsThis::add( label, msg ); |
|
QWhatsThis::add( mNameEdit, msg ); |
|
|
|
// "Organization" line edit and label: |
|
++row; |
|
mOrganizationEdit = new KLineEdit( tab ); |
|
glay->addWidget( mOrganizationEdit, row, 1 ); |
|
label = new QLabel( mOrganizationEdit, i18n("Organi&zation:"), tab ); |
|
glay->addWidget( label, row, 0 ); |
|
msg = i18n("<qt><h3>Organization</h3>" |
|
"<p>This field should have the name of your organization " |
|
"if you'd like it to be shown in the email header that " |
|
"is sent out.</p>" |
|
"<p>It is safe (and normal) to leave this blank.</p></qt>"); |
|
QWhatsThis::add( label, msg ); |
|
QWhatsThis::add( mOrganizationEdit, msg ); |
|
|
|
// "Email Address" line edit and label: |
|
// (row 3: spacer) |
|
++row; |
|
mEmailEdit = new KLineEdit( tab ); |
|
glay->addWidget( mEmailEdit, row, 1 ); |
|
label = new QLabel( mEmailEdit, i18n("&Email address:"), tab ); |
|
glay->addWidget( label, row, 0 ); |
|
msg = i18n("<qt><h3>Email address</h3>" |
|
"<p>This field should have your full email address.</p>" |
|
"<p>If you leave this blank, or get it wrong, people " |
|
"will have trouble replying to you.</p></qt>"); |
|
QWhatsThis::add( label, msg ); |
|
QWhatsThis::add( mEmailEdit, msg ); |
|
|
|
// |
|
// Tab Widget: Cryptography |
|
// |
|
row = -1; |
|
mCryptographyTab = tab = new QWidget( tabWidget ); |
|
tabWidget->addTab( tab, i18n("Cryptograph&y") ); |
|
glay = new QGridLayout( tab, 6, 2, marginHint(), spacingHint() ); |
|
glay->setColStretch( 1, 1 ); |
|
|
|
// "OpenPGP Signature Key" requester and label: |
|
++row; |
|
mPGPSigningKeyRequester = new Kleo::SigningKeyRequester( false, Kleo::SigningKeyRequester::OpenPGP, tab ); |
|
mPGPSigningKeyRequester->dialogButton()->setText( i18n("Chang&e...") ); |
|
mPGPSigningKeyRequester->setDialogCaption( i18n("Your OpenPGP Signature Key") ); |
|
msg = i18n("Select the OpenPGP key which should be used to " |
|
"digitally sign your messages."); |
|
mPGPSigningKeyRequester->setDialogMessage( msg ); |
|
|
|
msg = i18n("<qt><p>The OpenPGP key you choose here will be used " |
|
"to digitally sign messages. You can also use GnuPG keys.</p>" |
|
"<p>You can leave this blank, but KMail will not be able " |
|
"to digitally sign emails using OpenPGP; " |
|
"normal mail functions will not be affected.</p>" |
|
"<p>You can find out more about keys at <a>http://www.gnupg.org</a></p></qt>"); |
|
|
|
label = new QLabel( mPGPSigningKeyRequester, i18n("OpenPGP signing key:"), tab ); |
|
QWhatsThis::add( mPGPSigningKeyRequester, msg ); |
|
QWhatsThis::add( label, msg ); |
|
|
|
glay->addWidget( label, row, 0 ); |
|
glay->addWidget( mPGPSigningKeyRequester, row, 1 ); |
|
|
|
|
|
// "OpenPGP Encryption Key" requester and label: |
|
++row; |
|
mPGPEncryptionKeyRequester = new Kleo::EncryptionKeyRequester( false, Kleo::EncryptionKeyRequester::OpenPGP, tab ); |
|
mPGPEncryptionKeyRequester->dialogButton()->setText( i18n("Chang&e...") ); |
|
mPGPEncryptionKeyRequester->setDialogCaption( i18n("Your OpenPGP Encryption Key") ); |
|
msg = i18n("Select the OpenPGP key which should be used when encrypting " |
|
"to yourself and for the \"Attach My Public Key\" " |
|
"feature in the composer."); |
|
mPGPEncryptionKeyRequester->setDialogMessage( msg ); |
|
|
|
msg = i18n("<qt><p>The OpenPGP key you choose here will be used " |
|
"to encrypt messages to yourself and for the \"Attach My Public Key\" " |
|
"feature in the composer. You can also use GnuPG keys.</p>" |
|
"<p>You can leave this blank, but KMail will not be able " |
|
"to encrypt copies of outgoing messages to you using OpenPGP; " |
|
"normal mail functions will not be affected.</p>" |
|
"<p>You can find out more about keys at <a>http://www.gnupg.org</a></qt>"); |
|
label = new QLabel( mPGPEncryptionKeyRequester, i18n("OpenPGP encryption key:"), tab ); |
|
QWhatsThis::add( mPGPEncryptionKeyRequester, msg ); |
|
QWhatsThis::add( label, msg ); |
|
|
|
glay->addWidget( label, row, 0 ); |
|
glay->addWidget( mPGPEncryptionKeyRequester, row, 1 ); |
|
|
|
|
|
// "S/MIME Signature Key" requester and label: |
|
++row; |
|
mSMIMESigningKeyRequester = new Kleo::SigningKeyRequester( false, Kleo::SigningKeyRequester::SMIME, tab ); |
|
mSMIMESigningKeyRequester->dialogButton()->setText( i18n("Chang&e...") ); |
|
mSMIMESigningKeyRequester->setDialogCaption( i18n("Your S/MIME Signature Certificate") ); |
|
msg = i18n("Select the S/MIME certificate which should be used to " |
|
"digitally sign your messages."); |
|
mSMIMESigningKeyRequester->setDialogMessage( msg ); |
|
|
|
msg = i18n("<qt><p>The S/MIME (X.509) certificate you choose here will be used " |
|
"to digitally sign messages.</p>" |
|
"<p>You can leave this blank, but KMail will not be able " |
|
"to digitally sign emails using S/MIME; " |
|
"normal mail functions will not be affected.</p></qt>"); |
|
label = new QLabel( mSMIMESigningKeyRequester, i18n("S/MIME signing certificate:"), tab ); |
|
QWhatsThis::add( mSMIMESigningKeyRequester, msg ); |
|
QWhatsThis::add( label, msg ); |
|
glay->addWidget( label, row, 0 ); |
|
glay->addWidget( mSMIMESigningKeyRequester, row, 1 ); |
|
|
|
const Kleo::CryptoBackend::Protocol * smimeProtocol |
|
= Kleo::CryptoBackendFactory::instance()->smime(); |
|
|
|
label->setEnabled( smimeProtocol ); |
|
mSMIMESigningKeyRequester->setEnabled( smimeProtocol ); |
|
|
|
// "S/MIME Encryption Key" requester and label: |
|
++row; |
|
mSMIMEEncryptionKeyRequester = new Kleo::EncryptionKeyRequester( false, Kleo::EncryptionKeyRequester::SMIME, tab ); |
|
mSMIMEEncryptionKeyRequester->dialogButton()->setText( i18n("Chang&e...") ); |
|
mSMIMEEncryptionKeyRequester->setDialogCaption( i18n("Your S/MIME Encryption Certificate") ); |
|
msg = i18n("Select the S/MIME certificate which should be used when encrypting " |
|
"to yourself and for the \"Attach My Certificate\" " |
|
"feature in the composer."); |
|
mSMIMEEncryptionKeyRequester->setDialogMessage( msg ); |
|
|
|
msg = i18n("<qt><p>The S/MIME certificate you choose here will be used " |
|
"to encrypt messages to yourself and for the \"Attach My Certificate\" " |
|
"feature in the composer.</p>" |
|
"<p>You can leave this blank, but KMail will not be able " |
|
"to encrypt copies of outgoing messages to you using S/MIME; " |
|
"normal mail functions will not be affected.</p></qt>"); |
|
label = new QLabel( mSMIMEEncryptionKeyRequester, i18n("S/MIME encryption certificate:"), tab ); |
|
QWhatsThis::add( mSMIMEEncryptionKeyRequester, msg ); |
|
QWhatsThis::add( label, msg ); |
|
|
|
glay->addWidget( label, row, 0 ); |
|
glay->addWidget( mSMIMEEncryptionKeyRequester, row, 1 ); |
|
|
|
label->setEnabled( smimeProtocol ); |
|
mSMIMEEncryptionKeyRequester->setEnabled( smimeProtocol ); |
|
|
|
// "Preferred Crypto Message Format" combobox and label: |
|
++row; |
|
mPreferredCryptoMessageFormat = new QComboBox( false, tab ); |
|
QStringList l; |
|
l << Kleo::cryptoMessageFormatToLabel( Kleo::AutoFormat ) |
|
<< Kleo::cryptoMessageFormatToLabel( Kleo::InlineOpenPGPFormat ) |
|
<< Kleo::cryptoMessageFormatToLabel( Kleo::OpenPGPMIMEFormat ) |
|
<< Kleo::cryptoMessageFormatToLabel( Kleo::SMIMEFormat ) |
|
<< Kleo::cryptoMessageFormatToLabel( Kleo::SMIMEOpaqueFormat ); |
|
mPreferredCryptoMessageFormat->insertStringList( l ); |
|
label = new QLabel( mPreferredCryptoMessageFormat, |
|
i18n("Preferred crypto message format:"), tab ); |
|
|
|
glay->addWidget( label, row, 0 ); |
|
glay->addWidget( mPreferredCryptoMessageFormat, row, 1 ); |
|
|
|
++row; |
|
glay->setRowStretch( row, 1 ); |
|
|
|
// |
|
// Tab Widget: Advanced |
|
// |
|
row = -1; |
|
tab = new QWidget( tabWidget ); |
|
tabWidget->addTab( tab, i18n("&Advanced") ); |
|
glay = new QGridLayout( tab, 7, 2, marginHint(), spacingHint() ); |
|
// the last (empty) row takes all the remaining space |
|
glay->setRowStretch( 7-1, 1 ); |
|
glay->setColStretch( 1, 1 ); |
|
|
|
// "Reply-To Address" line edit and label: |
|
++row; |
|
mReplyToEdit = new KPIM::AddresseeLineEdit( tab, true, "mReplyToEdit" ); |
|
glay->addWidget( mReplyToEdit, row, 1 ); |
|
label = new QLabel ( mReplyToEdit, i18n("&Reply-To address:"), tab); |
|
glay->addWidget( label , row, 0 ); |
|
msg = i18n("<qt><h3>Reply-To addresses</h3>" |
|
"<p>This sets the <tt>Reply-to:</tt> header to contain a " |
|
"different email address to the normal <tt>From:</tt> " |
|
"address.</p>" |
|
"<p>This can be useful when you have a group of people " |
|
"working together in similar roles. For example, you " |
|
"might want any emails sent to have your email in the " |
|
"<tt>From:</tt> field, but any responses to go to " |
|
"a group address.</p>" |
|
"<p>If in doubt, leave this field blank.</p></qt>"); |
|
QWhatsThis::add( label, msg ); |
|
QWhatsThis::add( mReplyToEdit, msg ); |
|
|
|
// "BCC addresses" line edit and label: |
|
++row; |
|
mBccEdit = new KPIM::AddresseeLineEdit( tab, true, "mBccEdit" ); |
|
glay->addWidget( mBccEdit, row, 1 ); |
|
label = new QLabel( mBccEdit, i18n("&BCC addresses:"), tab ); |
|
glay->addWidget( label, row, 0 ); |
|
msg = i18n("<qt><h3>BCC (Blind Carbon Copy) addresses</h3>" |
|
"<p>The addresses that you enter here will be added to each " |
|
"outgoing mail that is sent with this identity. They will not " |
|
"be visible to other recipients.</p>" |
|
"<p>This is commonly used to send a copy of each sent message to " |
|
"another account of yours.</p>" |
|
"<p>To specify more than one address, use commas to separate " |
|
"the list of BCC recipients.</p>" |
|
"<p>If in doubt, leave this field blank.</p></qt>"); |
|
QWhatsThis::add( label, msg ); |
|
QWhatsThis::add( mBccEdit, msg ); |
|
|
|
// "Dictionary" combo box and label: |
|
++row; |
|
mDictionaryCombo = new DictionaryComboBox( tab ); |
|
glay->addWidget( mDictionaryCombo, row, 1 ); |
|
glay->addWidget( new QLabel( mDictionaryCombo, i18n("D&ictionary:"), tab ), |
|
row, 0 ); |
|
|
|
// "Sent-mail Folder" combo box and label: |
|
++row; |
|
mFccCombo = new KMFolderComboBox( tab ); |
|
mFccCombo->showOutboxFolder( false ); |
|
glay->addWidget( mFccCombo, row, 1 ); |
|
glay->addWidget( new QLabel( mFccCombo, i18n("Sent-mail &folder:"), tab ), |
|
row, 0 ); |
|
|
|
// "Drafts Folder" combo box and label: |
|
++row; |
|
mDraftsCombo = new KMFolderComboBox( tab ); |
|
mDraftsCombo->showOutboxFolder( false ); |
|
glay->addWidget( mDraftsCombo, row, 1 ); |
|
glay->addWidget( new QLabel( mDraftsCombo, i18n("&Drafts folder:"), tab ), |
|
row, 0 ); |
|
|
|
// "Special transport" combobox and label: |
|
++row; |
|
mTransportCheck = new QCheckBox( i18n("Special &transport:"), tab ); |
|
glay->addWidget( mTransportCheck, row, 0 ); |
|
mTransportCombo = new QComboBox( true, tab ); |
|
mTransportCombo->setEnabled( false ); // since !mTransportCheck->isChecked() |
|
mTransportCombo->insertStringList( KMail::TransportManager::transportNames() ); |
|
glay->addWidget( mTransportCombo, row, 1 ); |
|
connect( mTransportCheck, SIGNAL(toggled(bool)), |
|
mTransportCombo, SLOT(setEnabled(bool)) ); |
|
|
|
// the last row is a spacer |
|
|
|
// |
|
// Tab Widget: Signature |
|
// |
|
mSignatureConfigurator = new SignatureConfigurator( tabWidget ); |
|
mSignatureConfigurator->layout()->setMargin( KDialog::marginHint() ); |
|
tabWidget->addTab( mSignatureConfigurator, i18n("&Signature") ); |
|
|
|
KConfigGroup geometry( KMKernel::config(), "Geometry" ); |
|
if ( geometry.hasKey( "Identity Dialog size" ) ) |
|
resize( geometry.readSizeEntry( "Identity Dialog size" ) ); |
|
mNameEdit->setFocus(); |
|
|
|
connect( tabWidget, SIGNAL(currentChanged(QWidget*)), |
|
SLOT(slotAboutToShow(QWidget*)) ); |
|
} |
|
|
|
IdentityDialog::~IdentityDialog() { |
|
KConfigGroup geometry( KMKernel::config(), "Geometry" ); |
|
geometry.writeEntry( "Identity Dialog size", size() ); |
|
} |
|
|
|
void IdentityDialog::slotAboutToShow( QWidget * w ) { |
|
if ( w == mCryptographyTab ) { |
|
// set the configured email address as inital query of the key |
|
// requesters: |
|
const QString email = mEmailEdit->text().stripWhiteSpace(); |
|
mPGPEncryptionKeyRequester->setInitialQuery( email ); |
|
mPGPSigningKeyRequester->setInitialQuery( email ); |
|
mSMIMEEncryptionKeyRequester->setInitialQuery( email ); |
|
mSMIMESigningKeyRequester->setInitialQuery( email ); |
|
} |
|
} |
|
|
|
namespace { |
|
struct DoesntMatchEMailAddress { |
|
explicit DoesntMatchEMailAddress( const QString & s ) |
|
: email( s.stripWhiteSpace().lower() ) {} |
|
bool operator()( const GpgME::Key & key ) const; |
|
private: |
|
bool checkForEmail( const char * email ) const; |
|
static QString extractEmail( const char * email ); |
|
const QString email; |
|
}; |
|
|
|
bool DoesntMatchEMailAddress::operator()( const GpgME::Key & key ) const { |
|
const std::vector<GpgME::UserID> uids = key.userIDs(); |
|
for ( std::vector<GpgME::UserID>::const_iterator it = uids.begin() ; it != uids.end() ; ++it ) |
|
if ( checkForEmail( it->email() ? it->email() : it->id() ) ) |
|
return false; |
|
return true; // note the negation! |
|
} |
|
|
|
bool DoesntMatchEMailAddress::checkForEmail( const char * e ) const { |
|
const QString em = extractEmail( e ); |
|
return !em.isEmpty() && email == em; |
|
} |
|
|
|
QString DoesntMatchEMailAddress::extractEmail( const char * e ) { |
|
if ( !e || !*e ) |
|
return QString::null; |
|
const QString em = QString::fromUtf8( e ); |
|
if ( e[0] == '<' ) |
|
return em.mid( 1, em.length() - 2 ); |
|
else |
|
return em; |
|
} |
|
} |
|
|
|
void IdentityDialog::slotOk() { |
|
const QString email = mEmailEdit->text().stripWhiteSpace(); |
|
if ( email.isEmpty() ) |
|
return KDialogBase::slotOk(); |
|
const std::vector<GpgME::Key> & pgpSigningKeys = mPGPSigningKeyRequester->keys(); |
|
const std::vector<GpgME::Key> & pgpEncryptionKeys = mPGPEncryptionKeyRequester->keys(); |
|
const std::vector<GpgME::Key> & smimeSigningKeys = mSMIMESigningKeyRequester->keys(); |
|
const std::vector<GpgME::Key> & smimeEncryptionKeys = mSMIMEEncryptionKeyRequester->keys(); |
|
QString msg; |
|
if ( std::find_if( pgpSigningKeys.begin(), pgpSigningKeys.end(), |
|
DoesntMatchEMailAddress( email ) ) != pgpSigningKeys.end() ) |
|
msg = i18n("One of the configured OpenPGP signing keys does not contain " |
|
"any user ID with the configured email address for this " |
|
"identity (%1).\n" |
|
"This might result in warning messages on the receiving side " |
|
"when trying to verify signatures made with this configuration."); |
|
else if ( std::find_if( pgpEncryptionKeys.begin(), pgpEncryptionKeys.end(), |
|
DoesntMatchEMailAddress( email ) ) != pgpEncryptionKeys.end() ) |
|
msg = i18n("One of the configured OpenPGP encryption keys does not contain " |
|
"any user ID with the configured email address for this " |
|
"identity (%1)."); |
|
else if ( std::find_if( smimeSigningKeys.begin(), smimeSigningKeys.end(), |
|
DoesntMatchEMailAddress( email ) ) != smimeSigningKeys.end() ) |
|
msg = i18n("One of the configured S/MIME signing certificates does not contain " |
|
"the configured email address for this " |
|
"identity (%1).\n" |
|
"This might result in warning messages on the receiving side " |
|
"when trying to verify signatures made with this configuration."); |
|
else if ( std::find_if( smimeEncryptionKeys.begin(), smimeEncryptionKeys.end(), |
|
DoesntMatchEMailAddress( email ) ) != smimeEncryptionKeys.end() ) |
|
msg = i18n("One of the configured S/MIME encryption certificates does not contain " |
|
"the configured email address for this " |
|
"identity (%1)."); |
|
else |
|
return KDialogBase::slotOk(); |
|
|
|
if ( KMessageBox::warningContinueCancel( this, msg.arg( email ), |
|
i18n("Email Address Not Found in Key/Certificates"), |
|
KStdGuiItem::cont(), "warn_email_not_in_certificate" ) |
|
== KMessageBox::Continue ) |
|
return KDialogBase::slotOk(); |
|
} |
|
|
|
bool IdentityDialog::checkFolderExists( const QString & folderID, |
|
const QString & msg ) { |
|
KMFolder * folder = kmkernel->findFolderById( folderID ); |
|
if ( !folder ) { |
|
KMessageBox::sorry( this, msg ); |
|
return false; |
|
} |
|
return true; |
|
} |
|
|
|
void IdentityDialog::setIdentity( KPIM::Identity & ident ) { |
|
|
|
setCaption( i18n("Edit Identity \"%1\"").arg( ident.identityName() ) ); |
|
|
|
// "General" tab: |
|
mNameEdit->setText( ident.fullName() ); |
|
mOrganizationEdit->setText( ident.organization() ); |
|
mEmailEdit->setText( ident.emailAddr() ); |
|
|
|
// "Cryptography" tab: |
|
mPGPSigningKeyRequester->setFingerprint( ident.pgpSigningKey() ); |
|
mPGPEncryptionKeyRequester->setFingerprint( ident.pgpEncryptionKey() ); |
|
mSMIMESigningKeyRequester->setFingerprint( ident.smimeSigningKey() ); |
|
mSMIMEEncryptionKeyRequester->setFingerprint( ident.smimeEncryptionKey() ); |
|
mPreferredCryptoMessageFormat->setCurrentItem( format2cb( ident.preferredCryptoMessageFormat() ) ); |
|
|
|
// "Advanced" tab: |
|
mReplyToEdit->setText( ident.replyToAddr() ); |
|
mBccEdit->setText( ident.bcc() ); |
|
mTransportCheck->setChecked( !ident.transport().isEmpty() ); |
|
mTransportCombo->setEditText( ident.transport() ); |
|
mTransportCombo->setEnabled( !ident.transport().isEmpty() ); |
|
mDictionaryCombo->setCurrentByDictionary( ident.dictionary() ); |
|
|
|
if ( ident.fcc().isEmpty() || |
|
!checkFolderExists( ident.fcc(), |
|
i18n("The custom sent-mail folder for identity " |
|
"\"%1\" does not exist (anymore); " |
|
"therefore, the default sent-mail folder " |
|
"will be used.") |
|
.arg( ident.identityName() ) ) ) |
|
mFccCombo->setFolder( kmkernel->sentFolder() ); |
|
else |
|
mFccCombo->setFolder( ident.fcc() ); |
|
|
|
if ( ident.drafts().isEmpty() || |
|
!checkFolderExists( ident.drafts(), |
|
i18n("The custom drafts folder for identity " |
|
"\"%1\" does not exist (anymore); " |
|
"therefore, the default drafts folder " |
|
"will be used.") |
|
.arg( ident.identityName() ) ) ) |
|
mDraftsCombo->setFolder( kmkernel->draftsFolder() ); |
|
else |
|
mDraftsCombo->setFolder( ident.drafts() ); |
|
|
|
// "Signature" tab: |
|
mSignatureConfigurator->setSignature( ident.signature() ); |
|
} |
|
|
|
void IdentityDialog::updateIdentity( KPIM::Identity & ident ) { |
|
// "General" tab: |
|
ident.setFullName( mNameEdit->text() ); |
|
ident.setOrganization( mOrganizationEdit->text() ); |
|
QString email = mEmailEdit->text(); |
|
int atCount = email.contains('@'); |
|
if ( email.isEmpty() || atCount == 0 ) |
|
KMessageBox::sorry( this, "<qt>"+ |
|
i18n("Your email address is not valid because it " |
|
"does not contain a <emph>@</emph>: " |
|
"you will not create valid messages if you do not " |
|
"change your address.") + "</qt>", |
|
i18n("Invalid Email Address") ); |
|
else if ( atCount > 1 ) { |
|
KMessageBox::sorry( this, "<qt>" + |
|
i18n("Your email address is not valid because it " |
|
"contains more than one <emph>@</emph>: " |
|
"you will not create valid messages if you do not " |
|
"change your address.") + "</qt>", |
|
i18n("Invalid Email Address") ); |
|
} |
|
ident.setEmailAddr( email ); |
|
// "Cryptography" tab: |
|
ident.setPGPSigningKey( mPGPSigningKeyRequester->fingerprint().latin1() ); |
|
ident.setPGPEncryptionKey( mPGPEncryptionKeyRequester->fingerprint().latin1() ); |
|
ident.setSMIMESigningKey( mSMIMESigningKeyRequester->fingerprint().latin1() ); |
|
ident.setSMIMEEncryptionKey( mSMIMEEncryptionKeyRequester->fingerprint().latin1() ); |
|
ident.setPreferredCryptoMessageFormat( cb2format( mPreferredCryptoMessageFormat->currentItem() ) ); |
|
// "Advanced" tab: |
|
ident.setReplyToAddr( mReplyToEdit->text() ); |
|
ident.setBcc( mBccEdit->text() ); |
|
ident.setTransport( ( mTransportCheck->isChecked() ) ? |
|
mTransportCombo->currentText() : QString::null ); |
|
ident.setDictionary( mDictionaryCombo->currentDictionary() ); |
|
ident.setFcc( mFccCombo->getFolder() ? |
|
mFccCombo->getFolder()->idString() : QString::null ); |
|
ident.setDrafts( mDraftsCombo->getFolder() ? |
|
mDraftsCombo->getFolder()->idString() : QString::null ); |
|
// "Signature" tab: |
|
ident.setSignature( mSignatureConfigurator->signature() ); |
|
} |
|
|
|
void IdentityDialog::slotUpdateTransportCombo( const QStringList & sl ) { |
|
// save old setting: |
|
QString content = mTransportCombo->currentText(); |
|
// update combo box: |
|
mTransportCombo->clear(); |
|
mTransportCombo->insertStringList( sl ); |
|
// restore saved setting: |
|
mTransportCombo->setEditText( content ); |
|
} |
|
|
|
} |
|
|
|
#include "identitydialog.moc"
|
|
|