, * Andreas Oesterreicher and * Rudolf Hangl . */ /** * Klasse projektarbeit * @create 08-02-2007 */ require_once(dirname(__FILE__).'/basis_db.class.php'); class projektarbeit extends basis_db { public $new; // boolean public $result = array(); // adresse Objekt //Tabellenspalten public $projektarbeit_id; // integer public $projekttyp_kurzbz; // string public $bezeichnung; // string public $titel; // string public $titel_english; // string public $lehreinheit_id; // integer public $student_uid; // integer public $firma_id; // integer public $note; // integer public $punkte; // numeric(6,2) public $beginn; // date public $ende; // date public $faktor; // numeric(3,2) public $freigegeben; // boolean public $gesperrtbis; // date public $stundensatz; // numeric(6,2) public $gesamtstunden; // numeric(8,2) public $themenbereich; // sting public $anmerkung; // string public $ext_id; // integer public $insertamum; // timestamp public $insertvon; // bigint public $updateamum; // timestamp public $updatevon; // bigint public $final; // boolean public $abgabedatum; // Welche Version der Projektarbeit wird ab welchem Semester verwendet private $_versions = array( 'Diplom' => array( 'SS2025' => 3, 'SS2023' => 2, 'SS2022' => 1 ), 'Others' => array( 'SS2025' => 2, 'SS2022' => 1 ) ); // welche Vorlagen werden ab welcher Projekarbeitsversion verwendet (0 - erste "default" Vorlage) private $_projektarbeitVorlageMappings = array( 'Begutachter' => array( 2 => 'ProjektBeurteilungBAProzent', 0 => 'ProjektBeurteilungBA' ), 'Senatsvorsitz' => array( 2 => 'ProjektBeurteilungBAProzent', 0 => 'ProjektBeurteilungBA' ), 'Erstbegutachter' => array( 3 => 'ProjektBeurteilungMAProzent', 0 => 'ProjektBeurteilungMAErst' ), 'Zweitbegutachter' => array( 0 => 'ProjektBeurteilungMAZweit' ) ); /** * Konstruktor * @param $projektarbeit_id ID der Projektarbeit, die geladen werden soll (Default=null) */ public function __construct($projektarbeit_id=null) { parent::__construct(); if($projektarbeit_id != null) $this->load($projektarbeit_id); } /** * Laedt die Projektarbeit mit der ID $projektarbeit_id * @param $projektarbeit_id ID der zu ladenden Projektarbeit * @return true wenn ok, false im Fehlerfall */ public function load($projektarbeit_id) { if(!is_numeric($projektarbeit_id)) { $this->errormsg = 'Projektarbeit_id muss eine gueltige Zahl sein'; return false; } $qry = "SELECT * FROM lehre.tbl_projektarbeit " . "JOIN lehre.tbl_projekttyp USING (projekttyp_kurzbz) " . "WHERE projektarbeit_id=".$this->db_add_param($projektarbeit_id, FHC_INTEGER); if($this->db_query($qry)) { if($row = $this->db_fetch_object()) { $this->projektarbeit_id = $row->projektarbeit_id; $this->projekttyp_kurzbz = $row->projekttyp_kurzbz; $this->titel = $row->titel; $this->titel_english = $row->titel_english; $this->lehreinheit_id = $row->lehreinheit_id; $this->student_uid = $row->student_uid; $this->firma_id = $row->firma_id; $this->note = $row->note; $this->punkte = $row->punkte; $this->beginn = $row->beginn; $this->ende = $row->ende; $this->faktor = $row->faktor; $this->freigegeben = $this->db_parse_bool($row->freigegeben); $this->gesperrtbis = $row->gesperrtbis; $this->stundensatz = $row->stundensatz; $this->gesamtstunden = $row->gesamtstunden; $this->themenbereich = $row->themenbereich; $this->anmerkung = $row->anmerkung; $this->ext_id = $row->ext_id; $this->insertamum = $row->insertamum; $this->insertvon = $row->insertvon; $this->updateamum = $row->updateamum; $this->updatevon = $row->updatevon; $this->projekttyp_bezeichnung = $row->bezeichnung; $this->final = $this->db_parse_bool($row->final); $this->abgabedatum = $row->abgabedatum; return true; } else { $this->errormsg = 'Datensatz wurde nicht gefunden'; return false; } } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Prueft die Variablen auf Gueltigkeit * @return true wenn ok, false im Fehlerfall */ protected function validate() { //Gesamtlaenge pruefen if ($this->projekttyp_kurzbz==null) { $this->errormsg='Projekttyp_kurzbz darf nicht NULL sein!'; } if ($this->lehreinheit_id==null) { $this->errormsg='Lehreinheit_id darf nicht NULL sein!'; } if(mb_strlen($this->projekttyp_kurzbz)>16) { $this->errormsg = 'Projektyp_kurzbz darf nicht länger als 16 Zeichen sein'; return false; } if(mb_strlen($this->titel)>1024) { $this->errormsg = 'Titel darf nicht länger als 1024 Zeichen sein'; return false; } if(mb_strlen($this->titel_english)>1024) { $this->errormsg = 'Titel darf nicht länger als 1024 Zeichen sein'; return false; } if(mb_strlen($this->themenbereich)>64) { $this->errormsg = 'Themenbereich darf nicht länger als 64 Zeichen sein'; return false; } if(mb_strlen($this->anmerkung)>256) { $this->errormsg = 'Anmerkung darf nicht länger als 256 Zeichen sein'; return false; } /*if(!is_numeric($this->note)) { $this->errormsg = 'Note muß ein numerischer Wert sein - student_uid: '.$this->student_uid; return false; }*/ if($this->punkte!='' && !is_numeric($this->punkte)) { $this->errormsg = 'Punkte muss ein numerischer Wert sein'; return false; } if($this->faktor!='' && !is_numeric($this->faktor)) { $this->errormsg = 'Faktor muss ein numerischer Wert sein'; return false; } if($this->stundensatz!='' && !is_numeric($this->stundensatz)) { $this->errormsg = 'Stundensatz muss ein numerischer Wert sein'; return false; } if($this->gesamtstunden!='' && !is_numeric($this->gesamtstunden)) { $this->errormsg = 'Gesamtstunden muss ein numerischer Wert sein'; return false; } if(!is_bool($this->freigegeben)) { $this->errormsg = 'freigegeben ist ungueltig'; return false; } $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 $projektarbeit_id aktualisiert * @return true wenn ok, false im Fehlerfall */ public function save($new=null) { //Variablen pruefen if(!$this->validate()) return false; if($new==null) $new = $this->new; if($new) { //Neuen Datensatz einfuegen $qry='BEGIN; INSERT INTO lehre.tbl_projektarbeit (projekttyp_kurzbz, titel, lehreinheit_id, student_uid, firma_id, note, punkte, beginn, ende, faktor, freigegeben, gesperrtbis, stundensatz, gesamtstunden, themenbereich, anmerkung, insertamum, insertvon, updateamum, updatevon, titel_english, final) VALUES('. $this->db_add_param($this->projekttyp_kurzbz).', '. $this->db_add_param($this->titel).', '. $this->db_add_param($this->lehreinheit_id, FHC_INTEGER).', '. $this->db_add_param($this->student_uid).', '. $this->db_add_param($this->firma_id, FHC_INTEGER).', '. $this->db_add_param($this->note).', '. $this->db_add_param($this->punkte).', '. $this->db_add_param($this->beginn).', '. $this->db_add_param($this->ende).', '. $this->db_add_param($this->faktor).', '. $this->db_add_param($this->freigegeben, FHC_BOOLEAN).', '. $this->db_add_param($this->gesperrtbis).', '. $this->db_add_param($this->stundensatz).', '. $this->db_add_param($this->gesamtstunden).', '. $this->db_add_param($this->themenbereich).', '. $this->db_add_param($this->anmerkung).', now(), '. $this->db_add_param($this->insertvon).', now(), '. $this->db_add_param($this->updatevon).','. $this->db_add_param($this->titel_english).','. $this->db_add_param($this->final, FHC_BOOLEAN).');'; } else { //Updaten des bestehenden Datensatzes //Pruefen ob projektarbeit_id eine gueltige Zahl ist if(!is_numeric($this->projektarbeit_id)) { $this->errormsg = 'projektarbeit_id muss eine gueltige Zahl sein'; return false; } $qry='UPDATE lehre.tbl_projektarbeit SET '. 'projekttyp_kurzbz='.$this->db_add_param($this->projekttyp_kurzbz).', '. 'titel='.$this->db_add_param($this->titel).', '. 'titel_english='.$this->db_add_param($this->titel_english).', '. 'lehreinheit_id='.$this->db_add_param($this->lehreinheit_id, FHC_INTEGER).', '. 'student_uid='.$this->db_add_param($this->student_uid).', '. 'firma_id='.$this->db_add_param($this->firma_id, FHC_INTEGER).', '. 'note='.$this->db_add_param($this->note).', '. 'punkte='.$this->db_add_param($this->punkte).', '. 'beginn='.$this->db_add_param($this->beginn).', '. 'ende='.$this->db_add_param($this->ende).', '. 'faktor='.$this->db_add_param($this->faktor).', '. 'freigegeben='.$this->db_add_param($this->freigegeben, FHC_BOOLEAN).', '. 'gesperrtbis='.$this->db_add_param($this->gesperrtbis).', '. 'stundensatz='.$this->db_add_param($this->stundensatz).', '. 'gesamtstunden='.$this->db_add_param($this->gesamtstunden).', '. 'themenbereich='.$this->db_add_param($this->themenbereich).', '. 'anmerkung='.$this->db_add_param($this->anmerkung).', '. 'updateamum= now(), '. 'updatevon='.$this->db_add_param($this->updatevon).', '. 'final='.$this->db_add_param($this->final, FHC_BOOLEAN).' '. 'WHERE projektarbeit_id='.$this->db_add_param($this->projektarbeit_id, FHC_INTEGER).';'; } if($this->db_query($qry)) { if($new) { //Sequence auslesen $qry = "SELECT currval('lehre.tbl_projektarbeit_projektarbeit_id_seq') as id;"; if($this->db_query($qry)) { if($row = $this->db_fetch_object()) { $this->projektarbeit_id = $row->id; $this->db_query('COMMIT'); return true; } else { $this->errormsg = 'Fehler beim Auslesen der Sequence'; $this->db_query('ROLLBACK;'); return false; } } else { $this->errormsg = 'Fehler beim Auslesen der Sequence'; $this->db_query('ROLLBACK;'); return false; } } return true; } else { $this->errormsg = 'Fehler beim Speichern der Daten'; return false; } } /** * Loescht den Datenensatz mit der ID die uebergeben wird * @param $projektarbeit_id ID die geloescht werden soll * @return true wenn ok, false im Fehlerfall */ public function delete($projektarbeit_id) { if(!is_numeric($projektarbeit_id)) { $this->errormsg = 'Projektarbeit_id ist ungueltig'; return true; } $qry = "DELETE FROM lehre.tbl_projektarbeit WHERE projektarbeit_id=".$this->db_add_param($projektarbeit_id, FHC_INTEGER); if($this->db_query($qry)) { return true; } else { $this->errormsg = 'Fehler beim Loeschen des Datensatzes'; return false; } } /** * Laedt alle Projektarbeiten eines Studenten * @param student_uid * @return true wenn ok, false wenn Fehler */ public function getProjektarbeit($student_uid) { $qry = "SELECT * FROM lehre.tbl_projektarbeit JOIN lehre.tbl_projekttyp USING (projekttyp_kurzbz) WHERE student_uid=".$this->db_add_param($student_uid); if($this->db_query($qry)) { while($row = $this->db_fetch_object()) { $obj = new projektarbeit(); $obj->projektarbeit_id = $row->projektarbeit_id; $obj->projekttyp_kurzbz = $row->projekttyp_kurzbz; $obj->bezeichnung = $row->bezeichnung; $obj->titel = $row->titel; $obj->titel_english = $row->titel_english; $obj->lehreinheit_id = $row->lehreinheit_id; $obj->student_uid = $row->student_uid; $obj->firma_id = $row->firma_id; $obj->note = $row->note; $obj->punkte = $row->punkte; $obj->beginn = $row->beginn; $obj->ende = $row->ende; $obj->faktor = $row->faktor; $obj->freigegeben = $this->db_parse_bool($row->freigegeben); $obj->gesperrtbis = $row->gesperrtbis; $obj->stundensatz = $row->stundensatz; $obj->gesamtstunden = $row->gesamtstunden; $obj->themenbereich = $row->themenbereich; $obj->anmerkung = $row->anmerkung; $obj->ext_id = $row->ext_id; $obj->insertamum = $row->insertamum; $obj->insertvon = $row->insertvon; $obj->updateamum = $row->updateamum; $obj->updatevon = $row->updatevon; $obj->final = $this->db_parse_bool($row->final); $obj->abgabedatum = $row->abgabedatum; $this->result[] = $obj; } return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Laedt alle Projektarbeiten eines Studienganges/Studiensemesters * @param studiengang_kz, studiensemester_kurzbz * @return true wenn ok, false wenn Fehler */ public function getProjektarbeitStudiensemester($studiengang_kz, $studiensemester_kurzbz) { $qry = "SELECT tbl_projektarbeit.* , tbl_projekttyp.bezeichnung FROM lehre.tbl_projektarbeit JOIN lehre.tbl_projekttyp USING (projekttyp_kurzbz), lehre.tbl_lehreinheit, lehre.tbl_lehrveranstaltung WHERE tbl_projektarbeit.lehreinheit_id=tbl_lehreinheit.lehreinheit_id AND tbl_lehreinheit.lehrveranstaltung_id = tbl_lehrveranstaltung.lehrveranstaltung_id AND tbl_lehrveranstaltung.studiengang_kz=".$this->db_add_param($studiengang_kz, FHC_INTEGER)." AND tbl_lehreinheit.studiensemester_kurzbz=".$this->db_add_param($studiensemester_kurzbz); if($this->db_query($qry)) { while($row = $this->db_fetch_object()) { $obj = new projektarbeit(); $obj->projektarbeit_id = $row->projektarbeit_id; $obj->projekttyp_kurzbz = $row->projekttyp_kurzbz; $obj->bezeichnung = $row->bezeichnung; $obj->titel = $row->titel; $obj->titel_english = $row->titel_english; $obj->lehreinheit_id = $row->lehreinheit_id; $obj->student_uid = $row->student_uid; $obj->firma_id = $row->firma_id; $obj->note = $row->note; $obj->punkte = $row->punkte; $obj->beginn = $row->beginn; $obj->ende = $row->ende; $obj->faktor = $row->faktor; $obj->freigegeben = $this->db_parse_bool($row->freigegeben); $obj->gesperrtbis = $row->gesperrtbis; $obj->stundensatz = $row->stundensatz; $obj->gesamtstunden = $row->gesamtstunden; $obj->themenbereich = $row->themenbereich; $obj->anmerkung = $row->anmerkung; $obj->ext_id = $row->ext_id; $obj->insertamum = $row->insertamum; $obj->insertvon = $row->insertvon; $obj->updateamum = $row->updateamum; $obj->updatevon = $row->updatevon; $obj->final = $this->db_parse_bool($row->final); $this->result[] = $obj; } return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Prüft ob Projektarbeit aktuell ist (also zurzeit online bewertet wird). * @param $projektarbeit_id * @return boolean */ public function projektarbeitIsCurrent($projektarbeit_id) { $version = $this->getVersion($projektarbeit_id); // paarbeit sollte nur ab einem Studiensemester online bewertet werden return $version === null ? null : $version->isCurrent; } /** * Holt sich Version der Projektarbeit. * Liefert auch mit, ob die Version die aktuellste ist. * z.B.: Masterarbeiten waren ab der Änderung zur Gewichtung der Punkte aktuell, * Bachelorarbeiten waren ab dem Umstieg auf das Online Beurteilungsformular aktuell. * @param $projektarbeit_id * @return objekt mit Versionsinfo, null im Fehlerfall */ public function getVersion($projektarbeit_id) { // paarbeit sollte nur ab einem Studiensemester online bewertet werden $qry=" SELECT CASE WHEN semesters_diplom.studiensemester_kurzbz IS NOT NULL THEN semesters_diplom.studiensemester_kurzbz ELSE semesters.studiensemester_kurzbz END AS version_studiensemester_kurzbz, pa.projekttyp_kurzbz FROM lehre.tbl_projektarbeit pa JOIN lehre.tbl_lehreinheit USING(lehreinheit_id) JOIN public.tbl_studiensemester sem USING(studiensemester_kurzbz) LEFT JOIN ( SELECT start, studiensemester_kurzbz FROM public.tbl_studiensemester WHERE studiensemester_kurzbz IN (".$this->db_implode4SQL(array_keys($this->_versions['Others'])).") ) semesters ON sem.start >= semesters.start AND pa.projekttyp_kurzbz <> 'Diplom' LEFT JOIN ( SELECT start, studiensemester_kurzbz FROM public.tbl_studiensemester WHERE studiensemester_kurzbz IN (".$this->db_implode4SQL(array_keys($this->_versions['Diplom'])).") ) semesters_diplom ON sem.start >= semesters_diplom.start AND pa.projekttyp_kurzbz = 'Diplom' WHERE projektarbeit_id=".$this->db_add_param($projektarbeit_id, FHC_INTEGER)." ORDER BY semesters.start DESC, semesters_diplom.start DESC LIMIT 1"; $errormsg = "Fehler beim Ermitteln der Projektarbeit Version"; if ($this->db_query($qry)) { if ($row = $this->db_fetch_object()) { // known project types if (isset($this->_versions[$row->projekttyp_kurzbz][$row->version_studiensemester_kurzbz])) { $row->versionNumber = $this->_versions[$row->projekttyp_kurzbz][$row->version_studiensemester_kurzbz]; $row->isCurrent = $this->_versions[$row->projekttyp_kurzbz][$row->version_studiensemester_kurzbz] == max($this->_versions[$row->projekttyp_kurzbz]); } elseif (isset($this->_versions['Others'][$row->version_studiensemester_kurzbz])) { $row->versionNumber = $this->_versions['Others'][$row->version_studiensemester_kurzbz]; $row->isCurrent = $this->_versions['Others'][$row->version_studiensemester_kurzbz] == max($this->_versions['Others']); } else { $row->isCurrent = false; $row->versionNumber = 0; } return $row; } else { $this->errormsg = $errormsg; return null; } } else { $this->errormsg = $errormsg; return null; } } /** * Holt Version einer Projektarbeit für eine Betreuerart. * @param $projektarbeit_id * @param $betreuerart_kurzbz * @return string Vorlagenname */ public function getVorlage($projektarbeit_id, $betreuerart_kurzbz) { $version = $this->getVersion($projektarbeit_id); if ($version == null) return null; $key = 0; if (isset($this->_projektarbeitVorlageMappings[$betreuerart_kurzbz])) { foreach ($this->_projektarbeitVorlageMappings[$betreuerart_kurzbz] as $versionNumber => $vorlage) { if ($versionNumber <= $version->versionNumber && $versionNumber > $key) $key = $versionNumber; } } return isset($this->_projektarbeitVorlageMappings[$betreuerart_kurzbz][$key]) ? $this->_projektarbeitVorlageMappings[$betreuerart_kurzbz][$key] : ''; } /** * Holt alle möglichen, jemals verwendeten Projektarbeits-Vorlagen * @return array mit Vorlagennamen */ public function getAllVorlagen() { $vorlagen = array(); foreach ($this->_projektarbeitVorlageMappings as $mappings) { $vorlagen = array_unique(array_merge($vorlagen, $mappings)); } return $vorlagen; } } ?>