All Data Structures Functions Variables Pages
ContactStateTriggerRules.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  {
42  public function evaluateBeforeSave(RedBeanModel $model, $attribute)
43  {
44  switch($this->trigger->getOperator())
45  {
46  case OperatorRules::TYPE_EQUALS:
47  if ((int)$model->{$attribute}->id === (int)$this->trigger->value)
48  {
49  return true;
50  }
51  break;
52  case OperatorRules::TYPE_DOES_NOT_EQUAL:
53  if ((int)$model->{$attribute}->id !== (int)$this->trigger->value)
54  {
55  return true;
56  }
57  break;
58  case OperatorRules::TYPE_ONE_OF:
59  if (!is_array($this->trigger->value))
60  {
61  return false;
62  }
63  if (in_array($model->{$attribute}->id, $this->trigger->value))
64  {
65  return true;
66  }
67  break;
68  case OperatorRules::TYPE_CHANGES:
69  if (array_key_exists($attribute, $model->originalAttributeValues))
70  {
71  return true;
72  }
73  break;
74  case OperatorRules::TYPE_DOES_NOT_CHANGE:
75  if (!array_key_exists($attribute, $model->originalAttributeValues))
76  {
77  return true;
78  }
79  break;
80  case OperatorRules::TYPE_BECOMES:
81  if (array_key_exists($attribute, $model->originalAttributeValues) &&
82  (int)$model->{$attribute}->id === (int)$this->trigger->value)
83  {
84  return true;
85  }
86  break;
87  case OperatorRules::TYPE_WAS:
88  if (array_key_exists($attribute, $model->originalAttributeValues) &&
89  (int)$model->originalAttributeValues[$attribute][1] ===
90  (int)$this->trigger->value)
91  {
92  return true;
93  }
94  break;
95  case OperatorRules::TYPE_BECOMES_ONE_OF:
96  if (!is_array($this->trigger->value))
97  {
98  return false;
99  }
100  if (array_key_exists($attribute, $model->originalAttributeValues) &&
101  in_array($model->{$attribute}->id, $this->trigger->value))
102  {
103  return true;
104  }
105  break;
106  case OperatorRules::TYPE_WAS_ONE_OF:
107  if (!is_array($this->trigger->value))
108  {
109  return false;
110  }
111  if (array_key_exists($attribute, $model->originalAttributeValues) &&
112  in_array($model->originalAttributeValues[$attribute][1], $this->trigger->value))
113  {
114  return true;
115  }
116  break;
117  case OperatorRules::TYPE_IS_EMPTY:
118  if (!($model->{$attribute}->id > 0))
119  {
120  return true;
121  }
122  break;
123  case OperatorRules::TYPE_IS_NOT_EMPTY:
124  if ($model->{$attribute}->id > 0)
125  {
126  return true;
127  }
128  break;
129  default:
130  throw new NotSupportedException();
131  }
132  return false;
133  }
134  }
135 ?>
Generated on Sat Feb 22 2020 07:10:29