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 contact@x2engine.com.
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: * This is the model class for table "x2_role_to_user".
39: *
40: * @package application.models
41: * @property integer $id
42: * @property integer $roleId
43: * @property integer $userId
44: */
45: class RoleToUser extends CActiveRecord
46: {
47: /**
48: * Returns the static model of the specified AR class.
49: * @return RoleToUser the static model class
50: */
51: public static function model($className=__CLASS__)
52: {
53: return parent::model($className);
54: }
55:
56: /**
57: * @return string the associated database table name
58: */
59: public function tableName()
60: {
61: return 'x2_role_to_user';
62: }
63:
64: /**
65: * @return array validation rules for model attributes.
66: */
67: public function rules()
68: {
69: // NOTE: you should only define rules for those attributes that
70: // will receive user inputs.
71: return array(
72: array('roleId, userId', 'numerical', 'integerOnly'=>true),
73: // The following rule is used by search().
74: // Please remove those attributes that should not be searched.
75: array('id, roleId, userId', 'safe', 'on'=>'search'),
76: );
77: }
78:
79: /**
80: * @return array relational rules.
81: */
82: public function relations()
83: {
84: // NOTE: you may need to adjust the relation name and the related
85: // class name for the relations automatically generated below.
86: return array(
87: );
88: }
89:
90: /**
91: * @return array customized attribute labels (name=>label)
92: */
93: public function attributeLabels()
94: {
95: return array(
96: 'id' => 'ID',
97: 'roleId' => 'Role',
98: 'userId' => 'User',
99: );
100: }
101:
102: /**
103: * Retrieves a list of models based on the current search/filter conditions.
104: * @return CActiveDataProvider the data provider that can return the models based on the
105: * search/filter conditions.
106: */
107: public function search()
108: {
109: // Warning: Please modify the following code to remove attributes that
110: // should not be searched.
111:
112: $criteria=new CDbCriteria;
113:
114: $criteria->compare('id',$this->id);
115: $criteria->compare('roleId',$this->roleId);
116: $criteria->compare('userId',$this->userId);
117:
118: return new CActiveDataProvider(get_class($this), array(
119: 'criteria'=>$criteria,
120: ));
121: }
122:
123: public function afterSave () {
124: // roles have been updated, clear the cached roles for the corresponding user
125: Roles::clearCachedUserRoles ($this->userId);
126: parent::afterSave ();
127: }
128:
129: public function afterDelete () {
130: // Roles have been updated, clear the cached roles for the corresponding
131: // user (or for all group members, if a group)
132: if($this->type == 'user') {
133: Roles::clearCachedUserRoles ($this->userId);
134: } elseif($this->type == 'group') {
135: // Clear the role cache for all users who were in the group
136: $group = Groups::model()->findByPk($this->userId);
137: if(!empty($group)) {
138: if(count($group->users)>0) {
139: foreach($group->users as $user) {
140: Roles::clearCachedUserRoles($user->id);
141: }
142: }
143: }
144: }
145: parent::afterSave ();
146: }
147: }
148: