|
|
|
/*
|
|
|
|
* Copyright (C) 2005, Mart Kelder (mart.kde@hccnet.nl)
|
|
|
|
*
|
|
|
|
* 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 <tqmap.h>
|
|
|
|
#include <tqobject.h>
|
|
|
|
#include <tqptrvector.h>
|
|
|
|
#include <tqstringlist.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::kmailKeyTQMail = "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;
|
|
|
|
TQString 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 );
|
|
|
|
TQString 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;
|
|
|
|
}
|
|
|
|
|
|
|
|
TQMap< TQString, TQString > * KMail_Protocol::createConfig( KConfigGroup* config, const TQString& ) const
|
|
|
|
{
|
|
|
|
TQMap< TQString, TQString > *result = new TQMap<TQString, TQString>;
|
|
|
|
int id;
|
|
|
|
KConfig kmailconfig( "kmailrc", true, false );
|
|
|
|
//First: find the account in the configuration and get the type and id out of it.
|
|
|
|
TQString type = getTypeAndConfig( config->readEntry( "kmailname" ), kmailconfig, id );
|
|
|
|
TQString metadata;
|
|
|
|
|
|
|
|
if( type == "imap" || type == "cachedimap" )
|
|
|
|
{
|
|
|
|
//Construct metadata
|
|
|
|
if( kmailconfig.hasKey( "auth" ) )
|
|
|
|
metadata += TQString( "auth=%1," ).tqarg( 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 += TQString( "auth=%1," ).tqarg( 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( kmailKeyTQMail, "" ) );
|
|
|
|
result->insert( "password", "" );
|
|
|
|
result->insert( "savepassword", "false" );
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMail_Protocol::configFillGroupBoxes( TQStringList* lijst ) const
|
|
|
|
{
|
|
|
|
lijst->append( "KMail" );
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMail_Protocol::configFields( TQPtrVector< TQWidget >* vector, const TQObject*, TQPtrList< AccountInput >* result ) const
|
|
|
|
{
|
|
|
|
TQMap< TQString, TQString > accountList;
|
|
|
|
TQString type;
|
|
|
|
TQString name;
|
|
|
|
int nummer = kmailFirstGroup - 1;
|
|
|
|
|
|
|
|
KConfig kmailconfig( "kmailrc", true, false );
|
|
|
|
while( kmailconfig.hasGroup( TQString( kmailGroupName ).tqarg( ++nummer ) ) )
|
|
|
|
{
|
|
|
|
kmailconfig.setGroup( TQString( kmailGroupName ).tqarg( nummer ) );
|
|
|
|
type = kmailconfig.readEntry( kmailKeyType, TQString() );
|
|
|
|
name = kmailconfig.readEntry( kmailKeyName, TQString() );
|
|
|
|
if( type == "imap" || type == "cachedimap" || type == "pop" || type == "local" )
|
|
|
|
{
|
|
|
|
accountList.insert( name, name );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
result->append( new ComboInput( (TQWidget*)vector->at( 0 ), i18n( "KMail name" ), accountList, *accountList.begin(), "kmailname" ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMail_Protocol::readEntries( TQMap< TQString, TQString >* ) const
|
|
|
|
{
|
|
|
|
//The configuartion is read out on the right way
|
|
|
|
}
|
|
|
|
|
|
|
|
void KMail_Protocol::writeEntries( TQMap< TQString, TQString >* ) const
|
|
|
|
{
|
|
|
|
//The configuartion is read out on the right way
|
|
|
|
}
|
|
|
|
|
|
|
|
TQString KMail_Protocol::readPassword( bool store, const KConfigBase& config, int id ) const
|
|
|
|
{
|
|
|
|
if( !store )
|
|
|
|
return "";
|
|
|
|
|
|
|
|
return KOrnPassword::readKMailPassword( id, config );
|
|
|
|
}
|
|
|
|
|
|
|
|
TQString KMail_Protocol::getTypeAndConfig( const TQString& kmailname, KConfig &kmailconfig, int &id ) const
|
|
|
|
{
|
|
|
|
int nummer = kmailFirstGroup - 1;
|
|
|
|
bool found = false;
|
|
|
|
|
|
|
|
id = -1;
|
|
|
|
|
|
|
|
while( kmailconfig.hasGroup( TQString( kmailGroupName ).tqarg( ++nummer ) ) )
|
|
|
|
{
|
|
|
|
kmailconfig.setGroup( TQString( kmailGroupName ).tqarg( nummer ) );
|
|
|
|
if( kmailconfig.readEntry( kmailKeyName, TQString() ) == kmailname )
|
|
|
|
{
|
|
|
|
id = kmailconfig.readNumEntry( kmailKeyId, 0 );
|
|
|
|
found = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if( !found )
|
|
|
|
{
|
|
|
|
nummer = -1;
|
|
|
|
return TQString();
|
|
|
|
}
|
|
|
|
|
|
|
|
//The correct group is found, and kmailconfig.setGroup() is already called for the right group.
|
|
|
|
return kmailconfig.readEntry( kmailKeyType, TQString() );
|
|
|
|
}
|
|
|
|
|