summaryrefslogtreecommitdiff
path: root/kimap/storejob.cpp
diff options
context:
space:
mode:
authorChristian Mollekopf <chrigi_1@fastmail.fm>2012-06-25 23:43:13 (GMT)
committerChristian Mollekopf <chrigi_1@fastmail.fm>2012-06-25 23:43:13 (GMT)
commite21e62c14f5aae99d46643065fcb86e2e3abe230 (patch)
tree71d79d2de0b0f82f8b0a6ca3b8b09308d198ed33 /kimap/storejob.cpp
parent172803b38237e38a494aca62fffda918e5799d20 (diff)
downloadlibcalendaring-e21e62c14f5aae99d46643065fcb86e2e3abe230.tar.gz
initial import of kimap from
commit b54a325116b194da090f900c9a538710759eb303 Author: Stephen Kelly <steveire@gmail.com> Date: Sun May 6 20:44:53 2012 +0200 Revert "Port to const QRegExp API." This reverts commit 0ca0dfc7e0ca8095efd0b060d1d5e26ac9ceb379. The qtbase commit requiring this was reverted.
Diffstat (limited to 'kimap/storejob.cpp')
-rw-r--r--kimap/storejob.cpp194
1 files changed, 194 insertions, 0 deletions
diff --git a/kimap/storejob.cpp b/kimap/storejob.cpp
new file mode 100644
index 0000000..7be31c5
--- /dev/null
+++ b/kimap/storejob.cpp
@@ -0,0 +1,194 @@
+/*
+ Copyright (c) 2009 Kevin Ottens <ervin@kde.org>
+
+ This library is free software; you can redistribute it and/or modify it
+ under the terms of the GNU Library General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or (at your
+ option) any later version.
+
+ This library is distributed in the hope that it will be useful, but WITHOUT
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
+ License for more details.
+
+ You should have received a copy of the GNU Library General Public License
+ along with this library; see the file COPYING.LIB. If not, write to the
+ Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ 02110-1301, USA.
+*/
+
+#include "storejob.h"
+
+#include <KDE/KDebug>
+#include <KDE/KLocale>
+
+#include "job_p.h"
+#include "message_p.h"
+#include "session_p.h"
+
+namespace KIMAP
+{
+ class StoreJobPrivate : public JobPrivate
+ {
+ public:
+ StoreJobPrivate( Session *session, const QString& name ) : JobPrivate( session, name ) { }
+ ~StoreJobPrivate() { }
+
+ ImapSet set;
+ bool uidBased;
+ StoreJob::StoreMode mode;
+ MessageFlags flags;
+
+ QMap<int, MessageFlags> resultingFlags;
+ };
+}
+
+using namespace KIMAP;
+
+StoreJob::StoreJob( Session *session )
+ : Job( *new StoreJobPrivate(session, i18n("Store")) )
+{
+ Q_D(StoreJob);
+ d->uidBased = false;
+ d->mode = SetFlags;
+}
+
+StoreJob::~StoreJob()
+{
+}
+
+void StoreJob::setSequenceSet( const ImapSet &set )
+{
+ Q_D(StoreJob);
+ d->set = set;
+}
+
+ImapSet StoreJob::sequenceSet() const
+{
+ Q_D(const StoreJob);
+ return d->set;
+}
+
+void StoreJob::setUidBased(bool uidBased)
+{
+ Q_D(StoreJob);
+ d->uidBased = uidBased;
+}
+
+bool StoreJob::isUidBased() const
+{
+ Q_D(const StoreJob);
+ return d->uidBased;
+}
+
+void StoreJob::setFlags( const MessageFlags &flags )
+{
+ Q_D(StoreJob);
+ d->flags = flags;
+}
+
+MessageFlags StoreJob::flags() const
+{
+ Q_D(const StoreJob);
+ return d->flags;
+}
+
+void StoreJob::setMode( StoreMode mode )
+{
+ Q_D(StoreJob);
+ d->mode = mode;
+}
+
+StoreJob::StoreMode StoreJob::mode() const
+{
+ Q_D(const StoreJob);
+ return d->mode;
+}
+
+QMap<int, MessageFlags> StoreJob::resultingFlags() const
+{
+ Q_D(const StoreJob);
+ return d->resultingFlags;
+}
+
+void StoreJob::doStart()
+{
+ Q_D(StoreJob);
+
+ QByteArray parameters = d->set.toImapSequenceSet()+' ';
+
+ switch ( d->mode ) {
+ case SetFlags:
+ parameters+= "FLAGS";
+ break;
+ case AppendFlags:
+ parameters+= "+FLAGS";
+ break;
+ case RemoveFlags:
+ parameters+= "-FLAGS";
+ break;
+ }
+
+ parameters+=" (";
+ foreach ( const QByteArray &flag, d->flags ) {
+ parameters+=flag+' ';
+ }
+ if (!d->flags.isEmpty()) parameters.chop(1);
+ parameters+=')';
+
+ qDebug("%s", parameters.constData());
+
+ QByteArray command = "STORE";
+ if ( d->uidBased ) {
+ command = "UID "+command;
+ }
+
+ d->tags << d->sessionInternal()->sendCommand( command, parameters );
+}
+
+void StoreJob::handleResponse( const Message &response )
+{
+ Q_D(StoreJob);
+
+ if (handleErrorReplies(response) == NotHandled ) {
+ if ( response.content.size() == 4
+ && response.content[2].toString()=="FETCH"
+ && response.content[3].type()==Message::Part::List ) {
+
+ int id = response.content[1].toString().toInt();
+ qint64 uid = 0;
+ bool uidFound = false;
+ QList<QByteArray> resultingFlags;
+
+ QList<QByteArray> content = response.content[3].toList();
+
+ for ( QList<QByteArray>::ConstIterator it = content.constBegin();
+ it!=content.constEnd(); ++it ) {
+ QByteArray str = *it;
+ ++it;
+
+ if ( str=="FLAGS" ) {
+ if ( (*it).startsWith('(') && (*it).endsWith(')') ) {
+ QByteArray str = *it;
+ str.chop(1);
+ str.remove(0, 1);
+ resultingFlags = str.split(' ');
+ } else {
+ resultingFlags << *it;
+ }
+ } else if ( str=="UID" ) {
+ uid = it->toLongLong(&uidFound);
+ }
+ }
+
+ if ( !d->uidBased ) {
+ d->resultingFlags[id] = resultingFlags;
+ } else if ( uidFound ) {
+ d->resultingFlags[uid] = resultingFlags;
+ } else {
+ kWarning() << "We asked for UID but the server didn't give it back, resultingFlags not stored.";
+ }
+ }
+ }
+}
+