![JAR search and dependency download from the Maven repository](/logo.png)
org.infinispan.server.resp.commands.pubsub.UNSUBSCRIBE Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of infinispan-server-resp Show documentation
Show all versions of infinispan-server-resp Show documentation
Infinispan Resp Protocol Server
package org.infinispan.server.resp.commands.pubsub;
import java.util.List;
import java.util.concurrent.CompletionStage;
import org.infinispan.commons.marshall.WrappedByteArray;
import org.infinispan.commons.util.concurrent.AggregateCompletionStage;
import org.infinispan.commons.util.concurrent.CompletionStages;
import org.infinispan.server.resp.Resp3Handler;
import org.infinispan.server.resp.RespCommand;
import org.infinispan.server.resp.RespRequestHandler;
import org.infinispan.server.resp.SubscriberHandler;
import org.infinispan.server.resp.commands.PubSubResp3Command;
import org.infinispan.server.resp.commands.Resp3Command;
import org.infinispan.server.resp.meta.ClientMetadata;
import io.netty.channel.ChannelHandlerContext;
/**
* @see Redis documentation
* @since 14.0
*/
public class UNSUBSCRIBE extends RespCommand implements Resp3Command, PubSubResp3Command {
public static final String NAME = "UNSUBSCRIBE";
public UNSUBSCRIBE() {
super(NAME, -1, 0, 0, 0);
}
@Override
public CompletionStage perform(SubscriberHandler handler,
ChannelHandlerContext ctx,
List arguments) {
AggregateCompletionStage aggregateCompletionStage = CompletionStages.aggregateCompletionStage();
if (arguments.isEmpty()) {
return handler.unsubscribeAll(ctx);
} else {
ClientMetadata metadata = handler.respServer().metadataRepository().client();
for (byte[] keyChannel : arguments) {
WrappedByteArray wrappedByteArray = new WrappedByteArray(keyChannel);
RespCacheListener listener = handler.specificChannelSubscribers().remove(wrappedByteArray);
if (listener != null) {
aggregateCompletionStage.dependsOn(handler.handleStageListenerError(handler.cache().removeListenerAsync(listener), keyChannel, false));
metadata.decrementPubSubClients();
}
}
}
return handler.sendSubscriptions(ctx, aggregateCompletionStage.freeze(), arguments, false);
}
@Override
public CompletionStage perform(Resp3Handler handler, ChannelHandlerContext ctx, List arguments) {
SubscriberHandler subscriberHandler = new SubscriberHandler(handler.respServer(), handler);
return subscriberHandler.handleRequest(ctx, this, arguments);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy