diff --git a/src/core/Resources/maker/controller/CrudController.tpl.php b/src/core/Resources/maker/controller/CrudController.tpl.php index d4ff92b..43387d0 100644 --- a/src/core/Resources/maker/controller/CrudController.tpl.php +++ b/src/core/Resources/maker/controller/CrudController.tpl.php @@ -15,58 +15,65 @@ use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\HttpFoundation\Session\Session; use Symfony\Component\Routing\Annotation\Route; +use Symfony\Component\Security\Http\Attribute\IsGranted; class extends CrudController { - #[Route(path: "/admin//{page}", name: "admin__index", methods: ['GET'], requirements: ['page' => '\d+'])] + protected ?CrudConfiguration $configuration = null; + + #[Route(path: '/admin//{page}', name: 'admin__index', methods: ['GET'], requirements: ['page' => '\d+'])] public function index(RepositoryQuery $query, Request $request, Session $session, int $page = 1): Response { return $this->doIndex($page, $query, $request, $session); } - #[Route(path: "/admin//new", name: "admin__new", methods: ['GET', 'POST'])] + #[Route(path: '/admin//new', name: 'admin__new', methods: ['GET', 'POST'])] public function new(Factory $factory, EntityManager $entityManager, Request $request): Response { return $this->doNew($factory->create(), $entityManager, $request); } - #[Route(path: "/admin//show/{entity}", name: "admin__show", methods: ['GET'])] + #[Route(path: '/admin//show/{entity}', name: 'admin__show', methods: ['GET'])] + #[IsGranted('show', 'entity')] public function show(Entity $entity): Response { return $this->doShow($entity); } - #[Route(path: "/admin//filter", name: "admin__filter", methods: ['GET'])] + #[Route(path: '/admin//filter', name: 'admin__filter', methods: ['GET'])] public function filter(Session $session): Response { return $this->doFilter($session); } - #[Route(path: "/admin//edit/{entity}", name: "admin__edit", methods: ['GET', 'POST'])] + #[Route(path: '/admin//edit/{entity}', name: 'admin__edit', methods: ['GET', 'POST'])] + #[IsGranted('edit', 'entity')] public function edit(Entity $entity, EntityManager $entityManager, Request $request): Response { return $this->doEdit($entity, $entityManager, $request); } - #[Route(path: "/admin//inline_edit/{entity}/{context}/{label}", name: 'admin__inline_edit', methods: ['GET', 'POST'])] + #[Route(path: '/admin//inline_edit/{entity}/{context}/{label}', name: 'admin__inline_edit', methods: ['GET', 'POST'])] + #[IsGranted('edit', 'entity')] public function inlineEdit(string $context, string $label, Entity $entity, EntityManager $entityManager, Request $request): Response { return $this->doInlineEdit($context, $label, $entity, $entityManager, $request); } - #[Route(path: "/admin//sort/{page}", name: "admin__sort", methods: ['POST'], requirements: ['page' => '\d+'])] + #[Route(path: '/admin//sort/{page}', name: 'admin__sort', methods: ['POST'], requirements: ['page' => '\d+'])] public function sort(RepositoryQuery $query, EntityManager $entityManager, Request $request, Session $session, int $page = 1): Response { return $this->doSort($page, $query, $entityManager, $request, $session); } - #[Route(path: "/admin//batch/{page}", name: "admin__batch", methods: ['POST'], requirements: ['page' => '\d+'])] + #[Route(path: '/admin//batch/{page}', name: 'admin__batch', methods: ['POST'], requirements: ['page' => '\d+'])] public function batch(RepositoryQuery $query, EntityManager $entityManager, Request $request, Session $session, int $page = 1): Response { return $this->doBatch($page, $query, $entityManager, $request, $session); } - #[Route(path: "/admin//delete/{entity}", name: "admin__delete", methods: ['DELETE', 'POST'])] + #[Route(path: '/admin//delete/{entity}', name: 'admin__delete', methods: ['DELETE', 'POST'])] + #[IsGranted('delete', 'entity')] public function delete(Entity $entity, EntityManager $entityManager, Request $request): Response { return $this->doDelete($entity, $entityManager, $request); @@ -74,7 +81,11 @@ class extends CrudController protected function getConfiguration(): CrudConfiguration { - return CrudConfiguration::create() + if ($this->configuration) { + return $this->configuration; + } + + return $this->configuration = CrudConfiguration::create() ->setPageTitle('index', 'List of ') ->setPageTitle('edit', 'Edition of {id}') ->setPageTitle('new', 'New ')