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

package org.bouncycastle.asn1.tsp;

import org.bouncycastle.asn1.DLSequence;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.ASN1TaggedObject;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1ObjectIdentifier;
import org.bouncycastle.asn1.ASN1Object;

public class EncryptionInfo extends ASN1Object
{
    private ASN1ObjectIdentifier encryptionInfoType;
    private ASN1Encodable encryptionInfoValue;
    
    @Deprecated
    public static EncryptionInfo getInstance(final ASN1Object asn1Object) {
        return getInstance((Object)asn1Object);
    }
    
    public static EncryptionInfo getInstance(final Object o) {
        if (o instanceof EncryptionInfo) {
            return (EncryptionInfo)o;
        }
        if (o != null) {
            return new EncryptionInfo(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    public static EncryptionInfo getInstance(final ASN1TaggedObject asn1TaggedObject, final boolean b) {
        return getInstance((Object)ASN1Sequence.getInstance(asn1TaggedObject, b));
    }
    
    private EncryptionInfo(final ASN1Sequence asn1Sequence) {
        if (asn1Sequence.size() != 2) {
            throw new IllegalArgumentException("wrong sequence size in constructor: " + asn1Sequence.size());
        }
        this.encryptionInfoType = ASN1ObjectIdentifier.getInstance(asn1Sequence.getObjectAt(0));
        this.encryptionInfoValue = asn1Sequence.getObjectAt(1);
    }
    
    public EncryptionInfo(final ASN1ObjectIdentifier encryptionInfoType, final ASN1Encodable encryptionInfoValue) {
        this.encryptionInfoType = encryptionInfoType;
        this.encryptionInfoValue = encryptionInfoValue;
    }
    
    public ASN1ObjectIdentifier getEncryptionInfoType() {
        return this.encryptionInfoType;
    }
    
    public ASN1Encodable getEncryptionInfoValue() {
        return this.encryptionInfoValue;
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        return new DLSequence(this.encryptionInfoType, this.encryptionInfoValue);
    }
}
