org.bouncycastle.asn1.crmf.EncryptedKey Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bcprov-ext-jdk14 Show documentation
Show all versions of bcprov-ext-jdk14 Show documentation
The Bouncy Castle Crypto package is a Java implementation of cryptographic algorithms. This jar contains JCE provider and lightweight API for the Bouncy Castle Cryptography APIs for JDK 1.4. Note: this package includes the NTRU encryption algorithms.
package org.bouncycastle.asn1.crmf;
import org.bouncycastle.asn1.ASN1Choice;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1Object;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.ASN1TaggedObject;
import org.bouncycastle.asn1.DERTaggedObject;
import org.bouncycastle.asn1.cms.EnvelopedData;
public class EncryptedKey
extends ASN1Object
implements ASN1Choice
{
private EnvelopedData envelopedData;
private EncryptedValue encryptedValue;
public static EncryptedKey getInstance(Object o)
{
if (o instanceof EncryptedKey)
{
return (EncryptedKey)o;
}
else if (o instanceof ASN1TaggedObject)
{
return new EncryptedKey(EnvelopedData.getInstance((ASN1TaggedObject)o, false));
}
else if (o instanceof EncryptedValue)
{
return new EncryptedKey((EncryptedValue)o);
}
else
{
return new EncryptedKey(EncryptedValue.getInstance(o));
}
}
public EncryptedKey(EnvelopedData envelopedData)
{
this.envelopedData = envelopedData;
}
public EncryptedKey(EncryptedValue encryptedValue)
{
this.encryptedValue = encryptedValue;
}
public boolean isEncryptedValue()
{
return encryptedValue != null;
}
public ASN1Encodable getValue()
{
if (encryptedValue != null)
{
return encryptedValue;
}
return envelopedData;
}
/**
*
* EncryptedKey ::= CHOICE {
* encryptedValue EncryptedValue, -- deprecated
* envelopedData [0] EnvelopedData }
* -- The encrypted private key MUST be placed in the envelopedData
* -- encryptedContentInfo encryptedContent OCTET STRING.
*
*/
public ASN1Primitive toASN1Primitive()
{
if (encryptedValue != null)
{
return encryptedValue.toASN1Primitive();
}
return new DERTaggedObject(false, 0, envelopedData);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy