public class org.apache.kafkaesque.common.security.JaasContext extends java.lang.Object
{
private static final org.slf4j.Logger LOG;
private static final java.lang.String GLOBAL_CONTEXT_NAME_SERVER;
private static final java.lang.String GLOBAL_CONTEXT_NAME_CLIENT;
private final java.lang.String name;
private final org.apache.kafkaesque.common.security.JaasContext$Type type;
private final javax.security.auth.login.Configuration configuration;
private final java.util.List configurationEntries;
private final org.apache.kafkaesque.common.config.types.Password dynamicJaasConfig;
public static org.apache.kafkaesque.common.security.JaasContext loadServerContext(org.apache.kafkaesque.common.network.ListenerName, java.lang.String, java.util.Map)
{
org.apache.kafkaesque.common.network.ListenerName v;
org.apache.kafkaesque.common.security.JaasContext$Type v;
java.util.Locale v, v;
java.util.Map v;
java.lang.String v, v, v, v, v, v;
org.apache.kafkaesque.common.security.JaasContext v;
org.slf4j.Logger v;
java.lang.IllegalArgumentException v, v;
java.lang.Object v, v;
v := @parameter: org.apache.kafkaesque.common.network.ListenerName;
v := @parameter: java.lang.String;
v := @parameter: java.util.Map;
if v != null goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("listenerName should not be null for SERVER");
throw v;
label:
if v != null goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("mechanism should not be null for SERVER");
throw v;
label:
v = virtualinvoke v.<org.apache.kafkaesque.common.network.ListenerName: java.lang.String value()>();
v = <java.util.Locale: java.util.Locale ROOT>;
v = virtualinvoke v.<java.lang.String: java.lang.String toLowerCase(java.util.Locale)>(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[])>("\u.KafkaServer");
v = <java.util.Locale: java.util.Locale ROOT>;
v = virtualinvoke v.<java.lang.String: java.lang.String toLowerCase(java.util.Locale)>(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[])>("\u.sasl.jaas.config");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("sasl.jaas.config");
if v == null goto label;
v = <org.apache.kafkaesque.common.security.JaasContext: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object)>("Server config {} should be prefixed with SASL mechanism name, ignoring config", "sasl.jaas.config");
label:
v = <org.apache.kafkaesque.common.security.JaasContext$Type: org.apache.kafkaesque.common.security.JaasContext$Type SERVER>;
v = staticinvoke <org.apache.kafkaesque.common.security.JaasContext: org.apache.kafkaesque.common.security.JaasContext load(org.apache.kafkaesque.common.security.JaasContext$Type,java.lang.String,java.lang.String,org.apache.kafkaesque.common.config.types.Password)>(v, v, "KafkaServer", v);
return v;
}
public static org.apache.kafkaesque.common.security.JaasContext loadClientContext(java.util.Map)
{
org.apache.kafkaesque.common.security.JaasContext v;
java.util.Map v;
java.lang.Object v;
org.apache.kafkaesque.common.security.JaasContext$Type v;
v := @parameter: java.util.Map;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("sasl.jaas.config");
v = <org.apache.kafkaesque.common.security.JaasContext$Type: org.apache.kafkaesque.common.security.JaasContext$Type CLIENT>;
v = staticinvoke <org.apache.kafkaesque.common.security.JaasContext: org.apache.kafkaesque.common.security.JaasContext load(org.apache.kafkaesque.common.security.JaasContext$Type,java.lang.String,java.lang.String,org.apache.kafkaesque.common.config.types.Password)>(v, null, "KafkaClient", v);
return v;
}
static org.apache.kafkaesque.common.security.JaasContext load(org.apache.kafkaesque.common.security.JaasContext$Type, java.lang.String, java.lang.String, org.apache.kafkaesque.common.config.types.Password)
{
org.apache.kafkaesque.common.security.JaasContext v, v;
org.apache.kafkaesque.common.security.JaasConfig v;
java.lang.IllegalArgumentException v, v;
org.apache.kafkaesque.common.security.JaasContext$Type v;
javax.security.auth.login.AppConfigurationEntry[] v;
int v, v, v;
java.lang.String v, v, v, v;
org.apache.kafkaesque.common.config.types.Password v;
v := @parameter: org.apache.kafkaesque.common.security.JaasContext$Type;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesque.common.config.types.Password;
if v == null goto label;
v = new org.apache.kafkaesque.common.security.JaasConfig;
v = virtualinvoke v.<org.apache.kafkaesque.common.config.types.Password: java.lang.String value()>();
specialinvoke v.<org.apache.kafkaesque.common.security.JaasConfig: void <init>(java.lang.String,java.lang.String)>(v, v);
v = virtualinvoke v.<org.apache.kafkaesque.common.security.JaasConfig: javax.security.auth.login.AppConfigurationEntry[] getAppConfigurationEntry(java.lang.String)>(v);
if v == null goto label;
v = lengthof v;
if v != 0 goto label;
label:
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("JAAS config property does not contain any login modules");
throw v;
label:
v = lengthof v;
if v == 1 goto label;
v = new java.lang.IllegalArgumentException;
v = lengthof v;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("JAAS config property contains \u login modules, should be 1 module");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new org.apache.kafkaesque.common.security.JaasContext;
specialinvoke v.<org.apache.kafkaesque.common.security.JaasContext: void <init>(java.lang.String,org.apache.kafkaesque.common.security.JaasContext$Type,javax.security.auth.login.Configuration,org.apache.kafkaesque.common.config.types.Password)>(v, v, v, v);
return v;
label:
v = staticinvoke <org.apache.kafkaesque.common.security.JaasContext: org.apache.kafkaesque.common.security.JaasContext defaultContext(org.apache.kafkaesque.common.security.JaasContext$Type,java.lang.String,java.lang.String)>(v, v, v);
return v;
}
private static org.apache.kafkaesque.common.security.JaasContext defaultContext(org.apache.kafkaesque.common.security.JaasContext$Type, java.lang.String, java.lang.String)
{
org.apache.kafkaesque.common.security.JaasContext$Type v, v;
java.lang.String v, v, v, v, v, v, v, v;
javax.security.auth.login.Configuration v;
org.apache.kafkaesque.common.security.JaasContext v;
org.slf4j.Logger v, v;
java.lang.IllegalArgumentException v;
javax.security.auth.login.AppConfigurationEntry[] v;
v := @parameter: org.apache.kafkaesque.common.security.JaasContext$Type;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("java.security.auth.login.config");
if v != null goto label;
v = <org.apache.kafkaesque.common.security.JaasContext$Type: org.apache.kafkaesque.common.security.JaasContext$Type CLIENT>;
if v != v goto label;
v = <org.apache.kafkaesque.common.security.JaasContext: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("System property \'java.security.auth.login.config\' and Kafka SASL property \'sasl.jaas.config\' are not set, using default JAAS configuration.");
goto label;
label:
v = <org.apache.kafkaesque.common.security.JaasContext: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("System property \'java.security.auth.login.config\' is not set, using default JAAS configuration.");
label:
v = staticinvoke <javax.security.auth.login.Configuration: javax.security.auth.login.Configuration getConfiguration()>();
v = null;
v = v;
if v == null goto label;
v = virtualinvoke v.<javax.security.auth.login.Configuration: javax.security.auth.login.AppConfigurationEntry[] getAppConfigurationEntry(java.lang.String)>(v);
if v == null goto label;
v = v;
label:
if v != null goto label;
v = virtualinvoke v.<javax.security.auth.login.Configuration: javax.security.auth.login.AppConfigurationEntry[] getAppConfigurationEntry(java.lang.String)>(v);
if v != null goto label;
if v != null goto label;
v = "";
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[])>(" or \'\u0001\'");
label:
v = v;
if v != null goto label;
v = "not set";
goto label;
label:
v = v;
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,java.lang.String)>(v, 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[])>("Could not find a \'\u0001\'\u entry in the JAAS configuration. System property \'java.security.auth.login.config\' is \u0001");
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new org.apache.kafkaesque.common.security.JaasContext;
specialinvoke v.<org.apache.kafkaesque.common.security.JaasContext: void <init>(java.lang.String,org.apache.kafkaesque.common.security.JaasContext$Type,javax.security.auth.login.Configuration,org.apache.kafkaesque.common.config.types.Password)>(v, v, v, null);
return v;
}
public void <init>(java.lang.String, org.apache.kafkaesque.common.security.JaasContext$Type, javax.security.auth.login.Configuration, org.apache.kafkaesque.common.config.types.Password)
{
org.apache.kafkaesque.common.security.JaasContext v;
java.lang.IllegalArgumentException v;
org.apache.kafkaesque.common.security.JaasContext$Type v;
java.util.ArrayList v;
java.util.List v, v;
javax.security.auth.login.AppConfigurationEntry[] v;
java.lang.String v, v;
javax.security.auth.login.Configuration v;
org.apache.kafkaesque.common.config.types.Password v;
v := @this: org.apache.kafkaesque.common.security.JaasContext;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesque.common.security.JaasContext$Type;
v := @parameter: javax.security.auth.login.Configuration;
v := @parameter: org.apache.kafkaesque.common.config.types.Password;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.kafkaesque.common.security.JaasContext: java.lang.String name> = v;
v.<org.apache.kafkaesque.common.security.JaasContext: org.apache.kafkaesque.common.security.JaasContext$Type type> = v;
v.<org.apache.kafkaesque.common.security.JaasContext: javax.security.auth.login.Configuration configuration> = v;
v = virtualinvoke v.<javax.security.auth.login.Configuration: javax.security.auth.login.AppConfigurationEntry[] getAppConfigurationEntry(java.lang.String)>(v);
if v != null goto label;
v = new java.lang.IllegalArgumentException;
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[])>("Could not find a \'\u0001\' entry in this JAAS configuration.");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new java.util.ArrayList;
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = staticinvoke <java.util.Collections: java.util.List unmodifiableList(java.util.List)>(v);
v.<org.apache.kafkaesque.common.security.JaasContext: java.util.List configurationEntries> = v;
v.<org.apache.kafkaesque.common.security.JaasContext: org.apache.kafkaesque.common.config.types.Password dynamicJaasConfig> = v;
return;
}
public java.lang.String name()
{
org.apache.kafkaesque.common.security.JaasContext v;
java.lang.String v;
v := @this: org.apache.kafkaesque.common.security.JaasContext;
v = v.<org.apache.kafkaesque.common.security.JaasContext: java.lang.String name>;
return v;
}
public org.apache.kafkaesque.common.security.JaasContext$Type type()
{
org.apache.kafkaesque.common.security.JaasContext v;
org.apache.kafkaesque.common.security.JaasContext$Type v;
v := @this: org.apache.kafkaesque.common.security.JaasContext;
v = v.<org.apache.kafkaesque.common.security.JaasContext: org.apache.kafkaesque.common.security.JaasContext$Type type>;
return v;
}
public javax.security.auth.login.Configuration configuration()
{
org.apache.kafkaesque.common.security.JaasContext v;
javax.security.auth.login.Configuration v;
v := @this: org.apache.kafkaesque.common.security.JaasContext;
v = v.<org.apache.kafkaesque.common.security.JaasContext: javax.security.auth.login.Configuration configuration>;
return v;
}
public java.util.List configurationEntries()
{
org.apache.kafkaesque.common.security.JaasContext v;
java.util.List v;
v := @this: org.apache.kafkaesque.common.security.JaasContext;
v = v.<org.apache.kafkaesque.common.security.JaasContext: java.util.List configurationEntries>;
return v;
}
public org.apache.kafkaesque.common.config.types.Password dynamicJaasConfig()
{
org.apache.kafkaesque.common.security.JaasContext v;
org.apache.kafkaesque.common.config.types.Password v;
v := @this: org.apache.kafkaesque.common.security.JaasContext;
v = v.<org.apache.kafkaesque.common.security.JaasContext: org.apache.kafkaesque.common.config.types.Password dynamicJaasConfig>;
return v;
}
public static java.lang.String configEntryOption(java.util.List, java.lang.String, java.lang.String)
{
java.util.Iterator v;
java.util.List v;
java.util.Map v;
java.lang.Object v, v;
java.lang.String v, v, v;
boolean v, v;
v := @parameter: java.util.List;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = interfaceinvoke v.<java.util.List: 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()>();
if v == null goto label;
v = virtualinvoke v.<javax.security.auth.login.AppConfigurationEntry: java.lang.String getLoginModuleName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
label:
v = virtualinvoke v.<javax.security.auth.login.AppConfigurationEntry: java.util.Map getOptions()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
return v;
label:
return null;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/kafkaesque/common/security/JaasContext;");
<org.apache.kafkaesque.common.security.JaasContext: org.slf4j.Logger LOG> = v;
return;
}
}