summaryrefslogtreecommitdiff
path: root/src/main/java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java')
-rw-r--r--src/main/java/DNPM/ConsentManager.java7
-rw-r--r--src/main/java/DNPM/services/consent/ConsentManagerService.java9
-rw-r--r--src/main/java/DNPM/services/consent/MrConsentManagerService.java7
-rw-r--r--src/main/java/DNPM/services/consent/UkwConsentManagerService.java5
4 files changed, 26 insertions, 2 deletions
diff --git a/src/main/java/DNPM/ConsentManager.java b/src/main/java/DNPM/ConsentManager.java
index 3eca56b..e78dedd 100644
--- a/src/main/java/DNPM/ConsentManager.java
+++ b/src/main/java/DNPM/ConsentManager.java
@@ -69,7 +69,12 @@ public class ConsentManager implements IProcedureAnalyzer {
@Override
public void analyze(Procedure prozedur, Disease erkrankung) {
- consentManagerServiceFactory.currentUsableInstance().applyConsent(prozedur);
+ var consentManagerService = consentManagerServiceFactory.currentUsableInstance();
+ if (! consentManagerService.canApply(prozedur)) {
+ logger.error("Fehler im ConsentManagement: Kann Prozedur mit Formularnamen '{}' nicht anwenden", prozedur.getFormName());
+ return;
+ }
+ consentManagerService.applyConsent(prozedur);
}
}
diff --git a/src/main/java/DNPM/services/consent/ConsentManagerService.java b/src/main/java/DNPM/services/consent/ConsentManagerService.java
index 9e2d0fa..c05ad6b 100644
--- a/src/main/java/DNPM/services/consent/ConsentManagerService.java
+++ b/src/main/java/DNPM/services/consent/ConsentManagerService.java
@@ -15,4 +15,13 @@ public interface ConsentManagerService {
*/
void applyConsent(Procedure procedure);
+ /**
+ * Optionale Prüfung, ob die angegebene Prozedur angewendet werden kann.
+ * @param procedure Anzuwendende Prozedur
+ * @return Gibt <code>true</code> zurück, wenn die Prozedur angewendet werden kann.
+ */
+ default boolean canApply(Procedure procedure) {
+ return null != procedure;
+ }
+
}
diff --git a/src/main/java/DNPM/services/consent/MrConsentManagerService.java b/src/main/java/DNPM/services/consent/MrConsentManagerService.java
index bf054b4..20ee4db 100644
--- a/src/main/java/DNPM/services/consent/MrConsentManagerService.java
+++ b/src/main/java/DNPM/services/consent/MrConsentManagerService.java
@@ -22,7 +22,7 @@ import java.util.Map;
*/
public class MrConsentManagerService implements ConsentManagerService {
- private Logger logger = LoggerFactory.getLogger(this.getClass());
+ private final Logger logger = LoggerFactory.getLogger(this.getClass());
private final IOnkostarApi onkostarApi;
@@ -30,6 +30,11 @@ public class MrConsentManagerService implements ConsentManagerService {
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
*
diff --git a/src/main/java/DNPM/services/consent/UkwConsentManagerService.java b/src/main/java/DNPM/services/consent/UkwConsentManagerService.java
index c22a6e4..c539e5a 100644
--- a/src/main/java/DNPM/services/consent/UkwConsentManagerService.java
+++ b/src/main/java/DNPM/services/consent/UkwConsentManagerService.java
@@ -23,6 +23,11 @@ public class UkwConsentManagerService implements ConsentManagerService {
this.onkostarApi = onkostarApi;
}
+ @Override
+ public boolean canApply(Procedure procedure) {
+ return null != procedure && procedure.getFormName().equals("Excel-Formular");
+ }
+
/**
* Wende Consent an, wenn dieses Consent-Formular gespeichert wird
*