/admin/controller/fraud/ip.php

https://gitlab.com/shapcy/opencart · PHP · 204 lines · 146 code · 58 blank · 0 comment · 17 complexity · 48417938e9c74d336ac12a5bd20e45d8 MD5 · raw file

  1. <?php
  2. class ControllerFraudIp extends Controller {
  3. private $error = array();
  4. public function index() {
  5. $this->load->language('fraud/ip');
  6. $this->document->setTitle($this->language->get('heading_title'));
  7. $this->load->model('setting/setting');
  8. if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validate()) {
  9. $this->model_setting_setting->editSetting('ip', $this->request->post);
  10. $this->session->data['success'] = $this->language->get('text_success');
  11. $this->response->redirect($this->url->link('extension/fraud', 'token=' . $this->session->data['token'], true));
  12. }
  13. $data['heading_title'] = $this->language->get('heading_title');
  14. $data['text_edit'] = $this->language->get('text_edit');
  15. $data['text_enabled'] = $this->language->get('text_enabled');
  16. $data['text_disabled'] = $this->language->get('text_disabled');
  17. $data['text_ip_add'] = $this->language->get('text_ip_add');
  18. $data['text_ip_list'] = $this->language->get('text_ip_list');
  19. $data['text_loading'] = $this->language->get('text_loading');
  20. $data['entry_ip'] = $this->language->get('entry_ip');
  21. $data['entry_order_status'] = $this->language->get('entry_order_status');
  22. $data['entry_status'] = $this->language->get('entry_status');
  23. $data['help_ip'] = $this->language->get('help_ip');
  24. $data['help_order_status'] = $this->language->get('help_order_status');
  25. $data['button_save'] = $this->language->get('button_save');
  26. $data['button_cancel'] = $this->language->get('button_cancel');
  27. $data['button_ip_add'] = $this->language->get('button_ip_add');
  28. $data['tab_general'] = $this->language->get('tab_general');
  29. $data['tab_ip'] = $this->language->get('tab_ip');
  30. $data['token'] = $this->session->data['token'];
  31. if (isset($this->error['warning'])) {
  32. $data['error_warning'] = $this->error['warning'];
  33. } else {
  34. $data['error_warning'] = '';
  35. }
  36. $data['breadcrumbs'] = array();
  37. $data['breadcrumbs'][] = array(
  38. 'text' => $this->language->get('text_home'),
  39. 'href' => $this->url->link('common/dashboard', 'token=' . $this->session->data['token'], true)
  40. );
  41. $data['breadcrumbs'][] = array(
  42. 'text' => $this->language->get('text_fraud'),
  43. 'href' => $this->url->link('extension/fraud', 'token=' . $this->session->data['token'], true)
  44. );
  45. $data['breadcrumbs'][] = array(
  46. 'text' => $this->language->get('heading_title'),
  47. 'href' => $this->url->link('fraud/ip', 'token=' . $this->session->data['token'], true)
  48. );
  49. $data['action'] = $this->url->link('fraud/ip', 'token=' . $this->session->data['token'], true);
  50. $data['cancel'] = $this->url->link('extension/fraud', 'token=' . $this->session->data['token'], true);
  51. if (isset($this->request->post['ip_order_status_id'])) {
  52. $data['ip_order_status_id'] = $this->request->post['ip_order_status_id'];
  53. } else {
  54. $data['ip_order_status_id'] = $this->config->get('ip_order_status_id');
  55. }
  56. $this->load->model('localisation/order_status');
  57. $data['order_statuses'] = $this->model_localisation_order_status->getOrderStatuses();
  58. if (isset($this->request->post['ip_status'])) {
  59. $data['ip_status'] = $this->request->post['ip_status'];
  60. } else {
  61. $data['ip_status'] = $this->config->get('ip_status');
  62. }
  63. $data['header'] = $this->load->controller('common/header');
  64. $data['column_left'] = $this->load->controller('common/column_left');
  65. $data['footer'] = $this->load->controller('common/footer');
  66. $this->response->setOutput($this->load->view('fraud/ip', $data));
  67. }
  68. public function install() {
  69. $this->load->model('fraud/ip');
  70. $this->model_fraud_ip->install();
  71. }
  72. public function uninstall() {
  73. $this->load->model('fraud/ip');
  74. $this->model_fraud_ip->uninstall();
  75. }
  76. protected function validate() {
  77. if (!$this->user->hasPermission('modify', 'fraud/ip')) {
  78. $this->error['warning'] = $this->language->get('error_permission');
  79. }
  80. return !$this->error;
  81. }
  82. public function ip() {
  83. $this->load->language('fraud/ip');
  84. $this->load->model('fraud/ip');
  85. $this->load->model('customer/customer');
  86. $data['text_no_results'] = $this->language->get('text_no_results');
  87. $data['text_loading'] = $this->language->get('text_loading');
  88. $data['column_ip'] = $this->language->get('column_ip');
  89. $data['column_total'] = $this->language->get('column_total');
  90. $data['column_date_added'] = $this->language->get('column_date_added');
  91. $data['column_action'] = $this->language->get('column_action');
  92. $data['button_remove'] = $this->language->get('button_remove');
  93. if (isset($this->request->get['page'])) {
  94. $page = $this->request->get['page'];
  95. } else {
  96. $page = 1;
  97. }
  98. $data['ips'] = array();
  99. $results = $this->model_fraud_ip->getIps(($page - 1) * 10, 10);
  100. foreach ($results as $result) {
  101. $data['ips'][] = array(
  102. 'ip' => $result['ip'],
  103. 'total' => $this->model_customer_customer->getTotalCustomersByIp($result['ip']),
  104. 'date_added' => date('d/m/y', strtotime($result['date_added'])),
  105. 'filter_ip' => $this->url->link('customer/customer', 'token=' . $this->session->data['token'] . '&filter_ip=' . $result['ip'], true)
  106. );
  107. }
  108. $ip_total = $this->model_fraud_ip->getTotalIps();
  109. $pagination = new Pagination();
  110. $pagination->total = $ip_total;
  111. $pagination->page = $page;
  112. $pagination->limit = 10;
  113. $pagination->url = $this->url->link('fraud/ip/ip', 'token=' . $this->session->data['token'] . '&page={page}', true);
  114. $data['pagination'] = $pagination->render();
  115. $data['results'] = sprintf($this->language->get('text_pagination'), ($ip_total) ? (($page - 1) * 10) + 1 : 0, ((($page - 1) * 10) > ($ip_total - 10)) ? $ip_total : ((($page - 1) * 10) + 10), $ip_total, ceil($ip_total / 10));
  116. $this->response->setOutput($this->load->view('fraud/ip_ip', $data));
  117. }
  118. public function addIp() {
  119. $this->load->language('fraud/ip');
  120. $json = array();
  121. if (!$this->user->hasPermission('modify', 'fraud/ip')) {
  122. $json['error'] = $this->language->get('error_permission');
  123. } else {
  124. $this->load->model('fraud/ip');
  125. if (!$this->model_fraud_ip->getTotalIpsByIp($this->request->post['ip'])) {
  126. $this->model_fraud_ip->addIp($this->request->post['ip']);
  127. }
  128. $json['success'] = $this->language->get('text_success');
  129. }
  130. $this->response->addHeader('Content-Type: application/json');
  131. $this->response->setOutput(json_encode($json));
  132. }
  133. public function removeIp() {
  134. $this->load->language('fraud/ip');
  135. $json = array();
  136. if (!$this->user->hasPermission('modify', 'fraud/ip')) {
  137. $json['error'] = $this->language->get('error_permission');
  138. } else {
  139. $this->load->model('fraud/ip');
  140. $this->model_fraud_ip->removeIp($this->request->post['ip']);
  141. $json['success'] = $this->language->get('text_success');
  142. }
  143. $this->response->addHeader('Content-Type: application/json');
  144. $this->response->setOutput(json_encode($json));
  145. }
  146. }