Overview

Packages

  • Horde
    • Icalendar
      • UnitTests
  • Ingo
    • UnitTests
  • None

Classes

  • Horde_Core_Ui_VarRenderer_Ingo
  • Ingo
  • Ingo_Api
  • Ingo_Exception
  • Ingo_Exception_Pear
  • Ingo_LoginTasks_SystemTask_Upgrade
  • Ingo_Script
  • Ingo_Script_Imap
  • Ingo_Script_Imap_Api
  • Ingo_Script_Imap_Live
  • Ingo_Script_Maildrop
  • Ingo_Script_Maildrop_Comment
  • Ingo_Script_Maildrop_Recipe
  • Ingo_Script_Maildrop_Variable
  • Ingo_Script_Procmail
  • Ingo_Script_Procmail_Comment
  • Ingo_Script_Procmail_Recipe
  • Ingo_Script_Procmail_Variable
  • Ingo_Script_Sieve
  • Ingo_Script_Sieve_Action
  • Ingo_Script_Sieve_Action_Addflag
  • Ingo_Script_Sieve_Action_Discard
  • Ingo_Script_Sieve_Action_Fileinto
  • Ingo_Script_Sieve_Action_Flag
  • Ingo_Script_Sieve_Action_Keep
  • Ingo_Script_Sieve_Action_Notify
  • Ingo_Script_Sieve_Action_Redirect
  • Ingo_Script_Sieve_Action_Reject
  • Ingo_Script_Sieve_Action_Removeflag
  • Ingo_Script_Sieve_Action_Stop
  • Ingo_Script_Sieve_Action_Vacation
  • Ingo_Script_Sieve_Comment
  • Ingo_Script_Sieve_Else
  • Ingo_Script_Sieve_Elsif
  • Ingo_Script_Sieve_If
  • Ingo_Script_Sieve_Test
  • Ingo_Script_Sieve_Test_Address
  • Ingo_Script_Sieve_Test_Allof
  • Ingo_Script_Sieve_Test_Anyof
  • Ingo_Script_Sieve_Test_Body
  • Ingo_Script_Sieve_Test_Exists
  • Ingo_Script_Sieve_Test_False
  • Ingo_Script_Sieve_Test_Header
  • Ingo_Script_Sieve_Test_Not
  • Ingo_Script_Sieve_Test_Relational
  • Ingo_Script_Sieve_Test_Size
  • Ingo_Script_Sieve_Test_True
  • Ingo_Storage
  • Ingo_Storage_Blacklist
  • Ingo_Storage_Filters
  • Ingo_Storage_Filters_Sql
  • Ingo_Storage_Forward
  • Ingo_Storage_Mock
  • Ingo_Storage_Prefs
  • Ingo_Storage_Rule
  • Ingo_Storage_Spam
  • Ingo_Storage_Sql
  • Ingo_Storage_Vacation
  • Ingo_Storage_VacationTest
  • Ingo_Storage_Whitelist
  • Ingo_Test
  • Ingo_Transport
  • Ingo_Transport_Ldap
  • Ingo_Transport_Null
  • Ingo_Transport_Sivtest
  • Ingo_Transport_Timsieved
  • Ingo_Transport_Vfs
  • Overview
  • Package
  • Class
  • Tree
  1: <?php
  2: /**
  3:  * The Ingo_Script_Sieve_Test_Address class represents a test on parts or all
  4:  * of the addresses in the given fields.
  5:  *
  6:  * See the enclosed file LICENSE for license information (ASL).  If you
  7:  * did not receive this file, see http://www.horde.org/licenses/apache.
  8:  *
  9:  * @author  Mike Cochrane <mike@graftonhall.co.nz>
 10:  * @package Ingo
 11:  */
 12: class Ingo_Script_Sieve_Test_Address extends Ingo_Script_Sieve_Test
 13: {
 14:     /**
 15:      * Constructor.
 16:      *
 17:      * @param array $vars  Any required parameters.
 18:      */
 19:     public function __construct($vars)
 20:     {
 21:         $this->_vars['headers'] = isset($vars['headers'])
 22:             ? $vars['headers']
 23:             : '';
 24:         $this->_vars['comparator'] = isset($vars['comparator'])
 25:             ? $vars['comparator']
 26:             : 'i;ascii-casemap';
 27:         $this->_vars['match-type'] = isset($vars['match-type'])
 28:             ? $vars['match-type']
 29:             : ':is';
 30:         $this->_vars['address-part'] = isset($vars['address-part'])
 31:             ? $vars['address-part']
 32:             : ':all';
 33:         $this->_vars['addresses'] = isset($vars['addresses'])
 34:             ? $vars['addresses']
 35:             : '';
 36:     }
 37: 
 38:     /**
 39:      * Checks if the rule parameters are valid.
 40:      *
 41:      * @return boolean|string  True if this rule is valid, an error message
 42:      *                         otherwise.
 43:      */
 44:     public function check()
 45:     {
 46:         return preg_split('(\r\n|\n|\r)', $this->_vars['headers']) &&
 47:                preg_split('(\r\n|\n|\r)', $this->_vars['addresses']);
 48:     }
 49: 
 50:     /**
 51:      * Returns a script snippet representing this rule and any sub-rules.
 52:      *
 53:      * @return string  A Sieve script snippet.
 54:      */
 55:     public function toCode()
 56:     {
 57:         $code = 'address ' .
 58:             $this->_vars['address-part'] . ' ' .
 59:             ':comparator "' . $this->_vars['comparator'] . '" ' .
 60:             $this->_vars['match-type'] . ' ';
 61: 
 62:         $headers = preg_split('(\r\n|\n|\r|,)', $this->_vars['headers']);
 63:         $headers = array_filter($headers);
 64:         if (count($headers) > 1) {
 65:             $code .= "[";
 66:             $headerstr = '';
 67:             foreach ($headers as $header) {
 68:                 $header = trim($header);
 69:                 if (!empty($header)) {
 70:                     $headerstr .= empty($headerstr) ? '"' : ', "';
 71:                     $headerstr .= Ingo_Script_Sieve::escapeString($header, $this->_vars['match-type'] == ':regex') . '"';
 72:                 }
 73:             }
 74:             $code .= $headerstr . "] ";
 75:         } elseif (count($headers) == 1) {
 76:             $code .= '"' . Ingo_Script_Sieve::escapeString($headers[0], $this->_vars['match-type'] == ':regex') . '" ';
 77:         } else {
 78:             return "No Headers Specified";
 79:         }
 80: 
 81:         $addresses = preg_split('(\r\n|\n|\r)', $this->_vars['addresses']);
 82:         $addresses = array_filter($addresses);
 83:         if (count($addresses) > 1) {
 84:             $code .= "[";
 85:             $addressstr = '';
 86:             foreach ($addresses as $addr) {
 87:                 $addr = trim($addr);
 88:                 if (!empty($addr)) {
 89:                     $addressstr .= empty($addressstr) ? '"' : ', "';
 90:                     $addressstr .= Ingo_Script_Sieve::escapeString($addr, $this->_vars['match-type'] == ':regex') . '"';
 91:                 }
 92:             }
 93:             $code .= $addressstr . "] ";
 94:         } elseif (count($addresses) == 1) {
 95:             $code .= '"' . Ingo_Script_Sieve::escapeString($addresses[0], $this->_vars['match-type'] == ':regex') . '" ';
 96:         } else {
 97:             return "No Addresses Specified";
 98:         }
 99: 
100:         return $code;
101:     }
102: 
103:     /**
104:      * Returns a list of sieve extensions required for this rule and any
105:      * sub-rules.
106:      *
107:      * @return array  A Sieve extension list.
108:      */
109:     public function requires()
110:     {
111:         return ($this->_vars['match-type'] == ':regex')
112:             ? array('regex')
113:             : array();
114:     }
115: 
116: }
117: 
API documentation generated by ApiGen