Passed
Pull Request — master (#966)
by René
04:04
created

ShareController::createPersonalShare()   A

Complexity

Conditions 4
Paths 4

Size

Total Lines 11
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 20

Importance

Changes 2
Bugs 1 Features 0
Metric Value
cc 4
eloc 8
c 2
b 1
f 0
nc 4
nop 2
dl 0
loc 11
ccs 0
cts 9
cp 0
crap 20
rs 10
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
use OCA\Polls\Exceptions\NotAuthorizedException;
29
use OCA\Polls\Exceptions\InvalidUsername;
30
31
32
use OCP\IRequest;
33
use OCP\ILogger;
34
use OCP\AppFramework\Controller;
35
use OCP\AppFramework\Http;
36
use OCP\AppFramework\Http\DataResponse;
37
38
39
40
use OCA\Polls\Model\Acl;
41
use OCA\Polls\Service\ShareService;
42
43
class ShareController extends Controller {
44
45
	private $logger;
46
	private $shareService;
47
	private $userId;
48
49
	/**
50
	 * ShareController constructor.
51
	 * @param string $appName
52
	 * @param string $userId
53
	 * @param IRequest $request
54
	 * @param ILogger $logger
55
	 * @param ShareService $shareService
56
	 */
57
	public function __construct(
58
		string $appName,
59
		$userId,
60
		IRequest $request,
61
		ILogger $logger,
62
		ShareService $shareService
63
	) {
64
		parent::__construct($appName, $request);
65
		$this->logger = $logger;
66
		$this->userId = $userId;
67
		$this->shareService = $shareService;
68
	}
69
70
	/**
71
	 * Write a new share to the db and returns the new share as array
72
	 * @NoAdminRequired
73
	 * @NoCSRFRequired
74
	 * @param int $pollId
75
	 * @param Array $share
76
	 * @return DataResponse
77
	 */
78
	public function add($pollId, $share) {
79
		try {
80
			$return = $this->shareService->write(
81
				$pollId,
82
				$share['type'],
83
				$share['userId'],
84
				isset($share['userEmail']) ? $share['userEmail'] : ''
85
			);
86
			return new DataResponse($return, Http::STATUS_CREATED);
87
		} catch (NotAuthorizedException $e) {
88
			return new DataResponse(['error' => $e->getMessage()], $e->getStatus());
89
		} catch (\Exception $e) {
90
			return new DataResponse($e, Http::STATUS_CONFLICT);
91
		}
92
93
	}
94
95
	/**
96
	 * createPersonalShare
97
	 * Write a new share to the db and returns the new share as array
98
	 * @NoAdminRequired
99
	 * @PublicPage
100
	 * @NoCSRFRequired
101
	 * @param string $token
102
	 * @param string $userName
103
	 * @return DataResponse
104
	 */
105
	public function createPersonalShare($token, $userName) {
106
107
		try {
108
			return new DataResponse($this->shareService->createPersonalShare($token, $userName), Http::STATUS_CREATED);
109
		} catch (NotAuthorizedException $e) {
110
			return new DataResponse(['error' => $e->getMessage()], $e->getStatus());
111
		} catch (InvalidUsername $e) {
112
			return new DataResponse(['error' => $userName . ' is not valid'], Http::STATUS_CONFLICT);
113
		} catch (DoesNotExistException $e) {
114
			// return forbidden in all not catched error cases
115
			return new DataResponse($e, Http::STATUS_FORBIDDEN);
116
		}
117
	}
118
119
	/**
120
	 * remove
121
	 * remove share
122
	 * @NoAdminRequired
123
	 * @NoCSRFRequired
124
	 * @param Share $share
125
	 * @return DataResponse
126
	 */
127
128
	public function delete($share) {
129
		try {
130
			return new DataResponse(array(
131
				'action' => 'deleted',
132
				'shareId' => $this->shareService->remove($share['token'])->getId()
133
			), Http::STATUS_OK);
134
		} catch (NotAuthorizedException $e) {
135
			return new DataResponse(['error' => $e->getMessage()], $e->getStatus());
136
		} catch (Exception $e) {
137
			return new DataResponse($e, Http::STATUS_NOT_FOUND);
138
		}
139
	}
140
}
141