X-Git-Url: https://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2Fchat%2Fbackend%2FChatBackendApplication.java;h=76debbedad052df2f4d4f6392b0ac6b191950cae;hb=4aacef9fa8d116ea4ef9687c42b8744841c09457;hp=f8c38b6340dac3f1c5dd7e29f759546f43b350e5;hpb=f0113ff34d7a4147ce54116680b611061244f39a;p=demos%2Fkafka%2Fchat diff --git a/src/main/java/de/juplo/kafka/chat/backend/ChatBackendApplication.java b/src/main/java/de/juplo/kafka/chat/backend/ChatBackendApplication.java index f8c38b63..76debbed 100644 --- a/src/main/java/de/juplo/kafka/chat/backend/ChatBackendApplication.java +++ b/src/main/java/de/juplo/kafka/chat/backend/ChatBackendApplication.java @@ -1,21 +1,41 @@ package de.juplo.kafka.chat.backend; +import de.juplo.kafka.chat.backend.domain.ChatHomeService; +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.SpringBootApplication; -import org.springframework.context.annotation.Bean; - -import java.time.Clock; +import org.springframework.web.reactive.config.CorsRegistry; +import org.springframework.web.reactive.config.WebFluxConfigurer; @SpringBootApplication -public class ChatBackendApplication +public class ChatBackendApplication implements WebFluxConfigurer { - @Bean - public Clock clock() + @Autowired + ChatBackendProperties properties; + @Autowired + ChatHomeService chatHomeService; + @Autowired + StorageStrategy storageStrategy; + + + @Override + public void addCorsMappings(CorsRegistry registry) { - return Clock.systemDefaultZone(); + registry + .addMapping("/**") + .allowedOrigins(properties.getAllowedOrigins()); } + @PreDestroy + public void onExit() + { + storageStrategy + .write(chatHomeService) + .subscribe(); + } public static void main(String[] args) {