You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

229 lines
7.5 KiB

/* -*- mode: C++; c-file-style: "gnu" -*-
* Mail Filter Rule : incoming mail is sent trough the list of mail filter
* rules before it is placed in the associated mail folder (usually "inbox").
* This class represents one mail filter rule.
*
* Author: Stefan Taferner <taferner@kde.org>
* This code is under GPL
*/
#ifndef kmfilter_h
#define kmfilter_h
#include "kmsearchpattern.h"
#include "kmpopheaders.h"
#include <qptrlist.h>
class QString;
class KConfig;
class KMMessage;
class KMFilterAction;
class KMFolder;
// maximum number of filter actions per filter
const int FILTER_MAX_ACTIONS = 8;
class KMFilter
{
public:
/** Result codes returned by @ref process. They mean:
@param GoOn Everything OK. You are still the owner of the
message and you should continue applying filter actions to this
message.
@param CriticalError A critical error occurred (e.g. "disk full").
@param NoResult For internal use only!
*/
enum ReturnCode { NoResult, GoOn, CriticalError };
/** Constructor that initializes from given config file, if given.
* Filters are stored one by one in config groups, i.e. one filter, one group.
* The config group has to be preset if config is not 0. */
KMFilter( KConfig* aConfig=0 , bool popFilter = false);
/** Copy constructor. Constructs a deep copy of @p aFilter. */
KMFilter( const KMFilter & other );
/** Cleanup. */
~KMFilter() {}
/** Equivalent to @pattern()->name(). @return name of the filter */
QString name() const {
return mPattern.name();
}
/** Execute the filter action(s) on the given message.
Returns:
@li 2 if a critical error occurred,
@li 1 if the caller is still
the owner of the message,
@li 0 if processed successfully.
@param msg The message to which the actions should be applied.
@param stopIt Contains
TRUE if the caller may apply other filters and FALSE if he shall
stop the filtering of this message.
*/
ReturnCode execActions( KMMessage* msg, bool& stopIt ) const ;
/** Determines if the filter depends on the body of the message
*/
bool requiresBody(KMMsgBase* msgBase);
/** No descriptions */
KMPopFilterAction action();
/** No descriptions */
void setAction(const KMPopFilterAction aAction);
/** Write contents to given config file. The config group (see the
constructor above) has to be preset. The config object will be
deleted by higher levels, so it is not allowed to store a
pointer to it anywhere inside this function. */
void writeConfig( KConfig* config ) const;
/** Initialize from given config file. The config group (see
constructor above) has to be preset. The config object will be
deleted by higher levels, so it is not allowed to store a
pointer to it anywhere inside this function. */
void readConfig( KConfig* config );
/** Remove empty rules (and actions one day). */
void purify();
/** Check for empty pattern and action list. */
bool isEmpty() const;
/** Provides a reference to the internal action list. If your used
the @p setAction() and @p action() functions before, please
convert to using myFilter->actions()->at() and friends now. */
QPtrList<KMFilterAction>* actions() { return &mActions; }
/** Provides a reference to the internal action list. Const version. */
const QPtrList<KMFilterAction>* actions() const { return &mActions; }
/** Provides a reference to the internal pattern. If you used the
@p matches() function before, please convert to using
myFilter->pattern()->matches() now. */
KMSearchPattern* pattern() { return &mPattern; }
/** Provides a reference to the internal pattern. If you used the
@p matches() function before, please convert to using
myFilter->pattern()->matches() now. */
const KMSearchPattern* pattern() const { return &mPattern; }
/** Set whether this filter should be applied on
outbound messages (@p aApply == TRUE) or not.
@see applyOnOutbound applyOnInbound setApplyOnInbound
*/
void setApplyOnOutbound( bool aApply=TRUE ) { bApplyOnOutbound = aApply; }
/** @return TRUE if this filter should be applied on
outbound messages, FALSE otherwise.
@see setApplyOnOutbound applyOnInbound setApplyOnInbound
*/
bool applyOnOutbound() const { return bApplyOnOutbound; }
/** Set whether this filter should be applied on
inbound messages (@p aApply == TRUE) or not.
@see setApplyOnOutbound applyOnInbound applyOnOutbound
*/
void setApplyOnInbound( bool aApply=TRUE ) { bApplyOnInbound = aApply; }
/** @return TRUE if this filter should be applied on
inbound messages, FALSE otherwise.
@see setApplyOnOutbound applyOnOutbound setApplyOnInbound
*/
bool applyOnInbound() const { return bApplyOnInbound; }
/** Set whether this filter should be applied on
explicit (CTRL-J) filtering (@p aApply == TRUE) or not.
@see setApplyOnOutbound applyOnInbound applyOnOutbound
*/
void setApplyOnExplicit( bool aApply=TRUE ) { bApplyOnExplicit = aApply; }
/** @return TRUE if this filter should be applied on
explicit (CTRL-J) filtering, FALSE otherwise.
@see setApplyOnOutbound applyOnOutbound setApplyOnInbound
*/
bool applyOnExplicit() const { return bApplyOnExplicit; }
void setStopProcessingHere( bool aStop ) { bStopProcessingHere = aStop; }
bool stopProcessingHere() const { return bStopProcessingHere; }
/** Set whether this filter should be plugged into the filter menu.
*/
void setConfigureShortcut( bool aShort ) {
bConfigureShortcut = aShort;
bConfigureToolbar = bConfigureToolbar && bConfigureShortcut;
}
/** @return TRUE if this filter should be plugged into the filter menu,
FALSE otherwise.
@see setConfigureShortcut
*/
bool configureShortcut() const { return bConfigureShortcut; }
/** Set whether this filter should be plugged into the toolbar.
This can be done only if a shortcut is defined.
@see setConfigureShortcut
*/
void setConfigureToolbar( bool aTool ) {
bConfigureToolbar = aTool && bConfigureShortcut;
}
/** @return TRUE if this filter should be plugged into the toolbar,
FALSE otherwise.
@see setConfigureToolbar
*/
bool configureToolbar() const { return bConfigureToolbar; }
/** Set the icon to be used if plugged into the filter menu
or toolbar. Default is the gear icon.
@see setConfigureShortcut setConfigureToolbar
*/
void setIcon( QString icon ) { mIcon = icon; }
/** @return The name of the icon to be used.
@see setIcon
*/
QString icon() const { return mIcon; }
/**
* Called from the filter manager when a folder is moved.
* Tests if the folder aFolder is used in any action. Changes it
* to aNewFolder folder in this case.
* @return TRUE if a change in some action occurred,
* FALSE if no action was affected.
*/
bool folderRemoved( KMFolder* aFolder, KMFolder* aNewFolder );
/** Returns the filter in a human-readable form. useful for
debugging but not much else. Don't use, as it may well go away
in the future... */
#ifndef NDEBUG
const QString asString() const;
#endif
/** No descriptions */
bool isPopFilter() const {
return bPopFilter;
}
private:
KMSearchPattern mPattern;
QPtrList<KMFilterAction> mActions;
KMPopFilterAction mAction;
QString mIcon;
bool bPopFilter : 1;
bool bApplyOnInbound : 1;
bool bApplyOnOutbound : 1;
bool bApplyOnExplicit : 1;
bool bStopProcessingHere : 1;
bool bConfigureShortcut : 1;
bool bConfigureToolbar : 1;
};
#endif /*kmfilter_h*/