package de.juplo.kafka.chat.backend.domain;
-import lombok.EqualsAndHashCode;
-import lombok.Getter;
-import lombok.ToString;
import lombok.extern.slf4j.Slf4j;
import reactor.core.publisher.Flux;
import reactor.core.publisher.Mono;
import reactor.core.publisher.Sinks;
+import reactor.core.publisher.SynchronousSink;
import java.time.Clock;
import java.time.LocalDateTime;
@Slf4j
-@EqualsAndHashCode(of = { "id" })
-@ToString(of = { "id", "name" })
-public class ChatRoom
+public class ChatRoom extends ChatRoomInfo
{
public final static Pattern VALID_USER = Pattern.compile("^[a-z0-9-]{2,}$");
- @Getter
- private final UUID id;
- @Getter
- private final String name;
- @Getter
- private final int shard;
private final Clock clock;
private final ChatRoomService service;
private final int bufferSize;
ChatRoomService service,
int bufferSize)
{
+ super(id, name, shard);
log.info("Created ChatRoom {} with buffer-size {}", id, bufferSize);
- this.id = id;
- this.name = name;
- this.shard = shard;
this.clock = clock;
this.service = service;
this.bufferSize = bufferSize;
Message.MessageKey key = Message.MessageKey.of(user, id);
return service
.getMessage(key)
- .flatMap(existing -> text.equals(existing.getMessageText())
- ? Mono.just(existing)
- : Mono.error(() -> new MessageMutationException(existing, text)))
+ .handle((Message existing, SynchronousSink<Message> sink) ->
+ {
+ if (existing.getMessageText().equals(text))
+ {
+ sink.next(existing);
+ }
+ else
+ {
+ sink.error(new MessageMutationException(existing, text));
+ }
+ })
.switchIfEmpty(
Mono
- .fromSupplier(() ->service.persistMessage(key, LocalDateTime.now(clock), text))
+ .defer(() -> service.persistMessage(key, LocalDateTime.now(clock), text))
.doOnNext(m ->
{
Sinks.EmitResult result = sink.tryEmitNext(m);