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 1999-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 1999-2014 Horde LLC
 10:  * @license   http://www.horde.org/licenses/gpl GPL
 11:  * @package   IMP
 12:  */
 13: 
 14: /**
 15:  * This class provides authentication for IMP.
 16:  *
 17:  * @author    Chuck Hagenbuch <chuck@horde.org>
 18:  * @author    Jon Parise <jon@horde.org>
 19:  * @author    Michael Slusarz <slusarz@horde.org>
 20:  * @category  Horde
 21:  * @copyright 1999-2014 Horde LLC
 22:  * @license   http://www.horde.org/licenses/gpl GPL
 23:  * @package   IMP
 24:  */
 25: class IMP_Auth
 26: {
 27:     /**
 28:      * Authenticate to the mail server.
 29:      *
 30:      * @param array $credentials  An array of login credentials. If empty,
 31:      *                            attempts to login to the cached session.
 32:      *   - password: (string) The user password.
 33:      *   - server: (string) The server key to use (from backends.php).
 34:      *   - userId: (string) The username.
 35:      *
 36:      * @throws Horde_Auth_Exception
 37:      */
 38:     public static function authenticate($credentials = array())
 39:     {
 40:         global $injector, $registry;
 41: 
 42:         // Do 'horde' authentication.
 43:         $imp_app = $registry->getApiInstance('imp', 'application');
 44:         if (!empty($imp_app->initParams['authentication']) &&
 45:             ($imp_app->initParams['authentication'] == 'horde')) {
 46:             if ($registry->getAuth()) {
 47:                 return;
 48:             }
 49:             throw new Horde_Auth_Exception('', Horde_Auth::REASON_FAILED);
 50:         }
 51: 
 52:         if (!isset($credentials['server'])) {
 53:             $credentials['server'] = self::getAutoLoginServer();
 54:         }
 55: 
 56:         $imp_imap = $injector->getInstance('IMP_Factory_Imap')->create();
 57: 
 58:         // Check for valid IMAP Client object.
 59:         if (!$imp_imap->init) {
 60:             if (!isset($credentials['userId']) ||
 61:                 !isset($credentials['password'])) {
 62:                 throw new Horde_Auth_Exception('', Horde_Auth::REASON_BADLOGIN);
 63:             }
 64: 
 65:             try {
 66:                 $imp_imap->createBaseImapObject($credentials['userId'], $credentials['password'], $credentials['server']);
 67:             } catch (IMP_Imap_Exception $e) {
 68:                 self::_log(false, $imp_imap);
 69:                 throw $e->authException();
 70:             }
 71:         }
 72: 
 73:         try {
 74:             $imp_imap->login();
 75:         } catch (IMP_Imap_Exception $e) {
 76:             self::_log(false, $imp_imap);
 77:             throw $e->authException();
 78:         }
 79:     }
 80: 
 81:     /**
 82:      * Perform transparent authentication.
 83:      *
 84:      * @param Horde_Auth_Application $auth_ob  The authentication object.
 85:      *
 86:      * @return boolean  True on successful transparent authentication.
 87:      */
 88:     public static function transparent($auth_ob)
 89:     {
 90:         $credentials = $auth_ob->getCredential('credentials');
 91: 
 92:         if (empty($credentials['transparent'])) {
 93:             /* Attempt hordeauth authentication. */
 94:             $credentials = self::_canAutoLogin();
 95:             if ($credentials === false) {
 96:                 return false;
 97:             }
 98:         } else {
 99:             /* It is possible that preauthenticate() set the credentials.
100:              * If so, use that information instead of hordeauth. */
101:             $credentials['userId'] = $auth_ob->getCredential('userId');
102:         }
103: 
104:         if (!isset($credentials['password']) ||
105:             !strlen($credentials['password'])) {
106:             return false;
107:         }
108: 
109:         try {
110:             self::authenticate($credentials);
111:         } catch (Horde_Auth_Exception $e) {
112:             return false;
113:         }
114: 
115:         return true;
116:     }
117: 
118:     /**
119:      * Log login related message.
120:      *
121:      * @param boolean $status    True on success, false on failure.
122:      * @param IMP_Imap $imap_ob  The IMP_Imap object to use.
123:      */
124:     protected static function _log($status, $imap_ob)
125:     {
126:         $msg = $status
127:             ? 'Login success'
128:             : 'FAILED LOGIN';
129:         $user = $imap_ob->getParam('username');
130: 
131:         if (($auth_id = $GLOBALS['registry']->getAuth()) &&
132:             ($user != $auth_id)) {
133:             $user .= ' (Horde user ' . $auth_id . ')';
134:         }
135: 
136:         Horde::log(
137:             sprintf(
138:                 $msg . ' for %s (%s)%s to {%s}',
139:                 $user,
140:                 $_SERVER['REMOTE_ADDR'],
141:                 empty($_SERVER['HTTP_X_FORWARDED_FOR']) ? '' : ' (forwarded for [' . $_SERVER['HTTP_X_FORWARDED_FOR'] . '])',
142:                 $imap_ob->url
143:             ),
144:             $status ? 'NOTICE' : 'INFO'
145:         );
146:     }
147: 
148:     /**
149:      * Returns the autologin server key.
150:      *
151:      * @return string  The server key, or null if none available.
152:      */
153:     public static function getAutoLoginServer()
154:     {
155:         if (($servers = IMP_Imap::loadServerConfig()) === false) {
156:             return null;
157:         }
158: 
159:         $server_key = null;
160:         foreach ($servers as $key => $val) {
161:             if (is_null($server_key) && (substr($key, 0, 1) != '_')) {
162:                 $server_key = $key;
163:             }
164: 
165:             /* Determines if the given mail server is the "preferred" mail
166:              * server for this web server. This decision is based on the
167:              * global 'SERVER_NAME' and 'HTTP_HOST' server variables and the
168:              * contents of the 'preferred' field in the backend's config. */
169:             if (($preferred = $val->preferred) &&
170:                 (in_array($_SERVER['SERVER_NAME'], $preferred) ||
171:                  in_array($_SERVER['HTTP_HOST'], $preferred))) {
172:                 return $key;
173:             }
174:         }
175: 
176:         return $server_key;
177:     }
178: 
179:     /**
180:      * Returns whether we can log in without a login screen for $server_key.
181:      *
182:      * @param string $server_key  The server to check. Defaults to the
183:      *                            autologin server.
184:      * @param boolean $force      If true, check $server_key even if there is
185:      *                            more than one server available.
186:      *
187:      * @return array  The credentials needed to login ('userId', 'password',
188:      *                 'server') or false if autologin not available.
189:      */
190:     protected static function _canAutoLogin($server_key = null, $force = false)
191:     {
192:         global $injector, $registry;
193: 
194:         if (($servers = $injector->getInstance('IMP_Factory_Imap')->create()->loadServerConfig()) === false) {
195:             return false;
196:         }
197: 
198:         if (is_null($server_key) || !$force) {
199:             $auto_server = self::getAutoLoginServer();
200:             if (is_null($server_key)) {
201:                 $server_key = $auto_server;
202:             }
203:         }
204: 
205:         if ((!empty($auto_server) || $force) &&
206:             $registry->getAuth() &&
207:             !empty($servers[$server_key]->hordeauth)) {
208:             return array(
209:                 'userId' => $registry->getAuth((strcasecmp($servers[$server_key]->hordeauth, 'full') === 0) ? null : 'bare'),
210:                 'password' => $registry->getAuthCredential('password'),
211:                 'server' => $server_key
212:             );
213:         }
214: 
215:         return false;
216:     }
217: 
218:     /**
219:      * Perform post-login tasks. Session creation requires the full IMP
220:      * environment, which is not available until this callback.
221:      *
222:      * The following global IMP session variables are created by this method:
223:      *   - file_upload: (integer) If file uploads are allowed, the max size.
224:      *   - rteavail: (boolean) Is the HTML editor available?
225:      *
226:      * @throws Horde_Exception
227:      */
228:     public static function authenticateCallback()
229:     {
230:         global $browser, $injector, $session;
231: 
232:         $imp_imap = $injector->getInstance('IMP_Factory_Imap')->create();
233: 
234:         /* Perform post-login tasks for IMAP object. */
235:         $imp_imap->doPostLoginTasks();
236: 
237:         /* Does the server allow file uploads? If yes, store the
238:          * value, in bytes, of the maximum file size. */
239:         $session->set('imp', 'file_upload', $browser->allowFileUploads());
240: 
241:         /* Is the HTML editor available? */
242:         $session->set('imp', 'rteavail', $injector->getInstance('Horde_Editor')->supportedByBrowser());
243: 
244:         self::_log(true, $imp_imap);
245:     }
246: 
247: }
248: 
API documentation generated by ApiGen