![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/app/bundles/CategoryBundle/Controller/Api/ |
<?php namespace Mautic\CategoryBundle\Controller\Api; use Doctrine\Persistence\ManagerRegistry; use Mautic\ApiBundle\Controller\CommonApiController; use Mautic\ApiBundle\Helper\EntityResultHelper; use Mautic\CategoryBundle\Entity\Category; use Mautic\CategoryBundle\Model\CategoryModel; use Mautic\CoreBundle\Factory\MauticFactory; use Mautic\CoreBundle\Factory\ModelFactory; use Mautic\CoreBundle\Helper\AppVersion; use Mautic\CoreBundle\Helper\CoreParametersHelper; use Mautic\CoreBundle\Security\Permissions\CorePermissions; use Mautic\CoreBundle\Translation\Translator; use Symfony\Component\EventDispatcher\EventDispatcherInterface; use Symfony\Component\Form\FormFactoryInterface; use Symfony\Component\HttpFoundation\RequestStack; use Symfony\Component\Routing\RouterInterface; /** * @extends CommonApiController<Category> */ class CategoryApiController extends CommonApiController { public function __construct(CorePermissions $security, Translator $translator, EntityResultHelper $entityResultHelper, RouterInterface $router, FormFactoryInterface $formFactory, AppVersion $appVersion, RequestStack $requestStack, ManagerRegistry $doctrine, ModelFactory $modelFactory, EventDispatcherInterface $dispatcher, CoreParametersHelper $coreParametersHelper, MauticFactory $factory) { $categoryModel = $modelFactory->getModel('category'); \assert($categoryModel instanceof CategoryModel); $this->model = $categoryModel; $this->entityClass = Category::class; $this->entityNameOne = 'category'; $this->entityNameMulti = 'categories'; $this->serializerGroups = ['categoryDetails']; parent::__construct($security, $translator, $entityResultHelper, $router, $formFactory, $appVersion, $requestStack, $doctrine, $modelFactory, $dispatcher, $coreParametersHelper, $factory); } /** * Checks if user has permission to access retrieved entity. * * @param Category $entity * @param string $action view|create|edit|publish|delete * * @return bool */ protected function checkEntityAccess($entity, $action = 'view') { if (!$bundle = $entity->getBundle()) { $bundle = 'category'; } $permissionBase = $this->permissionBase; if ($this->security->checkPermissionExists($bundle.':categories:'.$action)) { // An entity specific category permission rule exists $permissionBase = $bundle.':categories'; } if ('create' != $action) { $ownPerm = "$permissionBase:{$action}own"; $otherPerm = "$permissionBase:{$action}other"; return $this->security->hasEntityAccess($ownPerm, $otherPerm, $entity->getCreatedBy()); } return $this->security->isGranted("$permissionBase:create"); } /** * @return array<string, mixed> */ protected function getEntityFormOptions(): array { return ['show_bundle_select' => true]; } }