/usr/share/horde/ingo/lib/Script/Sieve/Test/Allof.php is in php-horde-ingo 3.2.16-1ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 | <?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_Test_Allof class represents a Allof test structure.
*
* Equivalent to a logical AND of all the tests it contains.
*
* @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_Test_Allof extends Ingo_Script_Sieve_Test
{
/**
*/
protected $_tests = array();
/**
* Constructor.
*
* @param mixed $test A Ingo_Script_Sieve_Test object or a list of
* Ingo_Script_Sieve_Test objects.
*/
public function __construct($test = null)
{
if (is_array($test)) {
$this->_tests = $test;
} elseif (!is_null($test)) {
$this->_tests[] = $test;
}
}
/**
* Returns a script snippet representing this rule and any sub-rules.
*
* @return string A Sieve script snippet.
*/
public function generate()
{
$code = '';
if (count($this->_tests) > 1) {
$testlist = '';
foreach ($this->_tests as $test) {
$testlist .= (empty($testlist)) ? '' : ', ';
$testlist .= trim($test->generate());
}
$code = "allof ( $testlist )";
} elseif (count($this->_tests) == 1) {
$code = $this->_tests[0]->generate();
} else {
return 'true';
}
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()
{
foreach ($this->_tests as $test) {
$res = $test->check();
if ($res !== true) {
return $res;
}
}
return true;
}
/**
*/
public function addTest($test)
{
$this->_tests[] = $test;
}
/**
*/
public function getTests()
{
return $this->_tests;
}
/**
* 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->_tests as $test) {
$requires = array_merge($requires, $test->requires());
}
return $requires;
}
}
|