Akonadi

itemfetchhandler.cpp
1 /***************************************************************************
2  * Copyright (C) 2006 by Tobias Koenig <[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 "itemfetchhandler.h"
21 
22 #include "connection.h"
23 #include "itemfetchhelper.h"
24 #include "cachecleaner.h"
25 
26 using namespace Akonadi;
27 using namespace Akonadi::Server;
28 
29 ItemFetchHandler::ItemFetchHandler(AkonadiServer &akonadi)
30  : Handler(akonadi)
31 {}
32 
33 bool ItemFetchHandler::parseStream()
34 {
35  const auto &cmd = Protocol::cmdCast<Protocol::FetchItemsCommand>(m_command);
36 
37  CommandContext context = connection()->context();
38  if (!context.setScopeContext(cmd.scopeContext())) {
39  return failureResponse(QStringLiteral("Invalid scope context"));
40  }
41 
42  // We require context in case we do RID fetch
43  if (context.isEmpty() && cmd.scope().scope() == Scope::Rid) {
44  return failureResponse(QStringLiteral("No FETCH context specified"));
45  }
46 
47  CacheCleanerInhibitor inhibitor(akonadi());
48 
49  ItemFetchHelper fetchHelper(connection(), context, cmd.scope(), cmd.itemFetchScope(), cmd.tagFetchScope(), akonadi());
50  if (!fetchHelper.fetchItems()) {
51  return failureResponse(QStringLiteral("Failed to fetch items"));
52  }
53 
54  return successResponse<Protocol::FetchItemsResponse>();
55 }
The handler interfaces describes an entity capable of handling an AkonadiIMAP command.
Definition: handler.h:48
A RAII helper class to temporarily stop the CacheCleaner.
Definition: cachecleaner.h:46
Helper integration between Akonadi and Qt.
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Sat Jun 6 2020 23:09:05 by doxygen 1.8.11 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.