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: