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:  * @package application.controllers
 39:  */
 40: class RelationshipsController extends x2base {
 41: 
 42:     public $modelClass = 'Relationships';
 43: 
 44:     public $layout = '//layouts/column1';
 45: 
 46: 
 47:     public function filters() {
 48:         return array_merge(parent::filters(), array(
 49:             'accessControl',
 50:         ));
 51:     }
 52: 
 53:     public function accessRules() {
 54:         return array (
 55:             array ('allow',
 56:                 'actions' => array (
 57:                     'addRelationship', 
 58:                      
 59:                 ),
 60:                 'users' => array ('@'),
 61:             ),
 62:             array ('deny',
 63:                 'users' => array ('*')
 64:             )
 65:         );
 66:     }
 67: 
 68: 
 69:     /**
 70:      * Add a record to record relationship
 71:      *
 72:      * A record can be a contact, opportunity, or account. This function is
 73:      * called via ajax from the Relationships Widget.
 74:      */
 75:     public function actionAddRelationship() {
 76: 
 77:         //check if relationship already exits
 78:         if (isset($_POST['ModelName']) && isset($_POST['ModelId']) &&
 79:             isset($_POST['RelationshipModelName']) && isset($_POST['RelationshipModelId'])) {
 80: 
 81:             $modelName = $_POST['ModelName'];
 82:             $modelId = $_POST['ModelId'];
 83:             $relationshipModelName = $_POST['RelationshipModelName'];
 84:             $relationshipModelId = $_POST['RelationshipModelId'];
 85:             $model = $this->getModelFromTypeAndId ($modelName, $modelId);
 86:             if (!Yii::app()->controller->checkPermissions ($model, 'edit')) {
 87:                 $this->denied ();
 88:             }
 89:             $relationshipModel = $this->getModelFromTypeAndId (
 90:                 $relationshipModelName, $relationshipModelId);
 91:             if (!Yii::app()->controller->checkPermissions ($relationshipModel, 'view')) {
 92:                 $this->denied ();
 93:             }
 94: 
 95:             if (isset($_POST['mutual']) && $_POST['mutual'] == 'true')
 96:                 $_POST['secondLabel'] = $_POST['firstLabel'];
 97: 
 98:             if ($model->hasRelationship($relationshipModel)) {
 99:                 echo 'duplicate';
100:                 Yii::app()->end();
101:             }
102: 
103:             if ($model->createRelationship($relationshipModel, $_POST['firstLabel'], $_POST['secondLabel']) === true) {
104:                 echo 'success';
105:                 Yii::app()->end();
106:             } else {
107:                 echo 'failure';
108:                 Yii::app()->end();
109:             }
110:         } else {
111:             throw new CHttpException(400, Yii::t('app', 'Bad Request'));
112:         }
113:     }
114: 
115:      
116: 
117: 
118: }
119: