PageRenderTime 51ms CodeModel.GetById 19ms RepoModel.GetById 1ms app.codeStats 0ms

/admin/controller/catalog/download.php

https://bitbucket.org/jjasko/opencart_serbian
PHP | 469 lines | 347 code | 122 blank | 0 comment | 82 complexity | 8145c184a97e4afa8ceaf9d40cbc00ef MD5 | raw file
  1. <?php
  2. class ControllerCatalogDownload extends Controller {
  3. private $error = array();
  4. public function index() {
  5. $this->load->language('catalog/download');
  6. $this->document->setTitle($this->language->get('heading_title'));
  7. $this->load->model('catalog/download');
  8. $this->getList();
  9. }
  10. public function insert() {
  11. $this->load->language('catalog/download');
  12. $this->document->setTitle($this->language->get('heading_title'));
  13. $this->load->model('catalog/download');
  14. if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validateForm()) {
  15. $data = array();
  16. if (is_uploaded_file($this->request->files['download']['tmp_name'])) {
  17. $filename = $this->request->files['download']['name'] . '.' . md5(rand());
  18. move_uploaded_file($this->request->files['download']['tmp_name'], DIR_DOWNLOAD . $filename);
  19. if (file_exists(DIR_DOWNLOAD . $filename)) {
  20. $data['download'] = $filename;
  21. $data['mask'] = $this->request->files['download']['name'];
  22. }
  23. }
  24. $this->model_catalog_download->addDownload(array_merge($this->request->post, $data));
  25. $this->session->data['success'] = $this->language->get('text_success');
  26. $url = '';
  27. if (isset($this->request->get['sort'])) {
  28. $url .= '&sort=' . $this->request->get['sort'];
  29. }
  30. if (isset($this->request->get['order'])) {
  31. $url .= '&order=' . $this->request->get['order'];
  32. }
  33. if (isset($this->request->get['page'])) {
  34. $url .= '&page=' . $this->request->get['page'];
  35. }
  36. $this->redirect($this->url->link('catalog/download', 'token=' . $this->session->data['token'] . $url, 'SSL'));
  37. }
  38. $this->getForm();
  39. }
  40. public function update() {
  41. $this->load->language('catalog/download');
  42. $this->document->setTitle($this->language->get('heading_title'));
  43. $this->load->model('catalog/download');
  44. if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validateForm()) {
  45. $data = array();
  46. if (is_uploaded_file($this->request->files['download']['tmp_name'])) {
  47. $filename = $this->request->files['download']['name'] . '.' . md5(rand());
  48. move_uploaded_file($this->request->files['download']['tmp_name'], DIR_DOWNLOAD . $filename);
  49. if (file_exists(DIR_DOWNLOAD . $filename)) {
  50. $data['download'] = $filename;
  51. $data['mask'] = $this->request->files['download']['name'];
  52. }
  53. }
  54. $this->model_catalog_download->editDownload($this->request->get['download_id'], array_merge($this->request->post, $data));
  55. $this->session->data['success'] = $this->language->get('text_success');
  56. $url = '';
  57. if (isset($this->request->get['sort'])) {
  58. $url .= '&sort=' . $this->request->get['sort'];
  59. }
  60. if (isset($this->request->get['order'])) {
  61. $url .= '&order=' . $this->request->get['order'];
  62. }
  63. if (isset($this->request->get['page'])) {
  64. $url .= '&page=' . $this->request->get['page'];
  65. }
  66. $this->redirect($this->url->link('catalog/download', 'token=' . $this->session->data['token'] . $url, 'SSL'));
  67. }
  68. $this->getForm();
  69. }
  70. public function delete() {
  71. $this->load->language('catalog/download');
  72. $this->document->setTitle($this->language->get('heading_title'));
  73. $this->load->model('catalog/download');
  74. if (isset($this->request->post['selected']) && $this->validateDelete()) {
  75. foreach ($this->request->post['selected'] as $download_id) {
  76. $results = $this->model_catalog_download->getDownload($download_id) ;
  77. $filename = $results['filename'];
  78. if (file_exists(DIR_DOWNLOAD . $filename)) {
  79. @unlink(DIR_DOWNLOAD . $filename);
  80. }
  81. $this->model_catalog_download->deleteDownload($download_id);
  82. }
  83. $this->session->data['success'] = $this->language->get('text_success');
  84. $url = '';
  85. if (isset($this->request->get['sort'])) {
  86. $url .= '&sort=' . $this->request->get['sort'];
  87. }
  88. if (isset($this->request->get['order'])) {
  89. $url .= '&order=' . $this->request->get['order'];
  90. }
  91. if (isset($this->request->get['page'])) {
  92. $url .= '&page=' . $this->request->get['page'];
  93. }
  94. $this->redirect($this->url->link('catalog/download', 'token=' . $this->session->data['token'] . $url, 'SSL'));
  95. }
  96. $this->getList();
  97. }
  98. private function getList() {
  99. if (isset($this->request->get['sort'])) {
  100. $sort = $this->request->get['sort'];
  101. } else {
  102. $sort = 'dd.name';
  103. }
  104. if (isset($this->request->get['order'])) {
  105. $order = $this->request->get['order'];
  106. } else {
  107. $order = 'ASC';
  108. }
  109. if (isset($this->request->get['page'])) {
  110. $page = $this->request->get['page'];
  111. } else {
  112. $page = 1;
  113. }
  114. $url = '';
  115. if (isset($this->request->get['sort'])) {
  116. $url .= '&sort=' . $this->request->get['sort'];
  117. }
  118. if (isset($this->request->get['order'])) {
  119. $url .= '&order=' . $this->request->get['order'];
  120. }
  121. if (isset($this->request->get['page'])) {
  122. $url .= '&page=' . $this->request->get['page'];
  123. }
  124. $this->data['breadcrumbs'] = array();
  125. $this->data['breadcrumbs'][] = array(
  126. 'text' => $this->language->get('text_home'),
  127. 'href' => $this->url->link('common/home', 'token=' . $this->session->data['token'], 'SSL'),
  128. 'separator' => false
  129. );
  130. $this->data['breadcrumbs'][] = array(
  131. 'text' => $this->language->get('heading_title'),
  132. 'href' => $this->url->link('catalog/download', 'token=' . $this->session->data['token'] . $url, 'SSL'),
  133. 'separator' => ' :: '
  134. );
  135. $this->data['insert'] = $this->url->link('catalog/download/insert', 'token=' . $this->session->data['token'] . $url, 'SSL');
  136. $this->data['delete'] = $this->url->link('catalog/download/delete', 'token=' . $this->session->data['token'] . $url, 'SSL');
  137. $this->data['downloads'] = array();
  138. $data = array(
  139. 'sort' => $sort,
  140. 'order' => $order,
  141. 'start' => ($page - 1) * $this->config->get('config_admin_limit'),
  142. 'limit' => $this->config->get('config_admin_limit')
  143. );
  144. $download_total = $this->model_catalog_download->getTotalDownloads();
  145. $results = $this->model_catalog_download->getDownloads($data);
  146. foreach ($results as $result) {
  147. $action = array();
  148. $action[] = array(
  149. 'text' => $this->language->get('text_edit'),
  150. 'href' => $this->url->link('catalog/download/update', 'token=' . $this->session->data['token'] . '&download_id=' . $result['download_id'] . $url, 'SSL')
  151. );
  152. $this->data['downloads'][] = array(
  153. 'download_id' => $result['download_id'],
  154. 'name' => $result['name'],
  155. 'remaining' => $result['remaining'],
  156. 'selected' => isset($this->request->post['selected']) && in_array($result['download_id'], $this->request->post['selected']),
  157. 'action' => $action
  158. );
  159. }
  160. $this->data['heading_title'] = $this->language->get('heading_title');
  161. $this->data['text_no_results'] = $this->language->get('text_no_results');
  162. $this->data['column_name'] = $this->language->get('column_name');
  163. $this->data['column_remaining'] = $this->language->get('column_remaining');
  164. $this->data['column_action'] = $this->language->get('column_action');
  165. $this->data['button_insert'] = $this->language->get('button_insert');
  166. $this->data['button_delete'] = $this->language->get('button_delete');
  167. if (isset($this->error['warning'])) {
  168. $this->data['error_warning'] = $this->error['warning'];
  169. } else {
  170. $this->data['error_warning'] = '';
  171. }
  172. if (isset($this->session->data['success'])) {
  173. $this->data['success'] = $this->session->data['success'];
  174. unset($this->session->data['success']);
  175. } else {
  176. $this->data['success'] = '';
  177. }
  178. $url = '';
  179. if ($order == 'ASC') {
  180. $url .= '&order=DESC';
  181. } else {
  182. $url .= '&order=ASC';
  183. }
  184. if (isset($this->request->get['page'])) {
  185. $url .= '&page=' . $this->request->get['page'];
  186. }
  187. $this->data['sort_name'] = $this->url->link('catalog/download', 'token=' . $this->session->data['token'] . '&sort=dd.name' . $url, 'SSL');
  188. $this->data['sort_remaining'] = $this->url->link('catalog/download', 'token=' . $this->session->data['token'] . '&sort=d.remaining' . $url, 'SSL');
  189. $url = '';
  190. if (isset($this->request->get['sort'])) {
  191. $url .= '&sort=' . $this->request->get['sort'];
  192. }
  193. if (isset($this->request->get['order'])) {
  194. $url .= '&order=' . $this->request->get['order'];
  195. }
  196. $pagination = new Pagination();
  197. $pagination->total = $download_total;
  198. $pagination->page = $page;
  199. $pagination->limit = $this->config->get('config_admin_limit');
  200. $pagination->text = $this->language->get('text_pagination');
  201. $pagination->url = $this->url->link('catalog/download', 'token=' . $this->session->data['token'] . $url . '&page={page}', 'SSL');
  202. $this->data['pagination'] = $pagination->render();
  203. $this->data['sort'] = $sort;
  204. $this->data['order'] = $order;
  205. $this->template = 'catalog/download_list.tpl';
  206. $this->children = array(
  207. 'common/header',
  208. 'common/footer'
  209. );
  210. $this->response->setOutput($this->render());
  211. }
  212. private function getForm() {
  213. $this->data['heading_title'] = $this->language->get('heading_title');
  214. $this->data['entry_name'] = $this->language->get('entry_name');
  215. $this->data['entry_filename'] = $this->language->get('entry_filename');
  216. $this->data['entry_remaining'] = $this->language->get('entry_remaining');
  217. $this->data['entry_update'] = $this->language->get('entry_update');
  218. $this->data['button_save'] = $this->language->get('button_save');
  219. $this->data['button_cancel'] = $this->language->get('button_cancel');
  220. if (isset($this->error['warning'])) {
  221. $this->data['error_warning'] = $this->error['warning'];
  222. } else {
  223. $this->data['error_warning'] = '';
  224. }
  225. if (isset($this->error['name'])) {
  226. $this->data['error_name'] = $this->error['name'];
  227. } else {
  228. $this->data['error_name'] = array();
  229. }
  230. if (isset($this->error['download'])) {
  231. $this->data['error_download'] = $this->error['download'];
  232. } else {
  233. $this->data['error_download'] = '';
  234. }
  235. $url = '';
  236. if (isset($this->request->get['sort'])) {
  237. $url .= '&sort=' . $this->request->get['sort'];
  238. }
  239. if (isset($this->request->get['order'])) {
  240. $url .= '&order=' . $this->request->get['order'];
  241. }
  242. if (isset($this->request->get['page'])) {
  243. $url .= '&page=' . $this->request->get['page'];
  244. }
  245. $this->data['breadcrumbs'] = array();
  246. $this->data['breadcrumbs'][] = array(
  247. 'text' => $this->language->get('text_home'),
  248. 'href' => $this->url->link('common/home', 'token=' . $this->session->data['token'], 'SSL'),
  249. 'separator' => false
  250. );
  251. $this->data['breadcrumbs'][] = array(
  252. 'text' => $this->language->get('heading_title'),
  253. 'href' => $this->url->link('catalog/download', 'token=' . $this->session->data['token'] . $url, 'SSL'),
  254. 'separator' => ' :: '
  255. );
  256. if (!isset($this->request->get['download_id'])) {
  257. $this->data['action'] = $this->url->link('catalog/download/insert', 'token=' . $this->session->data['token'] . $url, 'SSL');
  258. } else {
  259. $this->data['action'] = $this->url->link('catalog/download/update', 'token=' . $this->session->data['token'] . '&download_id=' . $this->request->get['download_id'] . $url, 'SSL');
  260. }
  261. $this->data['cancel'] = $this->url->link('catalog/download', 'token=' . $this->session->data['token'] . $url, 'SSL');
  262. $this->load->model('localisation/language');
  263. $this->data['languages'] = $this->model_localisation_language->getLanguages();
  264. if (isset($this->request->get['download_id']) && ($this->request->server['REQUEST_METHOD'] != 'POST')) {
  265. $download_info = $this->model_catalog_download->getDownload($this->request->get['download_id']);
  266. }
  267. if (isset($download_info['filename'])) {
  268. $this->data['filename'] = $download_info['filename'];
  269. } else {
  270. $this->data['filename'] = '';
  271. }
  272. if (isset($this->request->get['download_id'])) {
  273. $this->data['show_update'] = true;
  274. } else {
  275. $this->data['show_update'] = false;
  276. }
  277. if (isset($this->request->post['download_description'])) {
  278. $this->data['download_description'] = $this->request->post['download_description'];
  279. } elseif (isset($this->request->get['download_id'])) {
  280. $this->data['download_description'] = $this->model_catalog_download->getDownloadDescriptions($this->request->get['download_id']);
  281. } else {
  282. $this->data['download_description'] = array();
  283. }
  284. if (isset($this->request->post['remaining'])) {
  285. $this->data['remaining'] = $this->request->post['remaining'];
  286. } elseif (!empty($download_info['remaining'])) {
  287. $this->data['remaining'] = $download_info['remaining'];
  288. } else {
  289. $this->data['remaining'] = 1;
  290. }
  291. if (isset($this->request->post['update'])) {
  292. $this->data['update'] = $this->request->post['update'];
  293. } else {
  294. $this->data['update'] = false;
  295. }
  296. $this->template = 'catalog/download_form.tpl';
  297. $this->children = array(
  298. 'common/header',
  299. 'common/footer'
  300. );
  301. $this->response->setOutput($this->render());
  302. }
  303. private function validateForm() {
  304. if (!$this->user->hasPermission('modify', 'catalog/download')) {
  305. $this->error['warning'] = $this->language->get('error_permission');
  306. }
  307. foreach ($this->request->post['download_description'] as $language_id => $value) {
  308. if ((utf8_strlen($value['name']) < 3) || (utf8_strlen($value['name']) > 64)) {
  309. $this->error['name'][$language_id] = $this->language->get('error_name');
  310. }
  311. }
  312. if ($this->request->files['download']['name']) {
  313. if ((utf8_strlen($this->request->files['download']['name']) < 3) || (utf8_strlen($this->request->files['download']['name']) > 128)) {
  314. $this->error['download'] = $this->language->get('error_filename');
  315. }
  316. if (utf8_substr(strrchr($this->request->files['download']['name'], '.'), 1) == 'php') {
  317. $this->error['download'] = $this->language->get('error_filetype');
  318. }
  319. if ($this->request->files['download']['error'] != UPLOAD_ERR_OK) {
  320. $this->error['warning'] = $this->language->get('error_upload_' . $this->request->files['download']['error']);
  321. }
  322. }
  323. if (!$this->error) {
  324. return true;
  325. } else {
  326. return false;
  327. }
  328. }
  329. private function validateDelete() {
  330. if (!$this->user->hasPermission('modify', 'catalog/download')) {
  331. $this->error['warning'] = $this->language->get('error_permission');
  332. }
  333. $this->load->model('catalog/product');
  334. foreach ($this->request->post['selected'] as $download_id) {
  335. $product_total = $this->model_catalog_product->getTotalProductsByDownloadId($download_id);
  336. if ($product_total) {
  337. $this->error['warning'] = sprintf($this->language->get('error_product'), $product_total);
  338. }
  339. }
  340. if (!$this->error) {
  341. return true;
  342. } else {
  343. return false;
  344. }
  345. }
  346. }
  347. ?>