All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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