1/*
2 Copyright (c) 2008,2009 Volker Krause <vkrause@kde.org>
3
4 This library is free software; you can redistribute it and/or modify it
5 under the terms of the GNU Library General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or (at your
7 option) any later version.
8
9 This library is distributed in the hope that it will be useful, but WITHOUT
10 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
12 License for more details.
13
14 You should have received a copy of the GNU Library General Public License
15 along with this library; see the file COPYING.LIB. If not, write to the
16 Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
17 02110-1301, USA.
18*/
19
20#ifndef AKONADI_MOVEJOBIMPL_P_H
21#define AKONADI_MOVEJOBIMPL_P_H
22
23#include "collection.h"
24#include "job.h"
25#include "job_p.h"
26#include "protocolhelper_p.h"
27
28#include <KLocalizedString>
29
30namespace Akonadi {
31
32/** Shared implementation details between item and collection move jobs. */
33template <typename T, typename MoveJob> class MoveJobImpl : public JobPrivate
34{
35public:
36 MoveJobImpl(Job *parent)
37 : JobPrivate(parent)
38 {
39 }
40
41 inline void sendCommand(const char *asapCommand)
42 {
43 MoveJob *q = static_cast<MoveJob *>(q_func()); // Job would be enough already, but then we don't have access to the non-public stuff...
44 if (objectsToMove.isEmpty()) {
45 q->setError(Job::Unknown);
46 q->setErrorText(i18n("No objects specified for moving"));
47 q->emitResult();
48 return;
49 }
50 if (!destination.isValid() && destination.remoteId().isEmpty()) {
51 q->setError(Job::Unknown);
52 q->setErrorText(i18n("No valid destination specified"));
53 q->emitResult();
54 return;
55 }
56
57 QByteArray command = newTag();
58 try {
59 command += ProtocolHelper::entitySetToByteArray(objectsToMove, asapCommand);
60 } catch (const std::exception &e) {
61 q->setError(Job::Unknown);
62 q->setErrorText(QString::fromUtf8(e.what()));
63 q->emitResult();
64 return;
65 }
66 command += ' ';
67 // with all the checks done before this indicates now whether this is a UID or RID based operation
68 if (objectsToMove.first().isValid()) {
69 command += QByteArray::number(destination.id());
70 } else {
71 command += ImapParser::quote(destination.remoteId().toUtf8());
72 }
73
74 // Source is optional
75 if (source.isValid()) {
76 command += ' ' + QByteArray::number(source.id());
77 } else if (!source.remoteId().isEmpty()) {
78 command += ' ' + ImapParser::quote(source.remoteId().toUtf8());
79 }
80 command += '\n';
81 writeData(command);
82 }
83
84 typename T::List objectsToMove;
85 Collection destination;
86 Collection source;
87};
88
89}
90
91#endif
92