Completed
Push — master ( 5c9ca5...9b182f )
by René
05:04 queued 11s
created

OptionController   A

Complexity

Total Complexity 19

Size/Duplication

Total Lines 191
Duplicated Lines 0 %

Test Coverage

Coverage 0%

Importance

Changes 3
Bugs 2 Features 0
Metric Value
eloc 75
dl 0
loc 191
ccs 0
cts 92
cp 0
rs 10
c 3
b 2
f 0
wmc 19

6 Methods

Rating   Name   Duplication   Size   Complexity  
A getByToken() 0 8 2
A get() 0 12 3
A __construct() 0 19 1
A remove() 0 17 3
A add() 0 25 4
B update() 0 36 6
1
<?php
2
/**
3
 * @copyright Copyright (c) 2017 Vinzenz Rosenkranz <[email protected]>
4
 *
5
 * @author René Gieling <[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\Polls\Controller;
25
26
use Exception;
27
use OCP\AppFramework\Db\DoesNotExistException;
28
29
use OCP\IRequest;
30
use OCP\ILogger;
31
use OCP\AppFramework\Controller;
32
use OCP\AppFramework\Http;
33
use OCP\AppFramework\Http\DataResponse;
34
35
use OCP\IGroupManager;
36
use OCP\Security\ISecureRandom;
37
38
use OCA\Polls\Db\Poll;
39
use OCA\Polls\Db\PollMapper;
40
use OCA\Polls\Db\Option;
41
use OCA\Polls\Db\OptionMapper;
42
use OCA\Polls\Service\LogService;
43
use OCA\Polls\Model\Acl;
44
45
class OptionController extends Controller {
46
47
	private $userId;
48
	private $optionMapper;
49
50
	private $groupManager;
51
	private $pollMapper;
52
	private $logger;
53
	private $logService;
54
	private $acl;
55
56
	/**
57
	 * OptionController constructor.
58
	 * @param string $appName
59
	 * @param $UserId
60
	 * @param IRequest $request
61
	 * @param ILogger $logger
62
	 * @param OptionMapper $optionMapper
63
	 * @param IGroupManager $groupManager
64
	 * @param PollMapper $pollMapper
65
	 * @param LogService $logService
66
	 * @param Acl $acl
67
	 */
68
69
	public function __construct(
70
		string $appName,
71
		$UserId,
72
		IRequest $request,
73
		OptionMapper $optionMapper,
74
		IGroupManager $groupManager,
75
		PollMapper $pollMapper,
76
		ILogger $logger,
77
		LogService $logService,
78
		Acl $acl
79
	) {
80
		parent::__construct($appName, $request);
81
		$this->userId = $UserId;
82
		$this->optionMapper = $optionMapper;
83
		$this->groupManager = $groupManager;
84
		$this->pollMapper = $pollMapper;
85
		$this->logger = $logger;
86
		$this->logService = $logService;
87
		$this->acl = $acl;
88
	}
89
90
91
	/**
92
	 * Get all options of given poll
93
	 * @NoAdminRequired
94
	 * @param integer $pollId
95
	 * @return array Array of Option objects
96
	 */
97
	public function get($pollId) {
98
99
		try {
100
101
			if (!$this->acl->getFoundByToken()) {
102
				$this->acl->setPollId($pollId);
103
			}
104
105
			return new DataResponse($this->optionMapper->findByPoll($pollId), Http::STATUS_OK);
106
107
		} catch (DoesNotExistException $e) {
108
			return new DataResponse($e, Http::STATUS_NOT_FOUND);
109
		}
110
	}
111
112
113
	/**
114
	 * getByToken
115
	 * Read all options of a poll based on a share token and return list as array
116
	 * @NoAdminRequired
117
	 * @PublicPage
118
	 * @NoCSRFRequired
119
	 * @param string $token
120
	 * @return DataResponse
121
	 */
122
	public function getByToken($token) {
123
124
		try {
125
			$this->acl->setToken($token);
126
			return $this->get($this->acl->getPollId());
127
128
		} catch (DoesNotExistException $e) {
129
			return new DataResponse($e, Http::STATUS_NOT_FOUND);
130
		}
131
	}
132
133
	/**
134
	 * Add a new Option to poll
135
	 * @NoAdminRequired
136
	 * @param Option $option
137
	 * @return DataResponse
138
	 */
139
	public function add($option) {
140
141
		try {
142
143
			if (!$this->acl->setPollId($option['pollId'])->getAllowEdit()) {
144
				return new DataResponse(null, Http::STATUS_UNAUTHORIZED);
145
			}
146
147
			$NewOption = new Option();
148
149
			$NewOption->setPollId($option['pollId']);
150
			$NewOption->setPollOptionText(trim(htmlspecialchars($option['pollOptionText'])));
151
			$NewOption->setTimestamp($option['timestamp']);
152
			if ($option['timestamp']) {
153
				$NewOption->setOrder($option['timestamp']);
154
			} else {
155
				$NewOption->setOrder($option['order']);
156
			}
157
158
			$this->optionMapper->insert($NewOption);
159
			$this->logService->setLog($option['pollId'], 'addOption');
160
			return new DataResponse($NewOption, Http::STATUS_OK);
161
162
		} catch (Exception $e) {
163
			return new DataResponse($e, Http::STATUS_NOT_FOUND);
164
		}
165
166
	}
167
168
	/**
169
	 * Update poll option
170
	 * @NoAdminRequired
171
	 * @param Option $option
172
	 * @return DataResponse
173
	 */
174
	public function update($option) {
175
176
		try {
177
			$this->logger->alert(json_encode($option));
178
			$updateOption = $this->optionMapper->find($option['id']);
179
180
			if (!$this->acl->setPollId($option['pollId'])->getAllowEdit()) {
181
				return new DataResponse(null, Http::STATUS_UNAUTHORIZED);
182
			}
183
184
			$updateOption->setPollOptionText(trim(htmlspecialchars($option['pollOptionText'])));
185
			$updateOption->setTimestamp($option['timestamp']);
186
187
			if ($option['timestamp']) {
188
				$updateOption->setOrder($option['timestamp']);
189
			} else {
190
				$updateOption->setOrder($option['order']);
191
			}
192
193
			if ($option['confirmed']) {
194
				// do not update confirmation date, if option is already confirmed
195
				if (!$updateOption->getConfirmed()) {
196
					$updateOption->setConfirmed(time());
197
				}
198
199
			} else {
200
				$updateOption->setConfirmed(0);
201
			}
202
203
			$this->optionMapper->update($updateOption);
204
			$this->logService->setLog($option['pollId'], 'updateOption');
205
206
			return new DataResponse($updateOption, Http::STATUS_OK);
207
208
		} catch (Exception $e) {
209
			return new DataResponse($e, Http::STATUS_NOT_FOUND);
210
		}
211
	}
212
213
	/**
214
	 * Remove a single option
215
	 * @NoAdminRequired
216
	 * @param Option $option
217
	 * @return DataResponse
218
	 */
219
	public function remove($option) {
220
		try {
221
222
			if (!$this->acl->setPollId($option['pollId'])->getAllowEdit()) {
223
				return new DataResponse(null, Http::STATUS_UNAUTHORIZED);
224
			}
225
226
			$this->optionMapper->remove($option['id']);
227
			$this->logService->setLog($option['pollId'], 'deleteOption');
228
229
			return new DataResponse(array(
230
				'action' => 'deleted',
231
				'optionId' => $option['id']
232
			), Http::STATUS_OK);
233
234
		} catch (Exception $e) {
235
			return new DataResponse($e, Http::STATUS_NOT_FOUND);
236
		}
237
238
	}
239
240
}
241