Failed Conditions
Push — master ( b2d0fe...a6f10d )
by Adrien
07:38
created

MessageRepository   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 28
Duplicated Lines 0 %

Test Coverage

Coverage 44.44%

Importance

Changes 0
Metric Value
eloc 8
dl 0
loc 28
ccs 4
cts 9
cp 0.4444
rs 10
c 0
b 0
f 0
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A getAccessibleSubQuery() 0 7 2
A getAllMessageToSend() 0 7 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Application\Repository;
6
7
use Application\Model\Message;
8
use Application\Model\User;
9
10
class MessageRepository extends AbstractRepository implements LimitedAccessSubQueryInterface
11
{
12
    /**
13
     * Returns pure SQL to get ID of all objects that are accessible to given user.
14
     *
15
     * @param null|User $user
16
     *
17
     * @return string
18
     */
19 8
    public function getAccessibleSubQuery(?User $user): string
20
    {
21 8
        if (!$user) {
22 1
            return '-1';
23
        }
24
25 7
        return 'SELECT id FROM message WHERE recipient_id = ' . $user->getId();
26
    }
27
28
    /**
29
     * @return Message[]
30
     */
31
    public function getAllMessageToSend(): array
32
    {
33
        $qb = $this->createQueryBuilder('message')
34
            ->where('message.dateSent IS NULL')
35
            ->addOrderBy('message.id');
36
37
        return $qb->getQuery()->setMaxResults(200)->getResult();
38
    }
39
}
40