1
0
mirror of https://github.com/pcvolkmer/onkostar-plugin-dnpm.git synced 2025-07-03 17:52:53 +00:00

Etwas Codebereinigung in Klasse ConsentManager

This commit is contained in:
2023-03-16 22:30:58 +01:00
parent 038328a3cc
commit 2e7d71069f

View File

@ -1,15 +1,5 @@
package DNPM; package DNPM;
import java.util.List;
import java.util.Map;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.transform.Transformers;
import org.hibernate.type.StandardBasicTypes;
import org.springframework.beans.factory.annotation.Autowired;
import de.itc.onkostar.api.Disease; import de.itc.onkostar.api.Disease;
import de.itc.onkostar.api.IOnkostarApi; import de.itc.onkostar.api.IOnkostarApi;
import de.itc.onkostar.api.Item; import de.itc.onkostar.api.Item;
@ -17,9 +7,22 @@ import de.itc.onkostar.api.Procedure;
import de.itc.onkostar.api.analysis.AnalyzerRequirement; import de.itc.onkostar.api.analysis.AnalyzerRequirement;
import de.itc.onkostar.api.analysis.IProcedureAnalyzer; import de.itc.onkostar.api.analysis.IProcedureAnalyzer;
import de.itc.onkostar.api.analysis.OnkostarPluginType; import de.itc.onkostar.api.analysis.OnkostarPluginType;
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 org.springframework.beans.factory.annotation.Autowired;
import java.util.List;
import java.util.Map;
public class ConsentManager implements IProcedureAnalyzer { public class ConsentManager implements IProcedureAnalyzer {
private final Logger logger = LoggerFactory.getLogger(this.getClass());
@Autowired @Autowired
private IOnkostarApi onkostarApi; private IOnkostarApi onkostarApi;
@ -65,26 +68,25 @@ public class ConsentManager implements IProcedureAnalyzer {
} }
@Override @Override
public void analyze(Procedure Prozedur, Disease Erkrankung) { public void analyze(Procedure prozedur, Disease erkrankung) {
int value = 0; int value = 0;
try { try {
SessionFactory sessionFactory = onkostarApi.getSessionFactory(); SessionFactory sessionFactory = onkostarApi.getSessionFactory();
Session session = sessionFactory.getCurrentSession(); Session session = sessionFactory.getCurrentSession();
// geänderte Werte checken // geänderte Werte checken
String sql1 = "select id, max(timestamp) AS datum from aenderungsprotokoll where entity_id = '" + Prozedur.getId() + "'"; String sql1 = "select id, max(timestamp) AS datum from aenderungsprotokoll where entity_id = '" + prozedur.getId() + "'";
SQLQuery query1 = session.createSQLQuery(sql1) SQLQuery query1 = session.createSQLQuery(sql1)
.addScalar("id", StandardBasicTypes.INTEGER) .addScalar("id", StandardBasicTypes.INTEGER)
.addScalar("datum", StandardBasicTypes.TIMESTAMP); .addScalar("datum", StandardBasicTypes.TIMESTAMP);
System.out.println(query1.uniqueResult().toString()); System.out.println(query1.uniqueResult().toString());
try {
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 " + 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 " + "FROM prozedur " +
"LEFT JOIN data_form_data_catalogue ON data_form_data_catalogue.data_form_id = prozedur.data_form_id " + "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_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_catalogue ON data_catalogue.id = data_catalogue_entry.data_catalogue_id " +
"LEFT JOIN data_form ON data_form.id = prozedur.data_form_id " + "LEFT JOIN data_form ON data_form.id = prozedur.data_form_id " +
"WHERE patient_id = " + Prozedur.getPatientId() + " " + "WHERE patient_id = " + prozedur.getPatientId() + " " +
"AND geloescht = 0 " + "AND geloescht = 0 " +
"AND data_catalogue_entry.type = 'formReference' " + "AND data_catalogue_entry.type = 'formReference' " +
"GROUP BY prozedur.id, prozedur.data_form_id, data_catalogue.name, data_catalogue_entry.name"; "GROUP BY prozedur.id, prozedur.data_form_id, data_catalogue.name, data_catalogue_entry.name";
@ -98,8 +100,10 @@ public class ConsentManager implements IProcedureAnalyzer {
.addScalar("datum", StandardBasicTypes.DATE); .addScalar("datum", StandardBasicTypes.DATE);
query.setResultTransformer(Transformers.aliasToBean(VerweisVon.class)); query.setResultTransformer(Transformers.aliasToBean(VerweisVon.class));
@SuppressWarnings("unchecked")
List<VerweisVon> result = query.list(); List<VerweisVon> result = query.list();
try {
for (VerweisVon var : result) { for (VerweisVon var : result) {
sql = var.getSQL(); sql = var.getSQL();
query = session.createSQLQuery(sql) query = session.createSQLQuery(sql)
@ -107,44 +111,36 @@ public class ConsentManager implements IProcedureAnalyzer {
if (query.uniqueResult() != null) { if (query.uniqueResult() != null) {
value = (Integer) query.uniqueResult(); value = (Integer) query.uniqueResult();
} }
if (value == Prozedur.getId()) { if (value == prozedur.getId()) {
Procedure andereprozedur = onkostarApi.getProcedure(var.getProcedure_id()); Procedure andereprozedur = onkostarApi.getProcedure(var.getProcedure_id());
try { try {
Map<String, Item> Felder = Prozedur.getAllValues(); Map<String, Item> felder = prozedur.getAllValues();
for (Map.Entry<String, Item> Feld: Felder.entrySet()) { for (Map.Entry<String, Item> feld : felder.entrySet()) {
if (Feld.getKey().length() > 6 && Feld.getKey().substring(0, 7).equals("Consent")) { if (feld.getKey().startsWith("Consent")) {
if (Feld.getKey().equals("ConsentStatusEinwilligungDNPM")) { if (feld.getKey().equals("ConsentStatusEinwilligungDNPM")) {
switch (Feld.getValue().getValue().toString()) { switch (feld.getValue().getValue().toString()) {
case "z": case "z":
andereprozedur.setValue(Feld.getKey(), new Item(Feld.getKey(), "active")); andereprozedur.setValue(feld.getKey(), new Item(feld.getKey(), "active"));
break; break;
case "a": case "a":
andereprozedur.setValue(Feld.getKey(), new Item(Feld.getKey(), "rejected"));
break;
case "w": case "w":
andereprozedur.setValue(Feld.getKey(), new Item(Feld.getKey(), "rejected")); andereprozedur.setValue(feld.getKey(), new Item(feld.getKey(), "rejected"));
break; break;
} }
} else { } else {
andereprozedur.setValue(Feld.getKey(), Prozedur.getValue(Feld.getKey())); andereprozedur.setValue(feld.getKey(), prozedur.getValue(feld.getKey()));
} }
} }
} }
onkostarApi.saveProcedure(andereprozedur); onkostarApi.saveProcedure(andereprozedur);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); logger.error("Kann Prozedur nicht speichern", e);
} }
value = 0; value = 0;
} }
} }
} catch (Exception e) { } catch (RuntimeException e) {
e.printStackTrace(); logger.error("Sonstiger Fehler bei der Ausführung von analyze()", e);
}
} catch (Exception e) {
System.out.println(e.getMessage());
}
} catch (Exception e) {
System.out.println(e.getMessage());
} }
} }