1 | <?php |
||||
2 | class ShiftAPI extends VolunteerAPI |
||||
3 | { |
||||
4 | use Processor; |
||||
0 ignored issues
–
show
introduced
by
![]() |
|||||
5 | |||||
6 | public function __construct() |
||||
7 | { |
||||
8 | parent::__construct('shifts'); |
||||
9 | } |
||||
10 | |||||
11 | public function setup($app) |
||||
12 | { |
||||
13 | parent::setup($app); |
||||
14 | $app->post('/Actions/CreateGroup', array($this, 'createGroup')); |
||||
15 | $app->post('/Actions/NewGroup', array($this, 'newGroup')); |
||||
16 | $app->post('/Actions/DeleteGroup', array($this, 'deleteGroup')); |
||||
17 | $app->post('/Actions/RemoveGroupSignupLink', array($this, 'removeGroupLink')); |
||||
18 | $app->post('/{shift}/Actions/Signup[/]', array($this, 'signup')); |
||||
19 | $app->post('/{shift}/Actions/Abandon[/]', array($this, 'abandon')); |
||||
20 | $app->post('/{shift}/Actions/Approve[/]', array($this, 'approvePending')); |
||||
21 | $app->post('/{shift}/Actions/Disapprove[/]', array($this, 'disapprovePending')); |
||||
22 | $app->post('/{shift}/Actions/StartGroupSignup', array($this, 'startGroupSignup')); |
||||
23 | $app->post('/{shift}/Actions/GenerateGroupLink', array($this, 'generateGroupLink')); |
||||
24 | $app->post('/{shift}/Actions/EmptyShift[/]', array($this, 'emptyShift')); |
||||
25 | $app->post('/{shift}/Actions/ForceShiftEmpty[/]', array($this, 'forceEmpty')); |
||||
26 | } |
||||
27 | |||||
28 | protected function canCreate($request) |
||||
29 | { |
||||
30 | //Check is handled by validateCreate... |
||||
31 | return true; |
||||
32 | } |
||||
33 | |||||
34 | protected function canUpdate($request, $entity) |
||||
35 | { |
||||
36 | if($this->isVolunteerAdmin($request)) |
||||
37 | { |
||||
38 | return true; |
||||
39 | } |
||||
40 | return $this->isUserDepartmentLead($entity['departmentID'], $this->user); |
||||
41 | } |
||||
42 | |||||
43 | protected function canDelete($request, $entity) |
||||
44 | { |
||||
45 | return $this->canUpdate($request, $entity); |
||||
46 | } |
||||
47 | |||||
48 | protected function validateCreate(&$obj, $request) |
||||
49 | { |
||||
50 | if($this->isVolunteerAdmin($request)) |
||||
51 | { |
||||
52 | return true; |
||||
53 | } |
||||
54 | if(!isset($obj['departmentID'])) |
||||
55 | { |
||||
56 | return false; |
||||
57 | } |
||||
58 | if(isset($obj['unbounded']) && $obj['unbounded']) |
||||
59 | { |
||||
60 | if(!isset($obj['minShifts']) || $obj['minShifts'] === 0 || $obj['minShifts'] === '') |
||||
61 | { |
||||
62 | $obj['minShifts'] = '1'; |
||||
63 | } |
||||
64 | } |
||||
65 | return $this->isUserDepartmentLead($obj['departmentID'], $this->user); |
||||
66 | } |
||||
67 | |||||
68 | protected function processEntry($entry, $request) |
||||
69 | { |
||||
70 | return $this->processShift($entry, $request); |
||||
71 | } |
||||
72 | |||||
73 | protected function postUpdateAction($newObj, $request, $oldObj) |
||||
74 | { |
||||
75 | $oldShift = new \VolunteerShift(false, $oldObj); |
||||
76 | if($oldShift->isFilled() && ($oldObj['startTime'] != $newObj['startTime'] || $oldObj['endTime'] != $newObj['endTime'])) |
||||
77 | { |
||||
78 | $email = new \Emails\ShiftEmail($oldShift, 'shiftChangedSource'); |
||||
79 | $this->sendEmail($email); |
||||
80 | } |
||||
81 | return true; |
||||
82 | } |
||||
83 | |||||
84 | protected function postDeleteAction($entry) |
||||
85 | { |
||||
86 | if(empty($entry)) |
||||
87 | { |
||||
88 | return true; |
||||
89 | } |
||||
90 | $shift = new \VolunteerShift(false, $entry[0]); |
||||
91 | if($shift->isFilled()) |
||||
92 | { |
||||
93 | $email = new \Emails\ShiftEmail($shift, 'shiftCanceledSource'); |
||||
94 | $this->sendEmail($email); |
||||
95 | } |
||||
96 | return true; |
||||
97 | } |
||||
98 | |||||
99 | protected function genUUID() |
||||
100 | { |
||||
101 | return sprintf('%04x%04x-%04x-%04x-%04x-%04x%04x%04x', |
||||
102 | // 32 bits for "time_low" |
||||
103 | mt_rand(0, 0xffff), mt_rand(0, 0xffff), |
||||
104 | |||||
105 | // 16 bits for "time_mid" |
||||
106 | mt_rand(0, 0xffff), |
||||
107 | |||||
108 | // 16 bits for "time_hi_and_version", |
||||
109 | // four most significant bits holds version number 4 |
||||
110 | mt_rand(0, 0x0fff) | 0x4000, |
||||
111 | |||||
112 | // 16 bits, 8 bits for "clk_seq_hi_res", |
||||
113 | // 8 bits for "clk_seq_low", |
||||
114 | // two most significant bits holds zero and one for variant DCE1.1 |
||||
115 | mt_rand(0, 0x3fff) | 0x8000, |
||||
116 | |||||
117 | // 48 bits for "node" |
||||
118 | mt_rand(0, 0xffff), mt_rand(0, 0xffff), mt_rand(0, 0xffff) |
||||
119 | ); |
||||
120 | } |
||||
121 | |||||
122 | public function createGroup($request, $response) |
||||
123 | { |
||||
124 | $array = $request->getParsedBody(); |
||||
125 | $count = count($array); |
||||
126 | $entArray = array(); |
||||
127 | $uuid = $this->genUUID(); |
||||
128 | $dataTable = $this->getDataTable(); |
||||
129 | //User must be able to edit all shifts |
||||
130 | for($i = 0; $i < $count; $i++) |
||||
131 | { |
||||
132 | $filter = $this->getFilterForPrimaryKey($array[$i]); |
||||
133 | $entity = $dataTable->read($filter); |
||||
134 | if($entity === false || !isset($entity[0])) |
||||
135 | { |
||||
136 | return $response->withStatus(404); |
||||
137 | } |
||||
138 | $entity = $entity[0]; |
||||
139 | if(!$this->canUpdate($request, $entity)) |
||||
140 | { |
||||
141 | return $response->withStatus(401); |
||||
142 | } |
||||
143 | $entity['groupID'] = $uuid; |
||||
144 | array_push($entArray, $entity); |
||||
145 | } |
||||
146 | //If we got here we can update them all |
||||
147 | $myRet = true; |
||||
148 | $errors = array(); |
||||
149 | for($i = 0; $i < $count; $i++) |
||||
150 | { |
||||
151 | $filter = $this->getFilterForPrimaryKey($array[$i]); |
||||
152 | $ret = $dataTable->update($filter, $entArray[$i]); |
||||
153 | if($ret === false) |
||||
154 | { |
||||
155 | $myRet = false; |
||||
156 | array_push($errors, $array[$i]); |
||||
157 | } |
||||
158 | } |
||||
159 | if($myRet) |
||||
0 ignored issues
–
show
|
|||||
160 | { |
||||
161 | return $response->withJson($myRet); |
||||
162 | } |
||||
163 | else |
||||
164 | { |
||||
165 | return $response->withJson(array('res'=>$myRet, 'errors'=>$errors)); |
||||
166 | } |
||||
167 | } |
||||
168 | |||||
169 | public function newGroup($request, $response) |
||||
170 | { |
||||
171 | if(!$this->canCreate($request)) |
||||
172 | { |
||||
173 | return $response->withStatus(401); |
||||
174 | } |
||||
175 | $data = $request->getParsedBody(); |
||||
176 | $shift = array(); |
||||
177 | $shift['groupID'] = $this->genUUID(); |
||||
178 | $shift['departmentID'] = $data['groupDepartmentID']; |
||||
179 | $shift['earlyLate'] = $data['groupEarlyLate']; |
||||
180 | $shift['enabled'] = $data['groupEnabled']; |
||||
181 | $shift['approvalNeeded'] = $data['groupApprovalNeeded']; |
||||
182 | $shift['endTime'] = $data['groupEndTime']; |
||||
183 | $shift['eventID'] = $data['groupEvent']; |
||||
184 | $shift['name'] = $data['groupName']; |
||||
185 | $shift['startTime'] = $data['groupStartTime']; |
||||
186 | $dataTable = $this->getDataTable(); |
||||
187 | $ret = true; |
||||
188 | foreach($data['roles'] as $role=>$count) |
||||
189 | { |
||||
190 | $count = intval($count); |
||||
191 | for($i = 0; $i < $count; $i++) |
||||
192 | { |
||||
193 | $shift['roleID'] = $role; |
||||
194 | if($dataTable->create($shift) === false) |
||||
195 | { |
||||
196 | $ret = false; |
||||
197 | } |
||||
198 | } |
||||
199 | } |
||||
200 | return $response->withJSON($ret); |
||||
201 | } |
||||
202 | |||||
203 | public function deleteGroup($request, $response) |
||||
204 | { |
||||
205 | $data = $request->getParsedBody(); |
||||
206 | $dataTable = $this->getDataTable(); |
||||
207 | $filter = new \Data\Filter('groupID eq '.$data['groupID']); |
||||
208 | $entities = $dataTable->read($filter); |
||||
209 | if(empty($entities)) |
||||
210 | { |
||||
211 | return $response->withStatus(404); |
||||
212 | } |
||||
213 | if(!$this->canUpdate($request, $entities[0])) |
||||
214 | { |
||||
215 | return $response->withStatus(401); |
||||
216 | } |
||||
217 | $res = $dataTable->delete($filter); |
||||
218 | if($res) |
||||
219 | { |
||||
220 | return $response->withJSON($res); |
||||
221 | } |
||||
222 | return $response->withJSON($res, 500); |
||||
223 | } |
||||
224 | |||||
225 | protected function doSignup($uid, $status, $entity, $filter, $dataTable) |
||||
226 | { |
||||
227 | if(isset($entity['earlyLate']) && $entity['earlyLate'] !== '-1') |
||||
228 | { |
||||
229 | $event = new \VolunteerEvent($entity['eventID']); |
||||
230 | if(!$event->hasVolOnEEList($uid, intval($entity['earlyLate']))) |
||||
231 | { |
||||
232 | $status = 'pending'; |
||||
233 | $entity['needEEApproval'] = true; |
||||
234 | $event->addToEEList($uid, intval($entity['earlyLate'])); |
||||
235 | } |
||||
236 | } |
||||
237 | else if(isset($entity['approvalNeeded']) && $entity['approvalNeeded']) |
||||
238 | { |
||||
239 | $status = 'pending'; |
||||
240 | } |
||||
241 | $entity['participant'] = $uid; |
||||
242 | $entity['status'] = $status; |
||||
243 | $entity['signupTime'] = date('c'); |
||||
244 | return $dataTable->update($filter, $entity); |
||||
245 | } |
||||
246 | |||||
247 | public function signup($request, $response, $args) |
||||
248 | { |
||||
249 | $this->validateLoggedIn($request); |
||||
250 | $shiftId = $args['shift']; |
||||
251 | $dataTable = $this->getDataTable(); |
||||
252 | $filter = $this->getFilterForPrimaryKey($shiftId); |
||||
253 | $entity = $dataTable->read($filter); |
||||
254 | if(empty($entity)) |
||||
255 | { |
||||
256 | return $response->withStatus(404); |
||||
257 | } |
||||
258 | $entity = $entity[0]; |
||||
259 | if(isset($entity['participant']) && strlen($entity['participant']) > 0) |
||||
260 | { |
||||
261 | return $response->withStatus(401); |
||||
262 | } |
||||
263 | $shift = new \VolunteerShift($shiftId, $entity); |
||||
264 | $entity = $this->processShift($entity, $request); |
||||
265 | if(isset($entity['minShifts']) && $entity['minShifts'] > 0) |
||||
266 | { |
||||
267 | $shift->makeCopy($dataTable); |
||||
268 | } |
||||
269 | if(isset($entity['overlap']) && $entity['overlap']) |
||||
270 | { |
||||
271 | $overlaps = $shift->findOverlaps($this->user->uid); |
||||
272 | $count = count($overlaps); |
||||
0 ignored issues
–
show
It seems like
$overlaps can also be of type true ; however, parameter $var of count() does only seem to accept Countable|array , maybe add an additional type check?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||
273 | $leads = array(); |
||||
274 | for($i = 0; $i < $count; $i++) |
||||
275 | { |
||||
276 | $dept = new \VolunteerDepartment($overlaps[$i]->departmentID); |
||||
277 | $leads = array_merge($leads, $dept->getLeadEmails()); |
||||
278 | $overlaps[$i]->status = 'pending'; |
||||
279 | $tmp = new \Data\Filter('_id eq '.$overlaps[$i]->{'_id'}); |
||||
280 | $res = $dataTable->update($tmp, $overlaps[$i]); |
||||
281 | if($res === false) |
||||
282 | { |
||||
283 | return $response->withJSON(array('err'=>'Unable to update overlap with id '.$overlaps[$i]->{'_id'})); |
||||
284 | } |
||||
285 | } |
||||
286 | $dept = new \VolunteerDepartment($entity['departmentID']); |
||||
287 | $leads = array_merge($leads, $dept->getLeadEmails()); |
||||
288 | $leads = array_unique($leads); |
||||
289 | $ret = $this->doSignup($this->user->uid, 'pending', $entity, $filter, $dataTable); |
||||
290 | $profile = new \VolunteerProfile($this->user->uid); |
||||
291 | $email = new \Emails\TwoShiftsAtOnceEmail($profile); |
||||
292 | $email->addLeads($leads); |
||||
293 | $emailProvider = \EmailProvider::getInstance(); |
||||
294 | if($emailProvider->sendEmail($email) === false) |
||||
295 | { |
||||
296 | throw new \Exception('Unable to send duplicate email!'); |
||||
297 | } |
||||
298 | return $response->withJSON($ret); |
||||
299 | } |
||||
300 | if(isset($entity['available']) && $entity['available']) |
||||
301 | { |
||||
302 | $ret = $this->doSignup($this->user->uid, 'filled', $entity, $filter, $dataTable); |
||||
303 | return $response->withJSON($ret); |
||||
304 | } |
||||
305 | if(isset($entity['status']) && $entity['status'] === 'groupPending') |
||||
306 | { |
||||
307 | $ret = $this->doSignup($this->user->uid, 'filled', $entity, $filter, $dataTable); |
||||
308 | return $response->withJSON($ret); |
||||
309 | } |
||||
310 | print_r($entity); die(); |
||||
0 ignored issues
–
show
|
|||||
311 | } |
||||
312 | |||||
313 | public function abandon($request, $response, $args) |
||||
314 | { |
||||
315 | $this->validateLoggedIn($request); |
||||
316 | $shiftId = $args['shift']; |
||||
317 | $dataTable = $this->getDataTable(); |
||||
318 | $filter = $this->getFilterForPrimaryKey($shiftId); |
||||
319 | $entity = $dataTable->read($filter); |
||||
320 | if(empty($entity)) |
||||
321 | { |
||||
322 | return $response->withStatus(404); |
||||
323 | } |
||||
324 | $entity = $entity[0]; |
||||
325 | if(!isset($entity['participant']) || $entity['participant'] !== $this->user->uid) |
||||
326 | { |
||||
327 | return $response->withStatus(401); |
||||
328 | } |
||||
329 | $entity['participant'] = ''; |
||||
330 | $entity['status'] = 'unfilled'; |
||||
331 | $entity['signupTime'] = ''; |
||||
332 | if(isset($entity['needEEApproval'])) |
||||
333 | { |
||||
334 | unset($entity['needEEApproval']); |
||||
335 | } |
||||
336 | return $response->withJSON($dataTable->update($filter, $entity)); |
||||
337 | } |
||||
338 | |||||
339 | public function approvePending($request, $response, $args) |
||||
340 | { |
||||
341 | if(!$this->canCreate($request)) |
||||
342 | { |
||||
343 | return $response->withStatus(401); |
||||
344 | } |
||||
345 | $shiftId = $args['shift']; |
||||
346 | $dataTable = $this->getDataTable(); |
||||
347 | $filter = $this->getFilterForPrimaryKey($shiftId); |
||||
348 | $entity = $dataTable->read($filter); |
||||
349 | if(empty($entity)) |
||||
350 | { |
||||
351 | return $response->withStatus(404); |
||||
352 | } |
||||
353 | $entity = $entity[0]; |
||||
354 | $entity['status'] = 'filled'; |
||||
355 | return $response->withJSON($dataTable->update($filter, $entity)); |
||||
356 | } |
||||
357 | |||||
358 | public function disapprovePending($request, $response, $args) |
||||
359 | { |
||||
360 | if(!$this->canCreate($request)) |
||||
361 | { |
||||
362 | return $response->withStatus(401); |
||||
363 | } |
||||
364 | $shiftId = $args['shift']; |
||||
365 | $dataTable = $this->getDataTable(); |
||||
366 | $filter = $this->getFilterForPrimaryKey($shiftId); |
||||
367 | $entity = $dataTable->read($filter); |
||||
368 | if(empty($entity)) |
||||
369 | { |
||||
370 | return $response->withStatus(404); |
||||
371 | } |
||||
372 | $entity['participant'] = ''; |
||||
373 | $entity['status'] = 'unfilled'; |
||||
374 | $profile = new \VolunteerProfile($this->user->uid); |
||||
375 | $email = new \Emails\PendingRejectedEmail($profile); |
||||
376 | $email->setShift($entity); |
||||
377 | $this->sendEmail($email); |
||||
378 | return $response->withJSON($dataTable->update($filter, $entity)); |
||||
379 | } |
||||
380 | |||||
381 | public function startGroupSignup($request, $response, $args) |
||||
382 | { |
||||
383 | $this->validateLoggedIn($request); |
||||
384 | $shiftId = $args['shift']; |
||||
385 | $dataTable = $this->getDataTable(); |
||||
386 | $filter = $this->getFilterForPrimaryKey($shiftId); |
||||
387 | $entity = $dataTable->read($filter); |
||||
388 | if(empty($entity)) |
||||
389 | { |
||||
390 | return $response->withStatus(404); |
||||
391 | } |
||||
392 | $entity = $entity[0]; |
||||
393 | if(isset($entity['participant']) && strlen($entity['participant']) > 0) |
||||
394 | { |
||||
395 | return $response->withStatus(401); |
||||
396 | } |
||||
397 | $filter = new \Data\Filter('groupID eq '.$entity['groupID'].' and enabled eq true'); |
||||
398 | $entities = $dataTable->read($filter); |
||||
399 | $count = count($entities); |
||||
0 ignored issues
–
show
It seems like
$entities can also be of type boolean ; however, parameter $var of count() does only seem to accept Countable|array , maybe add an additional type check?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||
400 | $dept = new \VolunteerDepartment($entity['departmentID']); |
||||
401 | $res = array(); |
||||
402 | $res['department'] = $dept->departmentName; |
||||
0 ignored issues
–
show
The property
departmentName does not exist on VolunteerDepartment . Since you implemented __get , consider adding a @property annotation.
![]() |
|||||
403 | $res['earlyLate'] = $entity['earlyLate']; |
||||
404 | $res['endTime'] = $entity['endTime']; |
||||
405 | $res['eventID'] = $entity['eventID']; |
||||
406 | $res['name'] = $entity['name']; |
||||
407 | $res['startTime'] = $entity['startTime']; |
||||
408 | $res['groupID'] = $entity['groupID']; |
||||
409 | $res['shifts'] = array(); |
||||
410 | $roles = array(); |
||||
411 | for($i = 0; $i < $count; $i++) |
||||
412 | { |
||||
413 | if(isset($entities[$i]['status']) && ($entities[$i]['status'] === 'filled' || $entities[$i]['status'] === 'pending')) |
||||
414 | { |
||||
415 | continue; |
||||
416 | } |
||||
417 | if(!isset($roles[$entities[$i]['roleID']])) |
||||
418 | { |
||||
419 | $roles[$entities[$i]['roleID']] = new \VolunteerRole($entities[$i]['roleID']); |
||||
420 | } |
||||
421 | $role = $roles[$entities[$i]['roleID']]; |
||||
422 | $entities[$i]['role'] = $role->display_name; |
||||
423 | array_push($res['shifts'], $entities[$i]); |
||||
424 | } |
||||
425 | return $response->withJSON($res); |
||||
426 | } |
||||
427 | |||||
428 | public function generateGroupLink($request, $response, $args) |
||||
429 | { |
||||
430 | $this->validateLoggedIn($request); |
||||
431 | $shiftId = $args['shift']; |
||||
432 | $dataTable = $this->getDataTable(); |
||||
433 | $filter = $this->getFilterForPrimaryKey($shiftId); |
||||
434 | $entity = $dataTable->read($filter); |
||||
435 | if(empty($entity)) |
||||
436 | { |
||||
437 | return $response->withStatus(404); |
||||
438 | } |
||||
439 | $entity = $entity[0]; |
||||
440 | if(isset($entity['participant']) && strlen($entity['participant']) > 0) |
||||
441 | { |
||||
442 | return $response->withStatus(401); |
||||
443 | } |
||||
444 | $data = $request->getParsedBody(); |
||||
445 | $myShift = $data['myshift']; |
||||
446 | $roles = array(); |
||||
447 | foreach($data as $key => $value) |
||||
448 | { |
||||
449 | if(substr($key, 0, 6) === "roles.") |
||||
450 | { |
||||
451 | $roles[substr($key, 6)] = $value; |
||||
452 | } |
||||
453 | } |
||||
454 | $filter = new \Data\Filter('groupID eq '.$entity['groupID'].' and enabled eq true'); |
||||
455 | $entities = $dataTable->read($filter); |
||||
456 | $count = count($entities); |
||||
0 ignored issues
–
show
It seems like
$entities can also be of type boolean ; however, parameter $var of count() does only seem to accept Countable|array , maybe add an additional type check?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||
457 | $uuid = $this->genUUID(); |
||||
458 | $time = date('c'); |
||||
459 | for($i = 0; $i < $count; $i++) |
||||
460 | { |
||||
461 | if(isset($entities[$i]['status']) && ($entities[$i]['status'] === 'filled' || $entities[$i]['status'] === 'pending')) |
||||
462 | { |
||||
463 | $entities[$i] = false; |
||||
464 | continue; |
||||
465 | } |
||||
466 | if((string)$entities[$i]['_id'] === (string)new \MongoDB\BSON\ObjectId($myShift)) |
||||
467 | { |
||||
468 | $entities[$i]['participant'] = $this->user->uid; |
||||
469 | $entities[$i]['status'] = 'filled'; |
||||
470 | $entities[$i]['signupLink'] = $uuid; |
||||
471 | $entities[$i]['groupLinkCreated'] = $time; |
||||
472 | $entities[$i]['signupOn'] = $time; |
||||
473 | } |
||||
474 | else if(isset($roles[$entities[$i]['roleID']])) |
||||
475 | { |
||||
476 | $entities[$i]['status'] = 'groupPending'; |
||||
477 | $entities[$i]['signupLink'] = $uuid; |
||||
478 | $entities[$i]['groupLinkCreated'] = $time; |
||||
479 | $roles[$entities[$i]['roleID']]--; |
||||
480 | if($roles[$entities[$i]['roleID']] === 0) |
||||
481 | { |
||||
482 | unset($roles[$entities[$i]['roleID']]); |
||||
483 | } |
||||
484 | } |
||||
485 | else |
||||
486 | { |
||||
487 | $entities[$i] = false; |
||||
488 | } |
||||
489 | } |
||||
490 | if(count($roles) !== 0) |
||||
491 | { |
||||
492 | throw new \Exception('Not enough shifts to fullfill requests'); |
||||
493 | } |
||||
494 | for($i = 0; $i < $count; $i++) |
||||
495 | { |
||||
496 | if($entities[$i] === false) |
||||
497 | { |
||||
498 | continue; |
||||
499 | } |
||||
500 | $filter = new \Data\Filter('_id eq '.$entities[$i]['_id']); |
||||
501 | $res = $dataTable->update($filter, $entities[$i]); |
||||
502 | if($res === false) |
||||
503 | { |
||||
504 | throw new \Exception('Not able to save shift '.$entities[$i]['_id']); |
||||
505 | } |
||||
506 | } |
||||
507 | return $response->withJSON(array('uuid' => $uuid)); |
||||
508 | } |
||||
509 | |||||
510 | public function removeGroupLink($request, $response, $args) |
||||
0 ignored issues
–
show
The parameter
$args is not used and could be removed.
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
This check looks for parameters that have been defined for a function or method, but which are not used in the method body. ![]() |
|||||
511 | { |
||||
512 | if(!$this->canCreate($request)) |
||||
513 | { |
||||
514 | return $response->withStatus(401); |
||||
515 | } |
||||
516 | $data = $this->getParsedBody($request); |
||||
517 | if(!isset($data['groupID'])) |
||||
518 | { |
||||
519 | return $response->withStatus(400); |
||||
520 | } |
||||
521 | $groupID = $data['groupID']; |
||||
522 | $dataTable = $this->getDataTable(); |
||||
523 | $filter = new \Data\Filter("groupID eq '$groupID'"); |
||||
524 | $entity = $dataTable->read($filter); |
||||
525 | if(empty($entity)) |
||||
526 | { |
||||
527 | return $response->withStatus(404); |
||||
528 | } |
||||
529 | $count = count($entity); |
||||
0 ignored issues
–
show
It seems like
$entity can also be of type boolean ; however, parameter $var of count() does only seem to accept Countable|array , maybe add an additional type check?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||
530 | $res = true; |
||||
531 | for($i = 0; $i < $count; $i++) |
||||
532 | { |
||||
533 | $entity[$i]['signupLink'] = ''; |
||||
534 | if($entity[$i]['status'] === 'groupPending') |
||||
535 | { |
||||
536 | $entity['status'] = 'unfilled'; |
||||
537 | } |
||||
538 | $entity[$i]['groupLinkCreated'] = ''; |
||||
539 | $upFilter = new \Data\Filter('_id eq '.$entity[$i]['_id']); |
||||
540 | $tmp = $dataTable->update($upFilter, $entity[$i]); |
||||
541 | if($tmp === false) |
||||
542 | { |
||||
543 | $res = false; |
||||
544 | } |
||||
545 | } |
||||
546 | return $response->withJSON($res); |
||||
547 | } |
||||
548 | |||||
549 | function emptyShift($request, $response, $args) |
||||
0 ignored issues
–
show
|
|||||
550 | { |
||||
551 | $this->validateLoggedIn($request); |
||||
552 | $shiftId = $args['shift']; |
||||
553 | $dataTable = $this->getDataTable(); |
||||
554 | $filter = $this->getFilterForPrimaryKey($shiftId); |
||||
555 | $entity = $dataTable->read($filter); |
||||
556 | if(empty($entity)) |
||||
557 | { |
||||
558 | return $response->withStatus(404); |
||||
559 | } |
||||
560 | $entity = $entity[0]; |
||||
561 | if(!$this->canUpdate($request, $entity)) |
||||
562 | { |
||||
563 | return $response->withStatus(401); |
||||
564 | } |
||||
565 | $shift = new \VolunteerShift(false, $entity); |
||||
566 | $entity['participant'] = ''; |
||||
567 | $entity['status'] = 'unfilled'; |
||||
568 | if(isset($entity['needEEApproval'])) |
||||
569 | { |
||||
570 | unset($entity['needEEApproval']); |
||||
571 | } |
||||
572 | $ret = $dataTable->update($filter, $entity); |
||||
573 | if($ret) |
||||
574 | { |
||||
575 | $email = new \Emails\ShiftEmail($shift, 'shiftEmptiedSource'); |
||||
576 | $this->sendEmail($email); |
||||
577 | } |
||||
578 | return $response->withJSON($ret); |
||||
579 | } |
||||
580 | |||||
581 | function forceEmpty($request, $response, $args) |
||||
0 ignored issues
–
show
|
|||||
582 | { |
||||
583 | $this->validateLoggedIn($request); |
||||
584 | $shiftId = $args['shift']; |
||||
585 | $dataTable = $this->getDataTable(); |
||||
586 | $filter = $this->getFilterForPrimaryKey($shiftId); |
||||
587 | $entity = $dataTable->read($filter); |
||||
588 | if(empty($entity)) |
||||
589 | { |
||||
590 | return $response->withStatus(404); |
||||
591 | } |
||||
592 | $entity = $entity[0]; |
||||
593 | if(!$this->canUpdate($request, $entity)) |
||||
594 | { |
||||
595 | return $response->withStatus(401); |
||||
596 | } |
||||
597 | $entity['participant'] = ''; |
||||
598 | $entity['status'] = 'unfilled'; |
||||
599 | if(isset($entity['needEEApproval'])) |
||||
600 | { |
||||
601 | unset($entity['needEEApproval']); |
||||
602 | } |
||||
603 | return $response->withJSON($dataTable->update($filter, $entity)); |
||||
604 | } |
||||
605 | } |
||||
606 | /* vim: set tabstop=4 shiftwidth=4 expandtab: */ |
||||
607 |