mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 12:19:28 +00:00
309 lines
11 KiB
PHP
309 lines
11 KiB
PHP
<?php
|
|
|
|
$PERSON_ID = getAuthPersonId();
|
|
|
|
// all oe kurzbz for which logged user has a funktion
|
|
$ALL_FUNKTIONEN_OE_KURZBZ = isEmptyArray($all_funktionen_oe_kurzbz) ? "(NULL)"
|
|
: "(" . implode(",", array_map(function($string) { return $this->db->escape($string); }, array_keys($all_funktionen_oe_kurzbz))) . ")";
|
|
|
|
// all oes for which logged user has issues permissions, including permissions for "special" issue funktion
|
|
$ALL_OE_KURZBZ_BERECHTIGT = isEmptyArray($all_oe_kurzbz_berechtigt) ? "(NULL)"
|
|
: "(" . implode(",", array_map(function($string) { return $this->db->escape($string); }, $all_oe_kurzbz_berechtigt)) . ")";
|
|
|
|
// app apps for which issues should be displayed
|
|
$APPS = isEmptyArray($apps) ? "" : "(" . implode(",", array_map(function($string) { return $this->db->escape($string); }, $apps)) . ")";
|
|
|
|
// all prestudent status for which issues should be displayed
|
|
$RELEVANT_PRESTUDENT_STATUS = isEmptyArray($status) ? ""
|
|
: "(" . implode(",", array_map(function($string) { return $this->db->escape($string); }, $status)) . ")";
|
|
|
|
// get issues for the oes of the logged user or for the persons (students, oe-zuordnung) of the oes
|
|
$query = "WITH zustaendigkeiten AS (
|
|
SELECT fehlercode,
|
|
CASE
|
|
WHEN zst.person_id = ".$PERSON_ID;
|
|
|
|
if (!isEmptyArray($all_funktionen_oe_kurzbz))
|
|
{
|
|
$query .= " OR (zst.oe_kurzbz IN $ALL_FUNKTIONEN_OE_KURZBZ AND zst.funktion_kurzbz IS NULL) /* if oe is specified in fehler_zustaendigkeiten */";
|
|
|
|
// check for each oe for each function if zustaendig
|
|
foreach ($all_funktionen_oe_kurzbz as $oe_kurzbz => $funktionen_kurzbz)
|
|
{
|
|
foreach ($funktionen_kurzbz as $funktion_kurzbz)
|
|
{
|
|
$query .= " OR (zst.oe_kurzbz = '$oe_kurzbz' AND zst.funktion_kurzbz = '$funktion_kurzbz')";
|
|
}
|
|
}
|
|
}
|
|
|
|
$query .= " THEN TRUE
|
|
ELSE FALSE
|
|
END AS \"zustaendig\"
|
|
FROM system.tbl_fehler_zustaendigkeiten zst
|
|
)";
|
|
|
|
$query .= "
|
|
SELECT
|
|
issue_id, fehlercode AS \"Fehlercode\", fehler_kurzbz AS \"Fehler Kurzbezeichnung\", iss.fehlercode_extern AS \"Fehlercode extern\", datum AS \"Datum\",
|
|
inhalt AS \"Inhalt\", inhalt_extern AS \"Inhalt extern\", iss.person_id AS \"PersonId\", iss.oe_kurzbz AS \"OE\",
|
|
ftyp.bezeichnung_mehrsprachig[".$this->db->escape($language_index)."] AS \"Fehlertyp\",
|
|
stat.bezeichnung_mehrsprachig[".$this->db->escape($language_index)."] AS \"Fehlerstatus\",
|
|
verarbeitetvon AS \"Verarbeitet von\",verarbeitetamum AS \"Verarbeitet am\",
|
|
(SELECT STRING_AGG(app, ', ') FROM system.tbl_fehler_app WHERE fehlercode = fr.fehlercode GROUP BY fehlercode) AS \"Applikation\",
|
|
fr.fehlertyp_kurzbz AS \"Fehlertypcode\", iss.status_kurzbz AS \"Statuscode\",
|
|
pers.vorname AS \"Vorname\", pers.nachname AS \"Nachname\",
|
|
(
|
|
/* show all relevant Studiengänge of person and wether it is an employee*/
|
|
SELECT
|
|
STRING_AGG(studiengang || ' ' || last_status, ' | ')
|
|
|| (CASE WHEN EXISTS (
|
|
SELECT 1 FROM public.tbl_mitarbeiter ma
|
|
JOIN public.tbl_benutzer ben ON ma.mitarbeiter_uid = ben.uid
|
|
WHERE person_id = prestudents.person_id
|
|
AND ben.aktiv
|
|
) THEN ' | Mitarbeiter' ELSE '' END)
|
|
FROM (
|
|
SELECT
|
|
DISTINCT person_id, prestudent_id, UPPER(stg.typ || stg.kurzbz) AS studiengang,
|
|
get_rolle_prestudent(ps.prestudent_id, null) AS last_status
|
|
FROM
|
|
public.tbl_prestudent ps
|
|
JOIN public.tbl_studiengang stg USING (studiengang_kz)
|
|
WHERE
|
|
person_id = pers.person_id
|
|
ORDER BY
|
|
prestudent_id DESC
|
|
) prestudents
|
|
WHERE
|
|
last_status IN ('Abgewiesener','Aufgenommener', 'Student', 'Incoming', 'Diplomand', 'Abbrecher', 'Unterbrecher', 'Absolvent')
|
|
GROUP BY
|
|
person_id
|
|
LIMIT 1;
|
|
) AS \"Zugehörigkeit\",
|
|
CASE
|
|
WHEN
|
|
EXISTS(SELECT 1
|
|
FROM zustaendigkeiten
|
|
WHERE fehlercode = iss.fehlercode
|
|
AND zustaendig = TRUE) /* If Zuständigkeit is defined for the oe/person, zustaendig. */
|
|
THEN 'Ja'
|
|
WHEN
|
|
EXISTS(SELECT 1
|
|
FROM zustaendigkeiten
|
|
WHERE fehlercode = iss.fehlercode
|
|
AND zustaendig = FALSE) /* If Zuständigkeit is defined for different oe/person, not zustaendig. */
|
|
THEN 'Nein'
|
|
ELSE 'Ja' /* If no Zuständigkeit defined, zustaendig by default. */
|
|
END AS \"Hauptzuständig\",
|
|
(
|
|
SELECT
|
|
string_agg(vorname || ' ' || nachname, ' | ' ORDER BY vorname, nachname)
|
|
FROM
|
|
system.tbl_fehler_zustaendigkeiten
|
|
JOIN public.tbl_person USING (person_id)
|
|
WHERE
|
|
fehlercode = fr.fehlercode
|
|
GROUP BY
|
|
fehlercode
|
|
) AS \"Person Zuständigkeiten\",
|
|
(
|
|
SELECT
|
|
string_agg(organisationseinheittyp_kurzbz || ' ' || oe.bezeichnung ||
|
|
COALESCE(' - ' || fu.beschreibung, ''), ' | ' ORDER BY bezeichnung, oe_kurzbz)
|
|
FROM
|
|
system.tbl_fehler_zustaendigkeiten
|
|
LEFT JOIN public.tbl_organisationseinheit oe USING (oe_kurzbz)
|
|
LEFT JOIN public.tbl_funktion fu USING (funktion_kurzbz)
|
|
WHERE
|
|
fehlercode = fr.fehlercode
|
|
GROUP BY
|
|
fehlercode
|
|
) AS \"Organisationseinheit Zuständigkeiten\",
|
|
pers.bpk AS \"BPK\",
|
|
pers.matr_nr AS \"Matrikelnummer\"
|
|
FROM
|
|
system.tbl_issue iss
|
|
JOIN system.tbl_fehler fr USING (fehlercode)
|
|
JOIN system.tbl_fehlertyp ftyp USING (fehlertyp_kurzbz)
|
|
JOIN system.tbl_issue_status stat USING (status_kurzbz)
|
|
LEFT JOIN public.tbl_person pers ON iss.person_id = pers.person_id
|
|
WHERE
|
|
(
|
|
EXISTS ( /* if oe or person is specified in fehler_zustaendigkeiten */
|
|
SELECT 1 FROM zustaendigkeiten
|
|
WHERE fehlercode = iss.fehlercode
|
|
AND zustaendig = TRUE)";
|
|
|
|
// show issue if it is assigend to oe of logged in user or to student of oe of logged in user
|
|
$query .= " OR iss.oe_kurzbz IN $ALL_OE_KURZBZ_BERECHTIGT /* if issue is for oe */";
|
|
|
|
$query .= " OR (iss.oe_kurzbz IS NULL AND EXISTS ( /* if person_id of issue is a student of studiengang oe */
|
|
SELECT 1 FROM public.tbl_prestudent ps
|
|
JOIN public.tbl_prestudentstatus pss USING (prestudent_id)
|
|
JOIN public.tbl_studiengang stg USING (studiengang_kz)
|
|
WHERE person_id = iss.person_id
|
|
AND stg.oe_kurzbz IN ".$ALL_OE_KURZBZ_BERECHTIGT;
|
|
|
|
if (!isEmptyString($RELEVANT_PRESTUDENT_STATUS)) $query .= " AND pss.status_kurzbz IN ".$RELEVANT_PRESTUDENT_STATUS;
|
|
|
|
$query .= " AND NOT EXISTS (SELECT 1 /* irrelevant if already finished studies and studied a while ago */
|
|
FROM public.tbl_prestudentstatus ps_finished
|
|
JOIN public.tbl_studiensemester sem_finished USING (studiensemester_kurzbz)
|
|
WHERE prestudent_id = ps.prestudent_id
|
|
AND status_kurzbz IN ('Absolvent','Abbrecher','Abgewiesener')
|
|
AND datum::date + interval '2 months' < NOW()
|
|
AND EXISTS (SELECT 1 FROM public.tbl_prestudent /* if more recent prestudent exists, still display the issue */
|
|
JOIN public.tbl_prestudentstatus USING (prestudent_id)
|
|
JOIN public.tbl_studiensemester USING (studiensemester_kurzbz)
|
|
WHERE person_id = ps.person_id
|
|
AND prestudent_id <> ps_finished.prestudent_id
|
|
AND tbl_studiensemester.start::date > sem_finished.start::date";
|
|
|
|
if (!isEmptyString($RELEVANT_PRESTUDENT_STATUS)) $query .= " AND tbl_prestudentstatus.status_kurzbz IN ".$RELEVANT_PRESTUDENT_STATUS;
|
|
|
|
$query .= ")
|
|
)
|
|
)
|
|
)";
|
|
|
|
$query .= ") ";
|
|
|
|
if (!isEmptyString($APPS)) $query .= " AND EXISTS (SELECT 1 FROM system.tbl_fehler_app WHERE fehlercode = fr.fehlercode AND app IN ".$APPS.")";
|
|
|
|
$query .= " ORDER BY
|
|
CASE
|
|
WHEN fehlertyp_kurzbz = '".IssuesLib::ERRORTYPE_CODE."' THEN 0
|
|
WHEN fehlertyp_kurzbz = '".IssuesLib::WARNINGTYPE_CODE."' THEN 1
|
|
ELSE 2
|
|
END,
|
|
CASE
|
|
WHEN iss.status_kurzbz = '".IssuesLib::STATUS_NEU."' THEN 0
|
|
WHEN iss.status_kurzbz = '".IssuesLib::STATUS_IN_BEARBEITUNG."' THEN 1
|
|
ELSE 2
|
|
END,
|
|
datum DESC, fehlercode, issue_id DESC";
|
|
|
|
$filterWidgetArray = array(
|
|
'query' => $query,
|
|
'app' => 'core',
|
|
'datasetName' => 'issues',
|
|
'filter_id' => $this->input->get('filter_id'),
|
|
'tableUniqueId' => 'issues',
|
|
'requiredPermissions' => 'system/issues_verwalten',
|
|
'datasetRepresentation' => 'tablesorter',
|
|
'checkboxes' => 'issue_id',
|
|
'columnsAliases' => array(
|
|
'ID',
|
|
ucfirst($this->p->t('fehlermonitoring', 'fehlercode')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'fehlerkurzbz')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'fehlercodeExtern')),
|
|
ucfirst($this->p->t('global', 'datum')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'inhalt')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'inhaltExtern')),
|
|
'PersonId',
|
|
ucfirst($this->p->t('lehre', 'organisationseinheit')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'fehlertyp')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'fehlerstatus')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'verarbeitetVon')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'verarbeitetAm')),
|
|
ucfirst($this->p->t('global', 'applikation')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'fehlertypcode')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'statuscode')),
|
|
ucfirst($this->p->t('person', 'vorname')),
|
|
ucfirst($this->p->t('person', 'nachname')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'zugehoerigkeit')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'hauptzustaendig')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'zustaendigePersonen')),
|
|
ucfirst($this->p->t('fehlermonitoring', 'zustaendigeOrganisationseinheiten')),
|
|
'BPK',
|
|
'Matrikelnummer'
|
|
),
|
|
'formatRow' => function ($datasetRaw) {
|
|
|
|
if ($datasetRaw->{'Fehler Kurzbezeichnung'} == null)
|
|
{
|
|
$datasetRaw->{'Fehler Kurzbezeichnung'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'Fehlercode extern'} == null)
|
|
{
|
|
$datasetRaw->{'Fehlercode extern'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'Inhalt'} == null)
|
|
{
|
|
$datasetRaw->{'Inhalt'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'Inhalt extern'} == null)
|
|
{
|
|
$datasetRaw->{'Inhalt extern'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'PersonId'} == null)
|
|
{
|
|
$datasetRaw->{'PersonId'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'OE'} == null)
|
|
{
|
|
$datasetRaw->{'OE'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'Verarbeitet von'} == null)
|
|
{
|
|
$datasetRaw->{'Verarbeitet von'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'Zugehörigkeit'} == null)
|
|
{
|
|
$datasetRaw->{'Zugehörigkeit'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'Person Zuständigkeiten'} == null)
|
|
{
|
|
$datasetRaw->{'Person Zuständigkeiten'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'Organisationseinheit Zuständigkeiten'} == null)
|
|
{
|
|
$datasetRaw->{'Organisationseinheit Zuständigkeiten'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'BPK'} == null)
|
|
{
|
|
$datasetRaw->{'BPK'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'Matrikelnummer'} == null)
|
|
{
|
|
$datasetRaw->{'Matrikelnummer'} = '-';
|
|
}
|
|
|
|
return $datasetRaw;
|
|
},
|
|
'markRow' => function ($datasetRaw) {
|
|
|
|
$mark = '';
|
|
|
|
if ($datasetRaw->Statuscode == IssuesLib::STATUS_BEHOBEN)
|
|
$mark = "text-success";
|
|
elseif ($datasetRaw->Statuscode == IssuesLib::STATUS_NEU || $datasetRaw->Statuscode == IssuesLib::STATUS_IN_BEARBEITUNG)
|
|
{
|
|
if ($datasetRaw->Fehlertypcode == IssuesLib::ERRORTYPE_CODE)
|
|
{
|
|
$mark = "text-danger";
|
|
}
|
|
elseif ($datasetRaw->Fehlertypcode == IssuesLib::WARNINGTYPE_CODE)
|
|
{
|
|
$mark = "text-warning";
|
|
}
|
|
}
|
|
|
|
return $mark;
|
|
}
|
|
);
|
|
|
|
echo $this->widgetlib->widget('FilterWidget', $filterWidgetArray);
|