mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-07-01 19:09:27 +00:00
7340564d1e
. added AnrechnungJob sendMailToSTGL() . removed functions to send mail from CTRL Signed-off-by: cris-technikum <hainberg@technikum-wien.at>
230 lines
6.8 KiB
PHP
230 lines
6.8 KiB
PHP
<?php
|
|
/**
|
|
* FH-Complete
|
|
*
|
|
* @package FHC-API
|
|
* @author FHC-Team
|
|
* @copyright Copyright (c) 2021, fhcomplete.org
|
|
* @license GPLv3
|
|
* @link http://fhcomplete.org
|
|
* @since Version 1.0
|
|
* @filesource
|
|
*/
|
|
|
|
if (!defined('BASEPATH')) exit('No direct script access allowed');
|
|
|
|
class AnrechnungJob extends JOB_Controller
|
|
{
|
|
const APPROVE_ANRECHNUNG_URI = '/lehre/anrechnung/ApproveAnrechnungUebersicht';
|
|
|
|
/**
|
|
* Constructor
|
|
*/
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
$this->load->model('education/Zeugnisnote_model', 'ZeugnisnoteModel');
|
|
$this->load->model('education/Anrechnung_model', 'AnrechnungModel');
|
|
$this->load->model('organisation/Studiengang_model', 'StudiengangModel');
|
|
|
|
$this->load->helper('url');
|
|
$this->load->helper('hlp_sancho_helper');
|
|
}
|
|
|
|
/**
|
|
* Sets the Grades in FAS to angerechnet if the request was successfull
|
|
* @return void
|
|
*/
|
|
public function setAnrechnungGrades()
|
|
{
|
|
$this->logInfo('Start Anrechnung Grades Job');
|
|
// get all accepted requests that are not in the grades table yet
|
|
|
|
// get all placement tests with incorrect studyplan
|
|
$qry = "
|
|
SELECT
|
|
student_uid, lehrveranstaltung_id, studiensemester_kurzbz, genehmigt_von
|
|
FROM
|
|
lehre.tbl_anrechnung
|
|
JOIN public.tbl_student USING(prestudent_id)
|
|
WHERE
|
|
genehmigt_von is not null
|
|
AND EXISTS(
|
|
SELECT 1 FROM lehre.tbl_anrechnung_anrechnungstatus
|
|
WHERE anrechnung_id = tbl_anrechnung.anrechnung_id
|
|
AND status_kurzbz='approved'
|
|
AND datum>=now()-'5 days'::interval
|
|
)
|
|
AND NOT EXISTS(
|
|
SELECT 1 FROM lehre.tbl_zeugnisnote
|
|
WHERE
|
|
lehrveranstaltung_id = tbl_anrechnung.lehrveranstaltung_id
|
|
AND studiensemester_kurzbz = tbl_anrechnung.studiensemester_kurzbz
|
|
AND student_uid = tbl_student.student_uid
|
|
)
|
|
";
|
|
|
|
$db = new DB_Model();
|
|
$result_grades = $db->execReadOnlyQuery($qry);
|
|
|
|
$cnt = 0;
|
|
if (hasData($result_grades))
|
|
{
|
|
$grades = getData($result_grades);
|
|
foreach ($grades as $anrechnung)
|
|
{
|
|
$cnt++;
|
|
// Set zeugnisnote to angerechnet (= note 6)
|
|
$ret = $this->ZeugnisnoteModel->insert(array(
|
|
'lehrveranstaltung_id' => $anrechnung->lehrveranstaltung_id,
|
|
'student_uid' => $anrechnung->student_uid,
|
|
'studiensemester_kurzbz' => $anrechnung->studiensemester_kurzbz,
|
|
'uebernahmedatum' => (new DateTime())->format('Y-m-d H:m:i'),
|
|
'benotungsdatum' => (new DateTime())->format('Y-m-d H:m:i'),
|
|
'note' => 6,
|
|
'insertvon' => $anrechnung->genehmigt_von,
|
|
'bemerkung' => 'Digitale Anrechnung'
|
|
)
|
|
);
|
|
}
|
|
}
|
|
$this->logInfo('End Anrechnung Grades Job', array('Number of Grades added'=>$cnt));
|
|
}
|
|
|
|
// Send Sancho mail to STGL with yesterdays new Anrechnungen
|
|
public function sendMailToSTGL()
|
|
{
|
|
$this->logInfo('Start AnrechnungJob to send emails to STGL about yesterdays new Anrechnungen.');
|
|
|
|
// Get all yesterdays Anrechnungen
|
|
$this->AnrechnungModel->addSelect('anrechnung_id, studiensemester_kurzbz, lv.studiengang_kz, lv.bezeichnung, vorname, nachname');
|
|
$this->AnrechnungModel->addJoin('lehre.tbl_lehrveranstaltung lv', 'lehrveranstaltung_id');
|
|
$this->AnrechnungModel->addJoin('public.tbl_student student', 'prestudent_id');
|
|
$this->AnrechnungModel->addJoin('public.tbl_benutzer benutzer', 'ON (benutzer.uid = student.student_uid)');
|
|
$this->AnrechnungModel->addJoin('public.tbl_person person', 'person_id');
|
|
$this->AnrechnungModel->addOrder('lv.studiengang_kz, lv.bezeichnung');
|
|
|
|
$result = $this->AnrechnungModel->loadWhere(
|
|
'(lehre.tbl_anrechnung.insertamum)::date = (NOW() - INTERVAL \'1 DAY\')::DATE'
|
|
);
|
|
|
|
// Exit if there are no Anrechnungen
|
|
if (!$anrechnungen = getData($result)) {
|
|
$this->logInfo('ABORTED: Sending emails to STGL about yesterdays new Anrechnungen aborted - No new Anrechnungen found.');
|
|
exit;
|
|
}
|
|
|
|
$unique_studiengang_kz_arr = array_unique(array_column($anrechnungen, 'studiengang_kz'));
|
|
|
|
foreach ($unique_studiengang_kz_arr as $studiengang_kz)
|
|
{
|
|
// Get STG bezeichnung
|
|
$this->StudiengangModel->addSelect('UPPER( typ || kurzbz ) AS "stg_bezeichnung"');
|
|
$studiengang_bezeichnung = $this->StudiengangModel->load($studiengang_kz)->retval[0]->stg_bezeichnung;
|
|
|
|
// Get STGL mail address
|
|
list ($to, $vorname) = self::_getSTGLMailAddress($studiengang_kz);
|
|
|
|
// Get HTML table with new Anrechnungen of that STG plus amount of them
|
|
list ($anrechnungen_amount, $anrechnungen_table) = self::_getSTGLMailDataTable($studiengang_kz, $anrechnungen);
|
|
|
|
// Link to Antrag genehmigen dashboard
|
|
$url =
|
|
CIS_ROOT. 'cis/index.php?menu='.
|
|
CIS_ROOT. 'cis/menu.php?content_id=&content='.
|
|
CIS_ROOT. index_page(). self::APPROVE_ANRECHNUNG_URI;
|
|
|
|
// Prepare mail content
|
|
$body_fields = array(
|
|
'vorname' => $vorname,
|
|
'studiengang' => $studiengang_bezeichnung,
|
|
'anzahl' => $anrechnungen_amount,
|
|
'datentabelle' => $anrechnungen_table,
|
|
'link' => anchor($url, 'Anrechnungsanträge Übersicht')
|
|
);
|
|
|
|
// Send mail
|
|
sendSanchoMail(
|
|
'AnrechnungAntragStellen',
|
|
$body_fields,
|
|
$to,
|
|
'Anerkennung nachgewiesener Kenntnisse: Neuer Antrag wurde gestellt'
|
|
);
|
|
}
|
|
|
|
$this->logInfo('SUCCEDED: Sending emails to STGL about yesterdays new Anrechnungen succeded.');
|
|
}
|
|
|
|
// Get STGL mail address
|
|
private function _getSTGLMailAddress($studiengang_kz)
|
|
{
|
|
$result = $this->StudiengangModel->getLeitung($studiengang_kz);
|
|
|
|
// Get STGL mail address
|
|
if (hasData($result))
|
|
{
|
|
return array(
|
|
$result->retval[0]->uid. '@'. DOMAIN,
|
|
$result->retval[0]->vorname
|
|
);
|
|
}
|
|
// If not available, get assistance mail address
|
|
else
|
|
{
|
|
$result = $this->StudiengangModel->load($studiengang_kz);
|
|
|
|
if (hasData($result))
|
|
{
|
|
return array(
|
|
$result->retval[0]->email,
|
|
''
|
|
);
|
|
}
|
|
}
|
|
}
|
|
|
|
// Build HTML table with yesterdays new Anrechnungen of the given STG
|
|
private function _getSTGLMailDataTable($studiengang_kz, $anrechnungen)
|
|
{
|
|
$html = '';
|
|
$lv_bezeichnung = '';
|
|
|
|
// Filter Anrechnungen of given STG
|
|
$anrechnungen = array_filter(
|
|
$anrechnungen,
|
|
function ($anrechnung) use (&$studiengang_kz) {
|
|
return $anrechnung->studiengang_kz == $studiengang_kz;
|
|
});
|
|
|
|
// Amount of Anrechnungen
|
|
$amount = count($anrechnungen);
|
|
|
|
// HTML table body
|
|
$html .= '
|
|
<table style="width: 60%; border-collapse: collapse;" border="1" cellpadding="5">
|
|
<tbody>
|
|
';
|
|
|
|
foreach ($anrechnungen as $anrechnung)
|
|
{
|
|
// Head line for each LV bezeichnung
|
|
if ($anrechnung->bezeichnung != $lv_bezeichnung)
|
|
{
|
|
$html .= '<tr><td><span><strong>' . $anrechnung->bezeichnung . '</strong></span></td></tr>';
|
|
}
|
|
|
|
$lv_bezeichnung = $anrechnung->bezeichnung;
|
|
|
|
// Row for each Anrechnung / student
|
|
$html .= '<tr><td><span>'. $anrechnung->vorname. ' '. $anrechnung->nachname. '</span></td></tr>';
|
|
}
|
|
|
|
$html .= '
|
|
</tbody>
|
|
</table>
|
|
';
|
|
|
|
return array($amount, $html);
|
|
}
|
|
}
|