| Conditions | 5 |
| Paths | 16 |
| Total Lines | 22 |
| Code Lines | 14 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 1 | ||
| Bugs | 0 | Features | 0 |
| 1 | <?php |
||
| 18 | public function getCourseRating(Course $course, ?Session $session = null): array |
||
| 19 | { |
||
| 20 | $qb = $this->em->createQueryBuilder() |
||
| 21 | ->select('AVG(v.vote) AS avgVote', 'COUNT(v.id) AS countVotes') |
||
| 22 | ->from(UserRelCourseVote::class, 'v') |
||
| 23 | ->where('v.course = :course') |
||
| 24 | ->setParameter('course', $course->getId(), ParameterType::INTEGER); |
||
| 25 | |||
| 26 | |||
| 27 | if ($session !== null) { |
||
| 28 | $qb->andWhere('v.session = :session') |
||
| 29 | ->setParameter('session', $session->getId(), ParameterType::INTEGER); |
||
| 30 | } else { |
||
| 31 | $qb->andWhere('v.session IS NULL'); |
||
| 32 | } |
||
| 33 | |||
| 34 | |||
| 35 | $row = $qb->getQuery()->getSingleResult(); |
||
| 36 | $avg = isset($row['avgVote']) && $row['avgVote'] !== null ? round((float) $row['avgVote'], 2) : 0.0; |
||
| 37 | $count = isset($row['countVotes']) ? (int) $row['countVotes'] : 0; |
||
| 38 | |||
| 39 | return ['avg' => $avg, 'average' => $avg, 'count' => $count]; |
||
| 40 | |||
| 44 |