DeleteImageController::__construct()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 1
dl 0
loc 3
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 1
1
<?php
2
3
namespace App\Controller\Media;
4
5
use App\Entity\Image;
6
use App\Event\Image\ImageDeleteEvent;
7
use App\Exception\RedirectException;
8
use Sensio\Bundle\FrameworkExtraBundle\Configuration\IsGranted;
9
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
10
use Symfony\Component\EventDispatcher\EventDispatcherInterface;
11
use Symfony\Component\HttpFoundation\RedirectResponse;
12
use Symfony\Component\HttpFoundation\Request;
13
use Symfony\Component\Routing\Annotation\Route;
14
15
/**
16
 * Class DeleteImageController
17
 * @package App\Controller\Image
18
 * @IsGranted("ROLE_USER")
19
 */
20
class DeleteImageController extends AbstractController
21
{
22
23
    /**
24
     * @var EventDispatcherInterface
25
     */
26
    private $dispatcher;
27
28
    public function __construct(EventDispatcherInterface $dispatcher)
29
    {
30
        $this->dispatcher = $dispatcher;
31
    }
32
33
    /**
34
     * @Route("/image/delete/{id}", name="image.deleteFromTrick", methods={"POST"})
35
     * @param Image $image
36
     * @param Request $request
37
     * @return RedirectResponse
38
     */
39
    public function deleteTrickImage(Image $image, Request $request)
40
    {
41
        $submittedToken = $request->request->get('_token');
42
        if (!$this->isCsrfTokenValid('delete-image' . $image->getId(), $submittedToken)) {
43
            throw new RedirectException($this->generateUrl('home'), 'Bad CSRF Token');
44
        }
45
46
        $trick = $image->getTrick();
47
        if ($trick !== null){
48
            $event = new ImageDeleteEvent($image, $trick);
49
            $this->dispatcher->dispatch(ImageDeleteEvent::NAME, $event);
50
        }
51
52
        return $this->redirectToRoute('trick.edit', [
53
            'id' => $trick->getId(),
54
        ]);
55
    }
56
}