Overview

Packages

  • IMP
  • None

Classes

  • IMP
  • IMP_Ajax_Application
  • IMP_Ajax_Imple_ContactAutoCompleter
  • IMP_Ajax_Imple_PassphraseDialog
  • IMP_Ajax_Queue
  • IMP_Api
  • IMP_Auth
  • IMP_Block_Newmail
  • IMP_Block_Summary
  • IMP_Compose
  • IMP_Compose_Exception
  • IMP_Compose_Stationery
  • IMP_Contents
  • IMP_Crypt_Pgp
  • IMP_Crypt_Smime
  • IMP_Dimp
  • IMP_Exception
  • IMP_Factory_AuthImap
  • IMP_Factory_Compose
  • IMP_Factory_Contents
  • IMP_Factory_Flags
  • IMP_Factory_Identity
  • IMP_Factory_Imap
  • IMP_Factory_Imaptree
  • IMP_Factory_Mail
  • IMP_Factory_Mailbox
  • IMP_Factory_MailboxList
  • IMP_Factory_MimeViewer
  • IMP_Factory_Pgp
  • IMP_Factory_Quota
  • IMP_Factory_Search
  • IMP_Factory_Sentmail
  • IMP_Factory_Smime
  • 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_Imap
  • IMP_Imap_Acl
  • IMP_Imap_Exception
  • IMP_Imap_PermanentFlags
  • IMP_Imap_Thread
  • IMP_Imap_Tree
  • IMP_Indices
  • IMP_Indices_Form
  • 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_Track
  • IMP_Maillog
  • IMP_Menu_Dimp
  • IMP_Message
  • IMP_Mime_Status
  • 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_Notification_Event_Status
  • IMP_Notification_Handler_Decorator_ImapAlerts
  • IMP_Notification_Handler_Decorator_NewmailNotify
  • IMP_Notification_Listener_AjaxStatus
  • Imp_Prefs_Identity
  • IMP_Prefs_Ui
  • IMP_Quota
  • IMP_Quota_Base
  • IMP_Quota_Command
  • IMP_Quota_Hook
  • IMP_Quota_Imap
  • IMP_Quota_Maildir
  • IMP_Quota_Mdaemon
  • IMP_Quota_Mercury32
  • IMP_Quota_Null
  • IMP_Quota_Sql
  • IMP_Search
  • IMP_Search_Element
  • IMP_Search_Element_Attachment
  • IMP_Search_Element_Autogenerated
  • IMP_Search_Element_Bulk
  • IMP_Search_Element_Contacts
  • IMP_Search_Element_Date
  • 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_Query
  • IMP_Search_Vfolder
  • IMP_Search_Vfolder_Builtin
  • IMP_Search_Vfolder_Vinbox
  • IMP_Search_Vfolder_Vtrash
  • IMP_Sentmail
  • IMP_Sentmail_Base
  • IMP_Sentmail_Null
  • IMP_Sentmail_Sql
  • IMP_Spam
  • IMP_Test
  • IMP_Tree_Flist
  • IMP_Tree_Jquerymobile
  • IMP_Tree_Simplehtml
  • IMP_Ui_Compose
  • IMP_Ui_Editor
  • IMP_Ui_Folder
  • IMP_Ui_Headers
  • IMP_Ui_Imageview
  • IMP_Ui_Mailbox
  • IMP_Ui_Message
  • IMP_Ui_Mimp
  • IMP_Ui_Search
  • IMP_Views_Compose
  • IMP_Views_ListMessages
  • IMP_Views_ShowMessage
  • Overview
  • Package
  • Class
  • Tree
  1: <?php
  2: /**
  3:  * Implementation of the Quota API for servers using Maildir++ quota files on
  4:  * the local filesystem.
  5:  *
  6:  * Copyright 2007-2012 Horde LLC (http://www.horde.org/)
  7:  *
  8:  * See the enclosed file COPYING for license information (GPL). If you
  9:  * did not receive this file, see http://www.horde.org/licenses/gpl.
 10:  *
 11:  * @author   Eric Rostetter <eric.rostetter@physics.utexas.edu>
 12:  * @category Horde
 13:  * @license  http://www.horde.org/licenses/gpl GPL
 14:  * @package  IMP
 15:  */
 16: class IMP_Quota_Maildir extends IMP_Quota_Base
 17: {
 18:     /**
 19:      * Constructor.
 20:      *
 21:      * @param array $params  Parameters:
 22:      * <pre>
 23:      * 'msg_count' - (boolean) Display information on the message limit rather
 24:      *               than the storage limit?
 25:      *               DEFAULT: false
 26:      * 'path' - (string) The path to the user's Maildir directory. You may use
 27:      *          the two-character sequence "~U" to represent the user's
 28:      *          account name, and the actual username will be substituted in
 29:      *          that location.
 30:      *          E.g., '/home/~U/Maildir/' or '/var/mail/~U/Maildir/'
 31:      *          DEFAULT: ''
 32:      * </pre>
 33:      */
 34:     public function __construct($params = array())
 35:     {
 36:         parent::__construct(array_merge(array(
 37:             'msg_count' => false,
 38:             'path' => ''
 39:         ), $params));
 40:     }
 41: 
 42:     /**
 43:      * Returns quota information (used/allocated), in bytes.
 44:      *
 45:      * @return array  An array with the following keys:
 46:      * <pre>
 47:      * 'limit' = Maximum quota allowed.
 48:      * 'usage' = Currently used portion of quota (in bytes).
 49:      * </pre>
 50:      * @throws IMP_Exception
 51:      */
 52:     public function getQuota()
 53:     {
 54:         $limit = $used = 0;
 55: 
 56:         // Get the full path to the quota file.
 57:         $full = $this->_params['path'] . '/maildirsize';
 58: 
 59:         // Substitute the username in the string if needed.
 60:         $full = str_replace('~U', $this->_params['username'], $full);
 61: 
 62:         // Read in the quota file and parse it, if possible.
 63:         if (!is_file($full)) {
 64:             throw new IMP_Exception(_("Unable to retrieve quota"));
 65:         }
 66: 
 67:         // Read in maildir quota file.
 68:         $lines = file($full);
 69: 
 70:         // Parse the lines.
 71:         foreach ($lines as $line_number => $line) {
 72:             if ($line_number == 0) {
 73:                 // First line, quota header.
 74:                 $line = preg_replace('/[ \t\n\r\0\x0B]/', '', $line);
 75:                 list($v1, $t1, $v2, $t2) = sscanf($line, '%ld%[CS],%ld%[CS]');
 76:                 if (is_null($v1) || is_null($t1)) {
 77:                     $v1 = 0;
 78:                 }
 79:                 if (is_null($v2) || is_null($t2)) {
 80:                     $v2 = 0;
 81:                 }
 82: 
 83:                 if ($this->_params['msg_count']) {
 84:                     if ($t1 == 'C') {
 85:                         $limit = $v1;
 86:                     }
 87:                     if ($t2 == 'C') {
 88:                         $limit = $v2;
 89:                     }
 90:                 } else {
 91:                     if ($t1 == 'S') {
 92:                         $limit = $v1;
 93:                     }
 94:                     if ($t2 == 'S') {
 95:                         $limit = $v2;
 96:                     }
 97:                 }
 98:             } else {
 99:                 // Any line other than the first line.
100:                 // The quota used is the sum of all lines found.
101:                 list($storage, $message) = sscanf(trim($line), '%ld %d');
102:                 if ($this->_params['msg_count'] && !is_null($message)) {
103:                     $used += $message;
104:                 } elseif (!$this->_params['msg_count'] && !is_null($storage)) {
105:                     $used += $storage;
106:                 }
107:             }
108:         }
109: 
110:         return array(
111:             'limit' => $limit,
112:             'usage' => $used
113:         );
114:     }
115: 
116: }
117: 
API documentation generated by ApiGen