io.nats.examples.chaosTestApp.ConnectableConsumer Maven / Gradle / Ivy
// Copyright 2023 The NATS Authors
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at:
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package io.nats.examples.chaosTestApp;
import io.nats.client.*;
import io.nats.client.api.ConsumerConfiguration;
import io.nats.client.api.DeliverPolicy;
import io.nats.examples.chaosTestApp.support.CommandLine;
import io.nats.examples.chaosTestApp.support.ConsumerKind;
import java.io.IOException;
import java.util.concurrent.atomic.AtomicLong;
public abstract class ConnectableConsumer implements ConnectionListener {
protected final Connection nc;
protected final JetStream js;
protected final OutputErrorListener errorListener;
protected final AtomicLong lastReceivedSequence;
protected final MessageHandler handler;
protected final ConsumerKind consumerKind;
protected final CommandLine cmd;
protected String initials;
protected String name;
protected String durableName;
protected String label;
public ConnectableConsumer(CommandLine cmd, String initials, ConsumerKind consumerKind) throws IOException, InterruptedException, JetStreamApiException {
this.cmd = cmd;
lastReceivedSequence = new AtomicLong(0);
this.consumerKind = consumerKind;
switch (consumerKind) {
case Durable:
durableName = initials + "-dur-" + new NUID().nextSequence();
name = durableName;
break;
case Ephemeral:
durableName = null;
name = initials + "-eph-" + new NUID().nextSequence();
break;
case Ordered:
durableName = null;
name = initials + "-ord-" + new NUID().nextSequence();
break;
}
this.initials = initials;
label = name + " (" + consumerKind.name() + ")";
errorListener = new OutputErrorListener(label);
Options options = cmd.makeOptions(this, errorListener);
nc = Nats.connect(options);
js = nc.jetStream();
handler = this::onMessage;
}
public void onMessage(Message m) throws InterruptedException {
m.ack();
long seq = m.metaData().streamSequence();
long lastSeq = lastReceivedSequence.get();
lastReceivedSequence.set(seq);
Output.workMessage(label, "Last Received Seq: " + seq + "(" + lastSeq + ")");
}
public abstract void refreshInfo();
@Override
public void connectionEvent(Connection conn, Events type) {
Output.controlMessage(label, "Connection: " + conn.getServerInfo().getPort() + " " + type.name().toLowerCase());
refreshInfo();
}
protected void updateLabel(String conName) {
if (!name.contains(conName))
{
int at = name.lastIndexOf("-");
name = name.substring(0, at + 1) + conName;
label = name + " (" + consumerKind.name() + ")";
}
}
public long getLastReceivedSequence() {
return lastReceivedSequence.get();
}
protected ConsumerConfiguration.Builder newCreateConsumer() {
return recreateConsumer(0);
}
private ConsumerConfiguration.Builder recreateConsumer(long last) {
return ConsumerConfiguration.builder()
.name(consumerKind == ConsumerKind.Ordered ? null : name)
.durable(durableName)
.deliverPolicy(last == 0 ? DeliverPolicy.All : DeliverPolicy.ByStartSequence)
.startSequence(last == 0 ? -1 : last + 1)
.filterSubject(cmd.subject);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy