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

package org.bouncycastle.asn1.pkcs;

import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.asn1.ASN1Primitive;
import java.util.Enumeration;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1Object;

public class PBES2Parameters extends ASN1Object implements PKCSObjectIdentifiers
{
    private KeyDerivationFunc func;
    private EncryptionScheme scheme;
    
    public static PBES2Parameters getInstance(final Object o) {
        if (o instanceof PBES2Parameters) {
            return (PBES2Parameters)o;
        }
        if (o != null) {
            return new PBES2Parameters(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    public PBES2Parameters(final KeyDerivationFunc func, final EncryptionScheme scheme) {
        this.func = func;
        this.scheme = scheme;
    }
    
    private PBES2Parameters(final ASN1Sequence asn1Sequence) {
        final Enumeration objects = asn1Sequence.getObjects();
        final ASN1Sequence instance = ASN1Sequence.getInstance(objects.nextElement().toASN1Primitive());
        if (instance.getObjectAt(0).equals(PBES2Parameters.id_PBKDF2)) {
            this.func = new KeyDerivationFunc(PBES2Parameters.id_PBKDF2, PBKDF2Params.getInstance(instance.getObjectAt(1)));
        }
        else {
            this.func = KeyDerivationFunc.getInstance(instance);
        }
        this.scheme = EncryptionScheme.getInstance(objects.nextElement());
    }
    
    public KeyDerivationFunc getKeyDerivationFunc() {
        return this.func;
    }
    
    public EncryptionScheme getEncryptionScheme() {
        return this.scheme;
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        return new DERSequence(this.func, this.scheme);
    }
}
