com.fitbur.bouncycastle.pkcs.PKCS8EncryptedPrivateKeyInfo Maven / Gradle / Ivy
package com.fitbur.bouncycastle.pkcs;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import com.fitbur.bouncycastle.asn1.ASN1Primitive;
import com.fitbur.bouncycastle.asn1.pkcs.EncryptedPrivateKeyInfo;
import com.fitbur.bouncycastle.asn1.pkcs.PrivateKeyInfo;
import com.fitbur.bouncycastle.cert.CertIOException;
import com.fitbur.bouncycastle.operator.InputDecryptor;
import com.fitbur.bouncycastle.operator.InputDecryptorProvider;
import com.fitbur.bouncycastle.util.io.Streams;
/**
* Holding class for a PKCS#8 EncryptedPrivateKeyInfo structure.
*/
public class PKCS8EncryptedPrivateKeyInfo
{
private EncryptedPrivateKeyInfo encryptedPrivateKeyInfo;
private static EncryptedPrivateKeyInfo parseBytes(byte[] pkcs8Encoding)
throws IOException
{
try
{
return EncryptedPrivateKeyInfo.getInstance(ASN1Primitive.fromByteArray(pkcs8Encoding));
}
catch (ClassCastException e)
{
throw new CertIOException("malformed data: " + e.getMessage(), e);
}
catch (IllegalArgumentException e)
{
throw new CertIOException("malformed data: " + e.getMessage(), e);
}
}
public PKCS8EncryptedPrivateKeyInfo(EncryptedPrivateKeyInfo encryptedPrivateKeyInfo)
{
this.encryptedPrivateKeyInfo = encryptedPrivateKeyInfo;
}
public PKCS8EncryptedPrivateKeyInfo(byte[] encryptedPrivateKeyInfo)
throws IOException
{
this(parseBytes(encryptedPrivateKeyInfo));
}
public EncryptedPrivateKeyInfo toASN1Structure()
{
return encryptedPrivateKeyInfo;
}
public byte[] getEncoded()
throws IOException
{
return encryptedPrivateKeyInfo.getEncoded();
}
public PrivateKeyInfo com.fitburcryptPrivateKeyInfo(InputDecryptorProvider inputDecryptorProvider)
throws PKCSException
{
try
{
InputDecryptor com.fitburcrytor = inputDecryptorProvider.get(encryptedPrivateKeyInfo.getEncryptionAlgorithm());
ByteArrayInputStream encIn = new ByteArrayInputStream(encryptedPrivateKeyInfo.getEncryptedData());
return PrivateKeyInfo.getInstance(Streams.readAll(com.fitburcrytor.getInputStream(encIn)));
}
catch (Exception e)
{
throw new PKCSException("unable to read encrypted data: " + e.getMessage(), e);
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy