summaryrefslogtreecommitdiffstats
path: root/korn/kmail_proto.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'korn/kmail_proto.cpp')
-rw-r--r--korn/kmail_proto.cpp246
1 files changed, 246 insertions, 0 deletions
diff --git a/korn/kmail_proto.cpp b/korn/kmail_proto.cpp
new file mode 100644
index 000000000..15b228f39
--- /dev/null
+++ b/korn/kmail_proto.cpp
@@ -0,0 +1,246 @@
+/*
+ * Copyright (C) 2005, Mart Kelder ([email protected])
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * 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 "kmail_proto.h"
+
+#include "account_input.h"
+#include "kio.h"
+#include "password.h"
+#include "protocols.h"
+
+#include <kconfig.h>
+#include <kdebug.h>
+#include <klocale.h>
+
+#include <qmap.h>
+#include <qobject.h>
+#include <qptrvector.h>
+#include <qstringlist.h>
+
+const char* KMail_Protocol::kmailGroupName = "Account %1";
+const char* KMail_Protocol::kmailKeyType = "Type";
+const char* KMail_Protocol::kmailKeyName = "Name";
+const char* KMail_Protocol::kmailKeyId = "Id";
+const char* KMail_Protocol::kmailKeyMBox = "Location";
+const char* KMail_Protocol::kmailKeyQMail = "Location";
+const int KMail_Protocol::kmailFirstGroup = 1;
+
+class KMailDrop;
+
+KMail_Protocol::KMail_Protocol()
+{
+}
+
+KMail_Protocol::~KMail_Protocol()
+{
+}
+
+const Protocol* KMail_Protocol::getProtocol( KConfigGroup* config ) const
+{
+ KConfig kmailconfig( "kmailrc", true, false );
+ int id;
+ QString type = getTypeAndConfig( config->readEntry( "kmailname" ), kmailconfig, id );
+
+ if( type == "imap" )
+ return Protocols::getProto( "imap" );
+ if( type == "cachedimap" )
+ return Protocols::getProto( "imap" );
+ if( type == "pop" )
+ return Protocols::getProto( "pop3" );
+ if( type == "local" )
+ return Protocols::getProto( "mbox" );
+ if( type == "maildir" )
+ return Protocols::getProto( "qmail" );
+
+ //Type not recognized, or does not exist in KOrn
+ kdWarning() << "KMail configuration not found" << endl;
+ return 0;
+}
+
+KMailDrop* KMail_Protocol::createMaildrop( KConfigGroup *config ) const
+{
+ int id;
+ KConfig kmailconfig( "kmailrc", true, false );
+ QString type = getTypeAndConfig( config->readEntry( "kmailname" ), kmailconfig, id );
+
+ if( type == "imap" || type == "cachedimap" || type == "pop" || type == "local" || type == "maildir" )
+ return new KKioDrop();
+
+ kdWarning() << "KMail configuration not found" << endl;
+ return 0;
+}
+
+QMap< QString, QString > * KMail_Protocol::createConfig( KConfigGroup* config, const QString& ) const
+{
+ QMap< QString, QString > *result = new QMap<QString, QString>;
+ int id;
+ KConfig kmailconfig( "kmailrc", true, false );
+ //First: find the account in the configuration and get the type and id out of it.
+ QString type = getTypeAndConfig( config->readEntry( "kmailname" ), kmailconfig, id );
+ QString metadata;
+
+ if( type == "imap" || type == "cachedimap" )
+ {
+ //Construct metadata
+ if( kmailconfig.hasKey( "auth" ) )
+ metadata += QString( "auth=%1," ).arg( kmailconfig.readEntry( "auth" ) );
+ if( !kmailconfig.hasKey( "use-tls" ) )
+ metadata += "tls=auto";
+ else
+ {
+ if( kmailconfig.readBoolEntry( "use-tls", false ) )
+ metadata += "tls=on";
+ else
+ metadata += "tls=off";
+ }
+ //Add the fields into the mapping.
+ result->insert( "name", config->readEntry( "name", "" ) );
+ result->insert( "server", kmailconfig.readEntry( "host", "localhost" ) );
+ result->insert( "port", kmailconfig.readEntry( "port", "143" ) );
+ result->insert( "ssl", kmailconfig.readEntry( "use-ssl", "false" ) );
+ result->insert( "metadata", metadata );
+ result->insert( "username", kmailconfig.readEntry( "login", "" ) );
+ result->insert( "mailbox", "INBOX" ); //Didn't find a good way to get this out of the configuration yet.
+ result->insert( "password", readPassword( kmailconfig.readBoolEntry( "store-passwd", false ), kmailconfig, id ) );
+ result->insert( "savepassword", kmailconfig.readEntry( "store-passwd", "false" ) );
+ }
+ if( type == "pop" )
+ {
+ //Constructing metadata
+ if( kmailconfig.hasKey( "auth" ) )
+ metadata += QString( "auth=%1," ).arg( kmailconfig.readEntry( "auth" ) );
+ if( !kmailconfig.hasKey( "use-tls" ) )
+ metadata += "tls=auto";
+ else
+ {
+ if( kmailconfig.readBoolEntry( "use-tls", false ) )
+ metadata += "tls=on";
+ else
+ metadata += "tls=off";
+ }
+ result->insert( "name", config->readEntry( "name", "" ) );
+ result->insert( "server", kmailconfig.readEntry( "host", "localhost" ) );
+ result->insert( "port", kmailconfig.readEntry( "port", "110" ) );
+ result->insert( "ssl", kmailconfig.readEntry( "use-ssl", "false" ) );
+ result->insert( "metadata", metadata );
+ result->insert( "username", kmailconfig.readEntry( "login", "" ) );
+ result->insert( "mailbox", "" );
+ result->insert( "password", readPassword( kmailconfig.readBoolEntry( "store-passwd", false ), kmailconfig, id ) );
+ result->insert( "savepassword", kmailconfig.readEntry( "store-password", "false" ) );
+ }
+ if( type == "local" ) //mbox
+ {
+ result->insert( "name", config->readEntry( "name", "" ) );
+ result->insert( "server", "" );
+ result->insert( "port", "0" );
+ result->insert( "ssl", "false" );
+ result->insert( "metadata", "" );
+ result->insert( "username", "" );
+ result->insert( "mailbox", kmailconfig.readPathEntry( kmailKeyMBox, "" ) );
+ result->insert( "password", "" );
+ result->insert( "savepassword", "false" );
+ }
+ if( type == "maildir" )
+ {
+ result->insert( "name", config->readEntry( "name", "" ) );
+ result->insert( "server", "" );
+ result->insert( "port", "0" );
+ result->insert( "ssl", "false" );
+ result->insert( "metadata", "" );
+ result->insert( "username", "" );
+ result->insert( "mailbox", kmailconfig.readPathEntry( kmailKeyQMail, "" ) );
+ result->insert( "password", "" );
+ result->insert( "savepassword", "false" );
+ }
+
+ return result;
+}
+
+void KMail_Protocol::configFillGroupBoxes( QStringList* lijst ) const
+{
+ lijst->append( "KMail" );
+}
+
+void KMail_Protocol::configFields( QPtrVector< QWidget >* vector, const QObject*, QPtrList< AccountInput >* result ) const
+{
+ QMap< QString, QString > accountList;
+ QString type;
+ QString name;
+ int nummer = kmailFirstGroup - 1;
+
+ KConfig kmailconfig( "kmailrc", true, false );
+ while( kmailconfig.hasGroup( QString( kmailGroupName ).arg( ++nummer ) ) )
+ {
+ kmailconfig.setGroup( QString( kmailGroupName ).arg( nummer ) );
+ type = kmailconfig.readEntry( kmailKeyType, QString::null );
+ name = kmailconfig.readEntry( kmailKeyName, QString::null );
+ if( type == "imap" || type == "cachedimap" || type == "pop" || type == "local" )
+ {
+ accountList.insert( name, name );
+ }
+ }
+
+ result->append( new ComboInput( (QWidget*)vector->at( 0 ), i18n( "KMail name" ), accountList, *accountList.begin(), "kmailname" ) );
+}
+
+void KMail_Protocol::readEntries( QMap< QString, QString >* ) const
+{
+ //The configuartion is read out on the right way
+}
+
+void KMail_Protocol::writeEntries( QMap< QString, QString >* ) const
+{
+ //The configuartion is read out on the right way
+}
+
+QString KMail_Protocol::readPassword( bool store, const KConfigBase& config, int id ) const
+{
+ if( !store )
+ return "";
+
+ return KOrnPassword::readKMailPassword( id, config );
+}
+
+QString KMail_Protocol::getTypeAndConfig( const QString& kmailname, KConfig &kmailconfig, int &id ) const
+{
+ int nummer = kmailFirstGroup - 1;
+ bool found = false;
+
+ id = -1;
+
+ while( kmailconfig.hasGroup( QString( kmailGroupName ).arg( ++nummer ) ) )
+ {
+ kmailconfig.setGroup( QString( kmailGroupName ).arg( nummer ) );
+ if( kmailconfig.readEntry( kmailKeyName, QString::null ) == kmailname )
+ {
+ id = kmailconfig.readNumEntry( kmailKeyId, 0 );
+ found = true;
+ break;
+ }
+ }
+ if( !found )
+ {
+ nummer = -1;
+ return QString::null;
+ }
+
+ //The correct group is found, and kmailconfig.setGroup() is already called for the right group.
+ return kmailconfig.readEntry( kmailKeyType, QString::null );
+}
+