mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-22 06:29:27 +00:00
Merge branch 'master' of https://github.com/FH-Complete/FHC-Core
This commit is contained in:
@@ -1,5 +1,7 @@
|
||||
# FH-Complete
|
||||
|
||||
[](http://phpci.fhcomplete.org/project/view/1)
|
||||
|
||||
* [FH-Complete Homepage](http://www.fhcomplete.org)
|
||||
* [Wiki](http://fhcomplete.technikum-wien.at/dokuwiki/)
|
||||
* [Changelog](CHANGELOG.md)
|
||||
|
||||
@@ -16,8 +16,9 @@
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors: Christian Paminger <christian.paminger@technikum-wien.at>,
|
||||
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at> and
|
||||
* Rudolf Hangl <rudolf.hangl@technikum-wien.at>.
|
||||
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at>,
|
||||
* Rudolf Hangl <rudolf.hangl@technikum-wien.at> and
|
||||
* Andreas Moik <moik@technikum-wien.at>.
|
||||
*/
|
||||
/**
|
||||
* Klasse zur Verwaltung der Abschlusspruefungen
|
||||
@@ -327,12 +328,12 @@ class abschlusspruefung extends basis_db
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Liefert die letzte Abschlussprüfung eines Studenten
|
||||
* @param type $student_uid
|
||||
*/
|
||||
public function getLastAbschlusspruefung($student_uid)
|
||||
{
|
||||
/**
|
||||
* Liefert die letzte Abschlussprüfung eines Studenten
|
||||
* @param type $student_uid
|
||||
*/
|
||||
public function getLastAbschlusspruefung($student_uid)
|
||||
{
|
||||
$qry = "SELECT
|
||||
*
|
||||
FROM
|
||||
@@ -341,7 +342,7 @@ class abschlusspruefung extends basis_db
|
||||
WHERE student_uid=".$this->db_add_param($student_uid, FHC_STRING, false)."
|
||||
ORDER BY datum DESC LIMIT 1";
|
||||
|
||||
if($this->db_query($qry))
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
if($row = $this->db_fetch_object())
|
||||
{
|
||||
@@ -365,7 +366,6 @@ class abschlusspruefung extends basis_db
|
||||
$this->insertamum = $row->insertamum;
|
||||
$this->insertvon = $row->insertvon;
|
||||
$this->ext_id = $row->ext_id;
|
||||
|
||||
}
|
||||
return true;
|
||||
}
|
||||
@@ -374,7 +374,6 @@ class abschlusspruefung extends basis_db
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
?>
|
||||
|
||||
+27
-27
@@ -16,8 +16,9 @@
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors: Christian Paminger <christian.paminger@technikum-wien.at>,
|
||||
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at> and
|
||||
* Rudolf Hangl <rudolf.hangl@technikum-wien.at>.
|
||||
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at>,
|
||||
* Rudolf Hangl <rudolf.hangl@technikum-wien.at> and
|
||||
* Andreas Moik <moik@technikum-wien.at>.
|
||||
*/
|
||||
/**
|
||||
* Klasse Adresse
|
||||
@@ -279,20 +280,20 @@ class adresse extends basis_db
|
||||
{
|
||||
//Neuen Datensatz einfuegen
|
||||
$qry='BEGIN;INSERT INTO public.tbl_adresse (person_id, name, strasse, plz, typ, ort, nation, insertamum, insertvon,
|
||||
gemeinde, heimatadresse, zustelladresse, firma_id, updateamum, updatevon) VALUES('.
|
||||
$this->db_add_param($this->person_id, FHC_INTEGER).', '.
|
||||
$this->db_add_param($this->name).', '.
|
||||
$this->db_add_param($this->strasse).', '.
|
||||
$this->db_add_param($this->plz).', '.
|
||||
$this->db_add_param(trim($this->typ)).', '.
|
||||
$this->db_add_param($this->ort).', '.
|
||||
$this->db_add_param($this->nation).', now(), '.
|
||||
$this->db_add_param($this->insertvon).', '.
|
||||
$this->db_add_param($this->gemeinde).', '.
|
||||
$this->db_add_param($this->heimatadresse,FHC_BOOLEAN, false).', '.
|
||||
$this->db_add_param($this->zustelladresse,FHC_BOOLEAN, false).', '.
|
||||
$this->db_add_param($this->firma_id, FHC_INTEGER).', now(), '.
|
||||
$this->db_add_param($this->updatevon).');';
|
||||
gemeinde, heimatadresse, zustelladresse, firma_id, updateamum, updatevon) VALUES('.
|
||||
$this->db_add_param($this->person_id, FHC_INTEGER).', '.
|
||||
$this->db_add_param($this->name).', '.
|
||||
$this->db_add_param($this->strasse).', '.
|
||||
$this->db_add_param($this->plz).', '.
|
||||
$this->db_add_param(trim($this->typ)).', '.
|
||||
$this->db_add_param($this->ort).', '.
|
||||
$this->db_add_param($this->nation).', now(), '.
|
||||
$this->db_add_param($this->insertvon).', '.
|
||||
$this->db_add_param($this->gemeinde).', '.
|
||||
$this->db_add_param($this->heimatadresse,FHC_BOOLEAN, false).', '.
|
||||
$this->db_add_param($this->zustelladresse,FHC_BOOLEAN, false).', '.
|
||||
$this->db_add_param($this->firma_id, FHC_INTEGER).', now(), '.
|
||||
$this->db_add_param($this->updatevon).');';
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -307,16 +308,16 @@ class adresse extends basis_db
|
||||
' name='.$this->db_add_param($this->name).', '.
|
||||
' strasse='.$this->db_add_param($this->strasse).', '.
|
||||
' plz='.$this->db_add_param($this->plz).', '.
|
||||
' typ='.$this->db_add_param(trim($this->typ)).', '.
|
||||
' ort='.$this->db_add_param($this->ort).', '.
|
||||
' nation='.$this->db_add_param($this->nation).', '.
|
||||
' gemeinde='.$this->db_add_param($this->gemeinde).', '.
|
||||
' firma_id='.$this->db_add_param($this->firma_id, FHC_INTEGER).','.
|
||||
' updateamum= now(), '.
|
||||
' updatevon='.$this->db_add_param($this->updatevon).', '.
|
||||
' heimatadresse='.$this->db_add_param($this->heimatadresse, FHC_BOOLEAN, false).', '.
|
||||
' zustelladresse='.$this->db_add_param($this->zustelladresse, FHC_BOOLEAN, false).' '.
|
||||
'WHERE adresse_id='.$this->db_add_param($this->adresse_id, FHC_INTEGER, false).';';
|
||||
' typ='.$this->db_add_param(trim($this->typ)).', '.
|
||||
' ort='.$this->db_add_param($this->ort).', '.
|
||||
' nation='.$this->db_add_param($this->nation).', '.
|
||||
' gemeinde='.$this->db_add_param($this->gemeinde).', '.
|
||||
' firma_id='.$this->db_add_param($this->firma_id, FHC_INTEGER).','.
|
||||
' updateamum= now(), '.
|
||||
' updatevon='.$this->db_add_param($this->updatevon).', '.
|
||||
' heimatadresse='.$this->db_add_param($this->heimatadresse, FHC_BOOLEAN, false).', '.
|
||||
' zustelladresse='.$this->db_add_param($this->zustelladresse, FHC_BOOLEAN, false).' '.
|
||||
'WHERE adresse_id='.$this->db_add_param($this->adresse_id, FHC_INTEGER, false).';';
|
||||
}
|
||||
|
||||
if($this->db_query($qry))
|
||||
@@ -432,7 +433,6 @@ class adresse extends basis_db
|
||||
$this->errormsg = 'Es ist kein Datensatz mit dieser ID vorhanden';
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -15,9 +15,10 @@
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors: Christian Paminger <christian.paminger@technikum-wien.at>,
|
||||
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at> and
|
||||
* Rudolf Hangl <rudolf.hangl@technikum-wien.at>.
|
||||
* Authors: Christian Paminger <christian.paminger@technikum-wien.at>,
|
||||
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at>,
|
||||
* Rudolf Hangl <rudolf.hangl@technikum-wien.at> and
|
||||
* Andreas Moik <moik@technikum-wien.at>.
|
||||
*/
|
||||
require_once(dirname(__FILE__).'/basis_db.class.php');
|
||||
|
||||
@@ -156,8 +157,9 @@ class akadgrad extends basis_db
|
||||
}
|
||||
}
|
||||
|
||||
public function __toString(){
|
||||
return $this->akadgrad_kurzbz;
|
||||
public function __toString()
|
||||
{
|
||||
return $this->akadgrad_kurzbz;
|
||||
}
|
||||
}
|
||||
?>
|
||||
|
||||
+439
-440
@@ -1,440 +1,439 @@
|
||||
<?php
|
||||
/* Copyright (C) 2006 Technikum-Wien
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors: Christian Paminger <christian.paminger@technikum-wien.at>,
|
||||
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at> and
|
||||
* Rudolf Hangl <rudolf.hangl@technikum-wien.at>.
|
||||
*/
|
||||
require_once(dirname(__FILE__).'/basis_db.class.php');
|
||||
|
||||
class akte extends basis_db
|
||||
{
|
||||
public $new;
|
||||
public $result = array();
|
||||
|
||||
//Tabellenspalten
|
||||
public $akte_id;
|
||||
public $person_id;
|
||||
public $dokument_kurzbz;
|
||||
public $inhalt;
|
||||
public $mimetype;
|
||||
public $erstelltam;
|
||||
public $gedruckt;
|
||||
public $titel;
|
||||
public $bezeichnung;
|
||||
public $updateamum;
|
||||
public $updatevon;
|
||||
public $insertamum;
|
||||
public $insertvon;
|
||||
public $uid;
|
||||
public $ext_id;
|
||||
public $dms_id;
|
||||
public $nachgereicht;
|
||||
public $anmerkung;
|
||||
public $titel_intern;
|
||||
public $anmerkung_intern;
|
||||
|
||||
/**
|
||||
* Konstruktor
|
||||
* @param akte_id ID des zu ladenden Datensatzes
|
||||
*/
|
||||
public function __construct($akte_id=null)
|
||||
{
|
||||
parent::__construct();
|
||||
|
||||
if(!is_null($akte_id))
|
||||
$this->load($akte_id);
|
||||
}
|
||||
|
||||
/**
|
||||
* Laedt einen Datensatz
|
||||
* @param akte_id ID des zu ladenden Datensatzes
|
||||
*/
|
||||
public function load($akte_id)
|
||||
{
|
||||
//akte_id auf gueltigkeit pruefen
|
||||
if(!is_numeric($akte_id) || $akte_id == '')
|
||||
{
|
||||
$this->errormsg = 'akte_id muss eine gueltige Zahl sein';
|
||||
return false;
|
||||
}
|
||||
|
||||
//laden des Datensatzes
|
||||
$qry = "SELECT * FROM public.tbl_akte WHERE akte_id=".$this->db_add_param($akte_id, FHC_INTEGER);
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
if($row = $this->db_fetch_object())
|
||||
{
|
||||
$this->akte_id = $row->akte_id;
|
||||
$this->person_id = $row->person_id;
|
||||
$this->dokument_kurzbz = $row->dokument_kurzbz;
|
||||
$this->inhalt = $row->inhalt;
|
||||
$this->mimetype = $row->mimetype;
|
||||
$this->erstelltam = $row->erstelltam;
|
||||
$this->gedruckt = $this->db_parse_bool($row->gedruckt);
|
||||
$this->titel = $row->titel;
|
||||
$this->bezeichnung = $row->bezeichnung;
|
||||
$this->updateamum = $row->updateamum;
|
||||
$this->updatevon = $row->updatevon;
|
||||
$this->insertamum = $row->insertamum;
|
||||
$this->insertvon = $row->insertvon;
|
||||
$this->uid = $row->uid;
|
||||
$this->dms_id = $row->dms_id;
|
||||
$this->anmerkung = $row->anmerkung;
|
||||
$this->nachgereicht = $this->db_parse_bool($row->nachgereicht);
|
||||
$this->titel_intern = $row->titel_intern;
|
||||
$this->anmerkung_intern = $row->anmerkung_intern;
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler bei der Datenbankabfrage';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler bei der Datenbankabfrage';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Loescht einen Datensatz
|
||||
* @param akte_id ID des zu loeschenden Datensatzes
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function delete($akte_id)
|
||||
{
|
||||
//akte_id auf gueltigkeit pruefen
|
||||
if(!is_numeric($akte_id) || $akte_id == '')
|
||||
{
|
||||
$this->errormsg = 'akte_id muss eine gueltige Zahl sein';
|
||||
return false;
|
||||
}
|
||||
|
||||
$qry = "DELETE FROM public.tbl_akte WHERE akte_id=".$this->db_add_param($akte_id, FHC_INTEGER);
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
//Log schreiben
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Löschen';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Prueft die Variablen vor dem Speichern
|
||||
*
|
||||
* @return true wenn ok, sonst false
|
||||
*/
|
||||
protected function validate()
|
||||
{
|
||||
if($this->person_id=='')
|
||||
{
|
||||
$this->errormsg = 'Person ID muss angegeben werden';
|
||||
return false;
|
||||
}
|
||||
if($this->dokument_kurzbz=='')
|
||||
{
|
||||
$this->errormsg = 'DokumentKurzbz muss angegeben werden';
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Speichert den aktuellen Datensatz
|
||||
* Wenn $neu auf true gesetzt ist wird ein neuer Datensatz angelegt
|
||||
* andernfalls wird der Datensatz mit der ID in $akte_id aktualisiert
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function save($new=null)
|
||||
{
|
||||
if(!$this->validate())
|
||||
return false;
|
||||
|
||||
if($new==null)
|
||||
$new = $this->new;
|
||||
|
||||
if($new)
|
||||
{
|
||||
//Neuen Datensatz anlegen
|
||||
$qry = "BEGIN;INSERT INTO public.tbl_akte (person_id, dokument_kurzbz, inhalt, mimetype, erstelltam, gedruckt, titel,
|
||||
bezeichnung, updateamum, updatevon, insertamum, insertvon, uid, dms_id, nachgereicht, anmerkung, titel_intern, anmerkung_intern ) VALUES (".
|
||||
$this->db_add_param($this->person_id, FHC_INTEGER).', '.
|
||||
$this->db_add_param($this->dokument_kurzbz).', '.
|
||||
$this->db_add_param($this->inhalt).', '.
|
||||
$this->db_add_param($this->mimetype).', '.
|
||||
$this->db_add_param($this->erstelltam).', '.
|
||||
$this->db_add_param($this->gedruckt, FHC_BOOLEAN).', '.
|
||||
$this->db_add_param($this->titel).', '.
|
||||
$this->db_add_param($this->bezeichnung).', '.
|
||||
$this->db_add_param($this->updateamum).', '.
|
||||
$this->db_add_param($this->updatevon).', '.
|
||||
$this->db_add_param($this->insertamum).', '.
|
||||
$this->db_add_param($this->insertvon).', '.
|
||||
$this->db_add_param($this->uid).','.
|
||||
$this->db_add_param($this->dms_id, FHC_INTEGER).','.
|
||||
$this->db_add_param($this->nachgereicht, FHC_BOOLEAN).','.
|
||||
$this->db_add_param($this->anmerkung).','.
|
||||
$this->db_add_param($this->titel_intern).','.
|
||||
$this->db_add_param($this->anmerkung_intern).');';
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
//Bestehenden Datensatz aktualisieren
|
||||
$qry= "UPDATE public.tbl_akte SET".
|
||||
" person_id=".$this->db_add_param($this->person_id, FHC_INTEGER).",".
|
||||
" dokument_kurzbz=".$this->db_add_param($this->dokument_kurzbz).",".
|
||||
" inhalt=".$this->db_add_param($this->inhalt).",".
|
||||
" mimetype=".$this->db_add_param($this->mimetype).",".
|
||||
" erstelltam=".$this->db_add_param($this->erstelltam).",".
|
||||
" gedruckt=".$this->db_add_param($this->gedruckt,FHC_BOOLEAN).",".
|
||||
" titel=".$this->db_add_param($this->titel).",".
|
||||
" bezeichnung=".$this->db_add_param($this->bezeichnung).",".
|
||||
" updateamum=".$this->db_add_param($this->updateamum).",".
|
||||
" updatevon=".$this->db_add_param($this->updatevon).",".
|
||||
" uid=".$this->db_add_param($this->uid).",".
|
||||
" dms_id=".$this->db_add_param($this->dms_id, FHC_INTEGER).",".
|
||||
" nachgereicht=".$this->db_add_param($this->nachgereicht, FHC_BOOLEAN).",".
|
||||
" anmerkung=".$this->db_add_param($this->anmerkung).",".
|
||||
" titel_intern=".$this->db_add_param($this->titel_intern).",".
|
||||
" anmerkung_intern=".$this->db_add_param($this->anmerkung_intern).
|
||||
" WHERE akte_id=".$this->db_add_param($this->akte_id, FHC_INTEGER);
|
||||
}
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
if($new)
|
||||
{
|
||||
$qry = "SELECT currval('public.tbl_akte_akte_id_seq') as id";
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
if($row = $this->db_fetch_object())
|
||||
{
|
||||
$this->akte_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;
|
||||
}
|
||||
}
|
||||
else
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Speichern des Datensatzes';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Liefert die Akten einer Person
|
||||
*
|
||||
* @param $person_id
|
||||
* @param $dokument_kurzbz
|
||||
* @param $stg_kz -> wenn gesetzt werden nur Akten angezeigt die ZUSÄTZLICH zum Studiengang abgegeben worden sind ohne Zeugnis
|
||||
* @param $prestudent_id -> gesetzt wenn auch stg_kz gesetzt ist um sicherzugehen, dass Akten, die er schon für seinen Studiengang abgegeben hat,
|
||||
* nicht mehr angezeigt werden
|
||||
* @return true wenn ok, sonst false
|
||||
*/
|
||||
public function getAkten($person_id, $dokument_kurzbz=null, $stg_kz = null, $prestudent_id= null)
|
||||
{
|
||||
$qry = "SELECT
|
||||
akte_id, person_id, dokument_kurzbz, mimetype, erstelltam, gedruckt, titel_intern, anmerkung_intern,
|
||||
titel, bezeichnung, updateamum, insertamum, updatevon, insertvon, uid, dms_id, anmerkung, nachgereicht,
|
||||
CASE WHEN inhalt is not null THEN true ELSE false END as inhalt_vorhanden
|
||||
FROM public.tbl_akte WHERE person_id=".$this->db_add_param($person_id, FHC_INTEGER);
|
||||
if($dokument_kurzbz!=null)
|
||||
$qry.=" AND dokument_kurzbz=".$this->db_add_param($dokument_kurzbz);
|
||||
if($stg_kz != null && $prestudent_id != null)
|
||||
$qry.=" AND dokument_kurzbz not in (SELECT dokument_kurzbz FROM public.tbl_dokument JOIN public.tbl_dokumentstudiengang USING(dokument_kurzbz)
|
||||
WHERE studiengang_kz= ".$this->db_add_param($stg_kz).") AND dokument_kurzbz NOT IN ('Zeugnis') AND dokument_kurzbz NOT IN
|
||||
(SELECT dokument_kurzbz FROM public.tbl_dokumentprestudent JOIN public.tbl_dokument USING(dokument_kurzbz)
|
||||
WHERE prestudent_id=".$this->db_add_param($prestudent_id).")";
|
||||
|
||||
$qry.=" ORDER BY erstelltam";
|
||||
|
||||
$this->errormsg = $qry;
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
while($row = $this->db_fetch_object())
|
||||
{
|
||||
$akten = new akte();
|
||||
|
||||
$akten->akte_id = $row->akte_id;
|
||||
$akten->person_id = $row->person_id;
|
||||
$akten->dokument_kurzbz = $row->dokument_kurzbz;
|
||||
//$akte->inhalt = $row->inhalt;
|
||||
$akten->inhalt_vorhanden = $this->db_parse_bool($row->inhalt_vorhanden);
|
||||
$akten->mimetype = $row->mimetype;
|
||||
$akten->erstelltam = $row->erstelltam;
|
||||
$akten->gedruckt = $this->db_parse_bool($row->gedruckt);
|
||||
$akten->titel = $row->titel;
|
||||
$akten->bezeichnung = $row->bezeichnung;
|
||||
$akten->updateamum = $row->updateamum;
|
||||
$akten->updatevon = $row->updatevon;
|
||||
$akten->insertamum = $row->insertamum;
|
||||
$akten->insertvon = $row->insertvon;
|
||||
$akten->uid = $row->uid;
|
||||
$akten->dms_id = $row->dms_id;
|
||||
$akten->nachgereicht = $this->db_parse_bool($row->nachgereicht);
|
||||
$akten->anmerkung = $row->anmerkung;
|
||||
$akten->titel_intern = $row->titel_intern;
|
||||
$akten->anmerkung_intern = $row->anmerkung_intern;
|
||||
|
||||
$this->result[] = $akten;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Liefert die Akten die ein Outgoing sehen darf
|
||||
*
|
||||
* @param $person_id
|
||||
* @return true wenn ok, sonst false
|
||||
*/
|
||||
public function getAktenOutgoing($person_id)
|
||||
{
|
||||
$qry = "SELECT
|
||||
akte_id, person_id, dokument_kurzbz, mimetype, erstelltam, gedruckt,
|
||||
titel, bezeichnung, updateamum, insertamum, updatevon, insertvon, uid,
|
||||
dms_id,nachgereicht,anmerkung,titel_intern,anmerkung_intern
|
||||
FROM public.tbl_akte WHERE person_id=".$this->db_add_param($person_id, FHC_INTEGER);
|
||||
|
||||
$qry.=" AND dokument_kurzbz IN ('Lebenslf','Motivat','LearnAgr')";
|
||||
$qry.=" ORDER BY erstelltam";
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
while($row = $this->db_fetch_object())
|
||||
{
|
||||
$akten = new akte();
|
||||
|
||||
$akten->akte_id = $row->akte_id;
|
||||
$akten->person_id = $row->person_id;
|
||||
$akten->dokument_kurzbz = $row->dokument_kurzbz;
|
||||
//$akte->inhalt = $row->inhalt;
|
||||
$akten->mimetype = $row->mimetype;
|
||||
$akten->erstelltam = $row->erstelltam;
|
||||
$akten->gedruckt = $this->db_parse_bool($row->gedruckt);
|
||||
$akten->titel = $row->titel;
|
||||
$akten->bezeichnung = $row->bezeichnung;
|
||||
$akten->updateamum = $row->updateamum;
|
||||
$akten->updatevon = $row->updatevon;
|
||||
$akten->insertamum = $row->insertamum;
|
||||
$akten->insertvon = $row->insertvon;
|
||||
$akten->uid = $row->uid;
|
||||
$akten->dms_id = $row->dms_id;
|
||||
$akten->nachgereicht = $this->db_parse_bool($row->nachgereicht);
|
||||
$akten->anmerkung = $row->anmerkung;
|
||||
$akten->titel_intern = $row->titel_intern;
|
||||
$akten->anmerkung_intern = $row->anmerkung_intern;
|
||||
|
||||
$this->result[] = $akten;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Liefert die Akten anhand der dms_id
|
||||
*
|
||||
* @param $person_id
|
||||
* @return true wenn ok, sonst false
|
||||
*/
|
||||
public function getAktenDms($dms_id)
|
||||
{
|
||||
$qry = "SELECT
|
||||
akte_id, person_id, dokument_kurzbz, mimetype, erstelltam, gedruckt,
|
||||
titel, bezeichnung, updateamum, insertamum, updatevon, insertvon, uid,
|
||||
dms_id,nachgereicht,anmerkung,titel_intern,anmerkung_intern
|
||||
FROM public.tbl_akte WHERE dms_id=".$this->db_add_param($dms_id, FHC_INTEGER)."
|
||||
ORDER BY erstelltam";
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
while($row = $this->db_fetch_object())
|
||||
{
|
||||
$akten = new akte();
|
||||
|
||||
$akten->akte_id = $row->akte_id;
|
||||
$akten->person_id = $row->person_id;
|
||||
$akten->dokument_kurzbz = $row->dokument_kurzbz;
|
||||
//$akte->inhalt = $row->inhalt;
|
||||
$akten->mimetype = $row->mimetype;
|
||||
$akten->erstelltam = $row->erstelltam;
|
||||
$akten->gedruckt = $this->db_parse_bool($row->gedruckt);
|
||||
$akten->titel = $row->titel;
|
||||
$akten->bezeichnung = $row->bezeichnung;
|
||||
$akten->updateamum = $row->updateamum;
|
||||
$akten->updatevon = $row->updatevon;
|
||||
$akten->insertamum = $row->insertamum;
|
||||
$akten->insertvon = $row->insertvon;
|
||||
$akten->uid = $row->uid;
|
||||
$akten->dms_id = $row->dms_id;
|
||||
$akten->nachgereicht = $this->db_parse_bool($row->nachgereicht);
|
||||
$akten->anmerkung = $row->anmerkung;
|
||||
$akten->titel_intern = $row->titel_intern;
|
||||
$akten->anmerkung_intern = $row->anmerkung_intern;
|
||||
|
||||
$this->result[] = $akten;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
?>
|
||||
<?php
|
||||
/* Copyright (C) 2006 Technikum-Wien
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors: Christian Paminger <christian.paminger@technikum-wien.at>,
|
||||
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at>,
|
||||
* Rudolf Hangl <rudolf.hangl@technikum-wien.at> and
|
||||
* Andreas Moik <moik@technikum-wien.at>.
|
||||
*/
|
||||
require_once(dirname(__FILE__).'/basis_db.class.php');
|
||||
|
||||
class akte extends basis_db
|
||||
{
|
||||
public $new;
|
||||
public $result = array();
|
||||
|
||||
//Tabellenspalten
|
||||
public $akte_id;
|
||||
public $person_id;
|
||||
public $dokument_kurzbz;
|
||||
public $inhalt;
|
||||
public $mimetype;
|
||||
public $erstelltam;
|
||||
public $gedruckt;
|
||||
public $titel;
|
||||
public $bezeichnung;
|
||||
public $updateamum;
|
||||
public $updatevon;
|
||||
public $insertamum;
|
||||
public $insertvon;
|
||||
public $uid;
|
||||
public $ext_id;
|
||||
public $dms_id;
|
||||
public $nachgereicht;
|
||||
public $anmerkung;
|
||||
public $titel_intern;
|
||||
public $anmerkung_intern;
|
||||
|
||||
/**
|
||||
* Konstruktor
|
||||
* @param akte_id ID des zu ladenden Datensatzes
|
||||
*/
|
||||
public function __construct($akte_id=null)
|
||||
{
|
||||
parent::__construct();
|
||||
|
||||
if(!is_null($akte_id))
|
||||
$this->load($akte_id);
|
||||
}
|
||||
|
||||
/**
|
||||
* Laedt einen Datensatz
|
||||
* @param akte_id ID des zu ladenden Datensatzes
|
||||
*/
|
||||
public function load($akte_id)
|
||||
{
|
||||
//akte_id auf gueltigkeit pruefen
|
||||
if(!is_numeric($akte_id) || $akte_id == '')
|
||||
{
|
||||
$this->errormsg = 'akte_id muss eine gueltige Zahl sein';
|
||||
return false;
|
||||
}
|
||||
|
||||
//laden des Datensatzes
|
||||
$qry = "SELECT * FROM public.tbl_akte WHERE akte_id=".$this->db_add_param($akte_id, FHC_INTEGER);
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
if($row = $this->db_fetch_object())
|
||||
{
|
||||
$this->akte_id = $row->akte_id;
|
||||
$this->person_id = $row->person_id;
|
||||
$this->dokument_kurzbz = $row->dokument_kurzbz;
|
||||
$this->inhalt = $row->inhalt;
|
||||
$this->mimetype = $row->mimetype;
|
||||
$this->erstelltam = $row->erstelltam;
|
||||
$this->gedruckt = $this->db_parse_bool($row->gedruckt);
|
||||
$this->titel = $row->titel;
|
||||
$this->bezeichnung = $row->bezeichnung;
|
||||
$this->updateamum = $row->updateamum;
|
||||
$this->updatevon = $row->updatevon;
|
||||
$this->insertamum = $row->insertamum;
|
||||
$this->insertvon = $row->insertvon;
|
||||
$this->uid = $row->uid;
|
||||
$this->dms_id = $row->dms_id;
|
||||
$this->anmerkung = $row->anmerkung;
|
||||
$this->nachgereicht = $this->db_parse_bool($row->nachgereicht);
|
||||
$this->titel_intern = $row->titel_intern;
|
||||
$this->anmerkung_intern = $row->anmerkung_intern;
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler bei der Datenbankabfrage';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler bei der Datenbankabfrage';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Loescht einen Datensatz
|
||||
* @param akte_id ID des zu loeschenden Datensatzes
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function delete($akte_id)
|
||||
{
|
||||
//akte_id auf gueltigkeit pruefen
|
||||
if(!is_numeric($akte_id) || $akte_id == '')
|
||||
{
|
||||
$this->errormsg = 'akte_id muss eine gueltige Zahl sein';
|
||||
return false;
|
||||
}
|
||||
|
||||
$qry = "DELETE FROM public.tbl_akte WHERE akte_id=".$this->db_add_param($akte_id, FHC_INTEGER);
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
//Log schreiben
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Löschen';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Prueft die Variablen vor dem Speichern
|
||||
*
|
||||
* @return true wenn ok, sonst false
|
||||
*/
|
||||
protected function validate()
|
||||
{
|
||||
if($this->person_id=='')
|
||||
{
|
||||
$this->errormsg = 'Person ID muss angegeben werden';
|
||||
return false;
|
||||
}
|
||||
if($this->dokument_kurzbz=='')
|
||||
{
|
||||
$this->errormsg = 'DokumentKurzbz muss angegeben werden';
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Speichert den aktuellen Datensatz
|
||||
* Wenn $neu auf true gesetzt ist wird ein neuer Datensatz angelegt
|
||||
* andernfalls wird der Datensatz mit der ID in $akte_id aktualisiert
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function save($new=null)
|
||||
{
|
||||
if(!$this->validate())
|
||||
return false;
|
||||
|
||||
if($new==null)
|
||||
$new = $this->new;
|
||||
|
||||
if($new)
|
||||
{
|
||||
//Neuen Datensatz anlegen
|
||||
$qry = "BEGIN;INSERT INTO public.tbl_akte (person_id, dokument_kurzbz, inhalt, mimetype, erstelltam, gedruckt, titel,
|
||||
bezeichnung, updateamum, updatevon, insertamum, insertvon, uid, dms_id, nachgereicht, anmerkung, titel_intern, anmerkung_intern ) VALUES (".
|
||||
$this->db_add_param($this->person_id, FHC_INTEGER).', '.
|
||||
$this->db_add_param($this->dokument_kurzbz).', '.
|
||||
$this->db_add_param($this->inhalt).', '.
|
||||
$this->db_add_param($this->mimetype).', '.
|
||||
$this->db_add_param($this->erstelltam).', '.
|
||||
$this->db_add_param($this->gedruckt, FHC_BOOLEAN).', '.
|
||||
$this->db_add_param($this->titel).', '.
|
||||
$this->db_add_param($this->bezeichnung).', '.
|
||||
$this->db_add_param($this->updateamum).', '.
|
||||
$this->db_add_param($this->updatevon).', '.
|
||||
$this->db_add_param($this->insertamum).', '.
|
||||
$this->db_add_param($this->insertvon).', '.
|
||||
$this->db_add_param($this->uid).','.
|
||||
$this->db_add_param($this->dms_id, FHC_INTEGER).','.
|
||||
$this->db_add_param($this->nachgereicht, FHC_BOOLEAN).','.
|
||||
$this->db_add_param($this->anmerkung).','.
|
||||
$this->db_add_param($this->titel_intern).','.
|
||||
$this->db_add_param($this->anmerkung_intern).');';
|
||||
}
|
||||
else
|
||||
{
|
||||
//Bestehenden Datensatz aktualisieren
|
||||
$qry= "UPDATE public.tbl_akte SET".
|
||||
" person_id=".$this->db_add_param($this->person_id, FHC_INTEGER).",".
|
||||
" dokument_kurzbz=".$this->db_add_param($this->dokument_kurzbz).",".
|
||||
" inhalt=".$this->db_add_param($this->inhalt).",".
|
||||
" mimetype=".$this->db_add_param($this->mimetype).",".
|
||||
" erstelltam=".$this->db_add_param($this->erstelltam).",".
|
||||
" gedruckt=".$this->db_add_param($this->gedruckt,FHC_BOOLEAN).",".
|
||||
" titel=".$this->db_add_param($this->titel).",".
|
||||
" bezeichnung=".$this->db_add_param($this->bezeichnung).",".
|
||||
" updateamum=".$this->db_add_param($this->updateamum).",".
|
||||
" updatevon=".$this->db_add_param($this->updatevon).",".
|
||||
" uid=".$this->db_add_param($this->uid).",".
|
||||
" dms_id=".$this->db_add_param($this->dms_id, FHC_INTEGER).",".
|
||||
" nachgereicht=".$this->db_add_param($this->nachgereicht, FHC_BOOLEAN).",".
|
||||
" anmerkung=".$this->db_add_param($this->anmerkung).",".
|
||||
" titel_intern=".$this->db_add_param($this->titel_intern).",".
|
||||
" anmerkung_intern=".$this->db_add_param($this->anmerkung_intern).
|
||||
" WHERE akte_id=".$this->db_add_param($this->akte_id, FHC_INTEGER);
|
||||
}
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
if($new)
|
||||
{
|
||||
$qry = "SELECT currval('public.tbl_akte_akte_id_seq') as id";
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
if($row = $this->db_fetch_object())
|
||||
{
|
||||
$this->akte_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;
|
||||
}
|
||||
}
|
||||
else
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Speichern des Datensatzes';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Liefert die Akten einer Person
|
||||
*
|
||||
* @param $person_id
|
||||
* @param $dokument_kurzbz
|
||||
* @param $stg_kz -> wenn gesetzt werden nur Akten angezeigt die ZUSÄTZLICH zum Studiengang abgegeben worden sind ohne Zeugnis
|
||||
* @param $prestudent_id -> gesetzt wenn auch stg_kz gesetzt ist um sicherzugehen, dass Akten, die er schon für seinen Studiengang abgegeben hat,
|
||||
* nicht mehr angezeigt werden
|
||||
* @return true wenn ok, sonst false
|
||||
*/
|
||||
public function getAkten($person_id, $dokument_kurzbz=null, $stg_kz = null, $prestudent_id= null)
|
||||
{
|
||||
$qry = "SELECT
|
||||
akte_id, person_id, dokument_kurzbz, mimetype, erstelltam, gedruckt, titel_intern, anmerkung_intern,
|
||||
titel, bezeichnung, updateamum, insertamum, updatevon, insertvon, uid, dms_id, anmerkung, nachgereicht,
|
||||
CASE WHEN inhalt is not null THEN true ELSE false END as inhalt_vorhanden
|
||||
FROM public.tbl_akte WHERE person_id=".$this->db_add_param($person_id, FHC_INTEGER);
|
||||
if($dokument_kurzbz!=null)
|
||||
$qry.=" AND dokument_kurzbz=".$this->db_add_param($dokument_kurzbz);
|
||||
if($stg_kz != null && $prestudent_id != null)
|
||||
$qry.=" AND dokument_kurzbz not in (SELECT dokument_kurzbz FROM public.tbl_dokument JOIN public.tbl_dokumentstudiengang USING(dokument_kurzbz)
|
||||
WHERE studiengang_kz= ".$this->db_add_param($stg_kz).") AND dokument_kurzbz NOT IN ('Zeugnis') AND dokument_kurzbz NOT IN
|
||||
(SELECT dokument_kurzbz FROM public.tbl_dokumentprestudent JOIN public.tbl_dokument USING(dokument_kurzbz)
|
||||
WHERE prestudent_id=".$this->db_add_param($prestudent_id).")";
|
||||
|
||||
$qry.=" ORDER BY erstelltam";
|
||||
|
||||
$this->errormsg = $qry;
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
while($row = $this->db_fetch_object())
|
||||
{
|
||||
$akten = new akte();
|
||||
|
||||
$akten->akte_id = $row->akte_id;
|
||||
$akten->person_id = $row->person_id;
|
||||
$akten->dokument_kurzbz = $row->dokument_kurzbz;
|
||||
//$akte->inhalt = $row->inhalt;
|
||||
$akten->inhalt_vorhanden = $this->db_parse_bool($row->inhalt_vorhanden);
|
||||
$akten->mimetype = $row->mimetype;
|
||||
$akten->erstelltam = $row->erstelltam;
|
||||
$akten->gedruckt = $this->db_parse_bool($row->gedruckt);
|
||||
$akten->titel = $row->titel;
|
||||
$akten->bezeichnung = $row->bezeichnung;
|
||||
$akten->updateamum = $row->updateamum;
|
||||
$akten->updatevon = $row->updatevon;
|
||||
$akten->insertamum = $row->insertamum;
|
||||
$akten->insertvon = $row->insertvon;
|
||||
$akten->uid = $row->uid;
|
||||
$akten->dms_id = $row->dms_id;
|
||||
$akten->nachgereicht = $this->db_parse_bool($row->nachgereicht);
|
||||
$akten->anmerkung = $row->anmerkung;
|
||||
$akten->titel_intern = $row->titel_intern;
|
||||
$akten->anmerkung_intern = $row->anmerkung_intern;
|
||||
|
||||
$this->result[] = $akten;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Liefert die Akten die ein Outgoing sehen darf
|
||||
*
|
||||
* @param $person_id
|
||||
* @return true wenn ok, sonst false
|
||||
*/
|
||||
public function getAktenOutgoing($person_id)
|
||||
{
|
||||
$qry = "SELECT
|
||||
akte_id, person_id, dokument_kurzbz, mimetype, erstelltam, gedruckt,
|
||||
titel, bezeichnung, updateamum, insertamum, updatevon, insertvon, uid,
|
||||
dms_id,nachgereicht,anmerkung,titel_intern,anmerkung_intern
|
||||
FROM public.tbl_akte WHERE person_id=".$this->db_add_param($person_id, FHC_INTEGER);
|
||||
|
||||
$qry.=" AND dokument_kurzbz IN ('Lebenslf','Motivat','LearnAgr')";
|
||||
$qry.=" ORDER BY erstelltam";
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
while($row = $this->db_fetch_object())
|
||||
{
|
||||
$akten = new akte();
|
||||
|
||||
$akten->akte_id = $row->akte_id;
|
||||
$akten->person_id = $row->person_id;
|
||||
$akten->dokument_kurzbz = $row->dokument_kurzbz;
|
||||
//$akte->inhalt = $row->inhalt;
|
||||
$akten->mimetype = $row->mimetype;
|
||||
$akten->erstelltam = $row->erstelltam;
|
||||
$akten->gedruckt = $this->db_parse_bool($row->gedruckt);
|
||||
$akten->titel = $row->titel;
|
||||
$akten->bezeichnung = $row->bezeichnung;
|
||||
$akten->updateamum = $row->updateamum;
|
||||
$akten->updatevon = $row->updatevon;
|
||||
$akten->insertamum = $row->insertamum;
|
||||
$akten->insertvon = $row->insertvon;
|
||||
$akten->uid = $row->uid;
|
||||
$akten->dms_id = $row->dms_id;
|
||||
$akten->nachgereicht = $this->db_parse_bool($row->nachgereicht);
|
||||
$akten->anmerkung = $row->anmerkung;
|
||||
$akten->titel_intern = $row->titel_intern;
|
||||
$akten->anmerkung_intern = $row->anmerkung_intern;
|
||||
|
||||
$this->result[] = $akten;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Liefert die Akten anhand der dms_id
|
||||
*
|
||||
* @param $person_id
|
||||
* @return true wenn ok, sonst false
|
||||
*/
|
||||
public function getAktenDms($dms_id)
|
||||
{
|
||||
$qry = "SELECT
|
||||
akte_id, person_id, dokument_kurzbz, mimetype, erstelltam, gedruckt,
|
||||
titel, bezeichnung, updateamum, insertamum, updatevon, insertvon, uid,
|
||||
dms_id,nachgereicht,anmerkung,titel_intern,anmerkung_intern
|
||||
FROM public.tbl_akte WHERE dms_id=".$this->db_add_param($dms_id, FHC_INTEGER)."
|
||||
ORDER BY erstelltam";
|
||||
|
||||
if($this->db_query($qry))
|
||||
{
|
||||
while($row = $this->db_fetch_object())
|
||||
{
|
||||
$akten = new akte();
|
||||
|
||||
$akten->akte_id = $row->akte_id;
|
||||
$akten->person_id = $row->person_id;
|
||||
$akten->dokument_kurzbz = $row->dokument_kurzbz;
|
||||
//$akte->inhalt = $row->inhalt;
|
||||
$akten->mimetype = $row->mimetype;
|
||||
$akten->erstelltam = $row->erstelltam;
|
||||
$akten->gedruckt = $this->db_parse_bool($row->gedruckt);
|
||||
$akten->titel = $row->titel;
|
||||
$akten->bezeichnung = $row->bezeichnung;
|
||||
$akten->updateamum = $row->updateamum;
|
||||
$akten->updatevon = $row->updatevon;
|
||||
$akten->insertamum = $row->insertamum;
|
||||
$akten->insertvon = $row->insertvon;
|
||||
$akten->uid = $row->uid;
|
||||
$akten->dms_id = $row->dms_id;
|
||||
$akten->nachgereicht = $this->db_parse_bool($row->nachgereicht);
|
||||
$akten->anmerkung = $row->anmerkung;
|
||||
$akten->titel_intern = $row->titel_intern;
|
||||
$akten->anmerkung_intern = $row->anmerkung_intern;
|
||||
|
||||
$this->result[] = $akten;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
?>
|
||||
|
||||
+530
-530
File diff suppressed because it is too large
Load Diff
+303
-247
@@ -16,282 +16,338 @@
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors: Nikolaus Krondraf <nikolaus.krondraf@technikum-wien.at>
|
||||
* Authors: Nikolaus Krondraf <nikolaus.krondraf@technikum-wien.at> and
|
||||
* Andreas Moik <moik@technikum-wien.at>.
|
||||
*/
|
||||
require_once(dirname(__FILE__) . '/basis_db.class.php');
|
||||
require_once(dirname(__FILE__) . '/datum.class.php');
|
||||
require_once(dirname(__FILE__) . '/lehrveranstaltung.class.php');
|
||||
|
||||
class anrechnung extends basis_db {
|
||||
class anrechnung extends basis_db
|
||||
{
|
||||
|
||||
public $errormsg;
|
||||
public $new;
|
||||
public $result;
|
||||
// Tabellenspalten
|
||||
public $anrechnung_id; // integer
|
||||
public $prestudent_id; // integer
|
||||
public $lehrveranstaltung_id; // integer
|
||||
public $begruendung_id; // integer
|
||||
public $lehrveranstaltung_id_kompatibel; // integer
|
||||
public $genehmigt_von; // varchar(32)
|
||||
public $insertamum; // timestamp
|
||||
public $insertvon; // varchar(32)
|
||||
public $updateamum; // timestamp
|
||||
public $updatevon; // varchar(32)
|
||||
public $begruendungen = array();
|
||||
public $errormsg;
|
||||
public $new;
|
||||
public $result;
|
||||
// Tabellenspalten
|
||||
public $anrechnung_id; // integer
|
||||
public $prestudent_id; // integer
|
||||
public $lehrveranstaltung_id; // integer
|
||||
public $begruendung_id; // integer
|
||||
public $lehrveranstaltung_id_kompatibel; // integer
|
||||
public $genehmigt_von; // varchar(32)
|
||||
public $insertamum; // timestamp
|
||||
public $insertvon; // varchar(32)
|
||||
public $updateamum; // timestamp
|
||||
public $updatevon; // varchar(32)
|
||||
public $begruendungen = array();
|
||||
|
||||
/**
|
||||
* Konstruktor - Laedt optional eine Anrechnung
|
||||
* @param $anrechnung_id
|
||||
*/
|
||||
public function __construct($anrechnung_id = null) {
|
||||
parent::__construct();
|
||||
if ($anrechnung_id != null)
|
||||
$this->load($anrechnung_id);
|
||||
}
|
||||
|
||||
public function validate() {
|
||||
if (!is_numeric($this->prestudent_id)) {
|
||||
$this->errormsg = "Prestudent_id ist ungueltig";
|
||||
return false;
|
||||
/**
|
||||
* Konstruktor - Laedt optional eine Anrechnung
|
||||
* @param $anrechnung_id
|
||||
*/
|
||||
public function __construct($anrechnung_id = null)
|
||||
{
|
||||
parent::__construct();
|
||||
if ($anrechnung_id != null)
|
||||
$this->load($anrechnung_id);
|
||||
}
|
||||
|
||||
if (!is_numeric($this->lehrveranstaltung_id)) {
|
||||
$this->errormsg = "Wählen Sie eine Lehrveranstaltung aus";
|
||||
return false;
|
||||
public function validate()
|
||||
{
|
||||
if (!is_numeric($this->prestudent_id))
|
||||
{
|
||||
$this->errormsg = "Prestudent_id ist ungueltig";
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!is_numeric($this->lehrveranstaltung_id))
|
||||
{
|
||||
$this->errormsg = "Wählen Sie eine Lehrveranstaltung aus";
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!is_numeric($this->begruendung_id))
|
||||
{
|
||||
$this->errormsg = "Wählen Sie eine Begründung aus";
|
||||
return false;
|
||||
}
|
||||
|
||||
if ($this->begruendung_id == "2" && !is_numeric($this->lehrveranstaltung_id_kompatibel))
|
||||
{
|
||||
$this->errormsg = "Wählen Sie eine kompatible Lehrveranstaltung aus";
|
||||
return false;
|
||||
}
|
||||
|
||||
if (empty($this->genehmigt_von))
|
||||
{
|
||||
$this->errormsg = "Wählen Sie die Person aus, die die Anrechnung genehmigt hat";
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
if (!is_numeric($this->begruendung_id)) {
|
||||
$this->errormsg = "Wählen Sie eine Begründung aus";
|
||||
return false;
|
||||
/**
|
||||
* Lädt eine Anrechnung
|
||||
* @param $anrechnung_id ID der Anrechnung
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function getAnrechnung($anrechnung_id)
|
||||
{
|
||||
$qry = "SELECT anrechnung_id, prestudent_id, lehrveranstaltung_id, begruendung_id, bezeichnung AS begruendung, "
|
||||
. "lehrveranstaltung_id_kompatibel, genehmigt_von, insertamum, insertvon, updateamum, updatevon "
|
||||
. "FROM lehre.tbl_anrechnung "
|
||||
. "JOIN lehre.tbl_anrechnung_begruendung USING (begruendung_id) "
|
||||
. "WHERE anrechnung_id = " . $this->db_add_param($anrechnung_id);
|
||||
|
||||
if ($result = $this->db_query($qry))
|
||||
{
|
||||
if ($row = $this->db_fetch_object($result))
|
||||
{
|
||||
$datum = new datum();
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id);
|
||||
$row->insertamum = $datum->convertISODate($row->insertamum);
|
||||
$row->lehrveranstaltung_bez = $lehrveranstaltung->bezeichnung;
|
||||
|
||||
if ($row->lehrveranstaltung_id_kompatibel != '')
|
||||
{
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id_kompatibel);
|
||||
$row->lehrveranstaltung_bez_kompatibel = $lehrveranstaltung->bezeichnung;
|
||||
}
|
||||
else
|
||||
$row->lehrveranstaltung_bez_kompatibel = null;
|
||||
|
||||
$this->result[] = $row;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Es wurde kein Datensatz mit dieser ID gefunden';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Speichert eine Anrechnung
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function save()
|
||||
{
|
||||
if (!$this->validate())
|
||||
return false;
|
||||
|
||||
if ($this->new == "1")
|
||||
{
|
||||
// Neuen Datensatz anlegen
|
||||
$qry = 'INSERT INTO lehre.tbl_anrechnung (prestudent_id, lehrveranstaltung_id, begruendung_id, lehrveranstaltung_id_kompatibel, genehmigt_von, insertamum, insertvon, updateamum, updatevon) VALUES (' .
|
||||
$this->db_add_param($this->prestudent_id) . ', ' .
|
||||
$this->db_add_param($this->lehrveranstaltung_id) . ', ' .
|
||||
$this->db_add_param($this->begruendung_id) . ', ' .
|
||||
$this->db_add_param($this->lehrveranstaltung_id_kompatibel) . ', ' .
|
||||
$this->db_add_param($this->genehmigt_von) . ', ' .
|
||||
'NOW(),' .
|
||||
$this->db_add_param($this->insertvon) . ', ' .
|
||||
'NOW(),' .
|
||||
$this->db_add_param($this->updatevon) . ') RETURNING anrechnung_id;';
|
||||
}
|
||||
else
|
||||
{
|
||||
// Datensatz aktualisieren
|
||||
$qry = 'UPDATE lehre.tbl_anrechnung SET '
|
||||
. 'lehrveranstaltung_id = ' . $this->db_add_param($this->lehrveranstaltung_id) . ', '
|
||||
. 'begruendung_id = ' . $this->db_add_param($this->begruendung_id) . ', '
|
||||
. 'lehrveranstaltung_id_kompatibel = ' . $this->db_add_param($this->lehrveranstaltung_id_kompatibel) . ', '
|
||||
. 'genehmigt_von = ' . $this->db_add_param($this->genehmigt_von) . ', '
|
||||
. 'updateamum = NOW(), '
|
||||
. 'updatevon = ' . $this->db_add_param($this->updatevon) . ' '
|
||||
. 'WHERE anrechnung_id = ' . $this->db_add_param($this->anrechnung_id);
|
||||
}
|
||||
|
||||
if ($this->db_query($qry))
|
||||
{
|
||||
$this->anrechnung_id = $this->db_fetch_object()->anrechnung_id;
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Speichern der Anrechnung: ' . $this->db_last_error();
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
if ($this->begruendung_id == "2" && !is_numeric($this->lehrveranstaltung_id_kompatibel)) {
|
||||
$this->errormsg = "Wählen Sie eine kompatible Lehrveranstaltung aus";
|
||||
return false;
|
||||
/**
|
||||
* Gibt alle Anrechnungen eines Prestudenten zurück
|
||||
* @param $prestudent_id
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function getAnrechnungPrestudent($prestudent_id)
|
||||
{
|
||||
$qry = "SELECT anrechnung_id, prestudent_id, lehrveranstaltung_id, begruendung_id, bezeichnung AS begruendung, "
|
||||
. "lehrveranstaltung_id_kompatibel, genehmigt_von , insertamum, insertvon, updateamum, updatevon "
|
||||
. "FROM lehre.tbl_anrechnung "
|
||||
. "JOIN lehre.tbl_anrechnung_begruendung USING (begruendung_id) "
|
||||
. "WHERE prestudent_id = " . $this->db_add_param($prestudent_id);
|
||||
|
||||
if ($this->db_query($qry))
|
||||
{
|
||||
$datum = new datum();
|
||||
|
||||
while ($row = $this->db_fetch_object())
|
||||
{
|
||||
$row->insertamum = $datum->convertISODate($row->insertamum);
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id);
|
||||
$row->lehrveranstaltung_bez = $lehrveranstaltung->bezeichnung;
|
||||
|
||||
if ($row->lehrveranstaltung_id_kompatibel != '')
|
||||
{
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id_kompatibel);
|
||||
$row->lehrveranstaltung_bez_kompatibel = $lehrveranstaltung->bezeichnung;
|
||||
}
|
||||
else
|
||||
$row->lehrveranstaltung_bez_kompatibel = null;
|
||||
|
||||
$this->result[] = $row;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Datensatz konnte nicht geladen werden';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
if (empty($this->genehmigt_von)) {
|
||||
$this->errormsg = "Wählen Sie die Person aus, die die Anrechnung genehmigt hat";
|
||||
return false;
|
||||
/**
|
||||
* Loescht eine Anrechnung
|
||||
* @param $anrechnung_id
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function delete($anrechnung_id)
|
||||
{
|
||||
$qry = "DELETE FROM lehre.tbl_anrechnung WHERE anrechnung_id = " . $this->db_add_param($anrechnung_id);
|
||||
|
||||
if ($this->db_query($qry))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Datensatz konnte nicht geloescht werden';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Lädt eine Anrechnung
|
||||
* @param $anrechnung_id ID der Anrechnung
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function getAnrechnung($anrechnung_id) {
|
||||
$qry = "SELECT anrechnung_id, prestudent_id, lehrveranstaltung_id, begruendung_id, bezeichnung AS begruendung, "
|
||||
. "lehrveranstaltung_id_kompatibel, genehmigt_von, insertamum, insertvon, updateamum, updatevon "
|
||||
. "FROM lehre.tbl_anrechnung "
|
||||
. "JOIN lehre.tbl_anrechnung_begruendung USING (begruendung_id) "
|
||||
. "WHERE anrechnung_id = " . $this->db_add_param($anrechnung_id);
|
||||
|
||||
if ($result = $this->db_query($qry)) {
|
||||
if ($row = $this->db_fetch_object($result)) {
|
||||
$datum = new datum();
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id);
|
||||
$row->insertamum = $datum->convertISODate($row->insertamum);
|
||||
$row->lehrveranstaltung_bez = $lehrveranstaltung->bezeichnung;
|
||||
if ($row->lehrveranstaltung_id_kompatibel != '') {
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id_kompatibel);
|
||||
$row->lehrveranstaltung_bez_kompatibel = $lehrveranstaltung->bezeichnung;
|
||||
} else
|
||||
$row->lehrveranstaltung_bez_kompatibel = null;
|
||||
|
||||
$this->result[] = $row;
|
||||
}
|
||||
else {
|
||||
$this->errormsg = 'Es wurde kein Datensatz mit dieser ID gefunden';
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Speichert eine Anrechnung
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function save() {
|
||||
if (!$this->validate())
|
||||
return false;
|
||||
|
||||
if ($this->new == "1") {
|
||||
// Neuen Datensatz anlegen
|
||||
$qry = 'INSERT INTO lehre.tbl_anrechnung (prestudent_id, lehrveranstaltung_id, begruendung_id, lehrveranstaltung_id_kompatibel, genehmigt_von, insertamum, insertvon, updateamum, updatevon) VALUES (' .
|
||||
$this->db_add_param($this->prestudent_id) . ', ' .
|
||||
$this->db_add_param($this->lehrveranstaltung_id) . ', ' .
|
||||
$this->db_add_param($this->begruendung_id) . ', ' .
|
||||
$this->db_add_param($this->lehrveranstaltung_id_kompatibel) . ', ' .
|
||||
$this->db_add_param($this->genehmigt_von) . ', ' .
|
||||
'NOW(),' .
|
||||
$this->db_add_param($this->insertvon) . ', ' .
|
||||
'NOW(),' .
|
||||
$this->db_add_param($this->updatevon) . ') RETURNING anrechnung_id;';
|
||||
} else {
|
||||
// Datensatz aktualisieren
|
||||
$qry = 'UPDATE lehre.tbl_anrechnung SET '
|
||||
. 'lehrveranstaltung_id = ' . $this->db_add_param($this->lehrveranstaltung_id) . ', '
|
||||
. 'begruendung_id = ' . $this->db_add_param($this->begruendung_id) . ', '
|
||||
. 'lehrveranstaltung_id_kompatibel = ' . $this->db_add_param($this->lehrveranstaltung_id_kompatibel) . ', '
|
||||
. 'genehmigt_von = ' . $this->db_add_param($this->genehmigt_von) . ', '
|
||||
. 'updateamum = NOW(), '
|
||||
. 'updatevon = ' . $this->db_add_param($this->updatevon) . ' '
|
||||
. 'WHERE anrechnung_id = ' . $this->db_add_param($this->anrechnung_id);
|
||||
}
|
||||
|
||||
if ($this->db_query($qry)) {
|
||||
$this->anrechnung_id = $this->db_fetch_object()->anrechnung_id;
|
||||
return true;
|
||||
} else {
|
||||
$this->errormsg = 'Fehler beim Speichern der Anrechnung: ' . $this->db_last_error();
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Gibt alle Anrechnungen eines Prestudenten zurück
|
||||
* @param $prestudent_id
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function getAnrechnungPrestudent($prestudent_id) {
|
||||
$qry = "SELECT anrechnung_id, prestudent_id, lehrveranstaltung_id, begruendung_id, bezeichnung AS begruendung, "
|
||||
. "lehrveranstaltung_id_kompatibel, genehmigt_von , insertamum, insertvon, updateamum, updatevon "
|
||||
. "FROM lehre.tbl_anrechnung "
|
||||
. "JOIN lehre.tbl_anrechnung_begruendung USING (begruendung_id) "
|
||||
. "WHERE prestudent_id = " . $this->db_add_param($prestudent_id);
|
||||
|
||||
if ($this->db_query($qry)) {
|
||||
$datum = new datum();
|
||||
|
||||
while ($row = $this->db_fetch_object()) {
|
||||
$row->insertamum = $datum->convertISODate($row->insertamum);
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id);
|
||||
$row->lehrveranstaltung_bez = $lehrveranstaltung->bezeichnung;
|
||||
if ($row->lehrveranstaltung_id_kompatibel != '') {
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id_kompatibel);
|
||||
$row->lehrveranstaltung_bez_kompatibel = $lehrveranstaltung->bezeichnung;
|
||||
} else
|
||||
$row->lehrveranstaltung_bez_kompatibel = null;
|
||||
|
||||
$this->result[] = $row;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
else {
|
||||
$this->errormsg = 'Datensatz konnte nicht geladen werden';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Loescht eine Anrechnung
|
||||
* @param $anrechnung_id
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function delete($anrechnung_id) {
|
||||
$qry = "DELETE FROM lehre.tbl_anrechnung WHERE anrechnung_id = " . $this->db_add_param($anrechnung_id);
|
||||
|
||||
if ($this->db_query($qry)) {
|
||||
return true;
|
||||
} else {
|
||||
$this->errormsg = 'Datensatz konnte nicht geloescht werden';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Gibt die Anzahl der Notizen für eine Anrechnung zurück
|
||||
* @param $anrechung_id
|
||||
* @return Anzahl der Notizen, false im Fehlerfall
|
||||
*/
|
||||
public function getAnzahlNotizen($anrechung_id) {
|
||||
$qry = "SELECT COUNT(*) AS anzahl "
|
||||
/**
|
||||
* Gibt die Anzahl der Notizen für eine Anrechnung zurück
|
||||
* @param $anrechung_id
|
||||
* @return Anzahl der Notizen, false im Fehlerfall
|
||||
*/
|
||||
public function getAnzahlNotizen($anrechung_id)
|
||||
{
|
||||
$qry = "SELECT COUNT(*) AS anzahl "
|
||||
. "FROM public.tbl_notizzuordnung "
|
||||
. "WHERE anrechnung_id = " . $this->db_add_param($anrechung_id);
|
||||
|
||||
if ($result = $this->db_query($qry)) {
|
||||
if ($row = $this->db_fetch_object($result)) {
|
||||
return $row->anzahl;
|
||||
} else {
|
||||
$this->errormsg = 'Daten konnten nicht geladen werden';
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
$this->errormsg = 'Daten konnten nicht geladen werden';
|
||||
return false;
|
||||
if ($result = $this->db_query($qry))
|
||||
{
|
||||
if ($row = $this->db_fetch_object($result))
|
||||
{
|
||||
return $row->anzahl;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Daten konnten nicht geladen werden';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Daten konnten nicht geladen werden';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Gibt alle möglichen Begründungen zurück
|
||||
* @return array Array der Begründungen
|
||||
*/
|
||||
public function getAllBegruendung() {
|
||||
$qry = 'SELECT * FROM lehre.tbl_anrechnung_begruendung';
|
||||
/**
|
||||
* Gibt alle möglichen Begründungen zurück
|
||||
* @return array Array der Begründungen
|
||||
*/
|
||||
public function getAllBegruendung()
|
||||
{
|
||||
$qry = 'SELECT * FROM lehre.tbl_anrechnung_begruendung';
|
||||
|
||||
if ($this->db_query($qry)) {
|
||||
while ($row = $this->db_fetch_object()) {
|
||||
$stdobj = new stdClass();
|
||||
$stdobj->begruendung_id = $row->begruendung_id;
|
||||
$stdobj->bezeichnung = $row->bezeichnung;
|
||||
array_push($this->begruendungen, $stdobj);
|
||||
}
|
||||
return true;
|
||||
} else {
|
||||
$this->errormsg = 'Daten konnten nicht geladen werden';
|
||||
return false;
|
||||
if ($this->db_query($qry))
|
||||
{
|
||||
while ($row = $this->db_fetch_object())
|
||||
{
|
||||
$stdobj = new stdClass();
|
||||
$stdobj->begruendung_id = $row->begruendung_id;
|
||||
$stdobj->bezeichnung = $row->bezeichnung;
|
||||
array_push($this->begruendungen, $stdobj);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Daten konnten nicht geladen werden';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Lädt eine Anrechnung
|
||||
* @param $anrechnung_id ID der Anrechnung
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function load($anrechnung_id) {
|
||||
$qry = "SELECT anrechnung_id, prestudent_id, lehrveranstaltung_id, begruendung_id, bezeichnung AS begruendung, "
|
||||
/**
|
||||
* Lädt eine Anrechnung
|
||||
* @param $anrechnung_id ID der Anrechnung
|
||||
* @return true wenn ok, false im Fehlerfall
|
||||
*/
|
||||
public function load($anrechnung_id)
|
||||
{
|
||||
$qry = "SELECT anrechnung_id, prestudent_id, lehrveranstaltung_id, begruendung_id, bezeichnung AS begruendung, "
|
||||
. "lehrveranstaltung_id_kompatibel, genehmigt_von, insertamum, insertvon, updateamum, updatevon "
|
||||
. "FROM lehre.tbl_anrechnung "
|
||||
. "JOIN lehre.tbl_anrechnung_begruendung USING (begruendung_id) "
|
||||
. "WHERE anrechnung_id = " . $this->db_add_param($anrechnung_id);
|
||||
|
||||
if ($result = $this->db_query($qry)) {
|
||||
if ($row = $this->db_fetch_object($result)) {
|
||||
$this->anrechnung_id = $row->anrechnung_id;
|
||||
$this->prestudent_id = $row->prestudent_id;
|
||||
$this->lehrveranstaltung_id = $row->lehrveranstaltung_id;
|
||||
$this->lehrveranstaltung_id_kompatibel = $row->lehrveranstaltung_id_kompatibel;
|
||||
$this->begruendung_id = $row->begruendung_id;
|
||||
$this->begruendung = $row->begruendung;
|
||||
$this->genehmigt_von = $row->genehmigt_von;
|
||||
|
||||
$datum = new datum();
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id);
|
||||
$this->insertamum = $datum->convertISODate($row->insertamum);
|
||||
$this->lehrveranstaltung_bez = $lehrveranstaltung->bezeichnung;
|
||||
if ($row->lehrveranstaltung_id_kompatibel != '') {
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id_kompatibel);
|
||||
$this->lehrveranstaltung_bez_kompatibel = $lehrveranstaltung->bezeichnung;
|
||||
} else
|
||||
$this->lehrveranstaltung_bez_kompatibel = null;
|
||||
}
|
||||
else {
|
||||
$this->errormsg = 'Es wurde kein Datensatz mit dieser ID gefunden';
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
if ($result = $this->db_query($qry))
|
||||
{
|
||||
if ($row = $this->db_fetch_object($result))
|
||||
{
|
||||
$this->anrechnung_id = $row->anrechnung_id;
|
||||
$this->prestudent_id = $row->prestudent_id;
|
||||
$this->lehrveranstaltung_id = $row->lehrveranstaltung_id;
|
||||
$this->lehrveranstaltung_id_kompatibel = $row->lehrveranstaltung_id_kompatibel;
|
||||
$this->begruendung_id = $row->begruendung_id;
|
||||
$this->begruendung = $row->begruendung;
|
||||
$this->genehmigt_von = $row->genehmigt_von;
|
||||
|
||||
$datum = new datum();
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id);
|
||||
$this->insertamum = $datum->convertISODate($row->insertamum);
|
||||
$this->lehrveranstaltung_bez = $lehrveranstaltung->bezeichnung;
|
||||
|
||||
if ($row->lehrveranstaltung_id_kompatibel != '')
|
||||
{
|
||||
$lehrveranstaltung = new lehrveranstaltung($row->lehrveranstaltung_id_kompatibel);
|
||||
$this->lehrveranstaltung_bez_kompatibel = $lehrveranstaltung->bezeichnung;
|
||||
}
|
||||
else
|
||||
$this->lehrveranstaltung_bez_kompatibel = null;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Es wurde kein Datensatz mit dieser ID gefunden';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Laden der Daten';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Regular → Executable
+7
-4
@@ -79,7 +79,7 @@ class lehrveranstaltung extends basis_db
|
||||
public $alvs;
|
||||
public $lvps;
|
||||
public $las;
|
||||
|
||||
|
||||
public $benotung=false;
|
||||
public $lvinfo=false;
|
||||
public $curriculum=true;
|
||||
@@ -160,12 +160,15 @@ class lehrveranstaltung extends basis_db
|
||||
$this->alvs = $row->alvs;
|
||||
$this->lvps = $row->lvps;
|
||||
$this->las = $row->las;
|
||||
|
||||
|
||||
$this->benotung = $this->db_parse_bool($row->benotung);
|
||||
$this->lvinfo = $this->db_parse_bool($row->lvinfo);
|
||||
$this->lehrauftrag = $this->db_parse_bool($row->lehrauftrag);
|
||||
|
||||
// FIXME: LV-Bezeichnung richtig mehrsprachig machen
|
||||
// Zwischenzeitlich 'Italian' zum bezeichnung_arr dazugegeben
|
||||
$this->bezeichnung_arr['German'] = $this->bezeichnung;
|
||||
$this->bezeichnung_arr['Italian'] = $this->bezeichnung;
|
||||
$this->bezeichnung_arr['English'] = $this->bezeichnung_english;
|
||||
if ($this->bezeichnung_arr['English'] == '')
|
||||
$this->bezeichnung_arr['English'] = $this->bezeichnung_arr['German'];
|
||||
@@ -229,7 +232,7 @@ class lehrveranstaltung extends basis_db
|
||||
$lv_obj->lvnr = $row->lvnr;
|
||||
$lv_obj->semester_alternativ = $row->semester_alternativ;
|
||||
$lv_obj->farbe = $row->farbe;
|
||||
|
||||
|
||||
$lv_obj->benotung = $this->db_parse_bool($row->benotung);
|
||||
$lv_obj->lvinfo = $this->db_parse_bool($row->lvinfo);
|
||||
$lv_obj->lehrauftrag = $this->db_parse_bool($row->lehrauftrag);
|
||||
@@ -1189,7 +1192,7 @@ class lehrveranstaltung extends basis_db
|
||||
tbl_studienplan_lehrveranstaltung.studienplan_lehrveranstaltung_id_parent,
|
||||
tbl_studienplan_lehrveranstaltung.sort stpllv_sort,
|
||||
tbl_studienplan_lehrveranstaltung.curriculum,
|
||||
tbl_studienplan_lehrveranstaltung.export
|
||||
tbl_studienplan_lehrveranstaltung.export
|
||||
FROM lehre.tbl_lehrveranstaltung
|
||||
JOIN lehre.tbl_studienplan_lehrveranstaltung
|
||||
USING(lehrveranstaltung_id)
|
||||
|
||||
@@ -320,8 +320,8 @@ class studienordnung extends basis_db
|
||||
' studiengangbezeichnung_englisch='.$this->db_add_param($this->studiengangbezeichnung_englisch).', '.
|
||||
' studiengangkurzbzlang='.$this->db_add_param($this->studiengangkurzbzlang).','.
|
||||
' akadgrad_id='.$this->db_add_param($this->akadgrad_id, FHC_INTEGER).', '.
|
||||
' standort_id='.$this->db_add_param($this->standort_id, FHC_INTEGER).', '.
|
||||
' status_kurzbz='.$this->db_add_param($this->status_kurzbz, FHC_INTEGER).', '.
|
||||
' standort_id='.$this->db_add_param($this->standort_id, FHC_INTEGER).', '.
|
||||
' status_kurzbz='.$this->db_add_param($this->status_kurzbz).', '.
|
||||
' updateamum= now(), '.
|
||||
' updatevon='.$this->db_add_param($this->updatevon).' '.
|
||||
' WHERE studienordnung_id='.$this->db_add_param($this->studienordnung_id, FHC_INTEGER, false).';';
|
||||
|
||||
@@ -176,15 +176,18 @@ else
|
||||
$stp_ids=array();
|
||||
$stpl_main = new studienplan();
|
||||
|
||||
if($stpl_main->getStudienplaeneFromSem($stg_kz, $semester_aktuell, $sem))
|
||||
$sto_obj = new studienordnung();
|
||||
if($sto_obj->loadStudienordnungSTG($stg_kz, $semester_aktuell, $sem))
|
||||
{
|
||||
foreach($stpl_main->result as $row_sto)
|
||||
foreach($sto_obj->result as $row_sto)
|
||||
{
|
||||
//echo "$row_sto->studienordnung_id $row_sto->semester\n";
|
||||
$stp_obj = new studienplan();
|
||||
if($stp_obj->loadStudienplanSTO($row_sto->studienordnung_id, $orgform))
|
||||
{
|
||||
foreach($stp_obj->result as $row_stp)
|
||||
{
|
||||
$stp_ids_arr[]=array('stpid'=>$row_stp->studienplan_id,'semester'=>$row_sto->semester);
|
||||
$stp_ids[]=$row_stp->studienplan_id;
|
||||
}
|
||||
}
|
||||
@@ -193,6 +196,7 @@ else
|
||||
else
|
||||
echo "FAILED:".$stpl_main->errormsg;
|
||||
$qry='';
|
||||
|
||||
if(count($stp_ids)>0)
|
||||
{
|
||||
// Alle Lehrveranstaltungen die lt Studienplan zugeordnet sind
|
||||
@@ -207,10 +211,15 @@ else
|
||||
lehre.tbl_lehrveranstaltung
|
||||
JOIN lehre.tbl_studienplan_lehrveranstaltung USING(lehrveranstaltung_id)
|
||||
JOIN lehre.tbl_studienplan USING(studienplan_id)
|
||||
WHERE studienplan_id in (".$db->db_implode4SQL($stp_ids).")
|
||||
AND tbl_lehrveranstaltung.aktiv";
|
||||
if($sem!='')
|
||||
$qry.=" AND tbl_studienplan_lehrveranstaltung.semester=".$db->db_add_param($sem);
|
||||
WHERE (1!=1 ";
|
||||
|
||||
foreach($stp_ids_arr as $elem)
|
||||
{
|
||||
$qry.= "OR (
|
||||
studienplan_id=".$db->db_add_param($elem['stpid'])."
|
||||
AND tbl_studienplan_lehrveranstaltung.semester=".$db->db_add_param($elem['semester'])." )";
|
||||
}
|
||||
$qry.=") AND tbl_lehrveranstaltung.aktiv";
|
||||
$qry.=" UNION ";
|
||||
}
|
||||
|
||||
@@ -240,7 +249,7 @@ else
|
||||
}
|
||||
//$qry = 'SELECT distinct on(lehrveranstaltung_id) * FROM ('.$qry.' ORDER BY studienplan_id DESC) a';
|
||||
}
|
||||
// die($qry);
|
||||
//die($qry);
|
||||
if(!$result = $db->db_query($qry))
|
||||
die($db->db_last_error().'<BR>'.$qry);
|
||||
|
||||
|
||||
@@ -0,0 +1,154 @@
|
||||
<?php
|
||||
/* Copyright (C) 2016 Technikum-Wien
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Authors: Andreas Moik <moik@technikum-wien.at>
|
||||
*/
|
||||
|
||||
|
||||
require_once('../config/system.config.inc.php');
|
||||
require_once('../include/basis_db.class.php');
|
||||
require_once('../version.php');
|
||||
require_once('../include/benutzerberechtigung.class.php');
|
||||
|
||||
// Datenbank Verbindung
|
||||
$db = new basis_db();
|
||||
echo '<html>
|
||||
<head>
|
||||
<title>Studienplan_id prestudentstatus</title>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
||||
<link rel="stylesheet" href="../skin/vilesci.css" type="text/css" />
|
||||
<script>
|
||||
function hideStartButton()
|
||||
{
|
||||
document.getElementById("startButton").disabled=true;
|
||||
document.getElementById("startButton").value="Bitte warten...";
|
||||
}
|
||||
</script>
|
||||
</head>
|
||||
<body>
|
||||
<h2>Studienplan_id Update</h2>';
|
||||
|
||||
$uid = get_uid();
|
||||
$rechte = new benutzerberechtigung();
|
||||
$rechte->getBerechtigungen($uid);
|
||||
|
||||
if(!$rechte->isBerechtigt('admin'))
|
||||
{
|
||||
exit('Sie haben keine Berechtigung');
|
||||
}
|
||||
|
||||
|
||||
if(isset($_POST["start"]) && $_POST["start"] == "start")
|
||||
{
|
||||
if($result = $db->db_query("SELECT prestudent_id, orgform_kurzbz, studiensemester_kurzbz, ausbildungssemester, status_kurzbz FROM public.tbl_prestudentstatus WHERE studienplan_id IS NULL"))
|
||||
{
|
||||
$all_count = $db->db_num_rows($result);
|
||||
$entries_not_unique = 0;
|
||||
$entries_not_found = 0;
|
||||
$entries_with_error = 0;
|
||||
|
||||
echo "Es gibt <span style='color:red;'>" . $all_count . "</span> zu bearbeitende Einträge<br>";
|
||||
|
||||
while($row = $db->db_fetch_object($result))
|
||||
{
|
||||
$qry_search="
|
||||
SELECT
|
||||
studienplan_id
|
||||
FROM
|
||||
lehre.tbl_studienplan
|
||||
JOIN lehre.tbl_studienordnung USING(studienordnung_id)
|
||||
WHERE tbl_studienordnung.studiengang_kz=
|
||||
(
|
||||
SELECT studiengang_kz
|
||||
FROM public.tbl_prestudent
|
||||
WHERE prestudent_id=".$db->db_add_param($row->prestudent_id,FHC_INTEGER)."
|
||||
)
|
||||
AND lehre.tbl_studienplan.orgform_kurzbz=
|
||||
(
|
||||
SELECT COALESCE
|
||||
(
|
||||
".$db->db_add_param($row->orgform_kurzbz).",
|
||||
(
|
||||
SELECT orgform_kurzbz FROM public.tbl_studiengang
|
||||
WHERE
|
||||
studiengang_kz=(SELECT studiengang_kz FROM public.tbl_prestudent WHERE prestudent_id=".$db->db_add_param($row->prestudent_id,FHC_INTEGER).")
|
||||
)
|
||||
)
|
||||
)
|
||||
AND EXISTS
|
||||
(
|
||||
SELECT * FROM lehre.tbl_studienplan_semester
|
||||
WHERE
|
||||
studienplan_id=tbl_studienplan.studienplan_id
|
||||
AND studiensemester_kurzbz=".$db->db_add_param($row->studiensemester_kurzbz)."
|
||||
AND semester=".$db->db_add_param($row->ausbildungssemester,FHC_INTEGER)."
|
||||
);
|
||||
";
|
||||
|
||||
|
||||
$result_search = $db->db_query($qry_search);
|
||||
|
||||
$ct = $db->db_num_rows($result_search);
|
||||
if($ct < 1)
|
||||
{
|
||||
$entries_not_found++;
|
||||
}
|
||||
else if($ct > 1)
|
||||
{
|
||||
$entries_not_unique++;
|
||||
}
|
||||
else
|
||||
{
|
||||
$sp = $db->db_fetch_object($result_search);
|
||||
if(!$db->db_query("UPDATE public.tbl_prestudentstatus SET studienplan_id=".$db->db_add_param($sp->studienplan_id, FHC_INTEGER).
|
||||
" WHERE prestudent_id=".$db->db_add_param($row->prestudent_id, FHC_INTEGER).
|
||||
" AND status_kurzbz=".$db->db_add_param($row->status_kurzbz).
|
||||
" AND studiensemester_kurzbz=".$db->db_add_param($row->studiensemester_kurzbz).
|
||||
" AND ausbildungssemester=".$db->db_add_param($row->ausbildungssemester, FHC_INTEGER)
|
||||
))
|
||||
$entries_with_error ++;
|
||||
}
|
||||
}
|
||||
|
||||
$rest_count = $all_count - $entries_not_found - $entries_not_unique - $entries_with_error;
|
||||
$quote = 100/$all_count*$rest_count;
|
||||
|
||||
echo "Es wurden <span style='color:red;'>" . $rest_count . "</span> Einträge eingetragen<br>";
|
||||
echo $entries_not_found." nicht gefunden<br>";
|
||||
echo $entries_not_unique." nicht eindeutig<br>";
|
||||
echo $entries_with_error." konnten aufgrund eines Fehlers nicht eingetragen werden<br>";
|
||||
echo "Es wurde eine quote von " . round($quote,2) . "% erreicht<br>";
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
?>
|
||||
<p>Der folgende Vorgang kann unter Umständen mehrere Minuten dauern!</p>
|
||||
<p>Es wird versucht anhand der orgform_kurzbz, der prestudent_id, der studiensemester_kurzbz und des ausbildungssemesters die studienplan_id des prestudentstatus zu ermitteln</p>
|
||||
<p>Es werden nur Einträge mit studienplan_id IS NULL geändert</p>
|
||||
<p>Hinweis:</p>
|
||||
<p>Die Tabelle lehre.tbl_studienplan_semester muss hierfür bereits durch CHECKSYSTEM angelegt UND befüllt sein. Andernfalls kann keine studienplan_id gefunden werden!</p>
|
||||
|
||||
<form onclick="hideStartButton()" action='prestudentstatus_studienplan_id.php' method='POST'>
|
||||
<input type="hidden" name="start" value="start" />
|
||||
<input id="startButton" type="submit" value="Start" />
|
||||
</form>
|
||||
<?php
|
||||
}
|
||||
|
||||
echo '</body></html>';
|
||||
?>
|
||||
@@ -276,6 +276,7 @@
|
||||
{
|
||||
var beginNeeded = needed;
|
||||
|
||||
//distribute the remainig applicants to the present ZGVs
|
||||
for(var i=0; i < zgvElems.length; i++)
|
||||
{
|
||||
for(var j in aqr.studenten)
|
||||
@@ -296,8 +297,10 @@
|
||||
}
|
||||
}
|
||||
|
||||
//if we are finished or the ZGVs are full
|
||||
if(needed < 1 || beginNeeded == needed)
|
||||
{
|
||||
//distribute the rest of the applicants, WITH a ZGV group
|
||||
for(var j in aqr.studenten)
|
||||
{
|
||||
if(!aqr.studenten[j].selected && aqr.studenten[j].bezeichnung)
|
||||
@@ -310,6 +313,7 @@
|
||||
}
|
||||
}
|
||||
}
|
||||
//distribute the rest of the applicants, WITHOUT a ZGV group
|
||||
for(var j in aqr.studenten)
|
||||
{
|
||||
if(!aqr.studenten[j].selected && !aqr.studenten[j].bezeichnung)
|
||||
@@ -323,7 +327,7 @@
|
||||
}
|
||||
}
|
||||
if(needed > 0)
|
||||
alert("Es werden mehr Studenten benötigt, als es Bewerber gibt!");
|
||||
alert("Es werden mehr Bewerber benötigt, als es gibt!");
|
||||
return;
|
||||
}
|
||||
else
|
||||
|
||||
Reference in New Issue
Block a user