PageRenderTime 45ms CodeModel.GetById 17ms RepoModel.GetById 0ms app.codeStats 0ms

/admin/controller/sale/customer_ban_ip.php

https://gitlab.com/hazelnuts23/unitedfoodstuff
PHP | 356 lines | 258 code | 98 blank | 0 comment | 56 complexity | d7cd30a5f1be3845e950059b3b24a768 MD5 | raw file
  1. <?php
  2. class ControllerSaleCustomerBanIp extends Controller {
  3. private $error = array();
  4. public function index() {
  5. $this->load->language('sale/customer_ban_ip');
  6. $this->document->setTitle($this->language->get('heading_title'));
  7. $this->load->model('sale/customer_ban_ip');
  8. $this->getList();
  9. }
  10. public function add() {
  11. $this->load->language('sale/customer_ban_ip');
  12. $this->document->setTitle($this->language->get('heading_title'));
  13. $this->load->model('sale/customer_ban_ip');
  14. if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validateForm()) {
  15. $this->model_sale_customer_ban_ip->addCustomerBanIp($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('sale/customer_ban_ip', 'token=' . $this->session->data['token'] . $url, 'SSL'));
  28. }
  29. $this->getForm();
  30. }
  31. public function edit() {
  32. $this->load->language('sale/customer_ban_ip');
  33. $this->document->setTitle($this->language->get('heading_title'));
  34. $this->load->model('sale/customer_ban_ip');
  35. if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validateForm()) {
  36. $this->model_sale_customer_ban_ip->editCustomerBanIp($this->request->get['customer_ban_ip_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('sale/customer_ban_ip', 'token=' . $this->session->data['token'] . $url, 'SSL'));
  49. }
  50. $this->getForm();
  51. }
  52. public function delete() {
  53. $this->load->language('sale/customer_ban_ip');
  54. $this->document->setTitle($this->language->get('heading_title'));
  55. $this->load->model('sale/customer_ban_ip');
  56. if (isset($this->request->post['selected']) && $this->validateDelete()) {
  57. foreach ($this->request->post['selected'] as $customer_ban_ip_id) {
  58. $this->model_sale_customer_ban_ip->deleteCustomerBanIp($customer_ban_ip_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('sale/customer_ban_ip', 'token=' . $this->session->data['token'] . $url, 'SSL'));
  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 = 'ip';
  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'], 'SSL')
  105. );
  106. $data['breadcrumbs'][] = array(
  107. 'text' => $this->language->get('heading_title'),
  108. 'href' => $this->url->link('sale/customer_ban_ip', 'token=' . $this->session->data['token'] . $url, 'SSL')
  109. );
  110. $data['add'] = $this->url->link('sale/customer_ban_ip/add', 'token=' . $this->session->data['token'] . $url, 'SSL');
  111. $data['delete'] = $this->url->link('sale/customer_ban_ip/delete', 'token=' . $this->session->data['token'] . $url, 'SSL');
  112. $data['customer_ban_ips'] = 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. $customer_ban_ip_total = $this->model_sale_customer_ban_ip->getTotalCustomerBanIps($filter_data);
  120. $results = $this->model_sale_customer_ban_ip->getCustomerBanIps($filter_data);
  121. foreach ($results as $result) {
  122. $data['customer_ban_ips'][] = array(
  123. 'customer_ban_ip_id' => $result['customer_ban_ip_id'],
  124. 'ip' => $result['ip'],
  125. 'total' => $result['total'],
  126. 'customer' => $this->url->link('sale/customer', 'token=' . $this->session->data['token'] . '&filter_ip=' . $result['ip'], 'SSL'),
  127. 'edit' => $this->url->link('sale/customer_ban_ip/edit', 'token=' . $this->session->data['token'] . '&customer_ban_ip_id=' . $result['customer_ban_ip_id'] . $url, 'SSL')
  128. );
  129. }
  130. $data['heading_title'] = $this->language->get('heading_title');
  131. $data['text_list'] = $this->language->get('text_list');
  132. $data['text_no_results'] = $this->language->get('text_no_results');
  133. $data['text_confirm'] = $this->language->get('text_confirm');
  134. $data['column_ip'] = $this->language->get('column_ip');
  135. $data['column_customer'] = $this->language->get('column_customer');
  136. $data['column_action'] = $this->language->get('column_action');
  137. $data['button_add'] = $this->language->get('button_add');
  138. $data['button_edit'] = $this->language->get('button_edit');
  139. $data['button_delete'] = $this->language->get('button_delete');
  140. if (isset($this->error['warning'])) {
  141. $data['error_warning'] = $this->error['warning'];
  142. } else {
  143. $data['error_warning'] = '';
  144. }
  145. if (isset($this->session->data['success'])) {
  146. $data['success'] = $this->session->data['success'];
  147. unset($this->session->data['success']);
  148. } else {
  149. $data['success'] = '';
  150. }
  151. if (isset($this->request->post['selected'])) {
  152. $data['selected'] = (array)$this->request->post['selected'];
  153. } else {
  154. $data['selected'] = array();
  155. }
  156. $url = '';
  157. if ($order == 'ASC') {
  158. $url .= '&order=DESC';
  159. } else {
  160. $url .= '&order=ASC';
  161. }
  162. if (isset($this->request->get['page'])) {
  163. $url .= '&page=' . $this->request->get['page'];
  164. }
  165. $data['sort_ip'] = $this->url->link('sale/customer_ban_ip', 'token=' . $this->session->data['token'] . '&sort=ip' . $url, 'SSL');
  166. $url = '';
  167. if (isset($this->request->get['sort'])) {
  168. $url .= '&sort=' . $this->request->get['sort'];
  169. }
  170. if (isset($this->request->get['order'])) {
  171. $url .= '&order=' . $this->request->get['order'];
  172. }
  173. $pagination = new Pagination();
  174. $pagination->total = $customer_ban_ip_total;
  175. $pagination->page = $page;
  176. $pagination->limit = $this->config->get('config_limit_admin');
  177. $pagination->url = $this->url->link('sale/customer_ban_ip', 'token=' . $this->session->data['token'] . $url . '&page={page}', 'SSL');
  178. $data['pagination'] = $pagination->render();
  179. $data['results'] = sprintf($this->language->get('text_pagination'), ($customer_ban_ip_total) ? (($page - 1) * $this->config->get('config_limit_admin')) + 1 : 0, ((($page - 1) * $this->config->get('config_limit_admin')) > ($customer_ban_ip_total - $this->config->get('config_limit_admin'))) ? $customer_ban_ip_total : ((($page - 1) * $this->config->get('config_limit_admin')) + $this->config->get('config_limit_admin')), $customer_ban_ip_total, ceil($customer_ban_ip_total / $this->config->get('config_limit_admin')));
  180. $data['sort'] = $sort;
  181. $data['order'] = $order;
  182. $data['header'] = $this->load->controller('common/header');
  183. $data['column_left'] = $this->load->controller('common/column_left');
  184. $data['footer'] = $this->load->controller('common/footer');
  185. $this->response->setOutput($this->load->view('sale/customer_ban_ip_list.tpl', $data));
  186. }
  187. protected function getForm() {
  188. $data['heading_title'] = $this->language->get('heading_title');
  189. $data['text_form'] = !isset($this->request->get['customer_ban_ip_id']) ? $this->language->get('text_add') : $this->language->get('text_edit');
  190. $data['entry_ip'] = $this->language->get('entry_ip');
  191. $data['button_save'] = $this->language->get('button_save');
  192. $data['button_cancel'] = $this->language->get('button_cancel');
  193. if (isset($this->error['warning'])) {
  194. $data['error_warning'] = $this->error['warning'];
  195. } else {
  196. $data['error_warning'] = '';
  197. }
  198. if (isset($this->error['ip'])) {
  199. $data['error_ip'] = $this->error['ip'];
  200. } else {
  201. $data['error_ip'] = '';
  202. }
  203. $url = '';
  204. if (isset($this->request->get['sort'])) {
  205. $url .= '&sort=' . $this->request->get['sort'];
  206. }
  207. if (isset($this->request->get['order'])) {
  208. $url .= '&order=' . $this->request->get['order'];
  209. }
  210. if (isset($this->request->get['page'])) {
  211. $url .= '&page=' . $this->request->get['page'];
  212. }
  213. $data['breadcrumbs'] = array();
  214. $data['breadcrumbs'][] = array(
  215. 'text' => $this->language->get('text_home'),
  216. 'href' => $this->url->link('common/dashboard', 'token=' . $this->session->data['token'], 'SSL')
  217. );
  218. $data['breadcrumbs'][] = array(
  219. 'text' => $this->language->get('heading_title'),
  220. 'href' => $this->url->link('sale/customer_ban_ip', 'token=' . $this->session->data['token'] . $url, 'SSL')
  221. );
  222. if (!isset($this->request->get['customer_ban_ip_id'])) {
  223. $data['action'] = $this->url->link('sale/customer_ban_ip/add', 'token=' . $this->session->data['token'] . $url, 'SSL');
  224. } else {
  225. $data['action'] = $this->url->link('sale/customer_ban_ip/edit', 'token=' . $this->session->data['token'] . '&customer_ban_ip_id=' . $this->request->get['customer_ban_ip_id'] . $url, 'SSL');
  226. }
  227. $data['cancel'] = $this->url->link('sale/customer_ban_ip', 'token=' . $this->session->data['token'] . $url, 'SSL');
  228. if (isset($this->request->get['customer_ban_ip_id']) && ($this->request->server['REQUEST_METHOD'] != 'POST')) {
  229. $customer_ban_ip_info = $this->model_sale_customer_ban_ip->getCustomerBanIp($this->request->get['customer_ban_ip_id']);
  230. }
  231. if (isset($this->request->post['ip'])) {
  232. $data['ip'] = $this->request->post['ip'];
  233. } elseif (!empty($customer_ban_ip_info)) {
  234. $data['ip'] = $customer_ban_ip_info['ip'];
  235. } else {
  236. $data['ip'] = '';
  237. }
  238. $data['header'] = $this->load->controller('common/header');
  239. $data['column_left'] = $this->load->controller('common/column_left');
  240. $data['footer'] = $this->load->controller('common/footer');
  241. $this->response->setOutput($this->load->view('sale/customer_ban_ip_form.tpl', $data));
  242. }
  243. protected function validateForm() {
  244. if (!$this->user->hasPermission('modify', 'sale/customer_ban_ip')) {
  245. $this->error['warning'] = $this->language->get('error_permission');
  246. }
  247. if ((utf8_strlen($this->request->post['ip']) < 1) || (utf8_strlen($this->request->post['ip']) > 40)) {
  248. $this->error['ip'] = $this->language->get('error_ip');
  249. }
  250. return !$this->error;
  251. }
  252. protected function validateDelete() {
  253. if (!$this->user->hasPermission('modify', 'sale/customer_ban_ip')) {
  254. $this->error['warning'] = $this->language->get('error_permission');
  255. }
  256. return !$this->error;
  257. }
  258. }