public final class oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider extends oadd.org.apache.hadoop.security.alias.AbstractJavaKeyStoreProvider
{
public static final java.lang.String SCHEME_NAME;
private java.io.File file;
private java.util.Set permissions;
private void <init>(java.net.URI, oadd.org.apache.hadoop.conf.Configuration) throws java.io.IOException
{
oadd.org.apache.hadoop.conf.Configuration v;
oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider v;
java.net.URI v;
v := @this: oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider;
v := @parameter: java.net.URI;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
specialinvoke v.<oadd.org.apache.hadoop.security.alias.AbstractJavaKeyStoreProvider: void <init>(java.net.URI,oadd.org.apache.hadoop.conf.Configuration)>(v, v);
return;
}
protected java.lang.String getSchemeName()
{
oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider v;
v := @this: oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider;
return "localjceks";
}
protected java.io.OutputStream getOutputStreamForKeystore() throws java.io.IOException
{
org.slf4j.Logger v, v;
java.io.FileOutputStream v;
java.io.File v, v;
oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider v;
java.lang.String v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider;
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
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[])>("using \'\u0001\' for output stream.");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = new java.io.FileOutputStream;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
return v;
}
protected boolean keystoreExists() throws java.io.IOException
{
oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider v;
byte v;
long v;
java.io.File v, v;
boolean v, v;
v := @this: oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v == 0 goto label;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
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:
return v;
}
protected java.io.InputStream getInputStreamForFile() throws java.io.IOException
{
oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider v;
java.io.FileInputStream v;
java.io.File v;
v := @this: oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider;
v = new java.io.FileInputStream;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
specialinvoke v.<java.io.FileInputStream: void <init>(java.io.File)>(v);
return v;
}
protected void createPermissions(java.lang.String) throws java.io.IOException
{
oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider v;
int v;
java.util.Set v;
java.io.IOException v;
java.lang.NumberFormatException v;
java.lang.String v;
v := @this: oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider;
v := @parameter: java.lang.String;
label:
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String,int)>(v, 8);
label:
goto label;
label:
v := @caughtexception;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String,java.lang.Throwable)>("Invalid permissions mode provided while trying to createPermissions", v);
throw v;
label:
v = staticinvoke <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.util.Set modeToPosixFilePermission(int)>(v);
v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.util.Set permissions> = v;
return;
catch java.lang.NumberFormatException from label to label with label;
}
protected void stashOriginalFilePermissions() throws java.io.IOException
{
java.lang.String[] v, v, v;
java.util.StringTokenizer v;
int v, v, v, v;
java.lang.String v, v, v, v, v, v;
java.nio.file.Path v;
boolean v;
java.nio.file.LinkOption[] v;
java.util.Set v, v;
java.io.File v, v;
oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider v;
v := @this: oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider;
v = <oadd.org.apache.hadoop.util.Shell: boolean WINDOWS>;
if v != 0 goto label;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
v = virtualinvoke v.<java.io.File: java.lang.String getCanonicalPath()>();
v = newarray (java.lang.String)[0];
v = staticinvoke <java.nio.file.Paths: java.nio.file.Path get(java.lang.String,java.lang.String[])>(v, v);
v = newarray (java.nio.file.LinkOption)[0];
v = staticinvoke <java.nio.file.Files: java.util.Set getPosixFilePermissions(java.nio.file.Path,java.nio.file.LinkOption[])>(v, v);
v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.util.Set permissions> = v;
goto label;
label:
v = staticinvoke <oadd.org.apache.hadoop.util.Shell: java.lang.String[] getGetPermissionCommand()>();
v = lengthof v;
v = v + 1;
v = newarray (java.lang.String)[v];
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, v);
v = lengthof v;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
v = virtualinvoke v.<java.io.File: java.lang.String getCanonicalPath()>();
v[v] = v;
v = staticinvoke <oadd.org.apache.hadoop.util.Shell: java.lang.String execCommand(java.lang.String[])>(v);
v = new java.util.StringTokenizer;
v = <oadd.org.apache.hadoop.util.Shell: java.lang.String TOKEN_SEPARATOR_REGEX>;
specialinvoke v.<java.util.StringTokenizer: void <init>(java.lang.String,java.lang.String)>(v, v);
v = virtualinvoke v.<java.util.StringTokenizer: java.lang.String nextToken()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(1);
v = staticinvoke <java.nio.file.attribute.PosixFilePermissions: java.util.Set fromString(java.lang.String)>(v);
v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.util.Set permissions> = v;
label:
return;
}
protected void initFileSystem(java.net.URI) throws java.io.IOException
{
java.net.URISyntaxException v;
long v;
java.lang.String v, v, v;
java.net.URI v, v;
boolean v, v, v, v, v;
org.slf4j.Logger v, v, v, v, v, v, v;
java.io.IOException v;
java.io.File v, v, v, v, v, v;
oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider v;
oadd.org.apache.hadoop.fs.Path v;
v := @this: oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider;
v := @parameter: java.net.URI;
specialinvoke v.<oadd.org.apache.hadoop.security.alias.AbstractJavaKeyStoreProvider: void initFileSystem(java.net.URI)>(v);
label:
v = new java.io.File;
v = new java.net.URI;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: oadd.org.apache.hadoop.fs.Path getPath()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.fs.Path: java.lang.String toString()>();
specialinvoke v.<java.net.URI: void <init>(java.lang.String)>(v);
specialinvoke v.<java.io.File: void <init>(java.net.URI)>(v);
v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file> = v;
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
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[])>("initialized local file as \'\u0001\'.");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v == 0 goto label;
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
v = virtualinvoke v.<java.io.File: long length()>();
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[])>("the local file exists and is size \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
v = virtualinvoke v.<java.io.File: boolean canRead()>();
if v == 0 goto label;
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>("we can read the local file.");
label:
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
v = virtualinvoke v.<java.io.File: boolean canWrite()>();
if v == 0 goto label;
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>("we can write the local file.");
goto label;
label:
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("the local file does not exist.");
label:
goto label;
label:
v := @caughtexception;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
return;
catch java.net.URISyntaxException from label to label with label;
}
public void flush() throws java.io.IOException
{
java.lang.String[] v;
java.lang.String v, v, v, v;
java.nio.file.Path v;
boolean v, v;
org.slf4j.Logger v, v;
oadd.org.apache.hadoop.fs.permission.FsPermission v;
java.util.Set v, v, v;
java.io.File v, v;
oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider v;
v := @this: oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider;
specialinvoke v.<oadd.org.apache.hadoop.security.alias.AbstractJavaKeyStoreProvider: void flush()>();
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.util.Set permissions>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.Set)>(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[])>("Resetting permissions to \'\u0001\'");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
v = <oadd.org.apache.hadoop.util.Shell: boolean WINDOWS>;
if v != 0 goto label;
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
v = virtualinvoke v.<java.io.File: java.lang.String getCanonicalPath()>();
v = newarray (java.lang.String)[0];
v = staticinvoke <java.nio.file.Paths: java.nio.file.Path get(java.lang.String,java.lang.String[])>(v, v);
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.util.Set permissions>;
staticinvoke <java.nio.file.Files: java.nio.file.Path setPosixFilePermissions(java.nio.file.Path,java.util.Set)>(v, v);
goto label;
label:
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.util.Set permissions>;
v = staticinvoke <java.nio.file.attribute.PosixFilePermissions: java.lang.String toString(java.util.Set)>(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[])>("-\u0001");
v = staticinvoke <oadd.org.apache.hadoop.fs.permission.FsPermission: oadd.org.apache.hadoop.fs.permission.FsPermission valueOf(java.lang.String)>(v);
v = v.<oadd.org.apache.hadoop.security.alias.LocalJavaKeyStoreProvider: java.io.File file>;
staticinvoke <oadd.org.apache.hadoop.fs.FileUtil: void setPermission(java.io.File,oadd.org.apache.hadoop.fs.permission.FsPermission)>(v, v);
label:
return;
}
private static java.util.Set modeToPosixFilePermission(int)
{
int v, v, v, v, v, v, v, v, v, v;
java.util.EnumSet v;
java.nio.file.attribute.PosixFilePermission v, v, v, v, v, v, v, v, v;
v := @parameter: int;
v = staticinvoke <java.util.EnumSet: java.util.EnumSet noneOf(java.lang.Class)>(class "Ljava/nio/file/attribute/PosixFilePermission;");
v = v & 1;
if v == 0 goto label;
v = <java.nio.file.attribute.PosixFilePermission: java.nio.file.attribute.PosixFilePermission OTHERS_EXECUTE>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
v = v & 2;
if v == 0 goto label;
v = <java.nio.file.attribute.PosixFilePermission: java.nio.file.attribute.PosixFilePermission OTHERS_WRITE>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
v = v & 4;
if v == 0 goto label;
v = <java.nio.file.attribute.PosixFilePermission: java.nio.file.attribute.PosixFilePermission OTHERS_READ>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
v = v & 8;
if v == 0 goto label;
v = <java.nio.file.attribute.PosixFilePermission: java.nio.file.attribute.PosixFilePermission GROUP_EXECUTE>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
v = v & 16;
if v == 0 goto label;
v = <java.nio.file.attribute.PosixFilePermission: java.nio.file.attribute.PosixFilePermission GROUP_WRITE>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
v = v & 32;
if v == 0 goto label;
v = <java.nio.file.attribute.PosixFilePermission: java.nio.file.attribute.PosixFilePermission GROUP_READ>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
v = v & 64;
if v == 0 goto label;
v = <java.nio.file.attribute.PosixFilePermission: java.nio.file.attribute.PosixFilePermission OWNER_EXECUTE>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
v = v & 128;
if v == 0 goto label;
v = <java.nio.file.attribute.PosixFilePermission: java.nio.file.attribute.PosixFilePermission OWNER_WRITE>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
v = v & 256;
if v == 0 goto label;
v = <java.nio.file.attribute.PosixFilePermission: java.nio.file.attribute.PosixFilePermission OWNER_READ>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
return v;
}
}