edu.vt.middleware.ldap.ssl.X509CredentialConfig Maven / Gradle / Ivy
/*
$Id$
Copyright (C) 2003-2010 Virginia Tech.
All rights reserved.
SEE LICENSE FOR MORE INFORMATION
Author: Middleware Services
Email: [email protected]
Version: $Revision$
Updated: $Date$
*/
package edu.vt.middleware.ldap.ssl;
import java.io.IOException;
import java.security.GeneralSecurityException;
/**
* Provides the properties necessary for creating an SSL context initializer
* with a X509CredentialReader
.
*
* @author Middleware Services
* @version $Revision: 1106 $ $Date: 2010-01-29 23:34:13 -0500 (Fri, 29 Jan 2010) $
*/
public class X509CredentialConfig implements CredentialConfig
{
/** Reads X.509 certificates credential. */
protected X509CertificatesCredentialReader certsReader =
new X509CertificatesCredentialReader();
/** Reads X.509 certificate credential. */
protected X509CertificateCredentialReader certReader =
new X509CertificateCredentialReader();
/** Reads private key credential. */
protected PrivateKeyCredentialReader keyReader =
new PrivateKeyCredentialReader();
/** Name of the trust certificates to use for the SSL connection. */
private String trustCertificates;
/** Name of the authentication certificate to use for the SSL connection. */
private String authenticationCertificate;
/** Name of the key to use for the SSL connection. */
private String authenticationKey;
/**
* This returns the name of the trust certificates to use.
*
* @return String
trust certificates name
*/
public String getTrustCertificates()
{
return this.trustCertificates;
}
/**
* This sets the name of the trust certificates to use.
*
* @param s String
trust certificates name
*/
public void setTrustCertificates(final String s)
{
this.trustCertificates = s;
}
/**
* This returns the name of the authentication certificate to use.
*
* @return String
authentication certificate name
*/
public String getAuthenticationCertificate()
{
return this.authenticationCertificate;
}
/**
* This sets the name of the authentication certificate to use.
*
* @param s String
authentication certificate name
*/
public void setAuthenticationCertificate(final String s)
{
this.authenticationCertificate = s;
}
/**
* This returns the name of the authentication key to use.
*
* @return String
authentication key name
*/
public String getAuthenticationKey()
{
return this.authenticationKey;
}
/**
* This sets the name of the authentication key to use.
*
* @param s String
authentication key name
*/
public void setAuthenticationKey(final String s)
{
this.authenticationKey = s;
}
/** {@inheritDoc} */
public SSLContextInitializer createSSLContextInitializer()
throws GeneralSecurityException
{
final X509SSLContextInitializer sslInit = new X509SSLContextInitializer();
try {
if (this.trustCertificates != null) {
sslInit.setTrustCertificates(
this.certsReader.read(this.trustCertificates));
}
if (this.authenticationCertificate != null) {
sslInit.setAuthenticationCertificate(
this.certReader.read(this.authenticationCertificate));
}
if (this.authenticationKey != null) {
sslInit.setAuthenticationKey(
this.keyReader.read(this.authenticationKey));
}
} catch (IOException e) {
throw new GeneralSecurityException(e);
}
return sslInit;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy