Code Coverage |
||||||||||
Lines |
Functions and Methods |
Classes and Traits |
||||||||
Total | |
0.00% |
0 / 20 |
|
0.00% |
0 / 1 |
CRAP | |
0.00% |
0 / 1 |
UseraccountByRoleAndDepartmentList | |
0.00% |
0 / 20 |
|
0.00% |
0 / 1 |
30 | |
0.00% |
0 / 1 |
readResponse | |
0.00% |
0 / 20 |
|
0.00% |
0 / 1 |
30 |
1 | <?php |
2 | |
3 | /** |
4 | * @package ZMS API |
5 | * @copyright BerlinOnline Stadtportal GmbH & Co. KG |
6 | **/ |
7 | |
8 | namespace BO\Zmsapi; |
9 | |
10 | use BO\Mellon\Validator; |
11 | use BO\Slim\Render; |
12 | use BO\Zmsdb\Useraccount; |
13 | use BO\Zmsentities\Collection\UseraccountList as Collection; |
14 | use Psr\Http\Message\RequestInterface; |
15 | use Psr\Http\Message\ResponseInterface; |
16 | |
17 | class UseraccountByRoleAndDepartmentList extends BaseController |
18 | { |
19 | /** |
20 | * @SuppressWarnings(Param) |
21 | * @return String |
22 | */ |
23 | public function readResponse( |
24 | RequestInterface $request, |
25 | ResponseInterface $response, |
26 | array $args |
27 | ) { |
28 | $roleLevel = $args['level']; |
29 | $workstation = (new Helper\User($request, 2))->checkRights('useraccount'); |
30 | $resolveReferences = Validator::param('resolveReferences')->isNumber()->setDefault(1)->getValue(); |
31 | $department = Helper\User::checkDepartment($args['id']); |
32 | |
33 | /** @var Useraccount $useraccount */ |
34 | $useraccountList = new Collection(); |
35 | $useraccountList = (new Useraccount())->readListByRoleAndDepartment($roleLevel, $department->id, $resolveReferences)->withLessData(); |
36 | $useraccountList = $useraccountList->withAccessByWorkstation($workstation); |
37 | |
38 | if (! $useraccountList or count($useraccountList) === 0) { |
39 | throw new \BO\Zmsapi\Exception\Useraccount\UserRoleNotFoundAtDepartment(); |
40 | } |
41 | |
42 | $validUserAccounts = []; |
43 | foreach ($useraccountList as $useraccount) { |
44 | try { |
45 | Helper\User::testWorkstationAccessRights($useraccount); |
46 | $validUserAccounts[] = $useraccount; |
47 | } catch (\BO\Zmsentities\Exception\UserAccountAccessRightsFailed $e) { |
48 | continue; |
49 | } |
50 | } |
51 | $useraccountList = $validUserAccounts; |
52 | |
53 | $message = Response\Message::create($request); |
54 | $message->data = $useraccountList; |
55 | |
56 | $response = Render::withLastModified($response, time(), '0'); |
57 | return Render::withJson($response, $message, 200); |
58 | } |
59 | } |