*/ class DeviceApiController extends CommonApiController { use LeadAccessTrait; 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) { $leadDeviceModel = $modelFactory->getModel('lead.device'); \assert($leadDeviceModel instanceof DeviceModel); $this->model = $leadDeviceModel; $this->entityClass = LeadDevice::class; $this->entityNameOne = 'device'; $this->entityNameMulti = 'devices'; parent::__construct($security, $translator, $entityResultHelper, $router, $formFactory, $appVersion, $requestStack, $doctrine, $modelFactory, $dispatcher, $coreParametersHelper, $factory); } /** * @param LeadDevice &$entity * @param string $action */ protected function preSaveEntity(&$entity, $form, $parameters, $action = 'edit') { $lead = null; if (!empty($parameters['lead'])) { $lead = $parameters['lead']; } elseif (!empty($parameters['contact'])) { $lead = $parameters['contact']; } if ($lead) { $lead = $this->checkLeadAccess($lead, $action); if ($lead instanceof Response) { return $lead; } $entity->setLead($lead); unset($parameters['lead'], $parameters['contact']); } elseif ('new' === $action) { return $this->returnError('contact ID is mandatory', Response::HTTP_BAD_REQUEST); } } protected function checkEntityAccess($entity, $action = 'view') { return parent::checkEntityAccess($entity->getLead(), $action); } }