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

package org.bouncycastle.asn1.ess;

import org.bouncycastle.asn1.nist.NISTObjectIdentifiers;
import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1EncodableVector;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.DEROctetString;
import org.bouncycastle.util.Arrays;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.oiw.OIWObjectIdentifiers;
import org.bouncycastle.asn1.x509.IssuerSerial;
import org.bouncycastle.asn1.ASN1OctetString;
import org.bouncycastle.asn1.x509.AlgorithmIdentifier;
import org.bouncycastle.asn1.ASN1Object;

public class ESSCertIDv2 extends ASN1Object
{
    private static final AlgorithmIdentifier DEFAULT_HASH_ALGORITHM;
    private AlgorithmIdentifier hashAlgorithm;
    private ASN1OctetString certHash;
    private IssuerSerial issuerSerial;
    
    public static ESSCertIDv2 from(final ESSCertID essCertID) {
        return new ESSCertIDv2(new AlgorithmIdentifier(OIWObjectIdentifiers.idSHA1), essCertID.getCertHashObject(), essCertID.getIssuerSerial());
    }
    
    public static ESSCertIDv2 getInstance(final Object o) {
        if (o instanceof ESSCertIDv2) {
            return (ESSCertIDv2)o;
        }
        if (o != null) {
            return new ESSCertIDv2(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    private ESSCertIDv2(final ASN1Sequence asn1Sequence) {
        if (asn1Sequence.size() > 3) {
            throw new IllegalArgumentException("Bad sequence size: " + asn1Sequence.size());
        }
        int n = 0;
        if (asn1Sequence.getObjectAt(0) instanceof ASN1OctetString) {
            this.hashAlgorithm = ESSCertIDv2.DEFAULT_HASH_ALGORITHM;
        }
        else {
            this.hashAlgorithm = AlgorithmIdentifier.getInstance(asn1Sequence.getObjectAt(n++));
        }
        this.certHash = ASN1OctetString.getInstance(asn1Sequence.getObjectAt(n++));
        if (asn1Sequence.size() > n) {
            this.issuerSerial = IssuerSerial.getInstance(asn1Sequence.getObjectAt(n));
        }
    }
    
    public ESSCertIDv2(final byte[] array) {
        this(null, array, null);
    }
    
    public ESSCertIDv2(final AlgorithmIdentifier algorithmIdentifier, final byte[] array) {
        this(algorithmIdentifier, array, null);
    }
    
    public ESSCertIDv2(final byte[] array, final IssuerSerial issuerSerial) {
        this(null, array, issuerSerial);
    }
    
    public ESSCertIDv2(AlgorithmIdentifier default_HASH_ALGORITHM, final byte[] array, final IssuerSerial issuerSerial) {
        if (default_HASH_ALGORITHM == null) {
            default_HASH_ALGORITHM = ESSCertIDv2.DEFAULT_HASH_ALGORITHM;
        }
        this.hashAlgorithm = default_HASH_ALGORITHM;
        this.certHash = new DEROctetString(Arrays.clone(array));
        this.issuerSerial = issuerSerial;
    }
    
    public ESSCertIDv2(AlgorithmIdentifier default_HASH_ALGORITHM, final ASN1OctetString certHash, final IssuerSerial issuerSerial) {
        if (default_HASH_ALGORITHM == null) {
            default_HASH_ALGORITHM = ESSCertIDv2.DEFAULT_HASH_ALGORITHM;
        }
        if (certHash == null) {
            throw new NullPointerException("'certHash' cannot be null");
        }
        this.hashAlgorithm = default_HASH_ALGORITHM;
        this.certHash = certHash;
        this.issuerSerial = issuerSerial;
    }
    
    public AlgorithmIdentifier getHashAlgorithm() {
        return this.hashAlgorithm;
    }
    
    public ASN1OctetString getCertHashObject() {
        return this.certHash;
    }
    
    public byte[] getCertHash() {
        return Arrays.clone(this.certHash.getOctets());
    }
    
    public IssuerSerial getIssuerSerial() {
        return this.issuerSerial;
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        final ASN1EncodableVector asn1EncodableVector = new ASN1EncodableVector(3);
        if (!ESSCertIDv2.DEFAULT_HASH_ALGORITHM.equals(this.hashAlgorithm)) {
            asn1EncodableVector.add(this.hashAlgorithm);
        }
        asn1EncodableVector.add(this.certHash);
        if (this.issuerSerial != null) {
            asn1EncodableVector.add(this.issuerSerial);
        }
        return new DERSequence(asn1EncodableVector);
    }
    
    static {
        DEFAULT_HASH_ALGORITHM = new AlgorithmIdentifier(NISTObjectIdentifiers.id_sha256);
    }
}
