All Data Structures Functions Variables Pages
DropDownTriggerRules.php
1 <?php
2  /*********************************************************************************
3  * Zurmo is a customer relationship management program developed by
4  * Zurmo, Inc. Copyright (C) 2017 Zurmo Inc.
5  *
6  * Zurmo is free software; you can redistribute it and/or modify it under
7  * the terms of the GNU Affero General Public License version 3 as published by the
8  * Free Software Foundation with the addition of the following permission added
9  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
10  * IN WHICH THE COPYRIGHT IS OWNED BY ZURMO, ZURMO DISCLAIMS THE WARRANTY
11  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
12  *
13  * Zurmo is distributed in the hope that it will be useful, but WITHOUT
14  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15  * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
16  * details.
17  *
18  * You should have received a copy of the GNU Affero General Public License along with
19  * this program; if not, see http://www.gnu.org/licenses or write to the Free
20  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21  * 02110-1301 USA.
22  *
23  * You can contact Zurmo, Inc. with a mailing address at 27 North Wacker Drive
24  * Suite 370 Chicago, IL 60606. or at email address contact@zurmo.com.
25  *
26  * The interactive user interfaces in original and modified versions
27  * of this program must display Appropriate Legal Notices, as required under
28  * Section 5 of the GNU Affero General Public License version 3.
29  *
30  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
31  * these Appropriate Legal Notices must retain the display of the Zurmo
32  * logo and Zurmo copyright notice. If the display of the logo is not reasonably
33  * feasible for technical reasons, the Appropriate Legal Notices must display the words
34  * "Copyright Zurmo Inc. 2017. All rights reserved".
35  ********************************************************************************/
36 
41  {
48  public function evaluateBeforeSave(RedBeanModel $model, $attribute)
49  {
50  assert('is_string($attribute)');
51  switch($this->trigger->getOperator())
52  {
53  case OperatorRules::TYPE_EQUALS:
54  if (static::sanitize($model->{$attribute}->value) === static::sanitize($this->trigger->value))
55  {
56  return true;
57  }
58  break;
59  case OperatorRules::TYPE_DOES_NOT_EQUAL:
60  if (static::sanitize($model->{$attribute}->value) !== static::sanitize($this->trigger->value))
61  {
62  return true;
63  }
64  break;
65  case OperatorRules::TYPE_ONE_OF:
66  if (!is_array(static::sanitize($this->trigger->value)))
67  {
68  return false;
69  }
70  if (in_array(static::sanitize($model->{$attribute}->value), static::sanitize($this->trigger->value)))
71  {
72  return true;
73  }
74  break;
75  case OperatorRules::TYPE_CHANGES:
76  if (array_key_exists('value', $model->{$attribute}->originalAttributeValues))
77  {
78  return true;
79  }
80  break;
81  case OperatorRules::TYPE_DOES_NOT_CHANGE:
82  if (!array_key_exists('value', $model->{$attribute}->originalAttributeValues))
83  {
84  return true;
85  }
86  break;
87  case OperatorRules::TYPE_BECOMES:
88  if (array_key_exists('value', $model->{$attribute}->originalAttributeValues) &&
89  static::sanitize($model->{$attribute}->value) === static::sanitize($this->trigger->value))
90  {
91  return true;
92  }
93  break;
94  case OperatorRules::TYPE_WAS:
95  if (array_key_exists('value', $model->{$attribute}->originalAttributeValues) &&
96  static::sanitize($model->{$attribute}->originalAttributeValues['value']) ===
97  static::sanitize($this->trigger->value))
98  {
99  return true;
100  }
101  break;
102  case OperatorRules::TYPE_BECOMES_ONE_OF:
103  if (!is_array(static::sanitize($this->trigger->value)))
104  {
105  return false;
106  }
107  if (array_key_exists('value', $model->{$attribute}->originalAttributeValues) &&
108  in_array(static::sanitize($model->{$attribute}->value), static::sanitize($this->trigger->value)))
109  {
110  return true;
111  }
112  break;
113  case OperatorRules::TYPE_WAS_ONE_OF:
114  if (!is_array(static::sanitize($this->trigger->value)))
115  {
116  return false;
117  }
118  if (array_key_exists('value', $model->{$attribute}->originalAttributeValues) &&
119  in_array(static::sanitize($model->{$attribute}->originalAttributeValues['value']),
120  static::sanitize($this->trigger->value)))
121  {
122  return true;
123  }
124  break;
125  case OperatorRules::TYPE_IS_EMPTY:
126  if (empty($model->{$attribute}->value))
127  {
128  return true;
129  }
130  break;
131  case OperatorRules::TYPE_IS_NOT_EMPTY:
132  if (!empty($model->{$attribute}->value))
133  {
134  return true;
135  }
136  break;
137  default:
138  throw new NotSupportedException();
139  }
140  return false;
141  }
142 
150  public function evaluateTimeTriggerBeforeSave(RedBeanModel $model, $attribute, $changeRequiredToProcess = true)
151  {
152  assert('is_string($attribute)');
153  assert('is_bool($changeRequiredToProcess)');
154  if (array_key_exists('value', $model->{$attribute}->originalAttributeValues) || !$changeRequiredToProcess)
155  {
156  if ($this->trigger->getOperator() == OperatorRules::TYPE_DOES_NOT_CHANGE)
157  {
158  return true;
159  }
160  return $this->evaluateBeforeSave($model, $attribute);
161  }
162  return false;
163  }
164  }
165 ?>
evaluateTimeTriggerBeforeSave(RedBeanModel $model, $attribute, $changeRequiredToProcess=true)
evaluateBeforeSave(RedBeanModel $model, $attribute)
Generated on Sat Feb 22 2020 07:10:34