mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 20:29:29 +00:00
321 lines
9.6 KiB
PHP
321 lines
9.6 KiB
PHP
<?php
|
|
/**
|
|
* Klasse fuer Berechtigungen der User
|
|
* @author Christian Paminger
|
|
* @version 1.0
|
|
* @updated 11-Feb-2004
|
|
*/
|
|
class berechtigung
|
|
{
|
|
/**
|
|
* interne userberechtigung_id (Zaehler aus DB)
|
|
* @var integer
|
|
*/
|
|
var $userberechtigung_id;
|
|
/**
|
|
* @var integer
|
|
*/
|
|
var $studiengang_kz;
|
|
/**
|
|
* @var integer
|
|
*/
|
|
var $fachbereich_id;
|
|
/**
|
|
* @var string
|
|
*/
|
|
var $berechtigung_kurzbz;
|
|
/**
|
|
* @var string
|
|
*/
|
|
var $uid;
|
|
/**
|
|
* @var string
|
|
*/
|
|
var $studiensemester_kurzbz;
|
|
/**
|
|
* @var integer
|
|
*/
|
|
var $start;
|
|
/**
|
|
* @var integer
|
|
*/
|
|
var $ende;
|
|
/**
|
|
* @var integer
|
|
*/
|
|
var $starttimestamp;
|
|
/**
|
|
* @var integer
|
|
*/
|
|
var $endetimestamp;
|
|
/**
|
|
* @var string
|
|
*/
|
|
var $art;
|
|
|
|
/**
|
|
* @var array
|
|
*/
|
|
var $berechtigungen=array();
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
|
|
var $conn;
|
|
/**
|
|
* @var boolean
|
|
*/
|
|
var $new;
|
|
|
|
function berechtigung($conn)
|
|
{
|
|
$this->conn=$conn;
|
|
$this->new=true;
|
|
}
|
|
|
|
|
|
/**
|
|
* Ladet die Attribute der Berechtigung aus der Datenbank. Bei Fehler ist der
|
|
* Rueckgabewert 'false' und die Fehlermeldung steht in 'errormsg'.
|
|
* @return boolean true=ok, false=fehler
|
|
*/
|
|
function load($id)
|
|
{
|
|
// Berechtigung holen
|
|
$sql_query="SELECT * FROM tbl_userberechtigung WHERE userberechtigung_id=$id";
|
|
//echo $sql_query;
|
|
if(!($erg=pg_exec($this->conn, $sql_query)))
|
|
{
|
|
$this->errormsg=pg_errormessage($this->conn);
|
|
return false;
|
|
}
|
|
$num_rows=pg_numrows($erg);
|
|
if($num_rows!=1)
|
|
{
|
|
$this->errormsg="Zuwenige oder zuviele Ergebnisse (Anzahl: $num_rows)!";
|
|
return false;
|
|
}
|
|
$row=pg_fetch_object($erg,0);
|
|
|
|
$this->userberechtigung_id=$row->userberechtigung_id;
|
|
$this->studiengang_kz=$row->studiengang_kz;
|
|
$this->fachbereich_id=$row->fachbereich_id;
|
|
$this->berechtigung_kurzbz=$row->berechtigung_kurzbz;
|
|
$this->uid=$row->uid;
|
|
$this->studiensemester_kurzbz=$row->studiensemester_kurzbz;
|
|
$this->start=$row->start;
|
|
$this->ende=$row->ende;
|
|
$this->art=$row->art;
|
|
$this->new=false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* @return boolean true=ok, false=fehler
|
|
*/
|
|
function save()
|
|
{
|
|
// Connection holen
|
|
if (is_null($conn=$this->getConnection()))
|
|
{
|
|
return false;
|
|
}
|
|
// Daten zur Person speichern
|
|
|
|
if (!person::save()) {
|
|
$this->errormsg.="Daten zur LVA konnten nicht gespeichert werden.";
|
|
return false;
|
|
}
|
|
if ($this->new) {
|
|
$qry="INSERT INTO tbl_lehrveranstaltung(lvnr,unr,einheit_kurzbz,".
|
|
"lektor,lehrfach_nr,studiengang_kz,fachbereich_id,semester,verband,".
|
|
"gruppe,raumtyp,raumtypalternativ,semesterstunden,stundenblockung,".
|
|
"wochenrythmus,start_kw,anmerkung)".
|
|
"values(".
|
|
"'".$this->lvnr."',".
|
|
"'".$this->unr."',".
|
|
"'".$this->einheit_kurzbz."',".
|
|
"'".$this->lektor."',".
|
|
(strlen($this->lehrfach_nr)>0?$this->lehrfach_nr:NULL).",".
|
|
(strlen($this->studiengang_kz)>0?$this->studiengang_kz:NULL).",".
|
|
(strlen($this->fachbereich_id)>0?$this->fachbereich_id:NULL).",".
|
|
(strlen($this->semester)>0?$this->semester:NULL).",".
|
|
"'".$this->verband."',".
|
|
"'".$this->gruppe."',".
|
|
(strlen($this->raumtyp)>0?"'".$this->raumtyp."'":NULL).",".
|
|
(strlen($this->raumtypalternativ)>0?"'".$this->raumtypalternativ."'":NULL).",".
|
|
(strlen($this->semesterstunden)>0?$this->semesterstunden:NULL).",".
|
|
(strlen($this->stundenblockung)>0?$this->stundenblockung:NULL).",".
|
|
(strlen($this->wochenrythmus)>0?$this->wochenrythmus:NULL).",".
|
|
(strlen($this->start_kw)>0?$this->start_kw:NULL).",".
|
|
(strlen($this->anmerkung)>0?"'".$this->anmerkung."'":NULL).",".
|
|
")";
|
|
} else
|
|
{
|
|
$qry="UPDATE tbl_lehrveranstaltung ".
|
|
"SET lvnr='".$this->lvnr."',".
|
|
"unr='".$this->unr."',".
|
|
"einheit_kurzbz='".$this->einheit_kurzbz."',".
|
|
"lektor='".$this->lehrfach_nr."',".
|
|
"lehrfach_nr=".(strlen($this->lehrfach_nr)>0?$this->lehrfach_nr:NULL).",".
|
|
"studiengang_kz=".(strlen($this->studiengang_kz)>0?$this->studiengang_kz:NULL).",".
|
|
"fachbereich_id=".(strlen($this->fachbereich_id)>0?$this->fachbereich_id:NULL).",".
|
|
"semester=".(strlen($this->semester)>0?$this->semester:NULL).",".
|
|
"verband='".$this->verband."',".
|
|
"gruppe='".$this->gruppe."',".
|
|
"raumtyp=".(strlen($this->raumtyp)>0?"'".$this->raumtyp."'":NULL).",".
|
|
"raumtypalternativ=".(strlen($this->raumtypalternativ)>0?"'".$this->raumtypalternativ."'":NULL).",".
|
|
"semesterstunden=".(strlen($this->semesterstunden)>0?$this->semesterstunden:NULL).",".
|
|
"stundenblockung=".(strlen($this->stundenblockung)>0?$this->stundenblockung:NULL).",".
|
|
"wochenrythmus=".(strlen($this->wochenrythmus)>0?$this->wochenrythmus:NULL).",".
|
|
"start_kw=".(strlen($this->start_kw)>0?$this->start_kw:NULL).",".
|
|
"anmerkung=".(strlen($this->anmerkung)>0?"'".$this->anmerkung."'":NULL).
|
|
" WHERE lehrveranstaltung_id='".$this->lehrveranstaltung_id."'";
|
|
}
|
|
//echo "<br>".$qry;
|
|
if(!@pg_query($conn, $qry))
|
|
{
|
|
$this->errormsg=pg_errormessage($conn);
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
|
|
/**
|
|
* Rueckgabewert ist ein Array mit den Ergebnissen. Bei Fehler false und die
|
|
* Fehlermeldung liegt in errormsg.
|
|
* Wenn der Parameter stg_kz NULL ist tritt einheit_kurzbzb in Kraft.
|
|
* @param string $uid UserID
|
|
* @return variabel Array mit LVA; <b>false</b> bei Fehler
|
|
*/
|
|
function getBerechtigungen($uid)
|
|
{
|
|
// Berechtigungen holen
|
|
$sql_query="SELECT * FROM tbl_userberechtigung WHERE uid='$uid' AND (start<now() OR start IS NULL) AND (ende>now() OR ende IS NULL)";
|
|
//echo $sql_query;
|
|
if(!$erg=@pg_query($this->conn, $sql_query))
|
|
{
|
|
$this->errormsg=pg_errormessage($this->conn);
|
|
return false;
|
|
}
|
|
//$num_rows=pg_numrows($erg);
|
|
while($row=pg_fetch_object($erg))
|
|
{
|
|
$b=new berechtigung($this->conn);
|
|
$b->userberechtigung_id=$row->userberechtigung_id;
|
|
$b->studiengang_kz=$row->studiengang_kz;
|
|
$b->fachbereich_id=$row->fachbereich_id;
|
|
$b->berechtigung_kurzbz=$row->berechtigung_kurzbz;
|
|
$b->uid=$row->uid;
|
|
$b->studiensemester_kurzbz=$row->studiensemester_kurzbz;
|
|
$b->start=$row->start;
|
|
if ($row->start!=null)
|
|
$b->starttimestamp=mktime(0,0,0,substr($row->start,5,2),substr($row->start,8),substr($row->start,0,4));
|
|
else
|
|
$b->starttimestamp=null;
|
|
$b->ende=$row->ende;
|
|
if ($row->ende!=null)
|
|
$b->endetimestamp=mktime(23,59,59,substr($row->ende,5,2),substr($row->ende,8),substr($row->ende,0,4));
|
|
else
|
|
$b->endetimestamp=null;
|
|
$b->art=$row->art;
|
|
$this->berechtigungen[]=$b;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
function isBerechtigt($berechtigung,$studiengang_kz=null,$art=null, $fachbereich_id=null)
|
|
{
|
|
$timestamp=time();
|
|
foreach ($this->berechtigungen as $b)
|
|
{
|
|
//Fachbereichsberechtigung
|
|
if($fachbereich_id!=null)
|
|
{
|
|
//Wenn Fachbereichs oder Adminberechtigung
|
|
if(($berechtigung == $b->berechtigung_kurzbz || $b->berechtigung_kurzbz == 'admin') && ($b->fachbereich_id==$fachbereich_id || $b->fachbereich_id=='0'))
|
|
{
|
|
if ($b->starttimestamp!=null && $b->endetimestamp!=null)
|
|
{
|
|
if ($timestamp>$b->starttimestamp && $timestamp<$b->endetimestamp)
|
|
return true;
|
|
}
|
|
else
|
|
return true;
|
|
}
|
|
}
|
|
|
|
//Wenn Berechtigung fuer Bestimmte Klasse vorhanden ist
|
|
if($berechtigung == $b->berechtigung_kurzbz && $studiengang_kz==null && $art==null && $fachbereich_id==null)
|
|
if ($b->starttimestamp!=null && $b->endetimestamp!=null)
|
|
{
|
|
if ($timestamp>$b->starttimestamp && $timestamp<$b->endetimestamp)
|
|
return true;
|
|
}
|
|
else
|
|
return true;
|
|
//Wenn Berechtigung fuer Bestimmten Studiengang vorhanden ist
|
|
if ($berechtigung==$b->berechtigung_kurzbz
|
|
&& ($studiengang_kz==$b->studiengang_kz || $b->studiengang_kz==0) && $art==null && $b->fachbereich_id==null)
|
|
if ($b->starttimestamp!=null && $b->endetimestamp!=null)
|
|
{
|
|
if ($timestamp>$b->starttimestamp && $timestamp<$b->endetimestamp)
|
|
return true;
|
|
}
|
|
else
|
|
return true;
|
|
//Wenn Berechtigung mit Studiengang und der richtigen BerechtigungsArt (suid) vorhanden ist
|
|
if ($berechtigung==$b->berechtigung_kurzbz
|
|
&& ($studiengang_kz==$b->studiengang_kz || $b->studiengang_kz==0)
|
|
&& strstr($b->art,$art))
|
|
if ($b->starttimestamp!=null && $b->endetimestamp!=null)
|
|
{
|
|
if ($timestamp>$b->starttimestamp && $timestamp<$b->endetimestamp)
|
|
return true;
|
|
}
|
|
else
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Gibt Array mit Kennzahlen der Studiengaenge sortiert zurueck.
|
|
* Optional wird auf Berechtigung eingeschraenkt.
|
|
* Wenn Berechtigung ueber alle Studiengaenge steht im ersten Feld 0.
|
|
*/
|
|
function getStgKz($berechtigung=null)
|
|
{
|
|
$studiengang_kz=array();
|
|
$timestamp=time();
|
|
|
|
foreach ($this->berechtigungen as $b)
|
|
if ($berechtigung==$b->berechtigung_kurzbz || $berechtigung==null)
|
|
if($b->fachbereich_id==null)
|
|
$studiengang_kz[]=$b->studiengang_kz;
|
|
$studiengang_kz=array_unique($studiengang_kz);
|
|
sort($studiengang_kz);
|
|
return $studiengang_kz;
|
|
}
|
|
|
|
function getFbKz($berechtigung=null)
|
|
{
|
|
$fachbereichs_kz=array();
|
|
$timestamp=time();
|
|
|
|
foreach($this->berechtigungen as $b)
|
|
{
|
|
if(($berechtigung==$b->berechtigung_kurzbz || $berechtigung==null)
|
|
&& (($timestamp>$b->starttimestamp && $timestamp<$b->endetimestamp) || ($b->starttimestamp==null && $b->endetimestamp==null)))
|
|
{
|
|
if($b->fachbereich_id!='' && !in_array($b->fachbereich_id,$fachbereichs_kz))
|
|
$fachbereichs_kz[] = $b->fachbereich_id;
|
|
}
|
|
}
|
|
sort($fachbereichs_kz);
|
|
return $fachbereichs_kz;
|
|
}
|
|
}
|
|
?>
|