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

package org.bouncycastle.asn1.cryptopro;

import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1EncodableVector;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.internal.asn1.rosstandart.RosstandartObjectIdentifiers;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1TaggedObject;
import org.bouncycastle.asn1.ASN1ObjectIdentifier;
import org.bouncycastle.asn1.ASN1Object;

public class GOST3410PublicKeyAlgParameters extends ASN1Object
{
    private ASN1ObjectIdentifier publicKeyParamSet;
    private ASN1ObjectIdentifier digestParamSet;
    private ASN1ObjectIdentifier encryptionParamSet;
    
    public static GOST3410PublicKeyAlgParameters getInstance(final ASN1TaggedObject asn1TaggedObject, final boolean b) {
        return getInstance(ASN1Sequence.getInstance(asn1TaggedObject, b));
    }
    
    public static GOST3410PublicKeyAlgParameters getInstance(final Object o) {
        if (o instanceof GOST3410PublicKeyAlgParameters) {
            return (GOST3410PublicKeyAlgParameters)o;
        }
        if (o != null) {
            return new GOST3410PublicKeyAlgParameters(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    public GOST3410PublicKeyAlgParameters(final ASN1ObjectIdentifier publicKeyParamSet, final ASN1ObjectIdentifier digestParamSet) {
        this.publicKeyParamSet = publicKeyParamSet;
        this.digestParamSet = digestParamSet;
        this.encryptionParamSet = null;
    }
    
    public GOST3410PublicKeyAlgParameters(final ASN1ObjectIdentifier publicKeyParamSet, final ASN1ObjectIdentifier digestParamSet, final ASN1ObjectIdentifier encryptionParamSet) {
        this.publicKeyParamSet = publicKeyParamSet;
        this.digestParamSet = digestParamSet;
        this.encryptionParamSet = encryptionParamSet;
    }
    
    private GOST3410PublicKeyAlgParameters(final ASN1Sequence asn1Sequence) {
        this.publicKeyParamSet = ASN1ObjectIdentifier.getInstance(asn1Sequence.getObjectAt(0));
        if (this.publicKeyParamSet.equals(RosstandartObjectIdentifiers.id_tc26_gost_3410_12_256_paramSetA)) {
            if (asn1Sequence.size() > 1) {
                this.digestParamSet = ASN1ObjectIdentifier.getInstance(asn1Sequence.getObjectAt(1));
            }
        }
        else if (this.publicKeyParamSet.equals(RosstandartObjectIdentifiers.id_tc26_gost_3410_12_256_paramSetB) || this.publicKeyParamSet.equals(RosstandartObjectIdentifiers.id_tc26_gost_3410_12_256_paramSetC) || this.publicKeyParamSet.equals(RosstandartObjectIdentifiers.id_tc26_gost_3410_12_256_paramSetD)) {
            if (asn1Sequence.size() > 1) {
                throw new IllegalArgumentException("digestParamSet expected to be absent");
            }
        }
        else if (asn1Sequence.size() > 1) {
            this.digestParamSet = ASN1ObjectIdentifier.getInstance(asn1Sequence.getObjectAt(1));
        }
        if (asn1Sequence.size() > 2) {
            this.encryptionParamSet = (ASN1ObjectIdentifier)asn1Sequence.getObjectAt(2);
        }
    }
    
    public ASN1ObjectIdentifier getPublicKeyParamSet() {
        return this.publicKeyParamSet;
    }
    
    public ASN1ObjectIdentifier getDigestParamSet() {
        return this.digestParamSet;
    }
    
    public ASN1ObjectIdentifier getEncryptionParamSet() {
        return this.encryptionParamSet;
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        final ASN1EncodableVector asn1EncodableVector = new ASN1EncodableVector(3);
        asn1EncodableVector.add(this.publicKeyParamSet);
        if (this.digestParamSet != null) {
            asn1EncodableVector.add(this.digestParamSet);
        }
        if (this.encryptionParamSet != null) {
            asn1EncodableVector.add(this.encryptionParamSet);
        }
        return new DERSequence(asn1EncodableVector);
    }
}
