public class org.apache.kafkaesqueesque.common.network.SaslChannelBuilder extends java.lang.Object implements org.apache.kafkaesqueesque.common.network.ChannelBuilder, org.apache.kafkaesqueesque.common.network.ListenerReconfigurable
{
static final java.lang.String GSS_NATIVE_PROP;
private final org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol securityProtocol;
private final org.apache.kafkaesqueesque.common.network.ListenerName listenerName;
private final boolean isInterBrokerListener;
private final java.lang.String clientSaslMechanism;
private final org.apache.kafkaesqueesque.common.network.Mode mode;
private final java.util.Map jaasContexts;
private final boolean handshakeRequestEnable;
private final org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache credentialCache;
private final org.apache.kafkaesqueesque.common.security.token.delegation.internals.DelegationTokenCache tokenCache;
private final java.util.Map loginManagers;
private final java.util.Map subjects;
private org.apache.kafkaesqueesque.common.security.ssl.SslFactory sslFactory;
private java.util.Map configs;
private org.apache.kafkaesqueesque.common.security.kerberos.KerberosShortNamer kerberosShortNamer;
private java.util.Map saslCallbackHandlers;
private java.util.Map connectionsMaxReauthMsByMechanism;
private final org.apache.kafkaesqueesque.common.utils.Time time;
private final org.apache.kafkaesqueesque.common.utils.LogContext logContext;
private final org.slf4j.Logger log;
public void <init>(org.apache.kafkaesqueesque.common.network.Mode, java.util.Map, org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol, org.apache.kafkaesqueesque.common.network.ListenerName, boolean, java.lang.String, boolean, org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache, org.apache.kafkaesqueesque.common.security.token.delegation.internals.DelegationTokenCache, org.apache.kafkaesqueesque.common.utils.Time, org.apache.kafkaesqueesque.common.utils.LogContext)
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.network.Mode v;
java.util.HashMap v, v, v, v;
org.apache.kafkaesqueesque.common.utils.Time v;
java.util.Map v;
org.apache.kafkaesqueesque.common.network.ListenerName v;
int v, v;
java.lang.String v;
boolean v, v;
org.slf4j.Logger v;
org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol v;
org.apache.kafkaesqueesque.common.utils.LogContext v;
org.apache.kafkaesqueesque.common.security.token.delegation.internals.DelegationTokenCache v;
java.lang.Class v;
org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: org.apache.kafkaesqueesque.common.network.Mode;
v := @parameter: java.util.Map;
v := @parameter: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol;
v := @parameter: org.apache.kafkaesqueesque.common.network.ListenerName;
v := @parameter: boolean;
v := @parameter: java.lang.String;
v := @parameter: boolean;
v := @parameter: org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache;
v := @parameter: org.apache.kafkaesqueesque.common.security.token.delegation.internals.DelegationTokenCache;
v := @parameter: org.apache.kafkaesqueesque.common.utils.Time;
v := @parameter: org.apache.kafkaesqueesque.common.utils.LogContext;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.network.Mode mode> = v;
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map jaasContexts> = v;
v = new java.util.HashMap;
v = interfaceinvoke v.<java.util.Map: int size()>();
specialinvoke v.<java.util.HashMap: void <init>(int)>(v);
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map loginManagers> = v;
v = new java.util.HashMap;
v = interfaceinvoke v.<java.util.Map: int size()>();
specialinvoke v.<java.util.HashMap: void <init>(int)>(v);
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map subjects> = v;
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol securityProtocol> = v;
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.network.ListenerName listenerName> = v;
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: boolean isInterBrokerListener> = v;
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: boolean handshakeRequestEnable> = v;
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.lang.String clientSaslMechanism> = v;
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache credentialCache> = v;
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.token.delegation.internals.DelegationTokenCache tokenCache> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map saslCallbackHandlers> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map connectionsMaxReauthMsByMechanism> = v;
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.utils.Time time> = v;
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.utils.LogContext logContext> = v;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.utils.LogContext: org.slf4j.Logger logger(java.lang.Class)>(v);
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.slf4j.Logger log> = v;
return;
}
public void configure(java.util.Map) throws org.apache.kafkaesqueesque.common.KafkaException
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.network.Mode v, v, v, v, v;
org.apache.kafkaesqueesque.common.security.kerberos.KerberosShortNamer v;
java.util.Map v, v, v, v, v, v, v;
org.apache.kafkaesqueesque.common.security.ssl.SslFactory v, v;
boolean v, v, v, v, v;
org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol v, v;
java.util.Set v, v;
org.apache.kafkaesqueesque.common.security.authenticator.LoginManager v;
java.lang.Exception v;
java.util.List v;
java.lang.Throwable v;
java.lang.String v;
java.util.Iterator v, v;
javax.security.auth.Subject v;
org.apache.kafkaesqueesque.common.KafkaException v;
java.lang.Class v;
java.lang.Object v, v, v, v, v, v, v, v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.util.Map;
label:
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map configs> = v;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.network.Mode mode>;
v = <org.apache.kafkaesqueesque.common.network.Mode: org.apache.kafkaesqueesque.common.network.Mode SERVER>;
if v != v goto label;
specialinvoke v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: void createServerCallbackHandlers(java.util.Map)>(v);
specialinvoke v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: void createConnectionsMaxReauthMsMap(java.util.Map)>(v);
goto label;
label:
specialinvoke v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: void createClientCallbackHandler(java.util.Map)>(v);
label:
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map saslCallbackHandlers>;
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map jaasContexts>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.security.JaasContext: java.util.List configurationEntries()>();
interfaceinvoke v.<org.apache.kafkaesqueesque.common.security.auth.AuthenticateCallbackHandler: void configure(java.util.Map,java.lang.String,java.util.List)>(v, v, v);
goto label;
label:
v = specialinvoke v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.lang.Class defaultLoginClass()>();
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map jaasContexts>;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>("GSSAPI");
if v == 0 goto label;
label:
v = staticinvoke <org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.lang.String defaultKerberosRealm()>();
label:
goto label;
label:
v := @caughtexception;
v = "";
label:
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("sasl.kerberos.principal.to.local.rules");
if v == null goto label;
v = staticinvoke <org.apache.kafkaesqueesque.common.security.kerberos.KerberosShortNamer: org.apache.kafkaesqueesque.common.security.kerberos.KerberosShortNamer fromUnparsedRules(java.lang.String,java.util.List)>(v, v);
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.kerberos.KerberosShortNamer kerberosShortNamer> = v;
label:
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map jaasContexts>;
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = staticinvoke <org.apache.kafkaesqueesque.common.security.authenticator.LoginManager: org.apache.kafkaesqueesque.common.security.authenticator.LoginManager acquireLoginManager(org.apache.kafkaesqueesque.common.security.JaasContext,java.lang.String,java.lang.Class,java.util.Map)>(v, v, v, v);
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map loginManagers>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.security.authenticator.LoginManager: javax.security.auth.Subject subject()>();
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map subjects>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.network.Mode mode>;
v = <org.apache.kafkaesqueesque.common.network.Mode: org.apache.kafkaesqueesque.common.network.Mode SERVER>;
if v != v goto label;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("GSSAPI");
if v == 0 goto label;
specialinvoke v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: void maybeAddNativeGssapiCredentials(javax.security.auth.Subject)>(v);
goto label;
label:
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol securityProtocol>;
v = <org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol SASL_SSL>;
if v != v goto label;
v = new org.apache.kafkaesqueesque.common.security.ssl.SslFactory;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.network.Mode mode>;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: boolean isInterBrokerListener>;
specialinvoke v.<org.apache.kafkaesqueesque.common.security.ssl.SslFactory: void <init>(org.apache.kafkaesqueesque.common.network.Mode,java.lang.String,boolean)>(v, "none", v);
v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.ssl.SslFactory sslFactory> = v;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.ssl.SslFactory sslFactory>;
virtualinvoke v.<org.apache.kafkaesqueesque.common.security.ssl.SslFactory: void configure(java.util.Map)>(v);
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: void close()>();
v = new org.apache.kafkaesqueesque.common.KafkaException;
specialinvoke v.<org.apache.kafkaesqueesque.common.KafkaException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public java.util.Set reconfigurableConfigs()
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol v, v;
java.util.Set v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol securityProtocol>;
v = <org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol SASL_SSL>;
if v != v goto label;
v = <org.apache.kafkaesqueesque.common.config.SslConfigs: java.util.Set RECONFIGURABLE_CONFIGS>;
goto label;
label:
v = staticinvoke <java.util.Collections: java.util.Set emptySet()>();
label:
return v;
}
public void validateReconfiguration(java.util.Map)
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol v, v;
java.util.Map v;
org.apache.kafkaesqueesque.common.security.ssl.SslFactory v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.util.Map;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol securityProtocol>;
v = <org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol SASL_SSL>;
if v != v goto label;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.ssl.SslFactory sslFactory>;
virtualinvoke v.<org.apache.kafkaesqueesque.common.security.ssl.SslFactory: void validateReconfiguration(java.util.Map)>(v);
label:
return;
}
public void reconfigure(java.util.Map)
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol v, v;
java.util.Map v;
org.apache.kafkaesqueesque.common.security.ssl.SslFactory v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.util.Map;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol securityProtocol>;
v = <org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol SASL_SSL>;
if v != v goto label;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.ssl.SslFactory sslFactory>;
virtualinvoke v.<org.apache.kafkaesqueesque.common.security.ssl.SslFactory: void reconfigure(java.util.Map)>(v);
label:
return;
}
public org.apache.kafkaesqueesque.common.network.ListenerName listenerName()
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.network.ListenerName v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.network.ListenerName listenerName>;
return v;
}
public org.apache.kafkaesqueesque.common.network.KafkaChannel buildChannel(java.lang.String, java.nio.channels.SelectionKey, int, org.apache.kafkaesqueesque.common.memory.MemoryPool, org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry) throws org.apache.kafkaesqueesque.common.KafkaException
{
java.net.Socket v;
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.network.KafkaChannel v;
org.apache.kafkaesqueesque.common.network.Mode v, v;
org.apache.kafkaesqueesque.common.memory.MemoryPool v, v;
org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry v;
java.util.function.Supplier v, v;
java.util.Map v;
int v;
java.lang.String v, v;
org.slf4j.Logger v;
java.nio.channels.SelectionKey v;
java.lang.Exception v;
java.nio.channels.SelectableChannel v;
org.apache.kafkaesqueesque.common.network.TransportLayer v;
org.apache.kafkaesqueesque.common.KafkaException v;
java.lang.Object v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.lang.String;
v := @parameter: java.nio.channels.SelectionKey;
v := @parameter: int;
v := @parameter: org.apache.kafkaesqueesque.common.memory.MemoryPool;
v := @parameter: org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry;
label:
v = virtualinvoke v.<java.nio.channels.SelectionKey: java.nio.channels.SelectableChannel channel()>();
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.network.TransportLayer buildTransportLayer(java.lang.String,java.nio.channels.SelectionKey,java.nio.channels.SocketChannel,org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry)>(v, v, v, v);
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.network.Mode mode>;
v = <org.apache.kafkaesqueesque.common.network.Mode: org.apache.kafkaesqueesque.common.network.Mode SERVER>;
if v != v goto label;
v = staticinvoke <org.apache.kafkaesqueesque.common.network.SaslChannelBuilder$lambda_buildChannel_0__648: java.util.function.Supplier bootstrap$(org.apache.kafkaesqueesque.common.network.SaslChannelBuilder,java.lang.String,org.apache.kafkaesqueesque.common.network.TransportLayer,org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry)>(v, v, v, v);
goto label;
label:
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map loginManagers>;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.lang.String clientSaslMechanism>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = staticinvoke <org.apache.kafkaesqueesque.common.network.SaslChannelBuilder$lambda_buildChannel_1__647: java.util.function.Supplier bootstrap$(org.apache.kafkaesqueesque.common.network.SaslChannelBuilder,java.lang.String,java.net.Socket,org.apache.kafkaesqueesque.common.security.authenticator.LoginManager,org.apache.kafkaesqueesque.common.network.TransportLayer)>(v, v, v, v, v);
label:
v = new org.apache.kafkaesqueesque.common.network.KafkaChannel;
v = v;
if v == null goto label;
v = v;
goto label;
label:
v = <org.apache.kafkaesqueesque.common.memory.MemoryPool: org.apache.kafkaesqueesque.common.memory.MemoryPool NONE>;
label:
specialinvoke v.<org.apache.kafkaesqueesque.common.network.KafkaChannel: void <init>(java.lang.String,org.apache.kafkaesqueesque.common.network.TransportLayer,java.util.function.Supplier,int,org.apache.kafkaesqueesque.common.memory.MemoryPool,org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry)>(v, v, v, v, v, v);
label:
return v;
label:
v := @caughtexception;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Throwable)>("Failed to create channel due to ", v);
v = new org.apache.kafkaesqueesque.common.KafkaException;
specialinvoke v.<org.apache.kafkaesqueesque.common.KafkaException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.lang.Exception from label to label with label;
}
public void close()
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
java.util.Iterator v, v;
java.util.Collection v, v;
java.util.Map v, v, v;
java.lang.Object v, v;
boolean v, v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map loginManagers>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
virtualinvoke v.<org.apache.kafkaesqueesque.common.security.authenticator.LoginManager: void release()>();
goto label;
label:
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map loginManagers>;
interfaceinvoke v.<java.util.Map: void clear()>();
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map saslCallbackHandlers>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
interfaceinvoke v.<org.apache.kafkaesqueesque.common.security.auth.AuthenticateCallbackHandler: void close()>();
goto label;
label:
return;
}
protected org.apache.kafkaesqueesque.common.network.TransportLayer buildTransportLayer(java.lang.String, java.nio.channels.SelectionKey, java.nio.channels.SocketChannel, org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry) throws java.io.IOException
{
java.net.Socket v, v;
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry v;
javax.net.ssl.SSLEngine v;
java.net.InetAddress v;
java.nio.channels.SocketChannel v;
int v;
java.lang.String v, v;
org.apache.kafkaesqueesque.common.security.ssl.SslFactory v;
org.apache.kafkaesqueesque.common.network.SslTransportLayer v;
org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol v, v;
java.nio.channels.SelectionKey v;
org.apache.kafkaesqueesque.common.network.PlaintextTransportLayer v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.lang.String;
v := @parameter: java.nio.channels.SelectionKey;
v := @parameter: java.nio.channels.SocketChannel;
v := @parameter: org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol securityProtocol>;
v = <org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol SASL_SSL>;
if v != v goto label;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.ssl.SslFactory sslFactory>;
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
v = virtualinvoke v.<java.net.Socket: java.net.InetAddress getInetAddress()>();
v = virtualinvoke v.<java.net.InetAddress: java.lang.String getHostName()>();
v = virtualinvoke v.<java.nio.channels.SocketChannel: java.net.Socket socket()>();
v = virtualinvoke v.<java.net.Socket: int getPort()>();
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.security.ssl.SslFactory: javax.net.ssl.SSLEngine createSslEngine(java.lang.String,int)>(v, v);
v = staticinvoke <org.apache.kafkaesqueesque.common.network.SslTransportLayer: org.apache.kafkaesqueesque.common.network.SslTransportLayer create(java.lang.String,java.nio.channels.SelectionKey,javax.net.ssl.SSLEngine,org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry)>(v, v, v, v);
return v;
label:
v = new org.apache.kafkaesqueesque.common.network.PlaintextTransportLayer;
specialinvoke v.<org.apache.kafkaesqueesque.common.network.PlaintextTransportLayer: void <init>(java.nio.channels.SelectionKey)>(v);
return v;
}
protected org.apache.kafkaesqueesque.common.security.authenticator.SaslServerAuthenticator buildServerAuthenticator(java.util.Map, java.util.Map, java.lang.String, org.apache.kafkaesqueesque.common.network.TransportLayer, java.util.Map, java.util.Map, org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry)
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol v;
org.apache.kafkaesqueesque.common.security.authenticator.SaslServerAuthenticator v;
org.apache.kafkaesqueesque.common.security.kerberos.KerberosShortNamer v;
org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry v;
org.apache.kafkaesqueesque.common.utils.Time v;
org.apache.kafkaesqueesque.common.network.TransportLayer v;
java.util.Map v, v, v, v;
org.apache.kafkaesqueesque.common.network.ListenerName v;
java.lang.String v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesqueesque.common.network.TransportLayer;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry;
v = new org.apache.kafkaesqueesque.common.security.authenticator.SaslServerAuthenticator;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.kerberos.KerberosShortNamer kerberosShortNamer>;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.network.ListenerName listenerName>;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol securityProtocol>;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.utils.Time time>;
specialinvoke v.<org.apache.kafkaesqueesque.common.security.authenticator.SaslServerAuthenticator: void <init>(java.util.Map,java.util.Map,java.lang.String,java.util.Map,org.apache.kafkaesqueesque.common.security.kerberos.KerberosShortNamer,org.apache.kafkaesqueesque.common.network.ListenerName,org.apache.kafkaesqueesque.common.security.auth.SecurityProtocol,org.apache.kafkaesqueesque.common.network.TransportLayer,java.util.Map,org.apache.kafkaesqueesque.common.network.ChannelMetadataRegistry,org.apache.kafkaesqueesque.common.utils.Time)>(v, v, v, v, v, v, v, v, v, v, v);
return v;
}
protected org.apache.kafkaesqueesque.common.security.authenticator.SaslClientAuthenticator buildClientAuthenticator(java.util.Map, org.apache.kafkaesqueesque.common.security.auth.AuthenticateCallbackHandler, java.lang.String, java.lang.String, java.lang.String, org.apache.kafkaesqueesque.common.network.TransportLayer, javax.security.auth.Subject)
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.utils.LogContext v;
javax.security.auth.Subject v;
org.apache.kafkaesqueesque.common.utils.Time v;
org.apache.kafkaesqueesque.common.network.TransportLayer v;
java.util.Map v;
java.lang.String v, v, v, v;
org.apache.kafkaesqueesque.common.security.authenticator.SaslClientAuthenticator v;
org.apache.kafkaesqueesque.common.security.auth.AuthenticateCallbackHandler v;
boolean v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.util.Map;
v := @parameter: org.apache.kafkaesqueesque.common.security.auth.AuthenticateCallbackHandler;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesqueesque.common.network.TransportLayer;
v := @parameter: javax.security.auth.Subject;
v = new org.apache.kafkaesqueesque.common.security.authenticator.SaslClientAuthenticator;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.lang.String clientSaslMechanism>;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: boolean handshakeRequestEnable>;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.utils.Time time>;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.utils.LogContext logContext>;
specialinvoke v.<org.apache.kafkaesqueesque.common.security.authenticator.SaslClientAuthenticator: void <init>(java.util.Map,org.apache.kafkaesqueesque.common.security.auth.AuthenticateCallbackHandler,java.lang.String,javax.security.auth.Subject,java.lang.String,java.lang.String,java.lang.String,boolean,org.apache.kafkaesqueesque.common.network.TransportLayer,org.apache.kafkaesqueesque.common.utils.Time,org.apache.kafkaesqueesque.common.utils.LogContext)>(v, v, v, v, v, v, v, v, v, v, v);
return v;
}
java.util.Map loginManagers()
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
java.util.Map v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map loginManagers>;
return v;
}
private static java.lang.String defaultKerberosRealm()
{
java.lang.String v;
javax.security.auth.kerberos.KerberosPrincipal v;
v = new javax.security.auth.kerberos.KerberosPrincipal;
specialinvoke v.<javax.security.auth.kerberos.KerberosPrincipal: void <init>(java.lang.String,int)>("tmp", 1);
v = virtualinvoke v.<javax.security.auth.kerberos.KerberosPrincipal: java.lang.String getRealm()>();
return v;
}
private void createClientCallbackHandler(java.util.Map)
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
java.util.Map v, v;
java.lang.Object v, v;
java.lang.String v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.util.Map;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("sasl.client.callback.handler.class");
if v != null goto label;
v = specialinvoke v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.lang.Class clientCallbackHandlerClass()>();
label:
v = staticinvoke <org.apache.kafkaesqueesque.common.utils.Utils: java.lang.Object newInstance(java.lang.Class)>(v);
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map saslCallbackHandlers>;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.lang.String clientSaslMechanism>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
return;
}
private void createServerCallbackHandlers(java.util.Map)
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.apache.kafkaesqueesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredValidatorCallbackHandler v;
org.apache.kafkaesqueesque.common.security.scram.internals.ScramServerCallbackHandler v;
org.apache.kafkaesqueesque.common.security.plain.internals.PlainServerCallbackHandler v;
java.util.Map v, v, v;
java.lang.String v, v;
boolean v, v, v, v;
java.util.Iterator v;
java.util.Set v;
org.apache.kafkaesqueesque.common.security.token.delegation.internals.DelegationTokenCache v;
org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache$Cache v;
java.lang.Object v, v, v;
org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache v;
org.apache.kafkaesqueesque.common.security.authenticator.SaslServerCallbackHandler v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.util.Map;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map jaasContexts>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = staticinvoke <org.apache.kafkaesqueesque.common.network.ListenerName: java.lang.String saslMechanismPrefix(java.lang.String)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001sasl.server.callback.handler.class");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = staticinvoke <org.apache.kafkaesqueesque.common.utils.Utils: java.lang.Object newInstance(java.lang.Class)>(v);
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("PLAIN");
if v == 0 goto label;
v = new org.apache.kafkaesqueesque.common.security.plain.internals.PlainServerCallbackHandler;
specialinvoke v.<org.apache.kafkaesqueesque.common.security.plain.internals.PlainServerCallbackHandler: void <init>()>();
v = v;
goto label;
label:
v = staticinvoke <org.apache.kafkaesqueesque.common.security.scram.internals.ScramMechanism: boolean isScram(java.lang.String)>(v);
if v == 0 goto label;
v = new org.apache.kafkaesqueesque.common.security.scram.internals.ScramServerCallbackHandler;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache credentialCache>;
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache: org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache$Cache cache(java.lang.String,java.lang.Class)>(v, class "Lorg/apache/kafkaesqueesque/common/security/scram/ScramCredential;");
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.apache.kafkaesqueesque.common.security.token.delegation.internals.DelegationTokenCache tokenCache>;
specialinvoke v.<org.apache.kafkaesqueesque.common.security.scram.internals.ScramServerCallbackHandler: void <init>(org.apache.kafkaesqueesque.common.security.authenticator.CredentialCache$Cache,org.apache.kafkaesqueesque.common.security.token.delegation.internals.DelegationTokenCache)>(v, v);
v = v;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("OAUTHBEARER");
if v == 0 goto label;
v = new org.apache.kafkaesqueesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredValidatorCallbackHandler;
specialinvoke v.<org.apache.kafkaesqueesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredValidatorCallbackHandler: void <init>()>();
v = v;
goto label;
label:
v = new org.apache.kafkaesqueesque.common.security.authenticator.SaslServerCallbackHandler;
specialinvoke v.<org.apache.kafkaesqueesque.common.security.authenticator.SaslServerCallbackHandler: void <init>()>();
v = v;
label:
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map saslCallbackHandlers>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
return;
}
private void createConnectionsMaxReauthMsMap(java.util.Map)
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
java.util.Iterator v;
java.util.Set v;
java.util.Map v, v, v;
java.lang.Object v, v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.util.Map;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map jaasContexts>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = staticinvoke <org.apache.kafkaesqueesque.common.network.ListenerName: java.lang.String saslMechanismPrefix(java.lang.String)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001connections.max.reauth.ms");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("connections.max.reauth.ms");
label:
if v == null goto label;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map connectionsMaxReauthMsByMechanism>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
return;
}
private java.lang.Class defaultLoginClass()
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
java.util.Map v;
java.lang.String v, v;
boolean v, v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map jaasContexts>;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>("GSSAPI");
if v == 0 goto label;
return class "Lorg/apache/kafkaesqueesque/common/security/kerberos/KerberosLogin;";
label:
v = "OAUTHBEARER";
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.lang.String clientSaslMechanism>;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
return class "Lorg/apache/kafkaesqueesque/common/security/oauthbearer/internals/OAuthBearerRefreshingLogin;";
label:
return class "Lorg/apache/kafkaesqueesque/common/security/authenticator/DefaultLogin;";
}
private java.lang.Class clientCallbackHandlerClass()
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
byte v;
int v;
java.lang.String v;
boolean v, v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.lang.String clientSaslMechanism>;
v = -1;
v = virtualinvoke v.<java.lang.String: int hashCode()>();
lookupswitch(v)
{
case -1625286504: goto label;
case 2111859635: goto label;
default: goto label;
};
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("GSSAPI");
if v == 0 goto label;
v = 0;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("OAUTHBEARER");
if v == 0 goto label;
v = 1;
label:
lookupswitch(v)
{
case 0: goto label;
case 1: goto label;
default: goto label;
};
label:
return class "Lorg/apache/kafkaesqueesque/common/security/kerberos/KerberosClientCallbackHandler;";
label:
return class "Lorg/apache/kafkaesqueesque/common/security/oauthbearer/internals/OAuthBearerSaslClientCallbackHandler;";
label:
return class "Lorg/apache/kafkaesqueesque/common/security/authenticator/SaslClientCallbackHandler;";
}
private void maybeAddNativeGssapiCredentials(javax.security.auth.Subject)
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
java.lang.String v, v, v, v, v;
org.apache.kafkaesqueesque.common.security.kerberos.KerberosName v;
boolean v, v;
org.ietf.jgss.GSSCredential v;
org.slf4j.Logger v, v;
org.ietf.jgss.Oid v, v;
java.util.Set v, v;
org.ietf.jgss.GSSException v;
java.lang.IllegalArgumentException v;
javax.security.auth.Subject v;
org.ietf.jgss.GSSManager v;
org.apache.kafkaesqueesque.common.KafkaException v;
org.ietf.jgss.GSSName v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: javax.security.auth.Subject;
v = staticinvoke <java.lang.Boolean: boolean getBoolean(java.lang.String)>("sun.security.jgss.native");
if v == 0 goto label;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPrivateCredentials(java.lang.Class)>(class "Lorg/ietf/jgss/GSSCredential;");
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v == 0 goto label;
v = staticinvoke <org.apache.kafkaesqueesque.common.security.authenticator.SaslClientAuthenticator: java.lang.String firstPrincipal(javax.security.auth.Subject)>(v);
label:
v = staticinvoke <org.apache.kafkaesqueesque.common.security.kerberos.KerberosName: org.apache.kafkaesqueesque.common.security.kerberos.KerberosName parse(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.kafkaesqueesque.common.KafkaException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Principal has name with unexpected format \u0001");
specialinvoke v.<org.apache.kafkaesqueesque.common.KafkaException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.security.kerberos.KerberosName: java.lang.String serviceName()>();
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.security.kerberos.KerberosName: java.lang.String hostName()>();
label:
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.ietf.jgss.GSSManager gssManager()>();
v = new org.ietf.jgss.Oid;
specialinvoke v.<org.ietf.jgss.Oid: void <init>(java.lang.String)>("1.2.840.113554.1.2.2");
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001@\u0001");
v = <org.ietf.jgss.GSSName: org.ietf.jgss.Oid NT_HOSTBASED_SERVICE>;
v = virtualinvoke v.<org.ietf.jgss.GSSManager: org.ietf.jgss.GSSName createName(java.lang.String,org.ietf.jgss.Oid)>(v, v);
v = virtualinvoke v.<org.ietf.jgss.GSSManager: org.ietf.jgss.GSSCredential createCredential(org.ietf.jgss.GSSName,int,org.ietf.jgss.Oid,int)>(v, 2147483647, v, 2);
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPrivateCredentials()>();
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("Configured native GSSAPI private credentials for {}@{}", v, v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Cannot add private credential to subject; clients authentication may fail", v);
label:
return;
catch java.lang.IllegalArgumentException from label to label with label;
catch org.ietf.jgss.GSSException from label to label with label;
}
protected org.ietf.jgss.GSSManager gssManager()
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
org.ietf.jgss.GSSManager v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v = staticinvoke <org.ietf.jgss.GSSManager: org.ietf.jgss.GSSManager getInstance()>();
return v;
}
protected javax.security.auth.Subject subject(java.lang.String)
{
org.apache.kafkaesqueesque.common.network.SaslChannelBuilder v;
java.util.Map v;
java.lang.Object v;
java.lang.String v;
v := @this: org.apache.kafkaesqueesque.common.network.SaslChannelBuilder;
v := @parameter: java.lang.String;
v = v.<org.apache.kafkaesqueesque.common.network.SaslChannelBuilder: java.util.Map subjects>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
return v;
}
}