com.fitbur.bouncycastle.asn1.crmf.EncryptedKey Maven / Gradle / Ivy
package com.fitbur.bouncycastle.asn1.crmf;
import com.fitbur.bouncycastle.asn1.ASN1Choice;
import com.fitbur.bouncycastle.asn1.ASN1Encodable;
import com.fitbur.bouncycastle.asn1.ASN1Object;
import com.fitbur.bouncycastle.asn1.ASN1Primitive;
import com.fitbur.bouncycastle.asn1.ASN1TaggedObject;
import com.fitbur.bouncycastle.asn1.DERTaggedObject;
import com.fitbur.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, -- com.fitburprecated
* 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 - 2024 Weber Informatics LLC | Privacy Policy