projects
/
demos
/
kafka
/
chat
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
WAS:TMP:IS?FIX:WIP:test: `*ConfigurationIT` asserts, if restored messages can be...
[demos/kafka/chat]
/
src
/
main
/
java
/
de
/
juplo
/
kafka
/
chat
/
backend
/
domain
/
ChatRoomData.java
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
511b9ad
..
bff56c1
100644
(file)
--- 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,7
@@
package de.juplo.kafka.chat.backend.domain;
package de.juplo.kafka.chat.backend.domain;
+import de.juplo.kafka.chat.backend.domain.exceptions.InvalidUsernameException;
+import de.juplo.kafka.chat.backend.domain.exceptions.MessageMutationException;
import lombok.extern.slf4j.Slf4j;
import reactor.core.publisher.Flux;
import reactor.core.publisher.Mono;
import lombok.extern.slf4j.Slf4j;
import reactor.core.publisher.Flux;
import reactor.core.publisher.Mono;
@@
-17,23
+19,23
@@
public class ChatRoomData
{
public final static Pattern VALID_USER = Pattern.compile("^[a-z0-9-]{2,}$");
{
public final static Pattern VALID_USER = Pattern.compile("^[a-z0-9-]{2,}$");
- private final Chat
Room
Service service;
+ private final Chat
Message
Service service;
private final Clock clock;
private final Clock clock;
- private final int
bufferSize
;
+ private final int
historyLimit
;
private Sinks.Many<Message> sink;
public ChatRoomData(
Clock clock,
private Sinks.Many<Message> sink;
public ChatRoomData(
Clock clock,
- Chat
Room
Service service,
- int
bufferSize
)
+ Chat
Message
Service service,
+ int
historyLimit
)
{
{
- log.info("Created ChatRoom with
buffer-size {}", bufferSize
);
+ log.info("Created ChatRoom with
history-limit {}", historyLimit
);
this.clock = clock;
this.service = service;
this.clock = clock;
this.service = service;
- this.
bufferSize = bufferSize
;
+ this.
historyLimit = historyLimit
;
// @RequiredArgsConstructor unfortunately not possible, because
// @RequiredArgsConstructor unfortunately not possible, because
- // the `
bufferSize
` is not set, if `createSink()` is called
+ // the `
historyLimit
` is not set, if `createSink()` is called
// from the variable declaration!
this.sink = createSink();
}
// from the variable declaration!
this.sink = createSink();
}
@@
-76,7
+78,7
@@
public class ChatRoomData
}
}
- public Chat
Room
Service getChatRoomService()
+ public Chat
Message
Service getChatRoomService()
{
return service;
}
{
return service;
}
@@
-104,11
+106,17
@@
public class ChatRoomData
return service.getMessages(first, last);
}
return service.getMessages(first, last);
}
+ public void close()
+ {
+ log.info("{} is being closed", service.getChatRoomId());
+ sink.emitComplete(Sinks.EmitFailureHandler.FAIL_FAST);
+ }
+
private Sinks.Many<Message> createSink()
{
return Sinks
.many()
private Sinks.Many<Message> createSink()
{
return Sinks
.many()
- .
multicast
()
- .
onBackpressureBuffer(bufferSize
);
+ .
replay
()
+ .
limit(historyLimit
);
}
}
}
}