All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.infinispan.server.hotrod.TaskRequestProcessor Maven / Gradle / Ivy

package org.infinispan.server.hotrod;

import java.util.Map;
import java.util.concurrent.Executor;

import javax.security.auth.Subject;

import org.infinispan.AdvancedCache;
import org.infinispan.commons.logging.LogFactory;
import org.infinispan.commons.util.Util;
import org.infinispan.security.actions.SecurityActions;
import org.infinispan.server.hotrod.logging.Log;
import org.infinispan.tasks.TaskContext;
import org.infinispan.tasks.TaskManager;

import io.netty.channel.Channel;

public class TaskRequestProcessor extends BaseRequestProcessor {
   private static final Log log = LogFactory.getLog(TaskRequestProcessor.class, Log.class);

   private final HotRodServer server;
   private final TaskManager taskManager;

   TaskRequestProcessor(Channel channel, Executor executor, HotRodServer server) {
      super(channel, executor, server);
      this.server = server;
      this.taskManager = SecurityActions.getGlobalComponentRegistry(server.getCacheManager()).getComponent(TaskManager.class);
   }

   public void exec(HotRodHeader header, Subject subject, String taskName, Map taskParams) {
      TaskContext taskContext = new TaskContext()
            .parameters(taskParams)
            .subject(subject);
      if (!header.cacheName.isEmpty() || server.hasDefaultCache()) {
         AdvancedCache cache = server.cache(server.getCacheInfo(header), header, subject);
         taskContext.cache(cache);
      }

      taskManager.runTask(taskName, taskContext).whenComplete((result, throwable) -> handleExec(header, result, throwable));
   }

   private void handleExec(HotRodHeader header, Object result, Throwable throwable) {
      if (throwable != null) {
         writeException(header, throwable);
      } else {
         if (result != null && !(result instanceof byte[])) {
            writeException(header, log.errorSerializingResponse(result));
         } else {
            writeResponse(header, header.encoder().valueResponse(header, server, channel, OperationStatus.Success,
                  result == null ? Util.EMPTY_BYTE_ARRAY : (byte[]) result));
         }
      }
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy