- <?php
- 
- namespace App\Repository;
- 
- use App\Entity\User;
- use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
- use Doctrine\Persistence\ManagerRegistry;
- use Symfony\Component\Security\Core\Exception\UnsupportedUserException;
- use Symfony\Component\Security\Core\User\PasswordUpgraderInterface;
- use Symfony\Component\Security\Core\User\UserInterface;
- 
- /**
-  * @method User|null find($id, $lockMode = null, $lockVersion = null)
-  * @method User|null findOneBy(array $criteria, array $orderBy = null)
-  * @method User[]    findAll()
-  * @method User[]    findBy(array $criteria, array $orderBy = null, $limit = null, $offset = null)
-  */
- class UserRepository extends ServiceEntityRepository implements PasswordUpgraderInterface
- {
-     public function __construct(ManagerRegistry $registry)
-     {
-         parent::__construct($registry, User::class);
-     }
- 
-     /**
-      * Used to upgrade (rehash) the user's password automatically over time.
-      */
-     public function upgradePassword(UserInterface $user, string $newEncodedPassword): void
-     {
-         if (!$user instanceof User) {
-             throw new UnsupportedUserException(sprintf('Instances of "%s" are not supported.', \get_class($user)));
-         }
- 
-         $user->setPassword($newEncodedPassword);
-         $this->_em->persist($user);
-         $this->_em->flush();
-     }
- 
-     public function loadUserByUsername($username)
-     {
-         return $this->createQueryBuilder('u')
-             ->where('u.username = :username OR u.email = :email')
-             ->setParameter('username', $username)
-             ->setParameter('email', $username)
-             ->getQuery()
-             ->getOneOrNullResult();
-     }
- 
- 
-     public function countRecentLoginAttempts($id)
-     {
- 
-         return $this->createQueryBuilder('u')
-                     ->select('u.authentication_failure','u.locked')
-                     ->where('u.locked IS NOT NULL')
-                     ->andWhere('u.id = :id')
-                     ->setParameter('id', $id)
-                     ->getQuery()
-                     ->getOneOrNullResult()
-         ;
-     }
- 
-     public function findEmailUser($id)
-     {
-         return $this->createQueryBuilder('u')
-                     ->select('u.email')
-                     ->andWhere('u.id =:id')
-                     ->setParameter('id', $id)
-                     ->getQuery()
-                     ->getOneOrNullResult();
-     }
- 
-     public function findUserIsNotDelete()
-     {
-         return $this->createQueryBuilder('u')
-                     ->andWhere('u.isDelete =:etat')
-                     ->setParameter('etat', false)
-                     ->orderBy('u.id','DESC')
-                     ->getQuery()
-                     ->getResult();
-     }
- 
-     // /**
-     //  * @return User[] Returns an array of User objects
-     //  */
-     /*
-     public function findByExampleField($value)
-     {
-         return $this->createQueryBuilder('u')
-             ->andWhere('u.exampleField = :val')
-             ->setParameter('val', $value)
-             ->orderBy('u.id', 'ASC')
-             ->setMaxResults(10)
-             ->getQuery()
-             ->getResult()
-         ;
-     }
-     */
- 
-     /*
-     public function findOneBySomeField($value): ?User
-     {
-         return $this->createQueryBuilder('u')
-             ->andWhere('u.exampleField = :val')
-             ->setParameter('val', $value)
-             ->getQuery()
-             ->getOneOrNullResult()
-         ;
-     }
-     */
- }
-