Completed
Push — master ( eaa10a...12d04d )
by Albert
03:25
created

DatabasePostRepository   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 44
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 3

Test Coverage

Coverage 0%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 4
c 1
b 0
f 0
lcom 1
cbo 3
dl 0
loc 44
ccs 0
cts 32
cp 0
rs 10

4 Methods

Rating   Name   Duplication   Size   Complexity  
A count() 0 8 1
A paginated() 0 11 1
A bySlug() 0 4 1
A byCategory() 0 15 1
1
<?php
2
3
namespace Albert221\Blog\Repository;
4
5
use Doctrine\ORM\EntityRepository;
6
7
class DatabasePostRepository extends EntityRepository implements PostRepositoryInterface
8
{
9
    public function count()
10
    {
11
        $query = $this->createQueryBuilder('p')
12
            ->select('count(p.id)')
13
            ->getQuery();
14
15
        return $query->getSingleScalarResult();
16
    }
17
    
18
    public function paginated($page, $perPage)
19
    {
20
        $first = ($page - 1) * $perPage;
21
22
        $query = $this->createQueryBuilder('p')
23
            ->setFirstResult($first)
24
            ->setMaxResults($perPage)
25
            ->getQuery();
26
27
        return $query->getResult();
28
    }
29
30
    public function bySlug($slug)
31
    {
32
        return $this->findOneBy(['slug' => $slug]);
33
    }
34
35
    public function byCategory($category, $page, $perPage)
36
    {
37
        $first = ($page - 1) * $perPage;
38
        
39
        $qb = $this->createQueryBuilder('p');
40
41
        $query = $qb->join('p.category', 'c')
42
            ->where($qb->expr()->eq('c.slug', ':category'))
43
            ->setParameter(':category', $category)
44
            ->setFirstResult($first)
45
            ->setMaxResults($perPage)
46
            ->getQuery();
47
48
        return $query->getResult();
49
    }
50
}
51