FileDocCategorySizeDatePackage
CertPathBuilderSpi.javaAPI DocJava SE 5 API2221Fri Aug 26 14:57:16 BST 2005java.security.cert

CertPathBuilderSpi.java

/*
 * @(#)CertPathBuilderSpi.java	1.5 03/12/19
 *
 * Copyright 2004 Sun Microsystems, Inc. All rights reserved.
 * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
 */

package java.security.cert;

import java.security.InvalidAlgorithmParameterException;

/**
 * The <i>Service Provider Interface</i> (<b>SPI</b>) 
 * for the {@link CertPathBuilder CertPathBuilder} class. All 
 * <code>CertPathBuilder</code> implementations must include a class (the 
 * SPI class) that extends this class (<code>CertPathBuilderSpi</code>) and 
 * implements all of its methods. In general, instances of this class should 
 * only be accessed through the <code>CertPathBuilder</code> class. For 
 * details, see the Java Cryptography Architecture. 
 * <p>
 * <b>Concurrent Access</b>
 * <p>
 * Instances of this class need not be protected against concurrent
 * access from multiple threads. Threads that need to access a single
 * <code>CertPathBuilderSpi</code> instance concurrently should synchronize
 * amongst themselves and provide the necessary locking before calling the
 * wrapping <code>CertPathBuilder</code> object.
 * <p>
 * However, implementations of <code>CertPathBuilderSpi</code> may still
 * encounter concurrency issues, since multiple threads each
 * manipulating a different <code>CertPathBuilderSpi</code> instance need not
 * synchronize.
 *
 * @version 	1.5 12/19/03
 * @since	1.4
 * @author	Sean Mullan
 */
public abstract class CertPathBuilderSpi {

    /**
     * The default constructor.
     */
    public CertPathBuilderSpi() { }

    /**
     * Attempts to build a certification path using the specified 
     * algorithm parameter set.
     *
     * @param params the algorithm parameters
     * @return the result of the build algorithm
     * @throws CertPathBuilderException if the builder is unable to construct 
     * a certification path that satisfies the specified parameters
     * @throws InvalidAlgorithmParameterException if the specified parameters 
     * are inappropriate for this <code>CertPathBuilder</code>
     */
    public abstract CertPathBuilderResult engineBuild(CertPathParameters params)
	throws CertPathBuilderException, InvalidAlgorithmParameterException;
}