CSV Export der Studierenden für ÖH hinzugefügt

This commit is contained in:
oesi
2017-05-11 11:33:57 +02:00
parent bbcb337c2c
commit b835e1a6b5
+151
View File
@@ -0,0 +1,151 @@
<?php
/* Copyright (C) 2014 fhcomplete.org
*
* 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 Oesterreicher <andreas.oesterreicher@technikum-wien.at>
*
*/
/**
* 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";
}
}