package org.bouncycastle.asn1.pkcs; import java.math.BigInteger; import java.util.Enumeration; import org.bouncycastle.asn1.ASN1EncodableVector; import org.bouncycastle.asn1.ASN1OctetString; import org.bouncycastle.asn1.ASN1Sequence; import org.bouncycastle.asn1.DERInteger; import org.bouncycastle.asn1.DERObject; import org.bouncycastle.asn1.DERObjectIdentifier; import org.bouncycastle.asn1.DERSequence; public class PBKDF2Params extends KeyDerivationFunc { DERObjectIdentifier id; ASN1OctetString octStr; DERInteger iterationCount; DERInteger keyLength; PBKDF2Params( ASN1Sequence seq) { super(seq); Enumeration e = seq.getObjects(); id = (DERObjectIdentifier)e.nextElement(); ASN1Sequence params = (ASN1Sequence)e.nextElement(); e = params.getObjects(); octStr = (ASN1OctetString)e.nextElement(); iterationCount = (DERInteger)e.nextElement(); if (e.hasMoreElements()) { keyLength = (DERInteger)e.nextElement(); } else { keyLength = null; } } public byte[] getSalt() { return octStr.getOctets(); } public BigInteger getIterationCount() { return iterationCount.getValue(); } public BigInteger getKeyLength() { if (keyLength != null) { return keyLength.getValue(); } return null; } public DERObject getDERObject() { ASN1EncodableVector v = new ASN1EncodableVector(); ASN1EncodableVector subV = new ASN1EncodableVector(); v.add(id); subV.add(octStr); subV.add(iterationCount); if (keyLength != null) { subV.add(keyLength); } v.add(new DERSequence(subV)); return new DERSequence(v); } }