Différences
Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentes Révision précédente Prochaine révision | Révision précédente | ||
prog:symfony:entities:fixtures [04/10/2022 16:41] thierry [Prérequis] |
prog:symfony:entities:fixtures [09/10/2022 17:24] (Version actuelle) thierry [Créer un mot de passe d'utilisateur] |
||
---|---|---|---|
Ligne 11: | Ligne 11: | ||
===== Faker ===== | ===== Faker ===== | ||
- | * Address | + | Pour voir les differents formats généré par Faker, rdv ici -> [[https://fakerphp.github.io/formatters/numbers-and-strings/]] |
- | * Barcode | + | ===== AppFixtures.php ===== |
- | * Biased | + | <code php AppFixtures.php> |
- | * Color | + | <?php |
- | * Company | + | |
- | * DateTime | + | namespace App\DataFixtures; |
- | * File | + | |
- | * HtmlLorem | + | use Faker\Factory; |
- | * Image | + | use App\Entity\GTicket; |
- | * Internet | + | use Doctrine\Persistence\ObjectManager; |
- | * Lorem | + | use Doctrine\Bundle\FixturesBundle\Fixture; |
- | * Miscellaneous | + | |
- | * Payment | + | class AppFixtures extends Fixture |
- | * Person | + | { |
- | * PhoneNumber | + | const NB_TICKETS = 20000; |
- | * Text | + | |
- | * UserAgent | + | public function load(ObjectManager $manager): void |
- | * Uuid | + | { |
+ | |||
+ | $faker = Factory::create('fr_FR'); | ||
+ | for ($i=0;$i<self::NB_TICKETS;$i++) | ||
+ | { | ||
+ | $ticket=new GTicket(null); | ||
+ | $ticket->setNum($faker->randomNumber(4,false)); | ||
+ | $ticket->setMail($faker->email()); | ||
+ | $ticket->setDate($faker->dateTimeBetween('-1 week', '+4 week')); | ||
+ | $ticket->setIp($faker->ipv4()); | ||
+ | $manager->persist($ticket); | ||
+ | } | ||
+ | $manager->flush(); | ||
+ | } | ||
+ | } | ||
+ | |||
+ | </code> | ||
+ | |||
+ | ===== Application des fixtures ===== | ||
+ | ''symfony console doctrine:fixtures:load'' | ||
+ | ===== Cas particuliers ===== | ||
+ | ==== Créer un mot de passe d'utilisateur ==== | ||
+ | Il faut hasher le mot de passe avant de le stocker avec ''$user->setPassword'' | ||
+ | |||
+ | Dans l'exemple ci dessous : | ||
+ | - Nouvelle clause use :''use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;'' | ||
+ | - Modification/Ajout de la function ''construct'' pour injecter ''userPasswordHasherInterface'' | ||
+ | - Hashage du mot de passe avec ''$this->userPasswordHasherInterface->hashPassword($user,'password');'' | ||
+ | |||
+ | |||
+ | <code php> | ||
+ | use App\Entity\User; | ||
+ | use Doctrine\Persistence\ObjectManager; | ||
+ | use Doctrine\Bundle\FixturesBundle\Fixture; | ||
+ | use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface; | ||
+ | |||
+ | class AppFixtures extends Fixture | ||
+ | { | ||
+ | private $userPasswordHasherInterface; | ||
+ | public function __construct (UserPasswordHasherInterface $userPasswordHasherInterface) | ||
+ | { | ||
+ | $this->userPasswordHasherInterface = $userPasswordHasherInterface; | ||
+ | } | ||
+ | |||
+ | public function load(ObjectManager $manager): void | ||
+ | { | ||
+ | $user = new User; | ||
+ | $user->setEmail('test@test.com'); | ||
+ | $hashedPassword = $this->userPasswordHasherInterface->hashPassword($user,'password'); | ||
+ | $user->setPassword($hashedPassword); | ||
+ | $manager->persist($user); | ||
+ | $manager->flush(); | ||
+ | } | ||
+ | } | ||
+ | |||
+ | </code> | ||
+ | |||
====== Sources & Ressources ====== | ====== Sources & Ressources ====== | ||