[Users] Migrating mail filtering rules from KMAil to Claws-Mail

Renaud (Ron) Olgiati renaud at olgiati-in-paraguay.org
Wed Jun 20 10:47:11 CEST 2012


Some pointers on how I did it, in case it can be of help to others.
 
Cheers,
 
Ron.
-- 
       Passionate hatred can give meaning and purpose to an empty life.
                                                         -- Eric Hoffer
                                    
                   -- http://www.olgiati-in-paraguay.org --



Migrating mail filtering rules from KMAil to Claws-Mail

Getting fed up with KDE as the years go by and KDE becomes more and more 
bloatware, I finally decided to bite the bullet,  to get rid of KDE and move 
to a lighter Desktop Environment; the only thing keeping me in KDE was KMail, 
with over 125 filtering rules I did not relish entering one by one using the 
Claws-MailGUI.

So I looked into how could I speed up the process by working directly on the 
config files.

In KMail, the filter rules are part of ~/.kde4/share/config/kmailrc where each 
rule is in a paragraph beginning with [FilterN] with N the ID number of the 
rule. In Claws-Mail, they are in ~/.claws-mail/matcherrc, where each rule 
occupys one line.

Since about 95% of my rules were based on whether a given string was present 
in either the Subject header, the From header or the whole message, and simply 
moved the message to a given folder, I have decided to concentrate on those, 
and do with the GUI the few remaining and more complicated rules.

For the rules based on the presence of a string, in KMail each rule has lines 
for name= (the name of the rule), one or several filedA, fieldB etc lines for 
Subject, Message, From etc, the same number of contentsA, contentsB etc lines 
for the strings, an action-args line for the name of the folder, and an 
action-name=transfer indicating what the rule does; dead simple.

In Claws-Mail, each rule line starts with 'enabled rulename "Name Of The 
Rule"' indicating the rule is active, and called 'Name Of The Rule', then one 
or several 'subject matchcase "string1"', 'from matchcase "string2"' or 
'message matchcase "string3"' that indicate which header to filter on with 
what string, those being separated by '|' if any condition is sufficient for 
the rule, and '&' if all conditions must be fulfilled.

So I started by making a dummy rule file with the gui, which I then edited 
using Kwrite; it holds the building blocks I will use for cutting and pasting 
the rules together, with the addition of strings I will cut and paste from 
kmailrc :

	[preglobal]

	[postglobal]

	[filtering]

	enabled rulename "" subject matchcase "" move "#mh/mailmh/" 
	enabled rulename "" from matchcase "" move "#mh/mailmh/" 
	enabled rulename "" message matchcase "" move "#mh/mailmh/" 
	| subject matchcase "" 
	| from matchcase "" 
	| message matchcase "" 

Mode d'Emploi :

Start building your rule with one of the three 'enabled rulename....' 
segments, depending on whether the first condition of your rule is on Subject, 
From or Message. If your rule is on Message Body, Any Header etc adjust to 
suit.
Add | subject..., | from.... and | message...  segments to match all the 
FieldA, FieldB, etc in the Kmail rule, to build the skeleton of the rule.
Copy and paste the name, contentsA, B etc. and action-arg strings from kmailrc 
in their places between the "" in your rule skeleton.
And Presto, your rule is done. If your rule depends on all conditions being 
fulfilled together, replace all the '|' of the rule with '&'. If you want your 
rule to be case-sensitive, use 'match' instead of 'matchcase'.

While a rule in KMail is limited to eight conditions, there does not seem to 
be any such limitation in Claws-Mail, which means that if you were compelled 
in KMail to split a rule in several rules doing the same action, you can bring 
them all together in Claws-Mail.

To check for mis-pasted or forgotten strings, search your file for the strings 
'""' and 'mailmh/"'.

Once you have finished editing matcherrc, you will have to restart Claws-Mail 
for the new filter rules to be taken into account.

enabled rulename "test1" subject matchcase "Test2" move "#mh/mailmh/trash" 
mark_as_read
enabled rulename "test2" from matchcase "olgiati" & subject matchcase "test" & 
subject match "Case Sensitive" & from regexpcase "ABC*"
 & headers_part matchcase "headers" & body_part matchcase "body" & message 
matchcase "whole message" delete


A quick syntax and vocabulary :

enabled | disabled : whether the rule is active or not.

rulename "string" : the identifier of the rule.

[ from | subject | message | body_part | headers_part ] [match | matchcase | 
regexpcase ] "string" Where to look for the string, and how (case sensitive, 
insensitive, regular expression) A tilde ~ at the beginning implies a 
negation.of the condition. | means OR, & means AND and the two should not 
AFAIK be mixed in a rule.

[move "#mh/mailmh/string" | delete] : move message to the mail folder string, 
or delete it.
 




More information about the Users mailing list