mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 12:19:28 +00:00
127 lines
4.3 KiB
PHP
127 lines
4.3 KiB
PHP
<?php
|
|
|
|
if (! defined('BASEPATH')) exit('No direct script access allowed');
|
|
|
|
require_once('PlausiChecker.php');
|
|
|
|
/**
|
|
*
|
|
*/
|
|
class AusbildungssemPrestudentUngleichAusbildungssemStatus extends PlausiChecker
|
|
{
|
|
public function executePlausiCheck($params)
|
|
{
|
|
$results = array();
|
|
|
|
// get parameters from config
|
|
$exkludierte_studiengang_kz = isset($this->_config['exkludierteStudiengaenge']) ? $this->_config['exkludierteStudiengaenge'] : null;
|
|
|
|
// pass parameters needed for plausicheck
|
|
$studiensemester_kurzbz = isset($params['studiensemester_kurzbz']) ? $params['studiensemester_kurzbz'] : null;
|
|
$studiengang_kz = isset($params['studiengang_kz']) ? $params['studiengang_kz'] : null;
|
|
$person_id = isset($params['person_id']) ? $params['person_id'] : null;
|
|
|
|
// get all students failing the plausicheck
|
|
$prestudentRes = $this->getAusbildungssemPrestudentUngleichAusbildungssemStatus(
|
|
$studiensemester_kurzbz,
|
|
$studiengang_kz,
|
|
null,
|
|
$person_id,
|
|
$exkludierte_studiengang_kz
|
|
);
|
|
|
|
if (isError($prestudentRes)) return $prestudentRes;
|
|
|
|
if (hasData($prestudentRes))
|
|
{
|
|
$prestudents = getData($prestudentRes);
|
|
|
|
// populate results with data necessary for writing issues
|
|
foreach ($prestudents as $prestudent)
|
|
{
|
|
$results[] = array(
|
|
'person_id' => $prestudent->person_id,
|
|
'oe_kurzbz' => $prestudent->prestudent_stg_oe_kurzbz,
|
|
'fehlertext_params' => array(
|
|
'status_ausbildungssemester' => $prestudent->status_ausbildungssemester,
|
|
'student_ausbildungssemester' => $prestudent->student_ausbildungssemester,
|
|
'student_uid' => $prestudent->student_uid,
|
|
'prestudent_id' => $prestudent->prestudent_id,
|
|
'studiensemester_kurzbz' => $prestudent->studiensemester_kurzbz
|
|
),
|
|
'resolution_params' => array(
|
|
'prestudent_id' => $prestudent->prestudent_id,
|
|
'studiensemester_kurzbz' => $prestudent->studiensemester_kurzbz
|
|
)
|
|
);
|
|
}
|
|
}
|
|
|
|
// return the results
|
|
return success($results);
|
|
}
|
|
|
|
/**
|
|
* Ausbildungssemester of prestudent (lehrverband) must be the same as Ausbildungssemester of prestudentstatus.
|
|
* @param studiensemester_kurzbz string check is to be executed for certain Studiensemester
|
|
* @param studiengang_kz int if check is to be executed for certain Studiengang
|
|
* @param prestudent_id int if check is to be executed only for one prestudent
|
|
* @param person_id int if check is to be executed only for one person
|
|
* @param exkludierte_studiengang_kz array if certain Studiengänge have to be excluded from check
|
|
* @return success with prestudents or error
|
|
*/
|
|
public function getAusbildungssemPrestudentUngleichAusbildungssemStatus(
|
|
$studiensemester_kurzbz,
|
|
$studiengang_kz = null,
|
|
$prestudent_id = null,
|
|
$person_id = null,
|
|
$exkludierte_studiengang_kz = null
|
|
) {
|
|
$params = array($studiensemester_kurzbz, $studiensemester_kurzbz, $studiensemester_kurzbz);
|
|
|
|
$qry = "
|
|
SELECT
|
|
DISTINCT(student.student_uid), student.student_uid, prestudent.person_id, prestudent.prestudent_id,
|
|
status.ausbildungssemester AS status_ausbildungssemester, lv.semester AS student_ausbildungssemester, status.studiensemester_kurzbz,
|
|
stg.oe_kurzbz AS prestudent_stg_oe_kurzbz
|
|
FROM
|
|
public.tbl_student student
|
|
JOIN public.tbl_studentlehrverband lv USING(student_uid)
|
|
JOIN public.tbl_prestudent prestudent USING(prestudent_id)
|
|
JOIN public.tbl_prestudentstatus status USING(prestudent_id)
|
|
JOIN public.tbl_studiengang stg ON prestudent.studiengang_kz = stg.studiengang_kz
|
|
WHERE
|
|
status.studiensemester_kurzbz = ?
|
|
AND lv.studiensemester_kurzbz = ?
|
|
AND status.status_kurzbz NOT IN ('Interessent','Bewerber','Aufgenommener','Wartender','Abgewiesener','Unterbrecher')
|
|
AND get_rolle_prestudent (prestudent_id, ?)='Student'
|
|
AND status.ausbildungssemester != lv.semester";
|
|
|
|
if (isset($studiengang_kz))
|
|
{
|
|
$qry .= " AND stg.studiengang_kz = ?";
|
|
$params[] = $studiengang_kz;
|
|
}
|
|
|
|
if (isset($prestudent_id))
|
|
{
|
|
$qry .= " AND prestudent.prestudent_id = ?";
|
|
$params[] = $prestudent_id;
|
|
}
|
|
|
|
if (isset($person_id))
|
|
{
|
|
$qry .= " AND prestudent.person_id = ?";
|
|
$params[] = $person_id;
|
|
}
|
|
|
|
if (isset($exkludierte_studiengang_kz) && !isEmptyArray($exkludierte_studiengang_kz))
|
|
{
|
|
$qry .= " AND stg.studiengang_kz NOT IN ?";
|
|
$params[] = $exkludierte_studiengang_kz;
|
|
}
|
|
|
|
return $this->_db->execReadOnlyQuery($qry, $params);
|
|
}
|
|
}
|