Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
86.36% covered (warning)
86.36%
19 / 22
0.00% covered (danger)
0.00%
0 / 1
CRAP
0.00% covered (danger)
0.00%
0 / 1
UseraccountListByRoleAndDepartments
86.36% covered (warning)
86.36%
19 / 22
0.00% covered (danger)
0.00%
0 / 1
3.02
0.00% covered (danger)
0.00%
0 / 1
 readResponse
86.36% covered (warning)
86.36%
19 / 22
0.00% covered (danger)
0.00%
0 / 1
3.02
1<?php
2
3/**
4 * @package ZMS API
5 * @copyright BerlinOnline Stadtportal GmbH & Co. KG
6 **/
7
8namespace BO\Zmsapi;
9
10use BO\Slim\Render;
11use BO\Zmsdb\Useraccount;
12use Psr\Http\Message\RequestInterface;
13use Psr\Http\Message\ResponseInterface;
14
15class UseraccountListByRoleAndDepartments extends BaseController
16{
17    /**
18     * @SuppressWarnings(Param)
19     * @return \Psr\Http\Message\ResponseInterface
20     */
21    #[\Override]
22    public function readResponse(
23        RequestInterface $request,
24        ResponseInterface $response,
25        array $args
26    ) {
27        $roleName = $args['roleName'];
28        $workstation = (new Helper\User($request, 2))->checkPermissions('useraccount');
29
30        $rawIds = array_map('trim', explode(',', $args['ids']));
31        $rawIds = array_filter($rawIds, 'strlen');
32        $requestedDepartmentIds = Helper\User::normalizeDepartmentIds($rawIds);
33
34        $departmentIds = [];
35        if ($workstation->getUseraccount()->isSuperUser()) {
36            // Superusers can access all departments; no need to validate via DB here
37            $departmentIds = $requestedDepartmentIds;
38        } else {
39            // Non-superusers must go through Helper\User::checkDepartments for access checks
40            $departments = Helper\User::checkDepartments($requestedDepartmentIds);
41            foreach ($departments as $department) {
42                $departmentIds[] = $department->id;
43            }
44        }
45
46        $useraccountList = (new Useraccount())->readListByRoleAndDepartmentIds(
47            $roleName,
48            $departmentIds,
49            0,
50            false,
51            $workstation
52        );
53
54        $message = Response\Message::create($request);
55        $message->data = $useraccountList;
56
57        $response = Render::withLastModified($response, time(), '0');
58        return Render::withJson($response, $message, 200);
59    }
60}