org.bouncycastle.oer.its.PublicVerificationKey Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bcutil-jdk15on Show documentation
Show all versions of bcutil-jdk15on Show documentation
The Bouncy Castle Java APIs for ASN.1 extension and utility APIs used to support bcpkix and bctls. This jar contains APIs for JDK 1.5 and up.
The newest version!
package org.bouncycastle.oer.its;
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.DEROctetString;
import org.bouncycastle.asn1.DERTaggedObject;
/**
* PublicVerificationKey ::= CHOICE {
* ecdsaNistP256 EccP256CurvePoint,
* ecdsaBrainpoolP256r1 EccP256CurvePoint,
* ...,
* ecdsaBrainpoolP384r1 EccP384CurvePoint
* }
*/
public class PublicVerificationKey
extends ASN1Object
implements ASN1Choice
{
public final static int ecdsaNistP256 = 0;
public final static int ecdsaBrainpoolP256r1 = 1;
public final static int extension = 2;
public final static int ecdsaBrainpoolP384r1 = 3;
final int choice;
final ASN1Encodable curvePoint;
public PublicVerificationKey(int choice, ASN1Encodable curvePoint)
{
this.choice = choice;
this.curvePoint = curvePoint;
}
public static PublicVerificationKey getInstance(Object object)
{
if (object instanceof PublicVerificationKey)
{
return (PublicVerificationKey)object;
}
ASN1TaggedObject taggedObject = ASN1TaggedObject.getInstance(object);
ASN1Encodable point;
switch (taggedObject.getTagNo())
{
case ecdsaNistP256:
case ecdsaBrainpoolP256r1:
point = EccP256CurvePoint.getInstance(taggedObject.getObject());
break;
case extension:
point = DEROctetString.getInstance(taggedObject.getObject());
break;
case ecdsaBrainpoolP384r1:
point = EccP384CurvePoint.getInstance(taggedObject.getObject());
break;
default:
throw new IllegalArgumentException("unknown tag value " + taggedObject.getTagNo());
}
return new PublicVerificationKey(taggedObject.getTagNo(), point);
}
public static Builder builder()
{
return new Builder();
}
public int getChoice()
{
return choice;
}
public ASN1Encodable getCurvePoint()
{
return curvePoint;
}
public ASN1Primitive toASN1Primitive()
{
return new DERTaggedObject(choice, curvePoint);
}
public static class Builder
{
private int choice;
private ASN1Encodable curvePoint;
public Builder setChoice(int choice)
{
this.choice = choice;
return this;
}
public Builder setCurvePoint(EccCurvePoint curvePoint)
{
this.curvePoint = curvePoint;
return this;
}
public Builder ecdsaNistP256(EccP256CurvePoint point)
{
this.curvePoint = point;
return this;
}
public Builder ecdsaBrainpoolP256r1(EccP256CurvePoint point)
{
this.curvePoint = point;
return this;
}
public Builder ecdsaBrainpoolP384r1(EccP384CurvePoint point)
{
this.curvePoint = point;
return this;
}
public Builder extension(byte[] value)
{
this.curvePoint = new DEROctetString(value);
return this;
}
public PublicVerificationKey createPublicVerificationKey()
{
return new PublicVerificationKey(choice, curvePoint);
}
}
}