TMP
[demos/kafka/chat] / src / main / java / de / juplo / kafka / chat / backend / ChatBackendApplication.java
index dbd707e..d980dd3 100644 (file)
@@ -5,20 +5,19 @@ import de.juplo.kafka.chat.backend.implementation.StorageStrategy;
 import jakarta.annotation.PreDestroy;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
 import org.springframework.boot.autoconfigure.SpringBootApplication;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnExpression;
 import org.springframework.boot.autoconfigure.data.mongo.MongoReactiveDataAutoConfiguration;
 import org.springframework.boot.autoconfigure.data.mongo.MongoReactiveRepositoriesAutoConfiguration;
 import org.springframework.boot.autoconfigure.mongo.MongoAutoConfiguration;
 import org.springframework.boot.autoconfigure.mongo.MongoReactiveAutoConfiguration;
+import org.springframework.context.annotation.Configuration;
 import org.springframework.web.reactive.config.CorsRegistry;
 import org.springframework.web.reactive.config.WebFluxConfigurer;
 
 
-@SpringBootApplication(exclude = {
-               MongoReactiveDataAutoConfiguration.class,
-               MongoReactiveAutoConfiguration.class,
-               MongoReactiveRepositoriesAutoConfiguration.class,
-               MongoAutoConfiguration.class })
+@SpringBootApplication
 public class ChatBackendApplication implements WebFluxConfigurer
 {
        @Autowired
@@ -45,6 +44,17 @@ public class ChatBackendApplication implements WebFluxConfigurer
                                .subscribe();
        }
 
+       @ConditionalOnExpression("!'${chat.backend.inmemory.storage-strategy}'.toLowerCase().equals('mongodb')")
+       @Configuration
+       @EnableAutoConfiguration(exclude = {
+                       MongoReactiveDataAutoConfiguration.class,
+                       MongoReactiveAutoConfiguration.class,
+                       MongoReactiveRepositoriesAutoConfiguration.class,
+                       MongoAutoConfiguration.class })
+       public static class DisableMongoDBConfiguration
+       {
+       }
+
        public static void main(String[] args)
        {
                SpringApplication.run(ChatBackendApplication.class, args);