Passed
Push — dependabot/npm_and_yarn/cross-... ( a16049...ad80c0 )
by
unknown
16:45 queued 07:24
created

getSessionCourseUsers()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 16
Code Lines 13

Duplication

Lines 0
Ratio 0 %

Importance

Changes 4
Bugs 0 Features 0
Metric Value
cc 1
eloc 13
nc 1
nop 2
dl 0
loc 16
rs 9.8333
c 4
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
/* For licensing terms, see /license.txt */
6
7
namespace Chamilo\CoreBundle\Repository;
8
9
use Chamilo\CoreBundle\Entity\SessionRelCourseRelUser;
10
use Chamilo\CourseBundle\Entity\CLp;
11
use Chamilo\CourseBundle\Entity\CLpView;
12
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
13
use Doctrine\Persistence\ManagerRegistry;
14
15
class SessionRelCourseRelUserRepository extends ServiceEntityRepository
16
{
17
    public function __construct(ManagerRegistry $registry)
18
    {
19
        parent::__construct($registry, SessionRelCourseRelUser::class);
20
    }
21
22
    /**
23
     * Retrieves users from a course session and their LP progress.
24
     */
25
    public function getSessionCourseUsers(int $courseId, array $lpIds): array
26
    {
27
        $qb = $this->createQueryBuilder('scu')
28
            ->select('u.id AS userId, c.title AS courseTitle, lp.iid AS lpId, COALESCE(lpv.progress, 0) AS progress, IDENTITY(scu.session) AS sessionId')
29
            ->innerJoin('scu.user', 'u')
30
            ->innerJoin('scu.course', 'c')
31
            ->leftJoin(CLpView::class, 'lpv', 'WITH', 'lpv.user = u.id AND lpv.course = scu.course AND lpv.lp IN (:lpIds)')
32
            ->leftJoin(CLp::class, 'lp', 'WITH', 'lp.iid IN (:lpIds)')
33
            ->innerJoin('lp.resourceNode', 'rn')
34
            ->where('scu.course = :courseId')
35
            ->andWhere('rn.parent = c.resourceNode')
36
            ->andWhere('(lpv.progress < 100 OR lpv.progress IS NULL)')
37
            ->setParameter('courseId', $courseId)
38
            ->setParameter('lpIds', $lpIds);
39
40
        return $qb->getQuery()->getResult();
41
    }
42
}
43