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/config/PluginConfiguration.java | 16 +++++++- .../java/DNPM/database/ReadOnlyRepository.java | 20 +++++++++ .../java/DNPM/database/SettingsRepository.java | 14 +++++++ src/main/java/DNPM/services/SettingsService.java | 47 ++++++++++++++++++++++ .../DNPM/services/TherapieplanServiceFactory.java | 14 ++++--- src/main/java/de/itc/db/dnpm/Setting.java | 43 ++++++++++++++++++++ 6 files changed, 147 insertions(+), 7 deletions(-) create mode 100644 src/main/java/DNPM/database/ReadOnlyRepository.java create mode 100644 src/main/java/DNPM/database/SettingsRepository.java create mode 100644 src/main/java/DNPM/services/SettingsService.java create mode 100644 src/main/java/de/itc/db/dnpm/Setting.java (limited to 'src/main') diff --git a/src/main/java/DNPM/config/PluginConfiguration.java b/src/main/java/DNPM/config/PluginConfiguration.java index 36b1875..825c57c 100644 --- a/src/main/java/DNPM/config/PluginConfiguration.java +++ b/src/main/java/DNPM/config/PluginConfiguration.java @@ -1,10 +1,12 @@ package DNPM.config; +import DNPM.database.SettingsRepository; import DNPM.services.*; import de.itc.onkostar.api.IOnkostarApi; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; +import org.springframework.data.jpa.repository.config.EnableJpaRepositories; import javax.sql.DataSource; @@ -15,6 +17,7 @@ import javax.sql.DataSource; */ @Configuration @ComponentScan(basePackages = "DNPM.analyzer") +@EnableJpaRepositories(basePackages = "DNPM.database") public class PluginConfiguration { @Bean @@ -28,8 +31,17 @@ public class PluginConfiguration { } @Bean - public TherapieplanServiceFactory therapieplanServiceFactory(final IOnkostarApi onkostarApi, final FormService formService) { - return new TherapieplanServiceFactory(onkostarApi, formService); + public SettingsService settingsService(final SettingsRepository settingsRepository) { + return new SettingsService(settingsRepository); + } + + @Bean + public TherapieplanServiceFactory therapieplanServiceFactory( + final IOnkostarApi onkostarApi, + final SettingsService settingsService, + final FormService formService + ) { + return new TherapieplanServiceFactory(onkostarApi, settingsService, formService); } } diff --git a/src/main/java/DNPM/database/ReadOnlyRepository.java b/src/main/java/DNPM/database/ReadOnlyRepository.java new file mode 100644 index 0000000..775388d --- /dev/null +++ b/src/main/java/DNPM/database/ReadOnlyRepository.java @@ -0,0 +1,20 @@ +package DNPM.database; + +import org.springframework.data.repository.NoRepositoryBean; +import org.springframework.data.repository.Repository; + +import java.io.Serializable; +import java.util.List; + +/** + * Basis-Repository for ReadOnly Spring-Data-JPA Repositories + *
Entity-Klassen müssen in Package de.itc.db.dnpm liegen
+ * @param 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 OptionalOptional
+ * @return Optional mit Wert der SID
+ */
+ public Optionalmehrere_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();
}
diff --git a/src/main/java/de/itc/db/dnpm/Setting.java b/src/main/java/de/itc/db/dnpm/Setting.java
new file mode 100644
index 0000000..262d2c9
--- /dev/null
+++ b/src/main/java/de/itc/db/dnpm/Setting.java
@@ -0,0 +1,43 @@
+package de.itc.db.dnpm;
+
+import org.hibernate.annotations.Immutable;
+
+import javax.persistence.Column;
+import javax.persistence.Entity;
+import javax.persistence.Id;
+import javax.persistence.Table;
+
+@Entity
+@Immutable
+@Table(name = "einstellung")
+public class Setting {
+ @Id
+ private Long id;
+
+ private String name;
+
+ @Column(name = "wert")
+ private String value;
+
+ protected Setting() {
+ // No content
+ }
+
+ public Setting(Long id, String name, String value) {
+ this.id = id;
+ this.name = name;
+ this.value = value;
+ }
+
+ public Long getId() {
+ return id;
+ }
+
+ public String getName() {
+ return name;
+ }
+
+ public String getValue() {
+ return value;
+ }
+}
--
cgit v1.2.3