kde-playground/kdepim/kmailcvt
2015-09-23 11:27:31 +00:00
..
icons import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
pics import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
samples import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
CMakeLists.txt kdepim: cleanup 2015-09-23 11:27:31 +00:00
kimportpage.cpp import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
kimportpage.h import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
kimportpagedlg.ui kdepim: cleanup 2015-09-23 11:27:31 +00:00
kmailcvt.cpp import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
kmailcvt.h import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
kmailcvtfilterinfogui.cpp import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
kmailcvtfilterinfogui.h import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
kmailcvtkernel.cpp import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
kmailcvtkernel.h import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
kselfilterpage.cpp import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
kselfilterpage.h import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
kselfilterpagedlg.ui kdepim: cleanup 2015-09-23 11:27:31 +00:00
main.cpp import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
Messages.sh import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00
README import working copies of kdepim and kdepimlibs 2015-04-14 21:49:29 +00:00

The KDE Mail Import tool - KMailCVT
===================================

This directory contains the sources for the KMailCVT program.
KMailCVT imports messages into Akonadi.
The name KMailCVT stems from historic reasons: Before using Akonadi,
KMailCVT communicated over D-Bus with KMail to add messages. Nowadays
that is no longer necessary, KMailCVT is independent of KMail.

Writing a filter
----------------

...is very easy. Create two files filter_myformat.cpp and filter_myformat.h
and add "filter_myformat.cxx" to the end of the kmailcvt_SRCS line in
CMakeLists.txt and "filter_myformat.cpp filter_myformat.h" ../mailimporter/
Now run "cmake ../;" in
your kdepim source directory.

In the import method of your filter you are passed a FilterInfo object. This has
the following methods that you may want to use:

    void setFrom( const QString& from ); // Set to file importing from
    void setTo( const QString& to ); // Set to folder importing into
    void setCurrent( const QString& current ); // What we are doing
    void setCurrent( int percent = 0 ); // Set percentage of current file
    void setOverall( int percent = 0 ); // Set overall percentage
    void addLog( const QString& log ); // Add a message for the user to see
    void alert( const QString& message ); // Tell user something has gone wrong
    QWidget *parent(); // The parent widget
    Akonadi::Collection rootCollection(); // The root collection the mails should be
                                          // imported to.
    
    bool removeDupMsg; // true, if user selected 'remove duplicated messages'
    
Also, every now and again you should check to see if the shouldTerminate method
returns true, if it does the user has pressed cancel and your import method
should return.

To add a message, there are two possibilities:
1) Extract the mail into a KMime::Message::Ptr object and then call addAkonadiMessage
   with that message and the target collection.
   To facilitate creating a hierachy of folders, use the parseFolderString() method.
   Check for duplicates with checkForDuplicates() if removeDupMsg from the FilterInfo is true.
   Only call checkForDuplicates() if a message ID exists for the message, otherwise you could get
   false positives.
2) Extract the email (including all headers) into a KTempFile.
   Then use the following:

   if ( info->removeDupMsg )
     addMessage( info, folderName, tempfilepath );
   else
     addMessage_fastImport( info, folderName, tempfilepath );

The second method is only provided for compatibility with legacy filters and should
not be used anymore.

For a simple example, look at filter_plain

Finally for the filter to appear in the combo box in the wizard you need to edit
kselfilterpage.cpp and add an appropriate addFilter() function call.

Thomas McGuire, January 2010
Danny Kukawka, February 2005
Laurence Anderson, April 2003.