Completed
Pull Request — master (#30)
by
unknown
05:03
created

SurveyRepository::findSurveyByStatus()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 11
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 8
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
dl 0
loc 11
rs 9.4285
c 1
b 0
f 0
ccs 8
cts 8
cp 1
cc 1
eloc 8
nc 1
nop 1
crap 1
1
<?php
2
3
namespace AppBundle\Repository;
4
5
use AppBundle\Entity\DTO\SurveyFilter;
6
7
/**
8
 * SurveyRepository.
9
 *
10
 * This class was generated by the Doctrine ORM. Add your own custom
11
 * repository methods below.
12
 */
13
class SurveyRepository extends \Doctrine\ORM\EntityRepository
14
{
15 1
    public function findSurveyByStatus($status)
16
    {
17 1
        $query = $this->createQueryBuilder('s')
18 1
            ->where('s.status = :status')
19 1
            ->setParameter('status', $status)
20 1
            ->orderBy('s.type', 'ASC')
21 1
            ->addOrderBy('s.updatedAt', 'DESC')
22 1
            ->getQuery();
23
24 1
        return $query->getResult();
25
    }
26 1
    public function findSurveyByParams(SurveyFilter $parameters)
27
    {
28 1
        $type = $parameters->getType();
29 1
        $start = $parameters->getStart();
30 1
        $endDay = $parameters->getEnd();
31 1
        $end = date_time_set($endDay, 23, 59, 59);
32
33 1
        $query = $this->createQueryBuilder('s')
34 1
            ->where('s.type = :type')
35 1
            ->andWhere('s.updatedAt >= :start')
36 1
            ->andWhere('s.updatedAt <= :end')
37 1
            ->andWhere('s.status = :status')
38 1
            ->setParameters(array('type' => $type, 'start' => $start, 'end' => $end, 'status' => 'submited'))
39 1
            ->orderBy('s.updatedAt', 'DESC')
40 1
            ->getQuery();
41
42 1
        return $query->getResult();
43
    }
44
45 2
    public function findSurveyByUser($user)
46
    {
47 2
        $query = $this->createQueryBuilder('s')
48 2
            ->where('s.user = :user')
49 2
            ->setParameter('user', $user)
50 2
            ->orderBy('s.updatedAt', 'DESC')
51 2
            ->getQuery();
52
53 2
        return $query->getResult();
54
    }
55
}
56