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

package org.bouncycastle.asn1.cmp;

import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1OctetString;
import org.bouncycastle.asn1.x509.AlgorithmIdentifier;
import org.bouncycastle.asn1.ASN1Object;

public class KemCiphertextInfo extends ASN1Object
{
    private final AlgorithmIdentifier kem;
    private final ASN1OctetString ct;
    
    private KemCiphertextInfo(final ASN1Sequence asn1Sequence) {
        if (asn1Sequence.size() != 2) {
            throw new IllegalArgumentException("sequence size should 2");
        }
        this.kem = AlgorithmIdentifier.getInstance(asn1Sequence.getObjectAt(0));
        this.ct = ASN1OctetString.getInstance(asn1Sequence.getObjectAt(1));
    }
    
    public KemCiphertextInfo(final AlgorithmIdentifier kem, final ASN1OctetString ct) {
        this.kem = kem;
        this.ct = ct;
    }
    
    public static KemCiphertextInfo getInstance(final Object o) {
        if (o instanceof KemCiphertextInfo) {
            return (KemCiphertextInfo)o;
        }
        if (o != null) {
            return new KemCiphertextInfo(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    public AlgorithmIdentifier getKem() {
        return this.kem;
    }
    
    public ASN1OctetString getCt() {
        return this.ct;
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        return new DERSequence(this.kem, this.ct);
    }
}
