From 2e437352c53f0b06ce75cf26ed4c9ebc107302b7 Mon Sep 17 00:00:00 2001 From: Klaus Leithoff Date: Fri, 6 Feb 2015 12:41:03 +0000 Subject: [PATCH] * Mail/Sieve: check capability if VACATION is supported by SIEVE Server before trying to set an serverside vacation absent notice code clean up in hooks and conditional debug for sendMDN --- .../inc/class.emailadmin_imapbase.inc.php | 2 +- .../inc/class.emailadmin_script.inc.php | 7 +- mail/inc/class.mail_hooks.inc.php | 84 ------ mail/inc/class.mail_sieve.inc.php | 270 +++++++++--------- 4 files changed, 146 insertions(+), 217 deletions(-) diff --git a/emailadmin/inc/class.emailadmin_imapbase.inc.php b/emailadmin/inc/class.emailadmin_imapbase.inc.php index 170f10caa0..77fe2f3793 100644 --- a/emailadmin/inc/class.emailadmin_imapbase.inc.php +++ b/emailadmin/inc/class.emailadmin_imapbase.inc.php @@ -6228,7 +6228,7 @@ class emailadmin_imapbase { $acc = emailadmin_account::read($this->profileID); $identity = emailadmin_account::read_identity($acc['ident_id'], true, null, $acc); - + if (self::$debug) error_log(__METHOD__.__LINE__.array2string($identity)); $headers = $this->getMessageHeader($uid, '', 'object', true, $_folder); $mdn = new Horde_Mime_Mdn($headers); diff --git a/emailadmin/inc/class.emailadmin_script.inc.php b/emailadmin/inc/class.emailadmin_script.inc.php index 751928e431..23253cf3cc 100644 --- a/emailadmin/inc/class.emailadmin_script.inc.php +++ b/emailadmin/inc/class.emailadmin_script.inc.php @@ -105,8 +105,8 @@ class emailadmin_script { if ($this->debug) error_log(__CLASS__.'::'.__METHOD__.": error retrieving script: ".$script->getMessage()); return $script; } - #print "
AAA: Script is ". htmlentities($script) ."
"; + $lines = preg_split("/\n/",$script); //,PREG_SPLIT_NO_EMPTY); $rules = array(); @@ -228,6 +228,7 @@ class emailadmin_script { $this->script = $script; $this->rules = $rules; $this->vacation = $vacation; + if (!(in_array('vacation',$connection->_capability['extensions'])|| in_array('VACATION', $connection->_capability['extensions']))) $this->vacation = false; $this->emailNotification = $emailNotification; // Added email notifications if ($this->debug) error_log(__CLASS__.'::'.__METHOD__.": Script succesful retrieved: ".print_r($vacation,true)); @@ -265,11 +266,13 @@ class emailadmin_script { #LK } // lets generate the main body of the script from our rules - + //error_log(__METHOD__.__LINE__.array2string($connection->_capability)); $enotify = $variables= $supportsbody = false; if (in_array('enotify',$connection->_capability['extensions'])|| in_array('ENOTIFY', $connection->_capability['extensions'])) $enotify = true; if (in_array('variables',$connection->_capability['extensions'])|| in_array('VARIABLES', $connection->_capability['extensions'])) $variables = true; if (in_array('body', $connection->_capability['extensions']) || in_array('BODY', $connection->_capability['extensions'])) $supportsbody = true; + if (!(in_array('vacation',$connection->_capability['extensions'])|| in_array('VACATION', $connection->_capability['extensions']))) $this->vacation = false; + $newscriptbody = ""; $continue = 1; diff --git a/mail/inc/class.mail_hooks.inc.php b/mail/inc/class.mail_hooks.inc.php index b438beec7c..3f1ec938e6 100644 --- a/mail/inc/class.mail_hooks.inc.php +++ b/mail/inc/class.mail_hooks.inc.php @@ -337,39 +337,6 @@ class mail_hooks 'default'=> 0, 'admin' => False, ), -/* - // option requested by customer, removed for the new client - 'prefaskformultipleforward' => array( - 'type' => 'select', - 'label' => 'Confirm attach message', - 'help' => 'Do you want to be asked for confirmation before attaching selected messages to new mail?', - 'name' => 'prefaskformultipleforward', - 'values' => $no_yes, - 'xmlrpc' => True, - 'admin' => False, - 'forced' => '1', - ), -*/ -/* - 'mainscreen_showmail' => array( - 'type' => 'select', - 'label' => 'show new messages on home page', - 'help' => 'Should new messages show up on the Home page', - 'name' => 'mainscreen_showmail', - 'values' => $selectOptions, - 'xmlrpc' => True, - 'admin' => False, - ), - 'mainscreen_showfolders' => array( - 'type' => 'multiselect', - 'label' => 'home page folders', - 'help' => 'if shown, which folders should appear on the Home page', - 'name' => 'mainscreen_showfolders', - 'values' => $folderList, - 'xmlrpc' => True, - 'admin' => False, - ), -*/ array( 'type' => 'section', 'title' => lang('Configuration settings'), @@ -417,57 +384,6 @@ class mail_hooks 'default'=> 0, 'admin' => False, ), - /*'prefpreventmanagefolders' => array( - 'type' => 'select', - 'label' => 'Prevent managing folders', - 'help' => 'Do you want to prevent the managing of folders (creation, accessrights AND subscribtion)?', - 'name' => 'prefpreventmanagefolders', - 'values' => $prefAllowManageFolders, - 'xmlrpc' => True, - 'admin' => False, - 'forced' => '0', - ), - 'prefpreventforwarding' => array( - 'type' => 'select', - 'label' => 'Prevent managing forwards', - 'help' => 'Do you want to prevent the editing/setup for forwarding of mails via settings (, even if SIEVE is enabled)?', - 'name' => 'prefpreventforwarding', - 'values' => $no_yes, - 'xmlrpc' => True, - 'admin' => False, - 'forced' => '0', - ), - 'prefpreventnotificationformailviaemail' => array( - 'type' => 'select', - 'label' => 'Prevent managing notifications', - 'help' => 'Do you want to prevent the editing/setup of notification by mail to other emailadresses if emails arrive (, even if SIEVE is enabled)?', - 'name' => 'prefpreventnotificationformailviaemail', - 'values' => $no_yes, - 'xmlrpc' => True, - 'admin' => False, - 'forced' => '1', - ), - 'prefpreventeditfilterrules' => array( - 'type' => 'select', - 'label' => 'Prevent managing filters', - 'help' => 'Do you want to prevent the editing/setup of filter rules (, even if SIEVE is enabled)?', - 'name' => 'prefpreventeditfilterrules', - 'values' => $no_yes, - 'xmlrpc' => True, - 'admin' => False, - 'forced' => '0', - ), - 'prefpreventabsentnotice' => array( - 'type' => 'select', - 'label' => 'Prevent managing vacation notice', - 'help' => 'Do you want to prevent the editing/setup of the absent/vacation notice (, even if SIEVE is enabled)?', - 'name' => 'prefpreventabsentnotice', - 'values' => $no_yes, - 'xmlrpc' => True, - 'admin' => False, - 'forced' => '0', - ), - */ 'prefaskformove' => array( 'type' => 'select', 'label' => 'Confirm move to folder', diff --git a/mail/inc/class.mail_sieve.inc.php b/mail/inc/class.mail_sieve.inc.php index 00141c000d..404325f8ed 100644 --- a/mail/inc/class.mail_sieve.inc.php +++ b/mail/inc/class.mail_sieve.inc.php @@ -69,6 +69,8 @@ class mail_sieve if ($acc_id > 0) { $this->account = emailadmin_account::read($acc_id); + $identity = emailadmin_account::read_identity($acc_id,true); + $this->currentIdentity = mail_bo::generateIdentityString($identity,false); } $this->restoreSessionData(); @@ -111,7 +113,7 @@ class mail_sieve } else { - $content['msg'] = lang('error').':'.lang('Serverside Filterrules (Sieve) are not activated').'. '.lang('Please contact your Administrator to validate if your Server supports Serverside Filterrules, and how to enable them in EGroupware for your active Account (%1) with ID:%2.',$this->currentIdentity['identity_string'],$this->mailbo->profileID); + $content['msg'] = lang('error').':'.lang('Serverside Filterrules (Sieve) are not activated').'. '.lang('Please contact your Administrator to validate if your Server supports Serverside Filterrules, and how to enable them in EGroupware for your active Account (%1) with ID:%2.',$this->currentIdentity,$this->account->acc_id); $content['hideIfSieveDisabled']='mail_DisplayNone'; } $tmpl->exec('mail.mail_sieve.index',$content,$sel_options,array()); @@ -208,7 +210,7 @@ class mail_sieve } else { - $content['msg'] = lang('error').':'.lang('Serverside Filterrules (Sieve) are not activated').'. '.lang('Please contact your Administrator to validate if your Server supports Serverside Filterrules, and how to enable them in EGroupware for your active Account (%1) with ID:%2.',$this->currentIdentity['identity_string'],$this->mailbo->profileID); + $content['msg'] = lang('error').':'.lang('Serverside Filterrules (Sieve) are not activated').'. '.lang('Please contact your Administrator to validate if your Server supports Serverside Filterrules, and how to enable them in EGroupware for your active Account (%1) with ID:%2.',$this->currentIdentity,$this->account->acc_id); $content['hideIfSieveDisabled']='mail_DisplayNone'; } $eNotitmpl->exec('mail.mail_sieve.editEmailNotification', $content,$sel_options); @@ -524,167 +526,175 @@ class mail_sieve if ($icServer->acc_sieve_enabled) { $vacRules = $this->getVacation($account_id); - - if ($icServer->acc_imap_administration) + if ($vacRules['vacation']===false) { - $ByDate = array('by_date' => lang('By date')); + $content['msg'] = lang('error').':'.lang('Serverside Vacationnotice (via Sieve) are not activated').'. '. + lang('Please contact your Administrator to validate if your Server supports Serverside Vacationmessages, and how to enable them in EGroupware for your active Account (%1) with ID:%2.',$this->currentIdentity,$icServer->ImapServerId); + $content['hideIfSieveDisabled']='mail_DisplayNone'; } - if (!is_array($content) || ($content['acc_id'] && !isset($content['button']))) + else { - $content = $vacation = $vacRules['vacation']; - if (!empty($profileID)) $content['acc_id'] = $profileID; - if (empty($vacation['addresses']) || implode('',$vacation['addresses']) == '') + if ($icServer->acc_imap_administration) { - $content['addresses'] = $vacRules['aliases']; + $ByDate = array('by_date' => lang('By date')); } - if (!empty($vacation['forwards'])) + if (!is_array($content) || ($content['acc_id'] && !isset($content['button']))) { - $content['forwards'] = explode(",",$vacation['forwards']); + $content = $vacation = $vacRules['vacation']; + if (!empty($profileID)) $content['acc_id'] = $profileID; + if (empty($vacation['addresses']) || implode('',$vacation['addresses']) == '') + { + $content['addresses'] = $vacRules['aliases']; + } + if (!empty($vacation['forwards'])) + { + $content['forwards'] = explode(",",$vacation['forwards']); + } + else + { + $content['forwards'] = ''; + } + if (empty($vacation['text']) && $this->mailConfig['default_vacation_text']) $content['text'] = $this->mailConfig['default_vacation_text']; + //Set default value for days new entry + if (empty($content['days'])) + { + $content['days'] = '3'; + } + $preserv['is_admin_vac'] = $content['is_admin_vac'] = $this->is_admin_vac; } else { - $content['forwards'] = ''; - } - if (empty($vacation['text']) && $this->mailConfig['default_vacation_text']) $content['text'] = $this->mailConfig['default_vacation_text']; - //Set default value for days new entry - if (empty($content['days'])) - { - $content['days'] = '3'; - } - $preserv['is_admin_vac'] = $content['is_admin_vac'] = $this->is_admin_vac; - } - else - { - $this->restoreSessionData(); - list($button) = @each($content['button']); - unset ($content['button']); + $this->restoreSessionData(); + list($button) = @each($content['button']); + unset ($content['button']); - switch($button) - { - case 'save': - case 'apply': - if ($GLOBALS['egw_info']['user']['apps']['admin']) - { - // store text as default - if ($content['set_as_default'] == 1) + switch($button) + { + case 'save': + case 'apply': + if ($GLOBALS['egw_info']['user']['apps']['admin']) { - config::save_value('default_vacation_text', $content['text'], 'mail'); - } - } - if (isset($content['status'])) - { - //error_log(__METHOD__. 'content:' . array2string($content)); - $newVacation = $content; - - if (empty($this->mailConfig['prefpreventforwarding']) || - $this->mailConfig['prefpreventforwarding'] == 0 ) - { - if (is_array($content['forwards']) && !empty($content['forwards'])) + // store text as default + if ($content['set_as_default'] == 1) { + config::save_value('default_vacation_text', $content['text'], 'mail'); + } + } + if (isset($content['status'])) + { + //error_log(__METHOD__. 'content:' . array2string($content)); + $newVacation = $content; - $newVacation['forwards'] = implode(",",$content['forwards']); + if (empty($this->mailConfig['prefpreventforwarding']) || + $this->mailConfig['prefpreventforwarding'] == 0 ) + { + if (is_array($content['forwards']) && !empty($content['forwards'])) + { + + $newVacation['forwards'] = implode(",",$content['forwards']); + } + else + { + $newVacation ['forwards'] = ''; + } } else { - $newVacation ['forwards'] = ''; + unset($newVacation ['forwards']); } - } - else - { - unset($newVacation ['forwards']); - } - if (!in_array($newVacation['status'],array('on','off','by_date'))) - { - $newVacation['status'] = 'off'; - } - - $checkAddresses = isset($content['check_mail_sent_to']) && $content['check_mail_sent_to'] != 0; - if ($content['addresses']) - { - $newVacation ['addresses'] = $content['addresses']; - } - - if($this->checkRule($newVacation,$checkAddresses)) - { - if (isset($account_id) && $this->mail_admin) + if (!in_array($newVacation['status'],array('on','off','by_date'))) { - $resSetvac = $icServer->setVacationUser($account_id, $newVacation, $this->scriptName); + $newVacation['status'] = 'off'; + } + + $checkAddresses = isset($content['check_mail_sent_to']) && $content['check_mail_sent_to'] != 0; + if ($content['addresses']) + { + $newVacation ['addresses'] = $content['addresses']; + } + + if($this->checkRule($newVacation,$checkAddresses)) + { + if (isset($account_id) && $this->mail_admin) + { + $resSetvac = $icServer->setVacationUser($account_id, $newVacation, $this->scriptName); + } + else + { + $resSetvac = $icServer->setVacation($newVacation); + } + + if (!$resSetvac) + { + $msg = lang('vacation update failed') . "\n" . lang('Vacation notice update failed') . ":" . $this->account->imapServer()->error; + break; + } + // schedule job to switch message on/off, if request and not already in past + else + { + if ($newVacation['status'] == 'by_date' && $newVacation['end_date']+24*3600 > time() || + $vacRules && $vacRules['vacation']['status'] == 'by_date') + { + self::setAsyncJob($newVacation); + } + //Reset vacationNotice cache which is used in mail_ui get_rows + $cachedVacations = egw_cache::getCache(egw_cache::INSTANCE, 'email', 'vacationNotice'.$GLOBALS['egw_info']['user']['account_lid']); + $cachedVacations = array($icServer->acc_id => $newVacation) + (array)$cachedVacations; + egw_cache::setCache(egw_cache::INSTANCE,'email', 'vacationNotice'.$GLOBALS['egw_info']['user']['account_lid'], $cachedVacations); + + $msg = lang('Vacation notice sucessfully updated.'); + } } else { - $resSetvac = $icServer->setVacation($newVacation); + $msg .= implode("\n",$this->errorStack); } - - if (!$resSetvac) + // refresh vacationNotice on index + $response = egw_json_response::get(); + $response->call('app.mail.mail_callRefreshVacationNotice',$icServer->ImapServerId); + egw_framework::refresh_opener($msg, 'mail'); + if ($button === 'apply' || $icServer->error !=="") { - $msg = lang('vacation update failed') . "\n" . lang('Vacation notice update failed') . ":" . $this->account->imapServer()->error; break; } - // schedule job to switch message on/off, if request and not already in past - else - { - if ($newVacation['status'] == 'by_date' && $newVacation['end_date']+24*3600 > time() || - $vacRules && $vacRules['vacation']['status'] == 'by_date') - { - self::setAsyncJob($newVacation); - } - //Reset vacationNotice cache which is used in mail_ui get_rows - $cachedVacations = egw_cache::getCache(egw_cache::INSTANCE, 'email', 'vacationNotice'.$GLOBALS['egw_info']['user']['account_lid']); - $cachedVacations = array($icServer->acc_id => $newVacation) + (array)$cachedVacations; - egw_cache::setCache(egw_cache::INSTANCE,'email', 'vacationNotice'.$GLOBALS['egw_info']['user']['account_lid'], $cachedVacations); + } - $msg = lang('Vacation notice sucessfully updated.'); - } - } - else - { - $msg .= implode("\n",$this->errorStack); - } - // refresh vacationNotice on index - $response = egw_json_response::get(); - $response->call('app.mail.mail_callRefreshVacationNotice',$this->mailbo->profileID); - egw_framework::refresh_opener($msg, 'mail'); - if ($button === 'apply' || $icServer->error !=="") - { - break; - } - } - - case 'cancel': - egw_framework::window_close(); + case 'cancel': + egw_framework::window_close(); + } } - } - $sel_options = array( - 'status' => array( - 'on' => lang('Active'), - 'off' => lang('Deactive'), - ), - 'addresses' => array_combine($vacRules['aliases'],$vacRules['aliases']), - ); - if (!isset($account_id)) - { - $readonlys['acc_id'] = true; + $sel_options = array( + 'status' => array( + 'on' => lang('Active'), + 'off' => lang('Deactive'), + ), + 'addresses' => array_combine($vacRules['aliases'],$vacRules['aliases']), + ); + if (!isset($account_id)) + { + $readonlys['acc_id'] = true; + } + else + { + $sel_options['acc_id'] = $allAccounts; + } + if (!empty($ByDate)) + { + $sel_options['status'] += $ByDate; + } + if (!isset($GLOBALS['egw_info']['user']['apps']['admin'])) + { + $content['is_not_admin_user'] = true; + $readonlys['set_as_default'] = true; + } + $content['msg'] = $msg; } - else - { - $sel_options['acc_id'] = $allAccounts; - } - if (!empty($ByDate)) - { - $sel_options['status'] += $ByDate; - } - if (!isset($GLOBALS['egw_info']['user']['apps']['admin'])) - { - $content['is_not_admin_user'] = true; - $readonlys['set_as_default'] = true; - } - $content['msg'] = $msg; } else { - $content['msg'] = lang('error').':'.lang('Serverside Filterrules (Sieve) are not activated').'. '.lang('Please contact your Administrator to validate if your Server supports Serverside Filterrules, and how to enable them in EGroupware for your active Account (%1) with ID:%2.',$this->currentIdentity['identity_string'],$this->mailbo->profileID); + $content['msg'] = lang('error').':'.lang('Serverside Filterrules (Sieve) are not activated').'. '.lang('Please contact your Administrator to validate if your Server supports Serverside Filterrules, and how to enable them in EGroupware for your active Account (%1) with ID:%2.',$this->currentIdentity,$icServer->ImapServerId); $content['hideIfSieveDisabled']='mail_DisplayNone'; } $vtmpl->exec('mail.mail_sieve.editVacation',$content,$sel_options,$readonlys,$preserv,2);