org.bouncycastle.asn1.cmp.PollReqContent Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bcprov-ext-jdk15on Show documentation
Show all versions of bcprov-ext-jdk15on 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.5 to JDK 1.8. Note: this package includes the NTRU encryption algorithms.
package org.bouncycastle.asn1.cmp;
import java.math.BigInteger;
import org.bouncycastle.asn1.ASN1Integer;
import org.bouncycastle.asn1.ASN1Object;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.DERSequence;
public class PollReqContent
extends ASN1Object
{
private ASN1Sequence content;
private PollReqContent(ASN1Sequence seq)
{
content = seq;
}
public static PollReqContent getInstance(Object o)
{
if (o instanceof PollReqContent)
{
return (PollReqContent)o;
}
if (o != null)
{
return new PollReqContent(ASN1Sequence.getInstance(o));
}
return null;
}
/**
* Create a pollReqContent for a single certReqId.
*
* @param certReqId the certificate request ID.
*/
public PollReqContent(ASN1Integer certReqId)
{
this(new DERSequence(new DERSequence(certReqId)));
}
/**
* Create a pollReqContent for a multiple certReqIds.
*
* @param certReqIds the certificate request IDs.
*/
public PollReqContent(ASN1Integer[] certReqIds)
{
this(new DERSequence(intsToSequence(certReqIds)));
}
/**
* Create a pollReqContent for a single certReqId.
*
* @param certReqId the certificate request ID.
*/
public PollReqContent(BigInteger certReqId)
{
this(new ASN1Integer(certReqId));
}
/**
* Create a pollReqContent for a multiple certReqIds.
*
* @param certReqIds the certificate request IDs.
*/
public PollReqContent(BigInteger[] certReqIds)
{
this(intsToASN1(certReqIds));
}
public ASN1Integer[][] getCertReqIds()
{
ASN1Integer[][] result = new ASN1Integer[content.size()][];
for (int i = 0; i != result.length; i++)
{
result[i] = sequenceToASN1IntegerArray((ASN1Sequence)content.getObjectAt(i));
}
return result;
}
public BigInteger[] getCertReqIdValues()
{
BigInteger[] result = new BigInteger[content.size()];
for (int i = 0; i != result.length; i++)
{
result[i] = ASN1Integer.getInstance(
ASN1Sequence.getInstance(content.getObjectAt(i)).getObjectAt(0)).getValue();
}
return result;
}
private static ASN1Integer[] sequenceToASN1IntegerArray(ASN1Sequence seq)
{
ASN1Integer[] result = new ASN1Integer[seq.size()];
for (int i = 0; i != result.length; i++)
{
result[i] = ASN1Integer.getInstance(seq.getObjectAt(i));
}
return result;
}
private static DERSequence[] intsToSequence(ASN1Integer[] ids)
{
DERSequence[] result = new DERSequence[ids.length];
for (int i = 0; i != result.length; i++)
{
result[i] = new DERSequence(ids[i]);
}
return result;
}
private static ASN1Integer[] intsToASN1(BigInteger[] ids)
{
ASN1Integer[] result = new ASN1Integer[ids.length];
for (int i = 0; i != result.length; i++)
{
result[i] = new ASN1Integer(ids[i]);
}
return result;
}
/**
*
* PollReqContent ::= SEQUENCE OF SEQUENCE {
* certReqId INTEGER
* }
*
* @return a basic ASN.1 object representation.
*/
public ASN1Primitive toASN1Primitive()
{
return content;
}
}