Files
FHC-Core/application/models/education/Anrechnung_model.php
T
ma0068 b75c9cc524 portation of tab Anrechnungen
- switch version edit / non edit in config
2025-03-20 11:16:05 +01:00

268 lines
7.5 KiB
PHP

<?php
class Anrechnung_model extends DB_Model
{
const ANRECHNUNGSTATUS_PROGRESSED_BY_STGL = 'inProgressDP';
const ANRECHNUNGSTATUS_APPROVED = 'approved';
const ANRECHNUNGSTATUS_REJECTED = 'rejected';
/**
* Constructor
*/
public function __construct()
{
parent::__construct();
$this->dbTable = 'lehre.tbl_anrechnung';
$this->pk = 'anrechnung_id';
}
/**
* Creates new Anrechnungsantrag.
* Saves new Anrechnung and sets Anrechnungstatus for the new Anrechnung.
*
* @param $prestudent_id
* @param $studiensemester_kurzbz
* @param $lehrveranstaltung_id
* @param $begruendung_id
* @param $dms_id DMS ID of uploaded Nachweisdokument
* @param null $anmerkung_student = Herkunft der Kenntnisse
* @return array
*/
public function createAnrechnungsantrag(
$prestudent_id, $studiensemester_kurzbz, $lehrveranstaltung_id,
$begruendung_id, $dms_id, $anmerkung_student = null, $begruendung_ects = null, $begruendung_lvinhalt = null
)
{
// Start DB transaction
$this->db->trans_start(false);
// Save Anrechnung
$result = $this->AnrechnungModel->insert(array(
'prestudent_id' => $prestudent_id,
'lehrveranstaltung_id' => $lehrveranstaltung_id,
'begruendung_id' => $begruendung_id,
'dms_id' => $dms_id,
'studiensemester_kurzbz' => $studiensemester_kurzbz,
'anmerkung_student' => $anmerkung_student,
'begruendung_ects' => $begruendung_ects,
'begruendung_lvinhalt' => $begruendung_lvinhalt,
'insertvon' => $this->_uid
));
// Store just inserted Anrechnung ID
$lastInsert_anrechnung_id = $result->retval;
// Save Anrechnungstatus
$this->AnrechnungModel->saveAnrechnungstatus($lastInsert_anrechnung_id, self::ANRECHNUNGSTATUS_PROGRESSED_BY_STGL);
// Transaction complete
$this->db->trans_complete();
if ($this->db->trans_status() === false)
{
$this->db->trans_rollback();
return error('Failed inserting Anrechnung', EXIT_ERROR);
}
return success($lastInsert_anrechnung_id);
}
/**
* Save Anrechnungstatus.
* @param $anrechnung_id
* @param $status_kurzbz
* @return array|null
*/
public function saveAnrechnungstatus($anrechnung_id, $status_kurzbz)
{
$qry = '
INSERT INTO lehre.tbl_anrechnung_anrechnungstatus (
anrechnung_id, status_kurzbz, insertvon
) VALUES ( ?, ?, ?);
';
return $this->execQuery($qry, array($anrechnung_id, $status_kurzbz, getAuthUID()));
}
/**
* Get the last inserted Anrechnungstatus
* @param $anrechnung_id
* @return array|null
*/
public function getLastAnrechnungstatus($anrechnung_id, $status_kurzbz = null)
{
if (is_string($status_kurzbz))
{
$qry = '
SELECT *
FROM lehre.tbl_anrechnungstatus
JOIN lehre.tbl_anrechnung_anrechnungstatus USING (status_kurzbz)
WHERE anrechnung_id = ?
AND status_kurzbz = ?
ORDER BY insertamum DESC
LIMIT 1
';
return $this->execQuery($qry, array($anrechnung_id, $status_kurzbz));
}
$qry = '
SELECT *
FROM lehre.tbl_anrechnungstatus
JOIN lehre.tbl_anrechnung_anrechnungstatus USING (status_kurzbz)
WHERE anrechnung_id = ?
ORDER BY insertamum DESC
LIMIT 1
';
return $this->execQuery($qry, array($anrechnung_id));
}
/**
* Get status approved / rejected, if present.
* @param $anrechnung_id
* @return array|null
*/
public function getApprovedOrRejected($anrechnung_id)
{
$qry = '
SELECT *
FROM lehre.tbl_anrechnungstatus
JOIN lehre.tbl_anrechnung_anrechnungstatus USING (status_kurzbz)
WHERE anrechnung_id = ?
AND (status_kurzbz = \'approved\' OR status_kurzbz = \'rejected\')
ORDER BY insertamum DESC
LIMIT 1
';
return $this->execQuery($qry, array($anrechnung_id));
}
/**
* Delete Anrechnungstatus.
*
* @param $anrechnungstatus_id
*/
public function deleteAnrechnungstatus($anrechnungstatus_id){
$qry = '
DELETE FROM lehre.tbl_anrechnung_anrechnungstatus
WHERE anrechnungstatus_id = ?
';
return $this->execQuery($qry, array($anrechnungstatus_id));
}
/**
* Delete last status approved / rejected.
* If last status is 'approved', Genehmigung is resetted.
*
* @param $anrechnung_id
* @return array
*/
public function withdrawApprovement($anrechnung_id)
{
// Get last Anrechnungstatus
if (!$result = getData($this->AnrechnungModel->getLastAnrechnungstatus($anrechnung_id))[0])
{
return error('Failed loading Anrechnung');
}
$last_status = $result->status_kurzbz;
$anrechnungstatus_id = $result->anrechnungstatus_id;
// Exit, if last status is not approved / rejected
if ($last_status != self::ANRECHNUNGSTATUS_APPROVED && $last_status != self::ANRECHNUNGSTATUS_REJECTED)
{
return error('Nothing to withdraw. Application is still in progress');
}
// Start DB transaction
$this->db->trans_start(false);
// If Anrechnung was approved
if ($last_status == self::ANRECHNUNGSTATUS_APPROVED)
{
// Reset Genehmigung
$this->AnrechnungModel->update($anrechnung_id, array('genehmigt_von' => NULL));
}
// Delete last status approved / rejected
$this->AnrechnungModel->deleteAnrechnungstatus($anrechnungstatus_id);
// Transaction complete
$this->db->trans_complete();
if ($this->db->trans_status() === false)
{
$this->db->trans_rollback();
return error('Failed withdrawing Genehmigung', EXIT_ERROR);
}
return success();
}
/**
* Get Anrechnungsdata for Table Anrechnungen
*
* @param $prestudent_id
* @return array
*/
public function getAnrechnungsData($prestudent_id)
{
$qry = '
SELECT
lehre.tbl_anrechnung.anrechnung_id,
lehre.tbl_anrechnung.prestudent_id,
lehre.tbl_anrechnung.lehrveranstaltung_id,
lehre.tbl_lehrveranstaltung.bezeichnung AS bez_lehrveranstaltung,
lehre.tbl_anrechnung_begruendung.bezeichnung AS begruendung,
lehre.tbl_anrechnung_anrechnungstatus.status_kurzbz AS status,
genehmigt_von,
lehre.tbl_anrechnung.insertamum,
lehre.tbl_anrechnung.insertvon,
lehre.tbl_anrechnung.updateamum,
lehre.tbl_anrechnung.updatevon,
lehrveranstaltung_id_kompatibel,
lv_comp.bezeichnung as lehrveranstaltung_bez_kompatibel,
count(nz.notizzuordnung_id) AS notizen_anzahl
FROM
lehre.tbl_anrechnung
JOIN lehre.tbl_lehrveranstaltung USING (lehrveranstaltung_id)
LEFT JOIN lehre.tbl_lehrveranstaltung lv_comp ON (lehre.tbl_anrechnung.lehrveranstaltung_id_kompatibel = lv_comp.lehrveranstaltung_id)
JOIN lehre.tbl_anrechnung_begruendung USING (begruendung_id)
LEFT JOIN lehre.tbl_anrechnung_anrechnungstatus ON (lehre.tbl_anrechnung_anrechnungstatus.anrechnung_id = lehre.tbl_anrechnung.anrechnung_id)
AND lehre.tbl_anrechnung_anrechnungstatus.insertamum = (
SELECT MAX(insertamum)
FROM lehre.tbl_anrechnung_anrechnungstatus
WHERE anrechnung_id = lehre.tbl_anrechnung.anrechnung_id
)
LEFT JOIN lehre.tbl_anrechnungstatus USING (status_kurzbz)
LEFT JOIN public.tbl_notizzuordnung nz ON (nz.anrechnung_id = lehre.tbl_anrechnung.anrechnung_id)
WHERE
lehre.tbl_anrechnung.prestudent_id = ?
GROUP BY
nz.anrechnung_id,
lehre.tbl_anrechnung.anrechnung_id,
lehre.tbl_anrechnung.prestudent_id,
lehre.tbl_anrechnung.lehrveranstaltung_id,
bez_lehrveranstaltung,
begruendung,
status,
genehmigt_von,
lehre.tbl_anrechnung.insertamum,
lehre.tbl_anrechnung.insertvon,
lehre.tbl_anrechnung.updateamum,
lehre.tbl_anrechnung.updatevon,
lehrveranstaltung_id_kompatibel,
lehrveranstaltung_bez_kompatibel
ORDER BY
lehre.tbl_anrechnung.updateamum ASC
';
return $this->execQuery($qry, array($prestudent_id));
}
}