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

mailcommon

  • sources
  • kde-4.12
  • kdepim
  • mailcommon
  • folder
foldercollectionmonitor.cpp
Go to the documentation of this file.
1 /*
2  Copyright (c) 2009, 2010, 2011 Montel Laurent <montel@kde.org>
3 
4  This program is free software; you can redistribute it and/or modify it
5  under the terms of the GNU General Public License, version 2, as
6  published by the Free Software Foundation.
7 
8  This program is distributed in the hope that it will be useful, but
9  WITHOUT ANY WARRANTY; without even the implied warranty of
10  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11  General Public License for more details.
12 
13  You should have received a copy of the GNU General Public License along
14  with this program; if not, write to the Free Software Foundation, Inc.,
15  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16 */
17 
18 #include "foldercollectionmonitor.h"
19 #include "util/mailutil.h"
20 #include "foldercollection.h"
21 #include "collectionpage/expirecollectionattribute.h"
22 
23 #include <Akonadi/ChangeRecorder>
24 #include <Akonadi/Collection>
25 #include <Akonadi/CollectionFetchScope>
26 #include <Akonadi/CollectionModel>
27 #include <Akonadi/EntityTreeModel>
28 #include <Akonadi/Item>
29 #include <Akonadi/ItemDeleteJob>
30 #include <Akonadi/ItemFetchJob>
31 #include <Akonadi/ItemFetchScope>
32 #include <Akonadi/KMime/MessageParts>
33 
34 #include <KMime/KMimeMessage>
35 
36 namespace MailCommon {
37 
38 FolderCollectionMonitor::FolderCollectionMonitor( Akonadi::Session *session, QObject *parent )
39  : QObject( parent )
40 {
41  // monitor collection changes
42  mMonitor = new Akonadi::ChangeRecorder( this );
43  mMonitor->setSession(session);
44  mMonitor->setCollectionMonitored( Akonadi::Collection::root() );
45  mMonitor->fetchCollectionStatistics( true );
46  mMonitor->collectionFetchScope().setIncludeStatistics( true );
47  mMonitor->fetchCollection( true );
48  mMonitor->setAllMonitored( true );
49  mMonitor->setMimeTypeMonitored( KMime::Message::mimeType() );
50 #ifdef MERGE_KNODE_IN_KMAIL
51  mMonitor->setMimeTypeMonitored( QString::fromLatin1("message/news") );
52 #endif
53  mMonitor->setResourceMonitored( "akonadi_search_resource", true );
54  mMonitor->setResourceMonitored( "akonadi_nepomuktag_resource", true );
55  mMonitor->itemFetchScope().fetchPayloadPart( Akonadi::MessagePart::Envelope );
56  mMonitor->itemFetchScope().setFetchModificationTime( false );
57  mMonitor->itemFetchScope().setFetchRemoteIdentification( false );
58 }
59 
60 FolderCollectionMonitor::~FolderCollectionMonitor()
61 {
62 }
63 
64 Akonadi::ChangeRecorder *FolderCollectionMonitor::monitor() const
65 {
66  return mMonitor;
67 }
68 
69 void FolderCollectionMonitor::expireAllFolders( bool immediate,
70  QAbstractItemModel *collectionModel )
71 {
72  if ( collectionModel ) {
73  expireAllCollection( collectionModel, immediate );
74  }
75 }
76 
77 void FolderCollectionMonitor::expireAllCollection( const QAbstractItemModel *model,
78  bool immediate,
79  const QModelIndex &parentIndex )
80 {
81  const int rowCount = model->rowCount( parentIndex );
82  for ( int row = 0; row < rowCount; ++row ) {
83  const QModelIndex index = model->index( row, 0, parentIndex );
84  const Akonadi::Collection collection =
85  model->data(
86  index, Akonadi::CollectionModel::CollectionRole ).value<Akonadi::Collection>();
87 
88  if ( !collection.isValid() || Util::isVirtualCollection( collection ) ) {
89  continue;
90  }
91 
92  bool mustDeleteExpirationAttribute = false;
93  MailCommon::ExpireCollectionAttribute *attr =
94  MailCommon::ExpireCollectionAttribute::expirationCollectionAttribute(
95  collection, mustDeleteExpirationAttribute );
96 
97  if ( attr->isAutoExpire() ) {
98  MailCommon::Util::expireOldMessages( collection, immediate );
99  }
100 
101  if ( model->rowCount( index ) > 0 ) {
102  expireAllCollection( model, immediate, index );
103  }
104 
105  if ( mustDeleteExpirationAttribute ) {
106  delete attr;
107  }
108  }
109 }
110 
111 void FolderCollectionMonitor::expunge( const Akonadi::Collection & col, bool sync )
112 {
113  if ( col.isValid() ) {
114  Akonadi::ItemDeleteJob *job = new Akonadi::ItemDeleteJob( col, this );
115  connect( job, SIGNAL(result(KJob*)), this, SLOT(slotDeleteJob(KJob*)) );
116  if ( sync ) {
117  job->exec();
118  }
119  } else {
120  kDebug() << " Try to expunge an invalid collection :" << col;
121  }
122 }
123 
124 void FolderCollectionMonitor::slotDeleteJob( KJob *job )
125 {
126  Util::showJobErrorMessage( job );
127 }
128 
129 }
130 
131 #include "foldercollectionmonitor.moc"
expirecollectionattribute.h
foldercollection.h
MailCommon::FolderCollectionMonitor::expireAllFolders
void expireAllFolders(bool immediate, QAbstractItemModel *collectionModel)
Definition: foldercollectionmonitor.cpp:69
MailCommon::ExpireCollectionAttribute::expirationCollectionAttribute
static ExpireCollectionAttribute * expirationCollectionAttribute(const Akonadi::Collection &collection, bool &mustDeleteExpirationAttribute)
Definition: expirecollectionattribute.cpp:182
MailCommon::ExpireCollectionAttribute
Definition: expirecollectionattribute.h:29
MailCommon::Util::isVirtualCollection
MAILCOMMON_EXPORT bool isVirtualCollection(const Akonadi::Collection &col)
Definition: mailutil.cpp:96
QObject
MailCommon::ExpireCollectionAttribute::isAutoExpire
bool isAutoExpire() const
Returns true if this folder automatically expires old messages.
Definition: expirecollectionattribute.cpp:86
foldercollectionmonitor.h
MailCommon::FolderCollectionMonitor::expireAllCollection
void expireAllCollection(const QAbstractItemModel *model, bool immediate, const QModelIndex &parentIndex=QModelIndex())
Definition: foldercollectionmonitor.cpp:77
MailCommon::FolderCollectionMonitor::expunge
void expunge(const Akonadi::Collection &, bool sync=false)
Definition: foldercollectionmonitor.cpp:111
QAbstractItemModel
MailCommon::FolderCollectionMonitor::FolderCollectionMonitor
FolderCollectionMonitor(Akonadi::Session *session, QObject *parent=0)
Definition: foldercollectionmonitor.cpp:38
MailCommon::FolderCollectionMonitor::monitor
Akonadi::ChangeRecorder * monitor() const
Definition: foldercollectionmonitor.cpp:64
MailCommon::Util::showJobErrorMessage
MAILCOMMON_EXPORT bool showJobErrorMessage(KJob *job)
Definition: mailutil.cpp:136
MailCommon::FolderCollectionMonitor::~FolderCollectionMonitor
~FolderCollectionMonitor()
Definition: foldercollectionmonitor.cpp:60
MailCommon::Util::expireOldMessages
MAILCOMMON_EXPORT void expireOldMessages(const Akonadi::Collection &collection, bool immediate)
Definition: mailutil.cpp:603
mailutil.h
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 22:55:14 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

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