- Ajout dans inscription de la confirmation du mot de passe.
This commit is contained in:
@ -2,7 +2,7 @@ APP_ENV=dev
|
||||
APP_SECRET=
|
||||
|
||||
DB_ROOT_PASSWORD=rootpswd
|
||||
DB_DATABASE=cloudsprint
|
||||
DB_DATABASE=booknest
|
||||
DB_USERNAME=dev
|
||||
DB_PASSWORD=cfai42
|
||||
DB_HOST=db
|
||||
|
@ -1,5 +1,4 @@
|
||||
<?php
|
||||
|
||||
namespace App\Controller;
|
||||
|
||||
use App\Entity\User;
|
||||
@ -14,9 +13,9 @@ use Doctrine\ORM\EntityManagerInterface;
|
||||
class RegistrationController extends AbstractController
|
||||
{
|
||||
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->passwordHasher = $passwordHasher;
|
||||
@ -30,16 +29,20 @@ class RegistrationController extends AbstractController
|
||||
$form->handleRequest($request);
|
||||
|
||||
if ($form->isSubmitted() && $form->isValid()) {
|
||||
// Hacher le mot de passe avant de persister l'utilisateur
|
||||
$plainPassword = $user->getPassword(); // Récupération du mot de passe brut
|
||||
$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é
|
||||
$plainPassword = $user->getPassword();
|
||||
$confirmPassword = $form->get('confirmPassword')->getData();
|
||||
|
||||
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->flush();
|
||||
|
||||
// Message flash de succès
|
||||
$this->addFlash('success', 'Votre compte a été créé avec succès !');
|
||||
return $this->redirectToRoute('home');
|
||||
}
|
||||
|
@ -23,6 +23,11 @@ $builder
|
||||
'label' => 'Mot de passe',
|
||||
'attr' => ['class' => 'form-control']
|
||||
])
|
||||
->add('confirmPassword', PasswordType::class, [
|
||||
'label' => 'Confirmer le mot de passe',
|
||||
'attr' => ['class' => 'form-control'],
|
||||
'mapped' => false, // Ce champ n'est pas mappé à l'entité User
|
||||
])
|
||||
->add('pseudo', TextType::class, [
|
||||
'label' => 'Pseudo',
|
||||
'attr' => ['class' => 'form-control']
|
||||
|
@ -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">
|
||||
Se connecter
|
||||
</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>
|
||||
</form>
|
||||
</div>
|
||||
|
@ -1,5 +1,3 @@
|
||||
{# templates/registration/register.html.twig #}
|
||||
|
||||
{% extends 'base.html.twig' %}
|
||||
|
||||
{% block title %}Inscription{% endblock %}
|
||||
@ -11,6 +9,30 @@
|
||||
|
||||
{{ 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">
|
||||
{{ form_label(form.email, 'Email', {'label_attr': {'class': 'block text-sm font-medium text-gray-700'}}) }}
|
||||
<div class="mt-1">
|
||||
@ -28,27 +50,11 @@
|
||||
</div>
|
||||
|
||||
<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">
|
||||
{{ 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>
|
||||
{{ form_errors(form.pseudo) }}
|
||||
</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) }}
|
||||
{{ form_errors(form.confirmPassword) }}
|
||||
</div>
|
||||
|
||||
<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'}
|
||||
}) }}
|
||||
</div>
|
||||
|
||||
{% for type, messages in app.flashes %}
|
||||
<div class="mb-4">
|
||||
<div class="mb-4 mt-4">
|
||||
{% for message in messages %}
|
||||
<div class="text-sm {% if type == 'success' %}text-green-600{% else %}text-red-600{% endif %}">
|
||||
{{ message }}
|
||||
<div class="text-sm p-4 rounded-lg shadow-lg
|
||||
{% 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>
|
||||
{% endfor %}
|
||||
</div>
|
||||
|
Reference in New Issue
Block a user