Java tutorial
package org.bouncycastle.jcajce.provider.config; import java.util.Map; import org.bouncycastle.asn1.ASN1ObjectIdentifier; import org.bouncycastle.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<String, String> attributeMap); }