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

org.bouncycastle.asn1.cms.CMSORIforKEMOtherInfo Maven / Gradle / Ivy

There is a newer version: 2.0.0.0-RC3
Show newest version
package org.bouncycastle.asn1.cms;

import org.bouncycastle.asn1.ASN1EncodableVector;
import org.bouncycastle.asn1.ASN1Integer;
import org.bouncycastle.asn1.ASN1Object;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.DEROctetString;
import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.asn1.DERTaggedObject;
import org.bouncycastle.asn1.x509.AlgorithmIdentifier;

/**
 * 
 *  CMSORIforKEMOtherInfo ::= SEQUENCE {
 *     wrap KeyEncryptionAlgorithmIdentifier,
 *     kekLength INTEGER (1..MAX),
 *     ukm [0] EXPLICIT UserKeyingMaterial OPTIONAL
 *   }
 *
 *   UserKeyingMaterial ::= OCTET STRING
 * 
*/ public class CMSORIforKEMOtherInfo extends ASN1Object { private final AlgorithmIdentifier wrap; private final int kekLength; private final byte[] ukm; public CMSORIforKEMOtherInfo(AlgorithmIdentifier wrap, int kekLength) { this(wrap, kekLength, null); } public CMSORIforKEMOtherInfo(AlgorithmIdentifier wrap, int kekLength, byte[] ukm) { this.wrap = wrap; this.kekLength = kekLength; this.ukm = ukm; } public ASN1Primitive toASN1Primitive() { ASN1EncodableVector v = new ASN1EncodableVector(); v.add(wrap); v.add(new ASN1Integer(kekLength)); if (ukm != null) { v.add(new DERTaggedObject(true, 0, new DEROctetString(ukm))); } return new DERSequence(v); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy