package org.bouncycastle.asn1.cms.ecc;

import org.bouncycastle.asn1.ASN1EncodableVector;
import org.bouncycastle.asn1.ASN1Object;
import org.bouncycastle.asn1.ASN1OctetString;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1TaggedObject;
import org.bouncycastle.asn1.DEROctetString;
import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.asn1.DERTaggedObject;
import org.bouncycastle.asn1.x509.AlgorithmIdentifier;
import org.bouncycastle.util.Arrays;

    ECC-CMS-SharedInfo ::= SEQUENCE {
       keyInfo AlgorithmIdentifier,
       entityUInfo [0] EXPLICIT OCTET STRING OPTIONAL,
       suppPubInfo [2] EXPLICIT OCTET STRING   }
/** * <pre> * ECC-CMS-SharedInfo ::= SEQUENCE { * keyInfo AlgorithmIdentifier, * entityUInfo [0] EXPLICIT OCTET STRING OPTIONAL, * suppPubInfo [2] EXPLICIT OCTET STRING } * </pre> */
public class ECCCMSSharedInfo extends ASN1Object { private final AlgorithmIdentifier keyInfo; private final byte[] entityUInfo; private final byte[] suppPubInfo; public ECCCMSSharedInfo( AlgorithmIdentifier keyInfo, byte[] entityUInfo, byte[] suppPubInfo) { this.keyInfo = keyInfo; this.entityUInfo = Arrays.clone(entityUInfo); this.suppPubInfo = Arrays.clone(suppPubInfo); } public ECCCMSSharedInfo( AlgorithmIdentifier keyInfo, byte[] suppPubInfo) { this.keyInfo = keyInfo; this.entityUInfo = null; this.suppPubInfo = Arrays.clone(suppPubInfo); } private ECCCMSSharedInfo( ASN1Sequence seq) { this.keyInfo = AlgorithmIdentifier.getInstance(seq.getObjectAt(0)); if (seq.size() == 2) { this.entityUInfo = null; this.suppPubInfo = ASN1OctetString.getInstance((ASN1TaggedObject)seq.getObjectAt(1), true).getOctets(); } else { this.entityUInfo = ASN1OctetString.getInstance((ASN1TaggedObject)seq.getObjectAt(1), true).getOctets(); this.suppPubInfo = ASN1OctetString.getInstance((ASN1TaggedObject)seq.getObjectAt(2), true).getOctets(); } }
Return an ECC-CMS-SharedInfo object from a tagged object.
Params:
  • obj – the tagged object holding the object we want.
  • explicit – true if the object is meant to be explicitly tagged false otherwise.
Throws:
/** * Return an ECC-CMS-SharedInfo object from a tagged object. * * @param obj the tagged object holding the object we want. * @param explicit true if the object is meant to be explicitly * tagged false otherwise. * @throws IllegalArgumentException if the object held by the * tagged object cannot be converted. */
public static ECCCMSSharedInfo getInstance( ASN1TaggedObject obj, boolean explicit) { return getInstance(ASN1Sequence.getInstance(obj, explicit)); } public static ECCCMSSharedInfo getInstance( Object obj) { if (obj instanceof ECCCMSSharedInfo) { return (ECCCMSSharedInfo)obj; } else if (obj != null) { return new ECCCMSSharedInfo(ASN1Sequence.getInstance(obj)); } return null; }
Produce an object suitable for an ASN1OutputStream.
/** * Produce an object suitable for an ASN1OutputStream. */
public ASN1Primitive toASN1Primitive() { ASN1EncodableVector v = new ASN1EncodableVector(); v.add(keyInfo); if (entityUInfo != null) { v.add(new DERTaggedObject(true, 0, new DEROctetString(entityUInfo))); } v.add(new DERTaggedObject(true, 2, new DEROctetString(suppPubInfo))); return new DERSequence(v); } }