Package net.naijatek.myalumni.framework.struts

Source Code of net.naijatek.myalumni.framework.struts.MyAlumniExceptionHandler

/*
* ====================================================================
* Copyright (C) 1997-2008 by Naijatek.com
*
* All copyright notices regarding MyAlumni MUST remain
* intact in the scripts and in the outputted HTML.
* The "powered by" text/logo with a link back to
* http://www.naijatek.com in
* the footer of the pages MUST remain visible when the pages
* are viewed on the internet or intranet.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*
* Support can be obtained from support forums at:
* http://www.naijatek.com/myalumni/forum
*
* Correspondence and Marketing Questions can be sent to:
* info at naijatek com
*
* <p>Title: MyAlumni </p>
* <p>Description: This system helps keep alive the line of communications between alumni/alumnus</p>
* <p>Copyright: Copyright (c) 1997-2008</p>
* <p>Company: Naijatek Solutions (http://www.naijatek.com)</p>
* @author Folashade Adeyosoye (shardayyy@naijatek.com)
* @version 1.0
*/
package net.naijatek.myalumni.framework.struts;


import java.util.Date;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import net.naijatek.myalumni.modules.common.domain.ErrorLogVO;
import net.naijatek.myalumni.modules.common.service.IErrorLogService;
import net.naijatek.myalumni.util.BaseConstants;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.struts.Globals;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.action.ActionMessage;
import org.apache.struts.action.ActionMessages;
import org.apache.struts.action.ExceptionHandler;
import org.apache.struts.config.ExceptionConfig;
import org.apache.struts.util.ModuleException;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.WebApplicationContextUtils;

/**
* Implementation of <strong>ExceptionHandler</strong> that handles any
* Exceptions that are bundles up to_email the Action layer. This allows us
* to_email gracelly handle any exception that Action classes do not catch.
*
* @author Folashade
* @version 1.0
*/
public final class MyAlumniExceptionHandler extends ExceptionHandler {

  private static Log logger = LogFactory.getLog(MyAlumniExceptionHandler.class);

  /**
   * This method handles any java.lang.Exceptions that are not caught in
   * previous classes. It will loop through and get all the causes (exception
   * chain), create ActionErrors, add them to_email the request and then
   * forward to_email the input.
   *
   * @see org.apache.struts.action.ExceptionHandler#execute()
   *      java.lang.Exception, org.apache.struts.config.ExceptionConfig,
   *      org.apache.struts.action.ActionMapping,
   *      org.apache.struts.action.ActionForm,
   *      javax.servlet.http.HttpServletRequest,
   *      javax.servlet.http.HttpServletResponse )
   *
   * @param ex
   *            Exception
   * @param ae
   *            ExceptionConfig
   * @param mapping
   *            ActionMapping
   * @param form
   *            ActionForm
   * @param request
   *            HttpServletRequest
   * @param response
   *            HttpServletResponse
   * @throws ServletException
   * @return ActionForward
   */
  public ActionForward execute(Exception ex, ExceptionConfig ae,
      ActionMapping mapping, ActionForm form, HttpServletRequest request,
      HttpServletResponse response) throws ServletException {   
   
    ActionMessages messages = new ActionMessages();
   
    // This is where it was suppose to forward to in the first place.
    ActionForward forward = super.execute(ex, ae, mapping, form, request, response);
   
    ServletContext sCtx = request.getSession().getServletContext();
      WebApplicationContext wac = WebApplicationContextUtils.getWebApplicationContext(sCtx);
      IErrorLogService loggerService = (IErrorLogService) wac.getBean(BaseConstants.SERVICE_ERRORLOGGER_LOOKUP);
     
    String forwardKey = new String();
    Integer statusCode = (Integer) request.getAttribute("javax.servlet.error.status_code");

    Throwable thr = (Throwable)request.getAttribute("javax.servlet.error.exception");
    StringBuffer strBuffer = new StringBuffer();
   
    if (thr != null){
      StackTraceElement[] stack = thr.getStackTrace();
      for(int n = 0; n < stack.length; n++) {
        strBuffer.append(stack[n].toString());
        strBuffer.append("\n");
      }  
    }
      
    //String messg = (String) request.getAttribute("javax.servlet.error.message");
    String messg = (String) ex.getMessage();
    messg = (messg != null && messg.length() >= 4000) ? messg.substring(0,3999) : messg;
   
    String trace = strBuffer.toString();
    trace = (trace != null && trace.length() >= 4000) ? trace.substring(0,3999) : trace;
   
    //String cause = (String) request.getAttribute("javax.servlet.error.request_uri");
    String cause =  new String();
    if (ex.getCause() != null)
      cause = ex.getCause().toString();

   
    String userName = new String();

    try {
      MyAlumniUserContainer sessionObj = null;
      HttpSession session = request.getSession(false);
      if (session != null) {
        sessionObj = (MyAlumniUserContainer) session.getAttribute(BaseConstants.USER_CONTAINER);
        userName = sessionObj.getToken().getMemberUserName();
      }
    } catch (Exception npe) {
      // do nothing
      userName = "";
    }

    ErrorLogVO errorLog = new ErrorLogVO();
    errorLog.setErrorDate(new Date());
    errorLog.setLoggedBy(userName);
    errorLog.setLastModifiedBy(userName);
    errorLog.setErrorMessage(messg);
    errorLog.setCause(cause);
    errorLog.setTrace(trace);

    loggerService.addErrorLog(errorLog);

 
        // 700: Insufficient Priviledges
        // 701: Session Timed Out
       
        if (statusCode != null) {
            int sc = ((Integer) statusCode).intValue();           
           
            switch (sc) {           
              case 700:
                  forwardKey = BaseConstants.SC_INSURFICIENT_PRIV_700;
                  messages.add(BaseConstants.FATAL_KEY, new ActionMessage("core.errorcode.00701"));
                  storeException(request, BaseConstants.FATAL_KEY, new ActionMessage("core.errorcode.00701"), forward);
                  break;
             
              case 701:
                  forwardKey = BaseConstants.SC_SESSION_EXPIRED_701;
                  messages.add(BaseConstants.FATAL_KEY, new ActionMessage("core.errorcode.00702"));
                  storeException(request, BaseConstants.FATAL_KEY, new ActionMessage("core.errorcode.00702"), forward);
                  break;
                 
            }           
        }
       
       
        if (forwardKey != null && forwardKey.length() == 0){
        String requestPathInfo = request.getPathInfo(); // request path info.
             
              if (requestPathInfo != null && requestPathInfo.startsWith("/admin/")){
                forwardKey = BaseConstants.FWD_ADMIN;
                  messages.add(BaseConstants.FATAL_KEY, new ActionMessage("core.errorcode.00703"));
                  storeException(request, BaseConstants.FATAL_KEY, new ActionMessage("core.errorcode.00703"), forward);
              }
              else if (requestPathInfo != null && requestPathInfo.startsWith("/member/")){
                forwardKey = BaseConstants.FWD_MEMBER;
                  messages.add(BaseConstants.FATAL_KEY, new ActionMessage("core.errorcode.00704"));
                  storeException(request, BaseConstants.FATAL_KEY, new ActionMessage("core.errorcode.00704"), forward);
              }
              else{
                forwardKey = BaseConstants.FWD_MEMBER;
                  messages.add(BaseConstants.FATAL_KEY, new ActionMessage("core.errorcode.00703"));
                  storeException(request, BaseConstants.FATAL_KEY, new ActionMessage("core.errorcode.00703"), forward);
              }
        }

        return mapping.findForward(forwardKey);
  }

  /**
   * This method overrides the the ExceptionHandler's storeException method in
   * order to_email create more than one error message.
   *
   * @param request -
   *            The request we are handling
   * @param property -
   *            The property name to_email use for this error
   * @param error -
   *            The error generated from_email the exception mapping
   * @param forward -
   *            The forward generated from_email the input path (from_email
   *            the form or exception mapping)
   */
  void storeException(HttpServletRequest request, String property,
      ActionMessage error, ActionForward forward) {
    ActionMessages errors = (ActionMessages) request
        .getAttribute(Globals.ERROR_KEY);

    if (errors == null) {
      errors = new ActionMessages();
    }

    errors.add(property, error);

    request.setAttribute(Globals.ERROR_KEY, errors);
  }

}
TOP

Related Classes of net.naijatek.myalumni.framework.struts.MyAlumniExceptionHandler

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.