PageRenderTime 28ms CodeModel.GetById 14ms RepoModel.GetById 1ms app.codeStats 0ms

/admin/controller/user/user_permission.php

https://bitbucket.org/Hibiki08/goodlack
PHP | 460 lines | 332 code | 122 blank | 6 comment | 74 complexity | a8938462580fde36927435058d44cd0f MD5 | raw file
Possible License(s): LGPL-2.1, MPL-2.0-no-copyleft-exception
  1. <?php
  2. class ControllerUserUserPermission extends Controller {
  3. private $error = array();
  4. public function index() {
  5. $this->load->language('user/user_group');
  6. $this->document->setTitle($this->language->get('heading_title'));
  7. $this->load->model('user/user_group');
  8. $this->getList();
  9. }
  10. public function add() {
  11. $this->load->language('user/user_group');
  12. $this->document->setTitle($this->language->get('heading_title'));
  13. $this->load->model('user/user_group');
  14. if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validateForm()) {
  15. $this->model_user_user_group->addUserGroup($this->request->post);
  16. $this->session->data['success'] = $this->language->get('text_success');
  17. $url = '';
  18. if (isset($this->request->get['sort'])) {
  19. $url .= '&sort=' . $this->request->get['sort'];
  20. }
  21. if (isset($this->request->get['order'])) {
  22. $url .= '&order=' . $this->request->get['order'];
  23. }
  24. if (isset($this->request->get['page'])) {
  25. $url .= '&page=' . $this->request->get['page'];
  26. }
  27. $this->response->redirect($this->url->link('user/user_permission', 'token=' . $this->session->data['token'] . $url, true));
  28. }
  29. $this->getForm();
  30. }
  31. public function edit() {
  32. $this->load->language('user/user_group');
  33. $this->document->setTitle($this->language->get('heading_title'));
  34. $this->load->model('user/user_group');
  35. if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validateForm()) {
  36. $this->model_user_user_group->editUserGroup($this->request->get['user_group_id'], $this->request->post);
  37. $this->session->data['success'] = $this->language->get('text_success');
  38. $url = '';
  39. if (isset($this->request->get['sort'])) {
  40. $url .= '&sort=' . $this->request->get['sort'];
  41. }
  42. if (isset($this->request->get['order'])) {
  43. $url .= '&order=' . $this->request->get['order'];
  44. }
  45. if (isset($this->request->get['page'])) {
  46. $url .= '&page=' . $this->request->get['page'];
  47. }
  48. $this->response->redirect($this->url->link('user/user_permission', 'token=' . $this->session->data['token'] . $url, true));
  49. }
  50. $this->getForm();
  51. }
  52. public function delete() {
  53. $this->load->language('user/user_group');
  54. $this->document->setTitle($this->language->get('heading_title'));
  55. $this->load->model('user/user_group');
  56. if (isset($this->request->post['selected']) && $this->validateDelete()) {
  57. foreach ($this->request->post['selected'] as $user_group_id) {
  58. $this->model_user_user_group->deleteUserGroup($user_group_id);
  59. }
  60. $this->session->data['success'] = $this->language->get('text_success');
  61. $url = '';
  62. if (isset($this->request->get['sort'])) {
  63. $url .= '&sort=' . $this->request->get['sort'];
  64. }
  65. if (isset($this->request->get['order'])) {
  66. $url .= '&order=' . $this->request->get['order'];
  67. }
  68. if (isset($this->request->get['page'])) {
  69. $url .= '&page=' . $this->request->get['page'];
  70. }
  71. $this->response->redirect($this->url->link('user/user_permission', 'token=' . $this->session->data['token'] . $url, true));
  72. }
  73. $this->getList();
  74. }
  75. protected function getList() {
  76. if (isset($this->request->get['sort'])) {
  77. $sort = $this->request->get['sort'];
  78. } else {
  79. $sort = 'name';
  80. }
  81. if (isset($this->request->get['order'])) {
  82. $order = $this->request->get['order'];
  83. } else {
  84. $order = 'ASC';
  85. }
  86. if (isset($this->request->get['page'])) {
  87. $page = $this->request->get['page'];
  88. } else {
  89. $page = 1;
  90. }
  91. $url = '';
  92. if (isset($this->request->get['sort'])) {
  93. $url .= '&sort=' . $this->request->get['sort'];
  94. }
  95. if (isset($this->request->get['order'])) {
  96. $url .= '&order=' . $this->request->get['order'];
  97. }
  98. if (isset($this->request->get['page'])) {
  99. $url .= '&page=' . $this->request->get['page'];
  100. }
  101. $data['breadcrumbs'] = array();
  102. $data['breadcrumbs'][] = array(
  103. 'text' => $this->language->get('text_home'),
  104. 'href' => $this->url->link('common/dashboard', 'token=' . $this->session->data['token'], true)
  105. );
  106. $data['breadcrumbs'][] = array(
  107. 'text' => $this->language->get('heading_title'),
  108. 'href' => $this->url->link('user/user_permission', 'token=' . $this->session->data['token'] . $url, true)
  109. );
  110. $data['add'] = $this->url->link('user/user_permission/add', 'token=' . $this->session->data['token'] . $url, true);
  111. $data['delete'] = $this->url->link('user/user_permission/delete', 'token=' . $this->session->data['token'] . $url, true);
  112. $data['user_groups'] = array();
  113. $filter_data = array(
  114. 'sort' => $sort,
  115. 'order' => $order,
  116. 'start' => ($page - 1) * $this->config->get('config_limit_admin'),
  117. 'limit' => $this->config->get('config_limit_admin')
  118. );
  119. $user_group_total = $this->model_user_user_group->getTotalUserGroups();
  120. $results = $this->model_user_user_group->getUserGroups($filter_data);
  121. foreach ($results as $result) {
  122. $data['user_groups'][] = array(
  123. 'user_group_id' => $result['user_group_id'],
  124. 'name' => $result['name'],
  125. 'edit' => $this->url->link('user/user_permission/edit', 'token=' . $this->session->data['token'] . '&user_group_id=' . $result['user_group_id'] . $url, true)
  126. );
  127. }
  128. $data['heading_title'] = $this->language->get('heading_title');
  129. $data['text_list'] = $this->language->get('text_list');
  130. $data['text_no_results'] = $this->language->get('text_no_results');
  131. $data['text_confirm'] = $this->language->get('text_confirm');
  132. $data['column_name'] = $this->language->get('column_name');
  133. $data['column_action'] = $this->language->get('column_action');
  134. $data['button_add'] = $this->language->get('button_add');
  135. $data['button_edit'] = $this->language->get('button_edit');
  136. $data['button_delete'] = $this->language->get('button_delete');
  137. if (isset($this->error['warning'])) {
  138. $data['error_warning'] = $this->error['warning'];
  139. } else {
  140. $data['error_warning'] = '';
  141. }
  142. if (isset($this->session->data['success'])) {
  143. $data['success'] = $this->session->data['success'];
  144. unset($this->session->data['success']);
  145. } else {
  146. $data['success'] = '';
  147. }
  148. if (isset($this->request->post['selected'])) {
  149. $data['selected'] = (array)$this->request->post['selected'];
  150. } else {
  151. $data['selected'] = array();
  152. }
  153. $url = '';
  154. if ($order == 'ASC') {
  155. $url .= '&order=DESC';
  156. } else {
  157. $url .= '&order=ASC';
  158. }
  159. if (isset($this->request->get['page'])) {
  160. $url .= '&page=' . $this->request->get['page'];
  161. }
  162. $data['sort_name'] = $this->url->link('user/user_permission', 'token=' . $this->session->data['token'] . '&sort=name' . $url, true);
  163. $url = '';
  164. if (isset($this->request->get['sort'])) {
  165. $url .= '&sort=' . $this->request->get['sort'];
  166. }
  167. if (isset($this->request->get['order'])) {
  168. $url .= '&order=' . $this->request->get['order'];
  169. }
  170. $pagination = new Pagination();
  171. $pagination->total = $user_group_total;
  172. $pagination->page = $page;
  173. $pagination->limit = $this->config->get('config_limit_admin');
  174. $pagination->url = $this->url->link('user/user_permission', 'token=' . $this->session->data['token'] . $url . '&page={page}', true);
  175. $data['pagination'] = $pagination->render();
  176. $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')));
  177. $data['sort'] = $sort;
  178. $data['order'] = $order;
  179. $data['header'] = $this->load->controller('common/header');
  180. $data['column_left'] = $this->load->controller('common/column_left');
  181. $data['footer'] = $this->load->controller('common/footer');
  182. $this->response->setOutput($this->load->view('user/user_group_list', $data));
  183. }
  184. protected function getForm() {
  185. $data['heading_title'] = $this->language->get('heading_title');
  186. $data['text_form'] = !isset($this->request->get['user_group_id']) ? $this->language->get('text_add') : $this->language->get('text_edit');
  187. $data['text_select_all'] = $this->language->get('text_select_all');
  188. $data['text_unselect_all'] = $this->language->get('text_unselect_all');
  189. $data['entry_name'] = $this->language->get('entry_name');
  190. $data['entry_access'] = $this->language->get('entry_access');
  191. $data['entry_modify'] = $this->language->get('entry_modify');
  192. $data['entry_hide'] = $this->language->get('entry_hide');
  193. $data['help_hide'] = $this->language->get('help_hide');
  194. $data['button_save'] = $this->language->get('button_save');
  195. $data['button_cancel'] = $this->language->get('button_cancel');
  196. if (isset($this->error['warning'])) {
  197. $data['error_warning'] = $this->error['warning'];
  198. } else {
  199. $data['error_warning'] = '';
  200. }
  201. if (isset($this->error['name'])) {
  202. $data['error_name'] = $this->error['name'];
  203. } else {
  204. $data['error_name'] = '';
  205. }
  206. $url = '';
  207. if (isset($this->request->get['sort'])) {
  208. $url .= '&sort=' . $this->request->get['sort'];
  209. }
  210. if (isset($this->request->get['order'])) {
  211. $url .= '&order=' . $this->request->get['order'];
  212. }
  213. if (isset($this->request->get['page'])) {
  214. $url .= '&page=' . $this->request->get['page'];
  215. }
  216. $data['breadcrumbs'] = array();
  217. $data['breadcrumbs'][] = array(
  218. 'text' => $this->language->get('text_home'),
  219. 'href' => $this->url->link('common/dashboard', 'token=' . $this->session->data['token'], true)
  220. );
  221. $data['breadcrumbs'][] = array(
  222. 'text' => $this->language->get('heading_title'),
  223. 'href' => $this->url->link('user/user_permission', 'token=' . $this->session->data['token'] . $url, true)
  224. );
  225. if (!isset($this->request->get['user_group_id'])) {
  226. $data['action'] = $this->url->link('user/user_permission/add', 'token=' . $this->session->data['token'] . $url, true);
  227. } else {
  228. $data['action'] = $this->url->link('user/user_permission/edit', 'token=' . $this->session->data['token'] . '&user_group_id=' . $this->request->get['user_group_id'] . $url, true);
  229. }
  230. $data['cancel'] = $this->url->link('user/user_permission', 'token=' . $this->session->data['token'] . $url, true);
  231. if (isset($this->request->get['user_group_id']) && $this->request->server['REQUEST_METHOD'] != 'POST') {
  232. $user_group_info = $this->model_user_user_group->getUserGroup($this->request->get['user_group_id']);
  233. }
  234. if (isset($this->request->post['name'])) {
  235. $data['name'] = $this->request->post['name'];
  236. } elseif (!empty($user_group_info)) {
  237. $data['name'] = $user_group_info['name'];
  238. } else {
  239. $data['name'] = '';
  240. }
  241. $ignore = array(
  242. 'common/dashboard',
  243. 'common/startup',
  244. 'common/login',
  245. 'common/logout',
  246. 'common/forgotten',
  247. 'common/reset',
  248. 'common/footer',
  249. 'common/header',
  250. 'error/not_found',
  251. 'error/permission'
  252. );
  253. $data['hiden'] = array();
  254. $data['permissions'] = array();
  255. $files = array();
  256. // Make path into an array
  257. $path = array(DIR_APPLICATION . 'controller/*');
  258. // While the path array is still populated keep looping through
  259. while (count($path) != 0) {
  260. $next = array_shift($path);
  261. $g_files = glob($next);
  262. if (!$g_files) $g_files = array();
  263. foreach ($g_files as $file) {
  264. // If directory add to path array
  265. if (is_dir($file)) {
  266. $path[] = $file . '/*';
  267. }
  268. // Add the file to the files to be deleted array
  269. if (is_file($file)) {
  270. $files[] = $file;
  271. }
  272. }
  273. }
  274. // Sort the file array
  275. sort($files);
  276. foreach ($files as $file) {
  277. $controller = substr($file, strlen(DIR_APPLICATION . 'controller/'));
  278. $permission = substr($controller, 0, strrpos($controller, '.'));
  279. $hidefiles = explode("/", $permission);
  280. //var_dump($hidefiles);
  281. if ($hidefiles[1] == "module" or $hidefiles[1] == "payment" or $hidefiles[1] == "shipping") {
  282. if (!in_array($permission, $ignore)) {
  283. $data['hiden'][] = $permission;
  284. }
  285. }
  286. if (!in_array($permission, $ignore)) {
  287. $data['permissions'][] = $permission;
  288. }
  289. }
  290. if (isset($this->request->post['permission']['hiden'])) {
  291. $data['ishide'] = $this->request->post['permission']['hiden'];
  292. } elseif (isset($user_group_info['permission']['hiden'])) {
  293. $data['ishide'] = $user_group_info['permission']['hiden'];
  294. } else {
  295. $data['ishide'] = array();
  296. }
  297. if (isset($this->request->post['permission']['access'])) {
  298. $data['access'] = $this->request->post['permission']['access'];
  299. } elseif (isset($user_group_info['permission']['access'])) {
  300. $data['access'] = $user_group_info['permission']['access'];
  301. } else {
  302. $data['access'] = array();
  303. }
  304. if (isset($this->request->post['permission']['modify'])) {
  305. $data['modify'] = $this->request->post['permission']['modify'];
  306. } elseif (isset($user_group_info['permission']['modify'])) {
  307. $data['modify'] = $user_group_info['permission']['modify'];
  308. } else {
  309. $data['modify'] = array();
  310. }
  311. $data['header'] = $this->load->controller('common/header');
  312. $data['column_left'] = $this->load->controller('common/column_left');
  313. $data['footer'] = $this->load->controller('common/footer');
  314. $this->response->setOutput($this->load->view('user/user_group_form', $data));
  315. }
  316. protected function validateForm() {
  317. if (!$this->user->hasPermission('modify', 'user/user_permission')) {
  318. $this->error['warning'] = $this->language->get('error_permission');
  319. }
  320. if ((utf8_strlen($this->request->post['name']) < 3) || (utf8_strlen($this->request->post['name']) > 64)) {
  321. $this->error['name'] = $this->language->get('error_name');
  322. }
  323. return !$this->error;
  324. }
  325. protected function validateDelete() {
  326. if (!$this->user->hasPermission('modify', 'user/user_permission')) {
  327. $this->error['warning'] = $this->language->get('error_permission');
  328. }
  329. $this->load->model('user/user');
  330. foreach ($this->request->post['selected'] as $user_group_id) {
  331. $user_total = $this->model_user_user->getTotalUsersByGroupId($user_group_id);
  332. if ($user_total) {
  333. $this->error['warning'] = sprintf($this->language->get('error_user'), $user_total);
  334. }
  335. }
  336. return !$this->error;
  337. }
  338. }