projects
/
demos
/
kafka
/
chat
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
feat: Introduced config switches to choose the used implementations
[demos/kafka/chat]
/
src
/
main
/
java
/
de
/
juplo
/
kafka
/
chat
/
backend
/
ChatBackendApplication.java
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
287c9ee
..
c61f848
100644
(file)
--- a/
src/main/java/de/juplo/kafka/chat/backend/ChatBackendApplication.java
+++ b/
src/main/java/de/juplo/kafka/chat/backend/ChatBackendApplication.java
@@
-1,24
+1,42
@@
-package de.juplo.kafka.chat
room
;
+package de.juplo.kafka.chat
.backend
;
+import de.juplo.kafka.chat.backend.domain.ChatHome;
+import de.juplo.kafka.chat.backend.persistence.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.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
@SpringBootApplication
-public class Chat
roomApplication
+public class Chat
BackendApplication implements WebFluxConfigurer
{
{
- @Bean
- public Clock clock()
+ @Autowired
+ ChatBackendProperties properties;
+ @Autowired
+ ChatHome chatHome;
+ @Autowired
+ StorageStrategy storageStrategy;
+
+
+ @Override
+ public void addCorsMappings(CorsRegistry registry)
{
{
- return Clock.systemDefaultZone();
+ registry
+ .addMapping("/**")
+ .allowedOrigins(properties.getAllowedOrigins());
}
}
+ @PreDestroy
+ public void onExit()
+ {
+ storageStrategy.write(chatHome.getChatRooms());
+ }
public static void main(String[] args)
{
public static void main(String[] args)
{
- SpringApplication.run(Chat
room
Application.class, args);
+ SpringApplication.run(Chat
Backend
Application.class, args);
}
}
}
}