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

org.infinispan.server.security.RespClientCertAuthenticator Maven / Gradle / Ivy

There is a newer version: 15.1.0.Dev05
Show newest version
package org.infinispan.server.security;

import java.util.Collections;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.CompletionStage;
import java.util.concurrent.ScheduledExecutorService;

import javax.security.auth.Subject;
import javax.security.sasl.SaslException;
import javax.security.sasl.SaslServer;

import org.infinispan.commons.util.Util;
import org.infinispan.commons.util.concurrent.CompletableFutures;
import org.infinispan.server.configuration.ServerConfiguration;
import org.infinispan.server.core.security.sasl.SaslAuthenticator;
import org.infinispan.server.core.security.sasl.SubjectSaslServer;
import org.wildfly.security.sasl.util.SaslMechanismInformation;

import io.netty.channel.Channel;

public class RespClientCertAuthenticator {

   private final String realmName;
   private final ElytronSASLAuthenticator authenticator;

   public RespClientCertAuthenticator(String realmName) {
      this.realmName = realmName;
      authenticator = new ElytronSASLAuthenticator(realmName, null, Collections.singleton(SaslMechanismInformation.Names.EXTERNAL));
   }


   public CompletionStage clientCertAuth(Channel channel) throws SaslException {
      SaslServer server = null;
      try {
         server = SaslAuthenticator.createSaslServer(authenticator, null, channel, SaslMechanismInformation.Names.EXTERNAL, "resp");
         if (server == null) {
            return CompletableFutures.completedNull();
         }

         server.evaluateResponse(Util.EMPTY_BYTE_ARRAY);
         return CompletableFuture.completedFuture((Subject) server.getNegotiatedProperty(SubjectSaslServer.SUBJECT));
      } catch (Throwable e) {
         throw new RuntimeException(e);
      } finally {
         if (server != null) {
            server.dispose();
         }
      }
   }

   public void init(ServerConfiguration configuration, ScheduledExecutorService timeoutExecutor) {
      authenticator.init(configuration, timeoutExecutor);
   }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy