From ef5c91a352788a2ad84afa18fa0c7cdadec70ed8 Mon Sep 17 00:00:00 2001
From: Paul-Christian Volkmer
Date: Mon, 20 Mar 2023 14:07:00 +0100
Subject: Issue #11: Service und Spring Data JPA Repository für
Systemeinstellungen
---
src/main/java/DNPM/services/SettingsService.java | 47 ++++++++++++++++++++++
.../DNPM/services/TherapieplanServiceFactory.java | 14 ++++---
2 files changed, 56 insertions(+), 5 deletions(-)
create mode 100644 src/main/java/DNPM/services/SettingsService.java
(limited to 'src/main/java/DNPM/services')
diff --git a/src/main/java/DNPM/services/SettingsService.java b/src/main/java/DNPM/services/SettingsService.java
new file mode 100644
index 0000000..b07a2f3
--- /dev/null
+++ b/src/main/java/DNPM/services/SettingsService.java
@@ -0,0 +1,47 @@
+package DNPM.services;
+
+import DNPM.database.SettingsRepository;
+
+import java.util.Optional;
+
+/**
+ * Implementiert den Dienst zur Ermittlung von Systemeinstellungen
+ */
+public class SettingsService {
+
+ private final SettingsRepository settingsRepository;
+
+ public SettingsService(final SettingsRepository settingsRepository) {
+ this.settingsRepository = settingsRepository;
+ }
+
+ /**
+ * Übergibt ein Optional für die Einstellung mit angegebenen Namen
+ * @param name Name der Einstellung
+ * @return Optional mit Wert der Einstellung oder ein leeres Optional, wenn Einstellung nicht gefunden
+ */
+ public Optional getSetting(String name) {
+ var sid = settingsRepository.findByName(name);
+ if (null == sid) {
+ return Optional.empty();
+ }
+ return Optional.of(sid.getValue());
+ }
+
+ /**
+ * Übergibt die SID als Optional
+ * @return Optional mit Wert der SID
+ */
+ public Optional getSID() {
+ return getSetting("SID");
+ }
+
+ /**
+ * Übergibt die Einstellung für mehrere_mtb_in_mtbepisode
+ * @return Übergibt true, wenn mehrere_mtb_in_mtbepisode auf "Ja" gesetzt ist.
+ */
+ public boolean multipleMtbsInMtbEpisode() {
+ var setting = getSetting("SID");
+ return setting.isPresent() && setting.get().equals("true");
+ }
+}
diff --git a/src/main/java/DNPM/services/TherapieplanServiceFactory.java b/src/main/java/DNPM/services/TherapieplanServiceFactory.java
index 5b3b54c..0b64410 100644
--- a/src/main/java/DNPM/services/TherapieplanServiceFactory.java
+++ b/src/main/java/DNPM/services/TherapieplanServiceFactory.java
@@ -6,18 +6,22 @@ public class TherapieplanServiceFactory {
private final IOnkostarApi onkostarApi;
+ private final SettingsService settingsService;
+
private final FormService formService;
- public TherapieplanServiceFactory(IOnkostarApi onkostarApi, FormService formService) {
+ public TherapieplanServiceFactory(
+ final IOnkostarApi onkostarApi,
+ final SettingsService settingsService,
+ final FormService formService
+ ) {
this.onkostarApi = onkostarApi;
+ this.settingsService = settingsService;
this.formService = formService;
}
public TherapieplanService currentUsableInstance() {
- if (
- null != onkostarApi.getGlobalSetting("mehrere_mtb_in_mtbepisode")
- && onkostarApi.getGlobalSetting("mehrere_mtb_in_mtbepisode").equals("true")
- ) {
+ if (settingsService.multipleMtbsInMtbEpisode()) {
return new MultipleMtbTherapieplanService();
}
--
cgit v1.2.3