2018-06-28 19:22:00 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Controller;
|
|
|
|
|
2020-07-01 23:12:49 +00:00
|
|
|
use App\Entity\ApiToken;
|
2018-06-28 19:22:00 +00:00
|
|
|
use App\Entity\User;
|
2020-07-01 23:12:49 +00:00
|
|
|
use App\Repository\ApiTokenRepository;
|
2018-06-28 19:22:00 +00:00
|
|
|
use App\Repository\InviteRepository;
|
2020-07-01 23:12:49 +00:00
|
|
|
use Doctrine\ORM\EntityManagerInterface;
|
2019-01-18 17:27:38 +00:00
|
|
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
2018-06-28 19:22:00 +00:00
|
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
|
|
|
2019-01-18 17:27:38 +00:00
|
|
|
class AccountController extends AbstractController
|
2018-06-28 19:22:00 +00:00
|
|
|
{
|
2020-07-01 23:12:49 +00:00
|
|
|
public function account(InviteRepository $inviteRepo, ApiTokenRepository $apiTokenRepo): Response
|
2018-06-28 19:22:00 +00:00
|
|
|
{
|
|
|
|
/** @var User $user */
|
|
|
|
if (null === $user = $this->getUser()) {
|
|
|
|
throw $this->createAccessDeniedException('User not found exception');
|
|
|
|
}
|
|
|
|
|
2020-07-01 23:12:49 +00:00
|
|
|
return $this->render(
|
|
|
|
'Account/account.html.twig', [
|
2018-06-28 19:22:00 +00:00
|
|
|
'invites' => $inviteRepo->findInvitesByUser($user),
|
2020-07-01 23:12:49 +00:00
|
|
|
'tokens' => $apiTokenRepo->findBy(['user' => $user->getId()]),
|
|
|
|
'user' => $user,
|
2018-06-28 19:22:00 +00:00
|
|
|
]);
|
|
|
|
}
|
2020-07-01 23:12:49 +00:00
|
|
|
|
|
|
|
public function addApiToken(EntityManagerInterface $em): Response
|
|
|
|
{
|
|
|
|
/** @var User|null $user */
|
|
|
|
if (null === $user = $this->getUser()) {
|
|
|
|
throw $this->createAccessDeniedException();
|
|
|
|
}
|
|
|
|
|
|
|
|
$token = new ApiToken($user);
|
|
|
|
$em->persist($token);
|
|
|
|
$em->flush();
|
|
|
|
|
|
|
|
$this->addFlash('success', 'API token created.');
|
|
|
|
|
|
|
|
return $this->redirectToRoute('user_account');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function revokeApiToken(string $key, ApiTokenRepository $repo, EntityManagerInterface $em): Response
|
|
|
|
{
|
|
|
|
$token = $repo->findOneBy(['key' => $key]);
|
|
|
|
|
|
|
|
if (null === $token || $token->getUser() !== $this->getUser()) {
|
|
|
|
throw $this->createNotFoundException('Token not found');
|
|
|
|
}
|
|
|
|
|
|
|
|
$em->remove($token);
|
|
|
|
$em->flush();
|
|
|
|
|
|
|
|
$this->addFlash('success', 'API token removed.');
|
|
|
|
|
|
|
|
return $this->redirectToRoute('user_account');
|
|
|
|
}
|
|
|
|
}
|