Files
server/usr/share/psa-horde/ingo/lib/Script/Sieve/If.php
2026-01-07 20:52:11 +01:00

211 lines
4.4 KiB
PHP

<?php
/**
* Copyright 2012-2017 Horde LLC (http://www.horde.org/)
*
* See the enclosed file LICENSE for license information (ASL). If you
* did not receive this file, see http://www.horde.org/licenses/apache.
*
* @author Mike Cochrane <mike@graftonhall.co.nz>
* @author Jan Schneider <jan@horde.org>
* @category Horde
* @license http://www.horde.org/licenses/apache ASL
* @package Ingo
*/
/**
* The Ingo_Script_Sieve_If class represents a Sieve If Statement.
*
* @author Mike Cochrane <mike@graftonhall.co.nz>
* @author Jan Schneider <jan@horde.org>
* @category Horde
* @license http://www.horde.org/licenses/apache ASL
* @package Ingo
*/
class Ingo_Script_Sieve_If implements Ingo_Script_Item
{
/**
* The Ingo_Script_Sieve_Test object for the if test.
*
* @var Ingo_Script_Sieve_Test
*/
protected $_test;
/**
* A list of Ingo_Script_Sieve_Action objects that go into the if clause.
*
* @var array
*/
protected $_actions = array();
/**
* A list of Ingo_Script_Sieve_Elseif objects that create optional elsif
* clauses.
*
* @var array
*/
protected $_elsifs = array();
/**
* A Ingo_Script_Sieve_Else object that creates an optional else clause.
*
* @var Ingo_Script_Sieve_Else
*/
protected $_else;
/**
* Constructor.
*
* @param Ingo_Script_Sieve_Test $test A Ingo_Script_Sieve_Test object.
*/
public function __construct($test = null)
{
$this->_test = is_null($test)
? new Ingo_Script_Sieve_Test_False()
: $test;
$this->_actions[] = new Ingo_Script_Sieve_Action_Keep();
$this->_else = new Ingo_Script_Sieve_Else();
}
/**
*/
public function getTest()
{
return $this->_test;
}
/**
*/
public function setTest($test)
{
$this->_test = $test;
}
/**
*/
public function getActions()
{
return $this->_actions;
}
/**
*/
public function setActions($actions)
{
$this->_actions = $actions;
}
/**
*/
public function getElsifs()
{
return $this->_elsifs;
}
/**
*/
public function setElsifs($elsifs)
{
$this->_elsifs = $elsifs;
}
/**
*/
public function addElsif($elsif)
{
$this->_elsifs[] = $elsif;
}
/**
*/
public function getElse()
{
return $this->_else;
}
/**
*/
public function setElse($else)
{
$this->_else = $else;
}
/**
* Returns a script snippet representing this rule and any sub-rules.
*
* @return string A Sieve script snippet.
*/
public function generate()
{
$code = 'if ' . $this->_test->generate() . " {\n";
foreach ($this->_actions as $action) {
$code .= ' ' . $action->generate() . "\n";
}
$code .= '}';
foreach ($this->_elsifs as $elsif) {
$code .= $elsif->generate();
}
$code .= $this->_else->generate();
return $code;
}
/**
* Checks if all sub-rules are valid.
*
* @return boolean|string True if all rules are valid, an error message
* otherwise.
*/
public function check()
{
$res = $this->_test->check();
if ($res !== true) {
return $res;
}
foreach ($this->_elsifs as $elsif) {
$res = $elsif->check();
if ($res !== true) {
return $res;
}
}
$res = $this->_else->check();
if ($res !== true) {
return $res;
}
foreach ($this->_actions as $action) {
$res = $action->check();
if ($res !== true) {
return $res;
}
}
return true;
}
/**
* Returns a list of sieve extensions required for this rule and any
* sub-rules.
*
* @return array A Sieve extension list.
*/
public function requires()
{
$requires = array();
foreach ($this->_actions as $action) {
$requires = array_merge($requires, $action->requires());
}
foreach ($this->_elsifs as $elsif) {
$requires = array_merge($requires, $elsif->requires());
}
return array_merge($requires, $this->_test->requires(), $this->_else->requires());
}
}