Issues (25)

src/AppBundle/Controller/FriendshipsController.php (1 issue)

Labels
Severity
1
<?php
2
3
/**
4
 * Donut Social Network - Yet another experimental social network.
5
 * Copyright (C) 2016-2018, Dejan Angelov <[email protected]>
6
 *
7
 * This file is part of Donut Social Network.
8
 *
9
 * Donut Social Network is free software: you can redistribute it and/or modify
10
 * it under the terms of the GNU General Public License as published by
11
 * the Free Software Foundation, either version 3 of the License, or
12
 * (at your option) any later version.
13
 *
14
 * Donut Social Network is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU General Public License
20
 * along with Donut Social Network.  If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 * @package Donut Social Network
23
 * @copyright Copyright (C) 2016-2018, Dejan Angelov <[email protected]>
24
 * @license https://github.com/angelov/donut/blob/master/LICENSE
25
 * @author Dejan Angelov <[email protected]>
26
 */
27
28
namespace AppBundle\Controller;
29
30
use Angelov\Donut\Core\CommandBus\CommandBusInterface;
31
use Angelov\Donut\Friendships\Commands\DeleteFriendshipCommand;
32
use Angelov\Donut\Friendships\Friendship;
33
use Angelov\Donut\Users\User;
34
use Doctrine\ORM\EntityManagerInterface;
35
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
36
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
37
use Symfony\Component\HttpFoundation\Response;
38
39
class FriendshipsController extends AbstractController
40
{
41
    private $commandBus;
42
43
    public function __construct(CommandBusInterface $commandBus)
44
    {
45
        $this->commandBus = $commandBus;
46
    }
47
48
    /**
49
     * @Route("/friendships/remove/{id}", name="app.friendships.remove", methods={"GET"})
50
     * @todo fix to use delete requests
51
     */
52
    public function delete(User $user, EntityManagerInterface $em) : Response
53
    {
54
        // @todo use custom repository
55
        $repository = $em->getRepository(Friendship::class);
56
57
        if (! $user->isFriendWith($this->getUser())) {
0 ignored issues
show
It seems like $this->getUser() can also be of type null; however, parameter $user of Angelov\Donut\Users\User::isFriendWith() does only seem to accept Angelov\Donut\Users\User, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

57
        if (! $user->isFriendWith(/** @scrutinizer ignore-type */ $this->getUser())) {
Loading history...
58
            $this->addFlash('error', 'Can\'t broke a nonexisting friendship.');
59
60
            return $this->redirectToRoute('app.friends.index');
61
        }
62
63
        $friendship = $repository->findOneBy([
64
            'user' => $this->getUser(),
65
            'friend' => $user
66
        ]);
67
68
        $this->commandBus->handle(new DeleteFriendshipCommand($friendship->getId()));
69
70
        $this->addFlash('success', 'Sorry to see broken friendships.');
71
72
        return $this->redirectToRoute('app.friends.index');
73
    }
74
}
75