private final List<ActorSelection> alternates;
private final DataTree dataTree;
private final ActorRef backend;
+ private final int maxMessages;
- ConnectClientSuccess(final ClientIdentifier target, final ActorRef backend, final List<ActorSelection> alternates,
- final Optional<DataTree> dataTree) {
- super(target);
+ ConnectClientSuccess(final ClientIdentifier target, final long sequence, final ActorRef backend,
+ final List<ActorSelection> alternates, final Optional<DataTree> dataTree, final int maxMessages) {
+ super(target, sequence);
this.backend = Preconditions.checkNotNull(backend);
this.alternates = ImmutableList.copyOf(alternates);
this.dataTree = dataTree.orElse(null);
+ Preconditions.checkArgument(maxMessages > 0, "Maximum messages has to be positive, not %s", maxMessages);
+ this.maxMessages = maxMessages;
}
- public ConnectClientSuccess(final @Nonnull ClientIdentifier target, final @Nonnull ActorRef backend,
- final @Nonnull List<ActorSelection> alternates,
- final @Nonnull DataTree dataTree) {
- this(target, backend, alternates, Optional.of(dataTree));
+ public ConnectClientSuccess(@Nonnull final ClientIdentifier target, final long sequence,
+ @Nonnull final ActorRef backend, @Nonnull final List<ActorSelection> alternates,
+ @Nonnull final DataTree dataTree, final int maxMessages) {
+ this(target, sequence, backend, alternates, Optional.of(dataTree), maxMessages);
}
/**
*
* @return a list of known backend alternates
*/
- public @Nonnull List<ActorSelection> getAlternates() {
+ @Nonnull
+ public List<ActorSelection> getAlternates() {
return alternates;
}
- public @Nonnull ActorRef getBackend() {
+ @Nonnull
+ public ActorRef getBackend() {
return backend;
}
return Optional.ofNullable(dataTree);
}
+ public int getMaxMessages() {
+ return maxMessages;
+ }
+
@Override
protected ConnectClientSuccessProxyV1 externalizableProxy(final ABIVersion version) {
return new ConnectClientSuccessProxyV1(this);
@Override
protected ToStringHelper addToStringAttributes(final ToStringHelper toStringHelper) {
- return super.addToStringAttributes(toStringHelper).add("alternates", alternates).add("dataTree", dataTree);
+ return super.addToStringAttributes(toStringHelper).add("alternates", alternates).add("dataTree", dataTree)
+ .add("maxMessages", maxMessages);
}
}