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"; + } +} +