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

edu.vt.middleware.ldap.servlets.CommonServlet Maven / Gradle / Ivy

/*
  $Id: CommonServlet.java 1330 2010-05-23 22:10:53Z dfisher $

  Copyright (C) 2003-2010 Virginia Tech.
  All rights reserved.

  SEE LICENSE FOR MORE INFORMATION

  Author:  Middleware Services
  Email:   [email protected]
  Version: $Revision: 1330 $
  Updated: $Date: 2010-05-23 18:10:53 -0400 (Sun, 23 May 2010) $
*/
package edu.vt.middleware.ldap.servlets;

import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import edu.vt.middleware.ldap.servlets.session.SessionManager;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

/**
 * CommonServlet contains common code that each servlet uses to
 * initialize itself.
 *
 * @author  Middleware Services
 * @version  $Revision: 1330 $ $Date: 2010-05-23 18:10:53 -0400 (Sun, 23 May 2010) $
 */
public class CommonServlet extends HttpServlet
{

  /** serial version uid. */
  private static final long serialVersionUID = -2580419817969949661L;

  /** Log for this class. */
  protected final Log logger = LogFactory.getLog(this.getClass());

  /** Used to manage a session after login and logout. */
  protected SessionManager sessionManager;


  /**
   * Initialize this servlet.
   *
   * @param  config  ServletConfig
   *
   * @throws  ServletException  if an error occurs
   */
  public void init(final ServletConfig config)
    throws ServletException
  {
    super.init(config);

    String sessionManagerClass = getInitParameter(
      ServletConstants.SESSION_MANAGER);
    if (sessionManagerClass == null) {
      sessionManagerClass = ServletConstants.DEFAULT_SESSION_MANAGER;
    }
    if (this.logger.isDebugEnabled()) {
      this.logger.debug(
        ServletConstants.SESSION_MANAGER + " = " + sessionManagerClass);
    }
    try {
      this.sessionManager = (SessionManager) Class.forName(sessionManagerClass)
          .newInstance();
    } catch (ClassNotFoundException e) {
      if (this.logger.isErrorEnabled()) {
        this.logger.error("Could not find class " + sessionManagerClass, e);
      }
      throw new ServletException(e);
    } catch (InstantiationException e) {
      if (this.logger.isErrorEnabled()) {
        this.logger.error(
          "Could not instantiate class " + sessionManagerClass,
          e);
      }
      throw new ServletException(e);
    } catch (IllegalAccessException e) {
      if (this.logger.isErrorEnabled()) {
        this.logger.error("Could not access class " + sessionManagerClass, e);
      }
      throw new ServletException(e);
    }

    String sessionId = getInitParameter(ServletConstants.SESSION_ID);
    if (sessionId == null) {
      sessionId = ServletConstants.DEFAULT_SESSION_ID;
    }
    if (this.logger.isDebugEnabled()) {
      this.logger.debug(ServletConstants.SESSION_ID + " = " + sessionId);
    }
    this.sessionManager.setSessionId(sessionId);


    String invalidateSession = getInitParameter(
      ServletConstants.INVALIDATE_SESSION);
    if (invalidateSession == null) {
      invalidateSession = ServletConstants.DEFAULT_INVALIDATE_SESSION;
    }
    if (this.logger.isDebugEnabled()) {
      this.logger.debug(
        ServletConstants.INVALIDATE_SESSION + " = " + invalidateSession);
    }
    this.sessionManager.setInvalidateSession(
      Boolean.valueOf(invalidateSession).booleanValue());
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy