Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/spreed.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Model/AttendeeMapper.php')
-rw-r--r--lib/Model/AttendeeMapper.php24
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/Model/AttendeeMapper.php b/lib/Model/AttendeeMapper.php
index 13d7d6d07..8bce0422f 100644
--- a/lib/Model/AttendeeMapper.php
+++ b/lib/Model/AttendeeMapper.php
@@ -79,6 +79,30 @@ class AttendeeMapper extends QBMapper {
/**
* @param int $roomId
+ * @param string $actorType
+ * @param int|null $lastJoinedCall
+ * @return int
+ */
+ public function getActorsCountByType(int $roomId, string $actorType, ?int $lastJoinedCall = null): int {
+ $query = $this->db->getQueryBuilder();
+ $query->select($query->func()->count('*', 'num_actors'))
+ ->from($this->getTableName())
+ ->where($query->expr()->eq('room_id', $query->createNamedParameter($roomId, IQueryBuilder::PARAM_INT)))
+ ->andWhere($query->expr()->eq('actor_type', $query->createNamedParameter($actorType)));
+
+ if ($lastJoinedCall !== null) {
+ $query->andWhere($query->expr()->gte('last_joined_call', $query->createNamedParameter($lastJoinedCall, IQueryBuilder::PARAM_INT)));
+ }
+
+ $result = $query->execute();
+ $count = (int) $result->fetchOne();
+ $result->closeCursor();
+
+ return $count;
+ }
+
+ /**
+ * @param int $roomId
* @param int[] $participantType
* @return int
*/