Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
92.86% covered (success)
92.86%
13 / 14
0.00% covered (danger)
0.00%
0 / 1
CRAP
0.00% covered (danger)
0.00%
0 / 1
EditTerminEndpoint
92.86% covered (success)
92.86%
13 / 14
0.00% covered (danger)
0.00%
0 / 1
4.01
0.00% covered (danger)
0.00%
0 / 1
 handle
92.86% covered (success)
92.86%
13 / 14
0.00% covered (danger)
0.00%
0 / 1
4.01
1<?php
2
3namespace Olz\Termine\Endpoints;
4
5use Olz\Api\OlzEditEntityTypedEndpoint;
6use PhpTypeScriptApi\HttpError;
7
8/**
9 * @phpstan-import-type OlzTerminId from TerminEndpointTrait
10 * @phpstan-import-type OlzTerminData from TerminEndpointTrait
11 *
12 * @extends OlzEditEntityTypedEndpoint<OlzTerminId, OlzTerminData>
13 */
14class EditTerminEndpoint extends OlzEditEntityTypedEndpoint {
15    use TerminEndpointTrait;
16
17    protected function handle(mixed $input): mixed {
18        $this->checkPermission('any');
19
20        $entity = $this->getEntityById($input['id']);
21
22        $current_user = $this->authUtils()->getCurrentUser();
23        $organizer_user = $entity->getOrganizerUser();
24        $is_organizer = ($organizer_user && $current_user?->getId() === $organizer_user->getId());
25
26        if (
27            !$this->entityUtils()->canUpdateOlzEntity($entity, null, 'termine_admin')
28            && !$is_organizer
29        ) {
30            throw new HttpError(403, "Kein Zugriff!");
31        }
32
33        $this->editUploads($entity);
34
35        return [
36            'id' => $entity->getId() ?? 0,
37            'meta' => $entity->getMetaData(),
38            'data' => $this->getEntityData($entity),
39        ];
40    }
41}