Admin::getForm()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 8
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
c 1
b 0
f 0
dl 0
loc 8
rs 9.4285
cc 1
eloc 6
nc 1
nop 0
1
<?php
2
/**
3
 * @copyright Copyright (c) 2016, Joas Schilling <[email protected]>
4
 *
5
 * @author Joas Schilling <[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 OCA\NextcloudAnnouncements\Settings;
25
26
use OCP\AppFramework\Http\TemplateResponse;
27
use OCP\IConfig;
28
use OCP\IL10N;
29
use OCP\Settings\ISettings;
30
31
class Admin implements ISettings {
32
33
	/** @var string */
34
	protected $appName;
35
36
	/** @var IConfig */
37
	protected $config;
38
39
	/**
40
	 * @param string $appName
41
	 * @param IConfig $config
42
	 */
43
	public function __construct($appName, IConfig $config) {
44
		$this->appName = $appName;
45
		$this->config = $config;
46
	}
47
48
	/**
49
	 * @return TemplateResponse
50
	 */
51
	public function getForm() {
52
		$groups = $this->config->getAppValue($this->appName, 'notification_groups', '["admin"]');
53
		$groups = implode('|', json_decode($groups, true));
54
55
		return new TemplateResponse($this->appName, 'admin', [
56
			'groups' => $groups,
57
		], 'blank');
58
	}
59
60
	/**
61
	 * @return string the section ID, e.g. 'sharing'
62
	 */
63
	public function getSection() {
64
		return 'additional';
65
	}
66
67
	/**
68
	 * @return int whether the form should be rather on the top or bottom of
69
	 * the admin section. The forms are arranged in ascending order of the
70
	 * priority values. It is required to return a value between 0 and 100.
71
	 *
72
	 * E.g.: 70
73
	 */
74
	public function getPriority() {
75
		return 30;
76
	}
77
78
}
79