public final class org.apache.zookeeper.util.PemReader extends java.lang.Object
{
private static final java.util.regex.Pattern CERT_PATTERN;
private static final java.util.regex.Pattern PRIVATE_KEY_PATTERN;
private static final java.util.regex.Pattern PUBLIC_KEY_PATTERN;
private void <init>()
{
org.apache.zookeeper.util.PemReader v;
v := @this: org.apache.zookeeper.util.PemReader;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static java.security.KeyStore loadTrustStore(java.io.File) throws java.io.IOException, java.security.GeneralSecurityException
{
javax.security.auth.x.X500Principal v;
java.util.Iterator v;
java.security.KeyStore v;
java.io.File v;
java.util.List v;
java.lang.Object v;
java.lang.String v;
boolean v;
v := @parameter: java.io.File;
v = staticinvoke <java.security.KeyStore: java.security.KeyStore getInstance(java.lang.String)>("JKS");
virtualinvoke v.<java.security.KeyStore: void load(java.io.InputStream,char[])>(null, null);
v = staticinvoke <org.apache.zookeeper.util.PemReader: java.util.List readCertificateChain(java.io.File)>(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.<java.security.cert.X509Certificate: javax.security.auth.x.X500Principal getSubjectX500Principal()>();
v = virtualinvoke v.<javax.security.auth.x.X500Principal: java.lang.String getName(java.lang.String)>("RFC2253");
virtualinvoke v.<java.security.KeyStore: void setCertificateEntry(java.lang.String,java.security.cert.Certificate)>(v, v);
goto label;
label:
return v;
}
public static java.security.KeyStore loadKeyStore(java.io.File, java.io.File, java.util.Optional) throws java.io.IOException, java.security.GeneralSecurityException
{
java.lang.Object[] v;
java.security.KeyStore v;
java.security.cert.CertificateException v;
java.io.File v, v;
java.util.List v;
java.security.PrivateKey v;
char[] v;
java.util.Optional v;
java.lang.Object v;
java.security.cert.Certificate[] v;
java.lang.String v;
boolean v;
v := @parameter: java.io.File;
v := @parameter: java.io.File;
v := @parameter: java.util.Optional;
v = staticinvoke <org.apache.zookeeper.util.PemReader: java.security.PrivateKey loadPrivateKey(java.io.File,java.util.Optional)>(v, v);
v = staticinvoke <org.apache.zookeeper.util.PemReader: java.util.List readCertificateChain(java.io.File)>(v);
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
v = new java.security.cert.CertificateException;
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[])>("Certificate file does not contain any certificates: \u0001");
specialinvoke v.<java.security.cert.CertificateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = staticinvoke <java.security.KeyStore: java.security.KeyStore getInstance(java.lang.String)>("JKS");
virtualinvoke v.<java.security.KeyStore: void load(java.io.InputStream,char[])>(null, null);
v = virtualinvoke v.<java.util.Optional: java.lang.Object orElse(java.lang.Object)>("");
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
v = newarray (java.security.cert.Certificate)[0];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
virtualinvoke v.<java.security.KeyStore: void setKeyEntry(java.lang.String,java.security.Key,char[],java.security.cert.Certificate[])>("key", v, v, v);
return v;
}
public static java.util.List readCertificateChain(java.io.File) throws java.io.IOException, java.security.GeneralSecurityException
{
byte[] v;
java.util.List v;
java.nio.charset.Charset v;
java.lang.String v;
java.nio.file.Path v;
java.io.File v;
v := @parameter: java.io.File;
v = new java.lang.String;
v = virtualinvoke v.<java.io.File: java.nio.file.Path toPath()>();
v = staticinvoke <java.nio.file.Files: byte[] readAllBytes(java.nio.file.Path)>(v);
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset US_ASCII>;
specialinvoke v.<java.lang.String: void <init>(byte[],java.nio.charset.Charset)>(v, v);
v = staticinvoke <org.apache.zookeeper.util.PemReader: java.util.List readCertificateChain(java.lang.String)>(v);
return v;
}
public static java.util.List readCertificateChain(java.lang.String) throws java.security.cert.CertificateException
{
byte[] v;
java.security.cert.CertificateFactory v;
java.util.ArrayList v;
java.security.cert.Certificate v;
java.util.regex.Matcher v;
java.io.ByteArrayInputStream v;
int v;
java.lang.String v, v;
java.util.regex.Pattern v;
boolean v;
v := @parameter: java.lang.String;
v = <org.apache.zookeeper.util.PemReader: java.util.regex.Pattern CERT_PATTERN>;
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = staticinvoke <java.security.cert.CertificateFactory: java.security.cert.CertificateFactory getInstance(java.lang.String)>("X.509");
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = 0;
label:
v = virtualinvoke v.<java.util.regex.Matcher: boolean find(int)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(1);
v = staticinvoke <org.apache.zookeeper.util.PemReader: byte[] base64Decode(java.lang.String)>(v);
v = new java.io.ByteArrayInputStream;
specialinvoke v.<java.io.ByteArrayInputStream: void <init>(byte[])>(v);
v = virtualinvoke v.<java.security.cert.CertificateFactory: java.security.cert.Certificate generateCertificate(java.io.InputStream)>(v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: int end()>();
goto label;
label:
return v;
}
public static java.security.PrivateKey loadPrivateKey(java.io.File, java.util.Optional) throws java.io.IOException, java.security.GeneralSecurityException
{
byte[] v;
java.nio.charset.Charset v;
java.security.PrivateKey v;
java.util.Optional v;
java.lang.String v;
java.nio.file.Path v;
java.io.File v;
v := @parameter: java.io.File;
v := @parameter: java.util.Optional;
v = new java.lang.String;
v = virtualinvoke v.<java.io.File: java.nio.file.Path toPath()>();
v = staticinvoke <java.nio.file.Files: byte[] readAllBytes(java.nio.file.Path)>(v);
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset US_ASCII>;
specialinvoke v.<java.lang.String: void <init>(byte[],java.nio.charset.Charset)>(v, v);
v = staticinvoke <org.apache.zookeeper.util.PemReader: java.security.PrivateKey loadPrivateKey(java.lang.String,java.util.Optional)>(v, v);
return v;
}
public static java.security.PrivateKey loadPrivateKey(java.lang.String, java.util.Optional) throws java.io.IOException, java.security.GeneralSecurityException
{
byte[] v;
java.security.spec.InvalidKeySpecException v, v;
java.security.KeyStoreException v;
javax.crypto.Cipher v;
javax.crypto.SecretKeyFactory v;
java.util.regex.Matcher v;
javax.crypto.EncryptedPrivateKeyInfo v;
javax.crypto.spec.PBEKeySpec v;
java.lang.String v, v, v, v;
boolean v, v;
java.security.spec.PKCS8EncodedKeySpec v, v;
java.security.AlgorithmParameters v;
java.security.KeyFactory v, v, v;
java.security.PrivateKey v, v, v;
char[] v;
java.util.Optional v;
java.lang.Object v;
java.util.regex.Pattern v;
javax.crypto.SecretKey v;
v := @parameter: java.lang.String;
v := @parameter: java.util.Optional;
v = <org.apache.zookeeper.util.PemReader: java.util.regex.Pattern PRIVATE_KEY_PATTERN>;
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 = new java.security.KeyStoreException;
specialinvoke v.<java.security.KeyStoreException: void <init>(java.lang.String)>("did not find a private key");
throw v;
label:
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(1);
v = staticinvoke <org.apache.zookeeper.util.PemReader: byte[] base64Decode(java.lang.String)>(v);
v = virtualinvoke v.<java.util.Optional: boolean isPresent()>();
if v == 0 goto label;
v = new javax.crypto.EncryptedPrivateKeyInfo;
specialinvoke v.<javax.crypto.EncryptedPrivateKeyInfo: void <init>(byte[])>(v);
v = virtualinvoke v.<javax.crypto.EncryptedPrivateKeyInfo: java.lang.String getAlgName()>();
v = staticinvoke <javax.crypto.SecretKeyFactory: javax.crypto.SecretKeyFactory getInstance(java.lang.String)>(v);
v = new javax.crypto.spec.PBEKeySpec;
v = virtualinvoke v.<java.util.Optional: java.lang.Object get()>();
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
specialinvoke v.<javax.crypto.spec.PBEKeySpec: void <init>(char[])>(v);
v = virtualinvoke v.<javax.crypto.SecretKeyFactory: javax.crypto.SecretKey generateSecret(java.security.spec.KeySpec)>(v);
v = virtualinvoke v.<javax.crypto.EncryptedPrivateKeyInfo: java.lang.String getAlgName()>();
v = staticinvoke <javax.crypto.Cipher: javax.crypto.Cipher getInstance(java.lang.String)>(v);
v = virtualinvoke v.<javax.crypto.EncryptedPrivateKeyInfo: java.security.AlgorithmParameters getAlgParameters()>();
virtualinvoke v.<javax.crypto.Cipher: void init(int,java.security.Key,java.security.AlgorithmParameters)>(2, v, v);
v = virtualinvoke v.<javax.crypto.EncryptedPrivateKeyInfo: java.security.spec.PKCS8EncodedKeySpec getKeySpec(javax.crypto.Cipher)>(v);
goto label;
label:
v = new java.security.spec.PKCS8EncodedKeySpec;
specialinvoke v.<java.security.spec.PKCS8EncodedKeySpec: void <init>(byte[])>(v);
v = v;
label:
v = staticinvoke <java.security.KeyFactory: java.security.KeyFactory getInstance(java.lang.String)>("RSA");
v = virtualinvoke v.<java.security.KeyFactory: java.security.PrivateKey generatePrivate(java.security.spec.KeySpec)>(v);
label:
return v;
label:
v := @caughtexception;
label:
v = staticinvoke <java.security.KeyFactory: java.security.KeyFactory getInstance(java.lang.String)>("EC");
v = virtualinvoke v.<java.security.KeyFactory: java.security.PrivateKey generatePrivate(java.security.spec.KeySpec)>(v);
label:
return v;
label:
v := @caughtexception;
v = staticinvoke <java.security.KeyFactory: java.security.KeyFactory getInstance(java.lang.String)>("DSA");
v = virtualinvoke v.<java.security.KeyFactory: java.security.PrivateKey generatePrivate(java.security.spec.KeySpec)>(v);
return v;
catch java.security.spec.InvalidKeySpecException from label to label with label;
catch java.security.spec.InvalidKeySpecException from label to label with label;
}
public static java.security.PublicKey loadPublicKey(java.io.File) throws java.io.IOException, java.security.GeneralSecurityException
{
byte[] v;
java.nio.charset.Charset v;
java.security.PublicKey v;
java.lang.String v;
java.nio.file.Path v;
java.io.File v;
v := @parameter: java.io.File;
v = new java.lang.String;
v = virtualinvoke v.<java.io.File: java.nio.file.Path toPath()>();
v = staticinvoke <java.nio.file.Files: byte[] readAllBytes(java.nio.file.Path)>(v);
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset US_ASCII>;
specialinvoke v.<java.lang.String: void <init>(byte[],java.nio.charset.Charset)>(v, v);
v = staticinvoke <org.apache.zookeeper.util.PemReader: java.security.PublicKey loadPublicKey(java.lang.String)>(v);
return v;
}
public static java.security.PublicKey loadPublicKey(java.lang.String) throws java.security.GeneralSecurityException
{
byte[] v;
java.security.spec.InvalidKeySpecException v, v;
java.security.KeyStoreException v;
java.util.regex.Matcher v;
java.lang.String v, v;
boolean v;
java.security.PublicKey v, v, v;
java.security.spec.X509EncodedKeySpec v;
java.security.KeyFactory v, v, v;
java.util.regex.Pattern v;
v := @parameter: java.lang.String;
v = <org.apache.zookeeper.util.PemReader: java.util.regex.Pattern PUBLIC_KEY_PATTERN>;
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 = new java.security.KeyStoreException;
specialinvoke v.<java.security.KeyStoreException: void <init>(java.lang.String)>("did not find a public key");
throw v;
label:
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(1);
v = staticinvoke <org.apache.zookeeper.util.PemReader: byte[] base64Decode(java.lang.String)>(v);
v = new java.security.spec.X509EncodedKeySpec;
specialinvoke v.<java.security.spec.X509EncodedKeySpec: void <init>(byte[])>(v);
label:
v = staticinvoke <java.security.KeyFactory: java.security.KeyFactory getInstance(java.lang.String)>("RSA");
v = virtualinvoke v.<java.security.KeyFactory: java.security.PublicKey generatePublic(java.security.spec.KeySpec)>(v);
label:
return v;
label:
v := @caughtexception;
label:
v = staticinvoke <java.security.KeyFactory: java.security.KeyFactory getInstance(java.lang.String)>("EC");
v = virtualinvoke v.<java.security.KeyFactory: java.security.PublicKey generatePublic(java.security.spec.KeySpec)>(v);
label:
return v;
label:
v := @caughtexception;
v = staticinvoke <java.security.KeyFactory: java.security.KeyFactory getInstance(java.lang.String)>("DSA");
v = virtualinvoke v.<java.security.KeyFactory: java.security.PublicKey generatePublic(java.security.spec.KeySpec)>(v);
return v;
catch java.security.spec.InvalidKeySpecException from label to label with label;
catch java.security.spec.InvalidKeySpecException from label to label with label;
}
private static byte[] base64Decode(java.lang.String)
{
byte[] v, v;
java.nio.charset.Charset v;
java.util.Base64$Decoder v;
java.lang.String v;
v := @parameter: java.lang.String;
v = staticinvoke <java.util.Base64: java.util.Base64$Decoder getMimeDecoder()>();
v = <java.nio.charset.StandardCharsets: java.nio.charset.Charset US_ASCII>;
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.nio.charset.Charset)>(v);
v = virtualinvoke v.<java.util.Base64$Decoder: byte[] decode(byte[])>(v);
return v;
}
static void <clinit>()
{
java.util.regex.Pattern v, v, v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String,int)>("-+BEGIN\\s+.*CERTIFICATE[^-]*-+(?:\\s|\\r|\\n)+([a-z0-9+/=\\r\\n]+)-+END\\s+.*CERTIFICATE[^-]*-+", 2);
<org.apache.zookeeper.util.PemReader: java.util.regex.Pattern CERT_PATTERN> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String,int)>("-+BEGIN\\s+.*PRIVATE\\s+KEY[^-]*-+(?:\\s|\\r|\\n)+([a-z0-9+/=\\r\\n]+)-+END\\s+.*PRIVATE\\s+KEY[^-]*-+", 2);
<org.apache.zookeeper.util.PemReader: java.util.regex.Pattern PRIVATE_KEY_PATTERN> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String,int)>("-+BEGIN\\s+.*PUBLIC\\s+KEY[^-]*-+(?:\\s|\\r|\\n)+([a-z0-9+/=\\r\\n]+)-+END\\s+.*PUBLIC\\s+KEY[^-]*-+", 2);
<org.apache.zookeeper.util.PemReader: java.util.regex.Pattern PUBLIC_KEY_PATTERN> = v;
return;
}
}