1: <?php
2: /*****************************************************************************************
3: * X2Engine Open Source Edition is a customer relationship management program developed by
4: * X2Engine, Inc. Copyright (C) 2011-2016 X2Engine Inc.
5: *
6: * This program 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 X2ENGINE, X2ENGINE DISCLAIMS THE WARRANTY
11: * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
12: *
13: * This program 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 X2Engine, Inc. P.O. Box 66752, Scotts Valley,
24: * California 95067, USA. or at email address [email protected].
25: *
26: * The interactive user interfaces in modified source and object code 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 "Powered by
32: * X2Engine" logo. If the display of the logo is not reasonably feasible for
33: * technical reasons, the Appropriate Legal Notices must display the words
34: * "Powered by X2Engine".
35: *****************************************************************************************/
36:
37: /**
38: * Model that assumes any attributes given to it.
39: *
40: * Intended for handling special data validation in Fields input.
41: *
42: * @package application.models
43: * @author Demitri Morgan <[email protected]>
44: */
45: class AmorphousModel extends CModel {
46:
47: private $_attributes = array();
48:
49: private $_mockFields = array();
50:
51: private $_tableName;
52:
53: public function __get($name){
54: if($this->hasAttribute($name)){
55: return $this->_attributes[$name];
56: } else
57: return parent::__get($name);
58: }
59:
60: public function __set($name, $value){
61: if($this->hasAttribute($name, $value)){
62: $this->setAttribute($name, $value);
63: } else
64: parent::__set($name, $value);
65: }
66:
67: public function addField(Fields $field,$name=null){
68: $name = empty($name) ? $field->fieldName : $name;
69: $this->_mockFields[$name] = $field;
70: if(!isset($this->_attributes[$name])){
71: $this->_attributes[$name] = '';
72: }
73: }
74:
75: public function attributeNames(){
76: return array_keys($this->_attributes);
77: }
78:
79: public function getAttribute($name){
80: return $this->_attributes[$name];
81: }
82:
83: public function getAttributeLabel($name){
84: if(isset($this->_mockFields[$name])){
85: return $this->_mockFields[$name]->attributeLabel;
86: } else
87: return null;
88: }
89:
90: public function getAttributes($names = null){
91: if($names == null)
92: return $this->_attributes;
93: else
94: parent::getAttributes($names);
95: }
96:
97: public function hasAttribute($name){
98: return array_key_exists($name,$this->_attributes);
99: }
100:
101: /**
102: * Automatically generate rules from X2Model.
103: *
104: * The "required" validator is excluded because, when validating input for a
105: * default value for a field that is required, blank should be a valid value
106: * because otherwise having the field be required would force the user to
107: * specify a non-blank default value.
108: * @return array
109: */
110: public function rules(){
111: $rules = X2Model::modelRules($this->_mockFields, $this);
112: foreach(array_keys($rules) as $ind) {
113: if(in_array($rules[$ind][1],array('required','unique','application.components.ValidLinkValidator')))
114: unset($rules[$ind]);
115: }
116: return $rules;
117: }
118:
119: public function setAttribute($name, $value){
120: $this->_attributes[$name] = $value;
121: }
122:
123: public function setTableName($value){
124: $this->_tableName = $value;
125: }
126:
127: public function tableName(){
128: return $this->_tableName;
129: }
130:
131: }
132:
133: ?>
134: