From f8026cf6244d66a8650ae1316d3a7fea61a00a99 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Wed, 6 Nov 2013 21:02:19 +0000 Subject: [PATCH] mail redirects on connection or authentication failure, or if there is no account to account wizard, so user can fix the problem --- mail/inc/class.mail_bo.inc.php | 81 +++++++++++++++------------------- mail/inc/class.mail_ui.inc.php | 29 ++++++++---- 2 files changed, 57 insertions(+), 53 deletions(-) diff --git a/mail/inc/class.mail_bo.inc.php b/mail/inc/class.mail_bo.inc.php index ff11e5851a..5b297ce2fd 100644 --- a/mail/inc/class.mail_bo.inc.php +++ b/mail/inc/class.mail_bo.inc.php @@ -55,14 +55,14 @@ class mail_bo /** * Active incomming (IMAP) Server Object * - * @var object + * @var emailadmin_imap */ var $icServer; /** * Active outgoing (smtp) Server Object * - * @var object + * @var emailadmin_smtp */ var $ogServer; @@ -98,19 +98,19 @@ class mail_bo * @array */ static $htmLawed_config = array('comment'=>1, //remove comments - 'make_tag_strict' => 3, // 3 is a new own config value, to indicate that transformation is to be performed, but don't transform font as size transformation of numeric sizes to keywords alters the intended result too much - 'keep_bad'=>2, //remove tags but keep element content (4 and 6 keep element content only if text (pcdata) is valid in parent element as per specs, this may lead to textloss if balance is switched on) - 'balance'=>1,//turn off tag-balancing (config['balance']=>0). That will not introduce any security risk; only standards-compliant tag nesting check/filtering will be turned off (basic tag-balance will remain; i.e., there won't be any unclosed tag, etc., after filtering) - 'direct_list_nest' => 1, - 'allow_for_inline' => array('table','div','li','p'),//block elements allowed for nesting when only inline is allowed; Example span does not allow block elements as table; table is the only element tested so far - // tidy eats away even some wanted whitespace, so we switch it off; - // we used it for its compacting and beautifying capabilities, which resulted in better html for further processing - 'tidy'=>0, - 'elements' => "* -script", - 'deny_attribute' => 'on*', - 'schemes'=>'href: file, ftp, http, https, mailto; src: cid, data, file, ftp, http, https; *:file, http, https, cid, src', - 'hook_tag' =>"hl_email_tag_transform", - ); + 'make_tag_strict' => 3, // 3 is a new own config value, to indicate that transformation is to be performed, but don't transform font as size transformation of numeric sizes to keywords alters the intended result too much + 'keep_bad'=>2, //remove tags but keep element content (4 and 6 keep element content only if text (pcdata) is valid in parent element as per specs, this may lead to textloss if balance is switched on) + 'balance'=>1,//turn off tag-balancing (config['balance']=>0). That will not introduce any security risk; only standards-compliant tag nesting check/filtering will be turned off (basic tag-balance will remain; i.e., there won't be any unclosed tag, etc., after filtering) + 'direct_list_nest' => 1, + 'allow_for_inline' => array('table','div','li','p'),//block elements allowed for nesting when only inline is allowed; Example span does not allow block elements as table; table is the only element tested so far + // tidy eats away even some wanted whitespace, so we switch it off; + // we used it for its compacting and beautifying capabilities, which resulted in better html for further processing + 'tidy'=>0, + 'elements' => "* -script", + 'deny_attribute' => 'on*', + 'schemes'=>'href: file, ftp, http, https, mailto; src: cid, data, file, ftp, http, https; *:file, http, https, cid, src', + 'hook_tag' =>"hl_email_tag_transform", + ); /** * static used define abbrevations for common access rights @@ -118,13 +118,13 @@ class mail_bo * @array */ static $aclShortCuts = array('' => array('label'=>'none','title'=>'The user has no rights whatsoever.'), - 'lrs' => array('label'=>'readable','title'=>'Allows a user to read the contents of the mailbox.'), - 'lprs' => array('label'=>'post','title'=>'Allows a user to read the mailbox and post to it through the delivery system by sending mail to the submission address of the mailbox.'), - 'ilprs' => array('label'=>'append','title'=>'Allows a user to read the mailbox and append messages to it, either via IMAP or through the delivery system.'), - 'cdilprsw' => array('label'=>'write','title'=>'Allows a user to read the maibox, post to it, append messages to it, and delete messages or the mailbox itself. The only right not given is the right to change the ACL of the mailbox.'), - 'acdilprsw' => array('label'=>'all','title'=>'The user has all possible rights on the mailbox. This is usually granted to users only on the mailboxes they own.'), - 'custom' => array('label'=>'custom','title'=>'User defined combination of rights for the ACL'), - ); + 'lrs' => array('label'=>'readable','title'=>'Allows a user to read the contents of the mailbox.'), + 'lprs' => array('label'=>'post','title'=>'Allows a user to read the mailbox and post to it through the delivery system by sending mail to the submission address of the mailbox.'), + 'ilprs' => array('label'=>'append','title'=>'Allows a user to read the mailbox and append messages to it, either via IMAP or through the delivery system.'), + 'cdilprsw' => array('label'=>'write','title'=>'Allows a user to read the maibox, post to it, append messages to it, and delete messages or the mailbox itself. The only right not given is the right to change the ACL of the mailbox.'), + 'acdilprsw' => array('label'=>'all','title'=>'The user has all possible rights on the mailbox. This is usually granted to users only on the mailboxes they own.'), + 'custom' => array('label'=>'custom','title'=>'User defined combination of rights for the ACL'), + ); /** * Folders that get automatic created AND get translated to the users language @@ -145,8 +145,9 @@ class mail_bo static $specialUseFolders; /** - * var to hold IDNA2 object - * @var class object + * IDNA2 instance + * + * @var egw_idna */ static $idna2; @@ -164,7 +165,7 @@ class mail_bo * @param int $_profileID=0 * @param boolean $_validate=true - flag wether the profileid should be validated or not, if validation is true, you may receive a profile * not matching the input profileID, if we can not find a profile matching the given ID - * @return object instance of mail_bo + * @return mail_bo */ public static function getInstance($_restoreSession=true, $_profileID=0, $_validate=true) { @@ -576,31 +577,23 @@ $_restoreSession=false; * * @param int $_icServerID * @param boolean $_adminConnection - * @return boolean true/false or PEAR_Error Object ((if available) on Failure) + * @throws Horde_Imap_Client_Exception on connection error or authentication failure + * @throws InvalidArgumentException on missing credentials */ function openConnection($_icServerID=0, $_adminConnection=false) { //error_log( "-------------------------->open connection ".function_backtrace()); //error_log(__METHOD__.__LINE__.' ->'.array2string($this->icServer)); - $tretval=true; - try + $mailbox=null; + if($this->folderExists($this->sessionData['mailbox'])) $mailbox = $this->sessionData['mailbox']; + if (empty($mailbox)) $mailbox = $this->icServer->getCurrentMailbox(); + if (isset(emailadmin_imap::$supports_keywords[$_icServerID])) { - $mailbox=null; - if($this->folderExists($this->sessionData['mailbox'])) $mailbox=$this->sessionData['mailbox']; - if (empty($mailbox))$mailbox = $this->icServer->getCurrentMailbox(); - if (isset(emailadmin_imap::$supports_keywords[$_icServerID])) - { - $this->icServer->openMailbox($mailbox); - } - else - { - $this->icServer->examineMailbox($mailbox); - } + $this->icServer->openMailbox($mailbox); } - catch (egw_exception $e) + else { - error_log(__METHOD__.__LINE__.$e->getMessage()); - $tretval = false; + $this->icServer->examineMailbox($mailbox); } //error_log(__METHOD__." using existing Connection ProfileID:".$_icServerID.' Status:'.print_r($this->icServer->_connected,true)); //error_log(__METHOD__.__LINE__."->open connection for Server with profileID:".$_icServerID.function_backtrace()); @@ -608,8 +601,6 @@ $_restoreSession=false; //make sure we are working with the correct hierarchyDelimiter on the current connection, calling getHierarchyDelimiter with false to reset the cache $hD = $this->getHierarchyDelimiter(false); self::$specialUseFolders = $this->getSpecialUseFolders(); - - return $tretval; } /** @@ -5711,7 +5702,7 @@ error_log(__METHOD__.__LINE__.array2string($headerObject['ATTACHMENTS'][$mime_id } $rp = mail_bo::getRandomString(); file_put_contents( "$dir/$rp$filename", $part->body); - + $path = "$dir/$rp$filename"; $mailObject->AddEmbeddedImage($path, $part->headers['content-id'], $filename, ($part->headers['content-transfer-encoding']?$part->headers['content-transfer-encoding']:'base64'), $part->ctype_primary.'/'.$part->ctype_secondary); } diff --git a/mail/inc/class.mail_ui.inc.php b/mail/inc/class.mail_ui.inc.php index c9ed872fc7..6968ca6068 100644 --- a/mail/inc/class.mail_ui.inc.php +++ b/mail/inc/class.mail_ui.inc.php @@ -120,14 +120,27 @@ class mail_ui emailadmin_bo::unsetCachedObjects(self::$icServerID); } - $this->mail_bo = mail_bo::getInstance(false,self::$icServerID); - if (mail_bo::$debug) error_log(__METHOD__.__LINE__.' Fetched IC Server:'.self::$icServerID.'/'.$this->mail_bo->profileID.':'.function_backtrace()); - //error_log(__METHOD__.__LINE__.array2string($this->mail_bo->icServer)); - //error_log(__METHOD__.__LINE__.array2string($this->mail_bo->icServer->ImapServerId)); - // no icServer Object: something failed big time - if (!isset($this->mail_bo->icServer)) exit; // ToDo: Exception or the dialog for setting up a server config - //openConnection gathers SpecialUseFolderInformation and Delimiter Info - $this->mail_bo->openConnection(self::$icServerID); + try { + $this->mail_bo = mail_bo::getInstance(false,self::$icServerID); + if (mail_bo::$debug) error_log(__METHOD__.__LINE__.' Fetched IC Server:'.self::$icServerID.'/'.$this->mail_bo->profileID.':'.function_backtrace()); + //error_log(__METHOD__.__LINE__.array2string($this->mail_bo->icServer)); + //error_log(__METHOD__.__LINE__.array2string($this->mail_bo->icServer->ImapServerId)); + //openConnection gathers SpecialUseFolderInformation and Delimiter Info + $this->mail_bo->openConnection(self::$icServerID); + } + catch (Exception $e) + { + // redirect to mail wizard to handle it (redirect works for ajax too) + egw_framework::redirect_link('/index.php', + (self::$icServerID ? array( + 'menuaction' => 'mail.mail_wizard.edit', + 'acc_id' => self::$icServerID, + ) : array( + 'menuaction' => 'mail.mail_wizard.add', + )) + array( + 'msg' => $e->getMessage()//.' ('.get_class($e).': '.$e->getCode().')', + )); + } $GLOBALS['egw']->session->commit_session(); //_debug_array($this->mail_bo->mailPreferences); }