X-Git-Url: https://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2Fchat%2Fbackend%2Fapi%2FChatBackendController.java;h=3b8fc84229f19dfb50be27e096dfc3fa649c7642;hb=fad1a04e738182403490b11575653e3a1130fd48;hp=cc6958fea54d31dfe1c83cca81cd7bf20a7890c8;hpb=9de7f5dd0a6cd0205a9540fac141614af57ae8f4;p=demos%2Fkafka%2Fchat diff --git a/src/main/java/de/juplo/kafka/chat/backend/api/ChatBackendController.java b/src/main/java/de/juplo/kafka/chat/backend/api/ChatBackendController.java index cc6958fe..3b8fc842 100644 --- a/src/main/java/de/juplo/kafka/chat/backend/api/ChatBackendController.java +++ b/src/main/java/de/juplo/kafka/chat/backend/api/ChatBackendController.java @@ -9,9 +9,7 @@ import org.springframework.web.bind.annotation.*; import reactor.core.publisher.Flux; import reactor.core.publisher.Mono; -import java.util.Optional; import java.util.UUID; -import java.util.stream.Stream; @RestController @@ -23,32 +21,31 @@ public class ChatBackendController @PostMapping("create") - public ChatRoomTo create(@RequestBody String name) + public Mono create(@RequestBody String name) { - return ChatRoomTo.from(chatHome.createChatroom(name)); + return chatHome.createChatroom(name).map(ChatRoomTo::from); } @GetMapping("list") - public Stream list() + public Flux list() { - return chatHome.list().map(chatroom -> ChatRoomTo.from(chatroom)); + return chatHome.getChatRooms().map(chatroom -> ChatRoomTo.from(chatroom)); } @GetMapping("list/{chatroomId}") public Flux list(@PathVariable UUID chatroomId) { return chatHome - .getChatroom(chatroomId) - .map(chatroom -> chatroom + .getChatRoom(chatroomId) + .flatMapMany(chatroom -> chatroom .getMessages() - .map(MessageTo::from)) - .get(); + .map(MessageTo::from)); } @GetMapping("get/{chatroomId}") - public Optional get(@PathVariable UUID chatroomId) + public Mono get(@PathVariable UUID chatroomId) { - return chatHome.getChatroom(chatroomId).map(chatroom -> ChatRoomTo.from(chatroom)); + return chatHome.getChatRoom(chatroomId).map(chatroom -> ChatRoomTo.from(chatroom)); } @PutMapping("put/{chatroomId}/{username}/{messageId}") @@ -60,9 +57,8 @@ public class ChatBackendController { return chatHome - .getChatroom(chatroomId) - .map(chatroom -> put(chatroom, username, messageId, text)) - .orElseThrow(() -> new UnknownChatroomException(chatroomId)); + .getChatRoom(chatroomId) + .flatMap(chatroom -> put(chatroom, username, messageId, text)); } public Mono put( @@ -77,7 +73,6 @@ public class ChatBackendController messageId, username, text) - .switchIfEmpty(chatroom.getMessage(username, messageId)) .map(message -> MessageTo.from(message)); } @@ -89,9 +84,8 @@ public class ChatBackendController { return chatHome - .getChatroom(chatroomId) - .map(chatroom -> get(chatroom, username, messageId)) - .orElseThrow(() -> new UnknownChatroomException(chatroomId)); + .getChatRoom(chatroomId) + .flatMap(chatroom -> get(chatroom, username, messageId)); } private Mono get( @@ -109,9 +103,8 @@ public class ChatBackendController public Flux> listen(@PathVariable UUID chatroomId) { return chatHome - .getChatroom(chatroomId) - .map(chatroom -> listen(chatroom)) - .orElseThrow(() -> new UnknownChatroomException(chatroomId)); + .getChatRoom(chatroomId) + .flatMapMany(chatroom -> listen(chatroom)); } private Flux> listen(ChatRoom chatroom) @@ -131,6 +124,6 @@ public class ChatBackendController @PostMapping("/store") public void store() { - storageStrategy.writeChatrooms(Flux.fromStream(chatHome.list())); + storageStrategy.write(chatHome.getChatRooms()); } }