1 | <?php |
||
2 | |||
3 | /* Divine CMS - Open source CMS for widespread use. |
||
4 | Copyright (c) 2019 Mykola Burakov ([email protected]) |
||
5 | |||
6 | See SOURCE.txt for other and additional information. |
||
7 | |||
8 | This file is part of Divine CMS. |
||
9 | |||
10 | This program is free software: you can redistribute it and/or modify |
||
11 | it under the terms of the GNU General Public License as published by |
||
12 | the Free Software Foundation, either version 3 of the License, or |
||
13 | (at your option) any later version. |
||
14 | |||
15 | This program is distributed in the hope that it will be useful, |
||
16 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
||
17 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||
18 | GNU General Public License for more details. |
||
19 | |||
20 | You should have received a copy of the GNU General Public License |
||
21 | along with this program. If not, see <http://www.gnu.org/licenses/>. */ |
||
22 | |||
23 | class ControllerAccountReset extends \Divine\Engine\Core\Controller |
||
0 ignored issues
–
show
|
|||
24 | { |
||
25 | private $error = array(); |
||
26 | |||
27 | public function index() |
||
0 ignored issues
–
show
|
|||
28 | { |
||
29 | if ($this->customer->isLogged()) { |
||
30 | $this->response->redirect($this->url->link('account/account', '', true)); |
||
31 | } |
||
32 | |||
33 | if (isset($this->request->get['code'])) { |
||
34 | $code = $this->request->get['code']; |
||
35 | } else { |
||
36 | $code = ''; |
||
37 | } |
||
38 | |||
39 | $this->load->model('account/customer'); |
||
40 | |||
41 | $customer_info = $this->model_account_customer->getCustomerByCode($code); |
||
42 | |||
43 | if ($customer_info) { |
||
44 | $this->load->language('account/reset'); |
||
45 | |||
46 | $this->document->setTitle($this->language->get('heading_title')); |
||
47 | |||
48 | if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validate()) { |
||
49 | $this->model_account_customer->editPassword($customer_info['email'], $this->request->post['password']); |
||
50 | |||
51 | $this->session->data['success'] = $this->language->get('text_success'); |
||
52 | |||
53 | $this->response->redirect($this->url->link('account/login', '', true)); |
||
54 | } |
||
55 | |||
56 | $data['heading_title'] = $this->language->get('heading_title'); |
||
0 ignored issues
–
show
Comprehensibility
Best Practice
introduced
by
|
|||
57 | |||
58 | $data['text_password'] = $this->language->get('text_password'); |
||
59 | |||
60 | $data['entry_password'] = $this->language->get('entry_password'); |
||
61 | $data['entry_confirm'] = $this->language->get('entry_confirm'); |
||
62 | |||
63 | $data['button_continue'] = $this->language->get('button_continue'); |
||
64 | $data['button_back'] = $this->language->get('button_back'); |
||
65 | |||
66 | $data['breadcrumbs'] = array(); |
||
67 | |||
68 | $data['breadcrumbs'][] = array( |
||
69 | 'text' => $this->language->get('text_home'), |
||
70 | 'href' => $this->url->link('common/home') |
||
71 | ); |
||
72 | |||
73 | $data['breadcrumbs'][] = array( |
||
74 | 'text' => $this->language->get('text_account'), |
||
75 | 'href' => $this->url->link('account/account', '', true) |
||
76 | ); |
||
77 | |||
78 | $data['breadcrumbs'][] = array( |
||
79 | 'text' => $this->language->get('heading_title'), |
||
80 | 'href' => $this->url->link('account/reset', '', true) |
||
81 | ); |
||
82 | |||
83 | if (isset($this->error['password'])) { |
||
84 | $data['error_password'] = $this->error['password']; |
||
85 | } else { |
||
86 | $data['error_password'] = ''; |
||
87 | } |
||
88 | |||
89 | if (isset($this->error['confirm'])) { |
||
90 | $data['error_confirm'] = $this->error['confirm']; |
||
91 | } else { |
||
92 | $data['error_confirm'] = ''; |
||
93 | } |
||
94 | |||
95 | $data['action'] = $this->url->link('account/reset', 'code=' . $code, true); |
||
96 | |||
97 | $data['back'] = $this->url->link('account/login', '', true); |
||
98 | |||
99 | if (isset($this->request->post['password'])) { |
||
100 | $data['password'] = $this->request->post['password']; |
||
101 | } else { |
||
102 | $data['password'] = ''; |
||
103 | } |
||
104 | |||
105 | if (isset($this->request->post['confirm'])) { |
||
106 | $data['confirm'] = $this->request->post['confirm']; |
||
107 | } else { |
||
108 | $data['confirm'] = ''; |
||
109 | } |
||
110 | |||
111 | $data['column'] = $this->load->controller('common/column'); |
||
112 | |||
113 | $data['content_top'] = $this->load->controller('common/content_top'); |
||
114 | $data['content_bottom'] = $this->load->controller('common/content_bottom'); |
||
115 | $data['footer'] = $this->load->controller('common/footer'); |
||
116 | $data['header'] = $this->load->controller('common/header'); |
||
117 | |||
118 | $this->response->setOutput($this->load->view('account/reset', $data)); |
||
119 | } else { |
||
120 | $this->load->language('account/reset'); |
||
121 | |||
122 | $this->session->data['error'] = $this->language->get('error_code'); |
||
123 | |||
124 | return new \Divine\Engine\Core\Action('account/login'); |
||
125 | } |
||
126 | } |
||
127 | |||
128 | protected function validate() |
||
129 | { |
||
130 | if ((\voku\helper\UTF8::strlen($this->request->post['password']) < 4) || (\voku\helper\UTF8::strlen($this->request->post['password']) > 20)) { |
||
131 | $this->error['password'] = $this->language->get('error_password'); |
||
132 | } |
||
133 | |||
134 | if ($this->request->post['confirm'] != $this->request->post['password']) { |
||
135 | $this->error['confirm'] = $this->language->get('error_confirm'); |
||
136 | } |
||
137 | |||
138 | return !$this->error; |
||
139 | } |
||
140 | } |
||
141 |
You can fix this by adding a namespace to your class:
When choosing a vendor namespace, try to pick something that is not too generic to avoid conflicts with other libraries.