public class org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler extends java.lang.Object implements org.apache.kafkaesqueesque.common.security.auth.AuthenticateCallbackHandler
{
private static final org.slf4j.Logger log;
private boolean configured;
public void <init>()
{
org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler v;
v := @this: org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler: boolean configured> = 0;
return;
}
public boolean configured()
{
org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler v;
boolean v;
v := @this: org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler;
v = v.<org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler: boolean configured>;
return v;
}
public void configure(java.util.Map, java.lang.String, java.util.List)
{
java.lang.Object[] v;
java.lang.IllegalArgumentException v;
java.util.List v;
org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler v;
java.util.Map v;
java.lang.String v, v, v;
boolean v;
v := @this: org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler;
v := @parameter: java.util.Map;
v := @parameter: java.lang.String;
v := @parameter: java.util.List;
v = "OAUTHBEARER";
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Unexpected SASL mechanism: %s", v);
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v.<org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler: boolean configured> = 1;
return;
}
public void handle(javax.security.auth.callback.Callback[]) throws java.io.IOException, javax.security.auth.callback.UnsupportedCallbackException
{
java.security.AccessControlContext v;
java.lang.IllegalStateException v;
javax.security.auth.callback.UnsupportedCallbackException v;
javax.security.auth.Subject v;
javax.security.auth.callback.Callback[] v;
org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler v;
int v, v;
boolean v, v, v;
javax.security.auth.callback.Callback v;
v := @this: org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler;
v := @parameter: javax.security.auth.callback.Callback[];
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler: boolean configured()>();
if v != 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Callback handler not configured");
throw v;
label:
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = v instanceof org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerTokenCallback;
if v == 0 goto label;
specialinvoke v.<org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler: void handleCallback(org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerTokenCallback)>(v);
goto label;
label:
v = v instanceof org.apache.kafkaesqueesque.common.security.auth.SaslExtensionsCallback;
if v == 0 goto label;
v = staticinvoke <java.security.AccessController: java.security.AccessControlContext getContext()>();
v = staticinvoke <javax.security.auth.Subject: javax.security.auth.Subject getSubject(java.security.AccessControlContext)>(v);
staticinvoke <org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler: void handleCallback(org.apache.kafkaesqueesque.common.security.auth.SaslExtensionsCallback,javax.security.auth.Subject)>(v, 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)>(v);
throw v;
label:
v = v + 1;
goto label;
label:
return;
}
public void close()
{
org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler v;
v := @this: org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler;
return;
}
private void handleCallback(org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerTokenCallback) throws java.io.IOException
{
java.security.AccessControlContext v;
java.lang.Object[] v;
org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerTokenCallback v;
java.util.Date v, v;
long v, v;
java.lang.Integer v;
java.util.TreeSet v;
org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler v;
int v, v, v;
org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerToken v;
org.slf4j.Logger v;
java.util.Iterator v;
java.util.Set v;
java.io.IOException v;
java.lang.IllegalArgumentException v;
javax.security.auth.Subject v;
org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler$1 v;
java.lang.Object v, v, v, v;
v := @this: org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler;
v := @parameter: org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerTokenCallback;
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerTokenCallback: org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerToken token()>();
if v == null goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Callback had a token already");
throw v;
label:
v = staticinvoke <java.security.AccessController: java.security.AccessControlContext getContext()>();
v = staticinvoke <javax.security.auth.Subject: javax.security.auth.Subject getSubject(java.security.AccessControlContext)>(v);
if v == null goto label;
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPrivateCredentials(java.lang.Class)>(class "Lorg/apache/kafkaesqueesque/common/security/oauthbearer/OAuthBearerToken;");
goto label;
label:
v = staticinvoke <java.util.Collections: java.util.Set emptySet()>();
label:
v = interfaceinvoke v.<java.util.Set: int size()>();
if v != 0 goto label;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>("No OAuth Bearer tokens in Subject\'s private credentials");
throw v;
label:
v = interfaceinvoke v.<java.util.Set: int size()>();
if v != 1 goto label;
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.oauthbearer.OAuthBearerTokenCallback: void token(org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerToken)>(v);
goto label;
label:
v = new java.util.TreeSet;
v = new org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler$1;
specialinvoke v.<org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler$1: void <init>(org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler)>(v);
specialinvoke v.<java.util.TreeSet: void <init>(java.util.Comparator)>(v);
interfaceinvoke v.<java.util.SortedSet: boolean addAll(java.util.Collection)>(v);
v = <org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler: org.slf4j.Logger log>;
v = newarray (java.lang.Object)[3];
v = interfaceinvoke v.<java.util.SortedSet: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = new java.util.Date;
v = interfaceinvoke v.<java.util.SortedSet: java.lang.Object first()>();
v = interfaceinvoke v.<org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerToken: long lifetimeMs()>();
specialinvoke v.<java.util.Date: void <init>(long)>(v);
v[1] = v;
v = new java.util.Date;
v = interfaceinvoke v.<java.util.SortedSet: java.lang.Object last()>();
v = interfaceinvoke v.<org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerToken: long lifetimeMs()>();
specialinvoke v.<java.util.Date: void <init>(long)>(v);
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object[])>("Found {} OAuth Bearer tokens in Subject\'s private credentials; the oldest expires at {}, will use the newest, which expires at {}", v);
v = interfaceinvoke v.<java.util.SortedSet: java.lang.Object last()>();
virtualinvoke v.<org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerTokenCallback: void token(org.apache.kafkaesqueesque.common.security.oauthbearer.OAuthBearerToken)>(v);
label:
return;
}
private static void handleCallback(org.apache.kafkaesqueesque.common.security.auth.SaslExtensionsCallback, javax.security.auth.Subject)
{
java.util.Iterator v;
java.util.Set v, v;
java.lang.Object v;
javax.security.auth.Subject v;
org.apache.kafkaesqueesque.common.security.auth.SaslExtensionsCallback v;
boolean v;
v := @parameter: org.apache.kafkaesqueesque.common.security.auth.SaslExtensionsCallback;
v := @parameter: javax.security.auth.Subject;
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);
label:
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/kafkaesqueesque/common/security/oauthbearer/internals/OAuthBearerSaslClientCallbackHandler;");
<org.apache.kafkaesqueesque.common.security.oauthbearer.internals.OAuthBearerSaslClientCallbackHandler: org.slf4j.Logger log> = v;
return;
}
}