Overview

Packages

  • IMP

Classes

  • IMP
  • IMP_Ajax_Addresses
  • IMP_Ajax_Application
  • IMP_Ajax_Application_Compose
  • IMP_Ajax_Application_Handler_Common
  • IMP_Ajax_Application_Handler_ComposeAttach
  • IMP_Ajax_Application_Handler_Draft
  • IMP_Ajax_Application_Handler_Dynamic
  • IMP_Ajax_Application_Handler_ImageUnblock
  • IMP_Ajax_Application_Handler_Mboxtoggle
  • IMP_Ajax_Application_Handler_Passphrase
  • IMP_Ajax_Application_Handler_Remote
  • IMP_Ajax_Application_Handler_RemotePrefs
  • IMP_Ajax_Application_Handler_Search
  • IMP_Ajax_Application_Handler_Smartmobile
  • IMP_Ajax_Application_ListMessages
  • IMP_Ajax_Application_ShowMessage
  • IMP_Ajax_Application_Viewport
  • IMP_Ajax_Application_Viewport_Error
  • IMP_Ajax_Imple_ImportEncryptKey
  • IMP_Ajax_Imple_ItipRequest
  • IMP_Ajax_Imple_PassphraseDialog
  • IMP_Ajax_Imple_VcardImport
  • IMP_Ajax_Queue
  • IMP_Api
  • IMP_Application
  • IMP_Auth
  • IMP_Basic_Base
  • IMP_Basic_Compose
  • IMP_Basic_Contacts
  • IMP_Basic_Error
  • IMP_Basic_Folders
  • IMP_Basic_Listinfo
  • IMP_Basic_Mailbox
  • IMP_Basic_Message
  • IMP_Basic_Pgp
  • IMP_Basic_Saveimage
  • IMP_Basic_Search
  • IMP_Basic_Searchbasic
  • IMP_Basic_Smime
  • IMP_Basic_Thread
  • IMP_Block_Newmail
  • IMP_Block_Summary
  • IMP_Compose
  • IMP_Compose_Attachment
  • IMP_Compose_Attachment_Linked_Metadata
  • IMP_Compose_Attachment_Metadata
  • IMP_Compose_Attachment_Storage
  • IMP_Compose_Attachment_Storage_AutoDetermine
  • IMP_Compose_Attachment_Storage_Temp
  • IMP_Compose_Attachment_Storage_VfsLinked
  • IMP_Compose_Exception
  • IMP_Compose_Exception_Address
  • IMP_Compose_HtmlSignature
  • IMP_Compose_Link
  • IMP_Compose_LinkedAttachment
  • IMP_Compose_Ui
  • IMP_Compose_View
  • IMP_Contacts
  • IMP_Contacts_Avatar_Addressbook
  • IMP_Contacts_Avatar_Gravatar
  • IMP_Contacts_Avatar_Unknown
  • IMP_Contacts_Flag_Host
  • IMP_Contacts_Image
  • IMP_Contents
  • IMP_Contents_InlineOutput
  • IMP_Contents_View
  • IMP_Crypt_Pgp
  • IMP_Crypt_Smime
  • IMP_Dynamic_AddressList
  • IMP_Dynamic_Base
  • IMP_Dynamic_Compose
  • IMP_Dynamic_Compose_Common
  • IMP_Dynamic_Helper_Base
  • IMP_Dynamic_Mailbox
  • IMP_Dynamic_Message
  • IMP_Exception
  • IMP_Factory_AuthImap
  • IMP_Factory_Compose
  • IMP_Factory_ComposeAtc
  • IMP_Factory_Contacts
  • IMP_Factory_Contents
  • IMP_Factory_Flags
  • IMP_Factory_Ftree
  • IMP_Factory_Identity
  • IMP_Factory_Imap
  • IMP_Factory_Mail
  • IMP_Factory_MailAutoconfig
  • IMP_Factory_Mailbox
  • IMP_Factory_MailboxCache
  • IMP_Factory_MailboxList
  • IMP_Factory_Maillog
  • IMP_Factory_MimeViewer
  • IMP_Factory_Pgp
  • IMP_Factory_PrefsSort
  • IMP_Factory_Quota
  • IMP_Factory_Search
  • IMP_Factory_Sentmail
  • IMP_Factory_Smime
  • IMP_Factory_Spam
  • IMP_Filter
  • IMP_Flag_Base
  • IMP_Flag_Imap
  • IMP_Flag_Imap_Answered
  • IMP_Flag_Imap_Deleted
  • IMP_Flag_Imap_Draft
  • IMP_Flag_Imap_Flagged
  • IMP_Flag_Imap_Forwarded
  • IMP_Flag_Imap_Junk
  • IMP_Flag_Imap_NotJunk
  • IMP_Flag_Imap_Seen
  • IMP_Flag_System_Attachment
  • IMP_Flag_System_Encrypted
  • IMP_Flag_System_HighPriority
  • IMP_Flag_System_List
  • IMP_Flag_System_LowPriority
  • IMP_Flag_System_Match_Address
  • IMP_Flag_System_Match_Flag
  • IMP_Flag_System_Match_Header
  • IMP_Flag_System_Personal
  • IMP_Flag_System_Signed
  • IMP_Flag_System_Unseen
  • IMP_Flag_User
  • IMP_Flags
  • IMP_Ftree
  • IMP_Ftree_Account
  • IMP_Ftree_Account_Imap
  • IMP_Ftree_Account_Inboxonly
  • IMP_Ftree_Account_Remote
  • IMP_Ftree_Account_Vfolder
  • IMP_Ftree_Element
  • IMP_Ftree_Eltdiff
  • IMP_Ftree_Iterator
  • IMP_Ftree_Iterator_Ancestors
  • IMP_Ftree_IteratorFilter
  • IMP_Ftree_IteratorFilter_Children
  • IMP_Ftree_IteratorFilter_Containers
  • IMP_Ftree_IteratorFilter_Expanded
  • IMP_Ftree_IteratorFilter_Invisible
  • IMP_Ftree_IteratorFilter_Mailboxes
  • IMP_Ftree_IteratorFilter_Nonimap
  • IMP_Ftree_IteratorFilter_Polled
  • IMP_Ftree_IteratorFilter_Remote
  • IMP_Ftree_IteratorFilter_Special
  • IMP_Ftree_IteratorFilter_Subscribed
  • IMP_Ftree_IteratorFilter_Vfolder
  • IMP_Ftree_Prefs
  • IMP_Ftree_Prefs_Expanded
  • IMP_Ftree_Prefs_Poll
  • IMP_Ftree_Select
  • IMP_Images
  • IMP_Imap
  • IMP_Imap_Acl
  • IMP_Imap_Cache_Wrapper
  • IMP_Imap_Config
  • IMP_Imap_Exception
  • IMP_Imap_Password
  • IMP_Imap_PermanentFlags
  • IMP_Imap_Remote
  • IMP_Indices
  • IMP_Indices_Mailbox
  • IMP_LoginTasks_SystemTask_GarbageCollection
  • IMP_LoginTasks_SystemTask_Upgrade
  • IMP_LoginTasks_SystemTask_UpgradeAuth
  • IMP_LoginTasks_Task_Autocreate
  • IMP_LoginTasks_Task_DeleteAttachmentsMonthly
  • IMP_LoginTasks_Task_DeleteSentmailMonthly
  • IMP_LoginTasks_Task_FilterOnLogin
  • IMP_LoginTasks_Task_PurgeSentmail
  • IMP_LoginTasks_Task_PurgeSpam
  • IMP_LoginTasks_Task_PurgeTrash
  • IMP_LoginTasks_Task_RecoverDraft
  • IMP_LoginTasks_Task_RenameSentmailMonthly
  • IMP_Mailbox
  • IMP_Mailbox_List
  • IMP_Mailbox_List_Pop3
  • IMP_Mailbox_List_Thread
  • IMP_Mailbox_List_Virtual
  • IMP_Mailbox_SessionCache
  • IMP_Mailbox_Ui
  • IMP_Maillog
  • IMP_Maillog_Log_Base
  • IMP_Maillog_Log_Forward
  • IMP_Maillog_Log_Mdn
  • IMP_Maillog_Log_Redirect
  • IMP_Maillog_Log_Reply
  • IMP_Maillog_Log_Replyall
  • IMP_Maillog_Log_Replylist
  • IMP_Maillog_Message
  • IMP_Maillog_Storage_Base
  • IMP_Maillog_Storage_Composite
  • IMP_Maillog_Storage_History
  • IMP_Maillog_Storage_Mdnsent
  • IMP_Maillog_Storage_Null
  • IMP_Mbox_Generate
  • IMP_Mbox_Import
  • IMP_Mbox_Size
  • IMP_Message
  • IMP_Message_Date
  • IMP_Message_Ui
  • IMP_Mime_Headers
  • IMP_Mime_Status
  • IMP_Mime_Status_RenderIssue
  • IMP_Mime_Status_RenderIssue_Display
  • IMP_Mime_Viewer_Alternative
  • IMP_Mime_Viewer_Appledouble
  • IMP_Mime_Viewer_Audio
  • IMP_Mime_Viewer_Enriched
  • IMP_Mime_Viewer_Externalbody
  • IMP_Mime_Viewer_Html
  • IMP_Mime_Viewer_Images
  • IMP_Mime_Viewer_Itip
  • IMP_Mime_Viewer_Mdn
  • IMP_Mime_Viewer_Partial
  • IMP_Mime_Viewer_Pdf
  • IMP_Mime_Viewer_Pgp
  • IMP_Mime_Viewer_Plain
  • IMP_Mime_Viewer_Related
  • IMP_Mime_Viewer_Rfc822
  • IMP_Mime_Viewer_Smil
  • IMP_Mime_Viewer_Smime
  • IMP_Mime_Viewer_Status
  • IMP_Mime_Viewer_Vcard
  • IMP_Mime_Viewer_Video
  • IMP_Mime_Viewer_Zip
  • IMP_Minimal_Base
  • IMP_Minimal_Compose
  • IMP_Minimal_Error
  • IMP_Minimal_Folders
  • IMP_Minimal_Mailbox
  • IMP_Minimal_Message
  • IMP_Minimal_Messagepart
  • IMP_Minimal_Search
  • IMP_Notification_Event_Status
  • IMP_Notification_Handler_Decorator_ImapAlerts
  • IMP_Notification_Handler_Decorator_NewmailNotify
  • IMP_Perms
  • IMP_Prefs_AttribText
  • IMP_Prefs_Identity
  • IMP_Prefs_Sort
  • IMP_Prefs_Sort_FixedDate
  • IMP_Prefs_Sort_None
  • IMP_Prefs_Sort_Sortpref
  • IMP_Prefs_Sort_Sortpref_Locked
  • IMP_Prefs_Special_Acl
  • IMP_Prefs_Special_ComposeTemplates
  • IMP_Prefs_Special_Drafts
  • IMP_Prefs_Special_Encrypt
  • IMP_Prefs_Special_Flag
  • IMP_Prefs_Special_HtmlSignature
  • IMP_Prefs_Special_ImageReplacement
  • IMP_Prefs_Special_InitialPage
  • IMP_Prefs_Special_Mailto
  • IMP_Prefs_Special_NewmailSound
  • IMP_Prefs_Special_PgpPrivateKey
  • IMP_Prefs_Special_PgpPublicKey
  • IMP_Prefs_Special_Remote
  • IMP_Prefs_Special_Searches
  • IMP_Prefs_Special_Sentmail
  • IMP_Prefs_Special_SmimePrivateKey
  • IMP_Prefs_Special_SmimePublicKey
  • IMP_Prefs_Special_Sourceselect
  • IMP_Prefs_Special_Spam
  • IMP_Prefs_Special_SpecialMboxes
  • IMP_Prefs_Special_Trash
  • IMP_Quota
  • IMP_Quota_Hook
  • IMP_Quota_Imap
  • IMP_Quota_Null
  • IMP_Quota_Ui
  • IMP_Remote
  • IMP_Remote_Account
  • IMP_Script_Package_Autocomplete
  • IMP_Script_Package_ComposeBase
  • IMP_Script_Package_DynamicBase
  • IMP_Script_Package_Editor
  • IMP_Script_Package_Imp
  • IMP_Search
  • IMP_Search_Element
  • IMP_Search_Element_Attachment
  • IMP_Search_Element_Autogenerated
  • IMP_Search_Element_Bulk
  • IMP_Search_Element_Contacts
  • IMP_Search_Element_Daterange
  • IMP_Search_Element_Flag
  • IMP_Search_Element_Header
  • IMP_Search_Element_Mailinglist
  • IMP_Search_Element_Or
  • IMP_Search_Element_Personal
  • IMP_Search_Element_Recipient
  • IMP_Search_Element_Size
  • IMP_Search_Element_Text
  • IMP_Search_Element_Within
  • IMP_Search_Filter
  • IMP_Search_Filter_Attachment
  • IMP_Search_Filter_Autogenerated
  • IMP_Search_Filter_Builtin
  • IMP_Search_Filter_Bulk
  • IMP_Search_Filter_Contacts
  • IMP_Search_Filter_Mailinglist
  • IMP_Search_Filter_Personal
  • IMP_Search_IteratorFilter
  • IMP_Search_Query
  • IMP_Search_Ui
  • IMP_Search_Vfolder
  • IMP_Search_Vfolder_Builtin
  • IMP_Search_Vfolder_Vinbox
  • IMP_Search_Vfolder_Vtrash
  • IMP_Sentmail
  • IMP_Sentmail_Mongo
  • IMP_Sentmail_Null
  • IMP_Sentmail_Sql
  • IMP_Smartmobile
  • IMP_Spam
  • IMP_Spam_Email
  • IMP_Spam_Null
  • IMP_Spam_Program
  • IMP_Test
  • IMP_Tree_Flist
  • IMP_Tree_Jquerymobile
  • IMP_Tree_Simplehtml
  • IMP_View_Subinfo

Interfaces

  • IMP_Compose_Attachment_Linked
  • IMP_Contacts_Avatar_Backend
  • IMP_Contacts_Flag_Backend
  • IMP_Spam_Base
  • Overview
  • Package
  • Class
  • Tree
  1: <?php
  2: /**
  3:  * Copyright 2003-2014 Horde LLC (http://www.horde.org/)
  4:  *
  5:  * See the enclosed file COPYING for license information (GPL). If you
  6:  * did not receive this file, see http://www.horde.org/licenses/gpl.
  7:  *
  8:  * @category  Horde
  9:  * @copyright 2003-2014 Horde LLC
 10:  * @license   http://www.horde.org/licenses/gpl GPL
 11:  * @package   IMP
 12:  */
 13: 
 14: /**
 15:  * Management of IMAP Access Control Lists.
 16:  *
 17:  * @author    Chris Hastie <imp@oak-wood.co.uk>
 18:  * @author    Michael Slusarz <slusarz@horde.org>
 19:  * @category  Horde
 20:  * @copyright 2003-2014 Horde LLC
 21:  * @license   http://www.horde.org/licenses/gpl GPL
 22:  * @package   IMP
 23:  */
 24: class IMP_Imap_Acl
 25: {
 26:     /**
 27:      * Cached data for getRightsMbox().
 28:      *
 29:      * @var array
 30:      */
 31:     protected $_cache = array();
 32: 
 33:     /**
 34:      * Retrieve the existing ACLs for a mailbox from the server.
 35:      *
 36:      * @param IMP_Mailbox $mbox  The mailbox to get the ACL for.
 37:      * @param boolean $user      Return only the current user's rights?
 38:      *
 39:      * @return mixed  If $user is false, see Horde_Imap_Client_Base::getACL().
 40:      *                If $user is true, see
 41:      *                Horde_Imap_Client_Base::getMyACLRights().
 42:      * @throws IMP_Exception
 43:      */
 44:     public function getACL(IMP_Mailbox $mbox, $user = false)
 45:     {
 46:         $imp_imap = $mbox->imp_imap;
 47: 
 48:         if ($imp_imap->access(IMP_Imap::ACCESS_ACL)) {
 49:             try {
 50:                 if ($user) {
 51:                     return $imp_imap->getMyACLRights($mbox);
 52:                 }
 53: 
 54:                 $ret = $imp_imap->getACL($mbox);
 55:                 $user = $imp_imap->getParam('username');
 56:                 if (!isset($ret[$user]) &&
 57:                     ($acl = $this->getACL($mbox, true))) {
 58:                     $ret[$user] = $acl;
 59:                 }
 60:                 return $ret;
 61:             } catch (IMP_Imap_Exception $e) {
 62:                 switch ($e->getCode()) {
 63:                 case $e::NOPERM:
 64:                     throw new IMP_Exception(_("You do not have permission to view the ACLs on this mailbox."));
 65:                 }
 66:             }
 67:         }
 68: 
 69:         $ret = new Horde_Imap_Client_Data_Acl(implode('', array_keys($this->getRights())));
 70:         unset($ret[Horde_Imap_Client::ACL_ADMINISTER]);
 71: 
 72:         return $user
 73:             ? $ret
 74:             : array($imp_imap->getParam('username') => $ret);
 75:     }
 76: 
 77:     /**
 78:      * Adds rights to an ACL on the server.
 79:      *
 80:      * @param IMP_Mailbox $mbox  The mailbox on which to edit the ACL.
 81:      * @param string $user       The user to grant rights to.
 82:      * @param string $rights     The rights to add.
 83:      *
 84:      * @throws IMP_Exception
 85:      */
 86:     public function addRights(IMP_Mailbox $mbox, $user, $rights)
 87:     {
 88:         $imp_imap = $mbox->imp_imap;
 89: 
 90:         if (!strlen($rights) || !$imp_imap->access(IMP_Imap::ACCESS_ACL)) {
 91:             return;
 92:         }
 93: 
 94:         try {
 95:             $imp_imap->setACL($mbox, $user, array(
 96:                 'action' => 'add',
 97:                 'rights' => $rights
 98:             ));
 99:         } catch (IMP_Imap_Exception $e) {
100:             throw new IMP_Exception(sprintf(_("Could not add rights for user \"%s\" for the mailbox \"%s\"."), $user, $mbox));
101:         }
102:     }
103: 
104:     /**
105:      * Removes rights to an ACL on the server.
106:      *
107:      * @param IMP_Mailbox $mbox  The mailbox on which to edit the ACL.
108:      * @param string $user       The user to remove rights from.
109:      * @param string $rights     The rights to remove.  If empty, removes the
110:      *                           entire ACL.
111:      *
112:      * @throws IMP_Exception
113:      */
114:     public function removeRights(IMP_Mailbox $mbox, $user, $rights)
115:     {
116:         $imap = $mbox->imp_imap;
117:         if (!$imap->access(IMP_Imap::ACCESS_ACL)) {
118:             return;
119:         }
120: 
121:         try {
122:             if (is_null($rights)) {
123:                 $imap->deleteACL($mbox, $user);
124:             } else {
125:                 $imap->setACL($mbox, $user, array(
126:                     'action' => 'remove',
127:                     'rights' => $rights
128:                 ));
129:             }
130:         } catch (IMP_Imap_Exception $e) {
131:             throw new IMP_Exception(sprintf(_("Could not remove rights for user \"%s\" for the mailbox \"%s\"."), $user, $mbox));
132:         }
133:     }
134: 
135:     /**
136:      * Can the current user edit the ACL for this mailbox?
137:      *
138:      * @param IMP_Mailbox $mbox  The mailbox name.
139:      *
140:      * @return boolean  True if the current user has administrative rights.
141:      */
142:     public function canEdit(IMP_Mailbox $mbox)
143:     {
144:         $rights = $this->getRightsMbox($mbox, $mbox->imp_imap->getParam('username'));
145:         return $rights[Horde_Imap_Client::ACL_ADMINISTER];
146:     }
147: 
148:     /**
149:      * Return master list of ACL rights.
150:      *
151:      * @return array  A list of ACL rights. Keys are the right identifiers,
152:      *                values are arrays containing two entries: 'desc' and
153:      *                'title'.
154:      */
155:     public function getRights()
156:     {
157:         return array(
158:             Horde_Imap_Client::ACL_LOOKUP => array(
159:                 'desc' => _("User can see the mailbox"),
160:                 'title' => _("List")
161:             ),
162:             Horde_Imap_Client::ACL_READ => array(
163:                 'desc' => _("Read messages"),
164:                 'title' => _("Read")
165:             ),
166:             Horde_Imap_Client::ACL_SEEN => array(
167:                 'desc' => _("Mark with Seen/Unseen flags"),
168:                 'title' => _("Mark (Seen)")
169:             ),
170:             Horde_Imap_Client::ACL_WRITE => array(
171:                 'desc' => _("Mark with other flags (e.g. Important/Answered)"),
172:                 'title' => _("Mark (Other)")
173:             ),
174:             Horde_Imap_Client::ACL_INSERT => array(
175:                 'desc' => _("Insert messages"),
176:                 'title' => _("Insert")
177:             ),
178:             Horde_Imap_Client::ACL_POST => array(
179:                 'desc' => _("Post to this mailbox (not enforced by IMAP)"),
180:                 'title' => _("Post")
181:             ),
182:             Horde_Imap_Client::ACL_ADMINISTER => array(
183:                 'desc' => _("Set permissions for other users"),
184:                 'title' => _("Administer")
185:             ),
186:             Horde_Imap_Client::ACL_CREATEMBOX => array(
187:                 'desc' => _("Create subfolders and rename mailbox"),
188:                 'title' => _("Create Subfolders/Rename Mailbox")
189:             ),
190:             Horde_Imap_Client::ACL_DELETEMBOX => array(
191:                 'desc' => _("Delete and rename mailbox"),
192:                 'title' => _("Delete/Rename Mailbox")
193:             ),
194:             Horde_Imap_Client::ACL_DELETEMSGS => array(
195:                 'desc' => _("Delete messages"),
196:                 'title' => _("Delete")
197:             ),
198:             Horde_Imap_Client::ACL_EXPUNGE => array(
199:                 'desc' => _("Purge messages"),
200:                 'title' => _("Purge")
201:             )
202:         );
203:     }
204: 
205:     /**
206:      * Return list of rights available on the server.
207:      *
208:      * @param IMP_Mailbox $mbox  The mailbox name.
209:      * @param string $user       The ACL identifier (user) to query.
210:      *
211:      * @return Horde_Imap_Client_Data_AclRights  An ACL rights object.
212:      */
213:     public function getRightsMbox(IMP_Mailbox $mbox, $user)
214:     {
215:         $smbox = strval($mbox);
216: 
217:         if (!isset($this->_cache[$smbox][$user])) {
218:             $imp_imap = $mbox->imp_imap;
219:             $ob = null;
220: 
221:             if ($imp_imap->access(IMP_Imap::ACCESS_ACL)) {
222:                 try {
223:                     $ob = $imp_imap->listACLRights($mbox, $user);
224:                 } catch (IMP_Imap_Exception $e) {}
225:             }
226: 
227:             $this->_cache[$smbox][$user] = is_null($ob)
228:                 ? new Horde_Imap_Client_Data_AclRights()
229:                 : $ob;
230:         }
231: 
232:         return $this->_cache[$smbox][$user];
233:     }
234: 
235: }
236: 
API documentation generated by ApiGen