2016-03-28 20:51:38 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* EGroupware Api: Support for Sieve scripts
|
|
|
|
*
|
|
|
|
* @link http://www.egroupware.org
|
|
|
|
* @package api
|
|
|
|
* @subpackage mail
|
|
|
|
* @author Ralf Becker <rb@stylite.de>
|
|
|
|
* @author Klaus Leithoff <kl@stylite.de>
|
|
|
|
* @author Lars Kneschke
|
|
|
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
|
|
|
* @version $Id$
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace EGroupware\Api\Mail;
|
|
|
|
|
|
|
|
use EGroupware\Api\Translation;
|
|
|
|
use Horde;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Support for Sieve scripts
|
|
|
|
*
|
|
|
|
* Constructor and setters will throw exceptions for connection, login or other errors.
|
|
|
|
*
|
|
|
|
* retriveRules and getters will not throw an exception, if there's no script currently.
|
|
|
|
*
|
|
|
|
* Most methods incl. constructor accept a script-name, but by default current active script is used
|
|
|
|
* and if theres no script Sieve::DEFAULT_SCRIPT_NAME.
|
|
|
|
*/
|
|
|
|
class Sieve extends Horde\ManageSieve
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* reference to Imap object
|
|
|
|
*
|
|
|
|
* @var Imap
|
|
|
|
*/
|
|
|
|
var $icServer;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string name of active script queried from Sieve server
|
|
|
|
*/
|
|
|
|
var $scriptName;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var $rules containing the rules
|
|
|
|
*/
|
|
|
|
var $rules;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var $vacation containing the vacation
|
|
|
|
*/
|
|
|
|
var $vacation;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var $emailNotification containing the emailNotification
|
|
|
|
*/
|
|
|
|
var $emailNotification;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var object $error the last PEAR error object
|
|
|
|
*/
|
|
|
|
var $error;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The timeout for the connection to the SIEVE server.
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
var $_timeout = 10;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Switch on some error_log debug messages
|
|
|
|
*
|
|
|
|
* @var boolean
|
|
|
|
*/
|
|
|
|
var $debug = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Default script name used if no active script found on server
|
|
|
|
*/
|
|
|
|
const DEFAULT_SCRIPT_NAME = 'mail';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*
|
|
|
|
* @param array|Imap $params =array()
|
|
|
|
*/
|
|
|
|
function __construct($params=array())
|
|
|
|
{
|
|
|
|
if (is_a($params, __NAMESPACE__.'\\Imap'))
|
|
|
|
{
|
|
|
|
$params = array(
|
|
|
|
'host' => $params->acc_sieve_host ? $params->acc_sieve_host : $params->acc_imap_host,
|
|
|
|
'port' => $params->acc_sieve_port,
|
|
|
|
'secure' => Account::ssl2secure($params->acc_sieve_ssl),
|
|
|
|
'user' => $params->isAdminConnection ? $params->acc_imap_admin_username : $params->acc_imap_username,
|
|
|
|
'password' => $params->isAdminConnection ? $params->acc_imap_admin_password : $params->acc_imap_password,
|
|
|
|
'euser' => $params->isAdminConnection ? $params->acc_imap_username : null,
|
2017-01-31 18:01:08 +01:00
|
|
|
//'logger' => new \admin_mail_logger('/tmp/sieve.log'),
|
2016-03-28 20:51:38 +02:00
|
|
|
);
|
|
|
|
}
|
2020-02-05 10:51:38 +01:00
|
|
|
// try "PLAIN" first, in case IMAP wrongly reports some digest, it does not (correctly) implement
|
2020-02-05 10:58:34 +01:00
|
|
|
array_unshift($this->supportedAuthMethods, self::AUTH_PLAIN);
|
|
|
|
|
2016-03-28 20:51:38 +02:00
|
|
|
parent::__construct($params);
|
|
|
|
|
|
|
|
$this->displayCharset = Translation::charset();
|
|
|
|
}
|
|
|
|
|
|
|
|
function getRules()
|
|
|
|
{
|
|
|
|
if (!isset($this->rules)) $this->retrieveRules();
|
|
|
|
|
|
|
|
return $this->rules;
|
|
|
|
}
|
|
|
|
|
|
|
|
function getVacation()
|
|
|
|
{
|
|
|
|
if (!isset($this->rules)) $this->retrieveRules();
|
|
|
|
|
|
|
|
return $this->vacation;
|
|
|
|
}
|
|
|
|
|
|
|
|
function getEmailNotification()
|
|
|
|
{
|
|
|
|
if (!isset($this->rules)) $this->retrieveRules();
|
|
|
|
|
|
|
|
return $this->emailNotification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set email notifications
|
|
|
|
*
|
|
|
|
* @param array $_rules
|
|
|
|
* @param string $_scriptName
|
|
|
|
* @param boolean $utf7imap_fileinto =false true: encode foldernames with utf7imap, default utf8
|
|
|
|
*/
|
|
|
|
function setRules(array $_rules, $_scriptName=null, $utf7imap_fileinto=false)
|
|
|
|
{
|
|
|
|
$script = $this->retrieveRules($_scriptName);
|
|
|
|
$script->debug = $this->debug;
|
|
|
|
$script->rules = $_rules;
|
|
|
|
$ret = $script->updateScript($this, $utf7imap_fileinto);
|
|
|
|
$this->error = $script->errstr;
|
|
|
|
return $ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set email notifications
|
|
|
|
*
|
|
|
|
* @param array $_vacation
|
|
|
|
* @param string $_scriptName
|
|
|
|
*/
|
|
|
|
function setVacation(array $_vacation, $_scriptName=null)
|
|
|
|
{
|
|
|
|
if ($this->debug)
|
|
|
|
{
|
|
|
|
error_log(__METHOD__ . "($_scriptName," . print_r($_vacation, true) . ')');
|
|
|
|
}
|
|
|
|
$script = $this->retrieveRules($_scriptName);
|
|
|
|
$script->debug = $this->debug;
|
|
|
|
$script->vacation = $_vacation;
|
|
|
|
$ret = $script->updateScript($this);
|
|
|
|
$this->error = $script->errstr;
|
|
|
|
return $ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set email notifications
|
|
|
|
*
|
|
|
|
* @param array $_emailNotification
|
|
|
|
* @param string $_scriptName
|
|
|
|
* @return Script
|
|
|
|
*/
|
|
|
|
function setEmailNotification(array $_emailNotification, $_scriptName=null)
|
|
|
|
{
|
|
|
|
if ($_emailNotification['externalEmail'] == '' || !preg_match("/\@/",$_emailNotification['externalEmail'])) {
|
|
|
|
$_emailNotification['status'] = 'off';
|
|
|
|
$_emailNotification['externalEmail'] = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$script = $this->retrieveRules($_scriptName);
|
|
|
|
$script->emailNotification = $_emailNotification;
|
|
|
|
$ret = $script->updateScript($this);
|
|
|
|
$this->error = $script->errstr;
|
|
|
|
return $ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrive rules, vacation, notifications and return Script object to update them
|
|
|
|
*
|
|
|
|
* @param string $_scriptName
|
|
|
|
* @return Script
|
|
|
|
*/
|
|
|
|
function retrieveRules($_scriptName=null)
|
|
|
|
{
|
|
|
|
if (!$_scriptName)
|
|
|
|
{
|
|
|
|
// query active script from Sieve server
|
|
|
|
if (empty($this->scriptName))
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$this->scriptName = $this->getActive();
|
|
|
|
}
|
|
|
|
catch(Exception $e) {
|
|
|
|
unset($e); // ignore NOTEXISTS exception
|
|
|
|
}
|
|
|
|
if (empty($this->scriptName))
|
|
|
|
{
|
|
|
|
$this->scriptName = self::DEFAULT_SCRIPT_NAME;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$_scriptName = $this->scriptName;
|
|
|
|
}
|
|
|
|
$script = new Script($_scriptName);
|
|
|
|
|
|
|
|
try {
|
|
|
|
$script->retrieveRules($this);
|
|
|
|
}
|
|
|
|
catch (\Exception $e) {
|
|
|
|
unset($e); // ignore not found script exception
|
|
|
|
}
|
|
|
|
$this->rules =& $script->rules;
|
|
|
|
$this->vacation =& $script->vacation;
|
|
|
|
$this->emailNotification =& $script->emailNotification; // Added email notifications
|
|
|
|
|
|
|
|
return $script;
|
|
|
|
}
|
|
|
|
}
|