- Ajout dans inscription de la confirmation du mot de passe.
This commit is contained in:
@ -2,7 +2,7 @@ APP_ENV=dev
|
|||||||
APP_SECRET=
|
APP_SECRET=
|
||||||
|
|
||||||
DB_ROOT_PASSWORD=rootpswd
|
DB_ROOT_PASSWORD=rootpswd
|
||||||
DB_DATABASE=cloudsprint
|
DB_DATABASE=booknest
|
||||||
DB_USERNAME=dev
|
DB_USERNAME=dev
|
||||||
DB_PASSWORD=cfai42
|
DB_PASSWORD=cfai42
|
||||||
DB_HOST=db
|
DB_HOST=db
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
@ -14,9 +13,9 @@ use Doctrine\ORM\EntityManagerInterface;
|
|||||||
class RegistrationController extends AbstractController
|
class RegistrationController extends AbstractController
|
||||||
{
|
{
|
||||||
private $entityManager;
|
private $entityManager;
|
||||||
private $passwordHasher; // Correction du nom de la variable
|
private $passwordHasher;
|
||||||
|
|
||||||
public function __construct(EntityManagerInterface $entityManager, UserPasswordHasherInterface $passwordHasher) // Correction ici
|
public function __construct(EntityManagerInterface $entityManager, UserPasswordHasherInterface $passwordHasher)
|
||||||
{
|
{
|
||||||
$this->entityManager = $entityManager;
|
$this->entityManager = $entityManager;
|
||||||
$this->passwordHasher = $passwordHasher;
|
$this->passwordHasher = $passwordHasher;
|
||||||
@ -30,16 +29,20 @@ class RegistrationController extends AbstractController
|
|||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
|
|
||||||
if ($form->isSubmitted() && $form->isValid()) {
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
// Hacher le mot de passe avant de persister l'utilisateur
|
$plainPassword = $user->getPassword();
|
||||||
$plainPassword = $user->getPassword(); // Récupération du mot de passe brut
|
$confirmPassword = $form->get('confirmPassword')->getData();
|
||||||
$hashedPassword = $this->passwordHasher->hashPassword($user, $plainPassword); // Hachage du mot de passe
|
|
||||||
$user->setPassword($hashedPassword); // Remplacer le mot de passe brut par le mot de passe haché
|
if ($plainPassword !== $confirmPassword) {
|
||||||
|
$this->addFlash('error', 'Les mots de passe ne correspondent pas.');
|
||||||
|
return $this->redirectToRoute('app_registration');
|
||||||
|
}
|
||||||
|
|
||||||
|
$hashedPassword = $this->passwordHasher->hashPassword($user, $plainPassword);
|
||||||
|
$user->setPassword($hashedPassword);
|
||||||
|
|
||||||
// Persist de l'utilisateur haché
|
|
||||||
$this->entityManager->persist($user);
|
$this->entityManager->persist($user);
|
||||||
$this->entityManager->flush();
|
$this->entityManager->flush();
|
||||||
|
|
||||||
// Message flash de succès
|
|
||||||
$this->addFlash('success', 'Votre compte a été créé avec succès !');
|
$this->addFlash('success', 'Votre compte a été créé avec succès !');
|
||||||
return $this->redirectToRoute('home');
|
return $this->redirectToRoute('home');
|
||||||
}
|
}
|
||||||
|
@ -12,39 +12,44 @@ use Symfony\Component\OptionsResolver\OptionsResolver;
|
|||||||
|
|
||||||
class RegistrationType extends AbstractType
|
class RegistrationType extends AbstractType
|
||||||
{
|
{
|
||||||
public function buildForm(FormBuilderInterface $builder, array $options)
|
public function buildForm(FormBuilderInterface $builder, array $options)
|
||||||
{
|
{
|
||||||
$builder
|
$builder
|
||||||
->add('email', EmailType::class, [
|
->add('email', EmailType::class, [
|
||||||
'label' => 'Email',
|
'label' => 'Email',
|
||||||
'attr' => ['class' => 'form-control']
|
'attr' => ['class' => 'form-control']
|
||||||
])
|
])
|
||||||
->add('password', PasswordType::class, [
|
->add('password', PasswordType::class, [
|
||||||
'label' => 'Mot de passe',
|
'label' => 'Mot de passe',
|
||||||
'attr' => ['class' => 'form-control']
|
'attr' => ['class' => 'form-control']
|
||||||
])
|
])
|
||||||
->add('pseudo', TextType::class, [
|
->add('confirmPassword', PasswordType::class, [
|
||||||
'label' => 'Pseudo',
|
'label' => 'Confirmer le mot de passe',
|
||||||
'attr' => ['class' => 'form-control']
|
'attr' => ['class' => 'form-control'],
|
||||||
])
|
'mapped' => false, // Ce champ n'est pas mappé à l'entité User
|
||||||
->add('firstname', TextType::class, [
|
])
|
||||||
'label' => 'Prénom',
|
->add('pseudo', TextType::class, [
|
||||||
'attr' => ['class' => 'form-control']
|
'label' => 'Pseudo',
|
||||||
])
|
'attr' => ['class' => 'form-control']
|
||||||
->add('lastname', TextType::class, [
|
])
|
||||||
'label' => 'Nom',
|
->add('firstname', TextType::class, [
|
||||||
'attr' => ['class' => 'form-control']
|
'label' => 'Prénom',
|
||||||
])
|
'attr' => ['class' => 'form-control']
|
||||||
->add('submit', SubmitType::class, [
|
])
|
||||||
'label' => 'S\'inscrire',
|
->add('lastname', TextType::class, [
|
||||||
'attr' => ['class' => 'btn btn-primary']
|
'label' => 'Nom',
|
||||||
]);
|
'attr' => ['class' => 'form-control']
|
||||||
}
|
])
|
||||||
|
->add('submit', SubmitType::class, [
|
||||||
|
'label' => 'S\'inscrire',
|
||||||
|
'attr' => ['class' => 'btn btn-primary']
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
public function configureOptions(OptionsResolver $resolver)
|
public function configureOptions(OptionsResolver $resolver)
|
||||||
{
|
{
|
||||||
$resolver->setDefaults([
|
$resolver->setDefaults([
|
||||||
'data_class' => User::class,
|
'data_class' => User::class,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,15 +30,7 @@
|
|||||||
<button type="submit" class="w-full px-4 py-2 bg-indigo-600 text-white font-semibold rounded-md hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500">
|
<button type="submit" class="w-full px-4 py-2 bg-indigo-600 text-white font-semibold rounded-md hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500">
|
||||||
Se connecter
|
Se connecter
|
||||||
</button>
|
</button>
|
||||||
{% for type, messages in app.flashes %}
|
|
||||||
<div class="mb-4">
|
|
||||||
{% for message in messages %}
|
|
||||||
<div class="text-sm {% if type == 'success' %}text-green-600{% else %}text-red-600{% endif %}">
|
|
||||||
{{ message }}
|
|
||||||
</div>
|
|
||||||
{% endfor %}
|
|
||||||
</div>
|
|
||||||
{% endfor %}
|
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
{# templates/registration/register.html.twig #}
|
|
||||||
|
|
||||||
{% extends 'base.html.twig' %}
|
{% extends 'base.html.twig' %}
|
||||||
|
|
||||||
{% block title %}Inscription{% endblock %}
|
{% block title %}Inscription{% endblock %}
|
||||||
@ -11,6 +9,30 @@
|
|||||||
|
|
||||||
{{ form_start(form) }}
|
{{ form_start(form) }}
|
||||||
|
|
||||||
|
<div class="mb-4">
|
||||||
|
{{ form_label(form.firstname, 'Prénom', {'label_attr': {'class': 'block text-sm font-medium text-gray-700'}}) }}
|
||||||
|
<div class="mt-1">
|
||||||
|
{{ form_widget(form.firstname, {'attr': {'class': 'w-full px-3 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500 sm:text-sm'}}) }}
|
||||||
|
</div>
|
||||||
|
{{ form_errors(form.firstname) }}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-4">
|
||||||
|
{{ form_label(form.lastname, 'Nom', {'label_attr': {'class': 'block text-sm font-medium text-gray-700'}}) }}
|
||||||
|
<div class="mt-1">
|
||||||
|
{{ form_widget(form.lastname, {'attr': {'class': 'w-full px-3 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500 sm:text-sm'}}) }}
|
||||||
|
</div>
|
||||||
|
{{ form_errors(form.lastname) }}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-4">
|
||||||
|
{{ form_label(form.pseudo, 'Pseudo', {'label_attr': {'class': 'block text-sm font-medium text-gray-700'}}) }}
|
||||||
|
<div class="mt-1">
|
||||||
|
{{ form_widget(form.pseudo, {'attr': {'class': 'w-full px-3 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500 sm:text-sm'}}) }}
|
||||||
|
</div>
|
||||||
|
{{ form_errors(form.pseudo) }}
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="mb-4">
|
<div class="mb-4">
|
||||||
{{ form_label(form.email, 'Email', {'label_attr': {'class': 'block text-sm font-medium text-gray-700'}}) }}
|
{{ form_label(form.email, 'Email', {'label_attr': {'class': 'block text-sm font-medium text-gray-700'}}) }}
|
||||||
<div class="mt-1">
|
<div class="mt-1">
|
||||||
@ -28,27 +50,11 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="mb-4">
|
<div class="mb-4">
|
||||||
{{ form_label(form.pseudo, 'Pseudo', {'label_attr': {'class': 'block text-sm font-medium text-gray-700'}}) }}
|
{{ form_label(form.confirmPassword, 'Confirmer le mot de passe', {'label_attr': {'class': 'block text-sm font-medium text-gray-700'}}) }}
|
||||||
<div class="mt-1">
|
<div class="mt-1">
|
||||||
{{ form_widget(form.pseudo, {'attr': {'class': 'w-full px-3 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500 sm:text-sm'}}) }}
|
{{ form_widget(form.confirmPassword, {'attr': {'class': 'w-full px-3 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500 sm:text-sm'}}) }}
|
||||||
</div>
|
</div>
|
||||||
{{ form_errors(form.pseudo) }}
|
{{ form_errors(form.confirmPassword) }}
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="mb-4">
|
|
||||||
{{ form_label(form.firstname, 'Prénom', {'label_attr': {'class': 'block text-sm font-medium text-gray-700'}}) }}
|
|
||||||
<div class="mt-1">
|
|
||||||
{{ form_widget(form.firstname, {'attr': {'class': 'w-full px-3 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500 sm:text-sm'}}) }}
|
|
||||||
</div>
|
|
||||||
{{ form_errors(form.firstname) }}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="mb-4">
|
|
||||||
{{ form_label(form.lastname, 'Nom', {'label_attr': {'class': 'block text-sm font-medium text-gray-700'}}) }}
|
|
||||||
<div class="mt-1">
|
|
||||||
{{ form_widget(form.lastname, {'attr': {'class': 'w-full px-3 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500 sm:text-sm'}}) }}
|
|
||||||
</div>
|
|
||||||
{{ form_errors(form.lastname) }}
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="mt-6 text-center">
|
<div class="mt-6 text-center">
|
||||||
@ -56,11 +62,25 @@
|
|||||||
'attr': {'class': 'w-full px-4 py-2 bg-indigo-600 text-white font-semibold rounded-md hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500'}
|
'attr': {'class': 'w-full px-4 py-2 bg-indigo-600 text-white font-semibold rounded-md hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500'}
|
||||||
}) }}
|
}) }}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% for type, messages in app.flashes %}
|
{% for type, messages in app.flashes %}
|
||||||
<div class="mb-4">
|
<div class="mb-4 mt-4">
|
||||||
{% for message in messages %}
|
{% for message in messages %}
|
||||||
<div class="text-sm {% if type == 'success' %}text-green-600{% else %}text-red-600{% endif %}">
|
<div class="text-sm p-4 rounded-lg shadow-lg
|
||||||
{{ message }}
|
{% if type == 'success' %}
|
||||||
|
bg-green-100 text-green-700 border-l-4 border-green-500
|
||||||
|
{% else %}
|
||||||
|
bg-red-100 text-red-700 border-l-4 border-red-500
|
||||||
|
{% endif %}
|
||||||
|
transition-all transform hover:scale-105">
|
||||||
|
<div class="font-semibold">
|
||||||
|
{% if type == 'success' %}
|
||||||
|
Succès:
|
||||||
|
{% else %}
|
||||||
|
Erreur:
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
<p>{{ message }}</p>
|
||||||
</div>
|
</div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
|
Reference in New Issue
Block a user