Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
100.00% covered (success)
100.00%
9 / 9
100.00% covered (success)
100.00%
2 / 2
CRAP
100.00% covered (success)
100.00%
1 / 1
ListUsersAction
100.00% covered (success)
100.00%
9 / 9
100.00% covered (success)
100.00%
2 / 2
4
100.00% covered (success)
100.00%
1 / 1
 __construct
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 __invoke
100.00% covered (success)
100.00%
8 / 8
100.00% covered (success)
100.00%
1 / 1
3
1<?php
2
3declare(strict_types=1);
4
5namespace App\Action\SuperAdmin;
6
7use App\Domain\Auth\Data\UserAuthData;
8use App\Domain\Exception\ForbiddenException;
9use App\Domain\SuperAdmin\Repository\SuperAdminRepository;
10use App\Renderer\JsonRenderer;
11use Psr\Http\Message\ResponseInterface;
12use Psr\Http\Message\ServerRequestInterface;
13
14/**
15 * List all users with their roles for user management.
16 */
17final readonly class ListUsersAction
18{
19    public function __construct(
20        private JsonRenderer $renderer,
21        private SuperAdminRepository $repository,
22    ) {}
23
24    public function __invoke(ServerRequestInterface $request, ResponseInterface $response): ResponseInterface
25    {
26        $user = $request->getAttribute('user');
27        if (!$user instanceof UserAuthData || $user->role !== 'super_admin') {
28            throw new ForbiddenException('Super admin access required');
29        }
30
31        $users = $this->repository->getAllUsers();
32
33        return $this->renderer->json($response, [
34            'success' => true,
35            'data' => ['users' => $users],
36        ]);
37    }
38}