/* * Copyright (C) 2004, 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 */ #ifndef MK_TDEIO_PROTO_H #define MK_TDEIO_PROTO_H /* * TDEIO can handle multiple protocols. But some protocols have their own * manipulations of KURL or MetaData , and some protocols could do more then other * protocols. So, this class is the generic class of a class specified * by a protocol. */ class TQString; #include <tdeio/global.h> #include <tdelocale.h> #include <tqstringlist.h> #include "protocol.h" #include "tdeio.h" class TDEIO_Protocol : public Protocol { public: /* * Constuctor; empty */ TDEIO_Protocol() {} /* * Destructor; empty too */ virtual ~TDEIO_Protocol() {} /* * Public enumeration */ enum DeleteTypeEnum { get, del }; /** * This are the implementation of the Protocol-functions */ virtual const Protocol* getProtocol( TDEConfigGroup* ) const { return this; } virtual KMailDrop* createMaildrop( TDEConfigGroup* config ) const { return new KKioDrop( config ); } virtual TQMap< TQString, TQString >* createConfig( TDEConfigGroup *group, const TQString& password ) const; /* * @return: the name of the tdeio_slave */ virtual TQString protocol( bool ) const { return "file"; } /* * @return: the name of the protocol used by the configuration */ virtual TQString configName() const { return "not specified"; } virtual bool connectionBased() const { return false; } /* * The next four functions return the [capebilities] of a protocol. * fullMessage means that by downloaden, the whole message is downloaded. * if it is false, only the headers should be downloaded. */ virtual bool canReadSubjects() const { return false; } virtual bool canDeleteMail() const { return false; } virtual bool canReadMail() const { return false; } virtual bool fullMessage() const { return false; } /* * The following lines are the options in the configuration; * true means that an option is enabled; * false means that the option is disabled. */ //virtual int fields() const { return server | port | username | password | mailbox; } //virtual int urlFields() const { return no_fields; } virtual unsigned short defaultPort( bool ) const { return 0; } /* * This sets the string of such fields in Configuration */ virtual TQString serverName() const { return i18n( "Server:" ); } virtual TQString portName() const { return i18n( "Port:" ); } virtual TQString usernameName() const { return i18n( "Username:" ); } virtual TQString mailboxName() const { return i18n( "Mailbox:" ); } virtual TQString passwordName() const { return i18n( "Password:" ); } virtual TQString savePasswordName() const { return i18n( "Save password" ); } virtual TQString authName() const { return i18n( "Authentication:" ); } /* * The next function returns the method of deleting: some protoocols * like to delete files with TDEIO::get; other with TDEIO::del */ virtual DeleteTypeEnum deleteFunction() const { return del; } /* * The next options are the input for the Authentication Combo, seperated by '|'. * The name should be the same as the auth-metadata. */ virtual TQStringList authList() const { return TQStringList::split( '|', "Plain", false ); } /* * The next functions are manipulations of an KURL. * At some points in the code, a KURL is used. But sometimes, * these have to had a little retouch. That is possible with these function. * * For example, by imap, by default, the whole message is downloaded and marked as reed. * By changing an option to the KURL path, this can be prevented. * * The most functions are recognized by name. * commitDelete return true if a protocol has to confirm a deletion. * It will be called after marking the messages for deletion. * deleteCommitKURL is the KURL manipulator; the KURL is as in the settings. * That KURL isn't retouch by deleteMailKURL. */ virtual void recheckConnectKURL( KURL &, TDEIO::MetaData & ) const { } virtual void recheckKURL ( KURL &, TDEIO::MetaData & ) const { }; virtual void readSubjectConnectKURL ( KURL & kurl, TDEIO::MetaData & ) const { kurl.setPath( "" ); } virtual void readSubjectKURL ( KURL &, TDEIO::MetaData & ) const { } //For editing a kurl (adding extra options) virtual void deleteMailConnectKURL( KURL & kurl, TDEIO::MetaData & ) const { kurl.setPath( "" ); } virtual void deleteMailKURL ( KURL &, TDEIO::MetaData & ) const { } virtual bool commitDelete() const { return false; } virtual void deleteCommitKURL( KURL &, TDEIO::MetaData & ) const { } virtual void readMailKURL ( KURL &, TDEIO::MetaData & ) const { } virtual const TDEIO_Protocol* getKIOProtocol() const { return this; } virtual void readEntries( TQMap< TQString, TQString >* ) const; virtual void readEntries( TQMap< TQString, TQString >*, TQMap< TQString, TQString >* ) const = 0; protected: /* * This enumeration is used when returning the capebilitys of a protocol */ enum Fields { no_fields = 0, server = 1, port = 2, username = 4, password = 8, mailbox = 16, save_password = 32, metadata = 64 }; void clearFields( TQMap< TQString, TQString > *map, const Fields fields ) const; }; #endif //MK_TDEIO_PROTO_H