X-Git-Url: https://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2Fchat%2Fbackend%2Fdomain%2FChatroom.java;h=df6794aa72064874176c18d822afc981f6a8cd71;hb=6df4d75042bf7dc6737b5de8ef2bc9d3a79e9a89;hp=e1638aa9e02395bc700a45e7526ab64dca882af9;hpb=bb86037c439adea0f2befde98571eaf966c9a5e0;p=demos%2Fkafka%2Fchat diff --git a/src/main/java/de/juplo/kafka/chat/backend/domain/Chatroom.java b/src/main/java/de/juplo/kafka/chat/backend/domain/Chatroom.java index e1638aa9..df6794aa 100644 --- a/src/main/java/de/juplo/kafka/chat/backend/domain/Chatroom.java +++ b/src/main/java/de/juplo/kafka/chat/backend/domain/Chatroom.java @@ -2,7 +2,6 @@ package de.juplo.kafka.chat.backend.domain; import lombok.Getter; import lombok.RequiredArgsConstructor; -import lombok.Value; import lombok.extern.slf4j.Slf4j; import reactor.core.publisher.Flux; import reactor.core.publisher.Mono; @@ -20,7 +19,7 @@ public class Chatroom private final UUID id; @Getter private final String name; - private final LinkedHashMap messages = new LinkedHashMap<>(); + private final LinkedHashMap messages = new LinkedHashMap<>(); private final Sinks.Many sink = Sinks.many().multicast().onBackpressureBuffer(); synchronized public Mono addMessage( @@ -39,9 +38,9 @@ public class Chatroom String user, String text) { - Message message = new Message(id, (long)messages.size(), timestamp, user, text); + Message.MessageKey key = Message.MessageKey.of(user, id); + Message message = new Message(key, (long)messages.size(), timestamp, text); - MessageKey key = new MessageKey(user, id); Message existing = messages.get(key); if (existing != null) { @@ -61,7 +60,7 @@ public class Chatroom { return Mono.fromSupplier(() -> { - MessageKey key = MessageKey.of(username, messageId); + Message.MessageKey key = Message.MessageKey.of(username, messageId); return messages.get(key); }); } @@ -82,12 +81,4 @@ public class Chatroom return serial >= first && serial <= last; })); } - - - @Value(staticConstructor = "of") - static class MessageKey - { - String username; - Long messageId; - } }