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

org.bouncycastle.asn1.pkcs.PrivateKeyInfo Maven / Gradle / Ivy

package org.bouncycastle.asn1.pkcs;

import java.io.IOException;
import java.util.Enumeration;

import org.bouncycastle.asn1.ASN1BitString;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1EncodableVector;
import org.bouncycastle.asn1.ASN1Integer;
import org.bouncycastle.asn1.ASN1Object;
import org.bouncycastle.asn1.ASN1OctetString;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1Set;
import org.bouncycastle.asn1.ASN1TaggedObject;
import org.bouncycastle.asn1.DERBitString;
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.BigIntegers;

/**
 * RFC 5958
 *
 * 
 *  [IMPLICIT TAGS]
 *
 *  OneAsymmetricKey ::= SEQUENCE {
 *      version                   Version,
 *      privateKeyAlgorithm       PrivateKeyAlgorithmIdentifier,
 *      privateKey                PrivateKey,
 *      attributes            [0] Attributes OPTIONAL,
 *      ...,
 *      [[2: publicKey        [1] PublicKey OPTIONAL ]],
 *      ...
 *  }
 *
 *  PrivateKeyInfo ::= OneAsymmetricKey
 *
 *  Version ::= INTEGER { v1(0), v2(1) } (v1, ..., v2)
 *
 *  PrivateKeyAlgorithmIdentifier ::= AlgorithmIdentifier
 *                                     { PUBLIC-KEY,
 *                                       { PrivateKeyAlgorithms } }
 *
 *  PrivateKey ::= OCTET STRING
 *                     -- Content varies based on type of key.  The
 *                     -- algorithm identifier dictates the format of
 *                     -- the key.
 *
 *  PublicKey ::= BIT STRING
 *                     -- Content varies based on type of key.  The
 *                     -- algorithm identifier dictates the format of
 *                     -- the key.
 *
 *  Attributes ::= SET OF Attribute { { OneAsymmetricKeyAttributes } }
 *  
*/ public class PrivateKeyInfo extends ASN1Object { private ASN1Integer version; private AlgorithmIdentifier privateKeyAlgorithm; private ASN1OctetString privateKey; private ASN1Set attributes; private ASN1BitString publicKey; public static PrivateKeyInfo getInstance(ASN1TaggedObject obj, boolean explicit) { return getInstance(ASN1Sequence.getInstance(obj, explicit)); } public static PrivateKeyInfo getInstance(Object obj) { if (obj instanceof PrivateKeyInfo) { return (PrivateKeyInfo)obj; } else if (obj != null) { return new PrivateKeyInfo(ASN1Sequence.getInstance(obj)); } return null; } private static int getVersionValue(ASN1Integer version) { int versionValue = version.intValueExact(); if (versionValue < 0 || versionValue > 1) { throw new IllegalArgumentException("invalid version for private key info"); } return versionValue; } public PrivateKeyInfo( AlgorithmIdentifier privateKeyAlgorithm, ASN1Encodable privateKey) throws IOException { this(privateKeyAlgorithm, privateKey, null, null); } public PrivateKeyInfo( AlgorithmIdentifier privateKeyAlgorithm, ASN1Encodable privateKey, ASN1Set attributes) throws IOException { this(privateKeyAlgorithm, privateKey, attributes, null); } public PrivateKeyInfo( AlgorithmIdentifier privateKeyAlgorithm, ASN1Encodable privateKey, ASN1Set attributes, byte[] publicKey) throws IOException { this.version = new ASN1Integer(publicKey != null ? BigIntegers.ONE : BigIntegers.ZERO); this.privateKeyAlgorithm = privateKeyAlgorithm; this.privateKey = new DEROctetString(privateKey); this.attributes = attributes; this.publicKey = publicKey == null ? null : new DERBitString(publicKey); } private PrivateKeyInfo(ASN1Sequence seq) { Enumeration e = seq.getObjects(); this.version = ASN1Integer.getInstance(e.nextElement()); int versionValue = getVersionValue(version); this.privateKeyAlgorithm = AlgorithmIdentifier.getInstance(e.nextElement()); this.privateKey = ASN1OctetString.getInstance(e.nextElement()); int lastTag = -1; while (e.hasMoreElements()) { ASN1TaggedObject tagged = (ASN1TaggedObject)e.nextElement(); int tag = tagged.getTagNo(); if (tag <= lastTag) { throw new IllegalArgumentException("invalid optional field in private key info"); } lastTag = tag; switch (tag) { case 0: { this.attributes = ASN1Set.getInstance(tagged, false); break; } case 1: { if (versionValue < 1) { throw new IllegalArgumentException("'publicKey' requires version v2(1) or later"); } this.publicKey = ASN1BitString.getInstance(tagged, false); break; } default: { throw new IllegalArgumentException("unknown optional field in private key info"); } } } } public ASN1Integer getVersion() { return version; } public ASN1Set getAttributes() { return attributes; } public AlgorithmIdentifier getPrivateKeyAlgorithm() { return privateKeyAlgorithm; } public ASN1OctetString getPrivateKey() { return new DEROctetString(privateKey.getOctets()); } public int getPrivateKeyLength() { return privateKey.getOctetsLength(); } public ASN1Encodable parsePrivateKey() throws IOException { return ASN1Primitive.fromByteArray(privateKey.getOctets()); } /** * Return true if a public key is present, false otherwise. * * @return true if public included, otherwise false. */ public boolean hasPublicKey() { return publicKey != null; } /** * for when the public key is an encoded object - if the bitstring * can't be decoded this routine throws an IOException. * * @return the public key as an ASN.1 primitive. * @throws IOException - if the bit string doesn't represent a DER * encoded object. */ public ASN1Encodable parsePublicKey() throws IOException { return publicKey == null ? null : ASN1Primitive.fromByteArray(publicKey.getOctets()); } /** * for when the public key is raw bits. * * @return the public key as the raw bit string... */ public ASN1BitString getPublicKeyData() { return publicKey; } public ASN1Primitive toASN1Primitive() { ASN1EncodableVector v = new ASN1EncodableVector(5); v.add(version); v.add(privateKeyAlgorithm); v.add(privateKey); if (attributes != null) { v.add(new DERTaggedObject(false, 0, attributes)); } if (publicKey != null) { v.add(new DERTaggedObject(false, 1, publicKey)); } return new DERSequence(v); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy