/* See LICENSE for licensing and NOTICE for copyright. */
package org.ldaptive.ssl;
import java.io.IOException;
import java.io.InputStream;
import java.security.GeneralSecurityException;
import java.security.cert.CertificateFactory;
import java.security.cert.X509Certificate;
/**
* Loads an X.509 certificate credential from a classpath, filepath, or stream resource. Supported certificate formats
* include: PEM, DER, and PKCS7.
*
* @author Middleware Services
*/
public class X509CertificateCredentialReader extends AbstractCredentialReader<X509Certificate>
{
@Override
public X509Certificate read(final InputStream is, final String... params)
throws IOException, GeneralSecurityException
{
final CertificateFactory cf = CertificateFactory.getInstance("X.509");
return (X509Certificate) cf.generateCertificate(getBufferedInputStream(is));
}
}