mirror of
https://github.com/pcvolkmer/onkostar-plugin-dnpm.git
synced 2025-07-01 17:02:53 +00:00
151 lines
6.7 KiB
Java
151 lines
6.7 KiB
Java
/*
|
|
* This file is part of onkostar-plugin-dnpm
|
|
*
|
|
* Copyright (c) 2025 the original author or authors.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in all
|
|
* copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
* SOFTWARE.
|
|
*/
|
|
|
|
package dev.dnpm.services.consent;
|
|
|
|
import dev.dnpm.VerweisVon;
|
|
import de.itc.onkostar.api.IOnkostarApi;
|
|
import de.itc.onkostar.api.Item;
|
|
import de.itc.onkostar.api.Procedure;
|
|
import org.hibernate.SQLQuery;
|
|
import org.hibernate.Session;
|
|
import org.hibernate.SessionFactory;
|
|
import org.hibernate.transform.Transformers;
|
|
import org.hibernate.type.StandardBasicTypes;
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
|
|
/**
|
|
* Detailimplementierung für das Formular `MR.Consent`
|
|
*
|
|
* @since 0.2.0
|
|
*/
|
|
public class MrConsentManagerService implements ConsentManagerService {
|
|
|
|
private final Logger logger = LoggerFactory.getLogger(this.getClass());
|
|
|
|
private final IOnkostarApi onkostarApi;
|
|
|
|
public MrConsentManagerService(final IOnkostarApi onkostarApi) {
|
|
this.onkostarApi = onkostarApi;
|
|
}
|
|
|
|
@Override
|
|
public boolean canApply(Procedure procedure) {
|
|
return null != procedure && procedure.getFormName().equals("MR.Consent");
|
|
}
|
|
|
|
/**
|
|
* Wende Consent an, wenn dieses Consent-Formular gespeichert wird
|
|
*
|
|
* @param procedure Prozedur des Consent-Formulars
|
|
*/
|
|
@Override
|
|
public void applyConsent(Procedure procedure) {
|
|
int value = 0;
|
|
try {
|
|
SessionFactory sessionFactory = onkostarApi.getSessionFactory();
|
|
Session session = sessionFactory.getCurrentSession();
|
|
// geänderte Werte checken
|
|
String sql1 = "select id, max(timestamp) AS datum from aenderungsprotokoll where entity_id = '" + procedure.getId() + "'";
|
|
SQLQuery query1 = session.createSQLQuery(sql1)
|
|
.addScalar("id", StandardBasicTypes.INTEGER)
|
|
.addScalar("datum", StandardBasicTypes.TIMESTAMP);
|
|
logger.info("Wert-Check: {}", query1.uniqueResult());
|
|
|
|
String sql = "SELECT prozedur.id AS procedure_id, prozedur.data_form_id, data_catalogue.name AS data_catalogue, data_catalogue_entry.name AS data_catalogue_entry, data_form.description AS formname, prozedur.beginndatum AS datum " +
|
|
"FROM prozedur " +
|
|
"LEFT JOIN data_form_data_catalogue ON data_form_data_catalogue.data_form_id = prozedur.data_form_id " +
|
|
"LEFT JOIN data_catalogue_entry ON data_catalogue_entry.data_catalogue_id = data_form_data_catalogue.data_catalogue_id " +
|
|
"LEFT JOIN data_catalogue ON data_catalogue.id = data_catalogue_entry.data_catalogue_id " +
|
|
"LEFT JOIN data_form ON data_form.id = prozedur.data_form_id " +
|
|
"WHERE patient_id = " + procedure.getPatientId() + " " +
|
|
"AND geloescht = 0 " +
|
|
"AND data_catalogue_entry.type = 'formReference' " +
|
|
"GROUP BY prozedur.id, prozedur.data_form_id, data_catalogue.name, data_catalogue_entry.name";
|
|
|
|
SQLQuery query = session.createSQLQuery(sql)
|
|
.addScalar("procedure_id", StandardBasicTypes.INTEGER)
|
|
.addScalar("data_form_id", StandardBasicTypes.INTEGER)
|
|
.addScalar("data_catalogue", StandardBasicTypes.STRING)
|
|
.addScalar("data_catalogue_entry", StandardBasicTypes.STRING)
|
|
.addScalar("formname", StandardBasicTypes.STRING)
|
|
.addScalar("datum", StandardBasicTypes.DATE);
|
|
|
|
query.setResultTransformer(Transformers.aliasToBean(VerweisVon.class));
|
|
|
|
@SuppressWarnings("unchecked")
|
|
List<VerweisVon> result = query.list();
|
|
|
|
for (VerweisVon verweisVon : result) {
|
|
sql = verweisVon.getSQL();
|
|
query = session.createSQLQuery(sql)
|
|
.addScalar("value", StandardBasicTypes.INTEGER);
|
|
if (query.uniqueResult() != null) {
|
|
value = (Integer) query.uniqueResult();
|
|
}
|
|
if (value == procedure.getId()) {
|
|
saveReferencedProcedure(procedure, verweisVon);
|
|
value = 0;
|
|
}
|
|
}
|
|
} catch (RuntimeException e) {
|
|
logger.error("Sonstiger Fehler bei der Ausführung von analyze()", e);
|
|
}
|
|
}
|
|
|
|
private void saveReferencedProcedure(Procedure prozedur, VerweisVon verweisVon) {
|
|
Procedure andereprozedur = onkostarApi.getProcedure(verweisVon.getProcedure_id());
|
|
try {
|
|
Map<String, Item> felder = prozedur.getAllValues();
|
|
for (Map.Entry<String, Item> feld : felder.entrySet()) {
|
|
if (feld.getKey().startsWith("Consent")) {
|
|
if (feld.getKey().equals("ConsentStatusEinwilligungDNPM")) {
|
|
switch (feld.getValue().getValue().toString()) {
|
|
case "z":
|
|
andereprozedur.setValue(feld.getKey(), new Item(feld.getKey(), "active"));
|
|
break;
|
|
case "a":
|
|
case "w":
|
|
andereprozedur.setValue(feld.getKey(), new Item(feld.getKey(), "rejected"));
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
} else {
|
|
andereprozedur.setValue(feld.getKey(), prozedur.getValue(feld.getKey()));
|
|
}
|
|
}
|
|
}
|
|
onkostarApi.saveProcedure(andereprozedur);
|
|
} catch (Exception e) {
|
|
logger.error("Kann Prozedur nicht speichern", e);
|
|
}
|
|
}
|
|
|
|
}
|