X-Git-Url: https://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2Fchat%2Fbackend%2Fpersistence%2Fkafka%2FKafkaChatHomeService.java;h=22cd74b75ac4c879fbbd0a0182491a3e87414655;hb=915ed8f85459da3c95f86b6351a3d7129668bc8e;hp=3ca5b7f7436f33d9476fec5be4f899a4f4244ee9;hpb=ead1db4a7daa0bcf944063f3920b3974c2f62e07;p=demos%2Fkafka%2Fchat diff --git a/src/main/java/de/juplo/kafka/chat/backend/persistence/kafka/KafkaChatHomeService.java b/src/main/java/de/juplo/kafka/chat/backend/persistence/kafka/KafkaChatHomeService.java index 3ca5b7f7..22cd74b7 100644 --- a/src/main/java/de/juplo/kafka/chat/backend/persistence/kafka/KafkaChatHomeService.java +++ b/src/main/java/de/juplo/kafka/chat/backend/persistence/kafka/KafkaChatHomeService.java @@ -20,14 +20,12 @@ import reactor.core.publisher.Mono; import java.time.*; import java.util.*; -import java.util.concurrent.ExecutorService; import java.util.stream.IntStream; @Slf4j public class KafkaChatHomeService implements ChatHomeService, Runnable, ConsumerRebalanceListener { - private final ExecutorService executorService; private final Consumer consumer; private final Producer producer; private final String topic; @@ -36,7 +34,7 @@ public class KafkaChatHomeService implements ChatHomeService, Runnable, Consumer private final boolean[] isShardOwned; private final long[] currentOffset; private final long[] nextOffset; - private final Map[] chatRoomMaps; + private final Map[] chatrooms; private final KafkaLikeShardingStrategy shardingStrategy; private boolean running; @@ -44,7 +42,6 @@ public class KafkaChatHomeService implements ChatHomeService, Runnable, Consumer public KafkaChatHomeService( - ExecutorService executorService, Consumer consumer, Producer producer, String topic, @@ -52,7 +49,6 @@ public class KafkaChatHomeService implements ChatHomeService, Runnable, Consumer int numShards) { log.debug("Creating KafkaChatHomeService"); - this.executorService = executorService; this.consumer = consumer; this.producer = producer; this.topic = topic; @@ -61,7 +57,7 @@ public class KafkaChatHomeService implements ChatHomeService, Runnable, Consumer this.isShardOwned = new boolean[numShards]; this.currentOffset = new long[numShards]; this.nextOffset = new long[numShards]; - this.chatRoomMaps = new Map[numShards]; + this.chatrooms = new Map[numShards]; this.shardingStrategy = new KafkaLikeShardingStrategy(numShards); } @@ -167,7 +163,7 @@ public class KafkaChatHomeService implements ChatHomeService, Runnable, Consumer Message message = new Message(key, record.offset(), timestamp, messageTo.getText()); - ChatRoom chatRoom = chatRoomMaps[record.partition()].get(chatRoomId); + ChatRoom chatRoom = chatrooms[record.partition()].get(chatRoomId); KafkaChatRoomService kafkaChatRoomService = (KafkaChatRoomService) chatRoom.getChatRoomService(); @@ -241,6 +237,12 @@ public class KafkaChatHomeService implements ChatHomeService, Runnable, Consumer } + public void putChatRoom(ChatRoom chatRoom) + { + // TODO: Nachricht senden! + chatrooms[chatRoom.getShard()].put(chatRoom.getId(), chatRoom); + } + @Override public Mono getChatRoom(int shard, UUID id) { @@ -250,7 +252,7 @@ public class KafkaChatHomeService implements ChatHomeService, Runnable, Consumer } else { - return Mono.justOrEmpty(chatRoomMaps[shard].get(id)); + return Mono.justOrEmpty(chatrooms[shard].get(id)); } } @@ -263,7 +265,7 @@ public class KafkaChatHomeService implements ChatHomeService, Runnable, Consumer } else { - return Flux.fromStream(chatRoomMaps[shard].values().stream()); + return Flux.fromStream(chatrooms[shard].values().stream()); } } }