Completed
Pull Request — dev (#22)
by
unknown
03:11
created

UserRepository::selectUsersByParams()   A

Complexity

Conditions 4
Paths 2

Size

Total Lines 19
Code Lines 12

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 20

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 19
rs 9.2
cc 4
eloc 12
nc 2
nop 1
ccs 0
cts 17
cp 0
crap 20
1
<?php
2
3
namespace AppBundle\Repository;
4
5
use Symfony\Bridge\Doctrine\Security\User\UserLoaderInterface;
6
use Symfony\Component\HttpFoundation\ParameterBag;
7
8
/**
9
 * UserRepository.
10
 *
11
 * This class was generated by the Doctrine ORM. Add your own custom
12
 * repository methods below.
13
 */
14
class UserRepository extends \Doctrine\ORM\EntityRepository implements UserLoaderInterface
15
{
16
    public function loadUserByUsername($username)
17
    {
18
        return $this->createQueryBuilder('user')
19
            ->andWhere('user.apiToken = :username')
20
            ->setParameter('username', $username)
21
            ->getQuery()
22
            ->getOneOrNullResult();
23
    }
24
25
    /**
26
     * @param ParameterBag $params
27
     * @return array
28
     */
29
    public function selectUsersByParams(ParameterBag $params):array
30
    {
31
        $postsQuery = $this->createQueryBuilder('Users')
32
            ->select('u')
33
            ->from('AppBundle:User', 'u')
34
            ->orderBy('u.createdAt', preg_match('/asc/i', $params->get('order')) ? 'ASC' : 'DESC');
35
36
        if ($params->has('name') && $params->get('name')) {
37
            $postsQuery->where(
38
                $postsQuery->expr()->like('u.firstName', ':name')
39
            )
40
                ->orWhere(
41
                    $postsQuery->expr()->like('u.lastName', ':name')
42
                )
43
                ->setParameter('name', '%' . $params->get('name') . '%');
44
        }
45
46
        return $postsQuery->getQuery()->getResult();
47
    }
48
}
49