Spaces:
No application file
No application file
namespace Mautic\LeadBundle\Controller\Api; | |
use Doctrine\Persistence\ManagerRegistry; | |
use Mautic\ApiBundle\Controller\CommonApiController; | |
use Mautic\ApiBundle\Helper\EntityResultHelper; | |
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 Mautic\LeadBundle\Controller\LeadAccessTrait; | |
use Mautic\LeadBundle\Entity\Company; | |
use Mautic\LeadBundle\Entity\Lead; | |
use Mautic\LeadBundle\Helper\IdentifyCompanyHelper; | |
use Mautic\LeadBundle\Model\CompanyModel; | |
use Symfony\Component\EventDispatcher\EventDispatcherInterface; | |
use Symfony\Component\Form\FormFactoryInterface; | |
use Symfony\Component\HttpFoundation\Request; | |
use Symfony\Component\HttpFoundation\RequestStack; | |
use Symfony\Component\HttpFoundation\Response; | |
use Symfony\Component\Routing\RouterInterface; | |
/** | |
* @extends CommonApiController<Company> | |
*/ | |
class CompanyApiController extends CommonApiController | |
{ | |
use CustomFieldsApiControllerTrait; | |
use LeadAccessTrait; | |
/** | |
* @var CompanyModel|null | |
*/ | |
protected $model; | |
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) | |
{ | |
$companyModel = $modelFactory->getModel('lead.company'); | |
\assert($companyModel instanceof CompanyModel); | |
$this->model = $companyModel; | |
$this->entityClass = Company::class; | |
$this->entityNameOne = 'company'; | |
$this->entityNameMulti = 'companies'; | |
$this->serializerGroups[] = 'companyDetails'; | |
parent::__construct($security, $translator, $entityResultHelper, $router, $formFactory, $appVersion, $requestStack, $doctrine, $modelFactory, $dispatcher, $coreParametersHelper, $factory); | |
$this->setCleaningRules('company'); | |
} | |
/** | |
* If an existing company is matched, it'll be merged. Otherwise it'll be created. | |
* | |
* @return Response | |
*/ | |
public function newEntityAction(Request $request) | |
{ | |
// Check for an email to see if the lead already exists | |
$parameters = $request->request->all(); | |
if (empty($parameters['force'])) { | |
$leadCompanyModel = $this->getModel('lead.company'); | |
\assert($leadCompanyModel instanceof CompanyModel); | |
[$company, $companyEntities] = IdentifyCompanyHelper::findCompany($parameters, $leadCompanyModel); | |
if (count($companyEntities)) { | |
return $this->editEntityAction($request, $company['id']); | |
} | |
} | |
return parent::newEntityAction($request); | |
} | |
/** | |
* @param Lead &$entity | |
* @param string $action | |
*/ | |
protected function preSaveEntity(&$entity, $form, $parameters, $action = 'edit') | |
{ | |
$this->setCustomFieldValues($entity, $form, $parameters); | |
} | |
/** | |
* Adds a contact to a company. | |
* | |
* @param int $companyId Company ID | |
* @param int $contactId Contact ID | |
* | |
* @return Response | |
* | |
* @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException | |
*/ | |
public function addContactAction($companyId, $contactId) | |
{ | |
$company = $this->model->getEntity($companyId); | |
$view = $this->view(['success' => 1], Response::HTTP_OK); | |
if (null === $company) { | |
return $this->notFound(); | |
} | |
$contact = $this->checkLeadAccess($contactId, 'edit'); | |
if ($contact instanceof Response) { | |
return $contact; | |
} | |
$this->model->addLeadToCompany($company, $contact); | |
return $this->handleView($view); | |
} | |
/** | |
* Removes given contact from a company. | |
* | |
* @param int $companyId List ID | |
* @param int $contactId Lead ID | |
* | |
* @return Response | |
* | |
* @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException | |
*/ | |
public function removeContactAction($companyId, $contactId) | |
{ | |
$company = $this->model->getEntity($companyId); | |
$view = $this->view(['success' => 1], Response::HTTP_OK); | |
if (null === $company) { | |
return $this->notFound(); | |
} | |
$contactModel = $this->getModel('lead'); | |
$contact = $contactModel->getEntity($contactId); | |
// Does the contact exist and the user has permission to edit | |
if (null === $contact) { | |
return $this->notFound(); | |
} elseif (!$this->security->hasEntityAccess('lead:leads:editown', 'lead:leads:editother', $contact->getPermissionUser())) { | |
return $this->accessDenied(); | |
} | |
$this->model->removeLeadFromCompany($company, $contact); | |
return $this->handleView($view); | |
} | |
} | |