<?php
namespace Webkul\UVDesk\CoreFrameworkBundle\Controller;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpFoundation\JsonResponse;
use Symfony\Component\EventDispatcher\GenericEvent;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\Security\Core\Encoder\UserPasswordEncoderInterface;
use Symfony\Component\EventDispatcher\EventDispatcherInterface;
use Symfony\Contracts\Translation\TranslatorInterface;
use Symfony\Component\Filesystem\Filesystem as Fileservice;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Webkul\UVDesk\CoreFrameworkBundle\Entity\User;
use Webkul\UVDesk\CoreFrameworkBundle\Entity\SavedFilters;
use Webkul\UVDesk\CoreFrameworkBundle\Workflow\Events as CoreWorkflowEvents;
use Webkul\UVDesk\CoreFrameworkBundle\Services\UserService;
class AccountXHR extends AbstractController
{
private $eventDispatcher;
private $translator;
private $userService;
public function __construct(UserService $userService, EventDispatcherInterface $eventDispatcher, TranslatorInterface $translator)
{
$this->eventDispatcher = $eventDispatcher;
$this->translator = $translator;
$this->userService = $userService;
}
public function listAgentsXHR(Request $request, ContainerInterface $container)
{
if (!$this->userService->isAccessAuthorized('ROLE_AGENT_MANAGE_AGENT')) {
return $this->redirect($this->generateUrl('helpdesk_member_dashboard'));
}
if (true === $request->isXmlHttpRequest()) {
$userRepository = $this->getDoctrine()->getRepository(User::class);
$agentCollection = $userRepository->getAllAgents($request->query, $container);
return new Response(json_encode($agentCollection), 200, ['Content-Type' => 'application/json']);
}
return new Response(json_encode([]), 404);
}
public function deleteAgent(Request $request)
{
if ($request->getMethod() != "DELETE") {
return new JsonResponse([
'alertClass' => 'warning',
'alertMessage' => $this->translator->trans("How did you land here?"),
], 404);
}
$id = $request->query->get('id');
$entityManager = $this->getDoctrine()->getManager();
/*
Original Code: $user = $em->getRepository('WebkulUserBundle:User')->findUserByCompany($id,$company->getId());
Using findUserByCompany() won't execute the UserListener, so user roles won't be set and user with ROLE_SUPER_ADMIN can be deleted as a result.
To trigger UserListener to set roles, you need to only select 'u' instead of both 'u, dt' in query select clause.
Doing this here instead of directly making changes to userRepository->findUserByCompany().
*/
$user = $entityManager->createQueryBuilder()
->select('u')
->from(User::class, 'u')
->leftJoin('u.userInstance', 'userInstance')
->where('u.id = :userId')->setParameter('userId', $id)
->andWhere('userInstance.supportRole != :roles')->setParameter('roles', 4)
->getQuery()
->getOneOrNullResult()
;
if ($user) {
if ($user->getAgentInstance()->getSupportRole() != "ROLE_SUPER_ADMIN") {
// Trigger agent delete event
$event = new CoreWorkflowEvents\Agent\Delete();
$event
->setUser($user)
;
$this->eventDispatcher->dispatch($event, 'uvdesk.automation.workflow.execute');
// Removing profile image from physical path
$fileService = new Fileservice;
if ($user->getAgentInstance()->getProfileImagePath()) {
$fileService->remove($this->getParameter('kernel.project_dir'). '/public' . $user->getAgentInstance()->getProfileImagePath());
}
$this->userService->removeAgent($user);
$json['alertClass'] = 'success';
$json['alertMessage'] = $this->translator->trans('Success ! Agent removed successfully.');
} else {
$json['alertClass'] = 'warning';
$json['alertMessage'] = $this->translator->trans("Warning ! You are allowed to remove account owner's account.");
}
} else {
$json['alertClass'] = 'danger';
$json['alertMessage'] = $this->translator->trans('Error ! Invalid user id.');
}
return new JsonResponse($json);
}
public function savedFiltersXHR(Request $request)
{
$json = array();
$em = $this->getDoctrine()->getManager();
$user = $this->userService->getCurrentUser();
$userData = $user->getAgentInstance();
if($request->getMethod() == 'POST') {
$content = $request->request->all();
$filter = new SavedFilters();
$filter->setName($content['name']);
$filter->setRoute($content['route']);
$filter->setUser($userData);
$em->persist($filter);
$em->flush();
if(isset($content['is_default'])) {
$userData->setDefaultFiltering($filter->getId());
$em->persist($userData);
$em->flush();
}
$json['filter'] = ['id' => $filter->getId(), 'name' => $filter->getName(), 'route' => $filter->getRoute(), 'is_default' => isset($content['is_default'])];
$json['alertClass'] = 'success';
$json['alertMessage'] = $this->translator->trans('Success ! Filter has been saved successfully.');
} elseif($request->getMethod() == 'PUT' || $request->getMethod() == 'PATCH') {
$content = $request->request->all();
$filter = $em->getRepository(SavedFilters::class)->find($content['id']);
$filter->setName($content['name']);
$filter->setRoute($content['route']);
$em->flush();
if(isset($content['is_default']))
$userData->setDefaultFiltering($filter->getId());
elseif($filter->getId() == $userData->getDefaultFiltering())
$userData->setDefaultFiltering(0);
$em->persist($userData);
$em->flush();
$json['filter'] = ['id' => $filter->getId(), 'name' => $filter->getName(), 'route' => $filter->getRoute(), 'is_default' => isset($content['is_default']) ? 1 : 0 ];
$json['alertClass'] = 'success';
$json['alertMessage'] = $this->translator->trans('Success ! Filter has been updated successfully.');
} elseif($request->getMethod() == 'DELETE') {
$id = $request->attributes->get('filterId');
$filter = $em->getRepository(SavedFilters::class)->find($id);
$em->remove($filter);
$em->flush();
// if($id == $userData->getDefaultFiltering())
// $userData->setDefaultFiltering(0);
// $em->persist($userData);
// $em->flush();
$json['alertClass'] = 'success';
$json['alertMessage'] = $this->translator->trans('Success ! Filter has been removed successfully.');
}
$response = new Response(json_encode($json));
$response->headers->set('Content-Type', 'application/json');
return $response;
}
}