aboutsummaryrefslogtreecommitdiff
path: root/lib/classes/JsonApi/Routes/Forum/PostingReactionStore.php
blob: 60e66c011c36ec5432fae2d62cc914b01eba4d09 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
<?php
namespace JsonApi\Routes\Forum;

use JsonApi\Errors\AuthorizationFailedException;
use JsonApi\Errors\BadRequestException;
use JsonApi\Errors\RecordNotFoundException;
use Psr\Http\Message\ServerRequestInterface as Request;
use Psr\Http\Message\ResponseInterface as Response;
use JsonApi\JsonApiController;
use JsonApi\Routes\ValidationTrait;
use Forum\Posting;
use Forum\PostingReaction;

class PostingReactionStore extends JsonApiController
{
    use ValidationTrait;

    protected $allowedIncludePaths = [
        \JsonApi\Schemas\Forum\PostingReaction::REL_USER
    ];

    public function __invoke(Request $request, Response $response, $args)
    {
        $json = $this->validate($request);
        $user = $this->getUser($request);

        $posting = Posting::find(self::arrayGet($json, 'data.relationships.posting.data.id'));
        if (!$posting) {
            throw new BadRequestException();
        }

        $range = get_object_by_range_id($posting->range_id);
        if (!$range) {
            throw new RecordNotFoundException();
        }

        if (!Authority::canShowForum($user, $range)) {
            throw new AuthorizationFailedException();
        }

        $data = [
            'posting_id' => $posting->posting_id,
            'user_id'    => $user->user_id,
            'emoji'      => self::arrayGet($json, 'data.attributes.emoji'),
        ];

        $reaction = PostingReaction::findOneBySQL(
            "posting_id = :posting_id AND user_id = :user_id AND emoji = :emoji",
            $data
        );

        if (!$reaction) {
            $reaction = PostingReaction::create($data);

            if ($user->user_id !== $posting->user_id) {
                \PersonalNotifications::add(
                    $posting->user_id,
                    \URLHelper::getURL(
                        "dispatch.php/course/forum/discussions/show/{$posting->discussion_id}#post_{$posting->posting_id}",
                        ['cid' => $posting->range_id],
                        true
                    ),
                    studip_interpolate(
                        _('%{name} hat auf deinen Beitrag reagiert.'),
                        ['name' => $user->getFullName()]
                    ),
                    null,
                    self::arrayGet($json, 'data.meta.emoji-icon')
                );
            }
        }

        return $this->getCreatedResponse($reaction);
    }

    protected function validateResourceDocument($json, $data)
    {
        $required_keys = [
            'data.attributes.emoji' => 'Missing `data.attributes.emoji`',
            'data.meta.emoji-icon' => 'Missing `data.meta.emoji-icon`',
            'data.relationships.posting.data.id' => 'Missing `data.relationships.posting.data.id`',
        ];

        foreach ($required_keys as $key => $error_message) {
            if (!self::arrayHas($json, $key)) {
                return $error_message;
            }
        }

        return null;
    }
}