public class org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler extends java.lang.Object implements org.apache.kafkaesqueesque.common.security.auth.AuthenticateCallbackHandler
{
private java.lang.String mechanism;
public void <init>()
{
org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler v;
v := @this: org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public void configure(java.util.Map, java.lang.String, java.util.List)
{
java.util.List v;
java.util.Map v;
org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler v;
java.lang.String v;
v := @this: org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler;
v := @parameter: java.util.Map;
v := @parameter: java.lang.String;
v := @parameter: java.util.List;
v.<org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler: java.lang.String mechanism> = v;
return;
}
public void handle(javax.security.auth.callback.Callback[]) throws javax.security.auth.callback.UnsupportedCallbackException
{
java.security.AccessControlContext v;
javax.security.auth.callback.UnsupportedCallbackException v, v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.Set v, v, v, v, v, v, v, v;
javax.security.auth.callback.Callback v;
javax.security.auth.callback.Callback[] v;
int v, v;
java.lang.String v, v, v, v, v, v, v;
java.util.Iterator v, v, v, v;
javax.security.auth.Subject v;
char[] v;
java.lang.Object v, v, v, v;
org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler v;
v := @this: org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler;
v := @parameter: javax.security.auth.callback.Callback[];
v = staticinvoke <java.security.AccessController: java.security.AccessControlContext getContext()>();
v = staticinvoke <javax.security.auth.Subject: javax.security.auth.Subject getSubject(java.security.AccessControlContext)>(v);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = v instanceof javax.security.auth.callback.NameCallback;
if v == 0 goto label;
if v == null goto label;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPublicCredentials(java.lang.Class)>(class "Ljava/lang/String;");
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPublicCredentials(java.lang.Class)>(class "Ljava/lang/String;");
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
virtualinvoke v.<javax.security.auth.callback.NameCallback: void setName(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<javax.security.auth.callback.NameCallback: java.lang.String getDefaultName()>();
virtualinvoke v.<javax.security.auth.callback.NameCallback: void setName(java.lang.String)>(v);
goto label;
label:
v = v instanceof javax.security.auth.callback.PasswordCallback;
if v == 0 goto label;
if v == null goto label;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPrivateCredentials(java.lang.Class)>(class "Ljava/lang/String;");
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPrivateCredentials(java.lang.Class)>(class "Ljava/lang/String;");
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
virtualinvoke v.<javax.security.auth.callback.PasswordCallback: void setPassword(char[])>(v);
goto label;
label:
v = new javax.security.auth.callback.UnsupportedCallbackException;
specialinvoke v.<javax.security.auth.callback.UnsupportedCallbackException: void <init>(javax.security.auth.callback.Callback,java.lang.String)>(v, "Could not login: the client is being asked for a password, but the Kafka client code does not currently support obtaining a password from the user.");
throw v;
label:
v = v instanceof javax.security.sasl.RealmCallback;
if v == 0 goto label;
v = virtualinvoke v.<javax.security.sasl.RealmCallback: java.lang.String getDefaultText()>();
virtualinvoke v.<javax.security.sasl.RealmCallback: void setText(java.lang.String)>(v);
goto label;
label:
v = v instanceof javax.security.sasl.AuthorizeCallback;
if v == 0 goto label;
v = virtualinvoke v.<javax.security.sasl.AuthorizeCallback: java.lang.String getAuthenticationID()>();
v = virtualinvoke v.<javax.security.sasl.AuthorizeCallback: java.lang.String getAuthorizationID()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
virtualinvoke v.<javax.security.sasl.AuthorizeCallback: void setAuthorized(boolean)>(v);
v = virtualinvoke v.<javax.security.sasl.AuthorizeCallback: boolean isAuthorized()>();
if v == 0 goto label;
virtualinvoke v.<javax.security.sasl.AuthorizeCallback: void setAuthorizedID(java.lang.String)>(v);
goto label;
label:
v = v instanceof org.apache.kafkaesqueesque.common.security.scram.ScramExtensionsCallback;
if v == 0 goto label;
v = v.<org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler: java.lang.String mechanism>;
v = staticinvoke <org.apache.kafkaesqueesque.common.security.scram.internals.ScramMechanism: boolean isScram(java.lang.String)>(v);
if v == 0 goto label;
if v == null goto label;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPublicCredentials(java.lang.Class)>(class "Ljava/util/Map;");
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPublicCredentials(java.lang.Class)>(class "Ljava/util/Map;");
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
virtualinvoke v.<org.apache.kafkaesqueesque.common.security.scram.ScramExtensionsCallback: void extensions(java.util.Map)>(v);
goto label;
label:
v = v instanceof org.apache.kafkaesqueesque.common.security.auth.SaslExtensionsCallback;
if v == 0 goto label;
v = "GSSAPI";
v = v.<org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler: java.lang.String mechanism>;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
if v == null goto label;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPublicCredentials(java.lang.Class)>(class "Lorg/apache/kafkaesqueesque/common/security/auth/SaslExtensions;");
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPublicCredentials(java.lang.Class)>(class "Lorg/apache/kafkaesqueesque/common/security/auth/SaslExtensions;");
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
virtualinvoke v.<org.apache.kafkaesqueesque.common.security.auth.SaslExtensionsCallback: void extensions(org.apache.kafkaesqueesque.common.security.auth.SaslExtensions)>(v);
goto label;
label:
v = new javax.security.auth.callback.UnsupportedCallbackException;
specialinvoke v.<javax.security.auth.callback.UnsupportedCallbackException: void <init>(javax.security.auth.callback.Callback,java.lang.String)>(v, "Unrecognized SASL ClientCallback");
throw v;
label:
v = v + 1;
goto label;
label:
return;
}
public void close()
{
org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler v;
v := @this: org.apache.kafkaesqueesque.common.security.authenticator.SaslClientCallbackHandler;
return;
}
}