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

package org.bouncycastle.asn1.pkcs;

import org.bouncycastle.asn1.DERNull;
import org.bouncycastle.internal.asn1.oiw.OIWObjectIdentifiers;
import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.DERTaggedObject;
import org.bouncycastle.asn1.ASN1EncodableVector;
import org.bouncycastle.asn1.ASN1Primitive;
import java.math.BigInteger;
import org.bouncycastle.asn1.ASN1TaggedObject;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.ASN1Integer;
import org.bouncycastle.asn1.x509.AlgorithmIdentifier;
import org.bouncycastle.asn1.ASN1Object;

public class RSASSAPSSparams extends ASN1Object
{
    private AlgorithmIdentifier hashAlgorithm;
    private AlgorithmIdentifier maskGenAlgorithm;
    private ASN1Integer saltLength;
    private ASN1Integer trailerField;
    public static final AlgorithmIdentifier DEFAULT_HASH_ALGORITHM;
    public static final AlgorithmIdentifier DEFAULT_MASK_GEN_FUNCTION;
    public static final ASN1Integer DEFAULT_SALT_LENGTH;
    public static final ASN1Integer DEFAULT_TRAILER_FIELD;
    
    public static RSASSAPSSparams getInstance(final Object o) {
        if (o instanceof RSASSAPSSparams) {
            return (RSASSAPSSparams)o;
        }
        if (o != null) {
            return new RSASSAPSSparams(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    public RSASSAPSSparams() {
        this.hashAlgorithm = RSASSAPSSparams.DEFAULT_HASH_ALGORITHM;
        this.maskGenAlgorithm = RSASSAPSSparams.DEFAULT_MASK_GEN_FUNCTION;
        this.saltLength = RSASSAPSSparams.DEFAULT_SALT_LENGTH;
        this.trailerField = RSASSAPSSparams.DEFAULT_TRAILER_FIELD;
    }
    
    public RSASSAPSSparams(final AlgorithmIdentifier hashAlgorithm, final AlgorithmIdentifier maskGenAlgorithm, final ASN1Integer saltLength, final ASN1Integer trailerField) {
        this.hashAlgorithm = hashAlgorithm;
        this.maskGenAlgorithm = maskGenAlgorithm;
        this.saltLength = saltLength;
        this.trailerField = trailerField;
    }
    
    private RSASSAPSSparams(final ASN1Sequence asn1Sequence) {
        this.hashAlgorithm = RSASSAPSSparams.DEFAULT_HASH_ALGORITHM;
        this.maskGenAlgorithm = RSASSAPSSparams.DEFAULT_MASK_GEN_FUNCTION;
        this.saltLength = RSASSAPSSparams.DEFAULT_SALT_LENGTH;
        this.trailerField = RSASSAPSSparams.DEFAULT_TRAILER_FIELD;
        for (int i = 0; i != asn1Sequence.size(); ++i) {
            final ASN1TaggedObject asn1TaggedObject = (ASN1TaggedObject)asn1Sequence.getObjectAt(i);
            switch (asn1TaggedObject.getTagNo()) {
                case 0: {
                    this.hashAlgorithm = AlgorithmIdentifier.getInstance(asn1TaggedObject, true);
                    break;
                }
                case 1: {
                    this.maskGenAlgorithm = AlgorithmIdentifier.getInstance(asn1TaggedObject, true);
                    break;
                }
                case 2: {
                    this.saltLength = ASN1Integer.getInstance(asn1TaggedObject, true);
                    break;
                }
                case 3: {
                    this.trailerField = ASN1Integer.getInstance(asn1TaggedObject, true);
                    break;
                }
                default: {
                    throw new IllegalArgumentException("unknown tag");
                }
            }
        }
    }
    
    public AlgorithmIdentifier getHashAlgorithm() {
        return this.hashAlgorithm;
    }
    
    public AlgorithmIdentifier getMaskGenAlgorithm() {
        return this.maskGenAlgorithm;
    }
    
    public BigInteger getSaltLength() {
        return this.saltLength.getValue();
    }
    
    public BigInteger getTrailerField() {
        return this.trailerField.getValue();
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        final ASN1EncodableVector asn1EncodableVector = new ASN1EncodableVector(4);
        if (!this.hashAlgorithm.equals(RSASSAPSSparams.DEFAULT_HASH_ALGORITHM)) {
            asn1EncodableVector.add(new DERTaggedObject(true, 0, this.hashAlgorithm));
        }
        if (!this.maskGenAlgorithm.equals(RSASSAPSSparams.DEFAULT_MASK_GEN_FUNCTION)) {
            asn1EncodableVector.add(new DERTaggedObject(true, 1, this.maskGenAlgorithm));
        }
        if (!this.saltLength.equals(RSASSAPSSparams.DEFAULT_SALT_LENGTH)) {
            asn1EncodableVector.add(new DERTaggedObject(true, 2, this.saltLength));
        }
        if (!this.trailerField.equals(RSASSAPSSparams.DEFAULT_TRAILER_FIELD)) {
            asn1EncodableVector.add(new DERTaggedObject(true, 3, this.trailerField));
        }
        return new DERSequence(asn1EncodableVector);
    }
    
    static {
        DEFAULT_HASH_ALGORITHM = new AlgorithmIdentifier(OIWObjectIdentifiers.idSHA1, DERNull.INSTANCE);
        DEFAULT_MASK_GEN_FUNCTION = new AlgorithmIdentifier(PKCSObjectIdentifiers.id_mgf1, RSASSAPSSparams.DEFAULT_HASH_ALGORITHM);
        DEFAULT_SALT_LENGTH = new ASN1Integer(20L);
        DEFAULT_TRAILER_FIELD = new ASN1Integer(1L);
    }
}
