user_permission.php (12934B)
1 <?php 2 class ControllerUserUserPermission extends Controller { 3 private $error = array(); 4 5 public function index() { 6 $this->load->language('user/user_group'); 7 8 $this->document->setTitle($this->language->get('heading_title')); 9 10 $this->load->model('user/user_group'); 11 12 $this->getList(); 13 } 14 15 public function add() { 16 $this->load->language('user/user_group'); 17 18 $this->document->setTitle($this->language->get('heading_title')); 19 20 $this->load->model('user/user_group'); 21 22 if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validateForm()) { 23 $this->model_user_user_group->addUserGroup($this->request->post); 24 25 $this->session->data['success'] = $this->language->get('text_success'); 26 27 $url = ''; 28 29 if (isset($this->request->get['sort'])) { 30 $url .= '&sort=' . $this->request->get['sort']; 31 } 32 33 if (isset($this->request->get['order'])) { 34 $url .= '&order=' . $this->request->get['order']; 35 } 36 37 if (isset($this->request->get['page'])) { 38 $url .= '&page=' . $this->request->get['page']; 39 } 40 41 $this->response->redirect($this->url->link('user/user_permission', 'user_token=' . $this->session->data['user_token'] . $url, true)); 42 } 43 44 $this->getForm(); 45 } 46 47 public function edit() { 48 $this->load->language('user/user_group'); 49 50 $this->document->setTitle($this->language->get('heading_title')); 51 52 $this->load->model('user/user_group'); 53 54 if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validateForm()) { 55 $this->model_user_user_group->editUserGroup($this->request->get['user_group_id'], $this->request->post); 56 57 $this->session->data['success'] = $this->language->get('text_success'); 58 59 $url = ''; 60 61 if (isset($this->request->get['sort'])) { 62 $url .= '&sort=' . $this->request->get['sort']; 63 } 64 65 if (isset($this->request->get['order'])) { 66 $url .= '&order=' . $this->request->get['order']; 67 } 68 69 if (isset($this->request->get['page'])) { 70 $url .= '&page=' . $this->request->get['page']; 71 } 72 73 $this->response->redirect($this->url->link('user/user_permission', 'user_token=' . $this->session->data['user_token'] . $url, true)); 74 } 75 76 $this->getForm(); 77 } 78 79 public function delete() { 80 $this->load->language('user/user_group'); 81 82 $this->document->setTitle($this->language->get('heading_title')); 83 84 $this->load->model('user/user_group'); 85 86 if (isset($this->request->post['selected']) && $this->validateDelete()) { 87 foreach ($this->request->post['selected'] as $user_group_id) { 88 $this->model_user_user_group->deleteUserGroup($user_group_id); 89 } 90 91 $this->session->data['success'] = $this->language->get('text_success'); 92 93 $url = ''; 94 95 if (isset($this->request->get['sort'])) { 96 $url .= '&sort=' . $this->request->get['sort']; 97 } 98 99 if (isset($this->request->get['order'])) { 100 $url .= '&order=' . $this->request->get['order']; 101 } 102 103 if (isset($this->request->get['page'])) { 104 $url .= '&page=' . $this->request->get['page']; 105 } 106 107 $this->response->redirect($this->url->link('user/user_permission', 'user_token=' . $this->session->data['user_token'] . $url, true)); 108 } 109 110 $this->getList(); 111 } 112 113 protected function getList() { 114 if (isset($this->request->get['sort'])) { 115 $sort = $this->request->get['sort']; 116 } else { 117 $sort = 'name'; 118 } 119 120 if (isset($this->request->get['order'])) { 121 $order = $this->request->get['order']; 122 } else { 123 $order = 'ASC'; 124 } 125 126 if (isset($this->request->get['page'])) { 127 $page = $this->request->get['page']; 128 } else { 129 $page = 1; 130 } 131 132 $url = ''; 133 134 if (isset($this->request->get['sort'])) { 135 $url .= '&sort=' . $this->request->get['sort']; 136 } 137 138 if (isset($this->request->get['order'])) { 139 $url .= '&order=' . $this->request->get['order']; 140 } 141 142 if (isset($this->request->get['page'])) { 143 $url .= '&page=' . $this->request->get['page']; 144 } 145 146 $data['breadcrumbs'] = array(); 147 148 $data['breadcrumbs'][] = array( 149 'text' => $this->language->get('text_home'), 150 'href' => $this->url->link('common/dashboard', 'user_token=' . $this->session->data['user_token'], true) 151 ); 152 153 $data['breadcrumbs'][] = array( 154 'text' => $this->language->get('heading_title'), 155 'href' => $this->url->link('user/user_permission', 'user_token=' . $this->session->data['user_token'] . $url, true) 156 ); 157 158 $data['add'] = $this->url->link('user/user_permission/add', 'user_token=' . $this->session->data['user_token'] . $url, true); 159 $data['delete'] = $this->url->link('user/user_permission/delete', 'user_token=' . $this->session->data['user_token'] . $url, true); 160 161 $data['user_groups'] = array(); 162 163 $filter_data = array( 164 'sort' => $sort, 165 'order' => $order, 166 'start' => ($page - 1) * $this->config->get('config_limit_admin'), 167 'limit' => $this->config->get('config_limit_admin') 168 ); 169 170 $user_group_total = $this->model_user_user_group->getTotalUserGroups(); 171 172 $results = $this->model_user_user_group->getUserGroups($filter_data); 173 174 foreach ($results as $result) { 175 $data['user_groups'][] = array( 176 'user_group_id' => $result['user_group_id'], 177 'name' => $result['name'], 178 'edit' => $this->url->link('user/user_permission/edit', 'user_token=' . $this->session->data['user_token'] . '&user_group_id=' . $result['user_group_id'] . $url, true) 179 ); 180 } 181 182 if (isset($this->error['warning'])) { 183 $data['error_warning'] = $this->error['warning']; 184 } else { 185 $data['error_warning'] = ''; 186 } 187 188 if (isset($this->session->data['success'])) { 189 $data['success'] = $this->session->data['success']; 190 191 unset($this->session->data['success']); 192 } else { 193 $data['success'] = ''; 194 } 195 196 if (isset($this->request->post['selected'])) { 197 $data['selected'] = (array)$this->request->post['selected']; 198 } else { 199 $data['selected'] = array(); 200 } 201 202 $url = ''; 203 204 if ($order == 'ASC') { 205 $url .= '&order=DESC'; 206 } else { 207 $url .= '&order=ASC'; 208 } 209 210 if (isset($this->request->get['page'])) { 211 $url .= '&page=' . $this->request->get['page']; 212 } 213 214 $data['sort_name'] = $this->url->link('user/user_permission', 'user_token=' . $this->session->data['user_token'] . '&sort=name' . $url, true); 215 216 $url = ''; 217 218 if (isset($this->request->get['sort'])) { 219 $url .= '&sort=' . $this->request->get['sort']; 220 } 221 222 if (isset($this->request->get['order'])) { 223 $url .= '&order=' . $this->request->get['order']; 224 } 225 226 $pagination = new Pagination(); 227 $pagination->total = $user_group_total; 228 $pagination->page = $page; 229 $pagination->limit = $this->config->get('config_limit_admin'); 230 $pagination->url = $this->url->link('user/user_permission', 'user_token=' . $this->session->data['user_token'] . $url . '&page={page}', true); 231 232 $data['pagination'] = $pagination->render(); 233 234 $data['results'] = sprintf($this->language->get('text_pagination'), ($user_group_total) ? (($page - 1) * $this->config->get('config_limit_admin')) + 1 : 0, ((($page - 1) * $this->config->get('config_limit_admin')) > ($user_group_total - $this->config->get('config_limit_admin'))) ? $user_group_total : ((($page - 1) * $this->config->get('config_limit_admin')) + $this->config->get('config_limit_admin')), $user_group_total, ceil($user_group_total / $this->config->get('config_limit_admin'))); 235 236 $data['sort'] = $sort; 237 $data['order'] = $order; 238 239 $data['header'] = $this->load->controller('common/header'); 240 $data['column_left'] = $this->load->controller('common/column_left'); 241 $data['footer'] = $this->load->controller('common/footer'); 242 243 $this->response->setOutput($this->load->view('user/user_group_list', $data)); 244 } 245 246 protected function getForm() { 247 $data['text_form'] = !isset($this->request->get['user_group_id']) ? $this->language->get('text_add') : $this->language->get('text_edit'); 248 249 if (isset($this->error['warning'])) { 250 $data['error_warning'] = $this->error['warning']; 251 } else { 252 $data['error_warning'] = ''; 253 } 254 255 if (isset($this->error['name'])) { 256 $data['error_name'] = $this->error['name']; 257 } else { 258 $data['error_name'] = ''; 259 } 260 261 $url = ''; 262 263 if (isset($this->request->get['sort'])) { 264 $url .= '&sort=' . $this->request->get['sort']; 265 } 266 267 if (isset($this->request->get['order'])) { 268 $url .= '&order=' . $this->request->get['order']; 269 } 270 271 if (isset($this->request->get['page'])) { 272 $url .= '&page=' . $this->request->get['page']; 273 } 274 275 $data['breadcrumbs'] = array(); 276 277 $data['breadcrumbs'][] = array( 278 'text' => $this->language->get('text_home'), 279 'href' => $this->url->link('common/dashboard', 'user_token=' . $this->session->data['user_token'], true) 280 ); 281 282 $data['breadcrumbs'][] = array( 283 'text' => $this->language->get('heading_title'), 284 'href' => $this->url->link('user/user_permission', 'user_token=' . $this->session->data['user_token'] . $url, true) 285 ); 286 287 if (!isset($this->request->get['user_group_id'])) { 288 $data['action'] = $this->url->link('user/user_permission/add', 'user_token=' . $this->session->data['user_token'] . $url, true); 289 } else { 290 $data['action'] = $this->url->link('user/user_permission/edit', 'user_token=' . $this->session->data['user_token'] . '&user_group_id=' . $this->request->get['user_group_id'] . $url, true); 291 } 292 293 $data['cancel'] = $this->url->link('user/user_permission', 'user_token=' . $this->session->data['user_token'] . $url, true); 294 295 if (isset($this->request->get['user_group_id']) && $this->request->server['REQUEST_METHOD'] != 'POST') { 296 $user_group_info = $this->model_user_user_group->getUserGroup($this->request->get['user_group_id']); 297 } 298 299 if (isset($this->request->post['name'])) { 300 $data['name'] = $this->request->post['name']; 301 } elseif (!empty($user_group_info)) { 302 $data['name'] = $user_group_info['name']; 303 } else { 304 $data['name'] = ''; 305 } 306 307 $ignore = array( 308 'common/dashboard', 309 'common/startup', 310 'common/login', 311 'common/logout', 312 'common/forgotten', 313 'common/reset', 314 'common/footer', 315 'common/header', 316 'error/not_found', 317 'error/permission' 318 ); 319 320 $data['permissions'] = array(); 321 322 $files = array(); 323 324 // Make path into an array 325 $path = array(DIR_APPLICATION . 'controller/*'); 326 327 // While the path array is still populated keep looping through 328 while (count($path) != 0) { 329 $next = array_shift($path); 330 331 foreach (glob($next) as $file) { 332 // If directory add to path array 333 if (is_dir($file)) { 334 $path[] = $file . '/*'; 335 } 336 337 // Add the file to the files to be deleted array 338 if (is_file($file)) { 339 $files[] = $file; 340 } 341 } 342 } 343 344 // Sort the file array 345 sort($files); 346 347 foreach ($files as $file) { 348 $controller = substr($file, strlen(DIR_APPLICATION . 'controller/')); 349 350 $permission = substr($controller, 0, strrpos($controller, '.')); 351 352 if (!in_array($permission, $ignore)) { 353 $data['permissions'][] = $permission; 354 } 355 } 356 357 if (isset($this->request->post['permission']['access'])) { 358 $data['access'] = $this->request->post['permission']['access']; 359 } elseif (isset($user_group_info['permission']['access'])) { 360 $data['access'] = $user_group_info['permission']['access']; 361 } else { 362 $data['access'] = array(); 363 } 364 365 if (isset($this->request->post['permission']['modify'])) { 366 $data['modify'] = $this->request->post['permission']['modify']; 367 } elseif (isset($user_group_info['permission']['modify'])) { 368 $data['modify'] = $user_group_info['permission']['modify']; 369 } else { 370 $data['modify'] = array(); 371 } 372 373 $data['header'] = $this->load->controller('common/header'); 374 $data['column_left'] = $this->load->controller('common/column_left'); 375 $data['footer'] = $this->load->controller('common/footer'); 376 377 $this->response->setOutput($this->load->view('user/user_group_form', $data)); 378 } 379 380 protected function validateForm() { 381 if (!$this->user->hasPermission('modify', 'user/user_permission')) { 382 $this->error['warning'] = $this->language->get('error_permission'); 383 } 384 385 if ((utf8_strlen($this->request->post['name']) < 3) || (utf8_strlen($this->request->post['name']) > 64)) { 386 $this->error['name'] = $this->language->get('error_name'); 387 } 388 389 return !$this->error; 390 } 391 392 protected function validateDelete() { 393 if (!$this->user->hasPermission('modify', 'user/user_permission')) { 394 $this->error['warning'] = $this->language->get('error_permission'); 395 } 396 397 $this->load->model('user/user'); 398 399 foreach ($this->request->post['selected'] as $user_group_id) { 400 $user_total = $this->model_user_user->getTotalUsersByGroupId($user_group_id); 401 402 if ($user_total) { 403 $this->error['warning'] = sprintf($this->language->get('error_user'), $user_total); 404 } 405 } 406 407 return !$this->error; 408 } 409 }