public class oadd.org.apache.hadoop.security.authentication.util.KerberosName extends java.lang.Object
{
private static final org.slf4j.Logger LOG;
public static final java.lang.String MECHANISM_HADOOP;
public static final java.lang.String MECHANISM_MIT;
public static final java.lang.String DEFAULT_MECHANISM;
private final java.lang.String serviceName;
private final java.lang.String hostName;
private final java.lang.String realm;
private static final java.util.regex.Pattern nameParser;
private static java.util.regex.Pattern parameterPattern;
private static final java.util.regex.Pattern ruleParser;
private static final java.util.regex.Pattern nonSimplePattern;
private static java.util.List rules;
private static java.lang.String ruleMechanism;
private static java.lang.String defaultRealm;
public static void resetDefaultRealm()
{
java.lang.String v;
org.slf4j.Logger v;
java.lang.Exception v;
label:
v = staticinvoke <oadd.org.apache.hadoop.security.authentication.util.KerberosUtil: java.lang.String getDefaultRealm()>();
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String defaultRealm> = v;
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>("resetting default realm failed, current default realm will still be used.", v);
label:
return;
catch java.lang.Exception from label to label with label;
}
public void <init>(java.lang.String)
{
java.lang.IllegalArgumentException v;
java.util.regex.Matcher v;
java.lang.String v, v, v, v, v;
java.util.regex.Pattern v;
oadd.org.apache.hadoop.security.authentication.util.KerberosName v;
boolean v, v;
v := @this: oadd.org.apache.hadoop.security.authentication.util.KerberosName;
v := @parameter: java.lang.String;
specialinvoke v.<java.lang.Object: void <init>()>();
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.regex.Pattern nameParser>;
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean matches()>();
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>("@");
if v == 0 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[])>("Malformed Kerberos name: \u0001");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String serviceName> = v;
v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String hostName> = null;
v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String realm> = null;
goto label;
label:
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(1);
v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String serviceName> = v;
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(3);
v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String hostName> = v;
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(5);
v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String realm> = v;
label:
return;
}
public static synchronized java.lang.String getDefaultRealm()
{
org.slf4j.Logger v;
java.lang.String v, v, v;
java.lang.Exception v;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String defaultRealm>;
if v != null goto label;
label:
v = staticinvoke <oadd.org.apache.hadoop.security.authentication.util.KerberosUtil: java.lang.String getDefaultRealm()>();
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String defaultRealm> = v;
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Kerberos krb configuration not found, setting default realm to empty");
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String defaultRealm> = "";
label:
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String defaultRealm>;
return v;
catch java.lang.Exception from label to label with label;
}
public java.lang.String toString()
{
java.lang.StringBuilder v;
java.lang.String v, v, v, v, v, v;
oadd.org.apache.hadoop.security.authentication.util.KerberosName v;
v := @this: oadd.org.apache.hadoop.security.authentication.util.KerberosName;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String serviceName>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String hostName>;
if v == null goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(47);
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String hostName>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String realm>;
if v == null goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(64);
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String realm>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
return v;
}
public java.lang.String getServiceName()
{
java.lang.String v;
oadd.org.apache.hadoop.security.authentication.util.KerberosName v;
v := @this: oadd.org.apache.hadoop.security.authentication.util.KerberosName;
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String serviceName>;
return v;
}
public java.lang.String getHostName()
{
java.lang.String v;
oadd.org.apache.hadoop.security.authentication.util.KerberosName v;
v := @this: oadd.org.apache.hadoop.security.authentication.util.KerberosName;
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String hostName>;
return v;
}
public java.lang.String getRealm()
{
java.lang.String v;
oadd.org.apache.hadoop.security.authentication.util.KerberosName v;
v := @this: oadd.org.apache.hadoop.security.authentication.util.KerberosName;
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String realm>;
return v;
}
static java.util.List parseRules(java.lang.String)
{
java.util.ArrayList v;
java.util.regex.Matcher v;
int v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v;
boolean v, v, v;
java.lang.IllegalArgumentException v;
oadd.org.apache.hadoop.security.authentication.util.KerberosName$Rule v, v;
java.util.regex.Pattern v;
v := @parameter: java.lang.String;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
label:
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.regex.Pattern ruleParser>;
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean lookingAt()>();
if v != 0 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[])>("Invalid rule: \u0001");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(2);
if v == null goto label;
v = new oadd.org.apache.hadoop.security.authentication.util.KerberosName$Rule;
specialinvoke v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName$Rule: void <init>()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = new oadd.org.apache.hadoop.security.authentication.util.KerberosName$Rule;
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(4);
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(5);
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(7);
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(9);
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(10);
v = "g";
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(11);
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
v = "L";
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(12);
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
specialinvoke v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName$Rule: void <init>(int,java.lang.String,java.lang.String,java.lang.String,java.lang.String,boolean,boolean)>(v, v, v, v, v, v, v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = virtualinvoke v.<java.util.regex.Matcher: int end()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
goto label;
label:
return v;
}
public java.lang.String getShortName() throws java.io.IOException
{
java.lang.String[] v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v;
boolean v, v;
org.slf4j.Logger v;
java.util.Iterator v;
oadd.org.apache.hadoop.security.authentication.util.KerberosName$NoMatchingRule v;
java.util.List v, v;
java.lang.Object v;
oadd.org.apache.hadoop.security.authentication.util.KerberosName v;
v := @this: oadd.org.apache.hadoop.security.authentication.util.KerberosName;
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String hostName>;
if v != null goto label;
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String realm>;
if v != null goto label;
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String serviceName>;
return v;
label:
v = newarray (java.lang.String)[2];
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String realm>;
v[0] = v;
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String serviceName>;
v[1] = v;
v = v;
goto label;
label:
v = newarray (java.lang.String)[3];
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String realm>;
v[0] = v;
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String serviceName>;
v[1] = v;
v = v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String hostName>;
v[2] = v;
v = v;
label:
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String ruleMechanism>;
if v != null goto label;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.List rules>;
if v == null goto label;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>("auth_to_local rule mechanism not set.Using default of hadoop");
v = "hadoop";
label:
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.List rules>;
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()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName$Rule: java.lang.String apply(java.lang.String[],java.lang.String)>(v, v);
if v == null goto label;
return v;
label:
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>("hadoop");
if v == 0 goto label;
v = new oadd.org.apache.hadoop.security.authentication.util.KerberosName$NoMatchingRule;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String toString()>();
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[])>("No rules applied to \u0001");
specialinvoke v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName$NoMatchingRule: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String toString()>();
return v;
}
public static java.lang.String getRules()
{
java.util.Iterator v;
java.util.List v, v;
java.lang.Object v;
java.lang.StringBuilder v, v;
java.lang.String v, v, v;
boolean v;
v = null;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.List rules>;
if v == null goto label;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.List rules>;
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()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName$Rule: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\n");
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
label:
return v;
}
public static boolean hasRulesBeenSet()
{
java.util.List v;
boolean v;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.List rules>;
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static boolean hasRuleMechanismBeenSet()
{
java.lang.String v;
boolean v;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String ruleMechanism>;
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static void setRules(java.lang.String)
{
java.util.List v;
java.lang.String v;
v := @parameter: java.lang.String;
if v == null goto label;
v = staticinvoke <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.List parseRules(java.lang.String)>(v);
goto label;
label:
v = null;
label:
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.List rules> = v;
return;
}
public static void setRuleMechanism(java.lang.String)
{
java.lang.String v, v;
java.lang.IllegalArgumentException v;
boolean v, v;
v := @parameter: java.lang.String;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>("hadoop");
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>("mit");
if v != 0 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[])>("Invalid rule mechanism: \u0001");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String ruleMechanism> = v;
return;
}
public static java.lang.String getRuleMechanism()
{
java.lang.String v;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String ruleMechanism>;
return v;
}
static void printRules() throws java.io.IOException
{
java.io.PrintStream v;
java.util.List v;
java.util.Iterator v;
int v;
java.lang.Object v;
java.lang.String v;
boolean v;
v = 0;
v = <oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.List rules>;
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()>();
v = <java.lang.System: java.io.PrintStream out>;
v = v + 1;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,oadd.org.apache.hadoop.security.authentication.util.KerberosName$Rule)>(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[])>("\u \u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
goto label;
label:
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
java.util.regex.Pattern v, v, v, v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Loadd/org/apache/hadoop/security/authentication/util/KerberosName;");
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: org.slf4j.Logger LOG> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("([^/@]+)(/([^/@]+))?(@([^/@]+))?");
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.regex.Pattern nameParser> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("([^$]*)(\\$(\\d*))?");
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.regex.Pattern parameterPattern> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("\\s*((DEFAULT)|(RULE:\\[(\\d*):([^\\]]*)](\\(([^)]*)\\))?(s/([^/]*)/([^/]*)/(g)?)?))/?(L)?");
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.regex.Pattern ruleParser> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("[/@]");
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.util.regex.Pattern nonSimplePattern> = v;
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String ruleMechanism> = null;
<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String defaultRealm> = null;
return;
}
}