edu.vt.middleware.ldap.ssl.KeyStoreSSLContextInitializer 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.security.GeneralSecurityException;
import java.security.KeyStore;
import javax.net.ssl.KeyManager;
import javax.net.ssl.KeyManagerFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.TrustManagerFactory;
/**
* Provides a SSLContextInitializer
which can use java KeyStores to
* create key and trust managers.
*
* @author Middleware Services
* @version $Revision: 1106 $ $Date: 2010-01-29 23:34:13 -0500 (Fri, 29 Jan 2010) $
*/
public class KeyStoreSSLContextInitializer extends AbstractSSLContextInitializer
{
/** KeyStore used to create trust managers. */
private KeyStore trustKeystore;
/** KeyStore used to create key managers. */
private KeyStore authenticationKeystore;
/** Password used to access the authentication keystore. */
private char[] authenticationPassword;
/**
* Sets the keystore to use for creating the trust managers.
*
* @param ks KeyStore
*/
public void setTrustKeystore(final KeyStore ks)
{
this.trustKeystore = ks;
}
/**
* Sets the keystore to use for creating the key managers.
*
* @param ks KeyStore
*/
public void setAuthenticationKeystore(final KeyStore ks)
{
this.authenticationKeystore = ks;
}
/**
* Sets the password used for accessing the authentication keystore.
*
* @param password char[]
*/
public void setAuthenticationPassword(final char[] password)
{
this.authenticationPassword = password;
}
/** {@inheritDoc} */
public TrustManager[] getTrustManagers()
throws GeneralSecurityException
{
TrustManager[] tm = null;
if (this.trustKeystore != null) {
final TrustManagerFactory tmf = TrustManagerFactory.getInstance(
TrustManagerFactory.getDefaultAlgorithm());
tmf.init(this.trustKeystore);
tm = tmf.getTrustManagers();
}
return tm;
}
/** {@inheritDoc} */
public KeyManager[] getKeyManagers()
throws GeneralSecurityException
{
KeyManager[] km = null;
if (
this.authenticationKeystore != null &&
this.authenticationPassword != null) {
final KeyManagerFactory kmf = KeyManagerFactory.getInstance(
KeyManagerFactory.getDefaultAlgorithm());
kmf.init(this.authenticationKeystore, this.authenticationPassword);
km = kmf.getKeyManagers();
}
return km;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy