, * Andreas Oesterreicher and * Rudolf Hangl . */ /** * Klasse Betriebsmittelperson * @create 13-01-2007 */ require_once(dirname(__FILE__).'/basis_db.class.php'); class betriebsmittelperson extends basis_db { public $debug=false; // boolean public $new; // boolean public $result = array(); //Tabellenspalten public $betriebsmittelperson_id; public $betriebsmittel_id; // integer public $person_id; // integer public $betriebsmittel_id_old; // integer public $person_id_old; // integer public $anmerkung; // string public $kaution; // numeric(5,2) public $ausgegebenam; // date public $retouram; // date public $ext_id; // integer public $insertamum; // timestamp public $insertvon; // bigint public $updateamum; // timestamp public $updatevon; // bigint public $nummer; public $betriebsmitteltyp; public $beschreibung; public $oe_kurzbz; public $nummer2; public $uid; /** * Konstruktor * @param $betriebsmittel_id * $person_id */ public function __construct($betriebsmittelperson_id=null) { parent::__construct(); if(!is_null($betriebsmittelperson_id)) $this->load($betriebsmittelperson_id); } /** * Laedt das Betriebsmittel mit der ID $betriebsmittelperson_id * @param $betriebsmittelperson_id ID des zu ladenden Zuordnung * @return true wenn ok, false im Fehlerfall */ public function load($betriebsmittelperson_id) { if(!is_numeric($betriebsmittelperson_id)) { $this->errormsg = 'Betriebsmittelperson_id ist ungueltig'; return false; } $qry = "SELECT tbl_betriebsmittel.*, tbl_betriebsmittelperson.* FROM wawi.tbl_betriebsmittel JOIN wawi.tbl_betriebsmittelperson USING(betriebsmittel_id) WHERE betriebsmittelperson_id=".$this->db_add_param($betriebsmittelperson_id, FHC_INTEGER); if($this->db_query($qry)) { if($row = $this->db_fetch_object()) { $this->betriebsmittelperson_id = $row->betriebsmittelperson_id; $this->betriebsmittel_id = $row->betriebsmittel_id; $this->beschreibung = $row->beschreibung; $this->betriebsmitteltyp = $row->betriebsmitteltyp; $this->nummer = $row->nummer; $this->inventarnummer = $row->inventarnummer; $this->reservieren = $this->db_parse_bool($row->reservieren); $this->person_id = $row->person_id; $this->anmerkung = $row->anmerkung; $this->kaution = $row->kaution; $this->ausgegebenam = $row->ausgegebenam; $this->retouram = $row->retouram; $this->insertamum = $row->insertamum; $this->insertvon = $row->insertvon; $this->updateamum = $row->updateamum; $this->updatevon = $row->updatevon; $this->ext_id = $row->ext_id; $this->ort_kurzbz = $row->ort_kurzbz; $this->oe_kurzbz = $row->oe_kurzbz; $this->nummer2 = $row->nummer2; $this->uid = $row->uid; return true; } else { $this->errormsg = 'Es wurde kein passender Datensatz gefunden'; return false; } } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Prueft die Variablen vor dem Speichern * * @return true wenn ok, sonst false */ protected function validate() { if($this->kaution=='') $this->kaution=0; if(!is_numeric($this->kaution)) { $this->errormsg = 'Kaution ist ungueltig'; return false; } if($this->ausgegebenam!='' && !mb_ereg("([0-9]{4})-([0-9]{2})-([0-9]{2})",$this->ausgegebenam) && !mb_ereg("([0-9]{2}).([0-9]{2}).([0-9]{4})",$this->ausgegebenam)) { $this->errormsg = 'Ausgegeben am Datum ist ungueltig'; return false; } if($this->retouram!='' && !mb_ereg("([0-9]{4})-([0-9]{2})-([0-9]{2})",$this->retouram) && !mb_ereg("([0-9]{2}).([0-9]{2}).([0-9]{4})",$this->retouram)) { $this->errormsg = 'Ausgegeben am Datum ist ungueltig'; return false; } if(mb_strlen($this->anmerkung)>256) { $this->errormsg = 'Anmerkung darf nicht laenger als 256 Zeichen sein'; return false; } if($this->kaution!='' && $this->kaution>9999.99) { $this->errormsg = 'Kaution darf nicht groesser als 9999.99 sein'; 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 $betriebsmittelperson_id aktualisiert * @param $new * @return true wenn ok, false im Fehlerfall */ public function save($new=null) { if(!$this->validate()) return false; if(is_null($new)) $new = $this->new; if($new) { //Neuen Datensatz einfuegen $qry='BEGIN;INSERT INTO wawi.tbl_betriebsmittelperson (betriebsmittel_id, person_id, anmerkung, kaution, ausgegebenam, retouram, insertamum, insertvon, updateamum, updatevon, uid) VALUES('. $this->db_add_param($this->betriebsmittel_id, FHC_INTEGER).', '. $this->db_add_param($this->person_id, FHC_INTEGER).', '. $this->db_add_param($this->anmerkung).', '. $this->db_add_param($this->kaution).', '. $this->db_add_param($this->ausgegebenam).', '. $this->db_add_param($this->retouram).', now(), '. $this->db_add_param($this->insertvon).', now(), '. $this->db_add_param($this->updatevon).', '. $this->db_add_param($this->uid).');'; } else { //Pruefen ob betriebsmittelperson_id eine gueltige Zahl ist if(!is_numeric($this->betriebsmittelperson_id)) { $this->errormsg = 'betriebsmittel_id und Person_id muessen gueltige Zahlen sein'; return false; } $qry='UPDATE wawi.tbl_betriebsmittelperson SET '. 'betriebsmittel_id='.$this->db_add_param($this->betriebsmittel_id, FHC_INTEGER).', '. 'person_id='.$this->db_add_param($this->person_id, FHC_INTEGER).', '. 'anmerkung='.$this->db_add_param($this->anmerkung).', '. 'kaution='.$this->db_add_param($this->kaution).', '. 'ausgegebenam='.$this->db_add_param($this->ausgegebenam).', '. 'retouram='.$this->db_add_param($this->retouram).', '. 'updateamum= now(), '. 'updatevon='.$this->db_add_param($this->updatevon).', '. 'uid = '.$this->db_add_param($this->uid).' '. 'WHERE betriebsmittelperson_id='.$this->db_add_param($this->betriebsmittelperson_id, FHC_INTEGER).';'; } if($this->db_query($qry)) { if($new) { $qry = "SELECT currval('wawi.seq_betriebsmittelperson_betriebsmittelperson_id') as id"; if($result = $this->db_query($qry)) { if($row = $this->db_fetch_object($result)) { $this->betriebsmittelperson_id = $row->id; $this->db_query('COMMIT;'); } else { $this->errormsg = 'Fehler beim Auslesen der Sequence'; $this->db_query('ROLLBACK;'); return false; } } else { $this->errormsg = 'Fehler beim Auslesen der Sequence'; $this->db_query('ROLLBACK;'); return false; } } return true; } else { $this->errormsg = 'Fehler beim Speichern der Betriebsmittelperson'; return false; } } /** * Loescht den Datenensatz mit der ID die uebergeben wird * @param $betriebsmittelperson_id ID die geloescht werden soll * @return true wenn ok, false im Fehlerfall */ public function delete($betriebsmittelperson_id) { if(!is_numeric($betriebsmittelperson_id)) { $this->errormsg = 'Betriebsmittelperson_id ist ungueltig'; return false; } $qry = 'DELETE FROM wawi.tbl_betriebsmittelperson WHERE betriebsmittelperson_id='.$this->db_add_param($betriebsmittelperson_id, FHC_INTEGER); if($this->db_query($qry)) return true; else { $this->errormsg = 'Fehler beim Loeschen der Daten'; return false; } } /** * Loescht ALLE zuordnungen zu einem Betriebsmittel * @param $betriebsmittel_id ID die geloescht werden soll * @return true wenn ok, false im Fehlerfall */ public function delete_betriebsmittel($betriebsmittel_id) { if(!is_numeric($betriebsmittel_id)) { $this->errormsg = 'Betriebsmittel_id ist ungueltig'; return false; } $qry = 'DELETE FROM wawi.tbl_betriebsmittelperson WHERE betriebsmittel_id='.$this->db_add_param($betriebsmittel_id, FHC_INTEGER); if($this->db_query($qry)) return true; else { $this->errormsg = 'Fehler beim Loeschen der Daten'; return false; } } /** * Laedt alle Betriebsmittel einer Person * Optional kann auch ein Typ uebergeben werden * @param $person_id ID der Person * @param $betriebsmitteltyp Typ auf den gefiltert werden soll * @return true wenn ok, false wenn Fehler */ public function getBetriebsmittelPerson($person_id, $betriebsmitteltyp=null, $order=null) { $this->result=array(); $this->errormsg = ''; if(!is_numeric($person_id)) { $this->errormsg = 'Person_id ist ungueltig'; return false; } $qry = "SELECT * FROM wawi.tbl_betriebsmittel JOIN wawi.tbl_betriebsmittelperson USING(betriebsmittel_id) WHERE person_id=".$this->db_add_param($person_id, FHC_INTEGER); if(!is_null($betriebsmitteltyp)) $qry.=" AND betriebsmitteltyp=".$this->db_add_param($betriebsmitteltyp); if(!is_null($order)) $qry.=" ORDER BY ".$order; else $qry.=" ORDER BY betriebsmitteltyp, nummer"; if($this->db_query($qry)) { while($row = $this->db_fetch_object()) { $bm = new betriebsmittelperson(); $bm->betriebsmittelperson_id = $row->betriebsmittelperson_id; $bm->betriebsmittel_id = $row->betriebsmittel_id; $bm->beschreibung = $row->beschreibung; $bm->betriebsmitteltyp = $row->betriebsmitteltyp; $bm->nummer = $row->nummer; $bm->inventarnummer = $row->inventarnummer; $bm->verwendung = $row->verwendung; $bm->reservieren = $this->db_parse_bool($row->reservieren); $bm->ort_kurzbz = $row->ort_kurzbz; $bm->person_id = $row->person_id; $bm->anmerkung = $row->anmerkung; $bm->kaution = $row->kaution; $bm->ausgegebenam = $row->ausgegebenam; $bm->retouram = $row->retouram; $bm->insertamum = $row->insertamum; $bm->insertvon = $row->insertvon; $bm->updateamum = $row->updateamum; $bm->updatevon = $row->updatevon; $bm->ext_id = $row->ext_id; $bm->oe_kurzbz = $row->oe_kurzbz; $bm->nummer2 = $row->nummer2; $bm->uid = $row->uid; $this->result[] = $bm; } return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Laedt die Betriebsmittelzuordnung der Person, welche das Betriebsmittel zuletzt hatte * bzw die Letzte Zuordnung von einer bestimmten Person * @param $betriebsmittel_id ID des zu ladenden Betriebsmittels * @param $person_id ID der Person (optional) * @return true wenn ok, false im Fehlerfall */ public function load_betriebsmittelpersonen($betriebsmittel_id, $person_id=null) { $this->result=array(); $this->errormsg=''; if(!is_numeric($betriebsmittel_id)) { $this->errormsg = 'Betriebsmittel_id ist ungueltig'; return false; } $qry=' SELECT * FROM wawi.tbl_betriebsmittel JOIN wawi.tbl_betriebsmittelperson USING(betriebsmittel_id) WHERE betriebsmittel_id='.$this->db_add_param($betriebsmittel_id, FHC_INTEGER); if(!is_null($person_id)) $qry.=" AND person_id=".$this->db_add_param($person_id, FHC_INTEGER); $qry.=' ORDER BY ausgegebenam desc, retouram desc LIMIT 1'; if($this->db_query($qry)) { if($row = $this->db_fetch_object()) { $this->betriebsmittelperson_id = $row->betriebsmittelperson_id; $this->betriebsmittel_id = $row->betriebsmittel_id; $this->beschreibung = $row->beschreibung; $this->betriebsmitteltyp = $row->betriebsmitteltyp; $this->nummer = $row->nummer; $this->inventarnummer = $row->inventarnummer; $this->reservieren = $this->db_parse_bool($row->reservieren); $this->ort_kurzbz = $row->ort_kurzbz; $this->person_id = $row->person_id; $this->anmerkung = $row->anmerkung; $this->kaution = $row->kaution; $this->ausgegebenam = $row->ausgegebenam; $this->retouram = $row->retouram; $this->insertamum = $row->insertamum; $this->insertvon = $row->insertvon; $this->updateamum = $row->updateamum; $this->updatevon = $row->updatevon; $this->ext_id = $row->ext_id; $this->oe_kurzbz = $row->oe_kurzbz; $this->nummer2 = $row->nummer2; $this->uid = $row->uid; return true; } else { $this->errormsg ='Es wurde kein Eintrag gefunden'; return false; } } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Laedt alle Zuordnungen zu diesem Betriebsmittel * @param $betriebsmittel_id ID des zu ladenden Betriebsmittels * @return true wenn ok, false im Fehlerfall */ public function getbetriebsmittelpersonen($betriebsmittel_id) { $this->result=array(); $this->errormsg=''; if(!is_numeric($betriebsmittel_id)) { $this->errormsg = 'Betriebsmittel_id ist ungueltig'; return false; } $qry=' SELECT * FROM wawi.tbl_betriebsmittel JOIN wawi.tbl_betriebsmittelperson USING(betriebsmittel_id) WHERE betriebsmittel_id='.$this->db_add_param($betriebsmittel_id, FHC_INTEGER).' ORDER BY ausgegebenam desc, retouram desc'; if($this->db_query($qry)) { while($row = $this->db_fetch_object()) { $bm = new betriebsmittelperson(); $bm->betriebsmittelperson_id = $row->betriebsmittelperson_id; $bm->betriebsmittel_id = $row->betriebsmittel_id; $bm->beschreibung = $row->beschreibung; $bm->betriebsmitteltyp = $row->betriebsmitteltyp; $bm->nummer = $row->nummer; $bm->inventarnummer = $row->inventarnummer; $bm->reservieren = $this->db_parse_bool($row->reservieren); $bm->ort_kurzbz = $row->ort_kurzbz; $bm->person_id = $row->person_id; $bm->anmerkung = $row->anmerkung; $bm->kaution = $row->kaution; $bm->ausgegebenam = $row->ausgegebenam; $bm->retouram = $row->retouram; $bm->insertamum = $row->insertamum; $bm->insertvon = $row->insertvon; $bm->updateamum = $row->updateamum; $bm->updatevon = $row->updatevon; $bm->ext_id = $row->ext_id; $bm->oe_kurzbz = $row->oe_kurzbz; $bm->nummer2 = $row->nummer2; $bm->uid = $row->uid; $this->result[] = $bm; } return true; } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Sucht welche Person die uebergebene Kartennummer hat * @param $nummer Kartennummer * @param boolean $checkRetour Optional. Default true. Checkt, ob die Karte bereits retourniert wurde. Wenn false werden auch bereits retournierte Karten zurückgegeben * @return true wenn ok, false im Fehlerfall */ public function getKartenzuordnung($nummer, $checkRetour=true) { // fuehrende Nullen bei Kartennummern auch checken $qry=' SELECT * FROM wawi.tbl_betriebsmittel JOIN wawi.tbl_betriebsmittelperson USING(betriebsmittel_id) WHERE (tbl_betriebsmittel.nummer='.$this->db_add_param($nummer).' OR tbl_betriebsmittel.nummer='.$this->db_add_param('0'.$nummer).' OR tbl_betriebsmittel.nummer='.$this->db_add_param('00'.$nummer).' OR tbl_betriebsmittel.nummer='.$this->db_add_param('000'.$nummer).' OR tbl_betriebsmittel.nummer='.$this->db_add_param('0000'.$nummer).' OR tbl_betriebsmittel.nummer='.$this->db_add_param('00000'.$nummer).' OR tbl_betriebsmittel.nummer2='.$this->db_add_param($nummer).' OR tbl_betriebsmittel.nummer2='.$this->db_add_param('0'.$nummer).' OR tbl_betriebsmittel.nummer2='.$this->db_add_param('00'.$nummer).' OR tbl_betriebsmittel.nummer2='.$this->db_add_param('000'.$nummer).' OR tbl_betriebsmittel.nummer2='.$this->db_add_param('0000'.$nummer).' OR tbl_betriebsmittel.nummer2='.$this->db_add_param('00000'.$nummer).' ) AND tbl_betriebsmittel.betriebsmitteltyp=\'Zutrittskarte\' AND (ausgegebenam<=now() OR ausgegebenam is NULL)'; if ($checkRetour == true) { $qry .= ' AND (retouram>=now() OR retouram is NULL)'; } if($this->db_query($qry)) { if($row = $this->db_fetch_object()) { $this->betriebsmittelperson_id = $row->betriebsmittelperson_id; $this->betriebsmittel_id = $row->betriebsmittel_id; $this->beschreibung = $row->beschreibung; $this->betriebsmitteltyp = $row->betriebsmitteltyp; $this->nummer = $row->nummer; $this->inventarnummer = $row->inventarnummer; $this->reservieren = $this->db_parse_bool($row->reservieren); $this->ort_kurzbz = $row->ort_kurzbz; $this->person_id = $row->person_id; $this->anmerkung = $row->anmerkung; $this->kaution = $row->kaution; $this->ausgegebenam = $row->ausgegebenam; $this->retouram = $row->retouram; $this->insertamum = $row->insertamum; $this->insertvon = $row->insertvon; $this->updateamum = $row->updateamum; $this->updatevon = $row->updatevon; $this->ext_id = $row->ext_id; $this->oe_kurzbz = $row->oe_kurzbz; $this->nummer2 = $row->nummer2; $this->uid = $row->uid; return true; } else { $this->errormsg = 'Karte ist derzeit nicht ausgegeben'; return false; } } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } /** * Sucht welche Person die uebergebene Kartennummer hat * @param $person_id Person ID * @param $nummer Kartennummer * @return true wenn ok, false im Fehlerfall */ public function getKartenzuordnungPerson($person_id, $nummer) { $qry=' SELECT * FROM wawi.tbl_betriebsmittel JOIN wawi.tbl_betriebsmittelperson USING(betriebsmittel_id) WHERE tbl_betriebsmittel.nummer2='.$this->db_add_param($nummer).' AND tbl_betriebsmittel.betriebsmitteltyp=\'Zutrittskarte\' AND tbl_betriebsmittelperson.person_id='.$this->db_add_param($person_id); if($this->db_query($qry)) { if($row = $this->db_fetch_object()) { $this->betriebsmittelperson_id = $row->betriebsmittelperson_id; $this->betriebsmittel_id = $row->betriebsmittel_id; $this->beschreibung = $row->beschreibung; $this->betriebsmitteltyp = $row->betriebsmitteltyp; $this->nummer = $row->nummer; $this->inventarnummer = $row->inventarnummer; $this->reservieren = $this->db_parse_bool($row->reservieren); $this->ort_kurzbz = $row->ort_kurzbz; $this->person_id = $row->person_id; $this->anmerkung = $row->anmerkung; $this->kaution = $row->kaution; $this->ausgegebenam = $row->ausgegebenam; $this->retouram = $row->retouram; $this->insertamum = $row->insertamum; $this->insertvon = $row->insertvon; $this->updateamum = $row->updateamum; $this->updatevon = $row->updatevon; $this->ext_id = $row->ext_id; $this->oe_kurzbz = $row->oe_kurzbz; $this->nummer2 = $row->nummer2; $this->uid = $row->uid; return true; } else { $this->errormsg = 'Karte ist derzeit nicht ausgegeben'; return false; } } else { $this->errormsg = 'Fehler beim Laden der Daten'; return false; } } } ?>