Completed
Push — master ( 392874...829d42 )
by Albert
05:23
created

CategoryRepository   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 34
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Test Coverage

Coverage 0%

Importance

Changes 1
Bugs 0 Features 1
Metric Value
wmc 3
c 1
b 0
f 1
lcom 1
cbo 2
dl 0
loc 34
ccs 0
cts 25
cp 0
rs 10

3 Methods

Rating   Name   Duplication   Size   Complexity  
A count() 0 8 1
A paginated() 0 11 1
A last() 0 10 1
1
<?php
2
3
namespace Albert221\Blog\Repository\Database;
4
5
use Albert221\Blog\Repository\CategoryRepositoryInterface;
6
use Doctrine\ORM\EntityRepository;
7
8
class CategoryRepository extends EntityRepository implements CategoryRepositoryInterface
9
{
10
    public function count()
11
    {
12
        $query = $this->createQueryBuilder('c')
13
            ->select('count(c.id)')
14
            ->getQuery();
15
16
        return $query->getSingleScalarResult();
17
    }
18
19
    public function paginated($page, $perPage)
20
    {
21
        $first = ($page - 1) * $perPage;
22
23
        $query = $this->createQueryBuilder('c')
24
            ->setFirstResult($first)
25
            ->setMaxResults($perPage)
26
            ->getQuery();
27
28
        return $query->getResult();
29
    }
30
31
    public function last($count)
32
    {
33
        $query = $this->createQueryBuilder('c')
34
            ->join('c.posts', 'p')
35
            ->orderBy('p.published_at', 'DESC')
36
            ->setMaxResults($count)
37
            ->getQuery();
38
        
39
        return $query->getResult();
40
    }
41
}
42