summaryrefslogtreecommitdiffstats
path: root/kmail/acljobs.h
diff options
context:
space:
mode:
Diffstat (limited to 'kmail/acljobs.h')
-rw-r--r--kmail/acljobs.h177
1 files changed, 177 insertions, 0 deletions
diff --git a/kmail/acljobs.h b/kmail/acljobs.h
new file mode 100644
index 00000000..0d4a731d
--- /dev/null
+++ b/kmail/acljobs.h
@@ -0,0 +1,177 @@
+/*
+ * acljobs.h
+ *
+ * Copyright (c) 2004 David Faure <faure@kde.org>
+ *
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; version 2 of the License
+ *
+ * This program 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 General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ *
+ * In addition, as a special exception, the copyright holders give
+ * permission to link the code of this program with any edition of
+ * the Qt library by Trolltech AS, Norway (or with modified versions
+ * of Qt that use the same license as Qt), and distribute linked
+ * combinations including the two. You must obey the GNU General
+ * Public License in all respects for all of the code used other than
+ * Qt. If you modify this file, you may extend this exception to
+ * your version of the file, but you are not obligated to do so. If
+ * you do not wish to do so, delete this exception statement from
+ * your version.
+ */
+
+#ifndef KMACLJOBS_H
+#define KMACLJOBS_H
+
+#include <kio/job.h>
+#include <qvaluevector.h>
+
+namespace KMail {
+
+ /// One entry in the ACL list: user and permissions
+ struct ACLListEntry {
+ ACLListEntry() {} // for QValueVector
+ ACLListEntry( const QString& u, const QString& irl, int p )
+ : userId( u ), internalRightsList( irl ), permissions( p ), changed( false ) {}
+ QString userId;
+ QString internalRightsList; ///< protocol-dependent string (e.g. IMAP rights list)
+ int permissions; ///< based on the ACLPermissions enum
+ bool changed; ///< special flag for KMFolderCachedImap
+ };
+
+ typedef QValueVector<ACLListEntry> ACLList;
+
+/**
+ * This namespace contains functions that return jobs for ACL operations.
+ *
+ * The current implementation is tied to IMAP.
+ * If someone wants to extend this to other protocols, turn the class into a namespace
+ * and use virtual methods.
+ */
+namespace ACLJobs {
+
+ /// Bitfield modelling the possible permissions.
+ /// This is modelled after the imap4 permissions except that Read is "rs".
+ /// The semantics of the bits is protocol-dependent.
+ enum ACLPermissions {
+ List = 1,
+ Read = 2,
+ WriteFlags = 4,
+ Insert = 8,
+ Create = 16,
+ Delete = 32,
+ Administer = 64,
+ Post = 128,
+ WriteSeenFlag = 256,
+ // alias for "all read/write permissions except admin"
+ AllWrite = List | Read | WriteFlags | Insert | Post | Create | Delete | WriteSeenFlag,
+ // alias for "all permissions"
+ All = List | Read | WriteFlags | Insert | Post | Create | Delete | Administer | WriteSeenFlag
+ };
+ /// Set the permissions for a given user on a given url
+ KIO::SimpleJob* setACL( KIO::Slave* slave, const KURL& url, const QString& user, unsigned int permissions );
+
+ class DeleteACLJob;
+ /// Delete the permissions for a given user on a given url
+ DeleteACLJob* deleteACL( KIO::Slave* slave, const KURL& url, const QString& user );
+
+ class GetACLJob;
+ /// List all ACLs for a given url
+ GetACLJob* getACL( KIO::Slave* slave, const KURL& url );
+
+ class GetUserRightsJob;
+ /// Get the users' rights for a given url
+ GetUserRightsJob* getUserRights( KIO::Slave* slave, const KURL& url );
+
+ class MultiSetACLJob;
+ /// Set and delete a list of permissions for different users on a given url
+ MultiSetACLJob* multiSetACL( KIO::Slave* slave, const KURL& url, const ACLList& acl );
+
+ /// List all ACLs for a given url
+ class GetACLJob : public KIO::SimpleJob
+ {
+ Q_OBJECT
+ public:
+ GetACLJob( const KURL& url, const QByteArray &packedArgs,
+ bool showProgressInfo );
+
+ const ACLList& entries() const { return m_entries; }
+
+ protected slots:
+ void slotInfoMessage( KIO::Job*, const QString& );
+ private:
+ ACLList m_entries;
+ };
+
+ /// Get the users' rights for a given url
+ class GetUserRightsJob : public KIO::SimpleJob
+ {
+ Q_OBJECT
+ public:
+ GetUserRightsJob( const KURL& url, const QByteArray &packedArgs,
+ bool showProgressInfo );
+ unsigned int permissions() const { return m_permissions; }
+
+ protected slots:
+ void slotInfoMessage( KIO::Job*, const QString& );
+ private:
+ unsigned int m_permissions;
+ };
+
+ /// Delete the permissions for a given user on a given url
+ /// This class only exists to store the userid in the job
+ class DeleteACLJob : public KIO::SimpleJob
+ {
+ Q_OBJECT
+ public:
+ DeleteACLJob( const KURL& url, const QString& userId,
+ const QByteArray &packedArgs,
+ bool showProgressInfo );
+
+ QString userId() const { return mUserId; }
+
+ private:
+ QString mUserId;
+ };
+
+ /// Set and delete a list of permissions for different users on a given url
+ class MultiSetACLJob : public KIO::Job {
+ Q_OBJECT
+
+ public:
+ MultiSetACLJob( KIO::Slave* slave, const KURL& url, const ACLList& acl, bool showProgressInfo );
+
+ signals:
+ // Emitted when a given user's permissions were successfully changed.
+ // This allows the caller to keep track of what exactly was done (and handle errors better)
+ void aclChanged( const QString& userId, int permissions );
+
+ protected slots:
+ virtual void slotStart();
+ virtual void slotResult( KIO::Job *job );
+
+ private:
+ KIO::Slave* mSlave;
+ const KURL mUrl;
+ const ACLList mACLList;
+ ACLList::const_iterator mACLListIterator;
+ };
+
+
+#ifndef NDEBUG
+ QString permissionsToString( unsigned int permissions );
+#endif
+}
+
+} // namespace
+
+#endif /* KMACLJOBS_H */