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 keeping quota information in a
  4:  * custom SQL database.
  5:  *
  6:  * Copyright 2006-2007 Tomas Simonaitis <haden@homelan.lt>
  7:  * Copyright 2006-2012 Horde LLC (http://www.horde.org/)
  8:  *
  9:  * See the enclosed file COPYING for license information (GPL). If you
 10:  * did not receive this file, see http://www.horde.org/licenses/gpl.
 11:  *
 12:  * @author   Tomas Simonaitis <haden@homelan.lt>
 13:  * @author   Jan Schneider <jan@horde.org>
 14:  * @category Horde
 15:  * @license  http://www.horde.org/licenses/gpl GPL
 16:  * @package  IMP
 17:  */
 18: class IMP_Quota_Sql extends IMP_Quota_Base
 19: {
 20:     /**
 21:      * DB object.
 22:      *
 23:      * @var Horde_Db_Adapter
 24:      */
 25:     protected $_db;
 26: 
 27:     /**
 28:      * Constructor.
 29:      *
 30:      * @param array $params  Parameters:
 31:      * <pre>
 32:      * 'db' - (Horde_Db_Adapter) [REQUIRED] The DB instance.
 33:      * 'query_quota' - (string) SQL query which returns single row/column with
 34:      *                 user quota (in bytes). %u is replaced with current user
 35:      *                 name, %U with the user name without the domain part, %d
 36:      *                 with the domain.
 37:      * 'query_used' - (string) SQL query which returns single row/column with
 38:      *                user used space (in bytes). Placeholders are the same
 39:      *                as in 'query_quota'.
 40:      * </pre>
 41:      *
 42:      * @throws InvalidArgumentException
 43:      */
 44:     public function __construct(array $params = array())
 45:     {
 46:         if (!isset($params['db'])) {
 47:             throw new IMP_Exception('Missing db parameter.');
 48:         }
 49:         $this->_db = $params['db'];
 50:         unset($params['db']);
 51: 
 52:         $params = array_merge(array(
 53:             'query_quota' => null,
 54:             'query_used' => null
 55:         ), $params);
 56: 
 57:         parent::__construct($params);
 58:     }
 59: 
 60:     /**
 61:      * Returns quota information.
 62:      *
 63:      * @return array  An array with the following keys:
 64:      * <pre>
 65:      * 'limit' - Maximum quota allowed
 66:      * 'usage' - Currently used portion of quota (in bytes)
 67:      * </pre>
 68:      * @throws IMP_Exception
 69:      */
 70:     public function getQuota()
 71:     {
 72:         $quota = array(
 73:             'limit' => 0,
 74:             'usage' => 0
 75:         );
 76: 
 77:         if (empty($this->_params['query_quota'])) {
 78:             Horde::logMessage(__CLASS__ . ': query_quota SQL query not set.', 'ERR');
 79:         } else {
 80:             @list($bare_user, $domain) = explode('@', $this->_params['username'], 2);
 81:             $query = str_replace(array('?', '%u', '%U', '%d'),
 82:                                  array($this->_db->quote($this->_params['username']),
 83:                                        $this->_db->quote($this->_params['username']),
 84:                                        $this->_db->quote($bare_user),
 85:                                        $this->_db->quote($domain)),
 86:                                  $this->_params['query_quota']);
 87:             try {
 88:                 $result = $this->_db->selectOne($query);
 89:             } catch (Horde_Db_Exception $e) {
 90:                 throw new IMP_Exception($e);
 91:             }
 92: 
 93:             $quota['limit'] = $result;
 94:         }
 95: 
 96:         if (empty($this->_params['query_used'])) {
 97:             Horde::logMessage(__CLASS__ . ': query_used SQL query not set.', 'ERR');
 98:         } else {
 99:             @list($bare_user, $domain) = explode('@', $this->_params['username'], 2);
100:             $query = str_replace(array('?', '%u', '%U', '%d'),
101:                                  array($this->_db->quote($this->_params['username']),
102:                                        $this->_db->quote($this->_params['username']),
103:                                        $this->_db->quote($bare_user),
104:                                        $this->_db->quote($domain)),
105:                                  $this->_params['query_used']);
106:             try {
107:                 $result = $this->_db->selectOne($query);
108:             } catch (Horde_Db_Exception $e) {
109:                 throw new IMP_Exception($e);
110:             }
111: 
112:             $quota['usage'] = $result;
113:         }
114: 
115:         return $quota;
116:     }
117: 
118: }
119: 
API documentation generated by ApiGen