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

package org.bouncycastle.asn1.pkcs;

import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.DEROctetString;
import org.bouncycastle.util.Arrays;
import java.util.Enumeration;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1OctetString;
import org.bouncycastle.asn1.x509.AlgorithmIdentifier;
import org.bouncycastle.asn1.ASN1Object;

public class EncryptedPrivateKeyInfo extends ASN1Object
{
    private AlgorithmIdentifier algId;
    private ASN1OctetString data;
    
    private EncryptedPrivateKeyInfo(final ASN1Sequence asn1Sequence) {
        final Enumeration objects = asn1Sequence.getObjects();
        this.algId = AlgorithmIdentifier.getInstance(objects.nextElement());
        this.data = ASN1OctetString.getInstance(objects.nextElement());
    }
    
    public EncryptedPrivateKeyInfo(final AlgorithmIdentifier algId, final byte[] array) {
        this.algId = algId;
        this.data = new DEROctetString(Arrays.clone(array));
    }
    
    public static EncryptedPrivateKeyInfo getInstance(final Object o) {
        if (o instanceof EncryptedPrivateKeyInfo) {
            return (EncryptedPrivateKeyInfo)o;
        }
        if (o != null) {
            return new EncryptedPrivateKeyInfo(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    public AlgorithmIdentifier getEncryptionAlgorithm() {
        return this.algId;
    }
    
    public byte[] getEncryptedData() {
        return Arrays.clone(this.data.getOctets());
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        return new DERSequence(this.algId, this.data);
    }
}
