211 lines
4.4 KiB
PHP
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());
|
|
}
|
|
}
|