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

DatabaseCategoryRepository   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 54
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 4

Test Coverage

Coverage 0%

Importance

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

4 Methods

Rating   Name   Duplication   Size   Complexity  
A count() 0 8 1
A paginated() 0 11 1
A postsCount() 0 12 1
A postsPaginated() 0 17 1
1
<?php
2
3
namespace Albert221\Blog\Repository;
4
5
use Albert221\Blog\Entity\Post;
6
use Doctrine\ORM\EntityRepository;
7
8
class DatabaseCategoryRepository 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 postsCount($slug)
32
    {
33
        $qb = $this->createQueryBuilder('c');
34
35
        $query = $qb->select('count(p.id)')
36
            ->join('c.posts', 'p')
37
            ->where($qb->expr()->eq('c.slug', ':slug'))
38
            ->setParameter(':slug', $slug)
39
            ->getQuery();
40
41
        return $query->getSingleScalarResult();
42
    }
43
44
    public function postsPaginated($slug, $page, $perPage)
45
    {
46
        $first = ($page - 1) * $perPage;
47
48
        $qb = $this->getEntityManager()->createQueryBuilder();
49
50
        $query = $qb->select('p')
51
            ->from(Post::class, 'p')
52
            ->join('p.category', 'c')
53
            ->where($qb->expr()->eq('c.slug', ':slug'))
54
            ->setParameter(':slug', $slug)
55
            ->setFirstResult($first)
56
            ->setMaxResults($perPage)
57
            ->getQuery();
58
59
        return $query->getResult();
60
    }
61
}
62