Akonadi

collectionstatsfetchhandler.cpp
1 /***************************************************************************
2  * Copyright (C) 2006 by Ingo Kloecker <[email protected]> *
3  * *
4  * This program is free software; you can redistribute it and/or modify *
5  * it under the terms of the GNU Library General Public License as *
6  * published by the Free Software Foundation; either version 2 of the *
7  * License, or (at your option) any later version. *
8  * *
9  * This program is distributed in the hope that it will be useful, *
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
12  * GNU General Public License for more details. *
13  * *
14  * You should have received a copy of the GNU Library General Public *
15  * License along with this program; if not, write to the *
16  * Free Software Foundation, Inc., *
17  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
18  ***************************************************************************/
19 
20 #include "collectionstatsfetchhandler.h"
21 
22 #include "connection.h"
23 #include "global.h"
24 #include "handlerhelper.h"
25 #include "akonadi.h"
26 #include "storage/datastore.h"
27 #include "storage/collectionstatistics.h"
28 
29 #include <private/scope_p.h>
30 
31 using namespace Akonadi;
32 using namespace Akonadi::Server;
33 
34 CollectionStatsFetchHandler::CollectionStatsFetchHandler(AkonadiServer &akonadi)
35  : Handler(akonadi)
36 {}
37 
38 bool CollectionStatsFetchHandler::parseStream()
39 {
40  const auto &cmd = Protocol::cmdCast<Protocol::FetchCollectionStatsCommand>(m_command);
41 
42  const Collection col = HandlerHelper::collectionFromScope(cmd.collection(), connection()->context());
43  if (!col.isValid()) {
44  return failureResponse(QStringLiteral("No status for this folder"));
45  }
46 
47  const auto stats = akonadi().collectionStatistics().statistics(col);
48  if (stats.count == -1) {
49  return failureResponse(QStringLiteral("Failed to query statistics."));
50  }
51 
52  Protocol::FetchCollectionStatsResponse resp;
53  resp.setCount(stats.count);
54  resp.setUnseen(stats.count - stats.read);
55  resp.setSize(stats.size);
56  return successResponse(std::move(resp));
57 }
The handler interfaces describes an entity capable of handling an AkonadiIMAP command.
Definition: handler.h:48
Represents a collection of PIM items.
Definition: collection.h:76
Helper integration between Akonadi and Qt.
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Fri Jun 5 2020 23:08:54 by doxygen 1.8.11 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.