X-Git-Url: http://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2Fchat%2Fbackend%2Fdomain%2FChatRoomData.java;h=ca33aca58fcc901d2d3784b1623283dcd08c918e;hb=900422dccb5a92fbceac34caa5e614b0d7f05ad7;hp=9dbeda9ed47d690dfb52561f7584647b6e7bf41a;hpb=465e722c9cd504932bc544c0f66e0b54007bdcdf;p=demos%2Fkafka%2Fchat diff --git a/src/main/java/de/juplo/kafka/chat/backend/domain/ChatRoomData.java b/src/main/java/de/juplo/kafka/chat/backend/domain/ChatRoomData.java index 9dbeda9e..ca33aca5 100644 --- a/src/main/java/de/juplo/kafka/chat/backend/domain/ChatRoomData.java +++ b/src/main/java/de/juplo/kafka/chat/backend/domain/ChatRoomData.java @@ -1,5 +1,6 @@ package de.juplo.kafka.chat.backend.domain; +import de.juplo.kafka.chat.backend.domain.exceptions.ChatRoomInactiveException; import de.juplo.kafka.chat.backend.domain.exceptions.InvalidUsernameException; import de.juplo.kafka.chat.backend.domain.exceptions.MessageMutationException; import lombok.extern.slf4j.Slf4j; @@ -23,6 +24,7 @@ public class ChatRoomData private final Clock clock; private final int historyLimit; private Sinks.Many sink; + private volatile boolean active = true; public ChatRoomData( @@ -37,7 +39,6 @@ public class ChatRoomData // @RequiredArgsConstructor unfortunately not possible, because // the `historyLimit` is not set, if `createSink()` is called // from the variable declaration! - this.sink = createSink(); } @@ -64,8 +65,8 @@ public class ChatRoomData sink.error(new MessageMutationException(existing, text)); } }) - .switchIfEmpty( - Mono + .switchIfEmpty(active + ? Mono .defer(() -> service.persistMessage(key, LocalDateTime.now(clock), text)) .doOnNext(m -> { @@ -74,7 +75,8 @@ public class ChatRoomData { log.warn("Emitting of message failed with {} for {}", result.name(), m); } - })); + }) + : Mono.error(new ChatRoomInactiveException(service.getChatRoomId()))); } @@ -91,9 +93,13 @@ public class ChatRoomData synchronized public Flux listen() { - return sink - .asFlux() - .doOnCancel(() -> sink = createSink()); // Sink hast to be recreated on auto-cancel! + return active + ? sink + .asFlux() + .doOnCancel(() -> sink = createSink()) // Sink hast to be recreated on auto-cancel! + : Flux + .error(new ChatRoomInactiveException(service.getChatRoomId())); + } public Flux getMessages() @@ -106,6 +112,20 @@ public class ChatRoomData return service.getMessages(first, last); } + public void activate() + { + log.info("{} is being activated", service.getChatRoomId()); + this.sink = createSink(); + active = true; + } + + public void deactivate() + { + log.info("{} is being deactivated", service.getChatRoomId()); + active = false; + sink.emitComplete(Sinks.EmitFailureHandler.FAIL_FAST); + } + private Sinks.Many createSink() { return Sinks