ILIAS  trunk Revision v11.0_alpha-3011-gc6b235a2e85
class.ilBookingParticipant.php
Go to the documentation of this file.
1<?php
2
24{
25 protected \ILIAS\BookingManager\InternalDomainService $domain;
26 protected ilLanguage $lng;
27 protected ilDBInterface $db;
28 protected int $participant_id;
29 protected int $booking_pool_id;
30 protected bool $is_new;
31 protected ilObjUser $user;
32
33 public function __construct(
34 int $a_user_id,
35 int $a_booking_pool_id
36 ) {
37 global $DIC;
38
39 if (!ilObjUser::_exists($a_user_id)) {
40 throw new ilException("User $a_user_id does not exist.");
41 }
42 if (!ilObjBookingPool::_exists($a_booking_pool_id)) {
43 throw new ilException("Booking Pool $a_booking_pool_id does not exist.");
44 }
45
46 $this->lng = $DIC->language();
47 $this->db = $DIC->database();
48 $this->user = $DIC->user();
49 $this->domain = $DIC->bookingManager()->internal()->domain();
50
51 $this->participant_id = $a_user_id;
52 $this->booking_pool_id = $a_booking_pool_id;
53
54 // if read and not exists, store it in db.
55 if (!$this->read()) {
56 $this->save();
57 $this->is_new = true;
58 } else {
59 $this->is_new = false;
60 }
61 }
62
63 protected function read(): ?int
64 {
65 $query = 'SELECT participant_id FROM booking_member' .
66 ' WHERE user_id = ' . $this->db->quote($this->participant_id, 'integer') .
67 ' AND booking_pool_id = ' . $this->db->quote($this->booking_pool_id, 'integer');
68
69 $set = $this->db->query($query);
70 $row = $this->db->fetchAssoc($set);
71 if (empty($row)) {
72 return null;
73 }
74 return (int) $row['participant_id'];
75 }
76
77 protected function save(): void
78 {
79 $assigner_id = $this->user->getId();
80 $next_id = $this->db->nextId('booking_member');
81
82 $query = 'INSERT INTO booking_member' .
83 ' (participant_id, user_id, booking_pool_id, assigner_user_id)' .
84 ' VALUES (' . $this->db->quote($next_id, 'integer') .
85 ',' . $this->db->quote($this->participant_id, 'integer') .
86 ',' . $this->db->quote($this->booking_pool_id, 'integer') .
87 ',' . $this->db->quote($assigner_id, 'integer') . ')';
88
89 $this->db->manipulate($query);
90 }
91
92 public function getIsNew(): bool
93 {
94 return $this->is_new;
95 }
96
102 public static function getAssignableParticipants(
103 int $a_bp_object_id
104 ): array {
105 $booking_object = new ilBookingObject($a_bp_object_id);
106 $pool_id = $booking_object->getPoolId();
107 $pool = new ilObjBookingPool($pool_id, false);
108 $overall_limit = (int) $pool->getOverallLimit();
109
110 $res = array();
111
112 $members = ilBookingReservation::getMembersWithoutReservation($a_bp_object_id);
113
114 foreach ($members as $member_id) {
115 //check if the user reached the limit of booking in this booking pool.
116 $total_reservations = ilBookingReservation::isBookingPoolLimitReachedByUser($member_id, $pool_id);
117
118 if ($overall_limit === 0 || ($overall_limit > 0 && $total_reservations < $overall_limit)) {
119 $user_name = ilObjUser::_lookupName($member_id);
120 $name = $user_name['lastname'] . ", " . $user_name['firstname'];
121 $index = $a_bp_object_id . "_" . $member_id;
122
123 if (!isset($res[$index])) {
124 $res[$index] = array(
125 "user_id" => $member_id,
126 "object_title" => array($booking_object->getTitle()),
127 "name" => $name
128 );
129 } elseif (!in_array($booking_object->getTitle(), $res[$index]['object_title'], true)) {
130 $res[$index]['object_title'][] = $booking_object->getTitle();
131 }
132 }
133 }
134
135 return $res;
136 }
137
138 public static function getList(
139 int $a_booking_pool,
140 ?array $a_filter = null,
141 ?int $a_object_id = null
142 ): array {
143 global $DIC;
144
145 $ilDB = $DIC->database();
146 $domain = $DIC->bookingManager()->internal()->domain();
147
148 $res = array();
149
150 $query = 'SELECT bm.user_id, bm.booking_pool_id, br.object_id, bo.title, br.status' .
151 ' FROM booking_member bm' .
152 ' LEFT JOIN booking_reservation br ON (bm.user_id = br.user_id)' .
153 ' LEFT JOIN booking_object bo ON (br.object_id = bo.booking_object_id AND bo.pool_id = ' . $ilDB->quote($a_booking_pool, 'integer') . ')';
154
155 $where = array('bm.booking_pool_id =' . $ilDB->quote($a_booking_pool, 'integer'));
156 if ($a_object_id) {
157 $where[] = 'br.object_id = ' . $ilDB->quote($a_object_id, 'integer');
158 }
159 if ($a_filter['title'] ?? false) {
160 $where[] = '(' . $ilDB->like('title', 'text', '%' . $a_filter['title'] . '%') .
161 ' OR ' . $ilDB->like('description', 'text', '%' . $a_filter['title'] . '%') . ')';
162 }
163 if ($a_filter['user_id'] ?? false) {
164 $where[] = 'bm.user_id = ' . $ilDB->quote($a_filter['user_id'], 'integer');
165 }
166
167 $query .= ' WHERE ' . implode(' AND ', $where);
168
169 $set = $ilDB->query($query);
170
171 while ($row = $ilDB->fetchAssoc($set)) {
172 $status = $row['status'];
173 //Nothing to show if the status is canceled when filtering by object
174 if ($status == ilBookingReservation::STATUS_CANCELLED && $a_object_id) {
175 continue;
176 }
177
178 if (!$domain->profile()->exists((int) $row['user_id'])) {
179 continue;
180 }
181
182 $user_name = ilObjUser::_lookupName($row['user_id']);
183 $name = $user_name['lastname'] . ", " . $user_name['firstname'];
184 $index = $a_booking_pool . "_" . $row['user_id'];
185
186 $title = (string) ($row['title'] ?? '');
187 $object_id = (int) ($row['object_id'] ?? -1);
188 if (!isset($res[$index])) {
189 $res[$index] = ['object_title' => [], 'obj_count' => 0, 'object_ids' => [], 'name' => $name];
190
191 if (
193 && $title !== ''
194 && $object_id !== -1
195 ) {
196 $res[$index]['object_title'] = [$title];
197 $res[$index]['obj_count'] = 1;
198 $res[$index]['object_ids'][] = $object_id;
199 }
200 } elseif ($title !== '' && (!in_array($title, $res[$index]['object_title'], true) && $status !== ilBookingReservation::STATUS_CANCELLED)) {
201 $res[$index]['object_title'][] = $title;
202 if (!isset($res[$index]['obj_count'])) {
203 $res[$index]['obj_count'] = 0;
204 }
205 $res[$index]['obj_count'] += 1;
206 $res[$index]['object_ids'][] = $object_id;
207 }
208 $res[$index]['user_id'] = $row['user_id'];
209 }
210
211 foreach ($res as $index => $val) {
212 if (isset($row['object_id'])) {
213 $res[$index]['object_ids'][] = $row['object_id'];
214 }
215 }
216
217 return $res;
218 }
219
224 public static function getBookingPoolParticipants(
225 int $a_booking_pool_id
226 ): array {
227 global $DIC;
228 $ilDB = $DIC->database();
229 $sql = 'SELECT * FROM booking_member WHERE booking_pool_id = ' . $ilDB->quote($a_booking_pool_id, 'integer');
230
231 $set = $ilDB->query($sql);
232
233 $res = array();
234 while ($row = $ilDB->fetchAssoc($set)) {
235 $res[] = $row['user_id'];
236 }
237
238 return $res;
239 }
240
245 public static function getUserFilter(
246 int $a_pool_id
247 ): array {
248 global $DIC;
249
250 $ilDB = $DIC->database();
251
252 $res = [];
253
254 $sql = "SELECT ud.usr_id,ud.lastname,ud.firstname,ud.login" .
255 " FROM usr_data ud " .
256 " RIGHT JOIN booking_member m ON (ud.usr_id = m.user_id)" .
257 " WHERE ud.usr_id <> " . $ilDB->quote(ANONYMOUS_USER_ID, "integer") .
258 " AND m.booking_pool_id = " . $ilDB->quote($a_pool_id, "integer") .
259 " ORDER BY ud.lastname,ud.firstname";
260
261 $set = $ilDB->query($sql);
262 while ($row = $ilDB->fetchAssoc($set)) {
263 $res[$row["usr_id"]] = $row["lastname"] . ", " . $row["firstname"] .
264 " (" . $row["login"] . ")";
265 }
266
267 return $res;
268 }
269
273 protected function isParticipantAssigned(
274 int $a_booking_object_id,
275 int $a_participant_id
276 ): bool {
277 return count(ilBookingReservation::getObjectReservationForUser($a_booking_object_id, $a_participant_id)) > 0;
278 }
279}
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static getAssignableParticipants(int $a_bp_object_id)
Get participants who can not have a reservation for this booking pool object id.
static getBookingPoolParticipants(int $a_booking_pool_id)
Get all participants for a booking pool.
ILIAS BookingManager InternalDomainService $domain
static getList(int $a_booking_pool, ?array $a_filter=null, ?int $a_object_id=null)
isParticipantAssigned(int $a_booking_object_id, int $a_participant_id)
Returns true if the participant has a reservation for this object.
__construct(int $a_user_id, int $a_booking_pool_id)
static getUserFilter(int $a_pool_id)
Get user data from db for an specific pool id.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static isBookingPoolLimitReachedByUser(int $a_user_id, int $a_pool_id)
static getMembersWithoutReservation(int $a_object_id)
Base class for ILIAS Exception handling.
language handling
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
User class.
static _lookupName(int $a_user_id)
static _exists(int $id, bool $reference=false, ?string $type=null)
checks if an object exists in object_data
const ANONYMOUS_USER_ID
Definition: constants.php:27
return['delivery_method'=> 'php',]
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
Interface ilDBInterface.
$res
Definition: ltiservices.php:69
global $DIC
Definition: shib_login.php:26