Files
FHC-Core/include/zeitwunsch_gueltigkeit.class.php
T
2024-10-17 15:34:00 +02:00

272 lines
9.2 KiB
PHP

<?php
require_once(dirname(__FILE__). '/basis_db.class.php');
class zeitwunsch_gueltigkeit extends basis_db
{
public $new; // boolean
public $result = array();
public $zeitwunsch_gueltigkeit_id; // integer
public $mitarbeiter_uid; // varchar 32
public $von; // date
public $bis; // date
public $insertamum; // timestamp
public $insertvon; // varchar 32
public $updateamum; // timestamp
public $updatevon; // varchar 32
public $studiensemester_kurzbz;
public $start;
public $ende;
public function __construct($zeitwunsch_gueltigkeit_id = null)
{
parent::__construct();
if (!is_null($zeitwunsch_gueltigkeit_id))
{
$this->load($zeitwunsch_gueltigkeit_id);
}
}
/**
* Ladet eine Zeitwunschgueltigkeit.
* @param $zeitwunsch_gueltigkeit_id
* @return bool
*/
public function load($zeitwunsch_gueltigkeit_id)
{
if (!is_numeric($zeitwunsch_gueltigkeit_id))
{
$this->errormsg = 'Wrong parameter zeitwunsch_gueltigkeit_id.';
return false;
}
$qry = '
SELECT *, studiensemester_kurzbz, start, ende
FROM campus.tbl_zeitwunsch_gueltigkeit, public.tbl_studiensemester
WHERE zeitwunsch_gueltigkeit_id = '.$this->db_add_param($zeitwunsch_gueltigkeit_id). '
AND (von < ende AND COALESCE(bis, \'2999-12-31\'::date ) > start)
ORDER BY start ASC
LIMIT 1
';
if ($result = $this->db_query($qry))
{
while ($row = $this->db_fetch_object($result))
{
$this->zeitwunsch_gueltigkeit_id = $row->zeitwunsch_gueltigkeit_id;
$this->von = $row->von;
$this->bis = $row->bis;
$this->insertamum = $row->insertamum;
$this->insertvon = $row->insertvon;
$this->updateamum = $row->updateamum;
$this->updatevon = $row->updatevon;
$this->studiensemester_kurzbz = $row->studiensemester_kurzbz;
$this->start = $row->start;
$this->ende = $row->ende;
}
return true;
}
else
{
$this->errormsg = 'Fehler bei der Datenbankabfrage';
return false;
}
}
/**
* Speichert eine Zeitwunschgueltigkeit
*/
public function save()
{
if($this->new)
{
$qry = '
INSERT INTO campus.tbl_zeitwunsch_gueltigkeit (mitarbeiter_uid, von, bis, insertvon)
VALUES ('.
$this->db_add_param($this->mitarbeiter_uid).', '.
$this->db_add_param($this->von).', '.
$this->db_add_param($this->bis).', '.
$this->db_add_param($this->insertvon). ')
RETURNING zeitwunsch_gueltigkeit_id;
';
}
else
{
$qry = '
UPDATE campus.tbl_zeitwunsch_gueltigkeit SET'.
' bis = '. $this->db_add_param($this->bis). ', '.
' updateamum = NOW(), '.
' updatevon = '.$this->db_add_param($this->updatevon).
' WHERE zeitwunsch_gueltigkeit_id = ' .$this->db_add_param($this->zeitwunsch_gueltigkeit_id, FHC_INTEGER);
}
if($result = $this->db_query($qry))
{
// Wenn neuer Eintrag
if ($this->new)
{
if($row = $this->db_fetch_object($result))
{
// ZWG ID des neuen ZWG Eintrags zurueckgeben
$this->zeitwunsch_gueltigkeit_id = $row->zeitwunsch_gueltigkeit_id;
}
}
return true;
}
else
{
$this->errormsg = 'Fehler beim Speichern der Zeitwunschgueltigkeit';
return false;
}
}
/**
* Ladet Zeitwunschgueltigkeiten einer UID mitsamt den zugehoerigen Studiensemestern.
* @param $uid
* @param numeric $limit limit = null liefert alle ZWG; limit = 1 liefert die letztgueltige Zeitwunsch-Gueltigkeit.
* @param bool $activeOnly Wenn während des laufenden Semesters der Zeitwunsch geaendert werden, werden mehrere ZWG im Semester hinterlegt.
* true liefert pro Studiensemester nur die letztgueltigen ZWG;
* false liefert alle ZWG pro Studiensemester
* @param string $bis string date, z.B. 2022-01-31
* @return bool
*/
public function getByUID($uid, $limit = null, $activeOnly = true, $bis = null)
{
$qry = '
WITH basic_select AS (
SELECT *,
row_number() over (PARTITION BY studiensemester_kurzbz ORDER BY von DESC) r
FROM campus.tbl_zeitwunsch_gueltigkeit, public.tbl_studiensemester
WHERE mitarbeiter_uid = ' . $this->db_add_param($uid);
// Wenn Bis-Datum angegeben
if (!is_null($bis))
{
// Zeitwuensche nur bis zum angegebenen Bis-Datum
$qry.= '
AND (von < ende AND '. $this->db_add_param($bis). '::date > start))
';
}
// Wenn kein Bis-Datum angegeben ist
else
{
// Zeitwuensche bis zum Semesterende des chronologisch letzten Zeitwunsches (also der ZWG, wo bis NULL ist)
$qry.= '
AND (von < ende AND COALESCE(bis, (SELECT ende FROM public.tbl_studiensemester WHERE von BETWEEN start AND ende)) > start))';
}
$qry.= '
SELECT *
FROM basic_select
';
// Wenn nur aktive Zeitwunschgueltigkeiten angezeigt werden sollen
if ($activeOnly)
{
$qry.= ' WHERE r = 1';
}
$qry.= ' ORDER BY von DESC, start DESC';
// Wenn Limit angegeben
if (!is_null($limit))
{
$qry.= ' LIMIT '.$this->db_add_param($limit);
}
if ($result = $this->db_query($qry))
{
$this->result = array();
while ($row = $this->db_fetch_object($result))
{
$obj = new StdClass();
$obj->zeitwunsch_gueltigkeit_id = $row->zeitwunsch_gueltigkeit_id;
$obj->von = $row->von;
$obj->bis = $row->bis;
$obj->studiensemester_kurzbz = $row->studiensemester_kurzbz;
$obj->start = $row->start;
$obj->ende = $row->ende;
$obj->insertamum = $row->insertamum;
$obj->insertvon = $row->insertvon;
$obj->updateamum = $row->updateamum;
$obj->updatevon = $row->updatevon;
$this->result[]= $obj;
}
return true;
}
else
{
$this->errormsg = 'Fehler bei der Datenbankabfrage';
return false;
}
}
/**
* Ladet Zeitwunschgueltigkeiten einer UID und eines bestimmten Semesters (defaultmaeßig nur die letztgueltige)
* @param $uid
* @param $studiensemester_kurzbz
* @param null $limit limit = null liefert alle ZWG des Studiensemesters; limit = 1 liefert die letztgueltige ZWG.
* @return bool
*/
public function getByStudiensemester($uid, $studiensemester_kurzbz, $limit = 1)
{
$qry = '
WITH studiensemester AS
(
SELECT studiensemester_kurzbz, start, ende
FROM public.tbl_studiensemester
WHERE studiensemester_kurzbz = '.$this->db_add_param($studiensemester_kurzbz). '
)
SELECT zwg.*, studiensemester_kurzbz, start, ende
FROM campus.tbl_zeitwunsch_gueltigkeit zwg, studiensemester ss
WHERE zwg.mitarbeiter_uid = '.$this->db_add_param($uid). '
AND (zwg.von < ss.ende AND COALESCE(zwg.bis, ss.ende) >= ss.start)
ORDER BY von DESC, bis DESC
';
// Wenn Limit angegeben
if (!is_null($limit))
{
// Ausgabe limitieren
$qry.= 'LIMIT '.$this->db_add_param($limit);
}
if ($result = $this->db_query($qry))
{
$this->result = array();
while ($row = $this->db_fetch_object($result))
{
$obj = new StdClass();
$obj->zeitwunsch_gueltigkeit_id = $row->zeitwunsch_gueltigkeit_id;
$obj->von = $row->von;
$obj->bis = $row->bis;
$obj->studiensemester_kurzbz = $row->studiensemester_kurzbz;
$obj->start = $row->start;
$obj->ende = $row->ende;
$obj->insertamum = $row->insertamum;
$obj->insertvon = $row->insertvon;
$obj->updateamum = $row->updateamum;
$obj->updatevon = $row->updatevon;
$this->result[]= $obj;
}
return true;
}
else
{
$this->errormsg = 'Fehler bei der Datenbankabfrage';
return false;
}
}
}