public class org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler extends java.lang.Object implements org.apache.kafkaesque.common.security.auth.AuthenticateCallbackHandler
{
private final org.slf4j.Logger log;
private static final java.lang.String OPTION_PREFIX;
private static final java.lang.String PRINCIPAL_CLAIM_NAME_OPTION;
private static final java.lang.String LIFETIME_SECONDS_OPTION;
private static final java.lang.String SCOPE_CLAIM_NAME_OPTION;
private static final java.util.Set RESERVED_CLAIMS;
private static final java.lang.String DEFAULT_PRINCIPAL_CLAIM_NAME;
private static final java.lang.String DEFAULT_LIFETIME_SECONDS_ONE_HOUR;
private static final java.lang.String DEFAULT_SCOPE_CLAIM_NAME;
private static final java.lang.String STRING_CLAIM_PREFIX;
private static final java.lang.String NUMBER_CLAIM_PREFIX;
private static final java.lang.String LIST_CLAIM_PREFIX;
private static final java.lang.String EXTENSION_PREFIX;
private static final java.lang.String QUOTE;
private org.apache.kafkaesque.common.utils.Time time;
private java.util.Map moduleOptions;
private boolean configured;
private static final java.util.regex.Pattern DOUBLEQUOTE;
private static final java.util.regex.Pattern BACKSLASH;
public void <init>()
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
org.apache.kafkaesque.common.utils.Time v;
org.slf4j.Logger v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
specialinvoke v.<java.lang.Object: void <init>()>();
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/kafkaesque/common/security/oauthbearer/internals/unsecured/OAuthBearerUnsecuredLoginCallbackHandler;");
v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: org.slf4j.Logger log> = v;
v = <org.apache.kafkaesque.common.utils.Time: org.apache.kafkaesque.common.utils.Time SYSTEM>;
v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: org.apache.kafkaesque.common.utils.Time time> = v;
v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.Map moduleOptions> = null;
v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: boolean configured> = 0;
return;
}
void time(org.apache.kafkaesque.common.utils.Time)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.Object v;
org.apache.kafkaesque.common.utils.Time v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: org.apache.kafkaesque.common.utils.Time;
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object)>(v);
v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: org.apache.kafkaesque.common.utils.Time time> = v;
return;
}
public boolean configured()
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
boolean v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: boolean configured>;
return v;
}
public void configure(java.util.Map, java.lang.String, java.util.List)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.Object[] v, v;
java.lang.Integer v;
java.util.Map v, v, v;
int v, v;
java.lang.String v, v, v, v;
boolean v;
java.lang.IllegalArgumentException v, v;
java.util.List v;
java.lang.Object v, v, v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
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 = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
if v != 1 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
if v != null goto label;
label:
v = new java.lang.IllegalArgumentException;
v = newarray (java.lang.Object)[1];
v = interfaceinvoke v.<java.util.List: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Must supply exactly 1 non-null JAAS mechanism configuration (size was %d)", v);
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = virtualinvoke v.<javax.security.auth.login.AppConfigurationEntry: java.util.Map getOptions()>();
v = staticinvoke <java.util.Collections: java.util.Map unmodifiableMap(java.util.Map)>(v);
v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.Map moduleOptions> = v;
v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: boolean configured> = 1;
return;
}
public void handle(javax.security.auth.callback.Callback[]) throws java.io.IOException, javax.security.auth.callback.UnsupportedCallbackException
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.IllegalStateException v;
javax.security.auth.callback.UnsupportedCallbackException v;
javax.security.auth.callback.Callback[] v;
int v, v;
org.apache.kafkaesque.common.KafkaException v, v;
java.lang.String v, v;
boolean v, v, v;
java.io.IOException v, v;
javax.security.auth.callback.Callback v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: javax.security.auth.callback.Callback[];
v = virtualinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: 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.kafkaesque.common.security.oauthbearer.OAuthBearerTokenCallback;
if v == 0 goto label;
label:
specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: void handleTokenCallback(org.apache.kafkaesque.common.security.oauthbearer.OAuthBearerTokenCallback)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.io.IOException;
v = virtualinvoke v.<org.apache.kafkaesque.common.KafkaException: java.lang.String getMessage()>();
specialinvoke v.<java.io.IOException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v = v instanceof org.apache.kafkaesque.common.security.auth.SaslExtensionsCallback;
if v == 0 goto label;
label:
specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: void handleExtensionsCallback(org.apache.kafkaesque.common.security.auth.SaslExtensionsCallback)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.io.IOException;
v = virtualinvoke v.<org.apache.kafkaesque.common.KafkaException: java.lang.String getMessage()>();
specialinvoke v.<java.io.IOException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
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;
catch org.apache.kafkaesque.common.KafkaException from label to label with label;
catch org.apache.kafkaesque.common.KafkaException from label to label with label;
}
public void close()
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
return;
}
private void handleTokenCallback(org.apache.kafkaesque.common.security.oauthbearer.OAuthBearerTokenCallback)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
byte[] v, v;
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredJws v;
java.util.Map v, v;
org.apache.kafkaesque.common.security.oauthbearer.OAuthBearerTokenCallback v;
boolean v, v, v, v;
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException v, v, v;
java.util.function.Predicate v;
java.util.Set v;
java.util.stream.Stream v;
java.lang.Object[] v, v;
java.lang.Double v;
long v, v;
java.nio.charset.Charset v, v;
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerIllegalTokenException v;
org.apache.kafkaesque.common.utils.Time v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
double v;
org.slf4j.Logger v, v;
java.lang.NumberFormatException v;
java.util.Base64$Encoder v, v;
java.lang.IllegalArgumentException v;
org.apache.kafkaesque.common.security.oauthbearer.OAuthBearerToken v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: org.apache.kafkaesque.common.security.oauthbearer.OAuthBearerTokenCallback;
v = virtualinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.OAuthBearerTokenCallback: org.apache.kafkaesque.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 = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.Map moduleOptions>;
v = interfaceinvoke v.<java.util.Map: boolean isEmpty()>();
if v == 0 goto label;
v = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Token not provided, this login cannot be used to establish client connections");
virtualinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.OAuthBearerTokenCallback: void token(org.apache.kafkaesque.common.security.oauthbearer.OAuthBearerToken)>(null);
return;
label:
v = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.Map moduleOptions>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.stream.Stream stream()>();
v = staticinvoke <org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler$lambda_handleTokenCallback_0__1004: java.util.function.Predicate bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: boolean noneMatch(java.util.function.Predicate)>(v);
if v == 0 goto label;
v = new org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException;
specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException: void <init>(java.lang.String)>("Extensions provided in login context without a token");
throw v;
label:
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String optionValue(java.lang.String)>("unsecuredLoginPrincipalClaimName");
if v == null goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
goto label;
label:
v = "sub";
label:
v = v;
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String optionValue(java.lang.String)>("unsecuredLoginScopeClaimName");
if v == null goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
goto label;
label:
v = "scope";
label:
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String claimOrHeaderJsonText(java.lang.String,java.lang.String)>("alg", "none");
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[])>("{\u0001}");
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String optionValue(java.lang.String,java.lang.String)>("unsecuredLoginLifetimeSeconds", "3600");
label:
v = newarray (java.lang.Object)[3];
v = staticinvoke <java.lang.Long: long parseLong(java.lang.String)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String expClaimText(long)>(v);
v[0] = v;
v = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: org.apache.kafkaesque.common.utils.Time time>;
v = interfaceinvoke v.<org.apache.kafkaesque.common.utils.Time: long milliseconds()>();
v = v / 1000.0;
v = staticinvoke <java.lang.Double: java.lang.Double valueOf(double)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String claimOrHeaderJsonText(java.lang.String,java.lang.Number)>("iat", v);
v[1] = v;
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String commaPrependedStringNumberAndListClaimsJsonText()>();
v[2] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("{%s,%s%s}", v);
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException;
v = virtualinvoke v.<java.lang.NumberFormatException: java.lang.String getMessage()>();
specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException: void <init>(java.lang.String)>(v);
throw v;
label:
v = staticinvoke <java.util.Base64: java.util.Base64$Encoder getUrlEncoder()>();
v = virtualinvoke v.<java.util.Base64$Encoder: java.util.Base64$Encoder withoutPadding()>();
v = new org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredJws;
v = newarray (java.lang.Object)[2];
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset UTF_8>;
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.nio.charset.Charset)>(v);
v = virtualinvoke v.<java.util.Base64$Encoder: java.lang.String encodeToString(byte[])>(v);
v[0] = v;
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset UTF_8>;
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.nio.charset.Charset)>(v);
v = virtualinvoke v.<java.util.Base64$Encoder: java.lang.String encodeToString(byte[])>(v);
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("%s.%s.", v);
specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredJws: void <init>(java.lang.String,java.lang.String,java.lang.String)>(v, v, v);
v = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: org.slf4j.Logger log>;
v = virtualinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredJws: java.lang.String principalName()>();
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("Retrieved token with principal {}", v);
virtualinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.OAuthBearerTokenCallback: void token(org.apache.kafkaesque.common.security.oauthbearer.OAuthBearerToken)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException;
v = virtualinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerIllegalTokenException: java.lang.String getMessage()>();
specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch java.lang.NumberFormatException from label to label with label;
catch org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerIllegalTokenException from label to label with label;
}
private void handleExtensionsCallback(org.apache.kafkaesque.common.security.auth.SaslExtensionsCallback)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.util.HashMap v;
javax.security.sasl.SaslException v;
java.util.Map v;
int v;
java.lang.String v, v, v;
boolean v, v;
java.util.Iterator v;
java.util.Set v;
org.apache.kafkaesque.common.config.ConfigException v;
org.apache.kafkaesque.common.security.auth.SaslExtensions v;
org.apache.kafkaesque.common.security.auth.SaslExtensionsCallback v;
java.lang.Object v, v, v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: org.apache.kafkaesque.common.security.auth.SaslExtensionsCallback;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.Map moduleOptions>;
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 = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("unsecuredLoginExtension_");
if v == 0 goto label;
v = "unsecuredLoginExtension_";
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = new org.apache.kafkaesque.common.security.auth.SaslExtensions;
specialinvoke v.<org.apache.kafkaesque.common.security.auth.SaslExtensions: void <init>(java.util.Map)>(v);
label:
staticinvoke <org.apache.kafkaesque.common.security.oauthbearer.internals.OAuthBearerClientInitialResponse: void validateExtensions(org.apache.kafkaesque.common.security.auth.SaslExtensions)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.kafkaesque.common.config.ConfigException;
v = virtualinvoke v.<javax.security.sasl.SaslException: java.lang.String getMessage()>();
specialinvoke v.<org.apache.kafkaesque.common.config.ConfigException: void <init>(java.lang.String)>(v);
throw v;
label:
virtualinvoke v.<org.apache.kafkaesque.common.security.auth.SaslExtensionsCallback: void extensions(org.apache.kafkaesque.common.security.auth.SaslExtensions)>(v);
return;
catch javax.security.sasl.SaslException from label to label with label;
}
private java.lang.String commaPrependedStringNumberAndListClaimsJsonText() throws org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.util.Map v;
boolean v, v, v, v;
java.util.Set v;
java.lang.StringBuilder v, v, v, v;
java.lang.Double v;
int v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.Iterator v;
java.lang.Object v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.Map moduleOptions>;
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 = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("unsecuredLoginStringClaim_");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = "unsecuredLoginStringClaim_";
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= v goto label;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(44);
v = "unsecuredLoginStringClaim_";
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String confirmNotReservedClaimName(java.lang.String)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String optionValue(java.lang.String)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String claimOrHeaderJsonText(java.lang.String,java.lang.String)>(v, v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("unsecuredLoginNumberClaim_");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = "unsecuredLoginNumberClaim_";
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= v goto label;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(44);
v = "unsecuredLoginNumberClaim_";
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String confirmNotReservedClaimName(java.lang.String)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String optionValue(java.lang.String)>(v);
v = staticinvoke <java.lang.Double: java.lang.Double valueOf(java.lang.String)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String claimOrHeaderJsonText(java.lang.String,java.lang.Number)>(v, v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("unsecuredLoginListClaim_");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = "unsecuredLoginListClaim_";
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= v goto label;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(44);
v = "unsecuredLoginListClaim_";
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String confirmNotReservedClaimName(java.lang.String)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String optionValue(java.lang.String)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String listJsonText(java.lang.String)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String claimOrHeaderJsonArrayText(java.lang.String,java.lang.String)>(v, v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
return v;
}
private java.lang.String confirmNotReservedClaimName(java.lang.String) throws org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.Object[] v;
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException v;
java.util.Set v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: java.lang.String;
v = <org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.Set RESERVED_CLAIMS>;
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = new org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Cannot explicitly set the \'%s\' claim", v);
specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerConfigException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
}
private java.lang.String listJsonText(java.lang.String)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
byte v;
boolean v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.StringBuilder v, v, v, v;
java.lang.String[] v;
int v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v;
char v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v > 1 goto label;
label:
return "[]";
label:
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, 1);
v = -1;
v = virtualinvoke v.<java.lang.String: int hashCode()>();
lookupswitch(v)
{
case 36: goto label;
case 40: goto label;
case 46: goto label;
case 91: goto label;
case 92: goto label;
case 94: goto label;
case 123: goto label;
case 124: goto label;
default: goto label;
};
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("\\");
if v == 0 goto label;
v = 0;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(".");
if v == 0 goto label;
v = 1;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("[");
if v == 0 goto label;
v = 2;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("(");
if v == 0 goto label;
v = 3;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("{");
if v == 0 goto label;
v = 4;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("|");
if v == 0 goto label;
v = 5;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("^");
if v == 0 goto label;
v = 6;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("$");
if v == 0 goto label;
v = 7;
label:
tableswitch(v)
{
case 0: goto label;
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
case 5: goto label;
case 6: goto label;
case 7: goto label;
default: goto label;
};
label:
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[])>("\\\u0001");
goto label;
label:
v = v;
label:
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(1);
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(v);
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.StringBuilder: int length()>();
if v != 0 goto label;
v = 91;
goto label;
label:
v = 44;
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(34);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String escape(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(34);
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>(v);
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>(v);
if v != 0 goto label;
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 = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>(v);
if v == 0 goto label;
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(",\"\"");
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(93);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
return v;
}
private java.lang.String optionValue(java.lang.String)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.String v, v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: java.lang.String;
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String optionValue(java.lang.String,java.lang.String)>(v, null);
return v;
}
private java.lang.String optionValue(java.lang.String, java.lang.String)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.String v, v, v, v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String option(java.lang.String)>(v);
if v == null goto label;
v = v;
goto label;
label:
v = v;
label:
return v;
}
private java.lang.String option(java.lang.String)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.IllegalStateException v;
java.util.Map v;
java.lang.Object v, v;
java.lang.String v;
boolean v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: java.lang.String;
v = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: 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 = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.Map moduleOptions>;
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
return v;
}
private java.lang.String claimOrHeaderJsonText(java.lang.String, java.lang.Number)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.String v, v, v;
java.lang.Number v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Number;
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String escape(java.lang.String)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.Number)>(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");
return v;
}
private java.lang.String claimOrHeaderJsonText(java.lang.String, java.lang.String)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.String v, v, v, v, v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String escape(java.lang.String)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String escape(java.lang.String)>(v);
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\"");
return v;
}
private java.lang.String claimOrHeaderJsonArrayText(java.lang.String, java.lang.String)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.Object[] v;
java.lang.IllegalArgumentException v;
java.lang.String v, v, v, v, v;
boolean v, v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("[");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>("]");
if v != 0 goto label;
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[])>("Illegal JSON array: %s", v);
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String escape(java.lang.String)>(v);
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");
return v;
}
private java.lang.String escape(java.lang.String)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.util.regex.Matcher v, v;
java.lang.String v, v, v, v, v;
java.util.regex.Pattern v, v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: java.lang.String;
v = <org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.regex.Pattern DOUBLEQUOTE>;
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = staticinvoke <java.util.regex.Matcher: java.lang.String quoteReplacement(java.lang.String)>("\\\"");
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String replaceAll(java.lang.String)>(v);
v = <org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.regex.Pattern BACKSLASH>;
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = staticinvoke <java.util.regex.Matcher: java.lang.String quoteReplacement(java.lang.String)>("\\\\");
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String replaceAll(java.lang.String)>(v);
return v;
}
private java.lang.String expClaimText(long)
{
org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler v;
java.lang.Double v;
long v, v;
org.apache.kafkaesque.common.utils.Time v;
java.lang.String v;
double v, v;
v := @this: org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler;
v := @parameter: long;
v = v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: org.apache.kafkaesque.common.utils.Time time>;
v = interfaceinvoke v.<org.apache.kafkaesque.common.utils.Time: long milliseconds()>();
v = v / 1000.0;
v = v + v;
v = staticinvoke <java.lang.Double: java.lang.Double valueOf(double)>(v);
v = specialinvoke v.<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.lang.String claimOrHeaderJsonText(java.lang.String,java.lang.Number)>("exp", v);
return v;
}
static void <clinit>()
{
java.util.HashSet v;
java.util.List v;
java.util.Set v;
java.lang.String[] v;
java.util.regex.Pattern v, v;
v = new java.util.HashSet;
v = newarray (java.lang.String)[2];
v[0] = "iat";
v[1] = "exp";
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
specialinvoke v.<java.util.HashSet: void <init>(java.util.Collection)>(v);
v = staticinvoke <java.util.Collections: java.util.Set unmodifiableSet(java.util.Set)>(v);
<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.Set RESERVED_CLAIMS> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String,int)>("\"", 16);
<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.regex.Pattern DOUBLEQUOTE> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String,int)>("\\", 16);
<org.apache.kafkaesque.common.security.oauthbearer.internals.unsecured.OAuthBearerUnsecuredLoginCallbackHandler: java.util.regex.Pattern BACKSLASH> = v;
return;
}
}