org.spongycastle.jcajce.provider.config.ConfigurableProvider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of prov Show documentation
Show all versions of prov Show documentation
Spongy Castle is a package-rename (org.bouncycastle.* to org.spongycastle.*) of Bouncy Castle
intended for the Android platform. Android unfortunately ships with a stripped-down version of
Bouncy Castle, which prevents easy upgrades - Spongy Castle overcomes this and provides a full,
up-to-date version of the Bouncy Castle cryptographic libs.
The newest version!
package org.spongycastle.jcajce.provider.config;
import java.util.Map;
import org.spongycastle.asn1.ASN1ObjectIdentifier;
import org.spongycastle.jcajce.provider.util.AsymmetricKeyInfoConverter;
/**
* Implemented by the BC provider. This allows setting of hidden parameters,
* such as the ImplicitCA parameters from X.962, if used.
*/
public interface ConfigurableProvider
{
/**
* Elliptic Curve CA parameters - thread local version
*/
static final String THREAD_LOCAL_EC_IMPLICITLY_CA = "threadLocalEcImplicitlyCa";
/**
* Elliptic Curve CA parameters - VM wide version
*/
static final String EC_IMPLICITLY_CA = "ecImplicitlyCa";
/**
* Diffie-Hellman Default Parameters - thread local version
*/
static final String THREAD_LOCAL_DH_DEFAULT_PARAMS = "threadLocalDhDefaultParams";
/**
* Diffie-Hellman Default Parameters - VM wide version
*/
static final String DH_DEFAULT_PARAMS = "DhDefaultParams";
/**
* A set of OBJECT IDENTIFIERs representing acceptable named curves for imported keys.
*/
static final String ACCEPTABLE_EC_CURVES = "acceptableEcCurves";
/**
* A set of OBJECT IDENTIFIERs to EC Curves providing local curve name mapping.
*/
static final String ADDITIONAL_EC_PARAMETERS = "additionalEcParameters";
void setParameter(String parameterName, Object parameter);
void addAlgorithm(String key, String value);
void addAlgorithm(String type, ASN1ObjectIdentifier oid, String className);
boolean hasAlgorithm(String type, String name);
void addKeyInfoConverter(ASN1ObjectIdentifier oid, AsymmetricKeyInfoConverter keyInfoConverter);
void addAttributes(String key, Map attributeMap);
}