All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bouncycastle.asn1.cmc.PKIData Maven / Gradle / Ivy

Go to download

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.

There is a newer version: 1.79
Show newest version
package org.bouncycastle.asn1.cmc;

import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1Object;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.DERSequence;

/**
 * 
 * PKIData ::= SEQUENCE {
 * controlSequence    SEQUENCE SIZE(0..MAX) OF TaggedAttribute,
 * reqSequence        SEQUENCE SIZE(0..MAX) OF TaggedRequest,
 * cmsSequence        SEQUENCE SIZE(0..MAX) OF TaggedContentInfo,
 * otherMsgSequence   SEQUENCE SIZE(0..MAX) OF OtherMsg
 * }
 * 
*/ public class PKIData extends ASN1Object { private final TaggedAttribute[] controlSequence; private final TaggedRequest[] reqSequence; private final TaggedContentInfo[] cmsSequence; private final OtherMsg[] otherMsgSequence; public PKIData( TaggedAttribute[] controlSequence, TaggedRequest[] reqSequence, TaggedContentInfo[] cmsSequence, OtherMsg[] otherMsgSequence) { this.controlSequence = copy(controlSequence); this.reqSequence = copy(reqSequence); this.cmsSequence = copy(cmsSequence); this.otherMsgSequence = copy(otherMsgSequence); } private PKIData(ASN1Sequence seq) { if (seq.size() != 4) { throw new IllegalArgumentException("Sequence not 4 elements."); } ASN1Sequence s = ((ASN1Sequence)seq.getObjectAt(0)); controlSequence = new TaggedAttribute[s.size()]; for (int t = 0; t < controlSequence.length; t++) { controlSequence[t] = TaggedAttribute.getInstance(s.getObjectAt(t)); } s = ((ASN1Sequence)seq.getObjectAt(1)); reqSequence = new TaggedRequest[s.size()]; for (int t = 0; t < reqSequence.length; t++) { reqSequence[t] = TaggedRequest.getInstance(s.getObjectAt(t)); } s = ((ASN1Sequence)seq.getObjectAt(2)); cmsSequence = new TaggedContentInfo[s.size()]; for (int t = 0; t < cmsSequence.length; t++) { cmsSequence[t] = TaggedContentInfo.getInstance(s.getObjectAt(t)); } s = ((ASN1Sequence)seq.getObjectAt(3)); otherMsgSequence = new OtherMsg[s.size()]; for (int t = 0; t < otherMsgSequence.length; t++) { otherMsgSequence[t] = OtherMsg.getInstance(s.getObjectAt(t)); } } public static PKIData getInstance(Object src) { if (src instanceof PKIData) { return (PKIData)src; } if (src != null) { return new PKIData(ASN1Sequence.getInstance(src)); } return null; } public ASN1Primitive toASN1Primitive() { return new DERSequence(new ASN1Encodable[]{ new DERSequence(controlSequence), new DERSequence(reqSequence), new DERSequence(cmsSequence), new DERSequence(otherMsgSequence) }); } public TaggedAttribute[] getControlSequence() { return copy(controlSequence); } private TaggedAttribute[] copy(TaggedAttribute[] taggedAtts) { TaggedAttribute[] tmp = new TaggedAttribute[taggedAtts.length]; System.arraycopy(taggedAtts, 0, tmp, 0, tmp.length); return tmp; } public TaggedRequest[] getReqSequence() { return copy(reqSequence); } private TaggedRequest[] copy(TaggedRequest[] taggedReqs) { TaggedRequest[] tmp = new TaggedRequest[taggedReqs.length]; System.arraycopy(taggedReqs, 0, tmp, 0, tmp.length); return tmp; } public TaggedContentInfo[] getCmsSequence() { return copy(cmsSequence); } private TaggedContentInfo[] copy(TaggedContentInfo[] taggedConts) { TaggedContentInfo[] tmp = new TaggedContentInfo[taggedConts.length]; System.arraycopy(taggedConts, 0, tmp, 0, tmp.length); return tmp; } public OtherMsg[] getOtherMsgSequence() { return copy(otherMsgSequence); } private OtherMsg[] copy(OtherMsg[] otherMsgs) { OtherMsg[] tmp = new OtherMsg[otherMsgs.length]; System.arraycopy(otherMsgs, 0, tmp, 0, tmp.length); return tmp; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy