diff --git a/application/controllers/jobs/AntragJob.php b/application/controllers/jobs/AntragJob.php index 131cfdced..0663be94b 100644 --- a/application/controllers/jobs/AntragJob.php +++ b/application/controllers/jobs/AntragJob.php @@ -306,11 +306,24 @@ class AntragJob extends JOB_Controller foreach ($prestudents as $prestudent) { - $result = $this->prestudentlib->setAbbrecher($prestudent->prestudent_id, $prestudent->studiensemester_kurzbz, $insertvon); - if (isError($result)) + $result = $this->StudierendenantragstatusModel->insert([ + 'studierendenantrag_id' => $prestudent->studierendenantrag_id, + 'studierendenantrag_statustyp_kurzbz' => Studierendenantragstatus_model::STATUS_DEREGISTERED, + 'insertvon' => 'AntragJob' + ]); + if (isError($result)) { $this->logError(getError($result)); - else - $count++; + } else { + $deregisterStatus = getData($result); + + $result = $this->prestudentlib->setAbbrecher($prestudent->prestudent_id, '', $insertvon); + if (isError($result)) { + $this->StudierendenantragstatusModel->delete($deregisterStatus); + $this->logError(getError($result)); + } else { + $count++; + } + } } $this->logInfo($count . " Students set to Abbrecher"); } diff --git a/application/controllers/jobs/ESIJob.php b/application/controllers/jobs/ESIJob.php new file mode 100644 index 000000000..c9a558a46 --- /dev/null +++ b/application/controllers/jobs/ESIJob.php @@ -0,0 +1,165 @@ +load->model('person/Person_model', 'PersonModel'); + $this->load->model('person/Kennzeichen_model', 'KennzeichenModel'); + } + + //------------------------------------------------------------------------------------------------------------------ + // Public methods + + /** + * Initialises generateESI job, handles job queue, logs infos/errors + */ + public function generateESI() + { + //$jobType = 'DVUHSendPruefungsaktivitaeten'; + $this->logInfo(ESIScheduler::JOB_TYPE_GENERATE_ESI.' job start'); + + // Gets the latest jobs + $lastJobs = $this->getLastJobs(ESIScheduler::JOB_TYPE_GENERATE_ESI); + + if (isError($lastJobs)) + { + $this->logError(getCode($lastJobs).': '.getError($lastJobs), ESIScheduler::JOB_TYPE_GENERATE_ESI); + } + else + { + $this->updateJobs( + getData($lastJobs), // Jobs to be updated + array(JobsQueueLib::PROPERTY_START_TIME), // Job properties to be updated + array(date('Y-m-d H:i:s')) // Job properties new values + ); + + $person_arr = $this->_getInputObjArray(getData($lastJobs)); + + foreach ($person_arr as $persobj) + { + if (!isset($persobj->person_id)) + $this->logError("Error when generating ESI: invalid parameters"); + else + { + $person_id = $persobj->person_id; + + // check if there already is an active ESI + $this->KennzeichenModel->addSelect('1'); + $activeKennzeichenRes = $this->KennzeichenModel->loadWhere( + array('person_id' => $person_id, 'kennzeichentyp_kurzbz' => ESIScheduler::KENNZEICHENTYP_KURZBZ, 'aktiv' => true) + ); + + if (hasData($activeKennzeichenRes)) + { + $this->logError("Active ESI for person Id $person_id already exists"); + continue; + } + + // get Matrikelnr for person for which ESI should be generated + $this->PersonModel->addSelect('matr_nr'); + $personRes = $this->PersonModel->load($person_id); + + if (!hasData($personRes)) + { + $this->logError("Person with Id $person_id not found"); + continue; + } + + $matr_nr = getData($personRes)[0]->matr_nr; + + if (isEmptyString($matr_nr)) + { + $this->logError("Matrikelnummer for person with Id $person_id is empty"); + continue; + } + + $esi = self::ESI_PREFIX.$matr_nr; + + // check if ESI was already used + $this->KennzeichenModel->addSelect('1'); + $existingKennzeichenRes = $this->KennzeichenModel->loadWhere( + array('person_id' => $person_id, 'kennzeichentyp_kurzbz' => ESIScheduler::KENNZEICHENTYP_KURZBZ, 'inhalt' => $esi) + ); + + if (hasData($existingKennzeichenRes)) + { + $this->logError("ESI $esi for person Id $person_id already exists"); + continue; + } + + // if everything ok, save the esi for the person + $saveEsiResult = $this->KennzeichenModel->insert( + array( + 'person_id' => $person_id, + 'kennzeichentyp_kurzbz' => ESIScheduler::KENNZEICHENTYP_KURZBZ, + 'inhalt' => $esi, + 'aktiv' => true, + 'insertvon' => self::INSERT_VON + ) + ); + + if (isError($saveEsiResult)) + { + $this->logError("Error when sending ESI, person Id $person_id ".getError($saveEsiResult)); + } + } + } + + // Update jobs properties values + $this->updateJobs( + getData($lastJobs), // Jobs to be updated + array(JobsQueueLib::PROPERTY_STATUS, JobsQueueLib::PROPERTY_END_TIME), // Job properties to be updated + array(JobsQueueLib::STATUS_DONE, date('Y-m-d H:i:s')) // Job properties new values + ); + + if (hasData($lastJobs)) $this->updateJobsQueue(ESIScheduler::JOB_TYPE_GENERATE_ESI, getData($lastJobs)); + } + + $this->logInfo(ESIScheduler::JOB_TYPE_GENERATE_ESI.' job stop'); + } + + // -------------------------------------------------------------------------------------------- + // Private methods + + /** + * Extracts input data from jobs. + * @param $jobs + * @return array with jobinput + */ + private function _getInputObjArray($jobs) + { + $mergedUsersArray = array(); + + if (count($jobs) == 0) return $mergedUsersArray; + + foreach ($jobs as $job) + { + $decodedInput = json_decode($job->input); + if ($decodedInput != null) + { + foreach ($decodedInput as $el) + { + $mergedUsersArray[] = $el; + } + } + } + return $mergedUsersArray; + } +} diff --git a/application/controllers/jobs/schedulers/ESIScheduler.php b/application/controllers/jobs/schedulers/ESIScheduler.php new file mode 100644 index 000000000..3ab858937 --- /dev/null +++ b/application/controllers/jobs/schedulers/ESIScheduler.php @@ -0,0 +1,108 @@ +load->model('organisation/Studiensemester_model', 'StudiensemesterModel'); + } + + //------------------------------------------------------------------------------------------------------------------ + // Public methods + + /** + * Creates jobs queue entries for generateESI job. + * @param string $studiensemester_kurzbz semester for which ESIs should be generated + */ + public function generateESI($studiensemester_kurzbz = null) + { + // if no semester given, get current studiensemester + if (!isset($studiensemester_kurzbz)) + { + $semRes = $this->StudiensemesterModel->getAkt(); + + if (hasData($semRes)) + { + $studiensemester_kurzbz = getData($semRes)[0]->studiensemester_kurzbz; + } + } + + if (isset($studiensemester_kurzbz)) + { + $this->logInfo('Start job queue scheduler '.self::JOB_TYPE_GENERATE_ESI); + + $qry = " + SELECT + DISTINCT person_id + FROM + public.tbl_person pers + JOIN public.tbl_prestudent ps USING (person_id) + JOIN public.tbl_prestudentstatus pss USING (prestudent_id) + WHERE + pss.studiensemester_kurzbz = ? + AND pers.matr_nr IS NOT NULL + AND pss.status_kurzbz IN ? + AND NOT EXISTS ( -- has no ESI yet + SELECT 1 + FROM + public.tbl_kennzeichen + WHERE + person_id = pers.person_id + AND kennzeichentyp_kurzbz = ? + AND aktiv + ) + AND NOT EXISTS ( -- making sure it's not an incoming + SELECT 1 + FROM + public.tbl_prestudentstatus + WHERE + prestudent_id = ps.prestudent_id + AND status_kurzbz = 'Incoming' + )"; + + $db = new DB_Model(); + $jobInputResult = $db->execReadOnlyQuery($qry, array($studiensemester_kurzbz, $this->_active_status_kurzbz, self::KENNZEICHENTYP_KURZBZ)); + + // If an error occured then log it + if (isError($jobInputResult)) + { + $this->logError(getError($jobInputResult)); + } + elseif (hasData($jobInputResult)) // if persons found + { + // Add the new job to the jobs queue + $addNewJobResult = $this->addNewJobsToQueue( + self::JOB_TYPE_GENERATE_ESI, // job type + $this->generateJobs( // gnerate the structure of the new job + JobsQueueLib::STATUS_NEW, + json_encode(getData($jobInputResult)) + ) + ); + + // If error occurred return it + if (isError($addNewJobResult)) $this->logError(getError($addNewJobResult)); + } + } + else + { + $this->logError('Error when getting Studiensemester'); + } + + $this->logInfo('End job queue scheduler '.self::JOB_TYPE_GENERATE_ESI); + } +} diff --git a/application/libraries/PrestudentLib.php b/application/libraries/PrestudentLib.php index 989e14585..ae4ad59c6 100644 --- a/application/libraries/PrestudentLib.php +++ b/application/libraries/PrestudentLib.php @@ -74,7 +74,7 @@ class PrestudentLib $result = $this->_ci->PrestudentstatusModel->withGrund($statusgrund_kurzbz)->insert([ 'prestudent_id' => $prestudent_id, 'status_kurzbz' => Prestudentstatus_model::STATUS_ABBRECHER, - 'studiensemester_kurzbz' => $studiensemester_kurzbz, + 'studiensemester_kurzbz' => $prestudent_status->studiensemester_kurzbz, 'ausbildungssemester' => $prestudent_status->ausbildungssemester, 'datum' => $datum, 'insertvon' => $insertvon, @@ -135,7 +135,7 @@ class PrestudentLib } //noch nicht eingetragene Zeugnisnoten auf 9 setzen - $result = $this->_ci->ZeugnisnoteModel->getZeugnisnoten($student->student_uid, $studiensemester_kurzbz); + $result = $this->_ci->ZeugnisnoteModel->getZeugnisnoten($student->student_uid, $prestudent_status->studiensemester_kurzbz); if (isError($result)) return $result; $result = getData($result) ?: []; @@ -181,7 +181,7 @@ class PrestudentLib //Studentlehrverband setzen $this->_ci->StudentlehrverbandModel->update([ - 'studiensemester_kurzbz' => $studiensemester_kurzbz, + 'studiensemester_kurzbz' => $prestudent_status->studiensemester_kurzbz, 'student_uid' => $student->student_uid ], [ 'studiengang_kz' => $student->studiengang_kz, diff --git a/application/models/education/Pruefung_model.php b/application/models/education/Pruefung_model.php index 0d6ad4158..4debc3e28 100644 --- a/application/models/education/Pruefung_model.php +++ b/application/models/education/Pruefung_model.php @@ -164,6 +164,7 @@ class Pruefung_model extends DB_Model $this->addSelect('ps.prestudent_id'); $this->addSelect('lv.bezeichnung as lvbezeichnung'); $this->addSelect('le.studiensemester_kurzbz'); + $this->addSelect('a.studierendenantrag_id'); $this->addSelect('a.typ'); $this->addSelect('campus.get_status_studierendenantrag(a.studierendenantrag_id) status'); diff --git a/application/models/person/Kennzeichen_model.php b/application/models/person/Kennzeichen_model.php new file mode 100644 index 000000000..fe8a9ac62 --- /dev/null +++ b/application/models/person/Kennzeichen_model.php @@ -0,0 +1,15 @@ +dbTable = 'public.tbl_kennzeichen'; + $this->pk = 'kennzeichen_id'; + } + +} diff --git a/application/views/lehre/lehrauftrag/acceptLehrauftrag.php b/application/views/lehre/lehrauftrag/acceptLehrauftrag.php index d018beda8..6c65559d9 100644 --- a/application/views/lehre/lehrauftrag/acceptLehrauftrag.php +++ b/application/views/lehre/lehrauftrag/acceptLehrauftrag.php @@ -142,14 +142,17 @@ $this->load->view(
- +
- p->t('dms' , 'informationsblattExterneLehrende'); ?> + p->t('ui' , 'hinweistextLehrauftrag'); ?> + + p->t('dms' , 'informationsblattExterneLehrende'); ?> +

- +
diff --git a/cis/testtool/frage.php b/cis/testtool/frage.php index 9f6cd4fb7..0aa37b299 100644 --- a/cis/testtool/frage.php +++ b/cis/testtool/frage.php @@ -148,6 +148,30 @@ echo ' alert(t("testtool/alleFragenBeantwortet")."'"?>); return true; } + + $(document).ready(function () { + $(document).bind('cut copy paste', function(e) + { + if (document.querySelector('.frage')) + { + e.preventDefault(); + } + }); + + $(document).on("keydown", function (e) + { + if (((e.ctrlKey || e.metaKey) && e.keyCode === 85) || e.keyCode === 123) + { + e.preventDefault(); + } + }); + + $(document).on("contextmenu", function (e) + { + e.preventDefault(); + }); + + }); //]]> @@ -598,7 +622,7 @@ if($frage->frage_id!='') $display_well = $frage->nummer == 0 ? '' : 'well'; // don't style frage 0 because this is always the introduction to gebiet echo ' -
+
'. $frage->text. '
diff --git a/cis/testtool/gebietfertig.php b/cis/testtool/gebietfertig.php index d8f9982d0..cf0a86ae2 100644 --- a/cis/testtool/gebietfertig.php +++ b/cis/testtool/gebietfertig.php @@ -50,9 +50,22 @@ $p = new phrasen($sprache_user); - + +




t('testtool/zeitAbgelaufen');?>

diff --git a/cis/testtool/login.php b/cis/testtool/login.php index 475ee9f00..d1944fe7a 100644 --- a/cis/testtool/login.php +++ b/cis/testtool/login.php @@ -426,6 +426,26 @@ if (isset($_POST['save']) && isset($_SESSION['prestudent_id'])) });'; ?> + $(document).bind('cut copy paste', function(e) + { + if (document.querySelector('.frage')) + { + e.preventDefault(); + } + }); + + $(document).on("keydown", function (e) + { + if (((e.ctrlKey || e.metaKey) && e.keyCode === 85) || e.keyCode === 123) + { + e.preventDefault(); + } + }); + + $(document).on("contextmenu", function (e) + { + e.preventDefault(); + }); // If Browser is any other than Mozilla Firefox and the test includes any MathML, // show message to use Mozilla Firefox var ua = navigator.userAgent; diff --git a/cis/testtool/menu.php b/cis/testtool/menu.php index 11fbc61d5..7c8b12b9d 100644 --- a/cis/testtool/menu.php +++ b/cis/testtool/menu.php @@ -414,7 +414,17 @@ else + +




t('testtool/prueflingGesperrt');?>

diff --git a/cis/testtool/topbar.php b/cis/testtool/topbar.php index 8432d4f41..7ca218ede 100644 --- a/cis/testtool/topbar.php +++ b/cis/testtool/topbar.php @@ -71,6 +71,18 @@ function changeSprache(sprache) parent.menu.location.href = parent.menu.location.pathname + '?sprache_user=' + sprache; // refreshes menu.php parent.content.location.href = parent.content.location.pathname + '?' + content_params; // refreshes login.php or frage.php } + + $(document).on("keydown", function (e) { + if (((e.ctrlKey || e.metaKey) && e.keyCode === 85) || e.keyCode === 123) + { + e.preventDefault(); + } + }); + + $(document).on("contextmenu", function (e) + { + e.preventDefault(); + }); setAlign('merge'); //Zeilenueberschriften ausgeben $headline = array('Typ der Projektarbeit','Titel der Projektarbeit','Student', - 'Note','Punkte','Beginn','Ende','Freigegeben','Gesperrt bis','Gesamtstunden','Themenbereich', + 'Note','Punkte','Beginn','Ende','Freigegeben','Gesperrt bis','Themenbereich', 'Anmerkung','Projektarbeit ID'); $i = 0; @@ -81,7 +81,7 @@ $qry = "SELECT trim(COALESCE(titelpre,'') || ' ' || COALESCE(vorname,'') || ' ' || COALESCE(nachname,'') || ' ' || COALESCE(titelpost,'')), (SELECT anmerkung FROM lehre.tbl_note WHERE note=tbl_projektarbeit.note) as anmerkung, punkte, beginn, - ende, CASE WHEN freigegeben THEN 'Ja' ELSE 'Nein' END, gesperrtbis, gesamtstunden, themenbereich, + ende, CASE WHEN freigegeben THEN 'Ja' ELSE 'Nein' END, gesperrtbis, themenbereich, tbl_projektarbeit.anmerkung, projektarbeit_id FROM lehre.tbl_projektarbeit, lehre.tbl_lehreinheit, lehre.tbl_lehrveranstaltung, diff --git a/include/mitarbeiter.class.php b/include/mitarbeiter.class.php index fb71be0eb..2802e241d 100644 --- a/include/mitarbeiter.class.php +++ b/include/mitarbeiter.class.php @@ -1086,12 +1086,33 @@ class mitarbeiter extends benutzer funktion_kurzbz='Leitung' AND (datum_von is null OR datum_von<=now()) AND (datum_bis is null OR datum_bis>=now()) AND - oe_kurzbz in (SELECT oe_kurzbz - FROM public.tbl_benutzerfunktion - WHERE + oe_kurzbz in ( + SELECT + oe_kurzbz + FROM + public.tbl_benutzerfunktion + WHERE funktion_kurzbz='oezuordnung' AND uid=".$this->db_add_param($uid)." AND (datum_von is null OR datum_von<=now()) AND (datum_bis is null OR datum_bis>=now()) + ORDER BY + ( + SELECT + 1 + FROM + hr.tbl_vertragsbestandteil_funktion + JOIN hr.tbl_vertragsbestandteil vbsfkt USING(vertragsbestandteil_id) + JOIN hr.tbl_vertragsbestandteil vbskarenz USING(dienstverhaeltnis_id) + WHERE + tbl_vertragsbestandteil_funktion.benutzerfunktion_id=tbl_benutzerfunktion.benutzerfunktion_id + AND vbskarenz.vertragsbestandteiltyp_kurzbz='karenz' + AND + ( + now()::date BETWEEN COALESCE(vbskarenz.von, '1970-01-01') AND COALESCE(vbskarenz.bis, '2170-12-31') + OR + now()::date BETWEEN COALESCE(vbskarenz.von, '1970-01-01') AND COALESCE(vbskarenz.bis, '2170-12-31') + ) + ) NULLS FIRST LIMIT 1 ) ORDER BY datum_von DESC "; @@ -1120,6 +1141,138 @@ class mitarbeiter extends benutzer return $return; } + /** + * Prueft ob eine Person im angegebenen Zeitraum Vorgesetzter von einem Mitarbeiter ist + * @param $leiter UID der zu pruefenden Leitungsposition + * @param $mitarbeiter UID der zu pruefenden Leitungsposition + * @param $datumvon Von Datum des zu pruefenden Zeitraums + * @param $datumbis BIS Datum des zu pruefenden Zeitraums + */ + public function isVorgesetzterByDate($leiter, $mitarbeiter, $datumvon, $datumbis) + { + // Alle OEs der zu pruefenden Leitungsposition holen (oes_leitung) + // Alle OEs des zu pruefenden Mitarbeiters holen (oes_mitarbeiter) + // OE-Ueberschneidungen pruefen + + $qry = " + WITH RECURSIVE + oes_leitung (oe_kurzbz, oe_parent_kurzbz, level) AS + ( + SELECT + oe_kurzbz, + oe_parent_kurzbz, + 1 as level + FROM + public.tbl_organisationseinheit + WHERE + oe_kurzbz IN ( + + -- Leitung im Zeitraum X + SELECT oe_kurzbz FROM public.tbl_benutzerfunktion + WHERE + funktion_kurzbz='Leitung' + AND uid=".$this->db_add_param($leiter)." + AND + ( + ".$this->db_add_param($datumvon)." BETWEEN COALESCE(tbl_benutzerfunktion.datum_von, '1970-01-01') AND COALESCE(tbl_benutzerfunktion.datum_bis, '2170-12-31') + OR + ".$this->db_add_param($datumbis)." BETWEEN COALESCE(tbl_benutzerfunktion.datum_von, '1970-01-01') AND COALESCE(tbl_benutzerfunktion.datum_bis, '2170-12-31') + ) + + ) + + UNION ALL + + SELECT + o.oe_kurzbz, + o.oe_parent_kurzbz, + oes_leitung.level + 1 as level + FROM + public.tbl_organisationseinheit o, oes_leitung + WHERE + o.oe_parent_kurzbz = oes_leitung.oe_kurzbz + ), + oes_mitarbeiter (oe_kurzbz, oe_parent_kurzbz, level) AS + ( + SELECT + oe_kurzbz, + oe_parent_kurzbz, + 1 as level + FROM + public.tbl_organisationseinheit + WHERE + oe_kurzbz IN ( + + -- OEZuordnung im Zeitraum X - bevorzugt nicht karenziert + SELECT oe_kurzbz FROM public.tbl_benutzerfunktion + WHERE + funktion_kurzbz='oezuordnung' + AND uid=".$this->db_add_param($mitarbeiter)." + AND ( + ".$this->db_add_param($datumvon)." BETWEEN COALESCE(tbl_benutzerfunktion.datum_von, '1970-01-01') AND COALESCE(tbl_benutzerfunktion.datum_bis, '2170-12-31') + OR + ".$this->db_add_param($datumbis)." BETWEEN COALESCE(tbl_benutzerfunktion.datum_von, '1970-01-01') AND COALESCE(tbl_benutzerfunktion.datum_bis, '2170-12-31') + ) + ORDER BY + ( + SELECT + 1 + FROM + hr.tbl_vertragsbestandteil_funktion + JOIN hr.tbl_vertragsbestandteil vbsfkt USING(vertragsbestandteil_id) + JOIN hr.tbl_vertragsbestandteil vbskarenz USING(dienstverhaeltnis_id) + WHERE + tbl_vertragsbestandteil_funktion.benutzerfunktion_id=tbl_benutzerfunktion.benutzerfunktion_id + AND vbskarenz.vertragsbestandteiltyp_kurzbz='karenz' + AND + ( + ".$this->db_add_param($datumvon)." BETWEEN COALESCE(vbskarenz.von, '1970-01-01') AND COALESCE(vbskarenz.bis, '2170-12-31') + OR + ".$this->db_add_param($datumbis)." BETWEEN COALESCE(vbskarenz.von, '1970-01-01') AND COALESCE(vbskarenz.bis, '2170-12-31') + ) + ) NULLS FIRST LIMIT 1 + + ) + + UNION ALL + + SELECT + o.oe_kurzbz, + o.oe_parent_kurzbz, + oes_mitarbeiter.level + 1 as level + FROM + public.tbl_organisationseinheit o, oes_mitarbeiter + WHERE + o.oe_kurzbz = oes_mitarbeiter.oe_parent_kurzbz + ) + SELECT + oe_kurzbz, level + FROM + oes_leitung + WHERE + oe_kurzbz in (SELECT oe_kurzbz FROM oes_mitarbeiter) + ORDER BY + oe_kurzbz, level + "; + + 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; + } + } + /** * Gibt ein Array mit den UIDs der Vorgesetzten zum Zeitpunkt des korrespondierenden Timesheets zurück * @param $uid @@ -1139,13 +1292,30 @@ class mitarbeiter extends benutzer funktion_kurzbz='Leitung' AND (datum_von is null OR datum_von<=".$this->db_add_param($date).") AND (datum_bis is null OR datum_bis>=".$this->db_add_param($date).") AND - oe_kurzbz in (SELECT oe_kurzbz - FROM public.tbl_benutzerfunktion - WHERE - funktion_kurzbz='oezuordnung' AND uid=".$this->db_add_param($uid)." AND - (datum_von is null OR (datum_von<= ".$this->db_add_param($date).")) AND - (datum_bis is null OR (datum_bis>=".$this->db_add_param($date).")) - ) + oe_kurzbz in ( + SELECT + oe_kurzbz + FROM + public.tbl_benutzerfunktion + WHERE + funktion_kurzbz='oezuordnung' AND uid=".$this->db_add_param($uid)." AND + (datum_von is null OR (datum_von<= ".$this->db_add_param($date).")) AND + (datum_bis is null OR (datum_bis>=".$this->db_add_param($date).")) + ORDER BY + ( + SELECT + 1 + FROM + hr.tbl_vertragsbestandteil_funktion + JOIN hr.tbl_vertragsbestandteil vbsfkt USING(vertragsbestandteil_id) + JOIN hr.tbl_vertragsbestandteil vbskarenz USING(dienstverhaeltnis_id) + WHERE + tbl_vertragsbestandteil_funktion.benutzerfunktion_id=tbl_benutzerfunktion.benutzerfunktion_id + AND vbskarenz.vertragsbestandteiltyp_kurzbz='karenz' + AND (vbskarenz.von <= ".$this->db_add_param($date)." OR vbskarenz.von is null) + AND (vbskarenz.bis >= ".$this->db_add_param($date)." OR vbskarenz.bis is null) + ) NULLS FIRST LIMIT 1 + ) ORDER BY datum_von DESC "; if (is_numeric($limit)) diff --git a/include/statistik.class.php b/include/statistik.class.php index a72c8bbeb..34477a548 100644 --- a/include/statistik.class.php +++ b/include/statistik.class.php @@ -512,7 +512,7 @@ class statistik extends basis_db $this->csv=''; $this->json=array(); $this->countRows=0; - set_time_limit(120); + set_time_limit(600); // In case a decryption function is used then perform password substitution $this->sql = $this->replaceSQLDecryptionPassword($this->sql); diff --git a/public/js/components/Studierendenantrag/Form/AbmeldungStgl.js b/public/js/components/Studierendenantrag/Form/AbmeldungStgl.js index 1650d3638..aafff8ac6 100644 --- a/public/js/components/Studierendenantrag/Form/AbmeldungStgl.js +++ b/public/js/components/Studierendenantrag/Form/AbmeldungStgl.js @@ -29,7 +29,8 @@ export default { switch (this.data?.status) { case 'Erstellt': return 'info'; - case 'Genehmigt': return 'success'; + case 'Genehmigt': + case 'Abgemeldet': return 'success'; default: return 'info'; } }, diff --git a/public/js/components/Studierendenantrag/Form/Wiederholung.js b/public/js/components/Studierendenantrag/Form/Wiederholung.js index c2aea93f2..c1c668ecb 100644 --- a/public/js/components/Studierendenantrag/Form/Wiederholung.js +++ b/public/js/components/Studierendenantrag/Form/Wiederholung.js @@ -37,7 +37,8 @@ export default { { case 'Erstellt': return 'info'; case 'Genehmigt': return 'success'; - case 'Verzichtet': return 'danger'; + case 'Verzichtet': + case 'Abgemeldet': return 'danger'; default: return 'info'; } }, diff --git a/rdf/lehrverbandsgruppe.rdf.php b/rdf/lehrverbandsgruppe.rdf.php index 755444b6d..4df07637a 100644 --- a/rdf/lehrverbandsgruppe.rdf.php +++ b/rdf/lehrverbandsgruppe.rdf.php @@ -85,7 +85,6 @@ if(isset($_GET['prestudent']) && $_GET['prestudent']=='false') else $berechtigt_studiengang = array_merge($berechtigt_studiengang, $berechtigung->getStgKz('assistenz')); -//var_dump($berechtigung); array_unique($berechtigt_studiengang); $stg_kz_query=''; if (count($berechtigt_studiengang)>0) @@ -382,13 +381,13 @@ function draw_orgformsubmenu($stg_kz, $orgform) $orgform_sequence[$stg_kz].= "\n\t\t\t\n"; $orgform_sequence[$stg_kz].= "\t\t\t"; - $orgform_sequence[$stg_kz].= "\n\t\t\t\tstudiensemester_kurzbz/bewerber\">\n"; + $orgform_sequence[$stg_kz].= "\n\t\t\t\tstudiensemester_kurzbz/bewerber\">\n"; $orgform_sequence[$stg_kz].= "\t\t\tstudiensemester_kurzbz/bewerber/reihungstestnichtangemeldet\" />\n"; $orgform_sequence[$stg_kz].= "\t\t\t"; $orgform_sequence[$stg_kz].= "\t\t\tstudiensemester_kurzbz/bewerber/reihungstestangemeldet\">\n"; - $orgform_sequence[$stg_kz].= "\t\t\t\tstudiensemester_kurzbz/bewerber/reihungstestangemeldet/reihungstestnichtangemeldet/teilgenommen\" />\n"; - $orgform_sequence[$stg_kz].= "\t\t\t\tstudiensemester_kurzbz/bewerber/reihungstestangemeldet/reihungstestnichtangemeldet/nichtteilgenommen\" />\n"; + $orgform_sequence[$stg_kz].= "\t\t\t\tstudiensemester_kurzbz/bewerber/reihungstestangemeldet/teilgenommen\" />\n"; + $orgform_sequence[$stg_kz].= "\t\t\t\tstudiensemester_kurzbz/bewerber/reihungstestangemeldet/nichtteilgenommen\" />\n"; $orgform_sequence[$stg_kz].= "\t\t\t\t"; $orgform_sequence[$stg_kz].= "\n\t\t\t\n"; @@ -915,7 +914,7 @@ draw_orgformpart($stg_kz); echo "\n\t\t\t\n"; echo "\t\t\t"; - echo "\t\t\t\tstudiensemester_kurzbz/bewerber\">\n"; + echo "\n\t\t\t\tstudiensemester_kurzbz/bewerber\">\n"; echo "\t\t\t\tstudiensemester_kurzbz/bewerber/reihungstestnichtangemeldet\" />\n"; echo "\t\t\t"; echo "\t\t\t\tstudiensemester_kurzbz/bewerber/reihungstestangemeldet\">\n"; diff --git a/system/dbupdate_3.4.php b/system/dbupdate_3.4.php index ac9e04f30..fb95dbf4f 100644 --- a/system/dbupdate_3.4.php +++ b/system/dbupdate_3.4.php @@ -48,12 +48,15 @@ require_once('dbupdate_3.4/30181_tabelle_anrechnung_neue_attribute_fuer_begruend require_once('dbupdate_3.4/29529_infocenter_anpassungen.php'); require_once('dbupdate_3.4/29835_uhstat1_erfassung_der_uhstat1_daten_ueber_das_bewerbungstool.php'); require_once('dbupdate_3.4/33714_erhoehter_studienbeitrag_fuer_drittsaatenangehoerig.php'); +require_once('dbupdate_3.4/36275_zeitaufzeichnung_karenz.php'); +require_once('dbupdate_3.4/21620_neues_feld_zum_erfassen_des_ESI.php'); require_once('dbupdate_3.4/17513_Entwicklungsteam.php'); // *** Pruefung und hinzufuegen der neuen Attribute und Tabellen echo '

Pruefe Tabellen und Attribute!

'; $tabellen=array( + "bis.tbl_abschluss" => array("ausbildung_code","abschluss_bez","bezeichnung","aktiv","in_oesterreich"), "bis.tbl_bisorgform" => array("bisorgform_kurzbz","code","bezeichnung"), "bis.tbl_archiv" => array("archiv_id","studiensemester_kurzbz","meldung","html","studiengang_kz","insertamum","insertvon","typ"), "bis.tbl_aufenthaltfoerderung" => array("aufenthaltfoerderung_code", "bezeichnung"), @@ -85,6 +88,7 @@ $tabellen=array( "bis.tbl_nationengruppe" => array("nationengruppe_kurzbz","nationengruppe_bezeichnung","aktiv"), "bis.tbl_oehbeitrag" => array("oehbeitrag_id","studierendenbeitrag","versicherung","von_studiensemester_kurzbz","bis_studiensemester_kurzbz","insertamum","insertvon","updateamum","updatevon"), "bis.tbl_orgform" => array("orgform_kurzbz","code","bezeichnung","rolle","bisorgform_kurzbz","bezeichnung_mehrsprachig"), + "bis.tbl_uhstat1daten" => array("uhstat1daten_id", "mutter_geburtsstaat", "mutter_bildungsstaat", "mutter_geburtsjahr", "mutter_bildungmax", "vater_geburtsstaat", "vater_bildungsstaat", "vater_geburtsjahr", "vater_bildungmax", "person_id", "insertamum", "insertvon", "updateamum", "updatevon"), "bis.tbl_verwendung" => array("verwendung_code","verwendungbez"), "bis.tbl_zgv" => array("zgv_code","zgv_bez","zgv_kurzbz","bezeichnung","aktiv"), "bis.tbl_zgvmaster" => array("zgvmas_code","zgvmas_bez","zgvmas_kurzbz","bezeichnung","aktiv"), @@ -133,6 +137,10 @@ $tabellen=array( "campus.tbl_pruefungsanmeldung" => array("pruefungsanmeldung_id","uid","pruefungstermin_id","lehrveranstaltung_id","status_kurzbz","wuensche","reihung","kommentar","statusupdatevon","statusupdateamum","anrechnung_id","pruefungstyp_kurzbz","insertamum"), "campus.tbl_pruefungsstatus" => array("status_kurzbz","bezeichnung"), "campus.tbl_reservierung" => array("reservierung_id","ort_kurzbz","studiengang_kz","uid","stunde","datum","titel","beschreibung","semester","verband","gruppe","gruppe_kurzbz","veranstaltung_id","insertamum","insertvon"), + "campus.tbl_studierendenantrag" => array("studierendenantrag_id","prestudent_id","studiensemester_kurzbz","datum","typ","insertamum","insertvon","datum_wiedereinstieg","grund","dms_id"), + "campus.tbl_studierendenantrag_lehrveranstaltung" => array("studierendenantrag_lehrveranstaltung_id","studierendenantrag_id","lehrveranstaltung_id","studiensemester_kurzbz","note","anmerkung","insertamum","insertvon"), + "campus.tbl_studierendenantrag_status" => array("studierendenantrag_status_id","studierendenantrag_id","studierendenantrag_statustyp_kurzbz","insertamum","insertvon", "grund"), + "campus.tbl_studierendenantrag_statustyp"=> array("studierendenantrag_statustyp_kurzbz","bezeichnung"), "campus.tbl_studentbeispiel" => array("student_uid","beispiel_id","vorbereitet","probleme","updateamum","updatevon","insertamum","insertvon"), "campus.tbl_studentuebung" => array("student_uid","mitarbeiter_uid","abgabe_id","uebung_id","note","mitarbeitspunkte","punkte","anmerkung","benotungsdatum","updateamum","updatevon","insertamum","insertvon"), "campus.tbl_template" => array("template_kurzbz","bezeichnung","xsd","xslt_xhtml","xslfo_pdf"), @@ -156,8 +164,12 @@ $tabellen=array( "fue.tbl_ressource" => array("ressource_id","student_uid","mitarbeiter_uid","betriebsmittel_id","firma_id","bezeichnung","beschreibung","insertamum","insertvon","updateamum","updatevon"), "fue.tbl_scrumteam" => array("scrumteam_kurzbz","bezeichnung","punkteprosprint","tasksprosprint","gruppe_kurzbz"), "fue.tbl_scrumsprint" => array("scrumsprint_id","scrumteam_kurzbz","sprint_kurzbz","sprintstart","sprintende","insertamum","insertvon","updateamum","updatevon"), + "hr.tbl_audit_log" => array("audit_log_id","mtime","action","username","table_name","diff_data","row_data"), "hr.tbl_sachaufwand" => array("sachaufwand_id","mitarbeiter_uid","sachaufwandtyp_kurzbz","dienstverhaeltnis_id","beginn","ende","anmerkung","insertamum","insertvon","updateamum","updatevon"), "hr.tbl_sachaufwandtyp" => array("sachaufwandtyp_kurzbz","bezeichnung","sort", "aktiv"), + "hr.tbl_stundensatz" => array("stundensatz_id","uid","stundensatztyp","stundensatz","oe_kurzbz","gueltig_von","gueltig_bis","insertamum","insertvon","updateamum","updatevon"), + "hr.tbl_stundensatztyp" => array("stundensatztyp","bezeichnung","aktiv","insertamum","insertvon","updateamum","updatevon"), + "hr.tbl_tmp_store" => array("tmp_store_id","typ","mitarbeiter_uid","formdata","insertvon","insertamum","updatevon","updateamum"), "hr.tbl_dienstverhaeltnis" => array("dienstverhaeltnis_id","mitarbeiter_uid","vertragsart_kurzbz","oe_kurzbz","von","bis","insertamum","insertvon","updateamum","updatevon"), "hr.tbl_vertragsart" => array("vertragsart_kurzbz","bezeichnung","anmerkung","dienstverhaeltnis","vertragsart_kurzbz_parent","aktiv","sort"), "hr.tbl_vertragsbestandteil" => array("vertragsbestandteil_id","dienstverhaeltnis_id","vertragsbestandteiltyp_kurzbz","von", "bis","insertamum", "insertvon","updateamum","updatevon"), @@ -260,6 +272,8 @@ $tabellen=array( "public.tbl_geschaeftsjahr" => array("geschaeftsjahr_kurzbz","start","ende","bezeichnung"), "public.tbl_gruppe" => array("gruppe_kurzbz","studiengang_kz","semester","bezeichnung","beschreibung","sichtbar","lehre","aktiv","sort","mailgrp","generiert","updateamum","updatevon","insertamum","insertvon","ext_id","orgform_kurzbz","gid","content_visible","gesperrt","zutrittssystem","aufnahmegruppe","direktinskription"), "public.tbl_gruppe_manager" => array("gruppe_manager_id","gruppe_kurzbz","uid","insertamum","insertvon"), + "public.tbl_kennzeichen" => array("kennzeichen_id", "person_id", "kennzeichentyp_kurzbz", "inhalt", "aktiv", "insertamum", "insertvon", "updateamum", "updatevon"), + "public.tbl_kennzeichentyp" => array("kennzeichentyp_kurzbz", "bezeichnung", "aktiv"), "public.tbl_kontakt" => array("kontakt_id","person_id","kontakttyp","anmerkung","kontakt","zustellung","updateamum","updatevon","insertamum","insertvon","ext_id","standort_id"), "public.tbl_kontaktmedium" => array("kontaktmedium_kurzbz","beschreibung"), "public.tbl_kontakttyp" => array("kontakttyp","beschreibung","bezeichnung_mehrsprachig"), @@ -292,8 +306,10 @@ $tabellen=array( "public.tbl_preoutgoing_status" => array("preoutgoing_status_kurzbz","bezeichnung"), "public.tbl_prestudent" => array("prestudent_id","aufmerksamdurch_kurzbz","person_id","studiengang_kz","berufstaetigkeit_code","ausbildungcode","zgv_code","zgvort","zgvdatum","zgvmas_code","zgvmaort","zgvmadatum","aufnahmeschluessel","facheinschlberuf","reihungstest_id","anmeldungreihungstest","reihungstestangetreten","rt_gesamtpunkte","rt_punkte1","rt_punkte2","bismelden","anmerkung","dual","insertamum","insertvon","updateamum","updatevon","ext_id","ausstellungsstaat","rt_punkte3", "zgvdoktor_code", "zgvdoktorort", "zgvdoktordatum","mentor","zgvnation","zgvmanation","zgvdoktornation","gsstudientyp_kurzbz","aufnahmegruppe_kurzbz","udf_values","priorisierung","foerderrelevant","standort_code","zgv_erfuellt","zgvmas_erfuellt","zgvdoktor_erfuellt"), "public.tbl_prestudentstatus" => array("prestudent_id","status_kurzbz","studiensemester_kurzbz","ausbildungssemester","datum","orgform_kurzbz","insertamum","insertvon","updateamum","updatevon","ext_id","studienplan_id","bestaetigtam","bestaetigtvon","fgm","faktiv", "anmerkung","bewerbung_abgeschicktamum","rt_stufe","statusgrund_id"), - "public.tbl_raumtyp" => array("raumtyp_kurzbz","beschreibung","kosten"), + "public.tbl_raumtyp" => array("raumtyp_kurzbz","beschreibung","kosten","aktiv"), "public.tbl_reihungstest" => array("reihungstest_id","studiengang_kz","ort_kurzbz","anmerkung","datum","uhrzeit","updateamum","updatevon","insertamum","insertvon","ext_id","freigeschaltet","max_teilnehmer","oeffentlich","studiensemester_kurzbz","aufnahmegruppe_kurzbz","stufe","anmeldefrist","zugangs_ueberpruefung","zugangscode"), + "public.tbl_rueckstellung" => array("rueckstellung_id","person_id","status_kurzbz","datum_bis","insertamum","insertvon"), + "public.tbl_rueckstellung_status" => array("status_kurzbz", "bezeichnung_mehrsprachig", "sort", "aktiv"), "public.tbl_rt_ort" => array("rt_id","ort_kurzbz","uid"), "public.tbl_rt_person" => array("rt_person_id","person_id","rt_id","studienplan_id","anmeldedatum","teilgenommen","ort_kurzbz","punkte","insertamum","insertvon","updateamum","updatevon"), "public.tbl_rt_studienplan" => array("reihungstest_id","studienplan_id"), diff --git a/system/dbupdate_3.4/21620_neues_feld_zum_erfassen_des_ESI.php b/system/dbupdate_3.4/21620_neues_feld_zum_erfassen_des_ESI.php new file mode 100644 index 000000000..5b6b22918 --- /dev/null +++ b/system/dbupdate_3.4/21620_neues_feld_zum_erfassen_des_ESI.php @@ -0,0 +1,146 @@ +db_query('SELECT 0 FROM public.tbl_kennzeichentyp WHERE 0 = 1')) +{ + $qry = 'CREATE TABLE public.tbl_kennzeichentyp ( + kennzeichentyp_kurzbz varchar(32) NOT NULL, + bezeichnung varchar(256) NOT NULL, + aktiv boolean NOT NULL DEFAULT TRUE + ); + + COMMENT ON TABLE public.tbl_kennzeichentyp IS \'Tabelle zur Verwaltung von Typen von externen Personenkennzeichen.\'; + COMMENT ON COLUMN public.tbl_kennzeichentyp.bezeichnung IS \'Voller Name des Kennzeichentyps.\'; + COMMENT ON COLUMN public.tbl_kennzeichentyp.aktiv IS \'Ob der Kennzeichentyp noch aktiv und verwendet wird.\'; + + ALTER TABLE public.tbl_kennzeichentyp ADD CONSTRAINT pk_tbl_kennzeichentyp PRIMARY KEY (kennzeichentyp_kurzbz)'; + + if (!$db->db_query($qry)) + echo 'public.tbl_kennzeichentyp: '.$db->db_last_error().'
'; + else + echo '
public.tbl_kennzeichentyp table created'; + + $qry = 'GRANT SELECT ON TABLE public.tbl_kennzeichentyp TO web;'; + if (!$db->db_query($qry)) + echo 'public.tbl_kennzeichentyp: '.$db->db_last_error().'
'; + else + echo '
Granted privileges to web on public.tbl_kennzeichentyp'; + + $qry = 'GRANT SELECT, UPDATE, INSERT, DELETE ON TABLE public.tbl_kennzeichentyp TO vilesci;'; + if (!$db->db_query($qry)) + echo 'public.tbl_kennzeichentyp: '.$db->db_last_error().'
'; + else + echo '
Granted privileges to vilesci on public.tbl_kennzeichentyp'; +} + +// SEQUENCE tbl_kennzeichen_id_seq +if ($result = $db->db_query("SELECT 0 FROM pg_class WHERE relname = 'tbl_kennzeichen_id_seq'")) +{ + if ($db->db_num_rows($result) == 0) + { + $qry = 'CREATE SEQUENCE public.tbl_kennzeichen_id_seq + START WITH 1 + INCREMENT BY 1 + NO MAXVALUE + NO MINVALUE + CACHE 1;'; + + if(!$db->db_query($qry)) + echo 'public.tbl_kennzeichen_id_seq '.$db->db_last_error().'
'; + else + echo '
Created sequence: public.tbl_kennzeichen_id_seq'; + + // GRANT SELECT, UPDATE ON SEQUENCE public.tbl_kennzeichen_id_seq TO vilesci; + $qry = 'GRANT SELECT, UPDATE ON SEQUENCE public.tbl_kennzeichen_id_seq TO vilesci;'; + if (!$db->db_query($qry)) + echo 'public.tbl_kennzeichen_id_seq '.$db->db_last_error().'
'; + else + echo '
Granted privileges to vilesci on public.tbl_kennzeichen_id_seq'; + + // GRANT SELECT, UPDATE ON SEQUENCE public.tbl_kennzeichen_id_seq TO fhcomplete; + $qry = 'GRANT SELECT, UPDATE ON SEQUENCE public.tbl_kennzeichen_id_seq TO fhcomplete;'; + if (!$db->db_query($qry)) + echo 'public.tbl_kennzeichen_id_seq '.$db->db_last_error().'
'; + else + echo '
Granted privileges to fhcomplete on public.tbl_kennzeichen_id_seq'; + } +} + +// Creates table public.tbl_kennzeichen if it doesn't exist and grants privileges +if (!$result = @$db->db_query('SELECT 0 FROM public.tbl_kennzeichen WHERE 0 = 1')) +{ + $qry = 'CREATE TABLE public.tbl_kennzeichen ( + kennzeichen_id integer NOT NULL DEFAULT NEXTVAL(\'public.tbl_kennzeichen_id_seq\'), + person_id integer NOT NULL, + kennzeichentyp_kurzbz varchar(32) NOT NULL, + inhalt text NOT NULL, + aktiv boolean NOT NULL DEFAULT TRUE, + insertamum timestamp DEFAULT NOW(), + insertvon varchar(32), + updateamum timestamp, + updatevon varchar(32) + ); + + COMMENT ON TABLE public.tbl_kennzeichen IS \'Tabelle zum Speichern von externen Personenkennzeichen.\'; + COMMENT ON COLUMN public.tbl_kennzeichen.kennzeichentyp_kurzbz IS \'Typ des externen Personen Kennzeichens.\'; + COMMENT ON COLUMN public.tbl_kennzeichen.inhalt IS \'Das externe Kennzeichen.\'; + COMMENT ON COLUMN public.tbl_kennzeichen.aktiv IS \'Ob das Kennzeichen noch aktiv ist und verwendet wird.\'; + + ALTER TABLE public.tbl_kennzeichen ADD CONSTRAINT pk_tbl_kennzeichen PRIMARY KEY (kennzeichen_id); + + ALTER TABLE public.tbl_kennzeichen ADD CONSTRAINT fk_kennzeichen_person FOREIGN KEY (person_id) + REFERENCES public.tbl_person(person_id) ON UPDATE CASCADE ON DELETE RESTRICT; + ALTER TABLE public.tbl_kennzeichen ADD CONSTRAINT fk_kennzeichen_kennzeichentyp_kurzbz FOREIGN KEY (kennzeichentyp_kurzbz) + REFERENCES public.tbl_kennzeichentyp(kennzeichentyp_kurzbz) ON UPDATE CASCADE ON DELETE RESTRICT; + + -- create unique constraint, no person can have the same kennzeichen twice + ALTER TABLE public.tbl_kennzeichen ADD CONSTRAINT uk_kennzeichen_person_id_inhalt UNIQUE (person_id, kennzeichentyp_kurzbz, inhalt); + -- create unique index - person can only have one active kennzeichen of each type + CREATE UNIQUE INDEX kennzeichen_aktiv_constraint ON public.tbl_kennzeichen (person_id, kennzeichentyp_kurzbz) WHERE aktiv;'; + + if (!$db->db_query($qry)) + echo 'public.tbl_kennzeichen: '.$db->db_last_error().'
'; + else + echo '
public.tbl_kennzeichen table created'; + + $qry = 'GRANT SELECT, UPDATE, INSERT, DELETE ON TABLE public.tbl_kennzeichen TO web;'; + if (!$db->db_query($qry)) + echo 'public.tbl_kennzeichen: '.$db->db_last_error().'
'; + else + echo '
Granted privileges to web on public.tbl_kennzeichen'; + + $qry = 'GRANT SELECT, UPDATE, INSERT, DELETE ON TABLE public.tbl_kennzeichen TO vilesci;'; + if (!$db->db_query($qry)) + echo 'public.tbl_kennzeichen: '.$db->db_last_error().'
'; + else + echo '
Granted privileges to vilesci on public.tbl_kennzeichen'; +} + +// public.tbl_kennzeichentyp: add type esi +if ($result = $db->db_query("SELECT 1 FROM public.tbl_kennzeichentyp WHERE kennzeichentyp_kurzbz='esi'")) +{ + if($db->db_num_rows($result)==0) + { + $qry = "INSERT INTO public.tbl_kennzeichentyp(kennzeichentyp_kurzbz, bezeichnung) VALUES('esi', 'European Student Identifier');"; + + if(!$db->db_query($qry)) + echo 'Kennzeichentyp: '.$db->db_last_error().'
'; + else + echo '
Neuer Kennzeichentyp esi in public.tbl_kennzeichentyp hinzugefügt'; + } +} + +// system.tbl_jobtypes: add type esi +if ($result = $db->db_query("SELECT 1 FROM system.tbl_jobtypes WHERE type='generateESI'")) +{ + if($db->db_num_rows($result)==0) + { + $qry = "INSERT INTO system.tbl_jobtypes(type, description) VALUES('generateESI', 'Generate and save European Student Identifier');"; + + if(!$db->db_query($qry)) + echo 'Jobtyp: '.$db->db_last_error().'
'; + else + echo '
Neuer Jobtyp generateESI in system.tbl_jobtypes hinzugefügt'; + } +} diff --git a/system/dbupdate_3.4/36275_zeitaufzeichnung_karenz.php b/system/dbupdate_3.4/36275_zeitaufzeichnung_karenz.php new file mode 100644 index 000000000..ecdbe31f5 --- /dev/null +++ b/system/dbupdate_3.4/36275_zeitaufzeichnung_karenz.php @@ -0,0 +1,16 @@ +db_query("SELECT * FROM information_schema.role_table_grants WHERE table_name='tbl_vertragsbestandteil_funktion' AND table_schema='hr' AND grantee='web' AND privilege_type='SELECT'")) +{ + if ($db->db_num_rows($result) == 0) + { + $qry = "GRANT SELECT ON hr.tbl_vertragsbestandteil_funktion TO web;"; + + if (! $db->db_query($qry)) + echo 'Vertragsbestandteil Funktion Rechte: ' . $db->db_last_error() . '
'; + else + echo 'Leserechte für Web User auf vertragsbetandteil_funktion hinzugefuegt'; + } +} diff --git a/system/phrasesupdate.php b/system/phrasesupdate.php index 289346dac..35b49d1f4 100644 --- a/system/phrasesupdate.php +++ b/system/phrasesupdate.php @@ -4408,7 +4408,7 @@ When on hold, the date is only a reminder.', ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'Procedure and terms of payment', 'description' => '', 'insertvon' => 'system' ) @@ -4424,7 +4424,7 @@ When on hold, the date is only a reminder.', 'sprache' => 'German', 'text' => 'Wir möchten Sie darauf aufmerksam machen, dass bei der Überweisung *immer* die Rechnungsnummer als Zahlungsreferenz anzuführen ist. Andernfalls erfolgt keine automatische Zahlungszuordnung und es kann zu einer Verzögerung der Darstellung des aktuellen Zahlungsstatus - der Rechnung im CIS kommen. + der Rechnung im Campus Informations-System kommen.

Im Falle dass der Betrag an ein falsches Konto überwiesen wurde, bitten wir Sie höflichst sich an Ihre Bank zu wenden. @@ -4438,7 +4438,16 @@ When on hold, the date is only a reminder.', ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'We would like to draw your attention to the fact that the invoice number must *always* be quoted as the payment reference when making a bank transfer. + Otherwise, no automatic payment allocation will take place and there may be a delay in displaying the current payment status of the invoice in Campus Informations-System. +
+
+ In the event that the amount has been transferred to an incorrect account, we kindly ask you to contact your bank. +
+
+ Each invoice is considered "paid" when the total amount has been credited to our account in full. +
+
', 'description' => '', 'insertvon' => 'system' ) @@ -4458,7 +4467,7 @@ When on hold, the date is only a reminder.', ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'FHTW account information', 'description' => '', 'insertvon' => 'system' ) @@ -4478,7 +4487,7 @@ When on hold, the date is only a reminder.', ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'All payments must be made to the following account number and the invoice number must be entered as the payment reference.', 'description' => '', 'insertvon' => 'system' ) @@ -4502,7 +4511,11 @@ When on hold, the date is only a reminder.', ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'Foreign bank transfers: +
+ In the case of foreign bank transfers, the charges are to be paid by +
+ the payer in addition to the invoice amounts.', 'description' => '', 'insertvon' => 'system' ) @@ -4522,7 +4535,7 @@ When on hold, the date is only a reminder.', ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'Invoices & payment confirmations', 'description' => '', 'insertvon' => 'system' ) @@ -4543,7 +4556,7 @@ When on hold, the date is only a reminder.', ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'Why is the deposit still outstanding despite payment?', 'description' => '', 'insertvon' => 'system' ) @@ -4565,7 +4578,9 @@ Die Transaktion und die Bearbeitung der Zahlung, kann bis zu sechs Werktage daue ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'The most common reason for this is that the invoice number is not entered as the payment reference in the bank transfer. +In this case, we kindly ask you to send an e-mail to billing@technikum-wien.at with a payment confirmation. +The transaction and processing of the payment can take up to six working days.', 'description' => '', 'insertvon' => 'system' ) @@ -4585,7 +4600,7 @@ Die Transaktion und die Bearbeitung der Zahlung, kann bis zu sechs Werktage daue ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'I have not received an invoice, what should I do?', 'description' => '', 'insertvon' => 'system' ) @@ -4606,7 +4621,8 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'In this case, please check your spam folder. If the invoice has not been sent, please inform us at billing@technikum-wien.at. +The invoice will be sent to you again. The amount is only to be transferred after receipt of the invoice!', 'description' => '', 'insertvon' => 'system' ) @@ -4626,7 +4642,7 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'Refund of the tuition fee', 'description' => '', 'insertvon' => 'system' ) @@ -4652,7 +4668,13 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'The tuition fee will not be refunded if... +-Freshmen who do not take up their study place after the start of the semester (September 1 / February 16) +-Students who discontinue their studies after the start of the semester (September 1 / February 16). + +-Interruption before 15.10. or 15.3.: tuition fees will be refunded +-Interruption after 15.10. or 15.3.: Tuition fee will not be refunded +-No tuition fees are payable in the semesters following the interruption; however, the ÖH fee must be paid in each semester of the interruption', 'description' => '', 'insertvon' => 'system' ) @@ -4672,7 +4694,7 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'You are exempt from paying tuition fees and have received an invoice for tuition fees?', 'description' => '', 'insertvon' => 'system' ) @@ -4692,7 +4714,7 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'Please contact your degree program assistant. The outstanding invoice will be canceled.', 'description' => '', 'insertvon' => 'system' ) @@ -4712,7 +4734,7 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'I made a mistake with the transfer, what should I do?', 'description' => '', 'insertvon' => 'system' ) @@ -4732,7 +4754,7 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'Please report the error to billing@technikum-wien.at.', 'description' => '', 'insertvon' => 'system' ) @@ -4752,7 +4774,7 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'An invoice has been transferred twice, what should I do?', 'description' => '', 'insertvon' => 'system' ) @@ -4772,7 +4794,7 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'If an invoice has been transferred twice, please report this to billing@technikum-wien.at. We will refund you one payment.', 'description' => '', 'insertvon' => 'system' ) @@ -4792,7 +4814,7 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'There are several items on the invoice - should a transfer be made for each item?', 'description' => '', 'insertvon' => 'system' ) @@ -4812,7 +4834,7 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'No, the total amount shown on the invoice must always be transferred.', 'description' => '', 'insertvon' => 'system' ) @@ -4832,7 +4854,7 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'When can the amount be transferred?', 'description' => '', 'insertvon' => 'system' ) @@ -4852,13 +4874,32 @@ Die Rechnung wird Ihnen erneut zugesendet. Erst nach Erhalt der Rechn ), array( 'sprache' => 'English', - 'text' => '', + 'text' => 'We would like to point out that bank transfers should only be made on receipt of the invoice. Please state the invoice number as the payment reference.', + 'description' => '', + 'insertvon' => 'system' + ) + ) + ), + array( + 'app' => 'infocenter', + 'category' => 'infocenter', + 'phrase' => 'zahlungsempfaenger', + 'insertvon' => 'system', + 'phrases' => array( + array( + 'sprache' => 'German', + 'text' => 'Fachhochschule Technikum Wien', + 'description' => '', + 'insertvon' => 'system' + ), + array( + 'sprache' => 'English', + 'text' => 'University of Applied Sciences Technikum Wien', 'description' => '', 'insertvon' => 'system' ) ) ), - array( 'app' => 'core', 'category' => 'password', @@ -24135,7 +24176,27 @@ array( 'insertvon' => 'system' ) ) - ) + ), + array( + 'app' => 'lehrauftrag', + 'category' => 'ui', + 'phrase' => 'hinweistextLehrauftrag', + 'insertvon' => 'system', + 'phrases' => array( + array( + 'sprache' => 'German', + 'text' => 'Hinweis: Das Akzeptieren von Lehraufträgen ersetzt alle vorhergehenden Lehraufträge dieses Studiensemesters.', + 'description' => '', + 'insertvon' => 'system' + ), + array( + 'sprache' => 'English', + 'text' => 'Note: Accepting teaching assignments replaces all previous teaching assignments for this study semester.', + 'description' => '', + 'insertvon' => 'system' + ) + ) + ) ); diff --git a/vilesci/stammdaten/auswertung_fhtw.php b/vilesci/stammdaten/auswertung_fhtw.php index e52235fda..aa39889cb 100644 --- a/vilesci/stammdaten/auswertung_fhtw.php +++ b/vilesci/stammdaten/auswertung_fhtw.php @@ -1081,77 +1081,6 @@ if ($punkteUebertragen) $msg_warning .= '
Der Prestudent '.$array['prestudent_id'].' hat bereits Gesamtpunkte eingetragen.'; } } - - $zuBewerberMachen = filter_input(INPUT_POST, 'zuBewerberMachen', FILTER_VALIDATE_BOOLEAN); - // Wenn zuBewerberMachen true ist, wird der Prestudent auch zum Bewerber gemacht - if ($zuBewerberMachen) - { - $prestudent = new prestudent($array['prestudent_id']); - - // Checken, ob schon Bewerberstatus vorhanden ist - if (!$prestudent->load_rolle($array['prestudent_id'], 'Bewerber', $prestudentrolle->studiensemester_kurzbz, $prestudentrolle->ausbildungssemester)) - { - // Checken, ob Abgewiesener-Status vorhanden ist - if (!$prestudent->load_rolle($array['prestudent_id'], 'Abgewiesener', $prestudentrolle->studiensemester_kurzbz, $prestudentrolle->ausbildungssemester)) - { - // Um einen Bewerberstatus zu setzen, muss "reihungstestangetreten" true sein - if ($prestudent->reihungstestangetreten == true) - { - // Um einen Bewerberstatus zu setzen, muss die ZGV ausgefüllt sein - if ($prestudent->zgv_code != '') - { - $studiengang = new studiengang($prestudent->studiengang_kz); - // Bei Mastern muss auch die ZGV-Master ausgefüllt sein - if ($studiengang->typ == 'm' && $prestudent->zgvmas_code == '') - { - $msg_error .= '
Fehler beim speichern des Bewerberstatus für Prestudent '.$array['prestudent_id'].'. Es muss zuerst eine Master-ZGV eingetragen sein.'; - } - else - { - $prestudent->new = true; - $prestudent->prestudent_id = $array['prestudent_id']; - $prestudent->status_kurzbz = 'Bewerber'; - $prestudent->studiensemester_kurzbz = $prestudentrolle->studiensemester_kurzbz; - $prestudent->ausbildungssemester = $prestudentrolle->ausbildungssemester; - $prestudent->datum = date('Y-m-d'); - $prestudent->insertamum = date('Y-m-d H:i:s'); - $prestudent->insertvon = $user; - $prestudent->orgform_kurzbz = $prestudentrolle->orgform_kurzbz; - $prestudent->bestaetigtam = ''; - $prestudent->bestaetigtvon = ''; - $prestudent->bewerbung_abgeschicktamum = ''; - $prestudent->studienplan_id = $prestudentrolle->studienplan_id; - - if (!$prestudent->save_rolle()) - { - $msg_error .= '
Fehler beim speichern des Bewerberstatus für Prestudent '.$array['prestudent_id'].': '.$prestudent->errormsg; - } - else - { - $count_success_bewerber++; - } - } - } - else - { - $msg_error .= '
Fehler beim speichern des Bewerberstatus für Prestudent '.$array['prestudent_id'].'. Es muss zuerst eine ZGV eingetragen sein.'; - } - } - else - { - $msg_error .= '
Fehler beim speichern des Bewerberstatus für Prestudent '.$array['prestudent_id'].'. Zuerst muss "Reihungstestverfahren absolviert" gesetzt sein.'; - } - } - else - { - $msg_error .= '
Fehler beim speichern des Bewerberstatus für Prestudent '.$array['prestudent_id'].'. Es ist bereits ein Abgewiesener-Status vorhanden'; - } - } - else - { - $msg_warning .= '
Der Prestudent '.$array['prestudent_id'].' hat bereits einen Bewerberstatus'; - } - } } } @@ -2440,30 +2369,7 @@ else { $("#uebertragenOptions").toggle(300); }); - - if($("#uebertragenOptionGesamtpunkte").not(":checked")) - { - $("#div_checkbox_bewerber").addClass("disabled"); - $("#div_checkbox_bewerber").find("label").addClass("text-muted"); - $("#div_checkbox_bewerber").find("label").prop("title", "Erst \"Gesamtpunkte\" und \"Reihungsverfahren absolviert\" setzen"); - $("#uebertragenOptionBewerber").prop("disabled", true); - } - $("#uebertragenOptionGesamtpunkte").on("click", function(e) - { - if($(this).is(":checked")) - { - $("#div_checkbox_bewerber").removeClass("disabled"); - $("#div_checkbox_bewerber").find("label").removeClass("text-muted"); - $("#uebertragenOptionBewerber").prop("disabled", false); - } - else - { - $("#div_checkbox_bewerber").addClass("disabled"); - $("#div_checkbox_bewerber").find("label").addClass("text-muted"); - $("#div_checkbox_bewerber").find("label").prop("title", "Erst \"Gesamtpunkte\" und \"Reihungsverfahren absolviert\" setzen"); - $("#uebertragenOptionBewerber").prop("disabled", true); - } - }); + }); function deleteResult(prestudent_id, gebiet_id, name, gebiet_bezeichnung) @@ -2859,17 +2765,11 @@ else { var prestudentPunkteArr = []; var gesamtpunkteSetzen = false; - var zuBewerberMachen = false; if ($("input.prestudentCheckbox:checked").length === 0) { alert("Bitte wählen Sie mindestens einen Eintrag aus der Liste"); return false; } - else if ($("#uebertragenOptionBewerber:checked").length === 1 && $("#uebertragenOptionGesamtpunkte:checked").length !== 1) - { - alert("Um den Bewerberstatus setzen zu können, muss \"Gesamtpunkte\" und \"Reihungsverfahren absolviert\" gesetzt sein"); - return false; - } else { $("input.prestudentCheckbox:checked").each(function() @@ -2886,15 +2786,10 @@ else { gesamtpunkteSetzen = true; } - if ($("#uebertragenOptionBewerber:checked").length === 1) - { - zuBewerberMachen = true; - } data = { prestudentPunkteArr: prestudentPunkteArr, gesamtpunkteSetzen: gesamtpunkteSetzen, - zuBewerberMachen: zuBewerberMachen, punkteUebertragen: true }; @@ -3246,8 +3141,9 @@ else
+
- +
diff --git a/vilesci/stammdaten/personen_wartung.php b/vilesci/stammdaten/personen_wartung.php index ee95854ed..d2b5c3446 100644 --- a/vilesci/stammdaten/personen_wartung.php +++ b/vilesci/stammdaten/personen_wartung.php @@ -229,7 +229,7 @@ if (isset($personToDelete) && isset($personToKeep) && $personToDelete >= 0 && $p die('Es sind bereits beide Personen in SAP vorhanden. Bitte zuerst direkt in der tbl_sap_students lösen.'); } } - + $personToDelete_obj = new person(); if ($personToDelete_obj->load($personToDelete)) { @@ -319,6 +319,199 @@ if (isset($personToDelete) && isset($personToKeep) && $personToDelete >= 0 && $p } } } + + if($result = @$db->db_query("SELECT 1 FROM public.tbl_kennzeichen LIMIT 1")) + { + $kennzeichen_has_personToKeep = array(); + $kennzeichen_has_personToDelete = array(); + + $kennzeichen_query = " + SELECT * + FROM public.tbl_kennzeichen + WHERE ( + person_id = " . $db->db_add_param($personToKeep, FHC_INTEGER) . " OR + person_id = " . $db->db_add_param($personToDelete, FHC_INTEGER) . " + ) + ORDER BY kennzeichentyp_kurzbz, aktiv DESC"; + + if ($result = $db->db_query($kennzeichen_query)) + { + while ($row = $db->db_fetch_object($result)) + { + if ($row->person_id === $personToKeep) + { + $kennzeichen_has_personToKeep[] = $row; + } + else if ($row->person_id === $personToDelete) + { + $kennzeichen_has_personToDelete[] = $row; + } + } + } + + if (!empty($kennzeichen_has_personToDelete)) + { + foreach ($kennzeichen_has_personToDelete as $kennzeichen_toDelete) + { + $kennzeichen_toKeep_Kurzbz = array_column($kennzeichen_has_personToKeep, 'kennzeichentyp_kurzbz'); + + if (in_array($kennzeichen_toDelete->kennzeichentyp_kurzbz, $kennzeichen_toKeep_Kurzbz)) + { + $kennzeichen_toKeep_Keys = array_keys($kennzeichen_toKeep_Kurzbz, $kennzeichen_toDelete->kennzeichentyp_kurzbz); + + foreach ($kennzeichen_toKeep_Keys as $key) + { + if (($kennzeichen_has_personToKeep[$key]->aktiv === 't' && $kennzeichen_toDelete->aktiv === 'f') || + ($kennzeichen_has_personToKeep[$key]->aktiv === 'f' && $kennzeichen_toDelete->aktiv === 't') || + ($kennzeichen_has_personToKeep[$key]->aktiv === 'f' && $kennzeichen_toDelete->aktiv === 'f')) + { + if ($kennzeichen_has_personToKeep[$key]->inhalt !== $kennzeichen_toDelete->inhalt) + { + $sql_query_upd1 .= "UPDATE public.tbl_kennzeichen SET person_id=" . $db->db_add_param($personToKeep, FHC_INTEGER) . " WHERE kennzeichen_id=" . $db->db_add_param($kennzeichen_toDelete->kennzeichen_id, FHC_INTEGER) . ";"; + $kennzeichen_has_personToKeep[] = $kennzeichen_toDelete; + continue 2; + } + else + { + if ($kennzeichen_toDelete->aktiv === 'f') + { + $sql_query_upd1 .= "DELETE FROM public.tbl_kennzeichen WHERE kennzeichen_id=" . $db->db_add_param($kennzeichen_toDelete->kennzeichen_id, FHC_INTEGER) . ";"; + $msg_warning[] = "Das nicht aktive Kennzeichen mit der ID '" . $kennzeichen_toDelete->kennzeichen_id . "' wurde gelöscht,
+ da es der gleiche Inhalt wie beim Kennzeichen mit der ID '". $kennzeichen_has_personToKeep[$key]->kennzeichen_id ."' ist."; + continue 2; + } + $msg_error[] = 'Beide Personen haben ein Kennzeichen mit dem gleichen Typ ('. $kennzeichen_toDelete->kennzeichentyp_kurzbz.') und den gleichen Inhalt. Können nicht zusammengelegt werden.
+ Sie müssen die Datensätze manuell bereinigen, bevor Sie die Personen zusammenlegen können.'; + $error = true; + break 2; + } + } + else if ($kennzeichen_has_personToKeep[$key]->aktiv === 't' && $kennzeichen_toDelete->aktiv === 't') + { + $msg_error[] = 'Beide Personen haben ein aktives Kennzeichen mit dem gleichen Typ ('. $kennzeichen_toDelete->kennzeichentyp_kurzbz.'). Können nicht zusammengelegt werden.
+ Sie müssen die Datensätze manuell bereinigen, bevor Sie die Personen zusammenlegen können.'; + $error = true; + break 2; + } + } + } + else + { + $sql_query_upd1 .= "UPDATE public.tbl_kennzeichen SET person_id=" . $db->db_add_param($personToKeep, FHC_INTEGER) . " WHERE kennzeichen_id=" . $db->db_add_param($kennzeichen_toDelete->kennzeichen_id, FHC_INTEGER) . ";"; + } + } + } + } + + if($result = @$db->db_query("SELECT 1 FROM bis.tbl_uhstat1daten LIMIT 1")) + { + $uhstat_has_personToKeep = array(); + $uhstat_has_personToDelete = array(); + + $uhstat_query = " + SELECT uhstat1daten_id, person_id + FROM bis.tbl_uhstat1daten + WHERE ( + person_id = " . $db->db_add_param($personToKeep, FHC_INTEGER) . " OR + person_id = " . $db->db_add_param($personToDelete, FHC_INTEGER) . " + ) + ORDER BY updateamum DESC NULLS LAST, insertamum DESC NULLS LAST"; + + // Herausfinden, ob UHSTAT Daten der löschenden oder zu belassenden Person zugeordnet sind + if ($result = $db->db_query($uhstat_query)) + { + while ($row = $db->db_fetch_object($result)) + { + if ($row->person_id === $personToKeep) + { + $uhstat_has_personToKeep[] = $row; + } + else if ($row->person_id === $personToDelete) + { + $uhstat_has_personToDelete[] = $row; + } + } + } + + // wenn UHSTAT Daten an Person, die gelöscht werden soll, hängen + if (!empty($uhstat_has_personToDelete)) + { + // Wenn es auch UHSTAT Daten für die Person, die bleibt, gibt + if (!empty($uhstat_has_personToKeep)) + { + // Unklar: welche Version der Daten soll behalten werden? + $msg_error[] = 'Beide Personen haben UHSTAT1 Daten. Können nicht zusammengelegt werden.
+ Sie müssen die Datensätze manuell bereinigen, bevor Sie die Personen zusammenlegen können:
+ zum UHSTAT von Person A + / + zum UHSTAT von Person B +
'; + + $error = true; + } + else + { + // Es gibt nur UHSTAT Daten für die zu löschende Person: Update + foreach ($uhstat_has_personToDelete as $uhstat_toDelete) + { + $sql_query_upd1 .= "UPDATE bis.tbl_uhstat1daten SET person_id=" . $db->db_add_param($personToKeep, FHC_INTEGER) . " WHERE uhstat1daten_id=" . $db->db_add_param($uhstat_toDelete->uhstat1daten_id, FHC_INTEGER) . ";"; + } + } + } + } + + if($result = @$db->db_query("SELECT 1 FROM public.tbl_rueckstellung LIMIT 1")) + { + $rueckstellung_has_personToKeep = array(); + $rueckstellung_has_personToDelete = array(); + + $rueckstellung_query = " + SELECT rueckstellung_id, person_id + FROM public.tbl_rueckstellung + WHERE ( + person_id = " . $db->db_add_param($personToKeep, FHC_INTEGER) . " OR + person_id = " . $db->db_add_param($personToDelete, FHC_INTEGER) . " + ) + ORDER BY insertamum DESC NULLS LAST"; + + // Herausfinden, ob Rueckstellung Daten der löschenden oder zu belassenden Person zugeordnet sind + if ($result = $db->db_query($rueckstellung_query)) + { + while ($row = $db->db_fetch_object($result)) + { + if ($row->person_id === $personToKeep) + { + $rueckstellung_has_personToKeep[] = $row; + } + else if ($row->person_id === $personToDelete) + { + $rueckstellung_has_personToDelete[] = $row; + } + } + } + + // wenn Rueckstellung Daten an Person, die gelöscht werden soll, hängen + if (!empty($rueckstellung_has_personToDelete)) + { + // Wenn es auch Rueckstellung Daten für die Person, die bleibt, gibt + if (!empty($rueckstellung_has_personToKeep)) + { + // Unklar: welche Version der Daten soll behalten werden? + $msg_error[] = 'Beide Personen haben Rückstellung Daten. Können nicht zusammengelegt werden.
+ Sie müssen die Datensätze manuell bereinigen, bevor Sie die Personen zusammenlegen können.'; + $error = true; + } + else + { + // Es gibt nur Rueckstellung Daten für die zu löschende Person: Update + foreach ($rueckstellung_has_personToDelete as $rueckstellung_toDelete) + { + $sql_query_upd1 .= "UPDATE public.tbl_rueckstellung SET person_id=" . $db->db_add_param($personToKeep, FHC_INTEGER) . " WHERE rueckstellung_id=" . $db->db_add_param($rueckstellung_toDelete->rueckstellung_id, FHC_INTEGER) . ";"; + } + } + } + } + if ($error == false) { // Wenn bei einer der Personen das Foto gesperrt ist, dann die Sperre uebernehmen @@ -437,7 +630,7 @@ if (isset($personToDelete) && isset($personToKeep) && $personToDelete >= 0 && $p Alte Anmerkungen: ".$personToDelete_obj->anmerkungen; $anmerkung .= " - + Zusammengelegt mit Person-ID ".$personToDelete_obj->person_id." am ".date('d.m.Y H:i:s')." von ".$uid; // Letztbenutzten Zugangscode abfragen und übernehmen @@ -1335,7 +1528,7 @@ if ($filter != '' || ($person_id_1 != '' && $person_id_2 != '')) $messageOutput .= '
'.$value; } } - echo '

' . $messageOutput . '

'; + echo '

' . $messageOutput . '

'; // Tabellen anzeigen echo '
'; diff --git a/vilesci/stammdaten/statistik_details.php b/vilesci/stammdaten/statistik_details.php index 8ad12dc0b..867766fa3 100644 --- a/vilesci/stammdaten/statistik_details.php +++ b/vilesci/stammdaten/statistik_details.php @@ -1,261 +1,279 @@ - - * Andreas Oesterreicher < andreas.oesterreicher@technikum-wien.at > - * Karl Burkhart < burkhart@technikum-wien.at > - */ -/** - * Seite zur Wartung der Statistiken - */ -require_once('../../config/vilesci.config.inc.php'); -require_once('../../include/statistik.class.php'); -require_once('../../include/benutzerberechtigung.class.php'); -require_once('../../include/berechtigung.class.php'); -require_once('../../include/functions.inc.php'); - -if(!$db = new basis_db()) -{ - die('Es konnte keine Verbindung zum Server aufgebaut werden.'); -} - -$user = get_uid(); - -$rechte = new benutzerberechtigung(); -$rechte->getBerechtigungen($user); - -if(!$rechte->isBerechtigt('basis/statistik', null, 'suid')) - die('Sie haben keine Berechtigung fuer diese Seite'); -?> - - - - Statistik - Details - - - - - - - - load($statistik_kurzbz); - } - else - { - $statistik_kurzbz = filter_input(INPUT_POST, 'statistik_kurzbz'); - $exists = false; - $statistik->berechtigung_kurzbz='addon/reports'; - } - - if(isset($_POST['save'])) - { - $statistik_kurzbz_orig = (isset($_POST['statistik_kurzbz_orig']) ? $_POST['statistik_kurzbz_orig'] : die('Statistik_kurzbz_orig fehlt')); - $bezeichnung = (isset($_POST['bezeichnung']) ? $_POST['bezeichnung'] : die('Bezeichnung fehlt')); - $url = (isset($_POST['url']) ? $_POST['url'] : die('URL fehlt')); - $sql = (isset($_POST['sql']) ? $_POST['sql'] : die('SQL fehlt')); - $gruppe = (isset($_POST['gruppe']) ? $_POST['gruppe'] : die('Gruppe fehlt')); - $content_id = (isset($_POST['content_id']) ? $_POST['content_id'] : die('ContentID fehlt')); - $publish = (isset($_POST['publish']) ? true : false); - $berechtigung_kurzbz = (isset($_POST['berechtigung_kurzbz']) ? $_POST['berechtigung_kurzbz'] : die('Berechtigungkurzbz fehlt')); - $preferences = (isset($_POST['preferences']) ? $_POST['preferences'] : die('preferences fehlt')); - - if(!$exists) - { - $statistik->insertamum = date('Y-m-d H:i:s'); - $statistik->insertvon = $user; - $statistik->new = true; - } - - $statistik->statistik_kurzbz = $statistik_kurzbz; - $statistik->statistik_kurzbz_orig = $statistik_kurzbz_orig; - $statistik->bezeichnung = $bezeichnung; - $statistik->url = $url; - $statistik->sql = $sql; - $statistik->gruppe = $gruppe; - $statistik->content_id = $content_id; - $statistik->publish = $publish; - $statistik->updateamum = date('Y-m-d H:i:s'); - $statistik->updatevon = $user; - $statistik->berechtigung_kurzbz = $berechtigung_kurzbz; - $statistik->preferences = $preferences; - - // Check if the SQL string contains functions to decrypt data and if there are - // variables to replace the value of the password (no clear password wanted!) - if (isSQLDecryptionValid($statistik->sql)) - { - $success = $statistik->save(); - - if($success): - ?> - Daten erfolgreich gespeichert - - - errormsg ?> - - - preferences); - - if(empty($preferences)) - { - $statistik->preferences = << - -
- new === false): ?> - Bearbeiten - - - Neu - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
KurzbzGruppe
BezeichnungContentID - content_id)): ?> - -  ContentID content_id?> bearbeiten - - - -
URLBerechtigung - getBerechtigungen(); - ?> - -
SQL
Publishpublish ? 'checked="checked"' : '' ?>>
Preferences
-
-
- -
- - - + + * Andreas Oesterreicher < andreas.oesterreicher@technikum-wien.at > + * Karl Burkhart < burkhart@technikum-wien.at > + */ +/** + * Seite zur Wartung der Statistiken + */ +require_once('../../config/vilesci.config.inc.php'); +require_once('../../include/statistik.class.php'); +require_once('../../include/benutzerberechtigung.class.php'); +require_once('../../include/berechtigung.class.php'); +require_once('../../include/functions.inc.php'); + +if(!$db = new basis_db()) +{ + die('Es konnte keine Verbindung zum Server aufgebaut werden.'); +} + +$user = get_uid(); + +$rechte = new benutzerberechtigung(); +$rechte->getBerechtigungen($user); + +if(!$rechte->isBerechtigt('basis/statistik', null, 'suid')) + die('Sie haben keine Berechtigung fuer diese Seite'); +?> + + + + Statistik - Details + + + + + + + + load($statistik_kurzbz); + } + else + { + $statistik_kurzbz = filter_input(INPUT_POST, 'statistik_kurzbz'); + $exists = false; + $statistik->berechtigung_kurzbz='addon/reports'; + } + + if(isset($_POST['save'])) + { + $statistik_kurzbz_orig = (isset($_POST['statistik_kurzbz_orig']) ? $_POST['statistik_kurzbz_orig'] : die('Statistik_kurzbz_orig fehlt')); + $bezeichnung = (isset($_POST['bezeichnung']) ? $_POST['bezeichnung'] : die('Bezeichnung fehlt')); + $url = (isset($_POST['url']) ? $_POST['url'] : die('URL fehlt')); + $sql = (isset($_POST['sql']) ? $_POST['sql'] : die('SQL fehlt')); + $gruppe = (isset($_POST['gruppe']) ? $_POST['gruppe'] : die('Gruppe fehlt')); + $content_id = (isset($_POST['content_id']) ? $_POST['content_id'] : die('ContentID fehlt')); + $publish = (isset($_POST['publish']) ? true : false); + $berechtigung_kurzbz = (isset($_POST['berechtigung_kurzbz']) ? $_POST['berechtigung_kurzbz'] : die('Berechtigungkurzbz fehlt')); + $preferences = (isset($_POST['preferences']) ? $_POST['preferences'] : die('preferences fehlt')); + + if(!$exists) + { + $statistik->insertamum = date('Y-m-d H:i:s'); + $statistik->insertvon = $user; + $statistik->new = true; + } + + $statistik->statistik_kurzbz = $statistik_kurzbz; + $statistik->statistik_kurzbz_orig = $statistik_kurzbz_orig; + $statistik->bezeichnung = $bezeichnung; + $statistik->url = $url; + $statistik->sql = $sql; + $statistik->gruppe = $gruppe; + $statistik->content_id = $content_id; + $statistik->publish = $publish; + $statistik->updateamum = date('Y-m-d H:i:s'); + $statistik->updatevon = $user; + $statistik->berechtigung_kurzbz = $berechtigung_kurzbz; + $statistik->preferences = $preferences; + + // Check if the SQL string contains functions to decrypt data and if there are + // variables to replace the value of the password (no clear password wanted!) + if (isSQLDecryptionValid($statistik->sql)) + { + $success = $statistik->save(); + + if($success): + ?> + Daten erfolgreich gespeichert + + + errormsg ?> + + + preferences); + + if(empty($preferences)) + { + $statistik->preferences = << +
+
+ new === false): ?> + Bearbeiten - + + Neu + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
KurzbzGruppe
BezeichnungContentID + content_id)): ?> + +  ContentID content_id?> bearbeiten + + + +
URLBerechtigung + getBerechtigungen(); + ?> + +
SQL
Publishpublish ? 'checked="checked"' : '' ?>>
Preferences
+
+
+ +
+
+ +