Completed
Push — master ( c76c8a...69e92e )
by Morris
181:30 queued 162:37
created

Security::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
c 0
b 0
f 0
nc 1
nop 1
dl 0
loc 5
rs 10
1
<?php
2
/**
3
 * @copyright Copyright (c) 2017 Arthur Schiwon <[email protected]>
4
 *
5
 * @author Arthur Schiwon <[email protected]>
6
 *
7
 * @license GNU AGPL version 3 or any later version
8
 *
9
 * This program is free software: you can redistribute it and/or modify
10
 * it under the terms of the GNU Affero General Public License as
11
 * published by the Free Software Foundation, either version 3 of the
12
 * License, or (at your option) any later version.
13
 *
14
 * This program is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU Affero General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU Affero General Public License
20
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 */
23
24
namespace OC\Settings\Personal;
25
26
27
use OCP\AppFramework\Http\TemplateResponse;
28
use OCP\IUserManager;
29
use OCP\Settings\ISettings;
30
31
class Security implements ISettings {
32
33
	private $userManager;
34
35
	public function __construct(
36
		IUserManager $userManager
37
	) {
38
		$this->userManager = $userManager;
39
	}
40
41
	/**
42
	 * @return TemplateResponse returns the instance with all parameters set, ready to be rendered
43
	 * @since 9.1
44
	 */
45
	public function getForm() {
46
		$user = $this->userManager->get(\OC_User::getUser());
47
		$passwordChangeSupported = false;
48
		if ($user !== null) {
49
			$passwordChangeSupported = $user->canChangePassword();
50
		}
51
52
		return new TemplateResponse('settings', 'settings/personal/security', [
53
			'passwordChangeSupported' => $passwordChangeSupported
54
		]);
55
	}
56
57
	/**
58
	 * @return string the section ID, e.g. 'sharing'
59
	 * @since 9.1
60
	 */
61
	public function getSection() {
62
		return 'security';
63
	}
64
65
	/**
66
	 * @return int whether the form should be rather on the top or bottom of
67
	 * the admin section. The forms are arranged in ascending order of the
68
	 * priority values. It is required to return a value between 0 and 100.
69
	 *
70
	 * E.g.: 70
71
	 * @since 9.1
72
	 */
73
	public function getPriority() {
74
		return 10;
75
	}
76
}
77