// 
// Decompiled by Procyon v0.6.0
// 

package org.bouncycastle.asn1.x509;

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

public class AttributeCertificate extends ASN1Object
{
    AttributeCertificateInfo acinfo;
    AlgorithmIdentifier signatureAlgorithm;
    ASN1BitString signatureValue;
    
    public static AttributeCertificate getInstance(final Object o) {
        if (o instanceof AttributeCertificate) {
            return (AttributeCertificate)o;
        }
        if (o != null) {
            return new AttributeCertificate(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    public AttributeCertificate(final AttributeCertificateInfo acinfo, final AlgorithmIdentifier signatureAlgorithm, final ASN1BitString signatureValue) {
        this.acinfo = acinfo;
        this.signatureAlgorithm = signatureAlgorithm;
        this.signatureValue = signatureValue;
    }
    
    private AttributeCertificate(final ASN1Sequence asn1Sequence) {
        if (asn1Sequence.size() != 3) {
            throw new IllegalArgumentException("Bad sequence size: " + asn1Sequence.size());
        }
        this.acinfo = AttributeCertificateInfo.getInstance(asn1Sequence.getObjectAt(0));
        this.signatureAlgorithm = AlgorithmIdentifier.getInstance(asn1Sequence.getObjectAt(1));
        this.signatureValue = ASN1BitString.getInstance(asn1Sequence.getObjectAt(2));
    }
    
    public AttributeCertificateInfo getAcinfo() {
        return this.acinfo;
    }
    
    public AlgorithmIdentifier getSignatureAlgorithm() {
        return this.signatureAlgorithm;
    }
    
    public ASN1BitString getSignatureValue() {
        return this.signatureValue;
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        final ASN1EncodableVector asn1EncodableVector = new ASN1EncodableVector(3);
        asn1EncodableVector.add(this.acinfo);
        asn1EncodableVector.add(this.signatureAlgorithm);
        asn1EncodableVector.add(this.signatureValue);
        return new DERSequence(asn1EncodableVector);
    }
}
