1 package de.juplo.kafka.chat.backend.api;
3 import de.juplo.kafka.chat.backend.domain.Chatroom;
4 import de.juplo.kafka.chat.backend.domain.ChatroomFactory;
5 import lombok.RequiredArgsConstructor;
6 import org.springframework.http.MediaType;
7 import org.springframework.web.bind.annotation.*;
8 import reactor.core.publisher.Flux;
9 import reactor.core.publisher.Mono;
11 import java.time.Clock;
12 import java.time.LocalDateTime;
13 import java.util.Collection;
14 import java.util.HashMap;
16 import java.util.UUID;
20 @RequiredArgsConstructor
21 public class ChatBackendController
23 private final Map<UUID, Chatroom> chatrooms = new HashMap<>();
24 private final ChatroomFactory factory;
25 private final Clock clock;
28 @PostMapping("create")
29 public Chatroom create(@RequestBody String name)
31 Chatroom chatroom = factory.createChatroom(UUID.randomUUID(), name);
32 chatrooms.put(chatroom.getId(), chatroom);
37 public Collection<Chatroom> list()
39 return chatrooms.values();
42 @GetMapping("get/{chatroomId}")
43 public Chatroom get(@PathVariable UUID chatroomId)
45 return chatrooms.get(chatroomId);
48 @PutMapping("put/{chatroomId}/{username}/{messageId}")
49 public Mono<MessageTo> put(
50 @PathVariable UUID chatroomId,
51 @PathVariable String username,
52 @PathVariable Long messageId,
53 @RequestBody String text)
55 Chatroom chatroom = chatrooms.get(chatroomId);
60 LocalDateTime.now(clock),
63 .switchIfEmpty(chatroom.getMessage(username, messageId))
64 .map(message -> MessageTo.from(message));
67 @GetMapping("get/{chatroomId}/{username}/{messageId}")
68 public Mono<MessageTo> get(
69 @PathVariable UUID chatroomId,
70 @PathVariable String username,
71 @PathVariable Long messageId)
76 .getMessage(username, messageId)
77 .map(message -> MessageTo.from(message));
81 path = "listen/{chatroomId}",
82 produces = MediaType.TEXT_EVENT_STREAM_VALUE)
83 public Flux<MessageTo> listen(@PathVariable UUID chatroomId)
89 .map(message -> MessageTo.from(message));