![JAR search and dependency download from the Maven repository](/logo.png)
org.infinispan.server.resp.commands.pubsub.SUBSCRIBE 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.lang.invoke.MethodHandles;
import java.nio.ByteBuffer;
import java.util.List;
import java.util.concurrent.CompletionStage;
import org.infinispan.commons.logging.LogFactory;
import org.infinispan.commons.marshall.WrappedByteArray;
import org.infinispan.commons.util.concurrent.AggregateCompletionStage;
import org.infinispan.commons.util.concurrent.CompletionStages;
import org.infinispan.encoding.DataConversion;
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.filter.EventListenerConverter;
import org.infinispan.server.resp.filter.EventListenerKeysFilter;
import org.infinispan.server.resp.logging.Log;
import org.infinispan.server.resp.meta.ClientMetadata;
import io.netty.channel.ChannelHandlerContext;
import io.netty.util.CharsetUtil;
/**
* @link https://redis.io/commands/subscribe/
* @since 14.0
*/
public class SUBSCRIBE extends RespCommand implements Resp3Command, PubSubResp3Command {
private static final Log log = LogFactory.getLog(MethodHandles.lookup().lookupClass(), Log.class);
public SUBSCRIBE() {
super(-2, 0, 0, 0);
}
@Override
public CompletionStage perform(Resp3Handler handler,
ChannelHandlerContext ctx,
List arguments) {
SubscriberHandler subscriberHandler = new SubscriberHandler(handler.respServer(), handler);
return subscriberHandler.handleRequest(ctx, this, arguments);
}
@Override
public CompletionStage perform(SubscriberHandler handler,
ChannelHandlerContext ctx,
List arguments) {
ClientMetadata metadata = handler.respServer().metadataRepository().client();
AggregateCompletionStage aggregateCompletionStage = CompletionStages.aggregateCompletionStage();
for (byte[] keyChannel : arguments) {
if (log.isTraceEnabled()) {
log.tracef("Subscriber for channel: " + CharsetUtil.UTF_8.decode(ByteBuffer.wrap(keyChannel)));
}
WrappedByteArray wrappedByteArray = new WrappedByteArray(keyChannel);
if (handler.specificChannelSubscribers().get(wrappedByteArray) == null) {
RespCacheListener pubSubListener = SubscriberHandler.newKeyListener(ctx.channel(), keyChannel);
handler.specificChannelSubscribers().put(wrappedByteArray, pubSubListener);
byte[] channel = KeyChannelUtils.keyToChannel(keyChannel);
DataConversion dc = handler.cache().getValueDataConversion();
CompletionStage stage = handler.cache().addListenerAsync(pubSubListener, new EventListenerKeysFilter(channel), new EventListenerConverter
© 2015 - 2025 Weber Informatics LLC | Privacy Policy