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

package org.bouncycastle.asn1.cms;

import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.ASN1TaggedObject;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.DERBitString;
import org.bouncycastle.asn1.ASN1BitString;
import org.bouncycastle.asn1.x509.AlgorithmIdentifier;
import org.bouncycastle.asn1.ASN1Object;

public class OriginatorPublicKey extends ASN1Object
{
    private AlgorithmIdentifier algorithm;
    private ASN1BitString publicKey;
    
    public OriginatorPublicKey(final AlgorithmIdentifier algorithm, final byte[] array) {
        this.algorithm = algorithm;
        this.publicKey = new DERBitString(array);
    }
    
    public OriginatorPublicKey(final AlgorithmIdentifier algorithm, final ASN1BitString publicKey) {
        this.algorithm = algorithm;
        this.publicKey = publicKey;
    }
    
    private OriginatorPublicKey(final ASN1Sequence asn1Sequence) {
        this.algorithm = AlgorithmIdentifier.getInstance(asn1Sequence.getObjectAt(0));
        this.publicKey = (DERBitString)asn1Sequence.getObjectAt(1);
    }
    
    public static OriginatorPublicKey getInstance(final ASN1TaggedObject asn1TaggedObject, final boolean b) {
        return new OriginatorPublicKey(ASN1Sequence.getInstance(asn1TaggedObject, b));
    }
    
    public static OriginatorPublicKey getInstance(final Object o) {
        if (o instanceof OriginatorPublicKey) {
            return (OriginatorPublicKey)o;
        }
        if (o != null) {
            return new OriginatorPublicKey(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    public AlgorithmIdentifier getAlgorithm() {
        return this.algorithm;
    }
    
    @Deprecated
    public DERBitString getPublicKey() {
        return DERBitString.convert(this.publicKey);
    }
    
    public ASN1BitString getPublicKeyData() {
        return this.publicKey;
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        return new DERSequence(this.algorithm, this.publicKey);
    }
}
