Nickbur /
Sunrise-CMS
| 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 ControllerCommonReset 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->user->isLogged() && isset($this->request->get['token']) && ($this->request->get['token'] == $this->session->data['token'])) { |
||
| 30 | $this->response->redirect($this->url->link('common/dashboard', '', true)); |
||
| 31 | } |
||
| 32 | |||
| 33 | if (!$this->config->get('config_password')) { |
||
| 34 | $this->response->redirect($this->url->link('common/login', '', true)); |
||
| 35 | } |
||
| 36 | |||
| 37 | if (isset($this->request->get['code'])) { |
||
| 38 | $code = $this->request->get['code']; |
||
| 39 | } else { |
||
| 40 | $code = ''; |
||
| 41 | } |
||
| 42 | |||
| 43 | $this->load->model('user/user'); |
||
| 44 | |||
| 45 | $user_info = $this->model_user_user->getUserByCode($code); |
||
| 46 | |||
| 47 | if ($user_info) { |
||
| 48 | $this->load->language('common/reset'); |
||
| 49 | |||
| 50 | $this->document->setTitle($this->language->get('heading_title')); |
||
| 51 | |||
| 52 | if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validate()) { |
||
| 53 | $this->model_user_user->editPassword($user_info['user_id'], $this->request->post['password']); |
||
| 54 | |||
| 55 | $this->session->data['success'] = $this->language->get('text_success'); |
||
| 56 | |||
| 57 | $this->response->redirect($this->url->link('common/login', '', true)); |
||
| 58 | } |
||
| 59 | |||
| 60 | $data['heading_title'] = $this->language->get('heading_title'); |
||
|
0 ignored issues
–
show
Comprehensibility
Best Practice
introduced
by
|
|||
| 61 | |||
| 62 | $data['text_password'] = $this->language->get('text_password'); |
||
| 63 | |||
| 64 | $data['entry_password'] = $this->language->get('entry_password'); |
||
| 65 | $data['entry_confirm'] = $this->language->get('entry_confirm'); |
||
| 66 | |||
| 67 | $data['button_save'] = $this->language->get('button_save'); |
||
| 68 | $data['button_cancel'] = $this->language->get('button_cancel'); |
||
| 69 | |||
| 70 | $data['breadcrumbs'] = array(); |
||
| 71 | |||
| 72 | $data['breadcrumbs'][] = array( |
||
| 73 | 'text' => $this->language->get('text_home'), |
||
| 74 | 'href' => $this->url->link('common/dashboard', '', true) |
||
| 75 | ); |
||
| 76 | |||
| 77 | $data['breadcrumbs'][] = array( |
||
| 78 | 'text' => $this->language->get('heading_title'), |
||
| 79 | 'href' => $this->url->link('common/reset', '', true) |
||
| 80 | ); |
||
| 81 | |||
| 82 | if (isset($this->error['password'])) { |
||
| 83 | $data['error_password'] = $this->error['password']; |
||
| 84 | } else { |
||
| 85 | $data['error_password'] = ''; |
||
| 86 | } |
||
| 87 | |||
| 88 | if (isset($this->error['confirm'])) { |
||
| 89 | $data['error_confirm'] = $this->error['confirm']; |
||
| 90 | } else { |
||
| 91 | $data['error_confirm'] = ''; |
||
| 92 | } |
||
| 93 | |||
| 94 | $data['action'] = $this->url->link('common/reset', 'code=' . $code, true); |
||
| 95 | |||
| 96 | $data['cancel'] = $this->url->link('common/login', '', true); |
||
| 97 | |||
| 98 | if (isset($this->request->post['password'])) { |
||
| 99 | $data['password'] = $this->request->post['password']; |
||
| 100 | } else { |
||
| 101 | $data['password'] = ''; |
||
| 102 | } |
||
| 103 | |||
| 104 | if (isset($this->request->post['confirm'])) { |
||
| 105 | $data['confirm'] = $this->request->post['confirm']; |
||
| 106 | } else { |
||
| 107 | $data['confirm'] = ''; |
||
| 108 | } |
||
| 109 | |||
| 110 | $data['header'] = $this->load->controller('common/header'); |
||
| 111 | $data['footer'] = $this->load->controller('common/footer'); |
||
| 112 | |||
| 113 | $this->response->setOutput($this->load->view('common/reset', $data)); |
||
| 114 | } else { |
||
| 115 | $this->load->model('setting/setting'); |
||
| 116 | |||
| 117 | $this->model_setting_setting->editSettingValue('config', 'config_password', '0'); |
||
| 118 | |||
| 119 | return new \Divine\Engine\Core\Action('common/login'); |
||
| 120 | } |
||
| 121 | } |
||
| 122 | |||
| 123 | protected function validate() |
||
| 124 | { |
||
| 125 | if ((\voku\helper\UTF8::strlen($this->request->post['password']) < 4) || (\voku\helper\UTF8::strlen($this->request->post['password']) > 20)) { |
||
| 126 | $this->error['password'] = $this->language->get('error_password'); |
||
| 127 | } |
||
| 128 | |||
| 129 | if ($this->request->post['confirm'] != $this->request->post['password']) { |
||
| 130 | $this->error['confirm'] = $this->language->get('error_confirm'); |
||
| 131 | } |
||
| 132 | |||
| 133 | return !$this->error; |
||
| 134 | } |
||
| 135 | } |
||
| 136 |
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.