Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 21
0.00% covered (danger)
0.00%
0 / 1
CRAP
0.00% covered (danger)
0.00%
0 / 1
CreateRoleEndpoint
0.00% covered (danger)
0.00%
0 / 21
0.00% covered (danger)
0.00%
0 / 1
20
0.00% covered (danger)
0.00%
0 / 1
 handle
0.00% covered (danger)
0.00%
0 / 21
0.00% covered (danger)
0.00%
0 / 1
20
1<?php
2
3namespace Olz\Roles\Endpoints;
4
5use Olz\Api\OlzCreateEntityTypedEndpoint;
6use Olz\Entity\Roles\Role;
7use Olz\Entity\Users\User;
8use PhpTypeScriptApi\HttpError;
9
10/**
11 * @phpstan-import-type OlzRoleId from RoleEndpointTrait
12 * @phpstan-import-type OlzRoleData from RoleEndpointTrait
13 *
14 * @extends OlzCreateEntityTypedEndpoint<OlzRoleId, OlzRoleData>
15 */
16class CreateRoleEndpoint extends OlzCreateEntityTypedEndpoint {
17    use RoleEndpointTrait;
18
19    protected function handle(mixed $input): mixed {
20        $parent_role = $input['data']['parentRole'] ?? null;
21        if (!$this->authUtils()->hasRoleEditPermission($parent_role)) {
22            throw new HttpError(403, "Kein Zugriff!");
23        }
24
25        $user_repo = $this->entityManager()->getRepository(User::class);
26        $role_repo = $this->entityManager()->getRepository(Role::class);
27
28        // Username validation
29        $new_username = $input['data']['username'];
30        if (!$this->authUtils()->isUsernameAllowed($new_username)) {
31            throw HttpError::validationError(['username' => ["Der Benutzername darf nur Buchstaben, Zahlen, und die Zeichen -_. enthalten."]]);
32        }
33        if (!$this->authUtils()->isUsernameUnique($new_username, null)) {
34            throw HttpError::validationError(['username' => ["Dieser Benutzername ist bereits vergeben."]]);
35        }
36
37        $entity = new Role();
38        $this->entityUtils()->createOlzEntity($entity, $input['meta']);
39        $entity->setOldUsername(null);
40        $entity->setPermissions('');
41        $this->updateEntityWithData($entity, $input['data']);
42
43        $this->entityManager()->persist($entity);
44        $this->entityManager()->flush();
45        $this->persistUploads($entity, $input['data']);
46
47        return [
48            'id' => $entity->getId() ?? 0,
49        ];
50    }
51}