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.
tdepim/kmail/identitydialog.cpp

737 lines
30 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
In addition, as a special exception, the copyright holders give
permission to link the code of this program with any edition of
the TQt library by Trolltech AS, Norway (or with modified versions
of TQt that use the same license as TQt), 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
TQt. 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 "xfaceconfigurator.h"
#include "folderrequester.h"
using KMail::FolderRequester;
#include "kmfoldermgr.h"
#include "transportmanager.h"
#include "dictionarycombobox.h"
#include "kleo_util.h"
#include "kmmainwidget.h"
#include "kmfolder.h"
#include "templatesconfiguration.h"
#include "templatesconfiguration_kfg.h"
#include "simplestringlisteditor.h"
// other tdepim headers:
// libtdepim
#include <libkpimidentities/identity.h>
#include <libtdepim/addresseelineedit.h>
// libkleopatra:
#include <ui/keyrequester.h>
#include <kleo/cryptobackendfactory.h>
#include <libemailfunctions/email.h>
// other KDE headers:
#include <klocale.h>
#include <kmessagebox.h>
#include <kconfig.h>
#include <kfileitem.h>
#include <kurl.h>
#include <kdebug.h>
#include <kpushbutton.h>
// TQt headers:
#include <tqtabwidget.h>
#include <tqlabel.h>
#include <tqwhatsthis.h>
#include <tqlayout.h>
#include <tqpushbutton.h>
#include <tqcheckbox.h>
#include <tqcombobox.h>
#include <tqgroupbox.h>
#include <tqtextedit.h>
// other headers:
#include <gpgmepp/key.h>
#include <iterator>
#include <algorithm>
using namespace KPIM;
namespace KMail {
IdentityDialog::IdentityDialog( TQWidget * parent, const char * name )
: KDialogBase( Plain, i18n("Edit Identity"), Ok|Cancel|Help, Ok,
parent, name )
{
// tmp. vars:
TQWidget * tab;
TQLabel * label;
int row;
TQGridLayout * glay;
TQString msg;
//
// Tab Widget: General
//
row = -1;
TQVBoxLayout * vlay = new TQVBoxLayout( plainPage(), 0, spacingHint() );
TQTabWidget *tabWidget = new TQTabWidget( plainPage(), "config-identity-tab" );
vlay->addWidget( tabWidget );
tab = new TQWidget( tabWidget );
tabWidget->addTab( tab, i18n("&General") );
glay = new TQGridLayout( tab, 5, 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 TQLabel( 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>");
TQWhatsThis::add( label, msg );
TQWhatsThis::add( mNameEdit, msg );
// "Organization" line edit and label:
++row;
mOrganizationEdit = new KLineEdit( tab );
glay->addWidget( mOrganizationEdit, row, 1 );
label = new TQLabel( 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>");
TQWhatsThis::add( label, msg );
TQWhatsThis::add( mOrganizationEdit, msg );
// "Email Address" line edit and label:
++row;
mEmailEdit = new KLineEdit( tab );
glay->addWidget( mEmailEdit, row, 1 );
label = new TQLabel( 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>This address is the primary one, used for all outgoing mail. "
"If you have more than one address, either create a new identity, "
"or add additional alias addresses in the field below.</p>"
"<p>If you leave this blank, or get it wrong, people "
"will have trouble replying to you.</p></qt>");
TQWhatsThis::add( label, msg );
TQWhatsThis::add( mEmailEdit, msg );
// "Email Aliases" string list edit and label:
++row;
mAliasEdit = new SimpleStringListEditor( tab );
glay->addMultiCellWidget( mAliasEdit, row, row+1, 1, 1 );
label = new TQLabel( mAliasEdit, i18n("Email a&liases:"), tab );
glay->addWidget( label, row, 0, TQt::AlignTop );
msg = i18n("<qt><h3>Email aliases</h3>"
"<p>This field contains alias addresses that should also "
"be considered as belonging to this identity (as opposed "
"to representing a different identity).</p>"
"<p>Example:</p>"
"<table>"
"<tr><th>Primary address:</th><td>first.last@example.org</td></tr>"
"<tr><th>Aliases:</th><td>first@example.org<br>last@example.org</td></tr>"
"</table>"
"<p>Type one alias address per line.</p></qt>");
TQWhatsThis::add( label, msg );
TQWhatsThis::add( mAliasEdit, msg );
//
// Tab Widget: Cryptography
//
row = -1;
mCryptographyTab = tab = new TQWidget( tabWidget );
tabWidget->addTab( tab, i18n("Cryptograph&y") );
glay = new TQGridLayout( 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 TQLabel( mPGPSigningKeyRequester, i18n("OpenPGP signing key:"), tab );
TQWhatsThis::add( mPGPSigningKeyRequester, msg );
TQWhatsThis::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 TQLabel( mPGPEncryptionKeyRequester, i18n("OpenPGP encryption key:"), tab );
TQWhatsThis::add( mPGPEncryptionKeyRequester, msg );
TQWhatsThis::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 TQLabel( mSMIMESigningKeyRequester, i18n("S/MIME signing certificate:"), tab );
TQWhatsThis::add( mSMIMESigningKeyRequester, msg );
TQWhatsThis::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 TQLabel( mSMIMEEncryptionKeyRequester, i18n("S/MIME encryption certificate:"), tab );
TQWhatsThis::add( mSMIMEEncryptionKeyRequester, msg );
TQWhatsThis::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 TQComboBox( false, tab );
TQStringList 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 TQLabel( 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 TQWidget( tabWidget );
tabWidget->addTab( tab, i18n("&Advanced") );
glay = new TQGridLayout( tab, 8, 2, marginHint(), spacingHint() );
// the last (empty) row takes all the remaining space
glay->setRowStretch( 8-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 TQLabel ( 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>");
TQWhatsThis::add( label, msg );
TQWhatsThis::add( mReplyToEdit, msg );
// "BCC addresses" line edit and label:
++row;
mBccEdit = new KPIM::AddresseeLineEdit( tab, true, "mBccEdit" );
glay->addWidget( mBccEdit, row, 1 );
label = new TQLabel( 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>");
TQWhatsThis::add( label, msg );
TQWhatsThis::add( mBccEdit, msg );
// "Dictionary" combo box and label:
++row;
mDictionaryCombo = new DictionaryComboBox( tab );
glay->addWidget( mDictionaryCombo, row, 1 );
glay->addWidget( new TQLabel( mDictionaryCombo, i18n("D&ictionary:"), tab ),
row, 0 );
// "Sent-mail Folder" combo box and label:
++row;
mFccCombo = new FolderRequester( tab,
kmkernel->getKMMainWidget()->folderTree() );
mFccCombo->setShowOutbox( false );
glay->addWidget( mFccCombo, row, 1 );
glay->addWidget( new TQLabel( mFccCombo, i18n("Sent-mail &folder:"), tab ),
row, 0 );
// "Drafts Folder" combo box and label:
++row;
mDraftsCombo = new FolderRequester( tab,
kmkernel->getKMMainWidget()->folderTree() );
mDraftsCombo->setShowOutbox( false );
glay->addWidget( mDraftsCombo, row, 1 );
glay->addWidget( new TQLabel( mDraftsCombo, i18n("&Drafts folder:"), tab ),
row, 0 );
// "Templates Folder" combo box and label:
++row;
mTemplatesCombo = new FolderRequester( tab,
kmkernel->getKMMainWidget()->folderTree() );
mTemplatesCombo->setShowOutbox( false );
glay->addWidget( mTemplatesCombo, row, 1 );
glay->addWidget( new TQLabel( mTemplatesCombo, i18n("&Templates folder:"), tab ),
row, 0 );
// "Special transport" combobox and label:
++row;
mTransportCheck = new TQCheckBox( i18n("Special &transport:"), tab );
glay->addWidget( mTransportCheck, row, 0 );
mTransportCombo = new TQComboBox( true, tab );
mTransportCombo->setEnabled( false ); // since !mTransportCheck->isChecked()
mTransportCombo->insertStringList( KMail::TransportManager::transportNames() );
glay->addWidget( mTransportCombo, row, 1 );
connect( mTransportCheck, TQT_SIGNAL(toggled(bool)),
mTransportCombo, TQT_SLOT(setEnabled(bool)) );
// the last row is a spacer
//
// Tab Widget: Templates
//
tab = new TQWidget( tabWidget );
tabWidget->addTab( tab, i18n("&Templates") );
vlay = new TQVBoxLayout( tab, marginHint(), spacingHint() );
mCustom = new TQCheckBox( i18n("&Use custom message templates"), tab );
vlay->addWidget( mCustom );
mWidget = new TemplatesConfiguration( tab , "identity-templates" );
mWidget->setEnabled( false );
vlay->addWidget( mWidget );
TQHBoxLayout *btns = new TQHBoxLayout( vlay, spacingHint() );
mCopyGlobal = new KPushButton( i18n("&Copy global templates"), tab );
mCopyGlobal->setEnabled( false );
btns->addWidget( mCopyGlobal );
connect( mCustom, TQT_SIGNAL( toggled( bool ) ),
mWidget, TQT_SLOT( setEnabled( bool ) ) );
connect( mCustom, TQT_SIGNAL( toggled( bool ) ),
mCopyGlobal, TQT_SLOT( setEnabled( bool ) ) );
connect( mCopyGlobal, TQT_SIGNAL(clicked()),
this, TQT_SLOT(slotCopyGlobal()) );
//
// Tab Widget: Signature
//
mSignatureConfigurator = new SignatureConfigurator( tabWidget );
mSignatureConfigurator->tqlayout()->setMargin( KDialog::marginHint() );
tabWidget->addTab( mSignatureConfigurator, i18n("&Signature") );
mXFaceConfigurator = new XFaceConfigurator( tabWidget );
mXFaceConfigurator->tqlayout()->setMargin( KDialog::marginHint() );
tabWidget->addTab( mXFaceConfigurator, i18n("&Picture") );
KConfigGroup geometry( KMKernel::config(), "Geometry" );
if ( geometry.hasKey( "Identity Dialog size" ) )
resize( geometry.readSizeEntry( "Identity Dialog size" ) );
mNameEdit->setFocus();
connect( tabWidget, TQT_SIGNAL(currentChanged(TQWidget*)),
TQT_SLOT(slotAboutToShow(TQWidget*)) );
}
IdentityDialog::~IdentityDialog() {
KConfigGroup geometry( KMKernel::config(), "Geometry" );
geometry.writeEntry( "Identity Dialog size", size() );
}
void IdentityDialog::slotAboutToShow( TQWidget * w ) {
if ( w == mCryptographyTab ) {
// set the configured email address as inital query of the key
// requesters:
const TQString email = mEmailEdit->text().stripWhiteSpace();
mPGPEncryptionKeyRequester->setInitialQuery( email );
mPGPSigningKeyRequester->setInitialQuery( email );
mSMIMEEncryptionKeyRequester->setInitialQuery( email );
mSMIMESigningKeyRequester->setInitialQuery( email );
}
}
void IdentityDialog::slotCopyGlobal() {
mWidget->loadFromGlobal();
}
namespace {
struct DoesntMatchEMailAddress {
explicit DoesntMatchEMailAddress( const TQString & s )
: email( s.stripWhiteSpace().lower() ) {}
bool operator()( const GpgME::Key & key ) const;
private:
bool checkForEmail( const char * email ) const;
static TQString extractEmail( const char * email );
const TQString 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 TQString em = extractEmail( e );
return !em.isEmpty() && email == em;
}
TQString DoesntMatchEMailAddress::extractEmail( const char * e ) {
if ( !e || !*e )
return TQString();
const TQString em = TQString::fromUtf8( e );
if ( e[0] == '<' )
return em.mid( 1, em.length() - 2 );
else
return em;
}
}
bool IdentityDialog::validateAddresses( const TQString & addresses )
{
TQString brokenAddress;
KPIM::EmailParseResult errorCode = KMMessage::isValidEmailAddressList( KMMessage::expandAliases( addresses ), brokenAddress );
if ( !( errorCode == KPIM::AddressOk || errorCode == KPIM::AddressEmpty ) ) {
TQString errorMsg( "<qt><p><b>" + brokenAddress +
"</b></p><p>" + KPIM::emailParseResultToString( errorCode ) +
"</p></qt>" );
KMessageBox::sorry( this, errorMsg, i18n("Invalid Email Address") );
return false;
}
return true;
}
void IdentityDialog::slotOk() {
const TQString email = mEmailEdit->text().stripWhiteSpace();
// Validate email addresses
if ( !isValidSimpleEmailAddress( email )) {
TQString errorMsg( simpleEmailAddressErrorMsg());
KMessageBox::sorry( this, errorMsg, i18n("Invalid Email Address") );
return;
}
const TQStringList aliases = mAliasEdit->stringList();
for ( TQStringList::const_iterator it = aliases.begin(), end = aliases.end() ; it != end ; ++it ) {
if ( !isValidSimpleEmailAddress( *it ) ) {
TQString errorMsg( simpleEmailAddressErrorMsg());
KMessageBox::sorry( this, errorMsg, i18n("Invalid Email Alias \"%1\"").arg( *it ) );
return;
}
}
if ( !validateAddresses( mReplyToEdit->text().stripWhiteSpace() ) ) {
return;
}
if ( !validateAddresses( mBccEdit->text().stripWhiteSpace() ) ) {
return;
}
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();
TQString msg;
bool err = false;
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.");
err = true;
}
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).");
err = true;
}
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.");
err = true;
}
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).");
err = true;
}
if ( err )
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;
if ( mSignatureConfigurator->isSignatureEnabled() &&
mSignatureConfigurator->signatureType()==Signature::FromFile ) {
KURL url( mSignatureConfigurator->fileURL() );
KFileItem signatureFile( KFileItem::Unknown, KFileItem::Unknown, url );
if ( !signatureFile.isFile() || !signatureFile.isReadable() || !signatureFile.isLocalFile() ) {
KMessageBox::error( this, i18n( "The signature file is not valid" ) );
return;
}
}
return KDialogBase::slotOk();
}
bool IdentityDialog::checkFolderExists( const TQString & folderID,
const TQString & 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.primaryEmailAddress() );
mAliasEdit->setStringList( ident.emailAliases() );
// "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() );
if ( ident.templates().isEmpty() ||
!checkFolderExists( ident.templates(),
i18n("The custom templates folder for identity "
"\"%1\" does not exist (anymore); "
"therefore, the default templates folder "
"will be used.")
.arg( ident.identityName() ) ) )
mTemplatesCombo->setFolder( kmkernel->templatesFolder() );
else
mTemplatesCombo->setFolder( ident.templates() );
// "Templates" tab:
uint identity = ident.uoid();
TQString iid = TQString("IDENTITY_%1").arg( identity );
Templates t( iid );
mCustom->setChecked(t.useCustomTemplates());
mWidget->loadFromIdentity( identity );
// "Signature" tab:
mSignatureConfigurator->setSignature( ident.signature() );
mXFaceConfigurator->setXFace( ident.xface() );
mXFaceConfigurator->setXFaceEnabled( ident.isXFaceEnabled() );
}
void IdentityDialog::updateIdentity( KPIM::Identity & ident ) {
// "General" tab:
ident.setFullName( mNameEdit->text() );
ident.setOrganization( mOrganizationEdit->text() );
TQString email = mEmailEdit->text();
ident.setPrimaryEmailAddress( email );
const TQStringList aliases = mAliasEdit->stringList();
ident.setEmailAliases( aliases );
// "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() : TQString() );
ident.setDictionary( mDictionaryCombo->currentDictionary() );
ident.setFcc( mFccCombo->folder() ?
mFccCombo->folder()->idString() : TQString() );
ident.setDrafts( mDraftsCombo->folder() ?
mDraftsCombo->folder()->idString() : TQString() );
ident.setTemplates( mTemplatesCombo->folder() ?
mTemplatesCombo->folder()->idString() : TQString() );
// "Templates" tab:
uint identity = ident.uoid();
TQString iid = TQString("IDENTITY_%1").arg( identity );
Templates t( iid );
kdDebug() << "use custom templates for identity " << identity << ": " << mCustom->isChecked() << endl;
t.setUseCustomTemplates(mCustom->isChecked());
t.writeConfig();
mWidget->saveToIdentity( identity );
// "Signature" tab:
ident.setSignature( mSignatureConfigurator->signature() );
ident.setXFace( mXFaceConfigurator->xface() );
ident.setXFaceEnabled( mXFaceConfigurator->isXFaceEnabled() );
}
void IdentityDialog::slotUpdateTransportCombo( const TQStringList & sl ) {
// save old setting:
TQString content = mTransportCombo->currentText();
// update combo box:
mTransportCombo->clear();
mTransportCombo->insertStringList( sl );
// restore saved setting:
mTransportCombo->setEditText( content );
}
}
#include "identitydialog.moc"