From b835e1a6b565ed41d02b3bd3d1deb2f13732ce61 Mon Sep 17 00:00:00 2001 From: oesi Date: Thu, 11 May 2017 11:33:57 +0200 Subject: [PATCH 1/7] =?UTF-8?q?CSV=20Export=20der=20Studierenden=20f=C3=BC?= =?UTF-8?q?r=20=C3=96H=20hinzugef=C3=BCgt?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- vilesci/statistik/studierendenliste_oeh.php | 151 ++++++++++++++++++++ 1 file changed, 151 insertions(+) create mode 100644 vilesci/statistik/studierendenliste_oeh.php diff --git a/vilesci/statistik/studierendenliste_oeh.php b/vilesci/statistik/studierendenliste_oeh.php new file mode 100644 index 000000000..3480e76cd --- /dev/null +++ b/vilesci/statistik/studierendenliste_oeh.php @@ -0,0 +1,151 @@ + + * + */ +/** + * CSV Export der Studierenden für ÖH + */ +require_once('../../config/vilesci.config.inc.php'); +require_once('../../include/functions.inc.php'); +require_once('../../include/benutzerberechtigung.class.php'); +require_once('../../include/erhalter.class.php'); +require_once('../../include/studiensemester.class.php'); +require_once('../../include/datum.class.php'); + +$uid = get_uid(); + +$rechte = new benutzerberechtigung(); +$rechte->getBerechtigungen($uid); + +if(!$rechte->isBerechtigt('admin')) + die('Sie haben keine Berechtigung fuer diese Seite'); + +$db = new basis_db(); +$datum_obj = new datum(); + +$stsem_obj = new studiensemester(); +$studiensemester_kurzbz = $stsem_obj->getAktOrNext(); + +$erhalter = new erhalter(); +$erhalter->getAll(); + +if(!isset($erhalter->result[0])) + die('Es ist kein Erhalter vorhanden'); + +$erhalter_row = $erhalter->result[0]; + +$filename='Studierendenliste'.$studiensemester_kurzbz.'_'.date('Y-m-d').'.csv'; + +header( 'Content-Type: text/csv' ); +header( 'Content-Disposition: attachment;filename='.$filename); + + +// Daten holen - Alle Personen mit akt. Status Student, Diplomand und Incoming die bezahlt haben +$qry=" +SELECT * FROM ( +SELECT DISTINCT ON (matrikelnr) matrikelnr AS personenkennzeichen, + tbl_person.svnr, + tbl_person.ersatzkennzeichen, + tbl_person.gebdatum, + tbl_person.nachname, + tbl_person.vorname, + tbl_person.geschlecht, + tbl_student.studiengang_kz, + tbl_student.student_uid, + (SELECT plz FROM public.tbl_adresse WHERE person_id=public.tbl_person.person_id ORDER BY zustelladresse desc LIMIT 1) AS zustell_plz, + (SELECT gemeinde FROM public.tbl_adresse WHERE person_id=public.tbl_person.person_id ORDER BY zustelladresse desc LIMIT 1) AS zustell_ort, + (SELECT strasse FROM public.tbl_adresse WHERE person_id=public.tbl_person.person_id ORDER BY zustelladresse desc LIMIT 1) AS zustell_strasse, + (SELECT plz FROM public.tbl_adresse WHERE person_id=public.tbl_person.person_id ORDER BY heimatadresse desc LIMIT 1) AS heimat_plz, + (SELECT gemeinde FROM public.tbl_adresse WHERE person_id=public.tbl_person.person_id ORDER BY heimatadresse desc LIMIT 1) AS heimat_ort, + (SELECT strasse FROM public.tbl_adresse WHERE person_id=public.tbl_person.person_id ORDER BY heimatadresse desc LIMIT 1) AS heimat_strasse, + tbl_person.person_id, + tbl_studiengang.bezeichnung as stg_bezeichnung, + tbl_studiengangstyp.bezeichnung as stg_typ, + get_rolle_prestudent(tbl_prestudent.prestudent_id, ".$db->db_add_param($studiensemester_kurzbz).") as status +FROM public.tbl_person + JOIN public.tbl_konto as ka using(person_id) + JOIN public.tbl_konto as kb using(person_id) + JOIN public.tbl_benutzer using(person_id) + JOIN public.tbl_student on(uid=student_uid) + JOIN public.tbl_prestudent using(prestudent_id) + JOIN public.tbl_prestudentstatus on(tbl_prestudentstatus.prestudent_id=tbl_student.prestudent_id) + JOIN public.tbl_studiengang ON(tbl_prestudent.studiengang_kz=tbl_studiengang.studiengang_kz) + JOIN public.tbl_studiengangstyp ON(tbl_studiengangstyp.typ=tbl_studiengang.typ) +WHERE + tbl_prestudentstatus.studiensemester_kurzbz=".$db->db_add_param($studiensemester_kurzbz)." + AND get_rolle_prestudent(tbl_prestudent.prestudent_id, ".$db->db_add_param($studiensemester_kurzbz).") in('Student','Diplomand','Incoming', 'Unterbrecher') + AND tbl_student.studiengang_kz<10000 + AND bismelden + AND tbl_benutzer.aktiv +) a +ORDER BY person_id"; + +$last_person_id=''; +$data_row = array(); +$personenkennzeichen = array(); +$studiengang_kz = array(); + +$data_row = array( + 'Nachname', + 'Vorname', + 'Geburtsdatum', + 'Studienort Plz', + 'Studienort Ort', + 'Studienort Strasse', + 'Heimatort Plz', + 'Heimatort Ort', + 'Heimatort Strasse', + 'Mail', + 'Studiengangstyp', + 'Studiengangsbezeichnung', + 'Status' + ); +echo implode(';',$data_row).";\r\n"; + +if($result = $db->db_query($qry)) +{ + while($row = $db->db_fetch_object($result)) + { + $last_person_id=$row->person_id; + + $personenkennzeichen[]=trim($row->personenkennzeichen); + if($row->studiengang_kz<0) + $studiengang_kz[] = sprintf('%1$03d',$erhalter_row->erhalter_kz).sprintf('%1$04d',abs($row->studiengang_kz)); + else + $studiengang_kz[] = sprintf('%1$04d',$row->studiengang_kz); + + $data_row = array( + $row->nachname, + $row->vorname, + $datum_obj->formatDatum($row->gebdatum,'Y-m-d'), + $row->zustell_plz, + $row->zustell_ort, + $row->zustell_strasse, + $row->heimat_plz, + $row->heimat_ort, + $row->heimat_strasse, + $row->student_uid.'@'.DOMAIN, + $row->stg_typ, + $row->stg_bezeichnung, + $row->status + ); + echo implode(';',$data_row).";\r\n"; + } +} + From 27f28b524d6bad638ce024a9bd4646b5b29758fd Mon Sep 17 00:00:00 2001 From: Gerald Raab Date: Fri, 12 May 2017 15:50:21 +0200 Subject: [PATCH 2/7] Addon Casetime-Aufruf mit Berechtigung zur XLS-Generierung --- cis/private/tools/zeitaufzeichnung.php | 428 +++++++++++++------------ 1 file changed, 217 insertions(+), 211 deletions(-) diff --git a/cis/private/tools/zeitaufzeichnung.php b/cis/private/tools/zeitaufzeichnung.php index 8ca3c9304..9a2bd3277 100755 --- a/cis/private/tools/zeitaufzeichnung.php +++ b/cis/private/tools/zeitaufzeichnung.php @@ -20,7 +20,7 @@ * Rudolf Hangl * Karl Burkhart * Manfred Kindl . - * Gerald Raab + * Gerald Raab */ require_once('../../../config/cis.config.inc.php'); require_once('../../../include/functions.inc.php'); @@ -32,7 +32,7 @@ require_once('../../../include/zeitaufzeichnung.class.php'); require_once('../../../include/zeitsperre.class.php'); require_once('../../../include/datum.class.php'); require_once('../../../include/projekt.class.php'); -require_once('../../../include/phrasen.class.php'); +require_once('../../../include/phrasen.class.php'); require_once('../../../include/organisationseinheit.class.php'); require_once('../../../include/service.class.php'); require_once('../../../include/mitarbeiter.class.php'); @@ -42,15 +42,15 @@ require_once('../../../include/bisverwendung.class.php'); require_once('../../../include/studiensemester.class.php'); require_once('../../../include/benutzerberechtigung.class.php'); -$sprache = getSprache(); -$p=new phrasen($sprache); - +$sprache = getSprache(); +$p=new phrasen($sprache); + if (!$db = new basis_db()) die($p->t("global/fehlerBeimOeffnenDerDatenbankverbindung")); - + $user = get_uid(); -//Wenn User Administrator ist und UID uebergeben wurde, dann die Zeiaufzeichnung +//Wenn User Administrator ist und UID uebergeben wurde, dann die Zeiaufzeichnung //des uebergebenen Users anzeigen if(isset($_GET['uid'])) { @@ -60,12 +60,18 @@ if(isset($_GET['uid'])) { $user = $_GET['uid']; } - else + else { die($p->t('global/FuerDieseAktionBenoetigenSieAdministrationsrechte')); } } - +$rechteexport = new benutzerberechtigung(); +$rechteexport->getBerechtigungen($user); +if($rechteexport->isBerechtigt('addon/casetimeGenerateXLS')) + $export_xls = 'true'; +else { + $export_xls = 'false'; +} $datum = new datum(); @@ -73,8 +79,8 @@ if (check_infrastruktur($user)) { $za_simple = 0; $activities = array('Design', 'Operativ', 'Betrieb', 'Pause', 'LehreIntern', 'LehreExtern', 'Arztbesuch', 'Dienstreise', 'Behoerde'); -} -else +} +else { $za_simple = 1; $activities = array('Arbeit', 'Pause', 'LehreIntern', 'LehreExtern', 'Arztbesuch', 'Dienstreise', 'Behoerde'); @@ -141,13 +147,13 @@ foreach($addon_obj->result as $addon) // Wenn Seite fertig geladen ist Addons aufrufen echo '