Files
FHC-Core/include/preincoming.class.php
T
Karl Burkhart 482a92f417
2011-04-27 13:51:25 +00:00

508 lines
15 KiB
PHP

<?php
/* Copyright (C) 2011 FH Technikum-Wien
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
*
* Authors: Christian Paminger <christian.paminger@technikum-wien.at>,
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at> and
* Karl Burkhart <burkhart@technikum-wien.at>.
*/
/**
* Klasse PreIncoming
* @create 20-04-2011
*/
require_once(dirname(__FILE__).'/basis_db.class.php');
class preincoming extends basis_db
{
public $new; // boolean
public $result = array(); // adresse Objekt
//Tabellenspalten
public $preincoming_id; // integer
public $person_id; // integer
public $mobilitaetsprogramm_code; // integer
public $zweck_code; // varchar(20)
public $firma_id; // integer
public $anmerkung; // text
public $universitaet; // varchar(256)
public $aktiv; // boolean
public $bachelorthesis; // boolean
public $masterthesis; // boolean
public $von; // date
public $bis; // date
public $uebernommen; // boolean
public $updateamum; // timestamp
public $updatevon; // string
public $insertamum; // timestamp
public $insertvon; // string
/**
* Konstruktor
* @param $preincoming_id ID des Datensatzes der geladen werden soll (Default=null)
*/
public function __construct($preincoming_id=null)
{
parent::__construct();
if(!is_null($preincoming_id))
$this->load($preincoming_id);
}
/**
* Laedt den Preincoming Datensatz mit der uebergebenen ID
* @param $preincoming_id ID des zu ladenden Preincoming
* @return true wenn ok, false im Fehlerfall
*/
public function load($preincoming_id)
{
//Pruefen ob id eine gueltige Zahl ist
if(!is_numeric($preincoming_id) || $preincoming_id == '')
{
$this->errormsg = 'id muss eine Zahl sein';
return false;
}
//Daten aus der Datenbank lesen
$qry = "SELECT * FROM public.tbl_preincoming WHERE preincoming_id='".addslashes($preincoming_id)."'";
if(!$this->db_query($qry))
{
$this->errormsg = 'Fehler bei einer Datenbankabfrage';
return false;
}
if($row = $this->db_fetch_object())
{
$this->preincoming_id = $row->preincoming_id;
$this->person_id = $row->person_id;
$this->mobilitaetsprogramm_code = $row->mobilitaetsprogramm_code;
$this->zweck_code = $row->zweck_code;
$this->firma_id = $row->firma_id;
$this->anmerkung = $row->anmerkung;
$this->universitaet = $row->universitaet;
$this->aktiv = ($row->aktiv=='t'?true:false);
$this->bachelorthesis = ($row->bachelorthesis=='t'?true:false);
$this->masterthesis = ($row->masterthesis=='t'?true:false);
$this->von = $row->von;
$this->bis = $row->bis;
$this->uebernommen = ($row->uebernommen=='t'?true:false);
$this->updateamum = $row->updateamum;
$this->updatevon = $row->updatevon;
$this->insertamum = $row->insertamum;
$this->insertvon = $row->insertvon;
}
else
{
$this->errormsg = 'Es ist kein Datensatz mit dieser ID vorhanden';
return false;
}
return true;
}
/**
* Laedt die Preincoming anhand der PersonID
*
* @param $person_id
*/
public function loadFromPerson($person_id)
{
$qry = "SELECT * FROM public.tbl_preincoming WHERE person_id='".addslashes($person_id)."'";
if($result = $this->db_query($qry))
{
while($row = $this->db_fetch_object($result))
{
$obj = new preincoming();
$obj->preincoming_id = $row->preincoming_id;
$obj->person_id = $row->person_id;
$obj->mobilitaetsprogramm_code = $row->mobilitaetsprogramm_code;
$obj->zweck_code = $row->zweck_code;
$obj->firma_id = $row->firma_id;
$obj->anmerkung = $row->anmerkung;
$obj->universitaet = $row->universitaet;
$obj->aktiv = ($row->aktiv=='t'?true:false);
$obj->bachelorthesis = ($row->bachelorthesis=='t'?true:false);
$obj->masterthesis = ($row->masterthesis=='t'?true:false);
$obj->von = $row->von;
$obj->bis = $row->bis;
$obj->uebernommen = ($row->uebernommen=='t'?true:false);
$obj->updateamum = $row->updateamum;
$obj->updatevon = $row->updatevon;
$obj->insertamum = $row->insertamum;
$obj->insertvon = $row->insertvon;
$this->result[] = $obj;
}
return true;
}
else
{
$this->errormsg = 'Fehler beim Laden der Daten';
return false;
}
}
/**
* Prueft die Variablen auf Gueltigkeit
* @return true wenn ok, false im Fehlerfall
*/
protected function validate()
{
if(mb_strlen($this->universitaet)>256)
{
$this->errormsg='Universitaet darf nicht laenger als 256 Zeichen sein';
return false;
}
if(!is_numeric($this->person_id))
{
$this->errormsg='PersonID muss eine gueltige Zahl sein';
return false;
}
if($this->firma_id!='' && !is_numeric($this->firma_id))
{
$this->errormsg='Firma ist ungueltig';
return false;
}
return true;
}
/**
* Speichert den aktuellen Datensatz in die Datenbank
* Wenn $neu auf true gesetzt ist wird ein neuer Datensatz angelegt
* andernfalls wird der Datensatz mit der ID in $adresse_id aktualisiert
* @return true wenn ok, false im Fehlerfall
*/
public function save()
{
//Variablen pruefen
if(!$this->validate())
return false;
if($this->new)
{
//Neuen Datensatz einfuegen
$qry='BEGIN;INSERT INTO public.tbl_preincoming (person_id, mobilitaetsprogramm_code, zweck_code,
firma_id, anmerkung, universitaet, aktiv, bachelorthesis, masterthesis,
von, bis, uebernommen, insertamum, insertvon, updateamum, updatevon) VALUES('.
$this->addslashes($this->person_id).', '.
$this->addslashes($this->mobilitaetsprogramm_code).', '.
$this->addslashes($this->zweck_code).', '.
$this->addslashes($this->firma_id).', '.
$this->addslashes($this->anmerkung).', '.
$this->addslashes($this->universitaet).', '.
($this->aktiv?'true':'false').', '.
($this->bachelorthesis?'true':'false').', '.
($this->masterthesis?'true':'false').', '.
$this->addslashes($this->von).', '.
$this->addslashes($this->bis).', '.
($this->uebernommen?'true':'false').', '.
$this->addslashes($this->insertamum).', '.
$this->addslashes($this->insertvon).', '.
$this->addslashes($this->updateamum).', '.
$this->addslashes($this->updatevon).');';
}
else
{
//Pruefen ob adresse_id eine gueltige Zahl ist
if(!is_numeric($this->preincoming_id))
{
$this->errormsg = 'preincoming_id muss eine gültige Zahl sein';
return false;
}
$qry='UPDATE public.tbl_preincoming SET'.
' person_id='.$this->addslashes($this->person_id).', '.
' mobilitaetsprogramm_code='.$this->addslashes($this->mobilitaetsprogramm_code).', '.
' zweck_code='.$this->addslashes($this->zweck_code).', '.
' firma_id='.$this->addslashes($this->firma_id).', '.
' anmerkung='.$this->addslashes($this->anmerkung).', '.
' universitaet='.$this->addslashes($this->universitaet).', '.
' aktiv='.($this->aktiv?'true':'false').', '.
' bachelorthesis='.($this->bachelorthesis?'true':'false').', '.
' masterthesis='.($this->masterthesis?'true':'false').', '.
' von='.$this->addslashes($this->von).', '.
' bis='.$this->addslashes($this->bis).','.
' uebernommen='.($this->uebernommen?'true':'false').', '.
' updateamum='.$this->addslashes($this->updateamum).','.
' updatevon='.$this->addslashes($this->updatevon).
' WHERE preincoming_id='.$this->preincoming_id.';';
}
if($this->db_query($qry))
{
if($this->new)
{
//aktuelle ID aus der Sequence holen
$qry="SELECT currval('public.seq_preincoming_preincoming_id') as id;";
if($this->db_query($qry))
{
if($row = $this->db_fetch_object())
{
$this->preincoming_id = $row->id;
$this->db_query('COMMIT');
}
else
{
$this->db_query('ROLLBACK');
$this->errormsg = "Fehler beim Auslesen der Sequence";
return false;
}
}
else
{
$this->db_query('ROLLBACK');
$this->errormsg = 'Fehler beim Auslesen der Sequence';
return false;
}
}
}
else
{
$this->errormsg = 'Fehler beim Speichern des Datensatzes';
return false;
}
return true;
}
/**
* Loescht den Preincoming Datenensatz mit der ID die uebergeben wird
* @param $preincoming ID die geloescht werden soll
* @return true wenn ok, false im Fehlerfall
*/
public function delete($preincoming_id)
{
//Pruefen ob preincoming_id eine gueltige Zahl ist
if(!is_numeric($preincoming_id) || $preincoming_id == '')
{
$this->errormsg = 'preincoming_id muss eine gültige Zahl sein'."\n";
return false;
}
//loeschen des Datensatzes
$qry="DELETE FROM public.tbl_preincoming WHERE preincoming_id='".addslashes($preincoming_id)."';";
if($this->db_query($qry))
{
return true;
}
else
{
$this->errormsg = 'Fehler beim Löschen der Daten'."\n";
return false;
}
}
/**
* Liefert ein Array mit den Lehrveranstaltungen denen der PreIncoming zugeordnet ist
*
* @param $preincoming_id
* @return Array mit LehrveranstaltungIDs
*/
public function getLehrveranstaltungen($preincoming_id)
{
$lvs = array();
if(!is_numeric($preincoming_id) || $preincoming_id=='')
{
$this->errormsg = 'ID muss eine gueltige Zahl sein';
return false;
}
$qry = "SELECT * FROM public.tbl_preincoming_lehrveranstaltung WHERE preincoming_id='".addslashes($preincoming_id)."';";
if($result = $this->db_query($qry))
{
while($row = $this->db_fetch_object($result))
{
$lvs[] = $row->lehrveranstaltung_id;
}
}
else
{
$this->errormsg = 'Fehler beim Laden der Lehrveranstaltungen';
return false;
}
return $lvs;
}
/**
* Entfernt die Zuordnung eines Preincoming zu einer LV
*
* @param $preincoming_id
* @param $lehrveranstaltung_id
*/
public function deleteLehrveranstaltung($preincoming_id, $lehrveranstaltung_id)
{
if(!is_numeric($preincoming_id) || $preincoming_id=='')
{
$this->errorsmg = 'Preincoming_id ist ungueltig';
return false;
}
if(!is_numeric($lehrveranstaltung_id) || $lehrveranstaltung_id=='')
{
$this->errormsg = 'Lehrveranstaltung ist ungueltig';
return false;
}
$qry = "DELETE FROM public.tbl_preincoming_lehrveranstaltung
WHERE preincoming_id='".addslashes($preincoming_id)."'
AND lehrveranstaltung_id='".addslashes($lehrveranstaltung_id)."';";
if($this->db_query($qry))
{
return true;
}
else
{
$this->errormsg = 'Fehler beim Löschen der LV Zuordnung';
return false;
}
}
/**
* Prueft ob die LV bereits zu dem Preincoming zugeordnet ist
*
* @param $preincoming_id
* @param $lehrveranstaltung_id
* @return boolean true wenn bereits zugeordnet, sonst false
*/
public function checkLehrveranstaltung($preincoming_id, $lehrveranstaltung_id)
{
$qry = "SELECT 1 FROM public.tbl_preincoming_lehrveranstaltung
WHERE
preincoming_id='".addslashes($preincoming_id)."'
AND lehrveranstaltung_id='".addslashes($lehrveranstaltung_id)."';";
if($result = $this->db_query($qry))
{
if($this->db_num_rows($result)>0)
return true;
else
return false;
}
else
{
$this->errormsg='Fehler beim Laden der Daten';
return false;
}
}
/**
* Teilt eine Lehrveranstaltung zu einem Preincoming zu
* @param $preincoming_id
* @param $lehrveranstaltung_id
* @param $insertamum
* @param $insertvon
*/
public function addLehrveranstaltung($preincoming_id, $lehrveranstaltung_id, $insertamum, $insertvon = "")
{
$qry = "INSERT INTO public.tbl_preincoming_lehrveranstaltung(lehrveranstaltung_id,
preincoming_id, insertamum, insertvon) VALUES(".
$this->addslashes($lehrveranstaltung_id).','.
$this->addslashes($preincoming_id).','.
$this->addslashes($insertamum).','.
$this->addslashes($insertvon).');';
if($this->db_query($qry))
{
return true;
}
else
{
$this->errormsg = 'Fehler beim Speichern der Zuteilung';
return false;
}
}
/**
* Laedt die PreIncoming anhand von Suchkriterien
*
* @param $filter
* @param $aktiv
* @param $von
* @param $bis
* @param $uebernommen
* @return boolean
*/
public function getPreincoming($filter, $aktiv=true, $von=null, $bis=null, $uebernommen=false)
{
$qry = "SELECT
titelpre, titelpost, vorname, nachname, tbl_preincoming.*
FROM
public.tbl_person
JOIN public.tbl_preincoming USING(person_id)
WHERE
1=1";
if($filter!='')
{
$qry.=" AND (lower(nachname) like lower('%".addslashes($filter)."%')
OR lower(vorname) like lower('%".addslashes($filter)."%')
OR lower(nachname || ' ' || vorname) like lower('%".addslashes($filter)."%')
OR lower(vorname || ' ' || nachname) like lower('%".addslashes($filter)."%'))";
}
if(!is_null($aktiv))
$qry.=" AND tbl_preincoming.aktiv=".($aktiv?'true':'false');
if(!is_null($uebernommen))
$qry.=" AND tbl_preincoming.uebernommen=".($uebernommen?'true':'false');
if($von!='')
$qry.=" AND tbl_preincoming.von>='".addslashes($von)."'";
if($bis!='')
$qry.=" AND tbl_preincoming.bis<='".addslashes($bis)."'";
if($result = $this->db_query($qry))
{
while($row = $this->db_fetch_object($result))
{
$obj = new preincoming();
$obj->preincoming_id = $row->preincoming_id;
$obj->person_id = $row->person_id;
$obj->mobilitaetsprogramm_code = $row->mobilitaetsprogramm_code;
$obj->zweck_code = $row->zweck_code;
$obj->firma_id = $row->firma_id;
$obj->anmerkung = $row->anmerkung;
$obj->universitaet = $row->universitaet;
$obj->aktiv = ($row->aktiv=='t'?true:false);
$obj->bachelorthesis = ($row->bachelorthesis=='t'?true:false);
$obj->masterthesis = ($row->masterthesis=='t'?true:false);
$obj->von = $row->von;
$obj->bis = $row->bis;
$obj->uebernommen = ($row->uebernommen=='t'?true:false);
$obj->updateamum = $row->updateamum;
$obj->updatevon = $row->updatevon;
$obj->insertamum = $row->insertamum;
$obj->insertvon = $row->insertvon;
$obj->vorname = $row->vorname;
$obj->nachname = $row->nachname;
$obj->titelpre = $row->titelpre;
$obj->titelpost = $row->titelpost;
$this->result[] = $obj;
}
return true;
}
else
{
$this->errormsg = 'Fehler beim Laden der Daten';
return false;
}
}
}
?>