$value ) { $filter .= ", `RID`=" . sql_escape($value) . " "; } } //filterTask (Array of integer) - Array if Task (optional, for list request) if (isset($_REQUEST['filterTask']) && is_array($_REQUEST['filterTask']) ) { foreach ( $_REQUEST['filterTask'] as $key => $value ) { // TODO $filter .= ", `RID`=" . sql_escape($value) . " "; } } // filterOccupancy (integer) - Occupancy state: (optional, for list request) // 1 occupied, 2 free, 3 occupied and free if (isset($_REQUEST['filterOccupancy']) && is_array($_REQUEST['filterOccupancy']) ) { foreach ( $_REQUEST['filterOccupancy'] as $key => $value ) { // TODO $filter .= ", `RID`=" . sql_escape($value) . " "; } } // format filter if( $filter != "" ) { $filter = ' WHERE '. substr($filter, 1); } // real request $shifts_source = sql_select("SELECT `SID` FROM `Shifts`". $filter); if ($shifts_source === false) return false; if (count($shifts_source) > 0) { return $shifts_source; } return null; } /** * Returns Shift by id. * * @param $id Shift ID */ function Shift($id) { $shifts_source = sql_select("SELECT * FROM `Shifts` WHERE `SID`=" . sql_escape($id) . " LIMIT 1"); $shiftsEntry_source = sql_select("SELECT `TID` , `UID` , `freeloaded` FROM `ShiftEntry` WHERE `SID`=" . sql_escape($id) ); if ($shifts_source === false) return false; if (count($shifts_source) > 0) { $result = $shifts_source[0]; $result['ShiftEntry'] = $shiftsEntry_source; $temp = NeededAngelTypes_by_shift($id); foreach( $temp as $e) { $result['NeedAngels'][] = array ( 'TID' => $e['angel_type_id'], 'count' => $e['count'], 'restricted' => $e['restricted'], 'taken' => $e['taken'] ); } return $result; } return null; } /** * Returns all shifts with needed angeltypes and count of subscribed jobs. */ function Shifts() { $shifts_source = sql_select(" SELECT `Shifts`.*, `Room`.`RID`, `Room`.`Name` as `room_name` FROM `Shifts` JOIN `Room` ON `Room`.`RID` = `Shifts`.`RID` "); if ($shifts_source === false) return false; foreach ($shifts_source as &$shift) { $needed_angeltypes = NeededAngelTypes_by_shift($shift['SID']); if ($needed_angeltypes === false) return false; $shift['angeltypes'] = $needed_angeltypes; } return $shifts_source; } ?>