Passed
Push — master ( 3b17fa...419220 )
by K
01:54
created

UserRolesRepository   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 20
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
eloc 4
dl 0
loc 20
ccs 7
cts 7
cp 1
rs 10
c 0
b 0
f 0
wmc 2

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 2 1
A getUserRoles() 0 7 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PerfectApp\RBAC;
6
7
use PDO;
8
9
class UserRolesRepository
10
{
11
    /**
12
     * @param PDO $pdo
13
     */
14 1
    public function __construct(private PDO $pdo)
15
    {
16 1
    }
17
18
    /**
19
     * @param int $userId
20
     * @return array|false
21
     */
22 1
    public function getUserRoles(int $userId): array|false
23
    {
24 1
        $stmt = $this->pdo->prepare('SELECT r.role_name FROM user_roles ur
25
                                    JOIN roles r ON ur.role_id = r.role_id
26 1
                                    WHERE ur.user_id = ?');
27 1
        $stmt->execute([$userId]);
28 1
        return $stmt->fetchAll(PDO::FETCH_COLUMN, 0);
29
    }
30
}
31