public final class oadd.org.apache.hadoop.util.KMSUtil extends java.lang.Object
{
public static final org.slf4j.Logger LOG;
private void <init>()
{
oadd.org.apache.hadoop.util.KMSUtil v;
v := @this: oadd.org.apache.hadoop.util.KMSUtil;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static oadd.org.apache.hadoop.crypto.key.KeyProvider createKeyProvider(oadd.org.apache.hadoop.conf.Configuration, java.lang.String) throws java.io.IOException
{
org.slf4j.Logger v;
oadd.org.apache.hadoop.crypto.key.KeyProvider v;
oadd.org.apache.hadoop.conf.Configuration v;
java.lang.String v;
java.net.URI v;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
v := @parameter: java.lang.String;
v = <oadd.org.apache.hadoop.util.KMSUtil: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Creating key provider with config key {}", v);
v = staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.net.URI getKeyProviderUri(oadd.org.apache.hadoop.conf.Configuration,java.lang.String)>(v, v);
if v == null goto label;
v = staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: oadd.org.apache.hadoop.crypto.key.KeyProvider createKeyProviderFromUri(oadd.org.apache.hadoop.conf.Configuration,java.net.URI)>(v, v);
goto label;
label:
v = null;
label:
return v;
}
public static java.net.URI getKeyProviderUri(oadd.org.apache.hadoop.conf.Configuration)
{
oadd.org.apache.hadoop.conf.Configuration v;
java.net.URI v;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
v = staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.net.URI getKeyProviderUri(oadd.org.apache.hadoop.conf.Configuration,java.lang.String)>(v, "hadoop.security.key.provider.path");
return v;
}
public static java.net.URI getKeyProviderUri(oadd.org.apache.hadoop.conf.Configuration, java.lang.String)
{
oadd.org.apache.hadoop.conf.Configuration v;
java.lang.String v, v;
java.net.URI v;
boolean v;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
v := @parameter: java.lang.String;
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.String getTrimmed(java.lang.String)>(v);
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v == 0 goto label;
label:
return null;
label:
v = staticinvoke <java.net.URI: java.net.URI create(java.lang.String)>(v);
return v;
}
public static oadd.org.apache.hadoop.crypto.key.KeyProvider createKeyProviderFromUri(oadd.org.apache.hadoop.conf.Configuration, java.net.URI) throws java.io.IOException
{
java.io.IOException v, v;
oadd.org.apache.hadoop.crypto.key.KeyProvider v;
oadd.org.apache.hadoop.conf.Configuration v;
java.lang.String v, v, v;
java.net.URI v;
boolean v;
v := @parameter: oadd.org.apache.hadoop.conf.Configuration;
v := @parameter: java.net.URI;
v = staticinvoke <oadd.org.apache.hadoop.crypto.key.KeyProviderFactory: oadd.org.apache.hadoop.crypto.key.KeyProvider get(java.net.URI,oadd.org.apache.hadoop.conf.Configuration)>(v, v);
if v != null goto label;
v = new java.io.IOException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.URI)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Could not instantiate KeyProvider for uri: \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<oadd.org.apache.hadoop.crypto.key.KeyProvider: boolean isTransient()>();
if v == 0 goto label;
v = new java.io.IOException;
v = virtualinvoke v.<java.lang.Object: java.lang.String toString()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("KeyProvider \u was found but it is a transient provider.");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
}
public static java.util.Map toJSON(oadd.org.apache.hadoop.crypto.key.KeyProvider$KeyVersion)
{
oadd.org.apache.hadoop.crypto.key.KeyProvider$KeyVersion v;
byte[] v;
java.util.HashMap v;
java.lang.String v, v, v;
v := @parameter: oadd.org.apache.hadoop.crypto.key.KeyProvider$KeyVersion;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
if v == null goto label;
v = virtualinvoke v.<oadd.org.apache.hadoop.crypto.key.KeyProvider$KeyVersion: java.lang.String getName()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("name", v);
v = virtualinvoke v.<oadd.org.apache.hadoop.crypto.key.KeyProvider$KeyVersion: java.lang.String getVersionName()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("versionName", v);
v = virtualinvoke v.<oadd.org.apache.hadoop.crypto.key.KeyProvider$KeyVersion: byte[] getMaterial()>();
v = staticinvoke <oadd.org.apache.commons.codec.binary.Base64: java.lang.String encodeBase64URLSafeString(byte[])>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("material", v);
label:
return v;
}
public static java.util.Map toJSON(oadd.org.apache.hadoop.crypto.key.KeyProviderCryptoExtension$EncryptedKeyVersion)
{
oadd.org.apache.hadoop.crypto.key.KeyProvider$KeyVersion v;
byte[] v;
oadd.org.apache.hadoop.crypto.key.KeyProviderCryptoExtension$EncryptedKeyVersion v;
java.util.Map v;
java.util.HashMap v;
java.lang.String v, v;
v := @parameter: oadd.org.apache.hadoop.crypto.key.KeyProviderCryptoExtension$EncryptedKeyVersion;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
if v == null goto label;
v = virtualinvoke v.<oadd.org.apache.hadoop.crypto.key.KeyProviderCryptoExtension$EncryptedKeyVersion: java.lang.String getEncryptionKeyVersionName()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("versionName", v);
v = virtualinvoke v.<oadd.org.apache.hadoop.crypto.key.KeyProviderCryptoExtension$EncryptedKeyVersion: byte[] getEncryptedKeyIv()>();
v = staticinvoke <oadd.org.apache.commons.codec.binary.Base64: java.lang.String encodeBase64URLSafeString(byte[])>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("iv", v);
v = virtualinvoke v.<oadd.org.apache.hadoop.crypto.key.KeyProviderCryptoExtension$EncryptedKeyVersion: oadd.org.apache.hadoop.crypto.key.KeyProvider$KeyVersion getEncryptedKeyVersion()>();
v = staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.util.Map toJSON(oadd.org.apache.hadoop.crypto.key.KeyProvider$KeyVersion)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("encryptedKeyVersion", v);
label:
return v;
}
public static java.lang.Object checkNotNull(java.lang.Object, java.lang.String) throws java.lang.IllegalArgumentException
{
java.lang.Object v;
java.lang.String v, v;
java.lang.IllegalArgumentException v;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.String;
if v != null goto label;
v = new java.lang.IllegalArgumentException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Parameter \'\u0001\' cannot be null");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
}
public static java.lang.String checkNotEmpty(java.lang.String, java.lang.String) throws java.lang.IllegalArgumentException
{
java.lang.String v, v, v;
java.lang.IllegalArgumentException v;
boolean v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, v);
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v == 0 goto label;
v = new java.lang.IllegalArgumentException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Parameter \'\u0001\' cannot be empty");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
}
public static java.util.List parseJSONEncKeyVersions(java.lang.String, java.util.List)
{
java.util.Iterator v;
java.util.ArrayList v;
java.util.List v;
oadd.org.apache.hadoop.crypto.key.KeyProviderCryptoExtension$EncryptedKeyVersion v;
int v;
java.lang.Object v;
java.lang.String v;
boolean v, v;
v := @parameter: java.lang.String;
v := @parameter: java.util.List;
staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "valueList");
v = new java.util.ArrayList;
v = interfaceinvoke v.<java.util.List: int size()>();
specialinvoke v.<java.util.ArrayList: void <init>(int)>(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 = staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: oadd.org.apache.hadoop.crypto.key.KeyProviderCryptoExtension$EncryptedKeyVersion parseJSONEncKeyVersion(java.lang.String,java.util.Map)>(v, v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
return v;
}
public static oadd.org.apache.hadoop.crypto.key.KeyProviderCryptoExtension$EncryptedKeyVersion parseJSONEncKeyVersion(java.lang.String, java.util.Map)
{
byte[] v, v;
oadd.org.apache.hadoop.crypto.key.kms.KMSClientProvider$KMSEncryptedKeyVersion v;
java.util.Map v;
java.lang.Object v, v, v, v, v, v, v, v, v, v;
java.lang.String v;
v := @parameter: java.lang.String;
v := @parameter: java.util.Map;
staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "valueMap");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("versionName");
v = staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "versionName");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("iv");
v = staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "iv");
v = staticinvoke <oadd.org.apache.commons.codec.binary.Base64: byte[] decodeBase64(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("encryptedKeyVersion");
v = staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "encryptedKeyVersion");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("versionName");
v = staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "versionName");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("material");
v = staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "material");
v = staticinvoke <oadd.org.apache.commons.codec.binary.Base64: byte[] decodeBase64(java.lang.String)>(v);
v = new oadd.org.apache.hadoop.crypto.key.kms.KMSClientProvider$KMSEncryptedKeyVersion;
specialinvoke v.<oadd.org.apache.hadoop.crypto.key.kms.KMSClientProvider$KMSEncryptedKeyVersion: void <init>(java.lang.String,java.lang.String,byte[],java.lang.String,byte[])>(v, v, v, v, v);
return v;
}
public static oadd.org.apache.hadoop.crypto.key.KeyProvider$KeyVersion parseJSONKeyVersion(java.util.Map)
{
byte[] v;
java.util.Map v;
oadd.org.apache.hadoop.crypto.key.kms.KMSClientProvider$KMSKeyVersion v, v;
java.lang.Object v, v, v;
boolean v, v;
v := @parameter: java.util.Map;
staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "valueMap");
v = null;
v = interfaceinvoke v.<java.util.Map: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>("material");
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("material");
v = staticinvoke <oadd.org.apache.commons.codec.binary.Base64: byte[] decodeBase64(java.lang.String)>(v);
goto label;
label:
v = null;
label:
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("versionName");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("name");
v = new oadd.org.apache.hadoop.crypto.key.kms.KMSClientProvider$KMSKeyVersion;
specialinvoke v.<oadd.org.apache.hadoop.crypto.key.kms.KMSClientProvider$KMSKeyVersion: void <init>(java.lang.String,java.lang.String,byte[])>(v, v, v);
v = v;
label:
return v;
}
public static oadd.org.apache.hadoop.crypto.key.KeyProvider$Metadata parseJSONMetadata(java.util.Map)
{
java.util.Date v;
oadd.org.apache.hadoop.crypto.key.kms.KMSClientProvider$KMSMetadata v, v;
long v;
java.util.Map v;
int v, v;
java.lang.Object v, v, v, v, v, v;
boolean v;
v := @parameter: java.util.Map;
staticinvoke <oadd.org.apache.hadoop.util.KMSUtil: java.lang.Object checkNotNull(java.lang.Object,java.lang.String)>(v, "valueMap");
v = null;
v = interfaceinvoke v.<java.util.Map: boolean isEmpty()>();
if v != 0 goto label;
v = new oadd.org.apache.hadoop.crypto.key.kms.KMSClientProvider$KMSMetadata;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("cipher");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("length");
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("description");
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("attributes");
v = new java.util.Date;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("created");
v = virtualinvoke v.<java.lang.Long: long longValue()>();
specialinvoke v.<java.util.Date: void <init>(long)>(v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>("versions");
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
specialinvoke v.<oadd.org.apache.hadoop.crypto.key.kms.KMSClientProvider$KMSMetadata: void <init>(java.lang.String,int,java.lang.String,java.util.Map,java.util.Date,int)>(v, v, v, v, v, v);
v = v;
label:
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/util/KMSUtil;");
<oadd.org.apache.hadoop.util.KMSUtil: org.slf4j.Logger LOG> = v;
return;
}
}