blob: 0047f6aa4927a45654258f358a58d0a393528b0b [file] [log] [blame]
package org.bouncycastle.asn1.x509;
import java.math.BigInteger;
import java.util.Enumeration;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1EncodableVector;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1TaggedObject;
import org.bouncycastle.asn1.DERInteger;
import org.bouncycastle.asn1.DERObject;
import org.bouncycastle.asn1.DERSequence;
public class RSAPublicKeyStructure
extends ASN1Encodable
{
private BigInteger modulus;
private BigInteger publicExponent;
public static RSAPublicKeyStructure getInstance(
ASN1TaggedObject obj,
boolean explicit)
{
return getInstance(ASN1Sequence.getInstance(obj, explicit));
}
public static RSAPublicKeyStructure getInstance(
Object obj)
{
if(obj == null || obj instanceof RSAPublicKeyStructure)
{
return (RSAPublicKeyStructure)obj;
}
if(obj instanceof ASN1Sequence)
{
return new RSAPublicKeyStructure((ASN1Sequence)obj);
}
throw new IllegalArgumentException("Invalid RSAPublicKeyStructure: " + obj.getClass().getName());
}
public RSAPublicKeyStructure(
BigInteger modulus,
BigInteger publicExponent)
{
this.modulus = modulus;
this.publicExponent = publicExponent;
}
public RSAPublicKeyStructure(
ASN1Sequence seq)
{
if (seq.size() != 2)
{
throw new IllegalArgumentException("Bad sequence size: "
+ seq.size());
}
Enumeration e = seq.getObjects();
modulus = DERInteger.getInstance(e.nextElement()).getPositiveValue();
publicExponent = DERInteger.getInstance(e.nextElement()).getPositiveValue();
}
public BigInteger getModulus()
{
return modulus;
}
public BigInteger getPublicExponent()
{
return publicExponent;
}
/**
* This outputs the key in PKCS1v2 format.
* <pre>
* RSAPublicKey ::= SEQUENCE {
* modulus INTEGER, -- n
* publicExponent INTEGER, -- e
* }
* </pre>
* <p>
*/
public DERObject toASN1Object()
{
ASN1EncodableVector v = new ASN1EncodableVector();
v.add(new DERInteger(getModulus()));
v.add(new DERInteger(getPublicExponent()));
return new DERSequence(v);
}
}