#4 InvalidInviteException handling removed from UserController due to new validator implemented.

This commit is contained in:
Alexey Skobkin 2018-06-30 03:02:05 +03:00
parent 01827680a1
commit 7d3b81b35a
3 changed files with 14 additions and 26 deletions

View file

@ -5,12 +5,11 @@ namespace App\Controller;
use App\Form\{CreateUserRequestType};
use App\FormRequest\CreateUserRequest;
use App\Repository\InviteRepository;
use App\User\Exception\InvalidInviteException;
use App\User\{InviteManager, UserManager};
use Doctrine\ORM\EntityManagerInterface;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
use Symfony\Component\Form\{FormError, FormInterface};
use Symfony\Component\Form\FormInterface;
use Symfony\Component\HttpFoundation\{Request, Response};
class UserController extends Controller
@ -26,16 +25,11 @@ class UserController extends Controller
$createUserRequest = new CreateUserRequest($inviteCode);
$form = $this->createRegisterForm($createUserRequest, $inviteCode);
$inviteInvalid = false;
if (null === $invite = $inviteRepo->findOneBy(['code' => $inviteCode, 'usedBy' => null])) {
$inviteInvalid = true;
}
$invite = $inviteRepo->findOneBy(['code' => $inviteCode, 'usedBy' => null]);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
try {
$user = $userManager->createUserByInvite(
$createUserRequest->username,
$createUserRequest->password,
@ -44,12 +38,6 @@ class UserController extends Controller
);
$inviteManager->createInvitesForUser($user);
} catch (InvalidInviteException $ex) {
// @FIXME refactor InvalidInviteException to proper validator
$form->get('inviteCode')->addError(new FormError('Invalid invite code'));
return $this->render('User/register.html.twig', ['form' => $form->createView()]);
}
$em->flush();
@ -58,7 +46,7 @@ class UserController extends Controller
return $this->render('User/register.html.twig', [
'form' => $form->createView(),
'inviteInvalid' => $inviteInvalid,
'inviteValid' => $invite ? true : null,
]);
}

View file

@ -2,7 +2,7 @@
namespace App\User\Exception;
class InvalidInviteException extends \Exception
class InvalidInviteException extends \InvalidArgumentException
{
protected $message = 'Invalid invite';
}

View file

@ -1,11 +1,11 @@
{% extends 'base.html.twig' %}
{% block content %}
{% if inviteInvalid %}
<h1>Invalid invite</h1>
{% else %}
{% if inviteValid %}
<div id="form-register">
{{ form(form) }}
</div>
{% else %}
<h1>Invalid invite</h1>
{% endif %}
{% endblock %}