/* * acljobs.h * * Copyright (c) 2004 David Faure * * * 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 TQt library by Trolltech AS, Norway (or with modified versions * of TQt that use the same license as TQt), 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 * TQt. 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 #include namespace KMail { /// One entry in the ACL list: user and permissions struct ACLListEntry { ACLListEntry() {} // for TQValueVector ACLListEntry( const TQString& u, const TQString& irl, int p ) : userId( u ), internalRightsList( irl ), permissions( p ), changed( false ) {} TQString userId; TQString internalRightsList; ///< protocol-dependent string (e.g. IMAP rights list) int permissions; ///< based on the ACLPermissions enum bool changed; ///< special flag for KMFolderCachedImap }; typedef TQValueVector 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 { // Used by KMFolderCachedImap and KMFolderImap, no better place for that yet, until we have a // common base class for both enum ACLFetchState { NotFetchedYet, ///< The user rights/ACL have not been fetched from the server yet, we don't know them Ok, ///< The user rights/ACL have been fetched from the server sucessfully FetchFailed ///< The attempt to fetch the user rights/ACL from the server failed }; /// 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 TDEIO::SimpleJob* setACL( TDEIO::Slave* slave, const KURL& url, const TQString& user, unsigned int permissions ); class DeleteACLJob; /// Delete the permissions for a given user on a given url DeleteACLJob* deleteACL( TDEIO::Slave* slave, const KURL& url, const TQString& user ); class GetACLJob; /// List all ACLs for a given url GetACLJob* getACL( TDEIO::Slave* slave, const KURL& url ); class GetUserRightsJob; /// Get the users' rights for a given url GetUserRightsJob* getUserRights( TDEIO::Slave* slave, const KURL& url ); class MultiSetACLJob; /// Set and delete a list of permissions for different users on a given url MultiSetACLJob* multiSetACL( TDEIO::Slave* slave, const KURL& url, const ACLList& acl ); /// List all ACLs for a given url class GetACLJob : public TDEIO::SimpleJob { Q_OBJECT public: GetACLJob( const KURL& url, const TQByteArray &packedArgs, bool showProgressInfo ); const ACLList& entries() const { return m_entries; } protected slots: void slotInfoMessage( TDEIO::Job*, const TQString& ); private: ACLList m_entries; }; /// Get the users' rights for a given url class GetUserRightsJob : public TDEIO::SimpleJob { Q_OBJECT public: GetUserRightsJob( const KURL& url, const TQByteArray &packedArgs, bool showProgressInfo ); unsigned int permissions() const { return m_permissions; } protected slots: void slotInfoMessage( TDEIO::Job*, const TQString& ); 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 TDEIO::SimpleJob { Q_OBJECT public: DeleteACLJob( const KURL& url, const TQString& userId, const TQByteArray &packedArgs, bool showProgressInfo ); TQString userId() const { return mUserId; } private: TQString mUserId; }; /// Set and delete a list of permissions for different users on a given url class MultiSetACLJob : public TDEIO::Job { Q_OBJECT public: MultiSetACLJob( TDEIO::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 TQString& userId, int permissions ); protected slots: virtual void slotStart(); virtual void slotResult( TDEIO::Job *job ); private: TDEIO::Slave* mSlave; const KURL mUrl; const ACLList mACLList; ACLList::const_iterator mACLListIterator; }; #ifndef NDEBUG TQString permissionsToString( unsigned int permissions ); #endif } } // namespace #endif /* KMACLJOBS_H */