org.bouncycastle.pqc.jcajce.spec.KyberParameterSpec Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bcprov-jdk15to18 Show documentation
Show all versions of bcprov-jdk15to18 Show documentation
The Bouncy Castle Crypto package is a Java implementation of cryptographic algorithms. This jar contains JCE provider and lightweight API for the Bouncy Castle Cryptography APIs for JDK 1.5 to JDK 1.8.
package org.bouncycastle.pqc.jcajce.spec;
import java.security.spec.AlgorithmParameterSpec;
import java.util.HashMap;
import java.util.Map;
import org.bouncycastle.pqc.crypto.crystals.kyber.KyberParameters;
import org.bouncycastle.util.Strings;
public class KyberParameterSpec
implements AlgorithmParameterSpec
{
public static final KyberParameterSpec kyber512 = new KyberParameterSpec(KyberParameters.kyber512);
public static final KyberParameterSpec kyber768 = new KyberParameterSpec(KyberParameters.kyber768);
public static final KyberParameterSpec kyber1024 = new KyberParameterSpec(KyberParameters.kyber1024);
public static final KyberParameterSpec kyber512_aes = new KyberParameterSpec(KyberParameters.kyber512_aes);
public static final KyberParameterSpec kyber768_aes = new KyberParameterSpec(KyberParameters.kyber768_aes);
public static final KyberParameterSpec kyber1024_aes = new KyberParameterSpec(KyberParameters.kyber1024_aes);
private static Map parameters = new HashMap();
static
{
parameters.put("kyber512", kyber512);
parameters.put("kyber768", kyber768);
parameters.put("kyber1024", kyber1024);
parameters.put("kyber512-aes", kyber512_aes);
parameters.put("kyber768-aes", kyber768_aes);
parameters.put("kyber1024-aes", kyber1024_aes);
}
private final String name;
private KyberParameterSpec(KyberParameters parameters)
{
this.name = parameters.getName();
}
public String getName()
{
return name;
}
public static KyberParameterSpec fromName(String name)
{
return (KyberParameterSpec)parameters.get(Strings.toLowerCase(name));
}
}