• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdepim API Reference
  • KDE Home
  • Contact Us
 

mailcommon

  • sources
  • kde-4.14
  • kdepim
  • mailcommon
  • filter
  • filteractions
filteractionunsetstatus.cpp
Go to the documentation of this file.
1 /* -*- mode: C++; c-file-style: "gnu" -*-
2 
3  Copyright (c) 2012-2015 Montel Laurent <montel@kde.org>
4 
5  This program is free software; you can redistribute it and/or modify it
6  under the terms of the GNU General Public License, version 2, as
7  published by the Free Software Foundation.
8 
9  This program is distributed in the hope that it will be useful, but
10  WITHOUT ANY WARRANTY; without even the implied warranty of
11  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12  General Public License for more details.
13 
14  You should have received a copy of the GNU General Public License along
15  with this program; if not, write to the Free Software Foundation, Inc.,
16  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 */
18 
19 #include "filteractionunsetstatus.h"
20 
21 #include <KDE/KLocale>
22 using namespace MailCommon;
23 
24 FilterAction* FilterActionUnsetStatus::newAction()
25 {
26  return new FilterActionUnsetStatus;
27 }
28 
29 FilterActionUnsetStatus::FilterActionUnsetStatus( QObject *parent )
30  : FilterActionStatus( QLatin1String("unset status"), i18nc( "action: to unset the status", "Unset Status" ), parent )
31 {
32 }
33 
34 bool FilterActionUnsetStatus::checkIsValid(int &index) const
35 {
36  index = mParameterList.indexOf( mParameter );
37  return ( index < 1 );
38 }
39 
40 bool FilterActionUnsetStatus::isEmpty() const
41 {
42  int index = 0;
43  return checkIsValid(index);
44 }
45 
46 QString FilterActionUnsetStatus::informationAboutNotValidAction() const
47 {
48  //KF5 add i18n
49  return QLatin1String("Status not defined.");
50 }
51 
52 FilterAction::ReturnCode FilterActionUnsetStatus::process(ItemContext &context , bool) const
53 {
54  int index = 0;
55  if ( checkIsValid(index) )
56  return ErrorButGoOn;
57 
58  Akonadi::MessageStatus status;
59  status.setStatusFromFlags( context.item().flags() );
60 
61 
62  Akonadi::MessageStatus newStatus = FilterActionStatus::stati[ index - 1 ];
63  //Laurent unread status doesn't exist. And crash if we use "const Akonadi::Item::Flag flag = *(flags.begin());" etc. => if we unset "unread" we set read
64  if ( newStatus == Akonadi::MessageStatus::statusUnread() ) {
65  Akonadi::MessageStatus oldStatus = status;
66  newStatus.setRead( true );
67  if ( oldStatus != newStatus ) {
68  context.item().setFlags( newStatus.statusFlags() );
69  context.setNeedsFlagStore();
70  }
71  return GoOn;
72  }
73 
74  QSet<QByteArray> flags = newStatus.statusFlags();
75  const Akonadi::Item::Flag flag = *(flags.begin());
76  if ( context.item().hasFlag( flag ) ) {
77  context.item().clearFlag( flag );
78  context.setNeedsFlagStore();
79  }
80  return GoOn;
81 }
82 
83 SearchRule::RequiredPart FilterActionUnsetStatus::requiredPart() const
84 {
85  return SearchRule::Envelope;
86 }
87 
88 QString FilterActionUnsetStatus::sieveCode() const
89 {
90  QString flagCode;
91  const QString parameter = argsAsString();
92  if (parameter == QLatin1String("R")) {
93  flagCode = QLatin1String("\\\\Seen");
94  } else if (parameter == QLatin1String("D")) {
95  flagCode = QLatin1String("\\\\Deleted");
96  } else if (parameter == QLatin1String("A")) {
97  flagCode =QLatin1String("\\\\Answered");
98  } else {
99  qDebug()<<" FilterActionSetStatus::sieveCode() unknown flags"<<parameter;
100  flagCode = parameter;
101  }
102 
103  const QString result = QString::fromLatin1("removeflag \"%1\";").arg(flagCode);
104  return result;
105 }
106 
107 QStringList FilterActionUnsetStatus::sieveRequires() const
108 {
109  return QStringList() << QLatin1String("imap4flags");
110 }
111 
MailCommon::FilterActionUnsetStatus::process
ReturnCode process(ItemContext &context, bool applyOnOutbound) const
Execute action on given message (inside the item context).
Definition: filteractionunsetstatus.cpp:52
MailCommon::FilterActionStatus::argsAsString
QString argsAsString() const
Return extra arguments as string.
Definition: filteractionstatus.cpp:98
MailCommon::FilterAction::GoOn
Go on with applying filter actions.
Definition: filteraction.h:62
MailCommon::FilterActionStatus
Definition: filteractionstatus.h:26
filteractionunsetstatus.h
MailCommon::FilterAction
Abstract base class for mail filter actions.
Definition: filteraction.h:52
MailCommon::FilterActionUnsetStatus::sieveCode
QString sieveCode() const
Definition: filteractionunsetstatus.cpp:88
MailCommon::FilterActionUnsetStatus::isEmpty
bool isEmpty() const
Determines whether this action is valid.
Definition: filteractionunsetstatus.cpp:40
MailCommon::FilterActionWithStringList::mParameterList
QStringList mParameterList
Definition: filteractionwithstringlist.h:85
MailCommon::FilterActionUnsetStatus::informationAboutNotValidAction
QString informationAboutNotValidAction() const
Definition: filteractionunsetstatus.cpp:46
MailCommon::FilterAction::ErrorButGoOn
A non-critical error occurred.
Definition: filteraction.h:63
QObject
MailCommon::FilterActionStatus::stati
static Akonadi::MessageStatus stati[]
Definition: filteractionstatus.h:39
QSet
MailCommon::SearchRule::RequiredPart
RequiredPart
Definition: searchrule.h:79
QString
MailCommon::FilterActionUnsetStatus::newAction
static FilterAction * newAction()
Definition: filteractionunsetstatus.cpp:24
QStringList
QSet::begin
iterator begin()
MailCommon::SearchRule::Envelope
Definition: searchrule.h:80
MailCommon::FilterActionWithString::mParameter
QString mParameter
Definition: filteractionwithstring.h:91
MailCommon::FilterActionUnsetStatus::requiredPart
SearchRule::RequiredPart requiredPart() const
Returns the required part from the item that is needed for the action to operate. ...
Definition: filteractionunsetstatus.cpp:83
MailCommon::FilterAction::ReturnCode
ReturnCode
Describes the possible return codes of filter processing:
Definition: filteraction.h:60
QLatin1String
MailCommon::ItemContext::item
Akonadi::Item & item()
Returns the item of the context.
Definition: itemcontext.cpp:29
context
const char * context
Definition: searchpatternedit.cpp:54
QString::fromLatin1
QString fromLatin1(const char *str, int size)
QStringList::indexOf
int indexOf(const QRegExp &rx, int from) const
MailCommon::ItemContext::setNeedsFlagStore
void setNeedsFlagStore()
Marks that the item's flags has been changed and needs to be written back.
Definition: itemcontext.cpp:54
MailCommon::ItemContext
A helper class for the filtering process.
Definition: itemcontext.h:39
MailCommon::FilterActionUnsetStatus::sieveRequires
QStringList sieveRequires() const
Definition: filteractionunsetstatus.cpp:107
QString::arg
QString arg(qlonglong a, int fieldWidth, int base, const QChar &fillChar) const
MailCommon::FilterActionUnsetStatus::FilterActionUnsetStatus
FilterActionUnsetStatus(QObject *parent=0)
Definition: filteractionunsetstatus.cpp:29
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:31:40 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

mailcommon

Skip menu "mailcommon"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members
  • Related Pages

kdepim API Reference

Skip menu "kdepim API Reference"
  • akonadi_next
  • akregator
  • blogilo
  • calendarsupport
  • console
  •   kabcclient
  •   konsolekalendar
  • kaddressbook
  • kalarm
  •   lib
  • kdgantt2
  • kjots
  • kleopatra
  • kmail
  • knode
  • knotes
  • kontact
  • korgac
  • korganizer
  • ktimetracker
  • libkdepim
  • libkleo
  • libkpgp
  • mailcommon
  • messagelist
  • messageviewer
  • pimprint

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal