, * Andreas Oesterreicher and * Rudolf Hangl . */ /** * Klasse Zeitaufzeichnung * @create 06-11-2007 */ require_once(dirname(__FILE__).'/basis_db.class.php'); class zeitaufzeichnung extends basis_db { public $new; // boolean public $result = array(); // zeitaufzeichnung Objekt public $done=false; // boolean //Tabellenspalten public $zeitaufzeichnung_id; // serial public $uid; // varchar(16) public $aktivitaet_kurzbz; // varchar(16) public $start; // timestamp public $ende; // timestamp public $beschreibung; // varchar(256) public $oe_kurzbz_1; // varchar(32) ehemals studiengangs_kz public $oe_kurzbz_2; // varchar(32) ehemals fachbereich_kurzbz public $insertamum; // timestamp public $insertvon; // varchar(16) public $updateamum; // timestamp public $updatevon; // varchar(16) public $projekt_kurzbz; // varchar(16) public $projektphase_id; // bigint public $ext_id; // bigint public $service_id; // integer public $kunde_uid; // varchar(32) public $homeoffice; // bool /** * Konstruktor * @param $zeitaufzeichnung_id ID der Zeitaufzeichnung die geladen werden soll (Default=null) */ public function __construct($zeitaufzeichnung_id=null) { parent::__construct(); if($zeitaufzeichnung_id != null) $this->load($zeitaufzeichnung_id); } /** * Laedt die Zeitaufzeichnung mit der ID $zeitaufzeichnung_id * @param $adress_id ID der zu ladenden Adresse * @return true wenn ok, false im Fehlerfall */ public function load($zeitaufzeichnung_id) { //Pruefen ob zeitaufzeichnung_id eine gueltige Zahl ist if(!is_numeric($zeitaufzeichnung_id) || $zeitaufzeichnung_id == '') { $this->errormsg = 'Zeitaufzeichnung_id muss eine Zahl sein'; return false; } //Daten aus der Datenbank lesen $qry = "SELECT * FROM campus.tbl_zeitaufzeichnung WHERE zeitaufzeichnung_id=".$this->db_add_param($zeitaufzeichnung_id, FHC_INTEGER); if(!$this->db_query($qry)) { $this->errormsg = 'Fehler bei einer Datenbankabfrage'; return false; } if($row = $this->db_fetch_object()) { $this->zeitaufzeichnung_id = $row->zeitaufzeichnung_id; $this->uid = $row->uid; $this->aktivitaet_kurzbz = $row->aktivitaet_kurzbz; $this->start = $row->start; $this->ende = $row->ende; $this->beschreibung = $row->beschreibung; $this->oe_kurzbz_1 = $row->oe_kurzbz_1; $this->oe_kurzbz_2 = $row->oe_kurzbz_2; $this->insertamum = $row->insertamum; $this->insertvon = $row->insertvon; $this->updateamum = $row->updateamum; $this->updatevon = $row->updatevon; $this->projekt_kurzbz = $row->projekt_kurzbz; $this->projektphase_id = $row->projektphase_id; $this->ext_id = $row->ext_id; $this->service_id = $row->service_id; $this->kunde_uid = $row->kunde_uid; $this->homeoffice = $row->homeoffice; } else { $this->errormsg = 'Es ist kein Datensatz mit dieser ID vorhanden'; return false; } return true; } /** * Prueft die Variablen auf Gueltigkeit * @return true wenn ok, false im Fehlerfall */ protected function validate() { $this->errormsg = ''; return true; } /** * Speichert den aktuellen Datensatz in die Datenbank * Wenn $neu auf true gesetzt ist wird ein neuer Datensatz angelegt * andernfalls wird der Datensatz mit der ID in $adresse_id aktualisiert * @return true wenn ok, false im Fehlerfall */ public function save() { //Variablen pruefen if(!$this->validate()) return false; // check ob identischer eintrag existiert // DienstreiseMT-Einträge sind hier ausgenommen da eintägige Dienstreisen mit der identen Arbeitszeit eingetragen werden könnten if ($this->aktivitaet_kurzbz != 'DienstreiseMT') { $check_qry = 'SELECT count(*) from campus.tbl_zeitaufzeichnung where uid='.$this->db_add_param($this->uid).' and aktivitaet_kurzbz != \'DienstreiseMT\' and start = '.$this->db_add_param($this->start).' and ende = '.$this->db_add_param($this->ende); if($this->db_query($check_qry) && $this->new) { if($row = $this->db_fetch_object()) { if ($row->count) { $this->errormsg = 'Identischer Eintrag existiert!'; return false; } } } } // ER - Checks if ($this->aktivitaet_kurzbz == 'Ersatzruhe') { $check_qry = "SELECT count(*) from campus.tbl_zeitaufzeichnung where uid=".$this->db_add_param($this->uid)." and (start < ".$this->db_add_param($this->ende)." and ende > ".$this->db_add_param($this->start).")"; if ($this->zeitaufzeichnung_id) $check_qry .= " and zeitaufzeichnung_id != ".$this->db_add_param($this->zeitaufzeichnung_id); if($this->db_query($check_qry)) { if($row = $this->db_fetch_object()) { if ($row->count) { $this->errormsg = 'Ersatzruhe darf nicht Überlappen!'; return false; } } } } if ($this->aktivitaet_kurzbz != 'Ersatzruhe' && $this->aktivitaet_kurzbz != 'DienstreiseMT') { $check_qry = "SELECT count(*) from campus.tbl_zeitaufzeichnung where uid=".$this->db_add_param($this->uid)." and (aktivitaet_kurzbz != 'DienstreiseMT' or aktivitaet_kurzbz IS NULL ) and (start < ".$this->db_add_param($this->ende)." and ende > ".$this->db_add_param($this->start).")"; if($this->db_query($check_qry)) { if($row = $this->db_fetch_object()) { if ($this->new) { if ($row->count) { $this->errormsg = 'Einträge dürfen nicht Überlappen!'; return false; } } else { if ($row->count > 1) { $this->errormsg = 'Einträge dürfen nicht Überlappen!'; return false; } } } } } if($this->new) { //Neuen Datensatz einfuegen $qry='BEGIN;INSERT INTO campus.tbl_zeitaufzeichnung (uid, aktivitaet_kurzbz, start, ende, beschreibung, oe_kurzbz_1, oe_kurzbz_2, insertamum, insertvon, updateamum, updatevon, projekt_kurzbz, projektphase_id, service_id, homeoffice, kunde_uid) VALUES('. $this->db_add_param($this->uid).', '. $this->db_add_param($this->aktivitaet_kurzbz).', '. $this->db_add_param($this->start).', '. $this->db_add_param($this->ende).', '. $this->db_add_param($this->beschreibung).', '. $this->db_add_param($this->oe_kurzbz_1).', '. $this->db_add_param($this->oe_kurzbz_2).','. $this->db_add_param($this->insertamum).', '. $this->db_add_param($this->insertvon).', '. $this->db_add_param($this->updateamum).', '. $this->db_add_param($this->updatevon).', '. $this->db_add_param($this->projekt_kurzbz).', '. $this->db_add_param($this->projektphase_id, FHC_INTEGER).', '. $this->db_add_param($this->service_id).', '. $this->db_add_param($this->homeoffice, FHC_BOOLEAN).', '. $this->db_add_param($this->kunde_uid).');'; } else { //Updaten des bestehenden Datensatzes //Pruefen ob zeitaufzeichnung_id eine gueltige Zahl ist if(!is_numeric($this->zeitaufzeichnung_id)) { $this->errormsg = 'zeitaufzeichnung_id muss eine gueltige Zahl sein'; return false; } $qry='UPDATE campus.tbl_zeitaufzeichnung SET'. ' uid='.$this->db_add_param($this->uid).', '. ' aktivitaet_kurzbz='.$this->db_add_param($this->aktivitaet_kurzbz).', '. ' start='.$this->db_add_param($this->start).', '. ' ende='.$this->db_add_param($this->ende).', '. ' beschreibung='.$this->db_add_param($this->beschreibung).', '. ' oe_kurzbz_1='.$this->db_add_param($this->oe_kurzbz_1).', '. ' oe_kurzbz_2='.$this->db_add_param($this->oe_kurzbz_2).', '. ' updateamum='.$this->db_add_param($this->updateamum).', '. ' updatevon='.$this->db_add_param($this->updatevon).', '. ' projekt_kurzbz='.$this->db_add_param($this->projekt_kurzbz).', '. ' projektphase_id='.$this->db_add_param($this->projektphase_id, FHC_INTEGER).', '. ' service_id='.$this->db_add_param($this->service_id).', '. ' homeoffice ='.$this->db_add_param($this->homeoffice, FHC_BOOLEAN).', '. ' kunde_uid='.$this->db_add_param($this->kunde_uid).' '. 'WHERE zeitaufzeichnung_id='.$this->db_add_param($this->zeitaufzeichnung_id, FHC_INTEGER, false); } if($this->db_query($qry)) { if($this->new) { //naechste ID aus der Sequence holen $qry="SELECT currval('campus.tbl_zeitaufzeichnung_zeitaufzeichnung_id_seq') as id;"; if($this->db_query($qry)) { if($row = $this->db_fetch_object()) { $this->zeitaufzeichnung_id = $row->id; $this->db_query('COMMIT'); return true; } else { $this->db_query('ROLLBACK'); $this->errormsg = "Fehler beim Auslesen der Sequence"; return false; } } else { $this->db_query('ROLLBACK'); $this->errormsg = 'Fehler beim Auslesen der Sequence'; return false; } } } else { $this->errormsg = 'Fehler beim Speichern'; return false; } return true; } /** * Loescht den Datenensatz mit der ID die uebergeben wird * @param $zeitaufzeichnnung_id ID die geloescht werden soll * @return true wenn ok, false im Fehlerfall */ public function delete($zeitaufzeichnung_id) { //Pruefen ob zeitaufzeichnung_id eine gueltige Zahl ist if(!is_numeric($zeitaufzeichnung_id) || $zeitaufzeichnung_id == '') { $this->errormsg = 'zeitaufzeichnung_id muss eine gueltige Zahl sein'; return false; } //loeschen des Datensatzes $qry="DELETE FROM campus.tbl_zeitaufzeichnung WHERE zeitaufzeichnung_id=".$this->db_add_param($zeitaufzeichnung_id, FHC_INTEGER, false); if($this->db_query($qry)) { return true; } else { $this->errormsg = 'Fehler beim Loeschen der Daten'; return false; } } /** * Laedt die Datensaetze eines Projektes * @param $projekt_kurzbz */ public function getListeProjekt($projekt_kurzbz) { $where = 'projekt_kurzbz='.$this->db_add_param($projekt_kurzbz); $qry = "SELECT *, to_char ((ende-start),'HH24:MI') as diff, (SELECT (to_char(sum(ende-start),'DD')::integer)*24+to_char(sum(ende-start),'HH24')::integer || ':' || to_char(sum(ende-start),'MI') FROM campus.tbl_zeitaufzeichnung WHERE $where ) as summe FROM campus.tbl_zeitaufzeichnung WHERE $where ORDER BY start DESC"; if($result = $this->db_query($qry)) { while($row = $this->db_fetch_object($result)) { $obj = new zeitaufzeichnung(); $obj->zeitaufzeichnung_id = $row->zeitaufzeichnung_id; $obj->uid = $row->uid; $obj->aktivitaet_kurzbz = $row->aktivitaet_kurzbz; $obj->start = $row->start; $obj->ende = $row->ende; $obj->beschreibung = $row->beschreibung; $obj->oe_kurzbz_1 = $row->oe_kurzbz_1; $obj->oe_kurzbz_2 = $row->oe_kurzbz_2; $obj->insertamum = $row->insertamum; $obj->insertvon = $row->insertvon; $obj->updateamum = $row->updateamum; $obj->updatevon = $row->updatevon; $obj->projekt_kurzbz = $row->projekt_kurzbz; $obj->projektphase_id = $row->projektphase_id; $obj->homeoffice = $row->homeoffice; $obj->ext_id = $row->ext_id; $obj->service_id = $row->service_id; $obj->kunde_uid = $row->kunde_uid; $obj->summe = $row->summe; $obj->diff = $row->diff; $this->result[] = $obj; } return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Laedt die Zeitaufzeichnungen eines Users in einer festgelegten Zeitspanne * @param $user * @param $from startdatum als String in Form Y-m-d * @param $to enddatum als String in Form Y-m-d * @param $excluded_activities zu ignorierende Aktivitätstypen * @return bool */ public function getListeUserFromTo($user, $from = null, $to = null, $excluded_activities = null) { $where = "uid=".$this->db_add_param($user); //standard wenn kein Datum gegeben - letzter Monat if(empty($from) && empty($to)) { $from = date('Y-m-d', strtotime('first day of previous month')); $to = date('Y-m-d', strtotime('last day of previous month')); } else if(empty($to))//standard wenn ein Datum gegeben - datum +/- 40 tage $to = date('Y-m-d', strtotime($from. ' + 40 days')); else if(empty($from)) $from = date('Y-m-d', strtotime($to. ' - 40 days')); //zusätzlicher Tag - SQL rechnet letzten Tag nicht hinein $to = date('Y-m-d', strtotime($to. ' + 1 days')); $where.= " AND ((start >= ".$this->db_add_param($from)."::DATE AND start <= ".$this->db_add_param($to)."::DATE) OR (ende >= ".$this->db_add_param($from)."::DATE AND ende <= ".$this->db_add_param($to)."::DATE))"; if (!empty($excluded_activities)) { $exactstring = is_array($excluded_activities) ? $this->db_implode4SQL($excluded_activities) : $this->db_add_param($excluded_activities); $where .= " AND (aktivitaet_kurzbz NOT IN (" . $exactstring . ") OR aktivitaet_kurzbz IS NULL)"; } $qry = "SELECT *, to_char ((ende-start),'HH24:MI') as diff, (SELECT (to_char(sum(ende-start),'DD')::integer)*24+to_char(sum(ende-start),'HH24')::integer || ':' || to_char(sum(ende-start),'MI') FROM campus.tbl_zeitaufzeichnung WHERE $where ) as summe FROM campus.tbl_zeitaufzeichnung WHERE $where ORDER BY start DESC"; if($result = $this->db_query($qry)) { while($row = $this->db_fetch_object($result)) { $obj = new zeitaufzeichnung(); $obj->zeitaufzeichnung_id = $row->zeitaufzeichnung_id; $obj->uid = $row->uid; $obj->aktivitaet_kurzbz = $row->aktivitaet_kurzbz; $obj->start = $row->start; $obj->ende = $row->ende; $obj->beschreibung = $row->beschreibung; $obj->oe_kurzbz_1 = $row->oe_kurzbz_1; $obj->oe_kurzbz_2 = $row->oe_kurzbz_2; $obj->insertamum = $row->insertamum; $obj->insertvon = $row->insertvon; $obj->updateamum = $row->updateamum; $obj->updatevon = $row->updatevon; $obj->projekt_kurzbz = $row->projekt_kurzbz; $obj->projektphase_id = $row->projektphase_id; $obj->homeoffice = $row->homeoffice; $obj->ext_id = $row->ext_id; $obj->service_id = $row->service_id; $obj->kunde_uid = $row->kunde_uid; $obj->summe = $row->summe; $obj->diff = $row->diff; $obj->datum = $row->start; $this->result[] = $obj; } return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Laedt die Zeitaufzeichnungen eines Users. Default: Die letzten 40 Tage * @param string $user * @param integer $days default: 40 Tage */ public function getListeUser($user, $days='40') { $where = "uid=".$this->db_add_param($user); if ($days!='') $where.= " AND start>(now() - INTERVAL '".$days." days')"; $qry = "SELECT *, CASE WHEN (ende IS NOT NULL AND ende > start) THEN to_char ((ende-start),'HH24:MI') ELSE '0' END as diff, (SELECT (to_char(sum(ende-start),'DD')::integer)*24+to_char(sum(ende-start),'HH24')::integer || ':' || to_char(sum(ende-start),'MI') FROM campus.tbl_zeitaufzeichnung WHERE $where ) as summe FROM campus.tbl_zeitaufzeichnung WHERE $where ORDER BY start DESC"; if($result = $this->db_query($qry)) { while($row = $this->db_fetch_object($result)) { $obj = new zeitaufzeichnung(); $obj->zeitaufzeichnung_id = $row->zeitaufzeichnung_id; $obj->uid = $row->uid; $obj->aktivitaet_kurzbz = $row->aktivitaet_kurzbz; $obj->start = $row->start; $obj->ende = $row->ende; $obj->beschreibung = $row->beschreibung; $obj->oe_kurzbz_1 = $row->oe_kurzbz_1; $obj->oe_kurzbz_2 = $row->oe_kurzbz_2; $obj->insertamum = $row->insertamum; $obj->insertvon = $row->insertvon; $obj->updateamum = $row->updateamum; $obj->updatevon = $row->updatevon; $obj->projekt_kurzbz = $row->projekt_kurzbz; $obj->projektphase_id = $row->projektphase_id; $obj->homeoffice = $row->homeoffice; $obj->ext_id = $row->ext_id; $obj->service_id = $row->service_id; $obj->kunde_uid = $row->kunde_uid; $obj->summe = $row->summe; $obj->diff = $row->diff; $obj->datum = $row->start; $this->result[] = $obj; } return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Laedt die Zeitaufzeichnungen eines Users aufgefüllt mit lehren Tagen. * Default: Die letzten 40 Tage * @param string $user * @param integer $days deafult: 40 Tage */ public function getListeUserFull($user, $days='40') { $where = "uid=".$this->db_add_param($user); if ($days!='') $where.= " AND ende>(now() - INTERVAL '".$days." days')"; $where_join = "and (z.aktivitaet_kurzbz != 'DienstreiseMT' or z.aktivitaet_kurzbz is null) and z.uid=".$this->db_add_param($user); if ($days!='') $where_join.= " AND z.ende>(now() - INTERVAL '".$days." days')"; if ($days=='') $max_anz = 180; else $max_anz = $days; $qry = "SELECT d.dates, z.*, to_char ((z.ende-z.start),'HH24:MI') as diff, (SELECT (to_char(sum(ende-start),'DD')::integer)*24+to_char(sum(ende-start),'HH24')::integer || ':' || to_char(sum(ende-start),'MI') FROM campus.tbl_zeitaufzeichnung WHERE $where) as summe FROM campus.tbl_zeitaufzeichnung z right join (select current_date - s.a as dates from generate_series(0,$max_anz,1) as s(a)) d on date(z.ende) = d.dates $where_join order by d.dates desc, z.start desc "; if($result = $this->db_query($qry)) { while($row = $this->db_fetch_object($result)) { $obj = new zeitaufzeichnung(); $obj->zeitaufzeichnung_id = $row->zeitaufzeichnung_id; $obj->uid = $row->uid; $obj->aktivitaet_kurzbz = $row->aktivitaet_kurzbz; $obj->start = $row->start; $obj->ende = $row->ende; $obj->beschreibung = $row->beschreibung; $obj->oe_kurzbz_1 = $row->oe_kurzbz_1; $obj->oe_kurzbz_2 = $row->oe_kurzbz_2; $obj->insertamum = $row->insertamum; $obj->insertvon = $row->insertvon; $obj->updateamum = $row->updateamum; $obj->updatevon = $row->updatevon; $obj->projekt_kurzbz = $row->projekt_kurzbz; $obj->projektphase_id = $row->projektphase_id; $obj->homeoffice = $row->homeoffice; $obj->ext_id = $row->ext_id; $obj->service_id = $row->service_id; $obj->kunde_uid = $row->kunde_uid; $obj->summe = $row->summe; $obj->diff = $row->diff; $obj->datum = $row->dates; $this->result[] = $obj; } return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Laedt die Zeitaufzeichnungen eines Users aufgefüllt mit lehren Tagen. * Default: Die letzten 40 Tage * @param string $user * @param integer $days deafult: 40 Tage */ public function getDienstreisenUser($user, $days='40') { $where = "uid=".$this->db_add_param($user); if ($days!='') $where.= " AND ende>(now() - INTERVAL '".$days." days')"; $where .= " AND aktivitaet_kurzbz = 'DienstreiseMT'"; $qry = "SELECT zeitaufzeichnung_id, start::date as starttag, TO_CHAR(start, 'HH24:MI') as startzeit, ende::date as endtag, TO_CHAR(ende, 'HH24:MI') as endzeit FROM campus.tbl_zeitaufzeichnung where $where ORDER BY ende DESC "; if($result = $this->db_query($qry)) { $dr_arr = array(); while($row = $this->db_fetch_object($result)) { if (array_key_exists($row->starttag, $dr_arr)) { $dr_arr[$row->starttag]['start'] = $row->startzeit; $dr_arr[$row->starttag]['id'] = $row->zeitaufzeichnung_id; } else { $dr_arr[$row->starttag] = array(); $dr_arr[$row->starttag]['start'] = $row->startzeit; $dr_arr[$row->starttag]['id'] = $row->zeitaufzeichnung_id; } if (array_key_exists($row->endtag, $dr_arr)) { $dr_arr[$row->endtag]['ende'] = $row->endzeit; $dr_arr[$row->endtag]['id'] = $row->zeitaufzeichnung_id; } else { $dr_arr[$row->endtag] = array(); $dr_arr[$row->endtag]['ende'] = $row->endzeit; $dr_arr[$row->endtag]['id'] = $row->zeitaufzeichnung_id; } $this->result = $dr_arr; } return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Löscht sämtliche Einträge eines Users für einen Tag * @param string $user * @param string $tag Y-m-d */ public function deleteEntriesForUser($user, $tag) { $where = "uid=".$this->db_add_param($user); $qry = "delete from campus.tbl_zeitaufzeichnung where $where and date_trunc('day', start) = '$tag'"; if($result = $this->db_query($qry)) { return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Löscht Pauseneinträge eines Users für einen Tag, die außerhalb der Arbeitszeit liegen * Löscht Pauseneinträge an Tagen ohne Arbeitszeit * @param string $user * @param string $tag Y-m-d */ public function cleanPausenForUser($user, $tag) { $where = "uid=".$this->db_add_param($user); $qry = " delete from campus.tbl_zeitaufzeichnung where aktivitaet_kurzbz = 'Pause' and start::date = '$tag' and $where and ( start::time >= (SELECT max(ende::time) as endzeit from campus.tbl_zeitaufzeichnung where $where and start::date = '$tag' AND (aktivitaet_kurzbz != 'LehreExtern' or aktivitaet_kurzbz is null ) and aktivitaet_kurzbz != 'Pause') or ende::time<= (SELECT min(start::time) as startzeit from campus.tbl_zeitaufzeichnung where $where and start::date = '$tag' AND (aktivitaet_kurzbz != 'LehreExtern' or aktivitaet_kurzbz is null ) and aktivitaet_kurzbz != 'Pause') or not exists (select 1 from campus.tbl_zeitaufzeichnung where aktivitaet_kurzbz != 'LehreExtern' and aktivitaet_kurzbz != 'Pause' and start::date = '$tag' and $where ) ) "; if($result = $this->db_query($qry)) { return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Holt alle ZA-Einträge Typ LehreIntern und LehreExtern eines Users * für das laufende Studienjahr und gibt die Summen in einem Array zurück * @param string $user * @return Array mit Key: LehreIntern, LehreExtern, LehreAuftraege, LehreInkludiert */ public function getLehreForUser($user,$sem) { $where = "uid=".$this->db_add_param($user); $where_sem = "studiensemester_kurzbz=".$this->db_add_param($sem); $lehre_arr = array("Lehre"=>0, "LehreExtern"=>0, "LehreAuftraege"=>0); $qry = " select sum(extract(epoch from ende-start))/3600 as lehre, aktivitaet_kurzbz from campus.tbl_zeitaufzeichnung where $where and aktivitaet_kurzbz in ('Lehre', 'LehreExtern') and start > (select start from public.tbl_studiensemester where $where_sem) group by aktivitaet_kurzbz "; if($result = $this->db_query($qry)) { while($row = $this->db_fetch_object($result)) { $lehre_arr[$row->aktivitaet_kurzbz] = round($row->lehre,2); } } else { return false; } $where = "mitarbeiter_uid=".$this->db_add_param($user); $where_sem = "l.studiensemester_kurzbz=".$this->db_add_param($sem); $qry = " SELECT sum(semstunden) AS stunden FROM ( SELECT sum(m.semesterstunden) AS semstunden FROM lehre.tbl_lehreinheitmitarbeiter m, lehre.tbl_lehreinheit l JOIN lehre.tbl_lehrveranstaltung lv using (lehrveranstaltung_id) JOIN public.tbl_studiengang s using (studiengang_kz) WHERE $where AND $where_sem AND l.lehreinheit_id = m.lehreinheit_id AND m.semesterstunden > 0 AND s.typ not in ('l') AND lv.studiengang_kz > 0 UNION SELECT sum(pb.stunden) AS semstunden FROM lehre.tbl_projektarbeit pa, lehre.tbl_projektbetreuer pb, public.tbl_benutzer b, lehre.tbl_lehreinheit l JOIN lehre.tbl_lehrveranstaltung lv using (lehrveranstaltung_id) JOIN public.tbl_studiengang s using (studiengang_kz) WHERE pa.lehreinheit_id = l.lehreinheit_id AND pb.projektarbeit_id = pa.projektarbeit_id AND pb.person_id = b.person_id AND b.uid = ".$this->db_add_param($user)." AND pb.stunden > 0 AND s.typ not in ('l') AND lv.studiengang_kz > 0 AND $where_sem ) AS semstunden "; if($result = $this->db_query($qry)) { while($row = $this->db_fetch_object($result)) { $lehre_arr["LehreAuftraege"] = round($row->stunden); } } else { return false; } return $lehre_arr; } /** * Holt das Datum bis zu dem die Eintragung für einen bestimmten User gesperrt ist * @param string $user * @return string $tag Y-m-d or false */ public function getEintragungGesperrtBisForUser($user) { //check if addon casetime is installed $qrytable = " SELECT EXISTS( SELECT 1 FROM information_schema.tables WHERE table_schema = 'addon' AND table_name = 'tbl_casetime_timesheet' ); "; $res = $this->db_query($qrytable); if ($this->db_fetch_row($res)[0] == 't') { //check if sent timesheets for the UID exist $where = "uid=".$this->db_add_param($user); $qry = "select max(datum) from addon.tbl_casetime_timesheet where ".$where." and abgeschicktamum is not null"; if ($result = $this->db_query($qry)) { $datum = $this->db_fetch_object($result); return $datum->max; } else { return false; } } else { return false; } } /** * Prüft, ob es für einen bestimmten User für einen bestimmten Tag eine Zeitaufzeichnung gibt * @param string $user Uid des zu prüfenden Users. * @param date $vonDay Startdatum des zu prüfenden Zeitraumes im Format d.m.Y. * @param date $bisDay Enddatum des zu prüfenden Zeitraumes im Format d.m.Y. * @return boolean true, wenn vorhanden, sonst false */ public function existsZeitaufzeichnung($user, $vonDay, $bisDay) { $datum = date($vonDay); $year = substr($datum, 6, 4); $month = substr($datum, 3, 2); $day = substr($datum, 0, 2); $datumbisDay = date($bisDay); $yearbisDay = substr($datumbisDay, 6, 4); $monthbisDay = substr($datumbisDay, 3, 2); $daybisDay = substr($datumbisDay, 0, 2); $bisDay = date("Y-m-d", (mktime(0, 0, 0, $monthbisDay, $daybisDay + 1, $yearbisDay))); $datum = date("Y-m-d", (mktime(0, 0, 0, $month, $day, $year))); $qry = " SELECT * FROM campus.tbl_zeitaufzeichnung WHERE uid = ". $this->db_add_param($user). " AND start >= ". $this->db_add_param($datum). " AND ende < ". $this->db_add_param($bisDay). "; "; if ($this->db_query($qry)) { $num_rows = $this->db_num_rows(); if ($num_rows >= 1) { return true; } else { return false; } } else { return false; } } /** Check, if there is a blocking PausenError * * @param string $uid User uid. * @param string $datumday Day to be check in the format "Y-m-d". * @return boolean True if there is a Pausen error. */ public function checkPausenErrors($uid, $datumday) { $tagesbeginn = ''; $tagesende = ''; $pausesumme = 0; $tagessaldo = ''; $elsumme = '00:00'; $pflichtpause = false; $blockingError = false; $datum = new datum(); $this->getListeUserFromTo($uid, $datumday, $datumday, null); foreach ($this->result as $row) { if($row->aktivitaet_kurzbz == 'DienstreiseMT' ) continue; $datumtag = $datum->formatDatum($row->datum, 'Y-m-d'); if (($tagesbeginn == '' || $datum->mktime_fromtimestamp($datum->formatDatum($tagesbeginn, $format = 'Y-m-d H:i:s')) > $datum->mktime_fromtimestamp($datum->formatDatum($row->start, $format = 'Y-m-d H:i:s'))) && $row->aktivitaet_kurzbz != 'LehreExtern' && $row->aktivitaet_kurzbz != 'Ersatzruhe') $tagesbeginn = $datum->formatDatum($row->start, 'H:i'); if (($tagesende == '' || $datum->mktime_fromtimestamp($datum->formatDatum($tagesende, $format = 'Y-m-d H:i:s')) < $datum->mktime_fromtimestamp($datum->formatDatum($row->ende, $format = 'Y-m-d H:i:s'))) && $row->aktivitaet_kurzbz != 'LehreExtern' && $row->aktivitaet_kurzbz != 'Ersatzruhe') $tagesende = $datum->formatDatum($row->ende, 'H:i'); if ($row->aktivitaet_kurzbz == "Pause") { list($h1, $m1) = explode(':', $row->diff); $pausesumme += ($h1 * 3600 + $m1 * 60); } } $tagessaldo = $datum->mktime_fromtimestamp($datum->formatDatum($tagesende, $format = 'Y-m-d H:i:s')) - $datum->mktime_fromtimestamp($datum->formatDatum($tagesbeginn, $format = 'Y-m-d H:i:s')) - 3600; list($h2, $m2) = explode(':', $elsumme); $elsumme = $h2 * 3600 + $m2 * 60; if ($datum->formatDatum($datumday, 'Y-m-d') >= '2019-11-06') { $pausesumme = $pausesumme; } elseif ($tagessaldo > 18000 && $tagessaldo < 19800 && $pflichtpause == false && $elsumme == 0) { $pausesumme = $tagessaldo - 18000; } elseif ($tagessaldo > 18000 && $pflichtpause == false && $elsumme == 0) { $pausesumme = $pausesumme + 1800; } if ($elsumme > 0) { $pausesumme = $pausesumme + $elsumme; $pflichtpause = true; } $tagessaldo = $tagessaldo - $pausesumme; //check if blocking error if (($tagessaldo >= 19800 && $pausesumme < 1800) || ($tagessaldo > 18000 && $tagessaldo < 19800 && $pausesumme < $tagessaldo - 18000)) { $blockingError = true; } return $blockingError; } } ?>