All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bouncycastle.pqc.jcajce.spec.FrodoParameterSpec Maven / Gradle / Ivy

Go to download

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.

There is a newer version: 1.79
Show newest version
package org.bouncycastle.pqc.jcajce.spec;

import java.security.spec.AlgorithmParameterSpec;
import java.util.HashMap;
import java.util.Map;

import org.bouncycastle.pqc.crypto.frodo.FrodoParameters;
import org.bouncycastle.util.Strings;

public class FrodoParameterSpec
    implements AlgorithmParameterSpec
{
    public static final FrodoParameterSpec frodokem640aes = new FrodoParameterSpec(FrodoParameters.frodokem640aes);
    public static final FrodoParameterSpec frodokem640shake = new FrodoParameterSpec(FrodoParameters.frodokem640shake);
    public static final FrodoParameterSpec frodokem976aes = new FrodoParameterSpec(FrodoParameters.frodokem976aes);
    public static final FrodoParameterSpec frodokem976shake = new FrodoParameterSpec(FrodoParameters.frodokem976shake);
    public static final FrodoParameterSpec frodokem1344aes = new FrodoParameterSpec(FrodoParameters.frodokem1344aes);
    public static final FrodoParameterSpec frodokem1344shake = new FrodoParameterSpec(FrodoParameters.frodokem1344shake);

    private static Map parameters = new HashMap();

    static
    {
        // old parameter names.
        parameters.put("frodokem19888r3", frodokem640aes);
        parameters.put("frodokem19888shaker3", frodokem640shake);
        parameters.put("frodokem31296r3", frodokem976aes);
        parameters.put("frodokem31296shaker3", frodokem976shake);
        parameters.put("frodokem43088r3", frodokem1344aes);
        parameters.put("frodokem43088shaker3", frodokem1344shake);
        // frodo scheme names
        parameters.put("frodokem640aes", frodokem640aes);
        parameters.put("frodokem640shake", frodokem640shake);
        parameters.put("frodokem976aes", frodokem976aes);
        parameters.put("frodokem976shake", frodokem976shake);
        parameters.put("frodokem1344aes", frodokem1344aes);
        parameters.put("frodokem1344shake", frodokem1344shake);
    }

    private final String name;

    private FrodoParameterSpec(FrodoParameters parameters)
    {
        this.name = parameters.getName();
    }

    public String getName()
    {
        return name;
    }

    public static FrodoParameterSpec fromName(String name)
    {
        return (FrodoParameterSpec) parameters.get(Strings.toLowerCase(name));
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy