mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 20:29:29 +00:00
311 lines
11 KiB
PHP
311 lines
11 KiB
PHP
<?php
|
|
class Pruefung_model extends DB_Model
|
|
{
|
|
|
|
/**
|
|
* Constructor
|
|
*/
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
$this->dbTable = 'campus.tbl_pruefung';
|
|
$this->pk = 'pruefung_id';
|
|
}
|
|
|
|
/**
|
|
* Gets Pruefungen of a person for a Studiensemester.
|
|
* @param int $person_id
|
|
* @param string $studiensemester_kurzbz
|
|
* @return object
|
|
*/
|
|
public function getByPerson($person_id, $studiensemester_kurzbz)
|
|
{
|
|
$qry = '
|
|
SELECT prfg.*, pers.matr_nr, lv.ects, stg.studiengang_kz, prst.prestudent_id,
|
|
UPPER(stg.typ||stg.kurzbz) AS studiengang, stg.bezeichnung AS studiengang_bezeichnung
|
|
FROM public.tbl_person pers
|
|
JOIN public.tbl_prestudent prst USING (person_id)
|
|
JOIN public.tbl_student USING (prestudent_id)
|
|
JOIN lehre.tbl_pruefung prfg USING (student_uid)
|
|
JOIN lehre.tbl_lehreinheit le USING (lehreinheit_id)
|
|
JOIN lehre.tbl_lehrveranstaltung lv USING (lehrveranstaltung_id)
|
|
JOIN public.tbl_studiengang stg ON prst.studiengang_kz = stg.studiengang_kz
|
|
WHERE pers.person_id = ?
|
|
AND le.studiensemester_kurzbz = ?
|
|
ORDER BY prfg.datum, pruefung_id';
|
|
|
|
return $this->execQuery($qry, array($person_id, $studiensemester_kurzbz));
|
|
}
|
|
|
|
/**
|
|
* Gets Pruefungen of a student for a Lehrveranstaltung.
|
|
*
|
|
* @param string $uid
|
|
* @param string $lehrveranstaltung_id
|
|
* @param string|null $sprache
|
|
*
|
|
* @return object
|
|
*/
|
|
public function getByStudentAndLv($uid, $lehrveranstaltung_id, $sprache = null)
|
|
{
|
|
// TODO(chris): Potentielle Anpassung "Eine UID"
|
|
$this->dbTable = 'lehre.tbl_pruefung';
|
|
|
|
if ($sprache) {
|
|
$sprache_qry = $this->db->compile_binds('SELECT index FROM public.tbl_sprache WHERE sprache = ?', [$sprache]);
|
|
$bezeichnung = 'bezeichnung_mehrsprachig[(' . $sprache_qry . ')]';
|
|
} else {
|
|
$bezeichnung = 'bezeichnung';
|
|
}
|
|
|
|
$this->addSelect($this->dbTable . '.pruefung_id, ' . $this->dbTable . '.pruefungstyp_kurzbz, ' . $this->dbTable . '.datum, COALESCE(n.' . $bezeichnung . ', n.note::text) AS note');
|
|
|
|
$this->addJoin('lehre.tbl_lehreinheit le', 'lehreinheit_id');
|
|
$this->addJoin('lehre.tbl_lehrveranstaltung lv', 'lehrveranstaltung_id');
|
|
$this->addJoin('lehre.tbl_note n', 'note');
|
|
|
|
return $this->loadWhere(['lehrveranstaltung_id' => $lehrveranstaltung_id, 'student_uid' => $uid]);
|
|
}
|
|
|
|
/**
|
|
* NOTE(chris): not used
|
|
* @return string
|
|
*/
|
|
protected function loadWhereThreeExamsFailed()
|
|
{
|
|
$this->load->config('studierendenantrag');
|
|
|
|
$this->dbTable = 'lehre.tbl_pruefung p';
|
|
|
|
$sprache_index = "SELECT index FROM public.tbl_sprache WHERE sprache='" . getUserLanguage() . "' LIMIT 1";
|
|
|
|
$this->addSelect('max(p.datum) as datum');
|
|
$this->addSelect('pers.vorname');
|
|
$this->addSelect('pers.nachname');
|
|
$this->addSelect('pers.person_id');
|
|
$this->addSelect('s.matrikelnr');
|
|
$this->addSelect('g.bezeichnung');
|
|
$this->addSelect('g.studiengang_kz');
|
|
$this->addSelect('o.bezeichnung_mehrsprachig[(' . $sprache_index . ')] AS orgform', false);
|
|
$this->addSelect('ps.prestudent_id');
|
|
$this->addSelect('lv.bezeichnung as lvbezeichnung');
|
|
$this->addSelect('le.studiensemester_kurzbz');
|
|
$this->addSelect('a.typ');
|
|
$this->addSelect('campus.get_status_studierendenantrag(a.studierendenantrag_id) status');
|
|
$this->addSelect('count(1) as count');
|
|
|
|
$this->addGroupBy([
|
|
'pers.vorname',
|
|
'pers.nachname',
|
|
'pers.person_id',
|
|
's.matrikelnr',
|
|
'g.bezeichnung',
|
|
'g.studiengang_kz',
|
|
'o.bezeichnung_mehrsprachig',
|
|
'ps.prestudent_id',
|
|
'lv.bezeichnung',
|
|
'le.studiensemester_kurzbz',
|
|
'a.typ',
|
|
'a.studierendenantrag_id'
|
|
]);
|
|
$this->addJoin('lehre.tbl_note n', 'note');
|
|
$this->addJoin('lehre.tbl_lehreinheit le', 'lehreinheit_id');
|
|
$this->addJoin('lehre.tbl_lehrveranstaltung lv', 'lehrveranstaltung_id');
|
|
$this->addJoin('public.tbl_student s', 'student_uid');
|
|
$this->addJoin('public.tbl_prestudent ps', 'prestudent_id');
|
|
$this->addJoin('public.tbl_person pers', 'person_id');
|
|
$this->addJoin('public.tbl_benutzer b', 's.student_uid=b.uid');
|
|
$this->addJoin('public.tbl_studiengang g', 'ps.studiengang_kz=g.studiengang_kz');
|
|
$this->addJoin(
|
|
'public.tbl_prestudentstatus pss',
|
|
'pss.prestudent_id=ps.prestudent_id
|
|
AND pss.studiensemester_kurzbz=le.studiensemester_kurzbz
|
|
AND pss.status_kurzbz=get_rolle_prestudent(ps.prestudent_id, le.studiensemester_kurzbz)',
|
|
'LEFT'
|
|
);
|
|
$this->addJoin('lehre.tbl_studienplan plan', 'studienplan_id', 'LEFT');
|
|
$this->addJoin('bis.tbl_orgform o', 'COALESCE(plan.orgform_kurzbz, pss.orgform_kurzbz, g.orgform_kurzbz)=o.orgform_kurzbz');
|
|
$this->db->join('campus.tbl_studierendenantrag a', 'ps.prestudent_id=a.prestudent_id and a.typ = ?', 'LEFT', false);
|
|
|
|
$this->db->where("n.positiv", false);
|
|
/* $this->db->where_in("p.pruefungstyp_kurzbz1", ['kommPruef','zusKommPruef']);*/
|
|
$this->db->where_in("get_rolle_prestudent(ps.prestudent_id, null)", $this->config->item('antrag_prestudentstatus_whitelist'));
|
|
|
|
$this->db->where("g.aktiv", true);
|
|
|
|
$this->db->where('lv.studiengang_kz not in(
|
|
SELECT ps.studiengang_kz
|
|
FROM
|
|
public.tbl_prestudent ps1
|
|
JOIN public.tbl_prestudentstatus pss USING (prestudent_id)
|
|
WHERE pss.statusgrund_id in ?
|
|
AND ps.prestudent_id = ps1.prestudent_id)', null, false);
|
|
|
|
// NOTE(chris): is Wiederholer without set statusgrund (legacy?)
|
|
$this->db->where(
|
|
'(SELECT COUNT(*)
|
|
FROM (SELECT DISTINCT studiensemester_kurzbz
|
|
FROM tbl_prestudentstatus _s
|
|
WHERE ausbildungssemester=get_absem_prestudent(ps.prestudent_id, le.studiensemester_kurzbz)
|
|
AND prestudent_id=ps.prestudent_id) a) = 1',
|
|
null,
|
|
false
|
|
);
|
|
|
|
return $this->db->get_compiled_select($this->dbTable);
|
|
}
|
|
|
|
/**
|
|
* @return stdClass
|
|
*/
|
|
public function loadWhereCommitteeExamsFailed()
|
|
{
|
|
$this->load->config('studierendenantrag');
|
|
|
|
$this->dbTable = 'lehre.tbl_pruefung p';
|
|
|
|
$this->addSelect('p.datum');
|
|
|
|
$this->addJoin('lehre.tbl_note n', 'note');
|
|
|
|
$this->db->where("n.positiv", false);
|
|
$note_blacklist = $this->config->item('note_blacklist_wiederholung');
|
|
if ($note_blacklist)
|
|
$this->db->where_not_in("n.note", $note_blacklist);
|
|
$this->db->where_in("p.pruefungstyp_kurzbz", ['kommPruef','zusKommPruef']);
|
|
|
|
$this->addOrder('p.datum', 'DESC');
|
|
|
|
return $this->load();
|
|
}
|
|
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
protected function withDetailsForStudierendenAntrag()
|
|
{
|
|
$this->load->config('studierendenantrag');
|
|
|
|
$sprache_index = "SELECT index FROM public.tbl_sprache WHERE sprache='" . getUserLanguage() . "' LIMIT 1";
|
|
|
|
$this->addSelect('pers.vorname');
|
|
$this->addSelect('pers.nachname');
|
|
$this->addSelect('pers.person_id');
|
|
$this->addSelect('s.matrikelnr');
|
|
$this->addSelect('g.bezeichnung');
|
|
$this->addSelect('g.studiengang_kz');
|
|
$this->addSelect('o.bezeichnung_mehrsprachig[(' . $sprache_index . ')] AS orgform', false);
|
|
$this->addSelect('ps.prestudent_id');
|
|
$this->addSelect('lv.bezeichnung as lvbezeichnung');
|
|
$this->addSelect('le.studiensemester_kurzbz');
|
|
$this->addSelect('a.studierendenantrag_id');
|
|
$this->addSelect('a.typ');
|
|
$this->addSelect('campus.get_status_studierendenantrag(a.studierendenantrag_id) status');
|
|
$this->addSelect('pss.ausbildungssemester');
|
|
|
|
$this->addJoin('(SELECT MAX(datum) AS datum, lehreinheit_id AS le_id, student_uid AS stud_uid FROM lehre.tbl_pruefung p WHERE pruefungstyp_kurzbz IN (\'kommPruef\', \'zusKommPruef\') GROUP BY lehreinheit_id, student_uid) lpd',
|
|
'p.datum = lpd.datum AND p.lehreinheit_id = lpd.le_id AND p.student_uid = lpd.stud_uid');
|
|
$this->addJoin('lehre.tbl_lehreinheit le', 'lehreinheit_id');
|
|
$this->addJoin('lehre.tbl_lehrveranstaltung lv', 'lehrveranstaltung_id');
|
|
$this->addJoin('public.tbl_student s', 'student_uid');
|
|
$this->addJoin('public.tbl_prestudent ps', 'prestudent_id');
|
|
$this->addJoin('public.tbl_person pers', 'person_id');
|
|
$this->addJoin('public.tbl_benutzer b', 's.student_uid=b.uid');
|
|
$this->addJoin('public.tbl_studiengang g', 'ps.studiengang_kz=g.studiengang_kz');
|
|
$this->addJoin(
|
|
'public.tbl_prestudentstatus pss',
|
|
'pss.prestudent_id=ps.prestudent_id
|
|
AND pss.studiensemester_kurzbz=le.studiensemester_kurzbz
|
|
AND pss.status_kurzbz=get_rolle_prestudent(ps.prestudent_id, le.studiensemester_kurzbz)',
|
|
'LEFT'
|
|
);
|
|
$this->addJoin('lehre.tbl_studienplan plan', 'studienplan_id', 'LEFT');
|
|
$this->addJoin('bis.tbl_orgform o', 'COALESCE(plan.orgform_kurzbz, pss.orgform_kurzbz, g.orgform_kurzbz)=o.orgform_kurzbz');
|
|
$this->addJoin(
|
|
'campus.tbl_studierendenantrag a',
|
|
'ps.prestudent_id=a.prestudent_id and a.typ=' . $this->escape(Studierendenantrag_model::TYP_WIEDERHOLUNG),
|
|
'LEFT'
|
|
);
|
|
|
|
$this->db->where("g.aktiv", true);
|
|
|
|
$statusgruende = $this->config->item('status_gruende_wiederholer');
|
|
if (is_array($statusgruende) && !isEmptyArray($statusgruende)) {
|
|
foreach ($statusgruende as $k => $v) {
|
|
$statusgruende[$k] = $this->db->escape($v);
|
|
}
|
|
$this->db->where('lv.studiengang_kz NOT IN(
|
|
SELECT ps1.studiengang_kz
|
|
FROM
|
|
public.tbl_prestudent ps1
|
|
JOIN public.tbl_prestudentstatus pss USING (prestudent_id)
|
|
WHERE pss.statusgrund_id in (' . implode(',', $statusgruende) . ')
|
|
AND ps.prestudent_id = ps1.prestudent_id)', null, false);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param integer $prestudent_id student_uid
|
|
*
|
|
* @return stdClass
|
|
*/
|
|
public function loadWhereCommitteeExamFailedForPrestudent($prestudent_id, $max_date = null, $studiensemester_kurzbz = null)
|
|
{
|
|
$this->withDetailsForStudierendenAntrag();
|
|
|
|
$this->db->where('ps.prestudent_id', $prestudent_id);
|
|
|
|
if ($max_date !== null) {
|
|
$this->db->where('p.datum <=', $max_date);
|
|
}
|
|
if ($studiensemester_kurzbz !== null) {
|
|
$this->db->where('le.studiensemester_kurzbz', $studiensemester_kurzbz);
|
|
}
|
|
|
|
return $this->loadWhereCommitteeExamsFailed();
|
|
}
|
|
|
|
/**
|
|
* @param string $status
|
|
* @param \DateTime $maxDate
|
|
* @param \DateTime $minDate
|
|
*
|
|
* @return stdClass
|
|
*/
|
|
public function getAllPrestudentsWhereCommitteeExamFailed($status, $maxDate, $minDate)
|
|
{
|
|
$this->withDetailsForStudierendenAntrag();
|
|
|
|
if ($maxDate)
|
|
$this->db->where("p.datum <= ", $maxDate->format('Y-m-d'));
|
|
if ($minDate)
|
|
$this->db->where("p.datum > ", $minDate->format('Y-m-d'));
|
|
|
|
$this->db->where("b.aktiv", true);
|
|
|
|
$this->db->where_in("get_rolle_prestudent(ps.prestudent_id, null)", $this->config->item('antrag_prestudentstatus_whitelist'));
|
|
|
|
if (is_array($status)) {
|
|
if (in_array(null, $status)) {
|
|
$status = array_filter($status);
|
|
if (count($status)) {
|
|
$this->db->group_start();
|
|
$this->db->where_in('campus.get_status_studierendenantrag(a.studierendenantrag_id)', $status);
|
|
$this->db->or_where('campus.get_status_studierendenantrag(a.studierendenantrag_id)', null);
|
|
$this->db->group_end();
|
|
} else {
|
|
$this->db->where('campus.get_status_studierendenantrag(a.studierendenantrag_id)', null);
|
|
}
|
|
} else {
|
|
$this->db->where_in('campus.get_status_studierendenantrag(a.studierendenantrag_id)', $status);
|
|
}
|
|
} else {
|
|
$this->db->where('campus.get_status_studierendenantrag(a.studierendenantrag_id)', $status);
|
|
}
|
|
|
|
return $this->loadWhereCommitteeExamsFailed();
|
|
}
|
|
|
|
}
|