Ojs\JournalBundle\Controller\JournalAnnouncementController::deleteAction PHP Метод

deleteAction() публичный Метод

public deleteAction ( Request $request, integer $id ) : RedirectResponse
$request Symfony\Component\HttpFoundation\Request
$id integer
Результат Symfony\Component\HttpFoundation\RedirectResponse
    public function deleteAction(Request $request, $id)
    {
        $journal = $this->get('ojs.journal_service')->getSelectedJournal();
        $eventDispatcher = $this->get('event_dispatcher');
        /** @var JournalAnnouncement $entity */
        $entity = $this->getDoctrine()->getRepository('OjsJournalBundle:JournalAnnouncement')->find($id);
        $this->throw404IfNotFound($entity);
        if (!$this->isGranted('DELETE', $journal, 'announcements')) {
            throw new AccessDeniedException("You are not authorized for this page!");
        }
        $em = $this->getDoctrine()->getManager();
        $csrf = $this->get('security.csrf.token_manager');
        $token = $csrf->getToken('ojs_journal_announcement' . $entity->getId());
        if ($token != $request->get('_token')) {
            throw new TokenNotFoundException("Token not found!");
        }
        $this->get('ojs_core.delete.service')->check($entity);
        $event = new JournalItemEvent($entity);
        $eventDispatcher->dispatch(JournalAnnouncementEvents::PRE_DELETE, $event);
        $em->remove($entity);
        $em->flush();
        $event = new JournalEvent($journal);
        $eventDispatcher->dispatch(JournalAnnouncementEvents::POST_DELETE, $event);
        if ($event->getResponse()) {
            return $event->getResponse();
        }
        $this->successFlashBag('successful.remove');
        return $this->redirectToRoute('ojs_journal_announcement_index', ['journalId' => $journal->getId()]);
    }