Completed
Pull Request — dev (#22)
by
unknown
23:02
created

UserRepository::getUsersByParams()   B

Complexity

Conditions 5
Paths 4

Size

Total Lines 25
Code Lines 16

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 30

Importance

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