Commit | Line | Data |
---|---|---|
6a488035 | 1 | <?php |
6a488035 TO |
2 | /* |
3 | +--------------------------------------------------------------------+ | |
bc77d7c0 | 4 | | Copyright CiviCRM LLC. All rights reserved. | |
6a488035 | 5 | | | |
bc77d7c0 TO |
6 | | This work is published under the GNU AGPLv3 license with some | |
7 | | permitted exceptions and without any warranty. For full license | | |
8 | | and copyright information, see https://civicrm.org/licensing | | |
6a488035 | 9 | +--------------------------------------------------------------------+ |
d25dd0ee | 10 | */ |
6a488035 TO |
11 | |
12 | /** | |
13 | * | |
14 | * @package CRM | |
ca5cec67 | 15 | * @copyright CiviCRM LLC https://civicrm.org/licensing |
6a488035 TO |
16 | */ |
17 | class CRM_ACL_Page_ACL extends CRM_Core_Page_Basic { | |
18 | ||
96f50de2 CW |
19 | public $useLivePageJS = TRUE; |
20 | ||
6a488035 | 21 | /** |
d2e5d2ce | 22 | * The action links that we need to display for the browse screen. |
6a488035 TO |
23 | * |
24 | * @var array | |
6a488035 | 25 | */ |
683bf891 | 26 | public static $_links = NULL; |
6a488035 TO |
27 | |
28 | /** | |
d2e5d2ce | 29 | * Get BAO Name. |
6a488035 | 30 | * |
a6c01b45 CW |
31 | * @return string |
32 | * Classname of BAO. | |
6a488035 | 33 | */ |
00be9182 | 34 | public function getBAOName() { |
6a488035 TO |
35 | return 'CRM_ACL_BAO_ACL'; |
36 | } | |
37 | ||
38 | /** | |
d2e5d2ce | 39 | * Get action Links. |
6a488035 | 40 | * |
a6c01b45 CW |
41 | * @return array |
42 | * (reference) of action links | |
6a488035 | 43 | */ |
00be9182 | 44 | public function &links() { |
6a488035 | 45 | if (!(self::$_links)) { |
cf0d1c08 | 46 | self::$_links = [ |
47 | CRM_Core_Action::UPDATE => [ | |
6a488035 TO |
48 | 'name' => ts('Edit'), |
49 | 'url' => 'civicrm/acl', | |
50 | 'qs' => 'reset=1&action=update&id=%%id%%', | |
51 | 'title' => ts('Edit ACL'), | |
cf0d1c08 | 52 | ], |
53 | CRM_Core_Action::DISABLE => [ | |
6a488035 | 54 | 'name' => ts('Disable'), |
1fe97a01 | 55 | 'ref' => 'crm-enable-disable', |
6a488035 | 56 | 'title' => ts('Disable ACL'), |
cf0d1c08 | 57 | ], |
58 | CRM_Core_Action::ENABLE => [ | |
6a488035 | 59 | 'name' => ts('Enable'), |
1fe97a01 | 60 | 'ref' => 'crm-enable-disable', |
6a488035 | 61 | 'title' => ts('Enable ACL'), |
cf0d1c08 | 62 | ], |
63 | CRM_Core_Action::DELETE => [ | |
6a488035 TO |
64 | 'name' => ts('Delete'), |
65 | 'url' => 'civicrm/acl', | |
66 | 'qs' => 'reset=1&action=delete&id=%%id%%', | |
67 | 'title' => ts('Delete ACL'), | |
cf0d1c08 | 68 | ], |
69 | ]; | |
6a488035 TO |
70 | } |
71 | return self::$_links; | |
72 | } | |
73 | ||
74 | /** | |
75 | * Run the page. | |
76 | * | |
5d6d0104 | 77 | * Set the breadcrumb before beginning the standard page run. |
6a488035 | 78 | */ |
00be9182 | 79 | public function run() { |
6a488035 | 80 | // set breadcrumb to append to admin/access |
cf0d1c08 | 81 | $breadCrumb = [ |
82 | [ | |
353ffa53 | 83 | 'title' => ts('Access Control'), |
cf0d1c08 | 84 | 'url' => CRM_Utils_System::url('civicrm/admin/access', 'reset=1'), |
85 | ], | |
86 | ]; | |
6a488035 | 87 | CRM_Utils_System::appendBreadCrumb($breadCrumb); |
6a488035 TO |
88 | |
89 | // parent run | |
90 | return parent::run(); | |
91 | } | |
92 | ||
93 | /** | |
d2e5d2ce | 94 | * Browse all acls. |
6a488035 | 95 | */ |
00be9182 | 96 | public function browse() { |
6a488035 | 97 | // get all acl's sorted by weight |
cf0d1c08 | 98 | $acl = []; |
6a488035 TO |
99 | $query = " |
100 | SELECT * | |
101 | FROM civicrm_acl | |
102 | WHERE ( object_table IN ( 'civicrm_saved_search', 'civicrm_uf_group', 'civicrm_custom_group', 'civicrm_event' ) ) | |
103 | ORDER BY entity_id | |
104 | "; | |
33621c4f | 105 | $dao = CRM_Core_DAO::executeQuery($query); |
6a488035 TO |
106 | |
107 | $roles = CRM_Core_OptionGroup::values('acl_role'); | |
108 | ||
cf0d1c08 | 109 | $group = [ |
0d48f1cc TO |
110 | '-1' => ts('- select -'), |
111 | '0' => ts('All Groups'), | |
112 | ] + CRM_Core_PseudoConstant::group(); | |
cf0d1c08 | 113 | $customGroup = [ |
0d48f1cc TO |
114 | '-1' => ts('- select -'), |
115 | '0' => ts('All Custom Groups'), | |
116 | ] + CRM_Core_PseudoConstant::get('CRM_Core_DAO_CustomField', 'custom_group_id'); | |
cf0d1c08 | 117 | $ufGroup = [ |
0d48f1cc TO |
118 | '-1' => ts('- select -'), |
119 | '0' => ts('All Profiles'), | |
120 | ] + CRM_Core_PseudoConstant::get('CRM_Core_DAO_UFField', 'uf_group_id'); | |
6a488035 | 121 | |
cf0d1c08 | 122 | $event = [ |
0d48f1cc TO |
123 | '-1' => ts('- select -'), |
124 | '0' => ts('All Events'), | |
125 | ] + CRM_Event_PseudoConstant::event(); | |
6a488035 TO |
126 | |
127 | while ($dao->fetch()) { | |
cf0d1c08 | 128 | $acl[$dao->id] = []; |
6a488035 TO |
129 | $acl[$dao->id]['name'] = $dao->name; |
130 | $acl[$dao->id]['operation'] = $dao->operation; | |
131 | $acl[$dao->id]['entity_id'] = $dao->entity_id; | |
132 | $acl[$dao->id]['entity_table'] = $dao->entity_table; | |
133 | $acl[$dao->id]['object_table'] = $dao->object_table; | |
134 | $acl[$dao->id]['object_id'] = $dao->object_id; | |
135 | $acl[$dao->id]['is_active'] = $dao->is_active; | |
136 | ||
6a488035 | 137 | if ($acl[$dao->id]['entity_id']) { |
34939410 | 138 | $acl[$dao->id]['entity'] = CRM_Utils_Array::value($acl[$dao->id]['entity_id'], $roles); |
6a488035 TO |
139 | } |
140 | else { | |
141 | $acl[$dao->id]['entity'] = ts('Everyone'); | |
142 | } | |
143 | ||
144 | switch ($acl[$dao->id]['object_table']) { | |
145 | case 'civicrm_saved_search': | |
5d6d0104 | 146 | $acl[$dao->id]['object'] = CRM_Utils_Array::value($acl[$dao->id]['object_id'], $group); |
6a488035 TO |
147 | $acl[$dao->id]['object_name'] = ts('Group'); |
148 | break; | |
149 | ||
150 | case 'civicrm_uf_group': | |
5d6d0104 | 151 | $acl[$dao->id]['object'] = CRM_Utils_Array::value($acl[$dao->id]['object_id'], $ufGroup); |
6a488035 TO |
152 | $acl[$dao->id]['object_name'] = ts('Profile'); |
153 | break; | |
154 | ||
155 | case 'civicrm_custom_group': | |
5d6d0104 | 156 | $acl[$dao->id]['object'] = CRM_Utils_Array::value($acl[$dao->id]['object_id'], $customGroup); |
6a488035 TO |
157 | $acl[$dao->id]['object_name'] = ts('Custom Group'); |
158 | break; | |
159 | ||
160 | case 'civicrm_event': | |
5d6d0104 | 161 | $acl[$dao->id]['object'] = CRM_Utils_Array::value($acl[$dao->id]['object_id'], $event); |
6a488035 TO |
162 | $acl[$dao->id]['object_name'] = ts('Event'); |
163 | break; | |
164 | } | |
165 | ||
166 | // form all action links | |
167 | $action = array_sum(array_keys($this->links())); | |
168 | ||
169 | if ($dao->is_active) { | |
170 | $action -= CRM_Core_Action::ENABLE; | |
171 | } | |
172 | else { | |
173 | $action -= CRM_Core_Action::DISABLE; | |
174 | } | |
175 | ||
87dab4a4 AH |
176 | $acl[$dao->id]['action'] = CRM_Core_Action::formLink( |
177 | self::links(), | |
178 | $action, | |
cf0d1c08 | 179 | ['id' => $dao->id], |
87dab4a4 AH |
180 | ts('more'), |
181 | FALSE, | |
182 | 'ACL.manage.action', | |
183 | 'ACL', | |
184 | $dao->id | |
6a488035 TO |
185 | ); |
186 | } | |
187 | $this->assign('rows', $acl); | |
188 | } | |
189 | ||
190 | /** | |
d2e5d2ce | 191 | * Get name of edit form. |
6a488035 | 192 | * |
a6c01b45 CW |
193 | * @return string |
194 | * Classname of edit form. | |
6a488035 | 195 | */ |
00be9182 | 196 | public function editForm() { |
6a488035 TO |
197 | return 'CRM_ACL_Form_ACL'; |
198 | } | |
199 | ||
200 | /** | |
d2e5d2ce | 201 | * Get edit form name. |
6a488035 | 202 | * |
a6c01b45 CW |
203 | * @return string |
204 | * name of this page. | |
6a488035 | 205 | */ |
00be9182 | 206 | public function editName() { |
6a488035 TO |
207 | return 'ACL'; |
208 | } | |
209 | ||
210 | /** | |
211 | * Get user context. | |
212 | * | |
77b97be7 EM |
213 | * @param null $mode |
214 | * | |
a6c01b45 CW |
215 | * @return string |
216 | * user context. | |
6a488035 | 217 | */ |
00be9182 | 218 | public function userContext($mode = NULL) { |
6a488035 TO |
219 | return 'civicrm/acl'; |
220 | } | |
96025800 | 221 | |
5d6d0104 AH |
222 | /** |
223 | * Edit an ACL. | |
224 | * | |
225 | * @param int $mode | |
226 | * What mode for the form ?. | |
227 | * @param int $id | |
228 | * Id of the entity (for update, view operations). | |
229 | * @param bool $imageUpload | |
230 | * Not used in this case, but extended from CRM_Core_Page_Basic. | |
231 | * @param bool $pushUserContext | |
232 | * Not used in this case, but extended from CRM_Core_Page_Basic. | |
233 | */ | |
234 | public function edit($mode, $id = NULL, $imageUpload = FALSE, $pushUserContext = TRUE) { | |
235 | if ($mode & (CRM_Core_Action::UPDATE)) { | |
236 | if (isset($id)) { | |
237 | $aclName = CRM_Core_DAO::getFieldValue('CRM_ACL_DAO_ACL', $id); | |
cf0d1c08 | 238 | CRM_Utils_System::setTitle(ts('Edit ACL – %1', [1 => $aclName])); |
5d6d0104 AH |
239 | } |
240 | } | |
241 | parent::edit($mode, $id, $imageUpload, $pushUserContext); | |
242 | } | |
243 | ||
6a488035 | 244 | } |