$name=$value; } public function __get($name) { return $this->$name; } /** * Laden von LV-Angebot * @param lvangebot_id ID des Datensatzes, der geladen werden soll * @return true wenn ok, false im Fehlerfall */ public function load($lvangebot_id) { if(!is_numeric($lvangebot_id)) { $this->errormsg = 'lvangebot_id muss eine gueltige Zahl sein'; return false; } $qry = "SELECT * FROM lehre.tbl_lvangebot WHERE lvangebot_id=".$this->db_add_param($lvangebot_id, FHC_INTEGER, false); if($this->db_query($qry)) { if($row = $this->db_fetch_object()) { $this->lvangebot_id=$row->lvangebot_id; $this->lehrveranstaltung_id=$row->lehrveranstaltung_id; $this->studiensemester_kurzbz=$row->studiensemester_kurzbz; $this->gruppe_kurzbz=$row->gruppe_kurzbz; $this->incomingplaetze=$row->incomingplaetze; $this->gesamtplaetze=$row->gesamtplaetze; $this->anmeldefenster_start=$row->anmeldefenster_start; $this->anmeldefenster_ende=$row->anmeldefenster_ende; $this->insertamum=$row->insertamum; $this->insertvon=$row->insertvon; $this->updatenamum=$row->updateamum; $this->updatevon=$row->updatevon; } } else { $this->errormsg = 'Datensatz konnte nicht geladen werden'; return false; } return true; } /** * Laden aller Einträge von LV-Angebot, die zu einer bestimmten LV gehören * @param lv_id ID der LV, dessen Angebote geladen werden sollen * @return true wenn ok, false im Fehlerfall */ public function getAllFromLvId($lv_id, $studiensemester_kurzbz=null) { if(!is_numeric($lv_id)) { $this->errormsg='lv_id muss eine gültige Zahl sein!'; return false; } $qry='SELECT tbl_lvangebot.* FROM lehre.tbl_lvangebot JOIN public.tbl_studiensemester USING(studiensemester_kurzbz) WHERE lehrveranstaltung_id='.$this->db_add_param($lv_id, FHC_INTEGER, false); if(!is_null($studiensemester_kurzbz)) $qry.=" AND studiensemester_kurzbz=".$this->db_add_param($studiensemester_kurzbz); $qry.= ' ORDER BY start'; if($this->db_query($qry)) { while($row = $this->db_fetch_object()) { $lvangebot=new lvangebot(); $lvangebot->lvangebot_id=$row->lvangebot_id; $lvangebot->lehrveranstaltung_id=$row->lehrveranstaltung_id; $lvangebot->studiensemester_kurzbz=$row->studiensemester_kurzbz; $lvangebot->gruppe_kurzbz=$row->gruppe_kurzbz; $lvangebot->incomingplaetze=$row->incomingplaetze; $lvangebot->gesamtplaetze=$row->gesamtplaetze; $lvangebot->anmeldefenster_start=$row->anmeldefenster_start; $lvangebot->anmeldefenster_ende=$row->anmeldefenster_ende; $lvangebot->insertamum=$row->insertamum; $lvangebot->insertvon=$row->insertvon; $lvangebot->updatenamum=$row->updateamum; $lvangebot->updatevon=$row->updatevon; $this->result[]=$lvangebot; } } else { $this->errormsg = 'Datensätze konnten nicht geladen werden'; return false; } return true; } /** * Prueft die Variablen auf Gueltigkeit * @return true wenn ok, false im Fehlerfall */ protected function validate() { //Zahlenfelder pruefen if(!is_numeric($this->lehrveranstaltung_id)) { $this->errormsg='lehrveranstaltung_id ist ungueltig'; return false; } if(!is_numeric($this->incomingplaetze) && $this->incomingplaetze!=='') { $this->errormsg='incomingplaetze enthaelt ungueltige Zeichen'; return false; } if(!is_numeric($this->gesamtplaetze) && $this->gesamtplaetze!=='') { $this->errormsg='gesamtplaetze enthaelt ungueltige Zeichen'; return false; } //not null prüfen if($this->studiensemester_kurzbz=='') { $this->errormsg='studiensemester_kurzbz ist leer'; } //Gesamtlaenge pruefen if(mb_strlen($this->studiensemester_kurzbz)>32) { $this->errormsg = 'studiensemester_kurzbz darf nicht länger als 32 Zeichen sein'; return false; } if(mb_strlen($this->gruppe_kurzbz)>32) { $this->errormsg = 'Gruppe darf nicht länger als 32 Zeichen sein'; return false; } //Anmeldefenster Start und Ende prüfen if($this->anmeldefenster_start!='' && $this->anmeldefenster_ende!='' && $this->anmeldefenster_start>$this->anmeldefenster_ende) { $this->errormsg = 'Anmeldefenster: Ende liegt vor Start'; return false; } $this->errormsg = ''; return true; } /** * Speichert den aktuellen Datensatz in die Datenbank * @return true wenn ok, false im Fehlerfall */ public function save() { //Variablen pruefen if(!$this->validate()) return false; if($this->new) { //Neuen Datensatz einfuegen $qry='BEGIN;INSERT INTO lehre.tbl_lvangebot (lehrveranstaltung_id, studiensemester_kurzbz, gruppe_kurzbz, incomingplaetze, gesamtplaetze, anmeldefenster_start, anmeldefenster_ende, insertamum, insertvon) VALUES ('. $this->db_add_param($this->lehrveranstaltung_id, FHC_INTEGER).', '. $this->db_add_param($this->studiensemester_kurzbz).', '. $this->db_add_param($this->gruppe_kurzbz).', '. $this->db_add_param($this->incomingplaetze, FHC_INTEGER).', '. $this->db_add_param($this->gesamtplaetze, FHC_INTEGER).', '. $this->db_add_param($this->anmeldefenster_start).', '. $this->db_add_param($this->anmeldefenster_ende).', '. 'now(), '. $this->db_add_param($this->insertvon).');'; } else { //Pruefen ob lvangebot_id eine gueltige Zahl ist if(!is_numeric($this->lvangebot_id)) { $this->errormsg = 'lvangebot_id muss eine gueltige Zahl sein'; return false; } $qry='UPDATE lehre.tbl_lvangebot SET'. ' lehrveranstaltung_id='.$this->db_add_param($this->lehrveranstaltung_id, FHC_INTEGER).', '. ' studiensemester_kurzbz='.$this->db_add_param($this->studiensemester_kurzbz).', '. ' gruppe_kurzbz='.$this->db_add_param($this->gruppe_kurzbz).', '. ' incomingplaetze='.$this->db_add_param($this->incomingplaetze, FHC_INTEGER).', '. ' gesamtplaetze='.$this->db_add_param($this->gesamtplaetze, FHC_INTEGER).', '. ' anmeldefenster_start='.$this->db_add_param($this->anmeldefenster_start).', '. ' anmeldefenster_ende='.$this->db_add_param($this->anmeldefenster_ende).', '. ' updateamum= now(), '. ' updatevon='.$this->db_add_param($this->updatevon).' '. ' WHERE lvangebot_id='.$this->db_add_param($this->lvangebot_id, FHC_INTEGER, false).';'; } if($this->db_query($qry)) { if($this->new) { //naechste ID aus der Sequence holen $qry="SELECT currval('lehre.seq_lvangebot_lvangebot_id') as id;"; if($this->db_query($qry)) { if($row = $this->db_fetch_object()) { $this->lvangebot_id = $row->id; $this->db_query('COMMIT'); } 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 des Datensatzes'; return false; } return $this->lvangebot_id; } /** * Loescht den Datenensatz mit der ID die uebergeben wird * @param $lvangebot_id ID die geloescht werden soll * @return true wenn ok, false im Fehlerfall */ public function delete($lvangebot_id) { //Pruefen ob lvangebot_id eine gueltige Zahl ist if(!is_numeric($lvangebot_id) || $lvangebot_id === '') { $this->errormsg = 'lvangebot_id muss eine gültige Zahl sein'; return false; } //loeschen des Datensatzes $qry="DELETE FROM lehre.tbl_lvangebot WHERE lvangebot_id=".$this->db_add_param($lvangebot_id, FHC_INTEGER); if($this->db_query($qry)) { return true; } else { $this->errormsg = 'Fehler beim Löschen von Eintrag '.$lvangebot_id; return false; } } /** * Laedt das LV-Angebot eines gesammten Studienplanes * @param $studienplan_id ID des Studienplanes */ public function getLVAngebotFromStudienplan($studienplan_id, $studiensemester_arr=null, $kompatible=false) { $qry = "SELECT tbl_lvangebot.* FROM lehre.tbl_studienplan_lehrveranstaltung JOIN lehre.tbl_lvangebot USING(lehrveranstaltung_id) WHERE tbl_studienplan_lehrveranstaltung.studienplan_id=".$this->db_add_param($studienplan_id); if(!is_null($studiensemester_arr)) $qry.=" AND tbl_lvangebot.studiensemester_kurzbz IN(".$this->implode4SQL($studiensemester_arr).")"; if($kompatible) { $qry.=" UNION SELECT tbl_lvangebot.* FROM lehre.tbl_studienplan_lehrveranstaltung JOIN lehre.tbl_lehrveranstaltung_kompatibel USING(lehrveranstaltung_id) JOIN lehre.tbl_lvangebot ON (tbl_lvangebot.lehrveranstaltung_id=tbl_lehrveranstaltung_kompatibel.lehrveranstaltung_id_kompatibel) WHERE tbl_studienplan_lehrveranstaltung.studienplan_id=".$this->db_add_param($studienplan_id); if(!is_null($studiensemester_arr)) $qry.=" AND tbl_lvangebot.studiensemester_kurzbz IN(".$this->implode4SQL($studiensemester_arr).")"; } if($this->db_query($qry)) { while($row = $this->db_fetch_object()) { $lvangebot=new lvangebot(); $lvangebot->lvangebot_id=$row->lvangebot_id; $lvangebot->lehrveranstaltung_id=$row->lehrveranstaltung_id; $lvangebot->studiensemester_kurzbz=$row->studiensemester_kurzbz; $lvangebot->gruppe_kurzbz=$row->gruppe_kurzbz; $lvangebot->incomingplaetze=$row->incomingplaetze; $lvangebot->gesamtplaetze=$row->gesamtplaetze; $lvangebot->anmeldefenster_start=$row->anmeldefenster_start; $lvangebot->anmeldefenster_ende=$row->anmeldefenster_ende; $lvangebot->insertamum=$row->insertamum; $lvangebot->insertvon=$row->insertvon; $lvangebot->updatenamum=$row->updateamum; $lvangebot->updatevon=$row->updatevon; $this->result[]=$lvangebot; } } else { $this->errormsg = 'Datensätze konnten nicht geladen werden'; return false; } return true; } /** * Prueft ob eine Anmeldung zu dieser Lehrveranstaltung derzeit moeglich ist */ public function AnmeldungMoeglich() { $datum_obj = new datum(); if($this->gruppe_kurzbz!='') { if($datum_obj->between($this->anmeldefenster_start, $this->anmeldefenster_ende, date('Y-m-d H:i:s'))) { if($this->gesamtplaetze!='') { // Gesamtplaetze pruefen $qry = "SELECT count(*) as anzahl FROM public.tbl_benutzergruppe WHERE gruppe_kurzbz=".$this->db_add_param($this->gruppe_kurzbz)." AND studiensemester_kurzbz=".$this->db_add_param($this->studiensemester_kurzbz); if($result = $this->db_query($qry)) { if($row = $this->db_fetch_object($result)) { if($row->anzahl<$this->gesamtplaetze) { return true; } else { $this->errormsg = 'Es sind bereits alle Plätze für diese Lehrveranstaltung belegt'; return false; } } } } else return true; } else { $this->errormsg = 'Eine Anmeldung zu dieser Lehrveranstaltung ist derzeit nicht moeglich'; return false; } } else { $this->errormsg = 'Es ist derzeit noch keine Gruppe für die Anmeldung zugeteilt'; return false; } } /** * Prueft ob eine Abmeldung von einer Lehrveranstaltung moeglich ist * und liefert die Gruppen von denen sich abgemeldet werden kann * @param $lehrveranstaltung_id * @param $studiensemester_kurzbz * @param $uid * @return $gruppen Array mit den Gruppen */ public function AbmeldungMoeglich($lehrveranstaltung_id, $studiensemester_kurzbz, $uid) { $qry = "SELECT gruppe_kurzbz FROM lehre.tbl_lvangebot JOIN public.tbl_benutzergruppe USING(studiensemester_kurzbz, gruppe_kurzbz) WHERE tbl_lvangebot.studiensemester_kurzbz=".$this->db_add_param($studiensemester_kurzbz)." AND tbl_benutzergruppe.uid=".$this->db_add_param($uid)." AND (tbl_lvangebot.lehrveranstaltung_id=".$this->db_add_param($lehrveranstaltung_id, FHC_INTEGER)." OR tbl_lvangebot.lehrveranstaltung_id IN(SELECT lehrveranstaltung_id_kompatibel FROM lehre.tbl_lehrveranstaltung_kompatibel WHERE lehrveranstaltung_id=".$this->db_add_param($lehrveranstaltung_id, FHC_INTEGER)." ) )"; if($result = $this->db_query($qry)) { $gruppen=array(); while($row = $this->db_fetch_object($result)) { $gruppen[] = $row->gruppe_kurzbz; } return $gruppen; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } } ?>