public final class oadd.org.apache.hadoop.security.ProviderUtils extends java.lang.Object
{
public static final java.lang.String NO_PASSWORD_WARN;
public static final java.lang.String NO_PASSWORD_ERROR;
public static final java.lang.String NO_PASSWORD_CONT;
public static final java.lang.String NO_PASSWORD_INSTRUCTIONS_DOC;
private static final org.slf4j.Logger LOG;
private void <init>()
{
oadd.org.apache.hadoop.security.ProviderUtils v;
v := @this: oadd.org.apache.hadoop.security.ProviderUtils;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static oadd.org.apache.hadoop.fs.Path unnestUri(java.net.URI)
{
java.lang.String[] v;
int v;
java.lang.StringBuilder v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
java.net.URI v;
oadd.org.apache.hadoop.fs.Path v;
v := @parameter: java.net.URI;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = virtualinvoke v.<java.net.URI: java.lang.String getAuthority()>();
if v == null goto label;
v = virtualinvoke v.<java.net.URI: java.lang.String getAuthority()>();
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String,int)>("@", 2);
v = v[0];
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)>("://");
v = lengthof v;
if v != 2 goto label;
v = v[1];
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
v = virtualinvoke v.<java.net.URI: java.lang.String getPath()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = virtualinvoke v.<java.net.URI: java.lang.String getQuery()>();
if v == null goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("?");
v = virtualinvoke v.<java.net.URI: java.lang.String getQuery()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
v = virtualinvoke v.<java.net.URI: java.lang.String getFragment()>();
if v == null goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("#");
v = virtualinvoke v.<java.net.URI: java.lang.String getFragment()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
v = new oadd.org.apache.hadoop.fs.Path;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
specialinvoke v.<oadd.org.apache.hadoop.fs.Path: void <init>(java.lang.String)>(v);
return v;
}
public static java.net.URI nestURIForLocalJavaKeyStoreProvider(java.net.URI) throws java.net.URISyntaxException
{
java.lang.IllegalArgumentException v, v;
java.lang.Class v;
java.lang.String v, v, v, v, v, v, v, v;
java.net.URI v, v;
boolean v;
v := @parameter: java.net.URI;
v = "file";
v = virtualinvoke v.<java.net.URI: java.lang.String getScheme()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("passed URI had a scheme other than file.");
throw v;
label:
v = virtualinvoke v.<java.net.URI: java.lang.String getAuthority()>();
if v == null goto label;
v = new java.lang.IllegalArgumentException;
v = class "Loadd/org/apache/hadoop/security/alias/JavaKeyStoreProvider;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
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[])>("passed URI must not have an authority component. For non-local keystores, please use \u0001");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new java.net.URI;
v = virtualinvoke v.<java.net.URI: java.lang.String getSchemeSpecificPart()>();
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[])>("//file\u0001");
v = virtualinvoke v.<java.net.URI: java.lang.String getFragment()>();
specialinvoke v.<java.net.URI: void <init>(java.lang.String,java.lang.String,java.lang.String)>("localjceks", v, v);
return v;
}
public static oadd.org.apache.hadoop.conf.Configuration excludeIncompatibleCredentialProviders(oadd.org.apache.hadoop.conf.Configuration, java.lang.Class) throws java.io.IOException
{
java.net.URISyntaxException v;
java.lang.String[] v;
java.lang.StringBuffer v;
int v, v, v, v;
oadd.org.apache.hadoop.conf.Configuration v, v;
java.lang.String v, v, v, v, v, v;
java.net.URI v, v;
boolean v, v, v;
org.slf4j.Logger v, v;
java.io.IOException v;
java.lang.Class v, v;
oadd.org.apache.hadoop.fs.Path v;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
v := @parameter: java.lang.Class;
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.String get(java.lang.String)>("hadoop.security.credential.provider.path");
if v != null goto label;
return v;
label:
v = new java.lang.StringBuffer;
specialinvoke v.<java.lang.StringBuffer: void <init>()>();
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(",");
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
label:
v = new java.net.URI;
specialinvoke v.<java.net.URI: void <init>(java.lang.String)>(v);
v = staticinvoke <oadd.org.apache.hadoop.security.ProviderUtils: oadd.org.apache.hadoop.fs.Path unnestUri(java.net.URI)>(v);
v = null;
label:
v = virtualinvoke v.<oadd.org.apache.hadoop.fs.Path: java.net.URI toUri()>();
v = virtualinvoke v.<java.net.URI: java.lang.String getScheme()>();
v = staticinvoke <oadd.org.apache.hadoop.fs.FileSystem: java.lang.Class getFileSystemClass(java.lang.String,oadd.org.apache.hadoop.conf.Configuration)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.StringBuffer: int length()>();
if v <= 0 goto label;
virtualinvoke v.<java.lang.StringBuffer: java.lang.StringBuffer append(java.lang.String)>(",");
label:
virtualinvoke v.<java.lang.StringBuffer: java.lang.StringBuffer append(java.lang.String)>(v);
label:
if v == null goto label;
v = virtualinvoke v.<java.lang.Class: boolean isAssignableFrom(java.lang.Class)>(v);
if v == 0 goto label;
v = <oadd.org.apache.hadoop.security.ProviderUtils: org.slf4j.Logger LOG>;
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[])>("Filesystem based provider excluded from provider path due to recursive dependency: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuffer: int length()>();
if v <= 0 goto label;
virtualinvoke v.<java.lang.StringBuffer: java.lang.StringBuffer append(java.lang.String)>(",");
label:
virtualinvoke v.<java.lang.StringBuffer: java.lang.StringBuffer append(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.hadoop.security.ProviderUtils: org.slf4j.Logger LOG>;
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[])>("Credential Provider URI is invalid.\u0001");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
label:
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuffer: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
return v;
label:
v = new oadd.org.apache.hadoop.conf.Configuration;
specialinvoke v.<oadd.org.apache.hadoop.conf.Configuration: void <init>(oadd.org.apache.hadoop.conf.Configuration)>(v);
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("");
if v == 0 goto label;
virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: void unset(java.lang.String)>("hadoop.security.credential.provider.path");
goto label;
label:
virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: void set(java.lang.String,java.lang.String)>("hadoop.security.credential.provider.path", v);
label:
return v;
catch java.io.IOException from label to label with label;
catch java.net.URISyntaxException from label to label with label;
}
public static char[] locatePassword(java.lang.String, java.lang.String) throws java.io.IOException
{
java.lang.Throwable v;
java.net.URL v;
java.io.IOException v;
java.lang.Thread v;
java.util.Map v;
char[] v;
java.lang.ClassLoader v;
java.lang.String v, v, v, v, v;
boolean v;
java.io.InputStream v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = null;
v = staticinvoke <java.lang.System: java.util.Map getenv()>();
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = staticinvoke <java.lang.System: java.lang.String getenv(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
label:
if v != null goto label;
if v == null goto label;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.ClassLoader getContextClassLoader()>();
v = virtualinvoke v.<java.lang.ClassLoader: java.net.URL getResource(java.lang.String)>(v);
if v != null goto label;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>("Password file does not exist");
throw v;
label:
v = virtualinvoke v.<java.net.URL: java.io.InputStream openStream()>();
label:
v = staticinvoke <oadd.org.apache.commons.io.IOUtils: java.lang.String toString(java.io.InputStream)>(v);
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
label:
if v == null goto label;
virtualinvoke v.<java.io.InputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
private static java.lang.String noPasswordInstruction(java.lang.String, java.lang.String)
{
java.lang.String v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
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[])>("    * In the environment variable \u0001\n    * In a file referred to by the configuration entry\n      \u.\nPlease review the documentation regarding provider passwords in\nthe keystore passwords section of the Credential Provider API\n");
return v;
}
public static java.lang.String noPasswordWarning(java.lang.String, java.lang.String)
{
java.lang.String v, v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = staticinvoke <oadd.org.apache.hadoop.security.ProviderUtils: java.lang.String noPasswordInstruction(java.lang.String,java.lang.String)>(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[])>("WARNING: You have accepted the use of the default provider password\nby not configuring a password in one of the two following locations:\n\u0001Continuing with the default provider password.\n");
return v;
}
public static java.lang.String noPasswordError(java.lang.String, java.lang.String)
{
java.lang.String v, v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = staticinvoke <oadd.org.apache.hadoop.security.ProviderUtils: java.lang.String noPasswordInstruction(java.lang.String,java.lang.String)>(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[])>("ERROR: The provider cannot find a password in the expected locations.\nPlease supply a password using one of the following two mechanisms:\n\u0001");
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Loadd/org/apache/hadoop/security/ProviderUtils;");
<oadd.org.apache.hadoop.security.ProviderUtils: org.slf4j.Logger LOG> = v;
return;
}
}