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

org.bouncycastle.asn1.x509.PolicyConstraints 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 Java 1.8 and later with debug enabled.

The newest version!
package org.bouncycastle.asn1.x509;

import java.math.BigInteger;

import org.bouncycastle.asn1.ASN1EncodableVector;
import org.bouncycastle.asn1.ASN1Integer;
import org.bouncycastle.asn1.ASN1Object;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1TaggedObject;
import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.asn1.DERTaggedObject;

/**
 * PKIX RFC 5280
 * 
 * id-ce-policyConstraints OBJECT IDENTIFIER ::=  { id-ce 36 }
 *
 * PolicyConstraints ::= SEQUENCE {
 *      requireExplicitPolicy           [0] SkipCerts OPTIONAL,
 *      inhibitPolicyMapping            [1] SkipCerts OPTIONAL }
 *
 * SkipCerts ::= INTEGER (0..MAX)
 * 
*/ public class PolicyConstraints extends ASN1Object { private BigInteger requireExplicitPolicyMapping; private BigInteger inhibitPolicyMapping; public PolicyConstraints(BigInteger requireExplicitPolicyMapping, BigInteger inhibitPolicyMapping) { this.requireExplicitPolicyMapping = requireExplicitPolicyMapping; this.inhibitPolicyMapping = inhibitPolicyMapping; } private PolicyConstraints(ASN1Sequence seq) { for (int i = 0; i != seq.size(); i++) { ASN1TaggedObject to = ASN1TaggedObject.getInstance(seq.getObjectAt(i)); if (to.getTagNo() == 0) { requireExplicitPolicyMapping = ASN1Integer.getInstance(to, false).getValue(); } else if (to.getTagNo() == 1) { inhibitPolicyMapping = ASN1Integer.getInstance(to, false).getValue(); } else { throw new IllegalArgumentException("Unknown tag encountered."); } } } public static PolicyConstraints getInstance( Object obj) { if (obj instanceof PolicyConstraints) { return (PolicyConstraints)obj; } if (obj != null) { return new PolicyConstraints(ASN1Sequence.getInstance(obj)); } return null; } public static PolicyConstraints fromExtensions(Extensions extensions) { return getInstance(Extensions.getExtensionParsedValue(extensions, Extension.policyConstraints)); } public BigInteger getRequireExplicitPolicyMapping() { return requireExplicitPolicyMapping; } public BigInteger getInhibitPolicyMapping() { return inhibitPolicyMapping; } public ASN1Primitive toASN1Primitive() { ASN1EncodableVector v = new ASN1EncodableVector(2); if (requireExplicitPolicyMapping != null) { v.add(new DERTaggedObject(false,0, new ASN1Integer(requireExplicitPolicyMapping))); } if (inhibitPolicyMapping != null) { v.add(new DERTaggedObject(false, 1, new ASN1Integer(inhibitPolicyMapping))); } return new DERSequence(v); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy