public class oadd.org.apache.hadoop.security.KDiag extends oadd.org.apache.hadoop.conf.Configured implements oadd.org.apache.hadoop.util.Tool, java.io.Closeable
{
private static final org.slf4j.Logger LOG;
public static final java.lang.String KRB5_CCNAME;
public static final java.lang.String KRB5_CONFIG;
public static final java.lang.String JAVA_SECURITY_KRB5_CONF;
public static final java.lang.String JAVA_SECURITY_KRB5_REALM;
public static final java.lang.String JAVA_SECURITY_KRB5_KDC_ADDRESS;
public static final java.lang.String SUN_SECURITY_KRB5_DEBUG;
public static final java.lang.String SUN_SECURITY_SPNEGO_DEBUG;
public static final java.lang.String SUN_SECURITY_JAAS_FILE;
public static final java.lang.String KERBEROS_KINIT_COMMAND;
public static final java.lang.String HADOOP_AUTHENTICATION_IS_DISABLED;
public static final java.lang.String UNSET;
public static final java.lang.String NO_DEFAULT_REALM;
public static final int KDIAG_FAILURE;
public static final java.lang.String DFS_DATA_TRANSFER_SASLPROPERTIES_RESOLVER_CLASS;
public static final java.lang.String DFS_DATA_TRANSFER_PROTECTION;
public static final java.lang.String ETC_KRB5_CONF;
public static final java.lang.String ETC_NTP;
public static final java.lang.String HADOOP_JAAS_DEBUG;
private java.io.PrintWriter out;
private java.io.File keytab;
private java.lang.String principal;
private long minKeyLength;
private boolean securityRequired;
private boolean nofail;
private boolean nologin;
private boolean jaas;
private boolean checkShortName;
private static final java.util.regex.Pattern nonSimplePattern;
private boolean probeHasFailed;
public static final java.lang.String CAT_CONFIG;
public static final java.lang.String CAT_JAAS;
public static final java.lang.String CAT_JVM;
public static final java.lang.String CAT_KERBEROS;
public static final java.lang.String CAT_LOGIN;
public static final java.lang.String CAT_OS;
public static final java.lang.String CAT_SASL;
public static final java.lang.String CAT_UGI;
public static final java.lang.String CAT_TOKEN;
public static final java.lang.String ARG_KEYLEN;
public static final java.lang.String ARG_KEYTAB;
public static final java.lang.String ARG_JAAS;
public static final java.lang.String ARG_NOFAIL;
public static final java.lang.String ARG_NOLOGIN;
public static final java.lang.String ARG_OUTPUT;
public static final java.lang.String ARG_PRINCIPAL;
public static final java.lang.String ARG_RESOURCE;
public static final java.lang.String ARG_SECURE;
public static final java.lang.String ARG_VERIFYSHORTNAME;
public void <init>(oadd.org.apache.hadoop.conf.Configuration, java.io.PrintWriter, java.io.File, java.lang.String, long, boolean)
{
java.io.PrintWriter v;
long v;
oadd.org.apache.hadoop.conf.Configuration v;
java.lang.String v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
v := @parameter: java.io.PrintWriter;
v := @parameter: java.io.File;
v := @parameter: java.lang.String;
v := @parameter: long;
v := @parameter: boolean;
specialinvoke v.<oadd.org.apache.hadoop.conf.Configured: void <init>(oadd.org.apache.hadoop.conf.Configuration)>(v);
v.<oadd.org.apache.hadoop.security.KDiag: long minKeyLength> = 256L;
v.<oadd.org.apache.hadoop.security.KDiag: boolean nofail> = 0;
v.<oadd.org.apache.hadoop.security.KDiag: boolean nologin> = 0;
v.<oadd.org.apache.hadoop.security.KDiag: boolean jaas> = 0;
v.<oadd.org.apache.hadoop.security.KDiag: boolean checkShortName> = 0;
v.<oadd.org.apache.hadoop.security.KDiag: boolean probeHasFailed> = 0;
v.<oadd.org.apache.hadoop.security.KDiag: java.io.File keytab> = v;
v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal> = v;
v.<oadd.org.apache.hadoop.security.KDiag: java.io.PrintWriter out> = v;
v.<oadd.org.apache.hadoop.security.KDiag: long minKeyLength> = v;
v.<oadd.org.apache.hadoop.security.KDiag: boolean securityRequired> = v;
return;
}
public void <init>()
{
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
specialinvoke v.<oadd.org.apache.hadoop.conf.Configured: void <init>()>();
v.<oadd.org.apache.hadoop.security.KDiag: long minKeyLength> = 256L;
v.<oadd.org.apache.hadoop.security.KDiag: boolean nofail> = 0;
v.<oadd.org.apache.hadoop.security.KDiag: boolean nologin> = 0;
v.<oadd.org.apache.hadoop.security.KDiag: boolean jaas> = 0;
v.<oadd.org.apache.hadoop.security.KDiag: boolean checkShortName> = 0;
v.<oadd.org.apache.hadoop.security.KDiag: boolean probeHasFailed> = 0;
return;
}
public void close() throws java.io.IOException
{
java.io.PrintWriter v, v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void flush()>();
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.PrintWriter out>;
if v == null goto label;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.PrintWriter out>;
virtualinvoke v.<java.io.PrintWriter: void close()>();
label:
return;
}
public int run(java.lang.String[]) throws java.lang.Exception
{
byte v;
boolean v, v, v, v, v, v, v, v, v, v;
java.io.PrintWriter v;
oadd.org.apache.hadoop.security.KDiag v;
java.util.List v;
java.lang.ClassLoader v;
java.lang.Throwable v;
java.lang.Object[] v, v, v, v, v;
java.lang.String[] v;
int v, v;
java.lang.String v, v, v, v, v, v;
java.util.LinkedList v;
org.slf4j.Logger v;
java.util.Iterator v;
java.io.File v, v;
java.lang.Class v;
java.lang.Object v;
java.io.InputStream v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String[];
v = new java.util.LinkedList;
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
specialinvoke v.<java.util.LinkedList: void <init>(java.util.Collection)>(v);
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String popOptionWithArgument(java.lang.String,java.util.List)>("--keytab", v);
if v == null goto label;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v.<oadd.org.apache.hadoop.security.KDiag: java.io.File keytab> = v;
label:
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String popOptionWithArgument(java.lang.String,java.util.List)>("--principal", v);
v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal> = v;
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String popOptionWithArgument(java.lang.String,java.util.List)>("--out", v);
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String popOptionWithArgument(java.lang.String,java.util.List)>("--keylen", v);
if v == null goto label;
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
v.<oadd.org.apache.hadoop.security.KDiag: long minKeyLength> = v;
label:
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: boolean popOption(java.lang.String,java.util.List)>("--secure", v);
v.<oadd.org.apache.hadoop.security.KDiag: boolean securityRequired> = v;
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: boolean popOption(java.lang.String,java.util.List)>("--nofail", v);
v.<oadd.org.apache.hadoop.security.KDiag: boolean nofail> = v;
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: boolean popOption(java.lang.String,java.util.List)>("--jaas", v);
v.<oadd.org.apache.hadoop.security.KDiag: boolean jaas> = v;
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: boolean popOption(java.lang.String,java.util.List)>("--nologin", v);
v.<oadd.org.apache.hadoop.security.KDiag: boolean nologin> = v;
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: boolean popOption(java.lang.String,java.util.List)>("--verifyshortname", v);
v.<oadd.org.apache.hadoop.security.KDiag: boolean checkShortName> = v;
label:
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String popOptionWithArgument(java.lang.String,java.util.List)>("--resource", v);
if null == v goto label;
v = <oadd.org.apache.hadoop.security.KDiag: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("Loading resource {}", v);
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
v = virtualinvoke v.<java.lang.ClassLoader: java.io.InputStream getResourceAsStream(java.lang.String)>(v);
label:
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = newarray (java.lang.Object)[1];
v[0] = v;
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, "CONFIG", "No resource %s", v);
if v == 0 goto label;
staticinvoke <oadd.org.apache.hadoop.conf.Configuration: void addDefaultResource(java.lang.String)>(v);
label:
if v == null goto label;
virtualinvoke v.<java.io.InputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Unknown arguments in command:", v);
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 = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("  \"%s\"", v);
goto label;
label:
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println()>();
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String usage()>();
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>(v, v);
v = (int) -1;
return v;
label:
if v == null goto label;
v = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Printing output to %s", v);
v = new java.io.PrintWriter;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
specialinvoke v.<java.io.PrintWriter: void <init>(java.io.File,java.lang.String)>(v, "UTF-8");
v.<oadd.org.apache.hadoop.security.KDiag: java.io.PrintWriter out> = v;
label:
virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean execute()>();
v = v.<oadd.org.apache.hadoop.security.KDiag: boolean probeHasFailed>;
if v == 0 goto label;
v = 41;
goto label;
label:
v = 0;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
private java.lang.String usage()
{
long v;
oadd.org.apache.hadoop.security.KDiag v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String arg(java.lang.String,java.lang.String,java.lang.String)>("-D", "key=value", "Define a configuration option");
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String arg(java.lang.String,java.lang.String,java.lang.String)>("--jaas", "", "Require a JAAS file to be defined in java.security.auth.login.config");
v = v.<oadd.org.apache.hadoop.security.KDiag: long minKeyLength>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long)>(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[])>("Require a minimum size for encryption keys supported by the JVM. Default value : \u0001");
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String arg(java.lang.String,java.lang.String,java.lang.String)>("--keylen", "<keylen>", v);
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String arg(java.lang.String,java.lang.String,java.lang.String)>("--keytab", "<keytab> --principal <principal>", "Login from a keytab as a specific principal");
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String arg(java.lang.String,java.lang.String,java.lang.String)>("--nofail", "", "Do not fail on the first problem");
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String arg(java.lang.String,java.lang.String,java.lang.String)>("--nologin", "", "Do not attempt to log in");
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String arg(java.lang.String,java.lang.String,java.lang.String)>("--out", "<file>", "Write output to a file");
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String arg(java.lang.String,java.lang.String,java.lang.String)>("--resource", "<resource>", "Load an XML configuration resource");
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String arg(java.lang.String,java.lang.String,java.lang.String)>("--secure", "", "Require the hadoop configuration to be secure");
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String arg(java.lang.String,java.lang.String,java.lang.String)>("--verifyshortname", "--principal <principal>", "Verify the short name of the specific principal does not contain \'@\' or \'/\'");
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lang.String)>(v, v, v, v, v, v, v, 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[])>("KDiag: Diagnose Kerberos Problems\n\u0001\u0001\u0001\u0001\u0001\u0001\u0001\u0001\u0001\u0001");
return v;
}
private java.lang.String arg(java.lang.String, java.lang.String, java.lang.String)
{
java.lang.Object[] v;
oadd.org.apache.hadoop.security.KDiag v;
java.lang.String v, v, v, v, v, v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = newarray (java.lang.Object)[4];
v[0] = v;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = " ";
goto label;
label:
v = "";
label:
v[1] = v;
v[2] = v;
v[3] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("  [%s%s%s] : %s", 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.\n");
return v;
}
public boolean execute() throws java.lang.Exception
{
java.net.InetAddress v;
java.lang.Long v;
oadd.org.apache.hadoop.conf.Configuration v, v;
java.util.Set v;
oadd.org.apache.hadoop.security.KDiag v;
java.lang.Throwable v;
java.lang.Object[] v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
long v, v;
java.util.ArrayList v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v;
java.util.Properties v;
oadd.org.apache.hadoop.security.UserGroupInformation v;
java.io.File v, v, v;
java.util.Date v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.String[] v, v, v;
int v, v, v, v, v, v;
java.lang.Boolean v, v, v;
org.slf4j.Logger v, v;
java.util.Iterator v;
java.lang.Object v;
java.util.Comparator v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v = newarray (java.lang.Object)[1];
v = new java.util.Date;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
specialinvoke v.<java.util.Date: void <init>(long)>(v);
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Kerberos Diagnostics scan at %s", v);
v = newarray (java.lang.Object)[1];
v = staticinvoke <java.net.InetAddress: java.net.InetAddress getLocalHost()>();
v = virtualinvoke v.<java.net.InetAddress: java.lang.String getCanonicalHostName()>();
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Hostname = %s", v);
v = newarray (java.lang.Object)[2];
v[0] = "--keylen";
v = v.<oadd.org.apache.hadoop.security.KDiag: long minKeyLength>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("%s = %d", v);
v = newarray (java.lang.Object)[2];
v[0] = "--keytab";
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.File keytab>;
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("%s = %s", v);
v = newarray (java.lang.Object)[2];
v[0] = "--principal";
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("%s = %s", v);
v = newarray (java.lang.Object)[2];
v[0] = "--verifyshortname";
v = v.<oadd.org.apache.hadoop.security.KDiag: boolean checkShortName>;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("%s = %s", v);
virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateKeyLength()>();
v = newarray (java.lang.Object)[1];
v = staticinvoke <oadd.org.apache.hadoop.security.authentication.util.KerberosUtil: java.lang.String getKrb5LoginModuleName()>();
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("JVM Kerberos Login Module = %s", v);
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Core System Properties", v);
v = newarray (java.lang.String)[9];
v[0] = "user.name";
v[1] = "java.version";
v[2] = "java.vendor";
v[3] = "java.security.krb.conf";
v[4] = "java.security.krb.realm";
v[5] = "java.security.krb.kdc";
v[6] = "sun.security.krb.debug";
v[7] = "sun.security.spnego.debug";
v[8] = "java.security.auth.login.config";
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void printSysprop(java.lang.String)>(v);
v = v + 1;
goto label;
label:
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void endln()>();
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("All System Properties", v);
v = new java.util.ArrayList;
v = staticinvoke <java.lang.System: java.util.Properties getProperties()>();
v = virtualinvoke v.<java.util.Properties: java.util.Set stringPropertyNames()>();
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = <java.lang.String: java.util.Comparator CASE_INSENSITIVE_ORDER>;
staticinvoke <java.util.Collections: void sort(java.util.List,java.util.Comparator)>(v, v);
v = virtualinvoke v.<java.util.ArrayList: 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()>();
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void printSysprop(java.lang.String)>(v);
goto label;
label:
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void endln()>();
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Environment Variables", v);
v = newarray (java.lang.String)[9];
v[0] = "HADOOP_JAAS_DEBUG";
v[1] = "KRB5CCNAME";
v[2] = "KRB5_CONFIG";
v[3] = "HADOOP_USER_NAME";
v[4] = "HADOOP_PROXY_USER";
v[5] = "HADOOP_TOKEN_FILE_LOCATION";
v[6] = "HADOOP_SECURE_LOG";
v[7] = "HADOOP_OPTS";
v[8] = "HADOOP_CLIENT_OPTS";
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void printEnv(java.lang.String)>(v);
v = v + 1;
goto label;
label:
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void endln()>();
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Configuration Options", v);
v = newarray (java.lang.String)[13];
v[0] = "hadoop.kerberos.kinit.command";
v[1] = "hadoop.security.authentication";
v[2] = "hadoop.security.authorization";
v[3] = "hadoop.kerberos.min.seconds.before.relogin";
v[4] = "hadoop.security.dns.interface";
v[5] = "hadoop.security.dns.nameserver";
v[6] = "hadoop.rpc.protection";
v[7] = "hadoop.security.saslproperties.resolver.class";
v[8] = "hadoop.security.crypto.codec.classes";
v[9] = "hadoop.security.group.mapping";
v[10] = "hadoop.security.impersonation.provider.class";
v[11] = "dfs.data.transfer.protection";
v[12] = "dfs.data.transfer.saslproperties.resolver.class";
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void printConfOpt(java.lang.String)>(v);
v = v + 1;
goto label;
label:
v = virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: oadd.org.apache.hadoop.conf.Configuration getConf()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean isSimpleAuthentication(oadd.org.apache.hadoop.conf.Configuration)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Hadoop authentication is disabled", v);
v = v.<oadd.org.apache.hadoop.security.KDiag: boolean securityRequired>;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void failif(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, "CONFIG", "Hadoop authentication is disabled", v);
v = <oadd.org.apache.hadoop.security.KDiag: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>("Security is not enabled for the Hadoop cluster");
goto label;
label:
v = new oadd.org.apache.hadoop.conf.Configuration;
specialinvoke v.<oadd.org.apache.hadoop.conf.Configuration: void <init>()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean isSimpleAuthentication(oadd.org.apache.hadoop.conf.Configuration)>(v);
if v == 0 goto label;
v = <oadd.org.apache.hadoop.security.KDiag: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>("The default cluster security is insecure");
v = v.<oadd.org.apache.hadoop.security.KDiag: boolean securityRequired>;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void failif(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, "CONFIG", "Hadoop authentication is disabled", v);
label:
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean getAndSet(java.lang.String)>("sun.security.krb.debug");
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean getAndSet(java.lang.String)>("sun.security.spnego.debug");
label:
staticinvoke <oadd.org.apache.hadoop.security.UserGroupInformation: void setConfiguration(oadd.org.apache.hadoop.conf.Configuration)>(v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateHadoopTokenFiles(oadd.org.apache.hadoop.conf.Configuration)>(v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateKrb5File()>();
virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: void printDefaultRealm()>();
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateSasl(java.lang.String)>("hadoop.security.saslproperties.resolver.class");
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.String get(java.lang.String)>("dfs.data.transfer.saslproperties.resolver.class");
if v == null goto label;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateSasl(java.lang.String)>("dfs.data.transfer.saslproperties.resolver.class");
label:
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateKinitExecutable()>();
v = v.<oadd.org.apache.hadoop.security.KDiag: boolean jaas>;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateJAAS(boolean)>(v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateNTPConf()>();
v = v.<oadd.org.apache.hadoop.security.KDiag: boolean checkShortName>;
if v == 0 goto label;
virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateShortName()>();
label:
v = v.<oadd.org.apache.hadoop.security.KDiag: boolean nologin>;
if v != 0 goto label;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Logging in", v);
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.File keytab>;
if v == null goto label;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.File keytab>;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void dumpKeytab(java.io.File)>(v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void loginFromKeytab()>();
goto label;
label:
v = staticinvoke <oadd.org.apache.hadoop.security.UserGroupInformation: oadd.org.apache.hadoop.security.UserGroupInformation getLoginUser()>();
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void dumpUGI(java.lang.String,oadd.org.apache.hadoop.security.UserGroupInformation)>("Log in user", v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateUGI(java.lang.String,oadd.org.apache.hadoop.security.UserGroupInformation)>("Login user", v);
v = newarray (java.lang.Object)[1];
v = staticinvoke <oadd.org.apache.hadoop.security.UserGroupInformation: boolean isLoginTicketBased()>();
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Ticket based login: %b", v);
v = newarray (java.lang.Object)[1];
v = staticinvoke <oadd.org.apache.hadoop.security.UserGroupInformation: boolean isLoginKeytabBased()>();
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Keytab based login: %b", v);
label:
v = staticinvoke <java.lang.Boolean: java.lang.String toString(boolean)>(v);
staticinvoke <java.lang.System: java.lang.String setProperty(java.lang.String,java.lang.String)>("sun.security.krb.debug", v);
v = staticinvoke <java.lang.Boolean: java.lang.String toString(boolean)>(v);
staticinvoke <java.lang.System: java.lang.String setProperty(java.lang.String,java.lang.String)>("sun.security.spnego.debug", v);
return 1;
label:
v := @caughtexception;
v = staticinvoke <java.lang.Boolean: java.lang.String toString(boolean)>(v);
staticinvoke <java.lang.System: java.lang.String setProperty(java.lang.String,java.lang.String)>("sun.security.krb.debug", v);
v = staticinvoke <java.lang.Boolean: java.lang.String toString(boolean)>(v);
staticinvoke <java.lang.System: java.lang.String setProperty(java.lang.String,java.lang.String)>("sun.security.spnego.debug", v);
throw v;
catch java.lang.Throwable from label to label with label;
}
protected boolean isSimpleAuthentication(oadd.org.apache.hadoop.conf.Configuration)
{
oadd.org.apache.hadoop.conf.Configuration v;
oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod v, v;
oadd.org.apache.hadoop.security.KDiag v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
v = staticinvoke <oadd.org.apache.hadoop.security.SecurityUtil: oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod getAuthenticationMethod(oadd.org.apache.hadoop.conf.Configuration)>(v);
v = <oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod: oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod SIMPLE>;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod: boolean equals(java.lang.Object)>(v);
return v;
}
protected void validateKeyLength() throws java.security.NoSuchAlgorithmException
{
java.lang.Object[] v, v;
long v, v;
oadd.org.apache.hadoop.security.KDiag v;
java.lang.Integer v, v;
byte v;
java.lang.Long v;
int v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v = staticinvoke <javax.crypto.Cipher: int getMaxAllowedKeyLength(java.lang.String)>("AES");
v = newarray (java.lang.Object)[1];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Maximum AES encryption key length %d bits", v);
v = v.<oadd.org.apache.hadoop.security.KDiag: long minKeyLength>;
v = v cmp v;
if v > 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = newarray (java.lang.Object)[2];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = v.<oadd.org.apache.hadoop.security.KDiag: long minKeyLength>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, "JVM", "Java Cryptography Extensions are not installed on this JVM. Maximum supported key length %s - minimum required %d", v);
return;
}
protected void validateShortName()
{
java.lang.Object[] v, v, v, v;
java.util.regex.Matcher v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure v;
boolean v, v;
java.io.IOException v;
oadd.org.apache.hadoop.security.KDiag v;
java.lang.IllegalArgumentException v;
java.util.regex.Pattern v;
oadd.org.apache.hadoop.security.authentication.util.KerberosName v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
if v != null goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void failif(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, "KERBEROS", "No principal defined", v);
label:
v = new oadd.org.apache.hadoop.security.authentication.util.KerberosName;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
specialinvoke v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<oadd.org.apache.hadoop.security.authentication.util.KerberosName: java.lang.String getShortName()>();
v = <oadd.org.apache.hadoop.security.KDiag: java.util.regex.Pattern nonSimplePattern>;
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean find()>();
if v == 0 goto label;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
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[])>("\u short name: \u still contains @ or /");
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void warn(java.lang.String,java.lang.String,java.lang.Object[])>("KERBEROS", v, v);
label:
goto label;
label:
v := @caughtexception;
v = new oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
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[])>("Failed to get short name for \u0001");
v = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure: void <init>(java.lang.String,java.lang.Throwable,java.lang.String,java.lang.Object[])>("KERBEROS", v, v, v);
throw v;
label:
v := @caughtexception;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
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[])>("KerberosName(\u) failed: %s\n%s");
v = newarray (java.lang.Object)[2];
v[0] = v;
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String stringifyException(java.lang.Throwable)>(v);
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void error(java.lang.String,java.lang.String,java.lang.Object[])>("KERBEROS", v, v);
label:
return;
catch java.io.IOException from label to label with label;
catch java.lang.IllegalArgumentException from label to label with label;
}
protected void printDefaultRealm()
{
java.lang.Throwable v, v;
java.lang.Object[] v, v, v, v, v;
java.lang.ReflectiveOperationException v;
java.lang.String v, v, v, v, v;
oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure v;
boolean v;
org.slf4j.Logger v;
oadd.org.apache.hadoop.security.KDiag v;
java.lang.reflect.InvocationTargetException v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
label:
v = staticinvoke <oadd.org.apache.hadoop.security.authentication.util.KerberosUtil: java.lang.String getDefaultRealm()>();
v = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Default Realm = %s", v);
if v != null goto label;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void warn(java.lang.String,java.lang.String,java.lang.Object[])>("KERBEROS", "Host has no default realm", v);
label:
goto label;
label:
v := @caughtexception;
v = new oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.ReflectiveOperationException)>(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[])>("Failed to invoke krb.Config.getDefaultRealm: %s: \u0001");
v = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure: void <init>(java.lang.String,java.lang.Throwable,java.lang.String,java.lang.Object[])>("JVM", v, v, v);
throw v;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getCause()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getCause()>();
goto label;
label:
v = v;
label:
v = virtualinvoke v.<java.lang.Throwable: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>("Cannot locate default realm");
if v == 0 goto label;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void warn(java.lang.String,java.lang.String,java.lang.Object[])>("KERBEROS", "Host has no default realm", v);
v = <oadd.org.apache.hadoop.security.KDiag: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String toString()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>(v, v);
goto label;
label:
v = newarray (java.lang.Object)[2];
v[0] = v;
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String stringifyException(java.lang.Throwable)>(v);
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void error(java.lang.String,java.lang.String,java.lang.Object[])>("KERBEROS", "Kerberos.getDefaultRealm() failed: %s\n%s", v);
label:
return;
catch java.lang.ClassNotFoundException from label to label with label;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.NoSuchMethodException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
}
private void validateHadoopTokenFiles(oadd.org.apache.hadoop.conf.Configuration) throws java.lang.ClassNotFoundException, oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure, java.lang.NoSuchMethodException, java.lang.SecurityException
{
java.lang.Object[] v, v, v, v;
java.lang.String[] v;
int v, v, v;
oadd.org.apache.hadoop.conf.Configuration v;
java.lang.String v, v, v, v, v, v, v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Locating Hadoop token files", v);
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("hadoop.token.files");
if v == null goto 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[])>("Found hadoop.token.files in system properties : \u0001");
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>(v, v);
label:
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.String get(java.lang.String)>("hadoop.token.files");
if v == null goto label;
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.String get(java.lang.String)>("hadoop.token.files");
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[])>("Found hadoop.token.files in hadoop configuration : \u0001");
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>(v, v);
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("hadoop.token.files");
if v == null goto label;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("hadoop.token.files in the system properties overrides the one specified in hadoop configuration", v);
goto label;
label:
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.String get(java.lang.String)>("hadoop.token.files");
label:
if v == null goto label;
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String[] getTrimmedStrings(java.lang.String)>(v);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verifyFileIsValid(java.io.File,java.lang.String,java.lang.String)>(v, "TOKEN", "token");
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(java.io.File,oadd.org.apache.hadoop.conf.Configuration,java.lang.String,java.lang.String)>(v, v, "TOKEN", "token");
label:
v = v + 1;
goto label;
label:
return;
}
private void validateKrb5File() throws java.io.IOException
{
java.lang.Object[] v, v, v, v, v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v;
java.lang.String v, v, v;
boolean v, v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v = <oadd.org.apache.hadoop.util.Shell: boolean WINDOWS>;
if v != 0 goto label;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Locating Kerberos configuration file", v);
v = "/etc/krb.conf";
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("java.security.krb.conf");
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = newarray (java.lang.Object)[2];
v[0] = "java.security.krb.conf";
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Setting kerberos path from sysprop %s: \"%s\"", v);
v = v;
label:
v = staticinvoke <java.lang.System: java.lang.String getenv(java.lang.String)>("KRB5_CONFIG");
if v == null goto label;
v = newarray (java.lang.Object)[2];
v[0] = "KRB5_CONFIG";
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Setting kerberos path from environment variable %s: \"%s\"", v);
v = v;
if v == null goto label;
v = newarray (java.lang.Object)[3];
v[0] = "java.security.krb.conf";
v[1] = "KRB5_CONFIG";
v[2] = "KRB5_CONFIG";
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Warning - both %s and %s were set - %s takes priority", v);
label:
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Kerberos configuration file = %s", v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void dump(java.io.File)>(v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void endln()>();
label:
return;
}
private void dumpKeytab(java.io.File) throws java.io.IOException
{
java.lang.Object[] v, v, v, v;
java.lang.Integer v, v, v;
org.apache.kerby.kerberos.kerb.type.base.EncryptionKey v;
org.apache.kerby.kerberos.kerb.type.KerberosTime v;
int v, v, v, v;
org.apache.kerby.kerberos.kerb.type.base.EncryptionType v;
org.apache.kerby.kerberos.kerb.keytab.Keytab v;
boolean v, v;
java.util.Iterator v, v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v, v;
java.util.List v, v;
java.lang.Object v, v;
org.apache.kerby.kerberos.kerb.type.base.PrincipalName v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.io.File;
v = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Examining keytab %s", v);
v = virtualinvoke v.<java.io.File: java.io.File getCanonicalFile()>();
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verifyFileIsValid(java.io.File,java.lang.String,java.lang.String)>(v, "KERBEROS", "keytab");
v = staticinvoke <org.apache.kerby.kerberos.kerb.keytab.Keytab: org.apache.kerby.kerberos.kerb.keytab.Keytab loadKeytab(java.io.File)>(v);
v = virtualinvoke v.<org.apache.kerby.kerberos.kerb.keytab.Keytab: java.util.List getPrincipals()>();
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;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("keytab principal count: %d", v);
v = 0;
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.<org.apache.kerby.kerberos.kerb.keytab.Keytab: java.util.List getKeytabEntries(org.apache.kerby.kerberos.kerb.type.base.PrincipalName)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = v + v;
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.<org.apache.kerby.kerberos.kerb.keytab.KeytabEntry: org.apache.kerby.kerberos.kerb.type.base.EncryptionKey getKey()>();
v = newarray (java.lang.Object)[4];
v = virtualinvoke v.<org.apache.kerby.kerberos.kerb.keytab.KeytabEntry: org.apache.kerby.kerberos.kerb.type.base.PrincipalName getPrincipal()>();
v[0] = v;
v = virtualinvoke v.<org.apache.kerby.kerberos.kerb.keytab.KeytabEntry: int getKvno()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = virtualinvoke v.<org.apache.kerby.kerberos.kerb.keytab.KeytabEntry: org.apache.kerby.kerberos.kerb.type.KerberosTime getTimestamp()>();
v[2] = v;
v = virtualinvoke v.<org.apache.kerby.kerberos.kerb.type.base.EncryptionKey: org.apache.kerby.kerberos.kerb.type.base.EncryptionType getKeyType()>();
v[3] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>(" %s: version=%d expires=%s encryption=%s", v);
goto label;
label:
v = newarray (java.lang.Object)[1];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("keytab entry count: %d", v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void endln()>();
return;
}
private void loginFromKeytab() throws java.io.IOException
{
java.lang.Object[] v, v, v, v, v;
java.lang.String v, v, v, v, v, v;
boolean v;
oadd.org.apache.hadoop.security.UserGroupInformation v;
org.slf4j.Logger v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v, v, v;
java.lang.IllegalAccessError v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.File keytab>;
if v == null goto label;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.File keytab>;
v = virtualinvoke v.<java.io.File: java.io.File getCanonicalFile()>();
v = newarray (java.lang.Object)[2];
v[0] = v;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Using keytab %s principal %s", v);
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
if v != null goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void failif(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, "KERBEROS", "No principal defined", v);
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
v = virtualinvoke v.<java.io.File: java.lang.String getPath()>();
v = staticinvoke <oadd.org.apache.hadoop.security.UserGroupInformation: oadd.org.apache.hadoop.security.UserGroupInformation loginUserFromKeytabAndReturnUGI(java.lang.String,java.lang.String)>(v, v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void dumpUGI(java.lang.String,oadd.org.apache.hadoop.security.UserGroupInformation)>(v, v);
v = v.<oadd.org.apache.hadoop.security.KDiag: java.lang.String principal>;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void validateUGI(java.lang.String,oadd.org.apache.hadoop.security.UserGroupInformation)>(v, v);
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Attempting to relogin", v);
label:
staticinvoke <oadd.org.apache.hadoop.security.UserGroupInformation: void setShouldRenewImmediatelyForTests(boolean)>(1);
virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: void reloginFromKeytab()>();
label:
goto label;
label:
v := @caughtexception;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void warn(java.lang.String,java.lang.String,java.lang.Object[])>("UGI", "Failed to reset UGI -and so could not try to relogin", v);
v = <oadd.org.apache.hadoop.security.KDiag: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Failed to reset UGI: {}", v, v);
goto label;
label:
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("No keytab: attempting to log in is as current user", v);
label:
return;
catch java.lang.IllegalAccessError from label to label with label;
}
private void dumpUGI(java.lang.String, oadd.org.apache.hadoop.security.UserGroupInformation) throws java.io.IOException
{
java.lang.Object[] v, v, v, v, v, v, v, v, v, v, v;
java.lang.String[] v;
oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod v, v;
int v, v;
java.lang.Boolean v;
oadd.org.apache.hadoop.security.Credentials v;
java.lang.String v, v;
boolean v, v, v;
oadd.org.apache.hadoop.security.UserGroupInformation v;
java.util.Iterator v;
oadd.org.apache.hadoop.security.KDiag v;
java.util.List v;
java.lang.Object v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v := @parameter: oadd.org.apache.hadoop.security.UserGroupInformation;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>(v, v);
v = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("UGI instance = %s", v);
v = newarray (java.lang.Object)[1];
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: boolean hasKerberosCredentials()>();
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Has kerberos credentials: %b", v);
v = newarray (java.lang.Object)[1];
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod getAuthenticationMethod()>();
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Authentication method: %s", v);
v = newarray (java.lang.Object)[1];
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod getRealAuthenticationMethod()>();
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Real Authentication method: %s", v);
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Group names", v);
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: java.lang.String[] getGroupNames()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>(v, v);
v = v + 1;
goto label;
label:
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Credentials", v);
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: oadd.org.apache.hadoop.security.Credentials getCredentials()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.security.Credentials: java.util.List getAllSecretKeys()>();
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Secret keys", v);
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
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 = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("%s", v);
goto label;
label:
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("(none)", v);
label:
virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: void dumpTokens(oadd.org.apache.hadoop.security.UserGroupInformation)>(v);
return;
}
private void validateUGI(java.lang.String, oadd.org.apache.hadoop.security.UserGroupInformation)
{
java.lang.Object[] v, v, v;
oadd.org.apache.hadoop.security.UserGroupInformation v;
oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod v, v, v;
oadd.org.apache.hadoop.security.KDiag v;
java.lang.String v;
boolean v, v, v, v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v := @parameter: oadd.org.apache.hadoop.security.UserGroupInformation;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod getAuthenticationMethod()>();
v = <oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod: oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod KERBEROS>;
if v != v goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = newarray (java.lang.Object)[1];
v[0] = v;
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, "LOGIN", "User %s is not authenticated by Kerberos", v);
if v == 0 goto label;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: boolean hasKerberosCredentials()>();
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, "LOGIN", "%s: No kerberos credentials for %s", v);
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: oadd.org.apache.hadoop.security.UserGroupInformation$AuthenticationMethod getAuthenticationMethod()>();
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, "LOGIN", "%s: Null AuthenticationMethod for %s", v);
label:
return;
}
private void validateKinitExecutable()
{
java.lang.Object[] v, v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v;
oadd.org.apache.hadoop.conf.Configuration v;
java.lang.String v;
boolean v, v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: oadd.org.apache.hadoop.conf.Configuration getConf()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.String getTrimmed(java.lang.String,java.lang.String)>("hadoop.kerberos.kinit.command", "");
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = newarray (java.lang.Object)[2];
v[0] = "hadoop.kerberos.kinit.command";
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("%s = %s", v);
v = virtualinvoke v.<java.io.File: boolean isAbsolute()>();
if v == 0 goto label;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verifyFileIsValid(java.io.File,java.lang.String,java.lang.String)>(v, "KERBEROS", "hadoop.kerberos.kinit.command");
goto label;
label:
v = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Executable %s is relative -must be on the PATH", v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void printEnv(java.lang.String)>("PATH");
label:
return;
}
private void validateSasl(java.lang.String)
{
java.lang.Object[] v, v, v;
java.lang.RuntimeException v;
oadd.org.apache.hadoop.security.KDiag v;
java.lang.Class v;
oadd.org.apache.hadoop.conf.Configuration v, v;
java.lang.String v, v;
oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Resolving SASL property %s", v);
v = virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: oadd.org.apache.hadoop.conf.Configuration getConf()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.String getTrimmed(java.lang.String)>(v);
label:
v = virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: oadd.org.apache.hadoop.conf.Configuration getConf()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.Class getClass(java.lang.String,java.lang.Class,java.lang.Class)>(v, class "Loadd/org/apache/hadoop/security/SaslPropertiesResolver;", class "Loadd/org/apache/hadoop/security/SaslPropertiesResolver;");
v = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Resolver is %s", v);
label:
goto label;
label:
v := @caughtexception;
v = new oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure: void <init>(java.lang.String,java.lang.Throwable,java.lang.String,java.lang.Object[])>("SASL", v, "Failed to load %s class %s", v);
throw v;
label:
return;
catch java.lang.RuntimeException from label to label with label;
}
private void validateJAAS(boolean) throws java.io.IOException
{
java.lang.Object[] v, v, v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v;
java.lang.String v;
boolean v, v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: boolean;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("java.security.auth.login.config");
if v == 0 goto label;
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, "JAAS", "No JAAS file specified in java.security.auth.login.config", v);
label:
if v == null goto label;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("JAAS", v);
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = newarray (java.lang.Object)[2];
v[0] = "java.security.auth.login.config";
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("JAAS file is defined in %s: %s", v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verifyFileIsValid(java.io.File,java.lang.String,java.lang.String)>(v, "JAAS", "JAAS file defined in java.security.auth.login.config");
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void dump(java.io.File)>(v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void endln()>();
label:
return;
}
private void validateNTPConf() throws java.io.IOException
{
java.lang.Object[] v;
java.lang.String v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v;
boolean v, v, v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v = <oadd.org.apache.hadoop.util.Shell: boolean WINDOWS>;
if v != 0 goto label;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>("/etc/ntp.conf");
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v == 0 goto label;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("NTP file: \u0001");
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verifyFileIsValid(java.io.File,java.lang.String,java.lang.String)>(v, "JAAS", v);
if v == 0 goto label;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("NTP", v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void dump(java.io.File)>(v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void endln()>();
label:
return;
}
private boolean verifyFileIsValid(java.io.File, java.lang.String, java.lang.String)
{
java.lang.Object[] v, v, v, v;
long v;
byte v;
java.lang.String v, v;
boolean v, v, v, v, v, v, v, v, v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.io.File;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.io.File: boolean exists()>();
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, v, "%s file does not exist: %s", v);
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: boolean isFile()>();
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, v, "%s path does not refer to a file: %s", v);
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: long length()>();
v = v cmp 0L;
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, v, "%s file is empty: %s", v);
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: boolean canRead()>();
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
v = specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: boolean verify(boolean,java.lang.String,java.lang.String,java.lang.Object[])>(v, v, "%s file is not readable: %s", v);
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public void dumpTokens(oadd.org.apache.hadoop.security.UserGroupInformation)
{
java.lang.Object[] v, v;
oadd.org.apache.hadoop.security.UserGroupInformation v;
java.util.Iterator v;
java.util.Collection v;
oadd.org.apache.hadoop.io.Text v;
oadd.org.apache.hadoop.security.KDiag v;
java.lang.Integer v;
int v;
oadd.org.apache.hadoop.security.Credentials v;
java.lang.Object v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: oadd.org.apache.hadoop.security.UserGroupInformation;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: oadd.org.apache.hadoop.security.Credentials getCredentials()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.security.Credentials: java.util.Collection getAllTokens()>();
v = newarray (java.lang.Object)[1];
v = interfaceinvoke v.<java.util.Collection: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void title(java.lang.String,java.lang.Object[])>("Token Count: %d", v);
v = interfaceinvoke v.<java.util.Collection: 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 = newarray (java.lang.Object)[1];
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.Token: oadd.org.apache.hadoop.io.Text getKind()>();
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("Token %s", v);
goto label;
label:
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void endln()>();
return;
}
private boolean getAndSet(java.lang.String)
{
java.lang.String v;
oadd.org.apache.hadoop.security.KDiag v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v = staticinvoke <java.lang.Boolean: boolean getBoolean(java.lang.String)>(v);
staticinvoke <java.lang.System: java.lang.String setProperty(java.lang.String,java.lang.String)>(v, "true");
return v;
}
private void flush()
{
java.io.PrintStream v, v;
java.io.PrintWriter v, v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.PrintWriter out>;
if v == null goto label;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.PrintWriter out>;
virtualinvoke v.<java.io.PrintWriter: void flush()>();
goto label;
label:
v = <java.lang.System: java.io.PrintStream out>;
virtualinvoke v.<java.io.PrintStream: void flush()>();
label:
v = <java.lang.System: java.io.PrintStream err>;
virtualinvoke v.<java.io.PrintStream: void flush()>();
return;
}
private transient void println(java.lang.String, java.lang.Object[])
{
java.io.PrintStream v;
java.io.PrintWriter v, v;
java.lang.Object[] v;
java.lang.String v, v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object[];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void flush()>();
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>(v, v);
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.PrintWriter out>;
if v == null goto label;
v = v.<oadd.org.apache.hadoop.security.KDiag: java.io.PrintWriter out>;
virtualinvoke v.<java.io.PrintWriter: void println(java.lang.String)>(v);
goto label;
label:
v = <java.lang.System: java.io.PrintStream out>;
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
label:
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void flush()>();
return;
}
private void println()
{
java.lang.Object[] v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("", v);
return;
}
private void endln()
{
java.lang.Object[] v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println()>();
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("-----", v);
return;
}
private transient void title(java.lang.String, java.lang.Object[])
{
java.lang.Object[] v, v;
java.lang.String v, v, v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object[];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println()>();
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println()>();
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>(v, 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 ==");
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>(v, v);
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println()>();
return;
}
private void printSysprop(java.lang.String)
{
java.lang.Object[] v;
java.lang.String v, v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v = newarray (java.lang.Object)[2];
v[0] = v;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String,java.lang.String)>(v, "(unset)");
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("%s = \"%s\"", v);
return;
}
private void printConfOpt(java.lang.String)
{
java.lang.Object[] v;
oadd.org.apache.hadoop.conf.Configuration v;
java.lang.String v, v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v = newarray (java.lang.Object)[2];
v[0] = v;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: oadd.org.apache.hadoop.conf.Configuration getConf()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.String get(java.lang.String,java.lang.String)>(v, "(unset)");
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("%s = \"%s\"", v);
return;
}
private void printEnv(java.lang.String)
{
java.lang.Object[] v;
java.lang.String v, v, v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v = staticinvoke <java.lang.System: java.lang.String getenv(java.lang.String)>(v);
v = newarray (java.lang.Object)[2];
v[0] = v;
if v == null goto label;
v = v;
goto label;
label:
v = "(unset)";
label:
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("%s = \"%s\"", v);
return;
}
private void dump(java.io.File) throws java.io.IOException
{
java.lang.Throwable v;
java.lang.Object[] v;
java.util.Iterator v;
java.io.FileInputStream v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v;
java.util.List v;
java.lang.Object v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.io.File;
v = new java.io.FileInputStream;
specialinvoke v.<java.io.FileInputStream: void <init>(java.io.File)>(v);
label:
v = staticinvoke <oadd.org.apache.commons.io.IOUtils: java.util.List readLines(java.io.InputStream)>(v);
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 = newarray (java.lang.Object)[1];
v[0] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("%s", v);
goto label;
label:
virtualinvoke v.<java.io.FileInputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private transient void fail(java.lang.String, java.lang.String, java.lang.Object[]) throws oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure
{
java.lang.Object[] v;
java.lang.String v, v;
oadd.org.apache.hadoop.security.KDiag v;
oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object[];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void error(java.lang.String,java.lang.String,java.lang.Object[])>(v, v, v);
v = new oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure: void <init>(java.lang.String,java.lang.String,java.lang.Object[])>(v, v, v);
throw v;
}
private transient boolean verify(boolean, java.lang.String, java.lang.String, java.lang.Object[]) throws oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure
{
java.lang.Object[] v;
java.lang.String v, v;
oadd.org.apache.hadoop.security.KDiag v;
boolean v, v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: boolean;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object[];
if v != 0 goto label;
v.<oadd.org.apache.hadoop.security.KDiag: boolean probeHasFailed> = 1;
v = v.<oadd.org.apache.hadoop.security.KDiag: boolean nofail>;
if v != 0 goto label;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void fail(java.lang.String,java.lang.String,java.lang.Object[])>(v, v, v);
goto label;
label:
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void error(java.lang.String,java.lang.String,java.lang.Object[])>(v, v, v);
label:
return 0;
label:
return 1;
}
private boolean verify(java.io.File, oadd.org.apache.hadoop.conf.Configuration, java.lang.String, java.lang.String) throws oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure
{
java.lang.Object[] v, v;
oadd.org.apache.hadoop.security.KDiag v;
java.io.File v;
java.lang.Exception v;
oadd.org.apache.hadoop.conf.Configuration v;
java.lang.String v, v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.io.File;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
label:
staticinvoke <oadd.org.apache.hadoop.security.Credentials: oadd.org.apache.hadoop.security.Credentials readTokenStorageFile(java.io.File,oadd.org.apache.hadoop.conf.Configuration)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = v.<oadd.org.apache.hadoop.security.KDiag: boolean nofail>;
if v != 0 goto label;
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void fail(java.lang.String,java.lang.String,java.lang.Object[])>(v, v, v);
goto label;
label:
v = newarray (java.lang.Object)[0];
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void error(java.lang.String,java.lang.String,java.lang.Object[])>(v, v, v);
label:
return 0;
label:
return 1;
catch java.lang.Exception from label to label with label;
}
private transient void error(java.lang.String, java.lang.String, java.lang.Object[])
{
java.lang.Object[] v, v;
java.lang.String v, v, v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object[];
v = newarray (java.lang.Object)[2];
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>(v, v);
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("ERROR: %s: %s", v);
return;
}
private transient void warn(java.lang.String, java.lang.String, java.lang.Object[])
{
java.lang.Object[] v, v;
java.lang.String v, v, v;
oadd.org.apache.hadoop.security.KDiag v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object[];
v = newarray (java.lang.Object)[2];
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>(v, v);
v[1] = v;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void println(java.lang.String,java.lang.Object[])>("WARNING: %s: %s", v);
return;
}
private transient void failif(boolean, java.lang.String, java.lang.String, java.lang.Object[]) throws oadd.org.apache.hadoop.security.KDiag$KerberosDiagsFailure
{
java.lang.Object[] v;
java.lang.String v, v;
oadd.org.apache.hadoop.security.KDiag v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.KDiag;
v := @parameter: boolean;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object[];
if v == 0 goto label;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void fail(java.lang.String,java.lang.String,java.lang.Object[])>(v, v, v);
label:
return;
}
public static transient int exec(oadd.org.apache.hadoop.conf.Configuration, java.lang.String[]) throws java.lang.Exception
{
java.lang.Throwable v;
int v;
java.lang.String[] v;
oadd.org.apache.hadoop.conf.Configuration v;
oadd.org.apache.hadoop.security.KDiag v;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
v := @parameter: java.lang.String[];
v = new oadd.org.apache.hadoop.security.KDiag;
specialinvoke v.<oadd.org.apache.hadoop.security.KDiag: void <init>()>();
label:
v = staticinvoke <oadd.org.apache.hadoop.util.ToolRunner: int run(oadd.org.apache.hadoop.conf.Configuration,oadd.org.apache.hadoop.util.Tool,java.lang.String[])>(v, v, v);
label:
virtualinvoke v.<oadd.org.apache.hadoop.security.KDiag: void close()>();
return v;
label:
v := @caughtexception;
throw v;
catch java.lang.Throwable from label to label with label;
}
public static void main(java.lang.String[])
{
oadd.org.apache.hadoop.util.ExitUtil$ExitException v;
org.slf4j.Logger v, v;
java.lang.String[] v;
java.lang.Exception v;
int v, v, v;
oadd.org.apache.hadoop.conf.Configuration v;
java.lang.String v, v;
v := @parameter: java.lang.String[];
label:
v = new oadd.org.apache.hadoop.conf.Configuration;
specialinvoke v.<oadd.org.apache.hadoop.conf.Configuration: void <init>()>();
v = staticinvoke <oadd.org.apache.hadoop.security.KDiag: int exec(oadd.org.apache.hadoop.conf.Configuration,java.lang.String[])>(v, v);
staticinvoke <oadd.org.apache.hadoop.util.ExitUtil: void terminate(int)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.hadoop.security.KDiag: org.slf4j.Logger LOG>;
v = virtualinvoke v.<oadd.org.apache.hadoop.util.ExitUtil$ExitException: java.lang.String toString()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>(v);
v = v.<oadd.org.apache.hadoop.util.ExitUtil$ExitException: int status>;
staticinvoke <java.lang.System: void exit(int)>(v);
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.hadoop.security.KDiag: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String toString()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
v = (int) -1;
staticinvoke <oadd.org.apache.hadoop.util.ExitUtil: void halt(int,java.lang.Throwable)>(v, v);
label:
return;
catch oadd.org.apache.hadoop.util.ExitUtil$ExitException from label to label with label;
catch java.lang.Exception from label to label with label;
}
static void <clinit>()
{
java.util.regex.Pattern v;
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Loadd/org/apache/hadoop/security/KDiag;");
<oadd.org.apache.hadoop.security.KDiag: org.slf4j.Logger LOG> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("[/@]");
<oadd.org.apache.hadoop.security.KDiag: java.util.regex.Pattern nonSimplePattern> = v;
return;
}
}